<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Category extends BaseModel
{
    protected $table = 'categories';

    protected $appends = ['fortuneCount'];

    protected $fillable = ['id', 'name', 'slug', 'parent_id', 'description', 'is_activated', 'is_deleted', 'created_at', 'updated_at'];

    public function scopeActivated($query)
    {
        return $query->where('is_activated', true);
    }

    public function scopePublished($query)
    {
        return $query->where('is_deleted', false)->where('is_activated', true);
    }

    public function fortune()
    {
        return $this->hasMany(Fortuneteller::class, 'category_id', 'id');
    }

    public function getFortuneCountAttribute() {
        return $this->fortune()->count();
    }

    public function parent() {
        return $this->belongsTo(Category::class, 'parent_id', 'id')->with('parent')->select('id', 'name', 'slug', 'parent_id')->where('is_deleted', false)->where('is_activated', true);
    }

    public function item() {
        return $this->hasMany(Category::class, 'parent_id', 'id')->select('id', 'name', 'slug', 'parent_id')->where('is_deleted', false)->where('is_activated', true);
    }
}
