mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
mod: check istablet
Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
@@ -1,14 +1,14 @@
|
|||||||
import 'dart:io';
|
|
||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
import 'package:PiliPlus/common/widgets/pair.dart';
|
import 'package:PiliPlus/common/widgets/pair.dart';
|
||||||
import 'package:PiliPlus/utils/extension.dart';
|
import 'package:PiliPlus/utils/extension.dart';
|
||||||
import 'package:PiliPlus/utils/storage.dart';
|
import 'package:PiliPlus/utils/storage.dart';
|
||||||
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
|
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
|
||||||
import 'package:device_info_plus/device_info_plus.dart';
|
import 'package:get/get.dart';
|
||||||
import 'package:webdav_client/webdav_client.dart' as webdav;
|
import 'package:webdav_client/webdav_client.dart' as webdav;
|
||||||
|
|
||||||
class WebDav {
|
class WebDav {
|
||||||
late String _webdavDirectory;
|
late String _webdavDirectory;
|
||||||
|
String? _fileName;
|
||||||
|
|
||||||
webdav.Client? _client;
|
webdav.Client? _client;
|
||||||
|
|
||||||
@@ -47,32 +47,10 @@ class WebDav {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<bool> _isPhone() async {
|
String _getFileName() {
|
||||||
final deviceInfoPlugin = DeviceInfoPlugin();
|
return Get.context!.isTablet
|
||||||
if (Platform.isAndroid) {
|
? 'piliplus_settings_pad.json'
|
||||||
AndroidDeviceInfo androidInfo = await deviceInfoPlugin.androidInfo;
|
: 'piliplus_settings_phone.json';
|
||||||
return androidInfo.systemFeatures.contains("android.hardware.telephony");
|
|
||||||
} else if (Platform.isIOS) {
|
|
||||||
IosDeviceInfo iosInfo = await deviceInfoPlugin.iosInfo;
|
|
||||||
return _isIosPhone(iosInfo.utsname.machine);
|
|
||||||
} else {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
bool _isIosPhone(String machine) {
|
|
||||||
if (machine.startsWith("iPhone")) {
|
|
||||||
return true;
|
|
||||||
} else if (machine.startsWith("iPad")) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
Future<String> _getFileName() async {
|
|
||||||
final isPhoneDevice = await _isPhone();
|
|
||||||
return isPhoneDevice
|
|
||||||
? 'piliplus_settings_phone.json'
|
|
||||||
: 'piliplus_settings_pad.json';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Future backup() async {
|
Future backup() async {
|
||||||
@@ -85,9 +63,8 @@ class WebDav {
|
|||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
String data = await GStorage.exportAllSettings();
|
String data = await GStorage.exportAllSettings();
|
||||||
final isPhoneDevice = await _isPhone();
|
_fileName ??= _getFileName();
|
||||||
final fileName = await _getFileName();
|
final path = '$_webdavDirectory/$_fileName';
|
||||||
final path = '$_webdavDirectory/$fileName';
|
|
||||||
try {
|
try {
|
||||||
await _client!.remove(path);
|
await _client!.remove(path);
|
||||||
} catch (_) {}
|
} catch (_) {}
|
||||||
@@ -107,9 +84,8 @@ class WebDav {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
final isPhoneDevice = await _isPhone();
|
_fileName ??= _getFileName();
|
||||||
final fileName = await _getFileName();
|
final path = '$_webdavDirectory/$_fileName';
|
||||||
final path = '$_webdavDirectory/$fileName';
|
|
||||||
final data = await _client!.read(path);
|
final data = await _client!.read(path);
|
||||||
await GStorage.importAllSettings(utf8.decode(data));
|
await GStorage.importAllSettings(utf8.decode(data));
|
||||||
SmartDialog.showToast('恢复成功');
|
SmartDialog.showToast('恢复成功');
|
||||||
|
|||||||
Reference in New Issue
Block a user