hasMany(Expense::class); } public function company(): BelongsTo { return $this->belongsTo(Company::class); } public function getFormattedCreatedAtAttribute(mixed $value): string { $dateFormat = CompanySetting::getSetting('carbon_date_format', $this->company_id); return Carbon::parse($this->created_at)->format($dateFormat); } public function getAmountAttribute(): float { return $this->expenses()->sum('amount'); } public function scopeWhereCompany(Builder $query): void { $query->where('company_id', request()->header('company')); } public function scopeWhereCategory(Builder $query, int $category_id): void { $query->orWhere('id', $category_id); } public function scopeWhereSearch(Builder $query, string $search): void { $query->where('name', 'LIKE', '%'.$search.'%'); } /** * Apply multiple filter conditions including category, company, and search. */ public function scopeApplyFilters(Builder $query, array $filters): void { $filters = collect($filters); if ($filters->get('category_id')) { $query->whereCategory($filters->get('category_id')); } if ($filters->get('company_id')) { $query->whereCompany($filters->get('company_id')); } if ($filters->get('search')) { $query->whereSearch($filters->get('search')); } } /** * @return LengthAwarePaginator|Collection */ public function scopePaginateData(Builder $query, string $limit) { if ($limit == 'all') { return $query->get(); } return $query->paginate($limit); } }