stack_wallet/lib/widgets/custom_buttons/app_bar_icon_button.dart

115 lines
3.1 KiB
Dart
Raw Normal View History

2023-05-26 21:21:16 +00:00
/*
* This file is part of Stack Wallet.
*
* Copyright (c) 2023 Cypher Stack
* All Rights Reserved.
* The code is distributed under GPLv3 license, see LICENSE file for details.
* Generated by Cypher Stack on 2023-05-26
*
*/
2022-08-26 08:11:35 +00:00
import 'package:flutter/material.dart';
import 'package:flutter_svg/svg.dart';
2024-05-27 23:56:22 +00:00
import '../../themes/stack_colors.dart';
import '../../utilities/assets.dart';
import '../../utilities/util.dart';
2022-08-26 08:11:35 +00:00
class AppBarIconButton extends StatelessWidget {
const AppBarIconButton({
2024-05-27 23:56:22 +00:00
super.key,
2022-08-26 08:11:35 +00:00
required this.icon,
required this.onPressed,
this.color,
// this.circularBorderRadius = 10.0,
this.size = 36.0,
this.shadows = const [],
this.semanticsLabel = "Button",
2024-05-27 23:56:22 +00:00
});
2022-08-26 08:11:35 +00:00
final Widget icon;
final VoidCallback? onPressed;
final Color? color;
// final double circularBorderRadius;
final double size;
final List<BoxShadow> shadows;
final String semanticsLabel;
2022-08-26 08:11:35 +00:00
@override
Widget build(BuildContext context) {
return Container(
2024-05-27 23:56:22 +00:00
height: size,
width: size,
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(1000),
color: color ?? Theme.of(context).extension<StackColors>()!.background,
boxShadow: shadows,
),
child: Semantics(
excludeSemantics: true,
label: semanticsLabel,
child: MaterialButton(
splashColor: Theme.of(context).extension<StackColors>()!.highlight,
padding: EdgeInsets.zero,
materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(1000),
),
2024-05-27 23:56:22 +00:00
onPressed: onPressed,
child: icon,
),
),
);
2022-08-26 08:11:35 +00:00
}
}
class AppBarBackButton extends StatelessWidget {
2022-09-26 20:21:13 +00:00
const AppBarBackButton({
2024-05-27 23:56:22 +00:00
super.key,
2022-09-26 20:21:13 +00:00
this.onPressed,
this.isCompact = false,
this.size,
this.iconSize,
this.semanticsLabel = "Back Button. Takes Back To Previous Page.",
2024-05-27 23:56:22 +00:00
});
2022-08-26 08:11:35 +00:00
final VoidCallback? onPressed;
2022-09-26 20:21:13 +00:00
final bool isCompact;
final double? size;
final double? iconSize;
final String semanticsLabel;
2022-08-26 08:11:35 +00:00
@override
Widget build(BuildContext context) {
2022-09-19 20:18:31 +00:00
final isDesktop = Util.isDesktop;
2022-08-26 08:11:35 +00:00
return Padding(
2024-05-27 23:56:22 +00:00
padding: isDesktop
? const EdgeInsets.symmetric(
vertical: 20,
horizontal: 24,
)
: const EdgeInsets.all(10),
child: AppBarIconButton(
semanticsLabel: semanticsLabel,
size: size ??
(isDesktop
? isCompact
? 42
: 56
: 32),
color: isDesktop
? Theme.of(context).extension<StackColors>()!.textFieldDefaultBG
: Theme.of(context).extension<StackColors>()!.background,
shadows: const [],
icon: SvgPicture.asset(
Assets.svg.arrowLeft,
width: iconSize ?? (isCompact ? 18 : 24),
height: iconSize ?? (isCompact ? 18 : 24),
color: Theme.of(context).extension<StackColors>()!.topNavIconPrimary,
),
onPressed: onPressed ?? Navigator.of(context).pop,
),
);
2022-08-26 08:11:35 +00:00
}
}