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

View File

@ -16,11 +16,7 @@ class FinishShoppingPage extends StatelessWidget {
body: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
IconButton(
onPressed: () {
Navigator.of(context).pop();
},
icon: const Icon(Icons.arrow_back)),
const BackButton(),
Container(
margin: const EdgeInsets.all(20),
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});
List<ReceiptItem> allReceiptItems() {
return receiptItems;
}
ReceiptItem? withProductId(int productId) {
for (var i = 0; i < receiptItems.length; i++) {
if (receiptItems[i].product.id == productId) {