Merge branch 'hotfix/#718'

This commit is contained in:
Luiz Fernando Vid 2019-01-15 15:00:56 -02:00
commit bf6bd6416a
2 changed files with 36 additions and 14 deletions

3
.gitignore vendored
View File

@ -11,4 +11,5 @@ npm-debug.log
.env
robots.txt
_ide_helper.php
.phpstorm.meta.php
.phpstorm.meta.php
/storage/debugbar/*

View File

@ -4,18 +4,24 @@ namespace App\Traits;
use Akaunting\Money\Money;
use Akaunting\Money\Currency;
use App\Models\Setting\Currency as CurrencyModel;
trait Currencies
{
public function convert($amount, $code, $rate, $format = false)
{
$default = new Currency(setting('general.default_currency', 'USD'));
$defaultCurrency = CurrencyModel::where('code', '=', $default->getCurrency())
->first(['code', 'rate']);
$defaultRate = $defaultCurrency ? $defaultCurrency->rate : 1;
$unratedAmount = $amount / $rate;
if ($format) {
$money = Money::$code($amount, true)->convert($default, (double) $rate)->format();
$money = Money::$code($unratedAmount, true)->convert($default, (double)$defaultRate)->format();
} else {
$money = Money::$code($amount)->convert($default, (double) $rate)->getAmount();
$money = Money::$code($unratedAmount)->convert($default, (double)$defaultRate)->getAmount();
}
return $money;
@ -24,9 +30,9 @@ trait Currencies
public function divide($amount, $code, $rate, $format = false)
{
if ($format) {
$money = Money::$code($amount, true)->divide((double) $rate)->format();
$money = Money::$code($amount, true)->divide((double)$rate)->format();
} else {
$money = Money::$code($amount)->divide((double) $rate)->getAmount();
$money = Money::$code($amount)->divide((double)$rate)->getAmount();
}
return $money;
@ -39,9 +45,9 @@ trait Currencies
$code = new Currency($code);
if ($format) {
$money = Money::$default($amount, true)->convert($code, (double) $rate)->format();
$money = Money::$default($amount, true)->convert($code, (double)$rate)->format();
} else {
$money = Money::$default($amount)->convert($code, (double) $rate)->getAmount();
$money = Money::$default($amount)->convert($code, (double)$rate)->getAmount();
}
return $money;
@ -52,9 +58,9 @@ trait Currencies
$code = new Currency($code);
if ($format) {
$money = Money::$default($amount, true)->convert($code, (double) $rate)->format();
$money = Money::$default($amount, true)->convert($code, (double)$rate)->format();
} else {
$money = Money::$default($amount)->convert($code, (double) $rate)->getAmount();
$money = Money::$default($amount)->convert($code, (double)$rate)->getAmount();
}
return $money;
@ -62,22 +68,37 @@ trait Currencies
public function getConvertedAmount($format = false, $with_tax = true)
{
$amount = $with_tax ? $this->amount : (isset($this->amount_without_tax) ? $this->amount_without_tax : $this->amount);
$amount = $this->amount;
if (! $with_tax && isset($this->amount_without_tax)) {
$amount = $this->amount_without_tax;
}
return $this->convert($amount, $this->currency_code, $this->currency_rate, $format);
}
public function getReverseConvertedAmount($format = false, $with_tax = true)
{
$amount = $with_tax ? $this->amount : (isset($this->amount_without_tax) ? $this->amount_without_tax : $this->amount);
$amount = $this->amount;
if (! $with_tax && isset($this->amount_without_tax)) {
$amount = $this->amount_without_tax;
}
return $this->reverseConvert($amount, $this->currency_code, $this->currency_rate, $format);
}
public function getDynamicConvertedAmount($format = false, $with_tax = true)
{
$amount = $with_tax ? $this->amount : (isset($this->amount_without_tax) ? $this->amount_without_tax : $this->amount);
$amount = $this->amount;
if (! $with_tax && isset($this->amount_without_tax)) {
$amount = $this->amount_without_tax;
}
return $this->dynamicConvert($this->default_currency_code, $amount, $this->currency_code, $this->currency_rate, $format);
return $this->dynamicConvert(
$this->default_currency_code,
$amount,
$this->currency_code,
$this->currency_rate,
$format
);
}
}