126 lines
3.9 KiB
PHP
126 lines
3.9 KiB
PHP
<?php
|
|
/**
|
|
* Created by PhpStorm.
|
|
* User: merdan
|
|
* Date: 12/9/2018
|
|
* Time: 9:52 PM
|
|
*/
|
|
|
|
namespace App\Models;
|
|
|
|
|
|
use Illuminate\Support\Carbon;
|
|
use Illuminate\Support\Facades\Config;
|
|
use Illuminate\Support\Facades\DB;
|
|
use Illuminate\Support\Str;
|
|
|
|
class Category extends \Illuminate\Database\Eloquent\Model{
|
|
use \Backpack\CRUD\CrudTrait;
|
|
/**
|
|
* Indicates whether the model should be timestamped.
|
|
*
|
|
* @var bool $timestamps
|
|
*/
|
|
public $timestamps = false;
|
|
/**
|
|
* The database table used by the model.
|
|
*
|
|
* @var string $table
|
|
*/
|
|
protected $table = 'categories';
|
|
/**
|
|
* Indicates whether the model should use soft deletes.
|
|
*
|
|
* @var bool $softDelete
|
|
*/
|
|
protected $softDelete = false;
|
|
protected $fillable = ['title_tk','title_ru','view_type','lft','rgt','parent_id','depth'];
|
|
|
|
/**
|
|
* Get the url of the event.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getUrlAttribute()
|
|
{
|
|
// switch ($this->view_type){
|
|
// case 'concert' : $rout_name = "showSubCategoryEventsPage";
|
|
// break;
|
|
// default : $rout_name = "showCategoryEventsPage";
|
|
// break;
|
|
// }
|
|
$rout_name = "showCategoryEventsPage";
|
|
return route($rout_name, ["cat_id"=>$this->id, "cat_slug"=>Str::slug($this->title)]);
|
|
//return URL::to('/') . '/e/' . $this->id . '/' . Str::slug($this->title);
|
|
}
|
|
|
|
public function getTitleAttribute(){
|
|
|
|
return $this->{'title_'.Config::get('app.locale')};
|
|
}
|
|
/**
|
|
* The events associated with the category.
|
|
*
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasMany
|
|
*/
|
|
public function events(){
|
|
return $this->hasMany(\App\Models\Event::class);
|
|
}
|
|
|
|
public function cat_events(){
|
|
return $this->hasMany(\App\Models\Event::class,'sub_category_id')
|
|
->withCount(['stats as views' => function($q){
|
|
$q->select(DB::raw("SUM(views) as v"));
|
|
}]);
|
|
}
|
|
|
|
public function scopeCategoryLiveEvents($query,$limit){
|
|
// dd($this->view_type);
|
|
return $query->select('id','title_tk','title_ru','lft')
|
|
->orderBy('lft')
|
|
->with(['events' => function($q) use($limit){
|
|
$q->select('id','title','description','category_id','sub_category_id','start_date')
|
|
->limit($limit)
|
|
->with('starting_ticket')
|
|
->withCount(['stats as views' => function($q){
|
|
$q->select(DB::raw("SUM(views) as v"));
|
|
}])
|
|
->onLive();
|
|
}]);
|
|
}
|
|
|
|
public function parent(){
|
|
return $this->belongsTo(Category::class,'parent_id');
|
|
}
|
|
|
|
public function children(){
|
|
return $this->hasMany(Category::class,'parent_id')
|
|
->select('id','title_ru','title_tk','parent_id','lft')
|
|
->orderBy('lft');
|
|
}
|
|
public function scopeMain($query){
|
|
return $query->where('depth',1)->orderBy('lft','asc');
|
|
}
|
|
|
|
public function scopeSub($query){
|
|
return $query->where('depth',2)->orderBy('lft','asc');
|
|
}
|
|
|
|
public function scopeChildren($query,$parent_id){
|
|
return $query->where('parent_id',$parent_id)->orderBy('lft','asc');
|
|
}
|
|
|
|
public function scopeWithLiveEvents($query, $orderBy, $start_date = null,$end_date = null, $limit = 8 ){
|
|
return $query->with(['cat_events' => function($query) use ($start_date, $end_date, $limit, $orderBy) {
|
|
$query->select('id','title','description','category_id','sub_category_id','start_date')
|
|
->limit($limit)
|
|
->with('starting_ticket')
|
|
->withCount(['stats as views' => function($q){
|
|
$q->select(DB::raw("SUM(views) as v"));}])
|
|
->onLive($start_date, $end_date)//event scope onLive get only live events
|
|
->orderBy($orderBy['field'],$orderBy['order']);
|
|
}]);
|
|
|
|
}
|
|
|
|
} |