receipt page

This commit is contained in:
Mikkel Troels Kongsted 2025-02-03 12:09:28 +01:00
parent 14bbfb7326
commit ddedaada31
4 changed files with 56 additions and 10 deletions

View File

@ -1,19 +1,27 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:mobile/pages/receipt_page.dart';
import 'package:mobile/repos/receipt.dart'; import 'package:mobile/repos/receipt.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
class ReceiptsListItem extends StatelessWidget { class ReceiptsListItem extends StatelessWidget {
final String dateFormatted; final String dateFormatted;
final int totalPrice; final int totalPrice;
final ReceiptPage receiptPage;
const ReceiptsListItem( const ReceiptsListItem(
{super.key, required this.dateFormatted, required this.totalPrice}); {super.key,
required this.dateFormatted,
required this.totalPrice,
required this.receiptPage});
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Card( return Card(
child: InkWell( child: InkWell(
borderRadius: const BorderRadius.all(Radius.circular(10)), borderRadius: const BorderRadius.all(Radius.circular(10)),
onTap: () {}, onTap: () {
Navigator.of(context)
.push(MaterialPageRoute(builder: (context) => receiptPage));
},
child: Container( child: Container(
padding: const EdgeInsets.all(20), padding: const EdgeInsets.all(20),
child: Row( child: Row(
@ -34,14 +42,15 @@ class AllReceiptsPage extends StatelessWidget {
return Column( return Column(
children: [ children: [
Expanded(child: Consumer<ReceiptRepo>( Expanded(child: Consumer<ReceiptRepo>(
builder: (_, cartRepo, __) { builder: (_, receiptRepo, __) {
final allReceipts = cartRepo.allReceipts(); final allReceipts = receiptRepo.allReceipts();
return ListView.builder( return ListView.builder(
shrinkWrap: true, shrinkWrap: true,
itemBuilder: (_, idx) { itemBuilder: (_, idx) {
return ReceiptsListItem( return ReceiptsListItem(
dateFormatted: allReceipts[idx].dateFormatted(), dateFormatted: allReceipts[idx].dateFormatted(),
totalPrice: allReceipts[idx].totalPrice()); totalPrice: allReceipts[idx].totalPrice(),
receiptPage: ReceiptPage(receipt: allReceipts[idx]));
}, },
itemCount: allReceipts.length, itemCount: allReceipts.length,
); );

View File

@ -16,11 +16,7 @@ class FinishShoppingPage extends StatelessWidget {
body: Column( body: Column(
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.start,
children: [ children: [
IconButton( const BackButton(),
onPressed: () {
Navigator.of(context).pop();
},
icon: const Icon(Icons.arrow_back)),
Container( Container(
margin: const EdgeInsets.all(20), margin: const EdgeInsets.all(20),
child: Expanded( child: Expanded(

View File

@ -0,0 +1,37 @@
import 'package:flutter/material.dart';
import 'package:mobile/repos/receipt.dart';
import 'package:mobile/widgets/receipt_item.dart';
class ReceiptPage extends StatelessWidget {
final Receipt receipt;
const ReceiptPage({super.key, required this.receipt});
@override
Widget build(BuildContext context) {
final receiptItems = receipt.allReceiptItems();
return Scaffold(
body: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
const BackButton(),
Container(
margin: const EdgeInsets.symmetric(horizontal: 10),
child: Text(receipt.dateFormatted())),
Container(
margin: const EdgeInsets.symmetric(horizontal: 10),
child: Expanded(
child: ListView.builder(
shrinkWrap: true,
itemBuilder: (_, idx) => ReceiptItemView(
pricePerAmount: receiptItems[idx].product.price,
name: receiptItems[idx].product.name,
amount: receiptItems[idx].amount),
itemCount: receiptItems.length)),
),
],
),
);
}
}

View File

@ -61,6 +61,10 @@ class Receipt {
Receipt({required this.date, required this.receiptItems, required this.id}); Receipt({required this.date, required this.receiptItems, required this.id});
List<ReceiptItem> allReceiptItems() {
return receiptItems;
}
ReceiptItem? withProductId(int productId) { ReceiptItem? withProductId(int productId) {
for (var i = 0; i < receiptItems.length; i++) { for (var i = 0; i < receiptItems.length; i++) {
if (receiptItems[i].product.id == productId) { if (receiptItems[i].product.id == productId) {