mirror of
https://github.com/hiddify/hiddify-next.git
synced 2026-06-05 21:05:07 +08:00
74 lines
2.1 KiB
Dart
74 lines
2.1 KiB
Dart
import 'package:fluentui_system_icons/fluentui_system_icons.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:toastification/toastification.dart';
|
|
|
|
enum AlertType {
|
|
info,
|
|
error,
|
|
success;
|
|
|
|
ToastificationType get _toastificationType => switch (this) {
|
|
success => ToastificationType.success,
|
|
error => ToastificationType.error,
|
|
info => ToastificationType.info,
|
|
};
|
|
}
|
|
|
|
class CustomToast extends StatelessWidget {
|
|
const CustomToast(this.message, {this.type = AlertType.info, this.icon, this.duration = const Duration(seconds: 3)});
|
|
|
|
const CustomToast.error(this.message, {this.duration = const Duration(seconds: 5)})
|
|
: type = AlertType.error,
|
|
icon = FluentIcons.error_circle_24_regular;
|
|
|
|
const CustomToast.success(this.message, {this.duration = const Duration(seconds: 3)})
|
|
: type = AlertType.success,
|
|
icon = FluentIcons.checkmark_24_regular;
|
|
|
|
final String message;
|
|
final AlertType type;
|
|
final IconData? icon;
|
|
final Duration duration;
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final scheme = Theme.of(context).colorScheme;
|
|
final color = switch (type) {
|
|
AlertType.info => null,
|
|
AlertType.error => scheme.error,
|
|
AlertType.success => scheme.tertiary,
|
|
};
|
|
|
|
return Container(
|
|
decoration: BoxDecoration(
|
|
borderRadius: const BorderRadius.all(Radius.circular(4)),
|
|
color: Theme.of(context).colorScheme.surface,
|
|
),
|
|
padding: const EdgeInsets.symmetric(horizontal: 12, vertical: 6),
|
|
child: Row(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: [
|
|
if (icon != null) ...[Icon(icon, color: color), const SizedBox(width: 8)],
|
|
Flexible(child: Text(message)),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
|
|
void show(BuildContext context) {
|
|
toastification.show(
|
|
context: context,
|
|
title: Text(message),
|
|
type: type._toastificationType,
|
|
alignment: Alignment.bottomLeft,
|
|
autoCloseDuration: duration,
|
|
style: ToastificationStyle.fillColored,
|
|
pauseOnHover: true,
|
|
showProgressBar: false,
|
|
dragToClose: true,
|
|
closeOnClick: true,
|
|
closeButtonShowType: CloseButtonShowType.onHover,
|
|
);
|
|
}
|
|
}
|