mirror of
https://github.com/Mercantec-GHC/h4-projekt-gruppe-0-sm.git
synced 2025-04-27 16:24:07 +02:00
receipt page
This commit is contained in:
parent
14bbfb7326
commit
ddedaada31
@ -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,
|
||||
);
|
||||
|
@ -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(
|
||||
|
37
mobile/lib/pages/receipt_page.dart
Normal file
37
mobile/lib/pages/receipt_page.dart
Normal 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)),
|
||||
),
|
||||
],
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
@ -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) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user