This repository has been archived on 2025-08-25. You can view files and clone it, but you cannot make any changes to it's state, such as pushing and creating new issues, pull requests or comments.
Seshat/lib/ui/sell_page/view_model/sell_view_model.dart
2025-08-15 23:23:43 +02:00

238 lines
6.3 KiB
Dart

import 'package:flutter/widgets.dart';
import 'package:mobile_scanner/mobile_scanner.dart';
import 'package:seshat/data/repositories/bal_repository.dart';
import 'package:seshat/data/repositories/book_instance_repository.dart';
import 'package:seshat/data/repositories/book_repository.dart';
import 'package:seshat/data/repositories/owner_repository.dart';
import 'package:seshat/domain/models/bal.dart';
import 'package:seshat/domain/models/book.dart';
import 'package:seshat/domain/models/book_instance.dart';
import 'package:seshat/domain/models/book_stack.dart';
import 'package:seshat/domain/models/owner.dart';
import 'package:seshat/domain/models/search_result.dart';
import 'package:seshat/utils/command.dart';
import 'package:seshat/utils/result.dart';
class SellViewModel extends ChangeNotifier {
SellViewModel({
required BalRepository balRepository,
required BookInstanceRepository bookInstanceRepository,
required BookRepository bookRepository,
required OwnerRepository ownerRepository,
}) : _balRepository = balRepository,
_bookInstanceRepository = bookInstanceRepository,
_bookRepository = bookRepository,
_ownerRepository = ownerRepository {
load = Command0(_load)..execute();
}
final BalRepository _balRepository;
final BookInstanceRepository _bookInstanceRepository;
final BookRepository _bookRepository;
final OwnerRepository _ownerRepository;
bool _showScan = false;
bool get showScan => _showScan;
set showScan(bool newValue) {
_showScan = newValue;
notifyListeners();
}
/*
* ===============================
* =====[ BOOKS & INSTANCES ]=====
* ===============================
*/
final List<BookStack> _soldBooks = [];
List<BookStack> get soldBooks => _soldBooks;
final List<BookStack> _scannedBooks = [];
List<BookStack> get scannedBooks => _scannedBooks;
bool isScanLoaded = false;
bool isSendingSell = false;
double minimumAmount = 0;
void sellBook(BookStack addedBook) {
minimumAmount += addedBook.instance.price;
_soldBooks.add(addedBook);
notifyListeners();
}
void sendSell(double givenAmount) async {
isSendingSell = true;
notifyListeners();
List<BookInstance> toSend = [];
int nbOfPl = 0;
for (BookStack book in _soldBooks) {
if (book.instance.price != 0) {
book.instance.soldPrice = book.instance.price;
givenAmount -= book.instance.price;
toSend.add(book.instance);
} else {
nbOfPl++;
}
}
if (nbOfPl != 0) {
double amountPerPl = givenAmount / nbOfPl;
for (BookStack book in _soldBooks) {
if (book.instance.price == 0) {
book.instance.soldPrice = amountPerPl;
toSend.add(book.instance);
}
}
}
await _bookInstanceRepository.sellBooks(toSend);
_soldBooks.clear();
isSendingSell = false;
notifyListeners();
}
void deleteBook(int id) {
_soldBooks.removeWhere((book) => book.instance.id == id);
notifyListeners();
}
Future<void> searchBook(String title, String author) async {
Bal? bal = await _balRepository.ongoingBal();
isScanLoaded = false;
_scannedBooks.clear();
final result = await _bookInstanceRepository.getBySearch(
bal!.id,
title,
author,
);
switch (result) {
case Ok():
for (SearchResult searchResult in result.value) {
if (searchResult.instance.available == false) {
continue;
}
if (_soldBooks
.where((book) => book.instance.id == searchResult.instance.id)
.isNotEmpty) {
continue;
}
Owner owner;
final result2 = await _ownerRepository.getOwnerById(
searchResult.instance.ownerId,
);
switch (result2) {
case Ok():
owner = result2.value;
break;
case Error():
continue;
}
_scannedBooks.add(
BookStack(searchResult.book, searchResult.instance, owner),
);
}
break;
case Error():
break;
}
isScanLoaded = true;
notifyListeners();
return;
}
Future<void> scanBook(BarcodeCapture barcode) async {
isScanLoaded = false;
int ean = int.parse(barcode.barcodes.first.rawValue!);
Bal? bal = await _balRepository.ongoingBal();
_scannedBooks.clear();
final result = await _bookInstanceRepository.getByEan(bal!.id, ean);
switch (result) {
case Ok():
Book book;
final result2 = await _bookRepository.getBookById(
result.value.first.bookId,
);
switch (result2) {
case Ok():
book = result2.value;
break;
case Error():
return;
}
for (BookInstance instance in result.value) {
if (instance.available == false) {
continue;
}
if (_soldBooks
.where((book) => book.instance.id == instance.id)
.isNotEmpty) {
continue;
}
Owner owner;
final result3 = await _ownerRepository.getOwnerById(instance.ownerId);
switch (result3) {
case Ok():
owner = result3.value;
break;
case Error():
continue;
}
_scannedBooks.add(BookStack(book, instance, owner));
}
break;
case Error():
break;
}
isScanLoaded = true;
notifyListeners();
return;
}
/*
* =================
* =====[ BAL ]=====
* =================
*/
Bal? _currentBal;
get currentBal => _currentBal;
/*
* =================================
* =====[ COMMAND AND LOADING ]=====
* =================================
*/
late final Command0 load;
bool isLoaded = false;
Future<Result<void>> _load() async {
final result1 = await _loadBal();
switch (result1) {
case Ok():
isLoaded = true;
break;
default:
break;
}
notifyListeners();
return result1;
}
Future<Result<void>> _loadBal() async {
final result = await _balRepository.getBals();
switch (result) {
case Ok():
_currentBal = result.value
.where((bal) => bal.state == BalState.ongoing)
.firstOrNull;
break;
case Error():
break;
}
return result;
}
}