. */ declare(strict_types=1); namespace FireflyIII\Support\Twig; use FireflyIII\Models\Account as AccountModel; use FireflyIII\Models\TransactionCurrency; use FireflyIII\Repositories\Account\AccountRepositoryInterface; use FireflyIII\Support\Facades\Amount; use Illuminate\Support\Facades\Log; use Twig\Extension\AbstractExtension; use Twig\TwigFilter; use Twig\TwigFunction; use Override; /** * Contains all amount formatting routines. */ class AmountFormat extends AbstractExtension { #[Override] public function getFilters(): array { return [ $this->formatAmount(), $this->formatAmountPlain(), ]; } protected function formatAmount(): TwigFilter { return new TwigFilter( 'formatAmount', static function (string $string): string { $currency = app('amount')->getNativeCurrency(); return app('amount')->formatAnything($currency, $string, true); }, ['is_safe' => ['html']] ); } protected function formatAmountPlain(): TwigFilter { return new TwigFilter( 'formatAmountPlain', static function (string $string): string { $currency = app('amount')->getNativeCurrency(); return app('amount')->formatAnything($currency, $string, false); }, ['is_safe' => ['html']] ); } #[Override] public function getFunctions(): array { return [ $this->formatAmountByAccount(), $this->formatAmountBySymbol(), $this->formatAmountByCurrency(), $this->formatAmountByCode(), ]; } /** * Will format the amount by the currency related to the given account. * * TODO Remove me when v2 hits. */ protected function formatAmountByAccount(): TwigFunction { return new TwigFunction( 'formatAmountByAccount', static function (AccountModel $account, string $amount, ?bool $coloured = null): string { $coloured ??= true; /** @var AccountRepositoryInterface $accountRepos */ $accountRepos = app(AccountRepositoryInterface::class); $currency = $accountRepos->getAccountCurrency($account) ?? app('amount')->getNativeCurrency(); return app('amount')->formatAnything($currency, $amount, $coloured); }, ['is_safe' => ['html']] ); } /** * Will format the amount by the currency related to the given account. */ protected function formatAmountBySymbol(): TwigFunction { return new TwigFunction( 'formatAmountBySymbol', static function (string $amount, string $symbol, ?int $decimalPlaces = null, ?bool $coloured = null): string { $decimalPlaces ??= 2; $coloured ??= true; $currency = new TransactionCurrency(); $currency->symbol = $symbol; $currency->decimal_places = $decimalPlaces; return app('amount')->formatAnything($currency, $amount, $coloured); }, ['is_safe' => ['html']] ); } /** * Will format the amount by the currency related to the given account. */ protected function formatAmountByCurrency(): TwigFunction { return new TwigFunction( 'formatAmountByCurrency', static function (TransactionCurrency $currency, string $amount, ?bool $coloured = null): string { $coloured ??= true; return app('amount')->formatAnything($currency, $amount, $coloured); }, ['is_safe' => ['html']] ); } /** * Use the code to format a currency. */ protected function formatAmountByCode(): TwigFunction { // formatAmountByCode return new TwigFunction( 'formatAmountByCode', static function (string $amount, string $code, ?bool $coloured = null): string { $coloured ??= true; /** @var null|TransactionCurrency $currency */ $currency = TransactionCurrency::whereCode($code)->first(); if (null === $currency) { Log::error(sprintf('Could not find currency with code "%s". Fallback to native currency.', $code)); $currency = Amount::getNativeCurrency(); Log::error(sprintf('Fallback currency is "%s".', $currency->code)); } return app('amount')->formatAnything($currency, $amount, $coloured); }, ['is_safe' => ['html']] ); } }