Merge PR 1457

This commit is contained in:
Elias Bonnici 2024-03-22 12:34:50 +01:00
commit e99c2312b2
No known key found for this signature in database
GPG Key ID: 5EAC28EA3F980CCF
6 changed files with 35 additions and 0 deletions

View File

@ -655,6 +655,7 @@
"s_no_export": null,
"s_export": null,
"l_export_configuration_file": null,
"l_exported_can_be_uploaded_at": null,
"@_otp_slot_actions": {},
"s_delete_slot": null,

View File

@ -655,6 +655,7 @@
"s_no_export": "No export",
"s_export": "Export",
"l_export_configuration_file": "Export configuration to file",
"l_exported_can_be_uploaded_at": "Exported credentials can be uploaded at",
"@_otp_slot_actions": {},
"s_delete_slot": "Delete credential",

View File

@ -655,6 +655,7 @@
"s_no_export": null,
"s_export": null,
"l_export_configuration_file": null,
"l_exported_can_be_uploaded_at": null,
"@_otp_slot_actions": {},
"s_delete_slot": null,

View File

@ -655,6 +655,7 @@
"s_no_export": null,
"s_export": null,
"l_export_configuration_file": null,
"l_exported_can_be_uploaded_at": null,
"@_otp_slot_actions": {},
"s_delete_slot": null,

View File

@ -655,6 +655,7 @@
"s_no_export": "Brak eksportu",
"s_export": "Eksportuj",
"l_export_configuration_file": "Eksportuj konfigurację do pliku",
"l_exported_can_be_uploaded_at": null,
"@_otp_slot_actions": {},
"s_delete_slot": "Usuń poświadczenie",

View File

@ -18,11 +18,13 @@ import 'dart:io';
import 'dart:math';
import 'package:file_picker/file_picker.dart';
import 'package:flutter/gestures.dart';
import 'package:flutter/material.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:logging/logging.dart';
import 'package:material_symbols_icons/symbols.dart';
import 'package:url_launcher/url_launcher.dart';
import '../../app/logging.dart';
import '../../app/message.dart';
@ -365,6 +367,17 @@ class _ConfigureYubiOtpDialogState
},
),
],
),
RichText(
text: TextSpan(
text: l10n.l_exported_can_be_uploaded_at,
style: Theme.of(context).textTheme.bodySmall?.copyWith(
color: Theme.of(context).colorScheme.onSurfaceVariant),
children: [
const TextSpan(text: ' '),
_createUploadOtpLink(context)
],
),
)
]
.map((e) => Padding(
@ -376,4 +389,21 @@ class _ConfigureYubiOtpDialogState
),
);
}
TextSpan _createUploadOtpLink(BuildContext context) {
final theme = Theme.of(context);
final uploadOtpUri = Uri.parse('https://upload.yubico.com');
return TextSpan(
text: uploadOtpUri.host,
style:
theme.textTheme.bodySmall?.copyWith(color: theme.colorScheme.primary),
recognizer: TapGestureRecognizer()
..onTap = () async {
await launchUrl(uploadOtpUri, mode: LaunchMode.externalApplication);
},
children: const [
TextSpan(text: ' ') // without this the recognizer takes over whole row
],
);
}
}