You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <?php
  2. namespace App\Models\Setting;
  3. use Akaunting\Money\Currency as ISOCurrencies;
  4. use App\Casts\RateCast;
  5. use App\Models\Banking\Account;
  6. use App\Traits\{Blamable, CompanyOwned, SyncsWithCompanyDefaults};
  7. use Database\Factories\Setting\CurrencyFactory;
  8. use Illuminate\Database\Eloquent\Factories\{Factory, HasFactory};
  9. use Illuminate\Database\Eloquent\Model;
  10. use Illuminate\Database\Eloquent\Relations\{BelongsTo, HasMany, HasOne};
  11. use Wallo\FilamentCompanies\FilamentCompanies;
  12. class Currency extends Model
  13. {
  14. use Blamable;
  15. use CompanyOwned;
  16. use HasFactory;
  17. use SyncsWithCompanyDefaults;
  18. protected $table = 'currencies';
  19. protected $fillable = [
  20. 'company_id',
  21. 'name',
  22. 'code',
  23. 'rate',
  24. 'precision',
  25. 'symbol',
  26. 'symbol_first',
  27. 'decimal_mark',
  28. 'thousands_separator',
  29. 'enabled',
  30. 'created_by',
  31. 'updated_by',
  32. ];
  33. protected $casts = [
  34. 'enabled' => 'boolean',
  35. 'symbol_first' => 'boolean',
  36. 'rate' => RateCast::class,
  37. ];
  38. public function company(): BelongsTo
  39. {
  40. return $this->belongsTo(FilamentCompanies::companyModel(), 'company_id');
  41. }
  42. public function defaultCurrency(): HasOne
  43. {
  44. return $this->hasOne(CompanyDefault::class, 'currency_code', 'code');
  45. }
  46. public function accounts(): HasMany
  47. {
  48. return $this->hasMany(Account::class, 'currency_code', 'code');
  49. }
  50. public function createdBy(): BelongsTo
  51. {
  52. return $this->belongsTo(FilamentCompanies::userModel(), 'created_by');
  53. }
  54. public function updatedBy(): BelongsTo
  55. {
  56. return $this->belongsTo(FilamentCompanies::userModel(), 'updated_by');
  57. }
  58. public static function getAvailableCurrencyCodes(): array
  59. {
  60. $allISOCurrencies = static::getAllCurrencies();
  61. $allISOCurrencyCodes = array_keys($allISOCurrencies);
  62. $storedCurrencyCodes = static::query()
  63. ->pluck('code')
  64. ->toArray();
  65. $availableCurrencyCodes = array_diff($allISOCurrencyCodes, $storedCurrencyCodes);
  66. return array_combine($availableCurrencyCodes, $availableCurrencyCodes);
  67. }
  68. public static function getAllCurrencies(): array
  69. {
  70. return ISOCurrencies::getCurrencies();
  71. }
  72. public static function getDefaultCurrencyCode(): ?string
  73. {
  74. $defaultCurrency = static::query()
  75. ->where('enabled', true)
  76. ->first();
  77. return $defaultCurrency?->code ?? null;
  78. }
  79. public static function convertBalance($balance, $oldCurrency, $newCurrency): int
  80. {
  81. $currencies = self::whereIn('code', [$oldCurrency, $newCurrency])->get();
  82. $oldCurrency = $currencies->firstWhere('code', $oldCurrency);
  83. $newCurrency = $currencies->firstWhere('code', $newCurrency);
  84. $oldRate = $oldCurrency->rate;
  85. $newRate = $newCurrency->rate;
  86. $cleanBalance = (int) filter_var($balance, FILTER_SANITIZE_NUMBER_INT);
  87. $convertedBalance = ($cleanBalance / $oldRate) * $newRate;
  88. return round($convertedBalance);
  89. }
  90. protected static function newFactory(): Factory
  91. {
  92. return CurrencyFactory::new();
  93. }
  94. }