Files
firefly-iii/app/Transformers/BudgetTransformer.php

128 lines
4.9 KiB
PHP
Raw Normal View History

<?php
/**
* BudgetTransformer.php
2020-02-16 13:57:18 +01:00
* Copyright (c) 2019 james@firefly-iii.org
*
* This file is part of Firefly III (https://github.com/firefly-iii).
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
declare(strict_types=1);
namespace FireflyIII\Transformers;
2025-01-03 14:56:06 +01:00
use FireflyIII\Enums\AutoBudgetType;
use FireflyIII\Models\Budget;
2025-01-18 17:20:39 +01:00
use FireflyIII\Models\TransactionCurrency;
use FireflyIII\Support\Facades\Amount;
2025-08-03 17:42:07 +02:00
use FireflyIII\Support\Facades\Steam;
2020-11-15 14:02:29 +01:00
use Symfony\Component\HttpFoundation\ParameterBag;
/**
* Class BudgetTransformer
*/
2018-12-16 13:55:19 +01:00
class BudgetTransformer extends AbstractTransformer
{
2025-08-03 20:17:50 +02:00
private readonly bool $convertToPrimary;
private readonly TransactionCurrency $primaryCurrency;
private array $types;
/**
2018-02-17 10:47:06 +01:00
* BudgetTransformer constructor.
*/
2018-12-16 13:55:19 +01:00
public function __construct()
{
$this->parameters = new ParameterBag();
2025-08-03 20:17:50 +02:00
$this->primaryCurrency = Amount::getPrimaryCurrency();
2025-07-31 20:35:44 +02:00
$this->convertToPrimary = Amount::convertToPrimary();
2025-08-03 20:17:50 +02:00
$this->types = [
AutoBudgetType::AUTO_BUDGET_RESET->value => 'reset',
AutoBudgetType::AUTO_BUDGET_ROLLOVER->value => 'rollover',
AutoBudgetType::AUTO_BUDGET_ADJUSTED->value => 'adjusted',
];
}
2018-02-17 10:47:06 +01:00
/**
* Transform a budget.
*/
public function transform(Budget $budget): array
{
2018-12-12 20:30:25 +01:00
2025-01-18 17:20:39 +01:00
// info for auto budget.
2025-08-03 20:17:50 +02:00
$abType = null;
$abAmount = null;
$abPrimary = null;
$abPeriod = null;
$currency = $budget->meta['currency'] ?? null;
if (null !== $budget->meta['auto_budget']) {
$abType = $this->types[$budget->meta['auto_budget']['type']];
$abAmount = Steam::bcround($budget->meta['auto_budget']['amount'], $currency->decimal_places);
$abPrimary = $this->convertToPrimary ? Steam::bcround($budget->meta['auto_budget']['pc_amount'], $this->primaryCurrency->decimal_places) : null;
$abPeriod = $budget->meta['auto_budget']['period'];
}
2021-03-21 09:15:40 +01:00
2020-10-23 19:11:25 +02:00
return [
2025-08-03 20:17:50 +02:00
'id' => (string)$budget->id,
'created_at' => $budget->created_at->toAtomString(),
'updated_at' => $budget->updated_at->toAtomString(),
'active' => $budget->active,
'name' => $budget->name,
'order' => $budget->order,
'notes' => $budget->meta['notes'],
'auto_budget_type' => $abType,
'auto_budget_period' => $abPeriod,
// new currency settings.
'object_has_currency_setting' => null !== $budget->meta['currency'],
'currency_id' => null === $currency ? null : (string)$currency->id,
'currency_code' => $currency?->code,
'currency_name' => $currency?->name,
'currency_symbol' => $currency?->symbol,
'currency_decimal_places' => $currency?->decimal_places,
'primary_currency_id' => (string)$this->primaryCurrency->id,
'primary_currency_name' => $this->primaryCurrency->name,
'primary_currency_code' => $this->primaryCurrency->code,
'primary_currency_symbol' => $this->primaryCurrency->symbol,
'primary_currency_decimal_places' => $this->primaryCurrency->decimal_places,
'auto_budget_amount' => $abAmount,
'pc_auto_budget_amount' => $abPrimary,
'spent' => $this->beautify($budget->meta['spent']), // always in primary currency.
'pc_spent' => $this->beautify($budget->meta['pc_spent']), // always in primary currency.
'links' => [
[
'rel' => 'self',
2025-08-03 20:17:50 +02:00
'uri' => '/budgets/' . $budget->id,
],
],
];
}
2020-07-12 17:32:48 +02:00
private function beautify(array $array): array
{
$return = [];
foreach ($array as $data) {
2025-08-03 20:17:50 +02:00
$data['sum'] = Steam::bcround($data['sum'], (int)$data['currency_decimal_places']);
2020-07-12 17:32:48 +02:00
$return[] = $data;
}
return $return;
}
2018-03-05 19:35:58 +01:00
}