Implemented ledger provider

This commit is contained in:
Stephan D
2026-01-22 18:56:12 +01:00
parent 1b59823105
commit 7ae32cac55
8 changed files with 300 additions and 35 deletions

View File

@@ -1,8 +1,9 @@
import 'package:pshared/api/responses/wallet_balance.dart';
import 'package:pshared/api/responses/wallets.dart';
import 'package:pshared/data/mapper/wallet/response.dart';
import 'package:pshared/models/wallet/balance.dart';
import 'package:pshared/models/wallet/wallet.dart';
import 'package:pshared/api/responses/ledger/accounts.dart';
import 'package:pshared/api/responses/ledger/balance.dart';
import 'package:pshared/data/mapper/ledger/account.dart';
import 'package:pshared/data/mapper/ledger/balance.dart';
import 'package:pshared/models/ledger/account.dart';
import 'package:pshared/models/ledger/balance.dart';
import 'package:pshared/service/authorization/service.dart';
import 'package:pshared/service/services.dart';
@@ -10,22 +11,22 @@ import 'package:pshared/service/services.dart';
class LedgerService {
static const String _objectType = Services.ledger;
static Future<List<WalletModel>> list(String organizationRef) async {
Future<List<LedgerAccount>> list(String organizationRef) async {
final json = await AuthorizationService.getGETResponse(
_objectType,
'/$organizationRef',
);
return WalletsResponse.fromJson(json).toDomain();
return LedgerAccountsResponse.fromJson(json).accounts.map((la) => la.toDomain()).toList();
}
static Future<WalletBalance> getBalance({
Future<LedgerBalance> getBalance({
required String organizationRef,
required String walletRef,
required String ledgerAccountRef,
}) async {
final json = await AuthorizationService.getGETResponse(
_objectType,
'/$organizationRef/$walletRef/balance',
'/$organizationRef/$ledgerAccountRef/balance',
);
return WalletBalanceResponse.fromJson(json).toDomain();
return LedgerBalanceResponse.fromJson(json).balance.toDomain();
}
}