Purchase.php 1.7KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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", "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 product()
  28. {
  29. return $this->hasOneThrough(
  30. Product::class,
  31. PurchaseDetail::class,
  32. "purchase_number",
  33. "number",
  34. "number",
  35. "product_number"
  36. );
  37. }
  38. public function supplier()
  39. {
  40. return $this->belongsTo(Supplier::class);
  41. }
  42. public function scopeFilter($query, array $filters)
  43. {
  44. $query->when($filters["search"] ?? null, function ($query, $search) {
  45. $query
  46. ->whereHas("supplier", function ($query) use ($search) {
  47. $query
  48. ->where("name", "like", "%" . $search . "%")
  49. ->orWhere("phone", "like", "%" . $search . "%")
  50. ->orWhere("email", "like", "%" . $search . "%");
  51. })
  52. ->orWhere(function ($query) use ($search) {
  53. $query->where("status", "like", "%" . $search . "%");
  54. });
  55. });
  56. }
  57. }