Merge branch 'release' of gitee.com:starlock-cn/app-starlock into release

This commit is contained in:
Daisy 2024-05-22 10:41:49 +08:00
commit e8fa6b5856
8 changed files with 304 additions and 275 deletions

View File

@ -608,7 +608,7 @@
"卡详情": "Card details",
"请输入": "Please enter",
"关闭后,智能锁将设置为全天常开模式,直到手动关闭": "After closing, the smart lock will be set to all-day open mode until manually closed",
"请输入小于1000的数字": "Please enter a number less than 1000",
"请输入小于或等于60的数字": "Please enter a number less than 60",
"操作成功": "Operation success",
"管理员密码相同,无需修改": "The administrator password is the same and does not need to be modified",
"修改密码": "Modify password",

View File

@ -633,7 +633,7 @@
"卡详情": "卡详情",
"请输入": "请输入",
"关闭后,智能锁将设置为全天常开模式,直到手动关闭": "关闭后,智能锁将设置为全天常开模式,直到手动关闭",
"请输入小于1000的数字": "请输入小于1000的数字",
"请输入小于或等于60的数字": "请输入小于或等于60的数字",
"操作成功": "操作成功",
"管理员密码相同,无需修改": "管理员密码相同,无需修改",
"修改密码": "修改密码",

View File

@ -608,7 +608,7 @@
"卡详情": "卡详情",
"请输入": "请输入",
"关闭后,智能锁将设置为全天常开模式,直到手动关闭": "关闭后,智能锁将设置为全天常开模式,直到手动关闭",
"请输入小于1000的数字": "请输入小于1000的数字",
"请输入小于或等于60的数字": "请输入小于或等于60的数字",
"操作成功": "操作成功",
"管理员密码相同,无需修改": "管理员密码相同,无需修改",
"修改密码": "修改密码",

View File

@ -1,9 +1,10 @@
import 'dart:async';
import 'package:flutter_blue_plus/flutter_blue_plus.dart';
import 'package:flutter_easyloading/flutter_easyloading.dart';
import 'package:get/get.dart';
import 'package:star_lock/blue/io_protocol/io_setSupportFunctionsWithParameters.dart';
import 'package:star_lock/login/login/entity/LoginEntity.dart';
import 'package:star_lock/tools/baseGetXController.dart';
import '../../../../blue/blue_manage.dart';
import '../../../../blue/io_reply.dart';
@ -15,47 +16,50 @@ import '../../../../tools/eventBusEventManage.dart';
import '../../../../tools/storage.dart';
import 'automaticBlocking_state.dart';
class AutomaticBlockingLogic extends BaseGetXController{
class AutomaticBlockingLogic extends BaseGetXController {
final AutomaticBlockingState state = AutomaticBlockingState();
void setAutoUnLock() async{
Future<void> setAutoUnLock() async {
String autoTime;
if(state.isOpen.value == false){
autoTime = "0";
}else{
if(state.isCustomLockTime.value == true){
if (state.isOpen.value == false) {
autoTime = '0';
} else {
if (state.isCustomLockTime.value == true) {
autoTime = state.timeController.text;
if(int.parse(autoTime) >= 1000){
showToast("请输入小于1000的数字".tr);
if (int.parse(autoTime) > 60) {
showToast('请输入小于或等于60的数字'.tr);
return;
}
}else{
} else {
autoTime = state.autoLockTime.value;
}
}
var entity = await ApiRepository.to.setAutoUnlock(
lockId: state.lockSetInfoData.value.lockId!,
autoLock:state.isOpen.value == true ? 1 : 0,
autoLockSecond: int.parse(autoTime),
final LoginEntity entity = await ApiRepository.to.setAutoUnlock(
lockId: state.lockSetInfoData.value.lockId!,
autoLock: state.isOpen.value == true ? 1 : 0,
autoLockSecond: int.parse(autoTime),
);
if(entity.errorCode!.codeIsSuccessful){
if (entity.errorCode!.codeIsSuccessful) {
state.autoLockTime.value = autoTime;
state.lockSetInfoData.value.lockSettingInfo!.autoLockSecond = int.parse(state.autoLockTime.value);
showToast("操作成功".tr, something: (){
state.lockSetInfoData.value.lockSettingInfo!.autoLockSecond =
int.parse(state.autoLockTime.value);
showToast('操作成功'.tr, something: () {
eventBus.fire(RefreshLockListInfoDataEvent());
eventBus.fire(PassCurrentLockInformationEvent(state.lockSetInfoData.value));
eventBus
.fire(PassCurrentLockInformationEvent(state.lockSetInfoData.value));
Get.back();
});
}, maskType: EasyLoadingMaskType.clear);
}
}
//
late StreamSubscription<Reply> _replySubscription;
void _initReplySubscription() {
_replySubscription = EventBusManager().eventBus!.on<Reply>().listen((reply) {
if(reply is SetSupportFunctionsWithParametersReply) {
_replySubscription =
EventBusManager().eventBus!.on<Reply>().listen((Reply reply) {
if (reply is SetSupportFunctionsWithParametersReply) {
_replySetSupportFunctionsWithParameters(reply);
}
@ -86,10 +90,10 @@ class AutomaticBlockingLogic extends BaseGetXController{
//
Future<void> _replySetSupportFunctionsWithParameters(Reply reply) async {
int status = reply.data[2];
switch(status){
final int status = reply.data[2];
switch (status) {
case 0x00:
//
//
state.sureBtnState.value = 0;
cancelBlueConnetctToastTimer();
dismissEasyLoading();
@ -106,34 +110,39 @@ class AutomaticBlockingLogic extends BaseGetXController{
// ()
Future<void> sendAutoLock() async {
if(state.sureBtnState.value == 1){
if (state.sureBtnState.value == 1) {
return;
}
state.sureBtnState.value = 1;
showEasyLoading();
showBlueConnetctToastTimer(action: (){
showBlueConnetctToastTimer(action: () {
dismissEasyLoading();
state.sureBtnState.value = 0;
});
BlueManage().blueSendData(BlueManage().connectDeviceName, (BluetoothConnectionState connectionState) async {
BlueManage().blueSendData(BlueManage().connectDeviceName,
(BluetoothConnectionState connectionState) async {
if (connectionState == BluetoothConnectionState.connected) {
var privateKey = await Storage.getStringList(saveBluePrivateKey);
List<int> getPrivateKeyList = changeStringListToIntList(privateKey!);
final List<String>? privateKey =
await Storage.getStringList(saveBluePrivateKey);
final List<int> getPrivateKeyList =
changeStringListToIntList(privateKey!);
var token = await Storage.getStringList(saveBlueToken);
List<int> getTokenList = changeStringListToIntList(token!);
final List<String>? token = await Storage.getStringList(saveBlueToken);
final List<int> getTokenList = changeStringListToIntList(token!);
var publicKey = await Storage.getStringList(saveBluePublicKey);
List<int> getPublicKeyList = changeStringListToIntList(publicKey!);
final List<String>? publicKey =
await Storage.getStringList(saveBluePublicKey);
final List<int> getPublicKeyList =
changeStringListToIntList(publicKey!);
String autoTime;
if(state.isOpen.value == false){
autoTime = "0";
}else{
if(state.isCustomLockTime.value == true){
if (state.isOpen.value == false) {
autoTime = '0';
} else {
if (state.isCustomLockTime.value == true) {
autoTime = state.timeController.text;
}else{
} else {
autoTime = state.autoLockTime.value;
}
}
@ -142,7 +151,7 @@ class AutomaticBlockingLogic extends BaseGetXController{
userID: await Storage.getUid(),
featureBit: 29,
featureParaLength: 2,
featureData: [int.parse(autoTime)],
featureData: <int>[int.parse(autoTime)],
token: getTokenList,
needAuthor: 1,
publicKey: getPublicKeyList,
@ -151,7 +160,7 @@ class AutomaticBlockingLogic extends BaseGetXController{
dismissEasyLoading();
cancelBlueConnetctToastTimer();
state.sureBtnState.value = 0;
if(state.ifCurrentScreen.value == true){
if (state.ifCurrentScreen.value == true) {
showBlueConnetctToast();
}
}
@ -159,36 +168,42 @@ class AutomaticBlockingLogic extends BaseGetXController{
}
void ifCanNext() {
if(((state.isOpen.value != (state.lockSetInfoData.value.lockSettingInfo!.autoLock! == 1 ? true : false)) &&
(state.autoLockTime.value != state.lockSetInfoData.value.lockSettingInfo!.autoLockSecond!.toString()) &&
(state.isJustForShow.value == false)) || ((state.isOpen.value = true) && (state.lockSetInfoData.value.lockSettingInfo!.autoLock! == 1) &&
(state.autoLockTime.value != state.lockSetInfoData.value.lockSettingInfo!.autoLockSecond!.toString()) &&
(state.isJustForShow.value == false))){
final int autoLock = state.lockSetInfoData.value.lockSettingInfo!.autoLock!;
final String autoLockSecond =
state.lockSetInfoData.value.lockSettingInfo!.autoLockSecond!.toString();
final bool openLock = autoLock == 1;
final bool isNotJustForShow = state.isJustForShow.value == false;
final bool isEditAutoLockSecond =
state.autoLockTime.value != autoLockSecond;
if (!isNotJustForShow) {
//
state.canNext.value = false;
return;
}
if (state.isOpen.value != openLock || isEditAutoLockSecond) {
state.canNext.value = true;
}else{
} else {
state.canNext.value = false;
}
}
@override
void onReady() {
// TODO: implement onReady
super.onReady();
_initReplySubscription();
Storage.getAutomaticLockOffTime()
.then((String value) => state.timeController.text = value);
}
@override
void onInit() {
// TODO: implement onInit
super.onInit();
// _readSupportFunctionsWithParameters();
}
@override
void onClose() {
// TODO: implement onClose
super.onClose();
_replySubscription.cancel();
}

View File

@ -4,9 +4,10 @@ import 'package:flutter/material.dart';
import 'package:flutter_easyloading/flutter_easyloading.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:get/get.dart';
import 'package:star_lock/main/lockDetail/lockSet/automaticBlocking/automaticBlocking_state.dart';
import 'package:star_lock/tools/storage.dart';
import '../../../../app_settings/app_colors.dart';
import '../../../../blue/blue_manage.dart';
import '../../../../tools/appRouteObserver.dart';
import '../../../../tools/commonItem.dart';
import '../../../../tools/showBottomSheetTool.dart';
@ -22,9 +23,10 @@ class AutomaticBlockingPage extends StatefulWidget {
State<AutomaticBlockingPage> createState() => _AutomaticBlockingPageState();
}
class _AutomaticBlockingPageState extends State<AutomaticBlockingPage> with RouteAware {
final logic = Get.put(AutomaticBlockingLogic());
final state = Get.find<AutomaticBlockingLogic>().state;
class _AutomaticBlockingPageState extends State<AutomaticBlockingPage>
with RouteAware {
final AutomaticBlockingLogic logic = Get.put(AutomaticBlockingLogic());
final AutomaticBlockingState state = Get.find<AutomaticBlockingLogic>().state;
@override
Widget build(BuildContext context) {
@ -33,85 +35,90 @@ class _AutomaticBlockingPageState extends State<AutomaticBlockingPage> with Rout
appBar: TitleAppBar(
barTitle: TranslationLoader.lanKeys!.automaticBlocking!.tr,
haveBack: true,
actionsList: [
actionsList: <Widget>[
Obx(() => TextButton(
onPressed: state.canNext.value == false ? null :() {
// if(state.isJustForShow.value == true){
// return;
// }
// if(state.isCustomLockTime.value == true && state.timeController.text.isEmpty){
// logic.showToast("请输入自定义时间");
// return;
// }
if(state.isOpen.value == false){
ShowTipView().showIosTipWithContentDialog('关闭后,智能锁将设置为全天常开模式,直到手动关闭'.tr, (){
logic.sendAutoLock();
});
}else{
logic.sendAutoLock();
}
},
child: Text(
state.canNext.value == false ? "" : TranslationLoader.lanKeys!.save!.tr,
style: TextStyle(color: Colors.white, fontSize: 24.sp),
),
)),
onPressed: state.canNext.value == false
? null
: () {
if (state.isOpen.value == false) {
ShowTipView().showIosTipWithContentDialog(
'关闭后,智能锁将设置为全天常开模式,直到手动关闭'.tr,
logic.sendAutoLock);
} else {
logic.sendAutoLock();
}
},
child: Text(
state.canNext.value == false
? ''
: TranslationLoader.lanKeys!.save!.tr,
style: TextStyle(color: Colors.white, fontSize: 24.sp),
),
)),
],
backgroundColor: AppColors.mainColor),
body: ListView(
children: [
Obx(() => CommonItem(
leftTitel: TranslationLoader.lanKeys!.automaticBlocking!.tr,
isHaveLine: false,
isHaveRightWidget: true,
rightWidget:
SizedBox(width: 60.w, height: 50.h, child: _switch())),),
children: <Widget>[
Obx(
() => CommonItem(
leftTitel: TranslationLoader.lanKeys!.automaticBlocking!.tr,
isHaveLine: false,
isHaveRightWidget: true,
rightWidget:
SizedBox(width: 60.w, height: 50.h, child: _switch())),
),
Visibility(
visible: state.isOpen.value == true ? true : false,
visible: state.isOpen.value == true,
child: Column(
children: [
Container(height: 10.h,),
Builder(builder: (context) {
children: <Widget>[
Container(
height: 10.h,
),
Builder(builder: (BuildContext context) {
return Obx(() => CommonItem(
leftTitel: TranslationLoader.lanKeys!.delayTime!.tr,
rightTitle: state.isCustomLockTime.value == true ? "自定义".tr : (state.autoLockTime.value.isNotEmpty && state.autoLockTime.value != "0") ? "${state.autoLockTime}s" : "",
rightTitle: state.isCustomLockTime.value == true
? '自定义'.tr
: (state.autoLockTime.value.isNotEmpty &&
state.autoLockTime.value != '0')
? '${state.autoLockTime}s'
: '',
isHaveLine: false,
isHaveDirection: true,
action: () {
if(state.isJustForShow.value == true){
if (state.isJustForShow.value == true) {
return;
}
var list = [
"5",
"10",
"15",
"30",
"60",
final List<String> list = <String>[
'5',
'10',
'15',
'30',
'60',
TranslationLoader.lanKeys!.custom!.tr
];
ShowBottomSheetTool().showSingleRowPicker(
//
//
context,
//
normalIndex: 0,
title: TranslationLoader.lanKeys!.time!.tr,
cancelTitle: TranslationLoader.lanKeys!.cancel!.tr,
cancelTitle:
TranslationLoader.lanKeys!.cancel!.tr,
sureTitle: TranslationLoader.lanKeys!.sure!.tr,
//
//
//adapter: PickerAdapter(),
data: list,
//
clickCallBack: (int index, var str) {
if(index != 5){
state.isCustomLockTime.value = false;
state.autoLockTime.value = str.toString();
}else{
state.isCustomLockTime.value = true;
}
logic.ifCanNext();
});
clickCallBack: (int index, Object str) {
if (index != 5) {
state.isCustomLockTime.value = false;
state.autoLockTime.value = str.toString();
Storage.saveAutomaticLockOffTime(str.toString());
} else {
state.isCustomLockTime.value = true;
}
logic.ifCanNext();
});
}));
}),
Container(height: 10.h),
@ -122,37 +129,37 @@ class _AutomaticBlockingPageState extends State<AutomaticBlockingPage> with Rout
padding: EdgeInsets.only(
left: 30.w, top: 10.w, right: 30.w, bottom: 10.w),
child: Column(
children: [
children: <Widget>[
Row(
children: [
children: <Widget>[
Text(
"${TranslationLoader.lanKeys!.pleaseEnter!.tr}${TranslationLoader.lanKeys!.time!.tr}(S)",
'${TranslationLoader.lanKeys!.pleaseEnter!.tr}${TranslationLoader.lanKeys!.time!.tr}(S)',
style: TextStyle(fontSize: 24.sp),
),
],
),
Obx(() => TextField(
//
maxLines: 1,
controller: state.timeController,
keyboardType: TextInputType.number,
autofocus: false,
readOnly: state.isJustForShow.value == true ? true : false,
onChanged: (value) {
state.autoLockTime.value = value;
logic.ifCanNext();
},
decoration: InputDecoration(
//
contentPadding:
const EdgeInsets.only(top: 12.0, bottom: 8.0),
hintText:
"${TranslationLoader.lanKeys!.pleaseEnter!.tr}${TranslationLoader.lanKeys!.time!.tr}(S)",
hintStyle: TextStyle(fontSize: 24.sp),
//线
border: InputBorder.none,
),
)),
//
maxLines: 1,
controller: state.timeController,
keyboardType: TextInputType.number,
autofocus: false,
readOnly: state.isJustForShow.value == true,
onChanged: (String value) {
state.autoLockTime.value = value;
logic.ifCanNext();
},
decoration: InputDecoration(
//
contentPadding: const EdgeInsets.only(
top: 12.0, bottom: 8.0),
hintText:
'${TranslationLoader.lanKeys!.pleaseEnter!.tr}${TranslationLoader.lanKeys!.time!.tr}(S)',
hintStyle: TextStyle(fontSize: 24.sp),
//线
border: InputBorder.none,
),
)),
Container(
height: 0.5.h,
color: Colors.grey,
@ -167,7 +174,7 @@ class _AutomaticBlockingPageState extends State<AutomaticBlockingPage> with Rout
padding: EdgeInsets.all(30.w),
child: Row(
mainAxisAlignment: MainAxisAlignment.start,
children: [
children: <Widget>[
Expanded(
child: Text(
TranslationLoader.lanKeys!.automaticBlockingTip!.tr,
@ -186,21 +193,19 @@ class _AutomaticBlockingPageState extends State<AutomaticBlockingPage> with Rout
trackColor: CupertinoColors.systemGrey5,
thumbColor: CupertinoColors.white,
value: state.isOpen.value,
onChanged: state.isJustForShow.value == true ? null : (value){
setState(() {
state.isOpen.value = value;
if(state.isOpen.value == false){
state.autoLockTime.value = "";
}
logic.ifCanNext();
});
},
onChanged: state.isJustForShow.value == true
? null
: (bool value) {
setState(() {
state.isOpen.value = value;
logic.ifCanNext();
});
},
);
}
@override
void didChangeDependencies() {
// TODO: implement didChangeDependencies
super.didChangeDependencies();
///
@ -209,7 +214,6 @@ class _AutomaticBlockingPageState extends State<AutomaticBlockingPage> with Rout
@override
void dispose() {
// TODO: implement dispose
///
AppRouteObserver().routeObserver.unsubscribe(this);
super.dispose();
@ -227,7 +231,9 @@ class _AutomaticBlockingPageState extends State<AutomaticBlockingPage> with Rout
void didPop() {
super.didPop();
logic.cancelBlueConnetctToastTimer();
if (EasyLoading.isShow) EasyLoading.dismiss(animation: true);
if (EasyLoading.isShow) {
EasyLoading.dismiss(animation: true);
}
state.ifCurrentScreen.value = false;
state.sureBtnState.value = 0;
}
@ -244,9 +250,10 @@ class _AutomaticBlockingPageState extends State<AutomaticBlockingPage> with Rout
void didPushNext() {
super.didPushNext();
logic.cancelBlueConnetctToastTimer();
if (EasyLoading.isShow) EasyLoading.dismiss(animation: true);
if (EasyLoading.isShow) {
EasyLoading.dismiss(animation: true);
}
state.ifCurrentScreen.value = false;
state.sureBtnState.value = 0;
}
}

View File

@ -98,8 +98,11 @@ class BaseGetXController extends GetxController {
"${'操作失败,请确认锁是否在附近,或重启手机蓝牙后再试。'.tr}${isContains == true ? "如果是全自动锁,请使屏幕变亮" : ""}");
}
void showToast(String status, {Function? something}) {
EasyLoading.showToast(status, duration: 2000.milliseconds);
void showToast(String status,
{Function? something,
EasyLoadingMaskType maskType = EasyLoadingMaskType.none}) {
EasyLoading.showToast(status,
duration: 2000.milliseconds, maskType: maskType);
if (something != null) {
delay(duration: 2100.milliseconds, something: something);
}

View File

@ -8,37 +8,35 @@ import 'package:shared_preferences/shared_preferences.dart';
import '../login/login/entity/LoginData.dart';
import '../main/lockMian/entity/lockListInfo_entity.dart';
const saveBluePublicKey = "BluePublicKey";
const saveBluePrivateKey = "BluePrivateKey";
const saveBlueSignKey = "BlueSignKey";
const saveBlueToken = "BlueGetToken";
const currentConnectionLockId = "CurrentConnectionLockId";
const currentConnectionMacAddress = "CurrentConnectionMacAddress";
const ifIsDemoModeOrNot = "IfIsDemoModeOrNot";
const isAgreePrivacy = "isAgreePrivacy"; //
const isAgreePosition = "isAgreePosition"; //
const isAgreeCamera = "isAgreeCamera"; ///
const String saveBluePublicKey = 'BluePublicKey';
const String saveBluePrivateKey = 'BluePrivateKey';
const String saveBlueSignKey = 'BlueSignKey';
const String saveBlueToken = 'BlueGetToken';
const String currentConnectionLockId = 'CurrentConnectionLockId';
const String currentConnectionMacAddress = 'CurrentConnectionMacAddress';
const String ifIsDemoModeOrNot = 'IfIsDemoModeOrNot';
const String isAgreePrivacy = 'isAgreePrivacy'; //
const String isAgreePosition = 'isAgreePosition'; //
const String isAgreeCamera = 'isAgreeCamera'; ///
const isShowUpdateVersion = "isShowUpdateVersion"; //
const saveLockAlias = "saveLockAlias"; //
const pushDeviceID = 'pushDeviceID'; //ID
const saveIsVip = "saveIsVip"; //VIP
const String isShowUpdateVersion = 'isShowUpdateVersion'; //
const String saveLockAlias = 'saveLockAlias'; //
const String pushDeviceID = 'pushDeviceID'; //ID
const String saveIsVip = 'saveIsVip'; //VIP
const saveUserLoginData = "userLoginData";
const saveLockMainListData = "lockMainListData";
const isOpenDeBug = "isOpenDeBug"; // debug
const String saveUserLoginData = 'userLoginData';
const String saveLockMainListData = 'lockMainListData';
const String isOpenDeBug = 'isOpenDeBug'; // debug
const String automaticLockOffTime = 'automaticLockOffTime'; //
class Storage {
Storage._internal();
factory Storage() => _instance;
Storage._internal();
static late final Storage _instance = Storage._internal();
static late SharedPreferences _preferences;
static Future<Storage> getInstance() async {
_preferences = await SharedPreferences.getInstance();
return _instance;
}
@ -73,127 +71,124 @@ class Storage {
// }
// int
static Future<void> setInt(key, value) async {
SharedPreferences sp = await SharedPreferences.getInstance();
static Future<void> setInt(String key, dynamic value) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
sp.setInt(key, value);
}
static Future<int?> getInt(key) async {
SharedPreferences sp = await SharedPreferences.getInstance();
static Future<int?> getInt(String key) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
return sp.getInt(key);
}
// bool
static Future<void> setBool(key, value) async {
SharedPreferences sp = await SharedPreferences.getInstance();
static Future<void> setBool(String key, dynamic value) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
sp.setBool(key, value);
}
static Future<bool?> getBool(key) async {
SharedPreferences sp = await SharedPreferences.getInstance();
static Future<bool?> getBool(String key) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
return sp.getBool(key);
}
// double
static Future<void> setDouble(key, value) async {
SharedPreferences sp = await SharedPreferences.getInstance();
static Future<void> setDouble(String key, dynamic value) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
sp.setDouble(key, value);
}
static Future<double?> getDouble(key) async {
SharedPreferences sp = await SharedPreferences.getInstance();
static Future<double?> getDouble(String key) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
return sp.getDouble(key);
}
// string
static Future<void> setString(key, value) async {
SharedPreferences sp = await SharedPreferences.getInstance();
static Future<void> setString(String key, dynamic value) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
sp.setString(key, value);
}
static Future<String?> getString(key) async {
SharedPreferences sp = await SharedPreferences.getInstance();
static Future<String?> getString(String key) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
return sp.getString(key);
}
//
static Future<void> setStringList(key, value) async {
SharedPreferences sp = await SharedPreferences.getInstance();
static Future<void> setStringList(String key, dynamic value) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
sp.setStringList(key, value);
}
static Future<List<String>?> getStringList(key) async {
SharedPreferences sp = await SharedPreferences.getInstance();
static Future<List<String>?> getStringList(String key) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
return sp.getStringList(key);
}
// key
static Future<bool> ifHaveKey(key) async {
SharedPreferences sp = await SharedPreferences.getInstance();
bool isContainKey = sp.containsKey(key) ?? false;
static Future<bool> ifHaveKey(String key) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
final bool isContainKey = sp.containsKey(key);
// AppLog.log(isContainKey);
return isContainKey;
}
//
static Future<void> removeData(key) async {
SharedPreferences sp = await SharedPreferences.getInstance();
static Future<void> removeData(String key) async {
final SharedPreferences sp = await SharedPreferences.getInstance();
sp.remove(key);
}
//
static Future<void> clearAll() async {
SharedPreferences sp = await SharedPreferences.getInstance();
final SharedPreferences sp = await SharedPreferences.getInstance();
sp.clear();
//
if (isAgreePrivacy != null) {
//退
await setString(isAgreePrivacy, isAgreePrivacy);
}
//退
await setString(isAgreePrivacy, isAgreePrivacy);
}
static Future<String?> getUid() async {
LoginData? loginData = await getLoginData();
String? uid = loginData!.uid.toString();
final LoginData? loginData = await getLoginData();
final String uid = loginData!.uid.toString();
// AppLog.log("pubUid:$uid");
return uid;
}
static Future<String?> getUserid() async {
LoginData? loginData = await getLoginData();
String? userid = loginData!.userid.toString();
final LoginData? loginData = await getLoginData();
final String userid = loginData!.userid.toString();
// AppLog.log("pubUid:$uid");
return userid;
}
static Future<String?> getMobile() async {
LoginData? loginData = await getLoginData();
String? mobile = loginData!.mobile;
final LoginData? loginData = await getLoginData();
final String? mobile = loginData!.mobile;
return mobile ?? '';
}
static Future<String?> getEmail() async {
LoginData? loginData = await getLoginData();
String? email = loginData!.email;
final LoginData? loginData = await getLoginData();
final String? email = loginData!.email;
return email;
}
static Future<String?> getNickname() async {
LoginData? loginData = await getLoginData();
String? nickname = loginData!.nickname;
final LoginData? loginData = await getLoginData();
final String? nickname = loginData!.nickname;
return nickname;
}
static Future<String?> getHeadUrl() async {
LoginData? loginData = await getLoginData();
String? headUrl = loginData!.headUrl;
final LoginData? loginData = await getLoginData();
final String? headUrl = loginData!.headUrl;
return headUrl;
}
static Future<LoginData?> getLoginData() async {
LoginData? loginData;
final data = await Storage.getString(saveUserLoginData);
final String? data = await Storage.getString(saveUserLoginData);
if (data != null && data.isNotEmpty) {
loginData = LoginData.fromJson(jsonDecode(data));
}
@ -211,11 +206,21 @@ class Storage {
static Future<LockListInfoGroupEntity?> getLockMainListData() async {
LockListInfoGroupEntity? lockListInfoGroupEntity;
final data = await Storage.getString(saveLockMainListData);
final String? data = await Storage.getString(saveLockMainListData);
if (data != null && data.isNotEmpty) {
lockListInfoGroupEntity =
LockListInfoGroupEntity.fromJson(jsonDecode(data));
}
return lockListInfoGroupEntity;
}
//
static Future<void> saveAutomaticLockOffTime(String data) async {
await Storage.setString(automaticLockOffTime, data);
}
static Future<String> getAutomaticLockOffTime() async {
final String data = await Storage.getString(automaticLockOffTime) ?? '0';
return data;
}
}

View File

@ -1,5 +1,4 @@
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:permission_handler/permission_handler.dart';
import 'package:star_lock/app_settings/app_settings.dart';
@ -7,7 +6,7 @@ import 'package:star_lock/tools/storage.dart';
import 'package:star_lock/translations/trans_lib.dart';
class PermissionDialog {
static Map<Permission, String> titles = {
static Map<Permission, String> titles = <Permission, String>{
Permission.camera: '相机'.tr,
Permission.photos: '相册'.tr,
Permission.storage: '读写'.tr,
@ -17,7 +16,7 @@ class PermissionDialog {
Permission.bluetoothConnect: '蓝牙'.tr,
};
static Map<Permission, String> contents = {
static Map<Permission, String> contents = <Permission, String>{
Permission.camera: '需要访问相机权限才能拍照上传文件例如头像上传'.tr,
Permission.photos: '需要访问相机权限才能使用相册图片上传文件上传头像'.tr,
Permission.storage: '需要访问读写权限才能使用本地图片上传头像'.tr,
@ -32,18 +31,18 @@ class PermissionDialog {
return false;
}
bool application = true;
List<Permission> permissions = [
final List<Permission> permissions = <Permission>[
Permission.bluetooth,
Permission.bluetoothScan,
Permission.bluetoothConnect,
];
Future<bool> getPermissionStatus(List<Permission> permissions) async {
bool isGranted = true;
List<PermissionStatus> permissionStatus = [];
for (Permission per in permissions) {
final List<PermissionStatus> permissionStatus = <PermissionStatus>[];
for (final Permission per in permissions) {
permissionStatus.add(await per.status);
}
for (PermissionStatus per in permissionStatus) {
for (final PermissionStatus per in permissionStatus) {
isGranted = isGranted && per.isGranted;
}
if (GetPlatform.isIOS) {
@ -52,19 +51,19 @@ class PermissionDialog {
return isGranted;
}
Permission permission = Permission.bluetoothScan;
dynamic cache = await Storage.getString(titles[permission]);
bool isGranted = await getPermissionStatus(permissions);
const Permission permission = Permission.bluetoothScan;
final dynamic cache = await Storage.getString(titles[permission]!);
final bool isGranted = await getPermissionStatus(permissions);
if (GetPlatform.isAndroid && !isGranted && cache is! String) {
application = await showCupertinoDialog(
context: Get.context!,
builder: (context) {
builder: (BuildContext context) {
return PopScope(
canPop: false,
child: CupertinoAlertDialog(
title: Text('${'申请'.tr}${titles[permission] ?? ''}${'权限'.tr}'),
content: Text(contents[permission] ?? ''),
actions: [
actions: <Widget>[
CupertinoDialogAction(
child: Text('不允许'.tr),
onPressed: () {
@ -83,12 +82,12 @@ class PermissionDialog {
);
if (application) {
await Storage.setString(titles[permission], titles[permission]);
await Storage.setString(titles[permission]!, titles[permission]);
}
} else if (cache is! String) {
await Storage.setString(titles[permission], titles[permission]);
await Storage.setString(titles[permission]!, titles[permission]);
} else {
bool isGranted = await getPermissionStatus(permissions);
final bool isGranted = await getPermissionStatus(permissions);
if (!isGranted) {
showSet(permission);
return false;
@ -96,7 +95,7 @@ class PermissionDialog {
}
if (application) {
await permissions.request();
bool isGranted = await getPermissionStatus(permissions);
final bool isGranted = await getPermissionStatus(permissions);
return isGranted;
}
return false;
@ -107,20 +106,20 @@ class PermissionDialog {
if (Get.context == null) {
return false;
}
bool isAndroid33 =
final bool isAndroid33 =
AppPlatform.isAndroid && AppPlatform.getSdkIntValue() >= 33;
//
List<Permission> requestPermission() {
List<Permission> permissions;
if (isAndroid33) {
permissions = [
permissions = <Permission>[
Permission.mediaLibrary,
Permission.photos,
Permission.videos,
];
} else {
permissions = [
permissions = <Permission>[
Permission.storage,
];
}
@ -129,7 +128,7 @@ class PermissionDialog {
Future<bool> permissionStatus(List<Permission> permissions) async {
bool isGranted = true;
for (Permission permission in permissions) {
for (final Permission permission in permissions) {
isGranted =
isGranted && (await permission.status) == PermissionStatus.granted;
}
@ -142,20 +141,20 @@ class PermissionDialog {
}
bool application = true;
Permission permission = Permission.photos;
List<Permission> permissions = requestPermission();
dynamic cache = await Storage.getString(titles[permission]);
bool isGranted = await permissionStatus(permissions);
const Permission permission = Permission.photos;
final List<Permission> permissions = requestPermission();
final dynamic cache = await Storage.getString(titles[permission]??'');
final bool isGranted = await permissionStatus(permissions);
if (AppPlatform.isAndroid && !isGranted && cache is! String) {
application = await showCupertinoDialog(
context: Get.context!,
builder: (context) {
builder: (BuildContext context) {
return PopScope(
canPop: false,
child: CupertinoAlertDialog(
title: Text('${'申请'.tr}${titles[permission] ?? ''}${'权限'.tr}'),
content: Text(contents[permission] ?? ''),
actions: [
actions: <Widget>[
CupertinoDialogAction(
child: Text('不允许'.tr),
onPressed: () {
@ -173,18 +172,18 @@ class PermissionDialog {
},
);
if (application) {
await Storage.setString(titles[permission], titles[permission]);
await Storage.setString(titles[permission]!, titles[permission]);
}
} else if (cache is String) {
bool isDenied = !(await permissionStatus(permissions));
final bool isDenied = !(await permissionStatus(permissions));
if (isDenied) {
showSet(permission);
return false;
}
}
if (application) {
Map<Permission, PermissionStatus> statuses = await permissions.request();
bool isGranted = await permissionStatus(statuses.keys.toList());
final Map<Permission, PermissionStatus> statuses = await permissions.request();
final bool isGranted = await permissionStatus(statuses.keys.toList());
return isGranted;
}
return false;
@ -195,14 +194,14 @@ class PermissionDialog {
if (Get.context == null) {
return false;
}
bool isAndroid33 =
final bool isAndroid33 =
AppPlatform.isAndroid && AppPlatform.getSdkIntValue() >= 33;
//
List<Permission> requestPermission() {
List<Permission> permissions;
if (isAndroid33) {
permissions = [
permissions = <Permission>[
Permission.mediaLibrary,
Permission.photos,
// Permission.audio,
@ -210,7 +209,7 @@ class PermissionDialog {
Permission.manageExternalStorage,
];
} else {
permissions = [
permissions = <Permission>[
Permission.storage,
];
}
@ -219,7 +218,7 @@ class PermissionDialog {
Future<bool> permissionStatus(List<Permission> permissions) async {
bool isGranted = true;
for (Permission permission in permissions) {
for (final Permission permission in permissions) {
isGranted =
isGranted && (await permission.status) == PermissionStatus.granted;
}
@ -234,20 +233,20 @@ class PermissionDialog {
}
bool application = true;
Permission permission = Permission.photos;
List<Permission> permissions = requestPermission();
dynamic cache = await Storage.getString(titles[permission]);
bool isGranted = await permissionStatus(permissions);
const Permission permission = Permission.photos;
final List<Permission> permissions = requestPermission();
final dynamic cache = await Storage.getString(titles[permission]??'');
final bool isGranted = await permissionStatus(permissions);
if (AppPlatform.isAndroid && !isGranted && cache is! String) {
application = await showCupertinoDialog(
context: Get.context!,
builder: (context) {
builder: (BuildContext context) {
return PopScope(
canPop: false,
child: CupertinoAlertDialog(
title: Text('${'申请'.tr}${titles[permission] ?? ''}${'权限'.tr}'),
content: Text('需要访问读写权限才能使用手动升级固件'.tr),
actions: [
actions: <Widget>[
CupertinoDialogAction(
child: Text('不允许'.tr),
onPressed: () {
@ -265,18 +264,18 @@ class PermissionDialog {
},
);
if (application) {
await Storage.setString(titles[permission], titles[permission]);
await Storage.setString(titles[permission]??'', titles[permission]);
}
} else if (cache is String) {
bool isDenied = !(await permissionStatus(permissions));
final bool isDenied = !(await permissionStatus(permissions));
if (isDenied) {
showSet(permission);
return false;
}
}
if (application) {
Map<Permission, PermissionStatus> statuses = await permissions.request();
bool isGranted = await permissionStatus(statuses.keys.toList());
final Map<Permission, PermissionStatus> statuses = await permissions.request();
final bool isGranted = await permissionStatus(statuses.keys.toList());
return isGranted;
}
return false;
@ -288,18 +287,18 @@ class PermissionDialog {
return false;
}
bool application = true;
PermissionStatus status = await permission.status;
dynamic cache = await Storage.getString(titles[permission]);
final PermissionStatus status = await permission.status;
final dynamic cache = await Storage.getString(titles[permission]??'');
if (AppPlatform.isAndroid && !status.isGranted && cache is! String) {
application = await showCupertinoDialog(
context: Get.context!,
builder: (context) {
builder: (BuildContext context) {
return PopScope(
canPop: false,
child: CupertinoAlertDialog(
title: Text('${'申请'.tr}${titles[permission] ?? ''}${'权限'.tr}'),
content: Text(content ?? contents[permission] ?? ''),
actions: [
actions: <Widget>[
CupertinoDialogAction(
child: Text('不允许'.tr),
onPressed: () {
@ -317,7 +316,7 @@ class PermissionDialog {
},
);
if (application) {
await Storage.setString(titles[permission], titles[permission]);
await Storage.setString(titles[permission]??'', titles[permission]);
}
} else if (cache is String) {
if (status.isDenied) {
@ -326,7 +325,7 @@ class PermissionDialog {
}
}
if (application) {
PermissionStatus status = await permission.request();
final PermissionStatus status = await permission.request();
return status.isGranted;
}
return false;
@ -339,14 +338,14 @@ class PermissionDialog {
}
showCupertinoDialog(
context: Get.context!,
builder: (context) {
builder: (BuildContext context) {
return PopScope(
canPop: false,
child: CupertinoAlertDialog(
title: Text('${titles[permission] ?? ''}${'权限被拒绝'.tr}'),
content: Text(
'${contents[permission] ?? ''}${'请手动在系统设置中开启'.tr}${titles[permission]}${'权限以继续使用应用'.tr}'),
actions: [
actions: <Widget>[
CupertinoDialogAction(
child: Text('去设置'.tr),
onPressed: () {