12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. <?php
  2. namespace App\Models;
  3. use App\Services\HelperService;
  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 amount(): Attribute
  24. {
  25. return Attribute::make(
  26. get:fn($value) => HelperService::setRupiahFormat($value, true)
  27. );
  28. }
  29. protected function expDate(): Attribute
  30. {
  31. return Attribute::make(
  32. get:fn($value) => Carbon::parse($value)->translatedFormat('l d/m/Y')
  33. );
  34. }
  35. public function member()
  36. {
  37. return $this->belongsTo(Member::class);
  38. }
  39. public function user()
  40. {
  41. return $this->belongsTo(User::class);
  42. }
  43. public function mutation()
  44. {
  45. return $this->hasOne(Mutation::class);
  46. }
  47. public function scopeFilter($query, array $filters)
  48. {
  49. $query->when($filters['search'] ?? null, function ($query, $search) {
  50. $query->where(function ($query) use ($search) {
  51. $query->orWhereHas('member', function ($query) use ($search) {
  52. $query->where('name', 'like', '%' . $search . '%');
  53. });
  54. });
  55. })->when($filters['startDate'] ?? null, function ($query, $date) {
  56. $query->whereDate('created_at', '>=', $date);
  57. })->when($filters['endDate'] ?? null, function ($query, $date) {
  58. $query->whereDate('created_at', '<=', $date);
  59. });
  60. }
  61. }