Add Diagnosis Exclusion

This commit is contained in:
2022-08-03 11:24:09 +07:00
parent 8c78fd3d84
commit f72a641f56
27 changed files with 20708 additions and 3 deletions

View File

@@ -62,4 +62,9 @@ class Corporate extends Model
{
return $this->hasMany(CorporateDivision::class, 'corporate_id');
}
public function importLogs()
{
return $this->morphMany(ImportLog::class, 'importable');
}
}

43
app/Models/Exclusion.php Normal file
View File

@@ -0,0 +1,43 @@
<?php
namespace App\Models;
use App\Traits\Blameable;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
class Exclusion extends Model
{
use HasFactory, SoftDeletes, Blameable;
protected $fillable = [
'corporate_id',
'service_code',
'type',
'exclusionable_id',
'exclusionable_type',
];
public function rules()
{
return $this->hasMany(ExclusionRules::class, 'exclusion_id');
}
public function exclusionable()
{
return $this->morphTo();
}
public function scopeFilter($query, Array $filters)
{
$query->when($filters['search'] ?? false, function ($query, $search) {
return $query
->whereHasMorph('exclusionable', [Icd::class], function ($query) use ($search) {
$query->where('code', 'like', "%" . $search . "%")
->orWhere('name', 'like', "%" . $search . "%");
})
;
});
}
}

View File

@@ -0,0 +1,24 @@
<?php
namespace App\Models;
use App\Traits\Blameable;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
class ExclusionRules extends Model
{
use HasFactory, SoftDeletes, Blameable;
protected $fillable = [
'exclusion_id',
'name',
'values',
];
public function exclusion()
{
return $this->belongsTo(Exclusion::class, 'exclusion_id');
}
}

65
app/Models/Icd.php Normal file
View File

@@ -0,0 +1,65 @@
<?php
namespace App\Models;
use App\Traits\Blameable;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
class Icd extends Model
{
use HasFactory, SoftDeletes, Blameable;
protected $table = 'icd';
protected $fillable = [
'rev',
'version',
'code',
'name',
'description',
'parent_code',
];
public $appends = [
'type',
'active'
];
public function getTypeAttribute()
{
return 'ICD-'.$this->rev;
}
public function getActiveAttribute()
{
return empty($this->deleted_at);
}
public function subCategories()
{
return $this->hasMany(Icd::class, 'parent_code', 'code');
}
public function category()
{
return $this->belongsTo(Icd::class, 'parent_code', 'code');
}
public function exclusions()
{
return $this->morphMany(Exclusion::class, 'exclusionable');
}
public function scopeFilter($query, Array $filters)
{
$query->when($filters['search'] ?? false, function ($query, $search) {
return $query
->where('code', 'like', "%" . $search . "%")
->orWhere('name', 'like', "%" . $search . "%")
;
});
}
}

View File

@@ -2,12 +2,28 @@
namespace App\Models;
use App\Traits\Blameable;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
use Illuminate\Support\Str;
class ImportLog extends Model
{
use HasFactory;
use HasFactory, SoftDeletes, Blameable;
protected static function boot()
{
parent::boot();
static::creating(function ($model) {
try {
$model->uuid = (string) Str::orderedUuid(); // generate uuid
} catch (\Exception $e) {
abort(500, $e->getMessage());
}
});
}
protected $fillable = [
'importable_type',