yubioath-flutter/lib/app/message.dart

68 lines
2.1 KiB
Dart
Raw Normal View History

import 'dart:async';
2022-07-04 13:56:31 +03:00
import 'dart:ui';
2022-03-25 17:43:32 +03:00
import 'package:flutter/material.dart';
import '../widgets/toast.dart';
import 'models.dart';
2022-03-25 17:43:32 +03:00
void Function() showMessage(
2022-03-25 17:43:32 +03:00
BuildContext context,
String message, {
Duration duration = const Duration(seconds: 2),
}) =>
showToast(context, message, duration: duration);
Future<void> showBottomMenu(
BuildContext context, List<MenuAction> actions) async {
await showBlurDialog(
2022-04-05 17:11:01 +03:00
context: context,
builder: (context) {
return AlertDialog(
title: const Text('Options'),
contentPadding: const EdgeInsets.only(bottom: 24, top: 4),
content: Column(
mainAxisSize: MainAxisSize.min,
children: actions
.map((a) => ListTile(
leading: a.icon,
title: Text(a.text),
contentPadding:
const EdgeInsets.symmetric(horizontal: 24),
enabled: a.action != null,
onTap: a.action == null
? null
: () {
Navigator.pop(context);
a.action?.call(context);
},
))
.toList(),
),
);
});
}
2022-07-04 13:56:31 +03:00
Future<T?> showBlurDialog<T>({
required BuildContext context,
required Widget Function(BuildContext) builder,
RouteSettings? routeSettings,
}) =>
showGeneralDialog(
context: context,
barrierDismissible: true,
barrierLabel: MaterialLocalizations.of(context).modalBarrierDismissLabel,
barrierColor: Colors.black12,
pageBuilder: (ctx, anim1, anim2) => builder(ctx),
transitionDuration: const Duration(milliseconds: 150),
transitionBuilder: (ctx, anim1, anim2, child) => BackdropFilter(
2022-07-05 13:13:56 +03:00
filter: ImageFilter.blur(
sigmaX: 20 * anim1.value, sigmaY: 20 * anim1.value),
2022-07-04 13:56:31 +03:00
child: FadeTransition(
opacity: anim1,
child: child,
),
),
routeSettings: routeSettings,
);