TopUp.php 1.7KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. namespace App\Models;
  3. use App\Services\CurrencyFormatService;
  4. use Carbon\Carbon;
  5. use Illuminate\Database\Eloquent\Casts\Attribute;
  6. use Illuminate\Database\Eloquent\Factories\HasFactory;
  7. use Illuminate\Database\Eloquent\Model;
  8. class TopUp extends Model
  9. {
  10. use HasFactory;
  11. protected $fillable = [
  12. 'amount',
  13. 'exp_date',
  14. 'member_id',
  15. 'user_id',
  16. ];
  17. protected function updatedAt(): Attribute
  18. {
  19. return Attribute::make(
  20. get:fn($value) => Carbon::parse($value)->translatedFormat('l d/m/Y')
  21. );
  22. }
  23. protected function balance(): Attribute
  24. {
  25. return Attribute::make(
  26. get:fn($value) => (new CurrencyFormatService)->setRupiahFormat($value, true)
  27. );
  28. }
  29. public function member()
  30. {
  31. return $this->belongsTo(Member::class);
  32. }
  33. public function user()
  34. {
  35. return $this->belongsTo(User::class);
  36. }
  37. public function scopeFilter($query, array $filters)
  38. {
  39. $query->when($filters['search'] ?? null, function ($query, $search) {
  40. $query->where(function ($query) use ($search) {
  41. $query->orWhereHas('member', function ($query) use ($search) {
  42. $query->where('plat_number', 'like', '%' . $search . '%')
  43. ->orWhere('phone', 'like', '%' . $search . '%');
  44. });
  45. });
  46. })->when($filters['startDate'] ?? null, function ($query, $date) {
  47. $query->whereDate('created_at', '>=', $date);
  48. })->when($filters['endDate'] ?? null, function ($query, $date) {
  49. $query->whereDate('created_at', '<=', $date);
  50. });
  51. }
  52. }