Merge branch 'hotfix/#718'
This commit is contained in:
commit
bf6bd6416a
3
.gitignore
vendored
3
.gitignore
vendored
@ -11,4 +11,5 @@ npm-debug.log
|
||||
.env
|
||||
robots.txt
|
||||
_ide_helper.php
|
||||
.phpstorm.meta.php
|
||||
.phpstorm.meta.php
|
||||
/storage/debugbar/*
|
@ -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
|
||||
);
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user