Purchase.php 1.4KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <?php
  2. namespace App\Models;
  3. use Carbon\Carbon;
  4. use Illuminate\Database\Eloquent\Casts\Attribute;
  5. use Illuminate\Database\Eloquent\Factories\HasFactory;
  6. use Illuminate\Database\Eloquent\Model;
  7. class Purchase extends Model
  8. {
  9. use HasFactory;
  10. protected $fillable = ["number", "ppn", "status", "supplier_id", "user_id"];
  11. protected function updatedAt(): Attribute
  12. {
  13. return Attribute::make(
  14. get: fn($value) => Carbon::parse($value)->translatedFormat(
  15. "l d/m/y"
  16. )
  17. );
  18. }
  19. public function purchaseDetail()
  20. {
  21. return $this->hasMany(
  22. PurchaseDetail::class,
  23. "purchase_number",
  24. "number"
  25. );
  26. }
  27. public function supplier()
  28. {
  29. return $this->belongsTo(Supplier::class);
  30. }
  31. public function scopeFilter($query, array $filters)
  32. {
  33. $query->when($filters["search"] ?? null, function ($query, $search) {
  34. $query
  35. ->whereHas("supplier", function ($query) use ($search) {
  36. $query
  37. ->where("name", "like", "%" . $search . "%")
  38. ->orWhere("phone", "like", "%" . $search . "%")
  39. ->orWhere("email", "like", "%" . $search . "%");
  40. })
  41. ->orWhere(function ($query) use ($search) {
  42. $query->where("status", "like", "%" . $search . "%");
  43. });
  44. });
  45. }
  46. }