mirror of
https://github.com/Mercantec-GHC/h4-projekt-gruppe-0-sm.git
synced 2025-04-28 08:44:06 +02:00
receipt page
This commit is contained in:
parent
14bbfb7326
commit
ddedaada31
@ -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,
|
||||||
);
|
);
|
||||||
|
@ -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(
|
||||||
|
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});
|
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) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user