fix: 优化删除账号code传4,修改常见问题文案,禁用输入框悬浮按钮,修复登录ios输入框聚焦问题

This commit is contained in:
speakeloudest 2026-01-22 18:47:56 -08:00
parent ab8eb891cc
commit b96008d6dc
5 changed files with 24 additions and 24 deletions

View File

@ -60,9 +60,9 @@ class HIHelpController extends GetxController {
KRMessage( KRMessage(
title: '设备与绑定问题', title: '设备与绑定问题',
content: [ content: [
'在绑定新设备之前请先添加您的邮箱', '在绑定新设备之前请先添加您的邮箱并设置账户密码',
'Hi快VPN支持最多两台设备同时在线包括一台iOS设备或Android加一台Mac或PC。', 'Hi快VPN支持最多两台设备同时在线包括一台iOS设备或Android加一台Mac或PC。',
'如超出设备数量限制,最早登陆的同类设备将会自动下线,需要重新登陆,设备限制为系统固定设定,不支持调整。', '如超出设备数量限制,请先手动移除设备后再进行登录,设备限制为系统固定设定,不支持调整。',
], ],
), ),
KRMessage( KRMessage(

View File

@ -58,7 +58,7 @@ class KRDeleteAccountController extends GetxController {
// API email type // API email type
final result = await _authApi.kr_sendCode( final result = await _authApi.kr_sendCode(
account, // account, //
2, // 4, //
); );
result.fold( result.fold(

View File

@ -159,6 +159,7 @@ class KRDeleteAccountView extends GetView<KRDeleteAccountController> {
height: 50.w, height: 50.w,
child: TextField( child: TextField(
controller: controller.kr_codeController, controller: controller.kr_codeController,
contextMenuBuilder: (context, editableTextState) => const SizedBox.shrink(),
keyboardType: TextInputType.number, keyboardType: TextInputType.number,
textInputAction: TextInputAction.done, textInputAction: TextInputAction.done,
autofillHints: const [AutofillHints.oneTimeCode], autofillHints: const [AutofillHints.oneTimeCode],

View File

@ -169,6 +169,7 @@ class KRInviteView extends GetView<KRInviteController> {
RepaintBoundary( RepaintBoundary(
child: TextField( child: TextField(
controller: controller.otherInviteCodeController, controller: controller.otherInviteCodeController,
contextMenuBuilder: (context, editableTextState) => const SizedBox.shrink(),
textInputAction: TextInputAction.done, textInputAction: TextInputAction.done,
onSubmitted: (_) => controller.kr_handleBindInviteCode(), onSubmitted: (_) => controller.kr_handleBindInviteCode(),
textAlign: TextAlign.center, textAlign: TextAlign.center,

View File

@ -125,7 +125,7 @@ class KRLoginView extends GetView<KRLoginController> {
child: Column( child: Column(
children: [ children: [
Obx(() => _buildStandardInputField( Obx(() => _buildStandardInputField(
controller: controller.accountController, textController: controller.accountController,
hintText: '请输入邮箱地址', hintText: '请输入邮箱地址',
suffixes: const [ suffixes: const [
'@gmail.com', '@gmail.com',
@ -161,7 +161,7 @@ class KRLoginView extends GetView<KRLoginController> {
/// ///
Widget _buildStandardInputField({ Widget _buildStandardInputField({
required TextEditingController controller, required TextEditingController textController,
required String hintText, required String hintText,
bool isPassword = false, bool isPassword = false,
List<String>? suffixes, List<String>? suffixes,
@ -173,8 +173,9 @@ class KRLoginView extends GetView<KRLoginController> {
VoidCallback? onEditingComplete, VoidCallback? onEditingComplete,
}) { }) {
return TextField( return TextField(
controller: controller, controller: textController,
focusNode: focusNode, focusNode: focusNode,
contextMenuBuilder: (context, editableTextState) => const SizedBox.shrink(),
onEditingComplete: onEditingComplete, onEditingComplete: onEditingComplete,
obscureText: isPassword, obscureText: isPassword,
style: KrAppTextStyle( style: KrAppTextStyle(
@ -217,8 +218,8 @@ class KRLoginView extends GetView<KRLoginController> {
// 使 RawAutocomplete // 使 RawAutocomplete
return SizedBox( return SizedBox(
child: RawAutocomplete<String>( child: RawAutocomplete<String>(
textEditingController: controller, textEditingController: textController,
focusNode: FocusNode(), focusNode: this.controller.kr_accountFocusNode,
optionsBuilder: (TextEditingValue textEditingValue) { optionsBuilder: (TextEditingValue textEditingValue) {
final inputText = textEditingValue.text; final inputText = textEditingValue.text;
@ -228,15 +229,10 @@ class KRLoginView extends GetView<KRLoginController> {
// 1. () // 1. ()
if (historyEmails != null) { if (historyEmails != null) {
if (inputText.isEmpty) { if (inputText.isEmpty) {
// RawAutocomplete options fieldViewBuilder
// RawAutocomplete optionsBuilder text
// Focus
// RawAutocomplete initialValue? triggerMode
//
options.addAll(historyEmails); options.addAll(historyEmails);
} else { } else {
options.addAll(historyEmails options.addAll(
.where((email) => email.startsWith(inputText))); historyEmails.where((email) => email.startsWith(inputText)));
} }
} }
@ -260,15 +256,16 @@ class KRLoginView extends GetView<KRLoginController> {
}, },
fieldViewBuilder: ( fieldViewBuilder: (
BuildContext context, BuildContext context,
TextEditingController textEditingController, TextEditingController
textEditingController, // This textEditingController is provided by RawAutocomplete
FocusNode focusNode, FocusNode focusNode,
VoidCallback onFieldSubmitted, VoidCallback onFieldSubmitted,
) { ) {
// 使 controller fieldViewBuilder textEditingController // Here we use the passed in textController, not the textEditingController provided by fieldViewBuilder
// controller // because we need to control the textController externally.
// RawAutocomplete textEditingController // Note: RawAutocomplete listens to textEditingController by default,
// controller RawAutocomplete // if we pass our own textController to RawAutocomplete,
// fieldViewBuilder textEditingController // the fieldViewBuilder's textEditingController is actually the one we passed.
return buildTextField( return buildTextField(
focusNode: focusNode, focusNode: focusNode,
onEditingComplete: onFieldSubmitted, onEditingComplete: onFieldSubmitted,
@ -338,6 +335,7 @@ class KRLoginView extends GetView<KRLoginController> {
height: 50, // height: 50, //
child: TextField( child: TextField(
controller: controller.codeController, controller: controller.codeController,
contextMenuBuilder: (context, editableTextState) => const SizedBox.shrink(),
keyboardType: TextInputType.number, keyboardType: TextInputType.number,
textInputAction: TextInputAction.done, textInputAction: TextInputAction.done,
autofillHints: const [AutofillHints.oneTimeCode], autofillHints: const [AutofillHints.oneTimeCode],