import 'package:cached_network_image/cached_network_image.dart'; import 'package:flutter/material.dart'; class CartBox extends StatefulWidget { const CartBox({Key? key, required this.imageUrl, required this.title, required this.quantity, required this.plus, required this.minus, required this.remove}) : super(key: key); final String imageUrl; final String title; final int quantity; final Function() plus; final Function() minus; final Function() remove; @override State createState() => _CartBoxState(); } class _CartBoxState extends State { @override Widget build(BuildContext context) { var currentQuantity = widget.quantity; return Container( margin: const EdgeInsets.all(8.0), child: Card( color: const Color(0xff212226), shape: RoundedRectangleBorder( borderRadius: BorderRadius.circular(10), ), child: Row( children: [ Flexible( flex: 2, child: CachedNetworkImage( imageUrl: widget.imageUrl, placeholder: (context, url) => const CircularProgressIndicator( color: Color(0xff8B0000), ), errorWidget: (context, url, error) => Image.asset('assets/image-error.webp'), fadeOutDuration: const Duration(milliseconds: 5), imageBuilder: (context, imageProvider) => Container( width: 300, height: 150, decoration: BoxDecoration( image: DecorationImage( image: imageProvider, fit: BoxFit.cover)), ), ), ), Flexible( flex: 3, child: Column( children: [ Container( margin: const EdgeInsets.only(left: 10.0, right: 10.0), child: Text( widget.title, style: const TextStyle( fontSize: 18, color: Colors.white, fontWeight: FontWeight.w600), textAlign: TextAlign.start, ), ), const SizedBox(height: 10,), Row( mainAxisAlignment: MainAxisAlignment.spaceAround, children: [ ElevatedButton( onPressed: (){ currentQuantity++; widget.plus(); setState(() {}); }, child: const Text("+") ), Text(currentQuantity.toString(), style: const TextStyle( fontSize: 15, color: Colors.white, fontWeight: FontWeight.w400) ), ElevatedButton( onPressed: (){ currentQuantity--; widget.minus(); setState(() {}); }, child: const Text("-") ) ], ) ], ), ), ], ), ), ); } }