stack_wallet/lib/widgets/desktop/delete_button.dart

111 lines
3.1 KiB
Dart
Raw Permalink 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-11-03 23:53:19 +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/text_styles.dart';
import '../../utilities/util.dart';
import 'custom_text_button.dart';
2022-11-03 23:53:19 +00:00
class DeleteButton extends StatelessWidget {
const DeleteButton({
2024-05-27 23:56:22 +00:00
super.key,
2022-11-03 23:53:19 +00:00
this.width,
this.height,
this.label,
this.onPressed,
this.enabled = true,
this.desktopMed = false,
2024-05-27 23:56:22 +00:00
});
2022-11-03 23:53:19 +00:00
final double? width;
final double? height;
final String? label;
final VoidCallback? onPressed;
final bool enabled;
final bool desktopMed;
TextStyle getStyle(bool isDesktop, BuildContext context) {
if (isDesktop) {
if (desktopMed) {
return STextStyles.desktopTextExtraSmall(context).copyWith(
color: enabled
? Theme.of(context).extension<StackColors>()!.accentColorRed
: Theme.of(context)
.extension<StackColors>()!
.buttonTextSecondaryDisabled,
);
} else {
return enabled
? STextStyles.desktopButtonSecondaryEnabled(context).copyWith(
color:
2024-05-27 23:56:22 +00:00
Theme.of(context).extension<StackColors>()!.accentColorRed,
)
2022-11-03 23:53:19 +00:00
: STextStyles.desktopButtonSecondaryDisabled(context);
}
} else {
return STextStyles.button(context).copyWith(
color: enabled
? Theme.of(context).extension<StackColors>()!.accentColorRed
: Theme.of(context)
.extension<StackColors>()!
.buttonTextSecondaryDisabled,
);
}
}
@override
Widget build(BuildContext context) {
final isDesktop = Util.isDesktop;
return CustomTextButtonBase(
height: desktopMed ? 56 : height,
width: width,
textButton: TextButton(
onPressed: enabled ? onPressed : null,
style: enabled
? Theme.of(context)
.extension<StackColors>()!
2023-01-24 19:29:12 +00:00
.getDeleteEnabledButtonStyle(context)
2022-11-03 23:53:19 +00:00
: Theme.of(context)
.extension<StackColors>()!
2023-01-24 19:29:12 +00:00
.getDeleteDisabledButtonStyle(context),
2022-11-03 23:53:19 +00:00
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
SvgPicture.asset(
Assets.svg.trash,
width: 20,
height: 20,
color: enabled
? Theme.of(context).extension<StackColors>()!.accentColorRed
: Theme.of(context)
.extension<StackColors>()!
.buttonTextSecondaryDisabled,
),
if (label != null)
const SizedBox(
width: 10,
),
if (label != null)
Text(
label!,
style: getStyle(isDesktop, context),
),
],
),
),
);
}
}