12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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 mutation()
  38. {
  39. return $this->hasOne(Mutation::class);
  40. }
  41. public function scopeFilter($query, array $filters)
  42. {
  43. $query->when($filters['search'] ?? null, function ($query, $search) {
  44. $query->where(function ($query) use ($search) {
  45. $query->orWhereHas('member', function ($query) use ($search) {
  46. $query->where('plat_number', 'like', '%' . $search . '%')
  47. ->orWhere('phone', 'like', '%' . $search . '%');
  48. });
  49. });
  50. })->when($filters['startDate'] ?? null, function ($query, $date) {
  51. $query->whereDate('created_at', '>=', $date);
  52. })->when($filters['endDate'] ?? null, function ($query, $date) {
  53. $query->whereDate('created_at', '<=', $date);
  54. });
  55. }
  56. }