/* * 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 * */ import 'package:flutter/material.dart'; import 'package:flutter_svg/svg.dart'; import '../../themes/stack_colors.dart'; import '../../utilities/assets.dart'; import '../../utilities/text_styles.dart'; import '../../utilities/util.dart'; import 'custom_text_button.dart'; class DeleteButton extends StatelessWidget { const DeleteButton({ Key? key, this.width, this.height, this.label, this.onPressed, this.enabled = true, this.desktopMed = false, }) : super(key: key); 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()!.accentColorRed : Theme.of(context) .extension()! .buttonTextSecondaryDisabled, ); } else { return enabled ? STextStyles.desktopButtonSecondaryEnabled(context).copyWith( color: Theme.of(context).extension()!.accentColorRed) : STextStyles.desktopButtonSecondaryDisabled(context); } } else { return STextStyles.button(context).copyWith( color: enabled ? Theme.of(context).extension()!.accentColorRed : Theme.of(context) .extension()! .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()! .getDeleteEnabledButtonStyle(context) : Theme.of(context) .extension()! .getDeleteDisabledButtonStyle(context), child: Row( mainAxisAlignment: MainAxisAlignment.center, children: [ SvgPicture.asset( Assets.svg.trash, width: 20, height: 20, color: enabled ? Theme.of(context).extension()!.accentColorRed : Theme.of(context) .extension()! .buttonTextSecondaryDisabled, ), if (label != null) const SizedBox( width: 10, ), if (label != null) Text( label!, style: getStyle(isDesktop, context), ), ], ), ), ); } }