Merge branch 'develop_address_book' into 'release'

Develop address book

See merge request StarlockTeam/app-starlock!99
This commit is contained in:
刘燕峰 2025-05-27 06:16:37 +00:00
commit fa18888df9
6 changed files with 229 additions and 58 deletions

View File

@ -29,6 +29,9 @@
<uses-permission android:name="android.permission.WRITE_SETTINGS" />
<!--允许读设备日志,用于问题排查-->
<uses-permission android:name="android.permission.READ_LOGS" />
<!--联系人-->
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_CONTACTS" />
<!--相机-->
<uses-permission android:name="android.permission.CAMERA" />

View File

@ -257,15 +257,42 @@ class _AuthorizedAdminPageState extends State<AuthorizedAdminPage>
onTap: () async {
final Contact? currentContact =
await logic.state.contactPicker.selectContact();
logic.state.contact = currentContact!;
if (currentContact.phoneNumbers!.isNotEmpty) {
logic.state.emailOrPhoneController.text = currentContact
.phoneNumbers![0]
.replaceAll(RegExp(r'\s+\b|\b\s'), '');
}
if (currentContact.fullName!.isNotEmpty) {
logic.state.keyNameController.text =
currentContact.fullName!;
if (currentContact != null) {
setState(() {
logic.state.contact = currentContact;
//
if (currentContact.phoneNumbers != null &&
currentContact.phoneNumbers!.isNotEmpty) {
//
String phoneNumber = currentContact.phoneNumbers![0];
//
phoneNumber =
phoneNumber.replaceAll(RegExp(r'[\s\(\)\-]'), '');
// ++
if (phoneNumber.startsWith('+')) {
phoneNumber = '+' +
phoneNumber
.substring(1)
.replaceAll(RegExp(r'[^\d]'), '');
} else {
phoneNumber =
phoneNumber.replaceAll(RegExp(r'[^\d]'), '');
}
logic.state.emailOrPhoneController.text = phoneNumber;
} else {
logic.state.emailOrPhoneController.text = '';
}
//
if (currentContact.fullName != null &&
currentContact.fullName!.isNotEmpty) {
logic.state.keyNameController.text =
currentContact.fullName!;
} else {
logic.state.keyNameController.text = '';
}
});
}
},
),
@ -602,17 +629,42 @@ class _AuthorizedAdminPageState extends State<AuthorizedAdminPage>
onTap: () async {
final Contact? currentContact =
await state.contactPicker.selectContact();
setState(() {
state.contact = currentContact!;
if (currentContact.phoneNumbers!.isNotEmpty) {
state.emailOrPhoneController.text = currentContact
.phoneNumbers![0]
.replaceAll(RegExp(r'\s+\b|\b\s'), '');
}
if (currentContact.fullName!.isNotEmpty) {
state.keyNameController.text = currentContact.fullName!;
}
});
if (currentContact != null) {
setState(() {
state.contact = currentContact;
//
if (currentContact.phoneNumbers != null &&
currentContact.phoneNumbers!.isNotEmpty) {
//
String phoneNumber = currentContact.phoneNumbers![0];
//
phoneNumber =
phoneNumber.replaceAll(RegExp(r'[\s\(\)\-]'), '');
// ++
if (phoneNumber.startsWith('+')) {
phoneNumber = '+' +
phoneNumber
.substring(1)
.replaceAll(RegExp(r'[^\d]'), '');
} else {
phoneNumber =
phoneNumber.replaceAll(RegExp(r'[^\d]'), '');
}
state.emailOrPhoneController.text = phoneNumber;
} else {
state.emailOrPhoneController.text = '';
}
//
if (currentContact.fullName != null &&
currentContact.fullName!.isNotEmpty) {
state.keyNameController.text = currentContact.fullName!;
} else {
state.keyNameController.text = '';
}
});
}
},
),
)

View File

@ -20,6 +20,7 @@ import 'package:star_lock/tools/pickers/time_picker/model/pduration.dart';
import 'package:star_lock/tools/regularExpression.dart';
import 'package:star_lock/tools/showTipView.dart';
import 'package:star_lock/tools/submitBtn.dart';
import 'package:permission_handler/permission_handler.dart';
class SendElectronicKeyView extends StatefulWidget {
SendElectronicKeyView({required this.type, Key? key}) : super(key: key);
@ -31,6 +32,14 @@ class SendElectronicKeyView extends StatefulWidget {
class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
with AutomaticKeepAliveClientMixin {
late FlutterContactPicker _contactPicker;
@override
void initState() {
super.initState();
_contactPicker = FlutterContactPicker();
}
@override
Widget build(BuildContext context) {
super.build(context);
@ -163,8 +172,8 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
color: Colors.white,
border: Border(
bottom: BorderSide(
color: AppColors.greyLineColor, //
width: 2.0.h, //
color: AppColors.greyLineColor,
width: 2.0.h,
),
)),
child: Row(
@ -174,17 +183,14 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
Expanded(
child: TextField(
controller: logic.getCurrentController(1),
//
maxLines: 1,
inputFormatters: <TextInputFormatter>[
FilteringTextInputFormatter.deny('\n'),
LengthLimitingTextInputFormatter(30),
],
// controller: _controller,
autofocus: false,
textAlign: TextAlign.end,
decoration: InputDecoration(
//
hintText: rightTitle,
hintStyle: TextStyle(fontSize: 22.sp),
focusedBorder: const OutlineInputBorder(
@ -205,9 +211,7 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
fontSize: 22.sp, textBaseline: TextBaseline.alphabetic),
),
),
SizedBox(
width: 10.w,
),
SizedBox(width: 10.w),
Container(
width: 32.w,
height: 32.w,
@ -220,24 +224,88 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
alignment: Alignment.center,
child: InkWell(
onTap: () async {
final Contact? currentContact =
await logic.state.contactPicker.selectContact();
logic.state.contact = currentContact!;
if (currentContact.phoneNumbers!.isNotEmpty) {
logic.state.emailOrPhoneController.text = currentContact
.phoneNumbers![0]
.replaceAll(RegExp(r'\s+\b|\b\s'), '');
}
if (currentContact.fullName!.isNotEmpty) {
logic.state.keyNameController.text =
currentContact.fullName!;
try {
final PermissionStatus status =
await Permission.contacts.request();
if (status.isGranted) {
//
final currentRoute = ModalRoute.of(context);
final Contact? currentContact =
await _contactPicker.selectContact();
//
if (currentRoute?.isCurrent == true && mounted) {
// GetX
if (Get.isRegistered<SendElectronicKeyViewLogic>(
tag: widget.type)) {
final logic = Get.find<SendElectronicKeyViewLogic>(
tag: widget.type);
if (currentContact != null) {
//
if (currentContact.phoneNumbers != null &&
currentContact.phoneNumbers!.isNotEmpty) {
String phoneNumber =
currentContact.phoneNumbers![0];
//
phoneNumber = phoneNumber.replaceAll(
RegExp(r'[\s\(\)\-]'), '');
// ++
if (phoneNumber.startsWith('+')) {
phoneNumber = '+' +
phoneNumber
.substring(1)
.replaceAll(RegExp(r'[^\d]'), '');
} else {
phoneNumber = phoneNumber.replaceAll(
RegExp(r'[^\d]'), '');
}
logic.state.emailOrPhoneController.text =
phoneNumber;
logic.state.emailOrPhone.value = phoneNumber;
}
//
if (currentContact.fullName != null &&
currentContact.fullName!.isNotEmpty) {
logic.state.keyNameController.text =
currentContact.fullName!;
}
// UI
logic.update();
}
}
}
} else {
//
if (mounted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(
content: Text('需要通讯录权限才能选择联系人'.tr),
duration: const Duration(seconds: 2),
),
);
}
}
} catch (e) {
print('Error selecting contact: $e');
if (mounted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(
content: Text('获取通讯录失败,请检查权限设置'.tr),
duration: const Duration(seconds: 2),
),
);
}
}
},
),
),
Container(
color: AppColors.greyLineColor, //
height: 2.0.h, //
color: AppColors.greyLineColor,
height: 2.0.h,
)
],
),
@ -616,17 +684,65 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
alignment: Alignment.center,
child: InkWell(
onTap: () async {
final Contact? currentContact =
await logic.state.contactPicker.selectContact();
logic.state.contact = currentContact!;
if (currentContact.phoneNumbers!.isNotEmpty) {
logic.state.emailOrPhoneController.text = currentContact
.phoneNumbers![0]
.replaceAll(RegExp(r'\s+\b|\b\s'), '');
}
if (currentContact.fullName!.isNotEmpty) {
logic.state.keyNameController.text =
currentContact.fullName!;
try {
final PermissionStatus status =
await Permission.contacts.request();
if (status.isGranted) {
final Contact? currentContact =
await _contactPicker.selectContact();
if (currentContact != null && mounted) {
//
if (currentContact.phoneNumbers != null &&
currentContact.phoneNumbers!.isNotEmpty) {
String phoneNumber = currentContact.phoneNumbers![0];
//
phoneNumber =
phoneNumber.replaceAll(RegExp(r'[\s\(\)\-]'), '');
// ++
if (phoneNumber.startsWith('+')) {
phoneNumber = '+' +
phoneNumber
.substring(1)
.replaceAll(RegExp(r'[^\d]'), '');
} else {
phoneNumber =
phoneNumber.replaceAll(RegExp(r'[^\d]'), '');
}
logic.state.emailOrPhoneController.text = phoneNumber;
logic.state.emailOrPhone.value = phoneNumber;
}
//
if (currentContact.fullName != null &&
currentContact.fullName!.isNotEmpty) {
logic.state.keyNameController.text =
currentContact.fullName!;
}
// UI
logic.update();
}
} else {
//
if (mounted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(
content: Text('需要通讯录权限才能选择联系人'.tr),
duration: const Duration(seconds: 2),
),
);
}
}
} catch (e) {
print('Error selecting contact: $e');
if (mounted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(
content: Text('获取通讯录失败,请检查权限设置'.tr),
duration: const Duration(seconds: 2),
),
);
}
}
},
),
@ -736,7 +852,7 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
child: Text(
'取消'.tr,
style: TextStyle(
color: Colors.black, fontSize: ScreenUtil().setSp(24)),
color: Colors.black, fontSize: 24.sp),
),
onPressed: () {
Navigator.pop(context);
@ -779,7 +895,7 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
Text(
titleStr,
style: TextStyle(
fontSize: ScreenUtil().setSp(20), color: Colors.black),
fontSize: 20.sp, color: Colors.black),
),
],
),

View File

@ -15,8 +15,8 @@ class SendElectronicKeyViewState {
TextEditingController realNameController = TextEditingController(); //
TextEditingController idCardController = TextEditingController(); //
final FlutterContactPicker contactPicker = FlutterContactPicker();
late Contact contact;
// final FlutterContactPicker contactPicker = FlutterContactPicker();
// late Contact contact;
RxBool isRemoteUnlock = false.obs; //
RxBool isAuthentication = false.obs; //

View File

@ -4,7 +4,7 @@ import 'package:star_lock/talk/starChart/constant/talk_status.dart';
class StartChartTalkStatus {
//
TalkStatus _status = TalkStatus.uninitialized;
TalkStatus _status = TalkStatus.none;
//
StartChartTalkStatus._();

View File

@ -155,7 +155,7 @@ dependencies:
# 选择日期时间
flutter_cupertino_datetime_picker: ^3.0.0
# 选择原生通讯录
flutter_native_contact_picker: ^0.0.4
flutter_native_contact_picker: 0.0.7
#底部弹出选择器
flutter_picker: ^2.1.0
#生成二维码