/* 
 * 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/flutter_svg.dart';
import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/assets.dart';
import 'package:stackwallet/widgets/conditional_parent.dart';
import 'package:stackwallet/widgets/rounded_container.dart';

enum UTXOStatusIconStatus {
  confirmed,
  unconfirmed;
}

class UTXOStatusIcon extends StatelessWidget {
  const UTXOStatusIcon({
    Key? key,
    required this.width,
    required this.height,
    required this.blocked,
    required this.selected,
    required this.status,
    required this.background,
  }) : super(key: key);

  final double width;
  final double height;
  final bool blocked;
  final bool selected;
  final UTXOStatusIconStatus status;
  final Color background;

  final _availableColor = const Color(0xFFF7931A);
  final _blockedColor = const Color(0xFF96B0D6);

  @override
  Widget build(BuildContext context) {
    return ConditionalParent(
      condition: status == UTXOStatusIconStatus.unconfirmed,
      builder: (child) => Stack(
        children: [
          child,
          Positioned(
            right: 0,
            bottom: 0,
            child: Stack(
              children: [
                RoundedContainer(
                  radiusMultiplier: 100,
                  color: background,
                  width: width / 2.8,
                  height: height / 2.8,
                ),
                Positioned(
                  right: width / 2.8 - width / 3,
                  left: width / 2.8 - width / 3,
                  top: height / 2.8 - height / 3,
                  child: SvgPicture.asset(
                    Assets.svg.pending,
                    width: width / 3,
                    height: height / 3,
                  ),
                ),
              ],
            ),
          ),
        ],
      ),
      child: Stack(
        alignment: Alignment.center,
        children: [
          RoundedContainer(
            radiusMultiplier: 100,
            color: selected
                ? Theme.of(context).extension<StackColors>()!.infoItemIcons
                : blocked
                    ? _blockedColor.withOpacity(0.3)
                    : _availableColor.withOpacity(0.2),
            width: width,
            height: height,
          ),
          SvgPicture.asset(
            selected
                ? Assets.svg.coinControl.selected
                : blocked
                    ? Assets.svg.coinControl.blocked
                    : Assets.svg.coinControl.unBlocked,
            width: 20,
            height: 20,
            color: selected
                ? Colors.white
                : blocked
                    ? _blockedColor
                    : _availableColor,
          ),
        ],
      ),
    );
  }
}