StockProduct.php 1.2KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. <?php
  2. namespace App\Models;
  3. use App\Models\Ppn;
  4. use App\Services\HelperService;
  5. use Illuminate\Database\Eloquent\Model;
  6. use Illuminate\Database\Eloquent\Casts\Attribute;
  7. use Illuminate\Database\Eloquent\Factories\HasFactory;
  8. class StockProduct extends Model
  9. {
  10. use HasFactory;
  11. protected $fillable = ["price", "qty", "ppn", "product_number"];
  12. protected function price(): Attribute
  13. {
  14. return Attribute::make(
  15. get: function ($value) {
  16. $ppn = Ppn::first()->ppn;
  17. return $this->ppn
  18. ? HelperService::addPPN($value, $ppn)
  19. : $value;
  20. }
  21. );
  22. }
  23. public function product()
  24. {
  25. return $this->belongsTo(Product::class, "product_number", "number");
  26. }
  27. public function scopeFilter($query, array $filters)
  28. {
  29. $query->when($filters["search"] ?? null, function ($query, $search) {
  30. $query->whereHas("product", function ($query) use ($search) {
  31. $query
  32. ->where("number", "like", "%" . $search . "%")
  33. ->orWhere("name", "like", "%" . $search . "%");
  34. });
  35. });
  36. }
  37. }