import 'package:flutter/material.dart';
import 'package:flutter_svg/svg.dart';
import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/assets.dart';
import 'package:stackwallet/utilities/util.dart';

class AppBarIconButton extends StatelessWidget {
  const AppBarIconButton({
    Key? key,
    required this.icon,
    required this.onPressed,
    this.color,
    // this.circularBorderRadius = 10.0,
    this.size = 36.0,
    this.shadows = const [],
    this.semanticsLabel = "Button",
  }) : super(key: key);

  final Widget icon;
  final VoidCallback? onPressed;
  final Color? color;
  // final double circularBorderRadius;
  final double size;
  final List<BoxShadow> shadows;
  final String semanticsLabel;

  @override
  Widget build(BuildContext context) {
    return Container(
        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),
            ),
            onPressed: onPressed,
            child: icon,
          ),
        ));
  }
}

class AppBarBackButton extends StatelessWidget {
  const AppBarBackButton({
    Key? key,
    this.onPressed,
    this.isCompact = false,
    this.size,
    this.iconSize,
    this.semanticsLabel = "Back Button. Takes Back To Previous Page.",
  }) : super(key: key);

  final VoidCallback? onPressed;
  final bool isCompact;
  final double? size;
  final double? iconSize;
  final String semanticsLabel;

  @override
  Widget build(BuildContext context) {
    final isDesktop = Util.isDesktop;
    return Padding(
        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,
        ));
  }
}