Compare commits
4 Commits
ef908dd4bd
...
0da8e2bc34
Author | SHA1 | Date | |
---|---|---|---|
0da8e2bc34 | |||
049d59d39c | |||
1f7764481c | |||
4462bb1cfb |
@ -18,18 +18,18 @@ enum WorkflowLevel: int
|
||||
case Archived = 200;
|
||||
case Cancelled = 240;
|
||||
|
||||
public function description(): string
|
||||
public function describe(): string
|
||||
{
|
||||
return match ($this) {
|
||||
self::Received => 'Study Received',
|
||||
self::Unassigned => 'Unassigned',
|
||||
self::Assigned => 'Assigned',
|
||||
self::Unassigned => 'Unassigned study',
|
||||
self::Assigned => 'Pending read',
|
||||
self::Dictated => 'Dictated',
|
||||
self::Transcribed => 'Transcribed',
|
||||
self::Repetition => 'Repetition',
|
||||
self::Repetition => 'Repeat interpretation',
|
||||
self::ReadInProgress => 'Read In Progress',
|
||||
self::DraftAvailable => 'Draft interpretation available',
|
||||
self::Finalized => 'Repoort finalized',
|
||||
self::DraftAvailable => 'Draft available',
|
||||
self::Finalized => 'Report finalized',
|
||||
self::UnderReview => 'Under Review',
|
||||
self::Published => 'Report published',
|
||||
self::Archived => 'Study archived',
|
||||
|
@ -44,7 +44,10 @@ public function remove(AssignPhysicianRequest $request)
|
||||
$study->assignedPhysicians()->detach($rad->id);
|
||||
|
||||
if ($study->assignedPhysicians()->count() === 0) {
|
||||
$study->update(['assigned_at' => null]);
|
||||
$study->update([
|
||||
'workflow_level' => WorkflowLevel::Unassigned->value,
|
||||
'assigned_at' => null,
|
||||
]);
|
||||
}
|
||||
|
||||
audit()
|
||||
@ -64,7 +67,10 @@ public function save(AssignPhysicianRequest $request)
|
||||
$rad = User::active()->findOrFail($request->input('rad_id'));
|
||||
|
||||
$study->assignedPhysicians()->attach($rad->id);
|
||||
$study->update(['assigned_at' => now()]);
|
||||
$study->update([
|
||||
'workflow_level' => WorkflowLevel::Assigned->value,
|
||||
'assigned_at' => now(),
|
||||
]);
|
||||
audit()
|
||||
->did(Activity::Assign_Physician)
|
||||
->on($study)
|
||||
|
@ -2,13 +2,13 @@
|
||||
|
||||
namespace App\Http\Controllers\Staff;
|
||||
|
||||
use App\Http\Controllers\HashidControllerBase;
|
||||
use App\Http\Controllers\HashedStudyControllerBase;
|
||||
use App\Models\Study;
|
||||
use App\Services\AuditTrail\Activity;
|
||||
use Closure;
|
||||
use Illuminate\Support\Str;
|
||||
|
||||
class DicomViewerController extends HashidControllerBase
|
||||
class DicomViewerController extends HashedStudyControllerBase
|
||||
{
|
||||
public function stone()
|
||||
{
|
||||
@ -22,8 +22,7 @@ public function ohif()
|
||||
|
||||
private function loadViewer(Closure $callback)
|
||||
{
|
||||
$this->decodeKeys();
|
||||
$study = Study::findOrFail($this->key);
|
||||
$study = $this->getStudy();
|
||||
$url = $callback($study);
|
||||
abort_if(blank($url), 404);
|
||||
$title = Str::limit($study->getPatientDemographic(), 40);
|
||||
|
@ -3,7 +3,6 @@
|
||||
namespace App\Models;
|
||||
|
||||
use App\Domain\ACL\Permission;
|
||||
use App\Domain\Report\ReportStatus;
|
||||
use App\Domain\Study\Priority;
|
||||
use App\Domain\Study\WorkflowLevel;
|
||||
use App\Models\Traits\HasDepartment;
|
||||
@ -177,25 +176,26 @@ public function isArchived(): bool
|
||||
|
||||
public function getWorkflowLevelLedAttribute(): string
|
||||
{
|
||||
// todo: implement
|
||||
$color = match ($this->workflow_level) {
|
||||
WorkflowLevel::Unassigned => 'bg-white',
|
||||
// ReportStatus::Opened => 'bg-secondary',
|
||||
WorkflowLevel::DraftAvailable => 'bg-info',
|
||||
WorkflowLevel::Finalized => 'bg-primary',
|
||||
WorkflowLevel::Published => 'bg-success',
|
||||
default => 'bg-light',
|
||||
};
|
||||
// <i class="fa-solid fa-spinner"></i>
|
||||
$icon = match ($this->workflow_level) {
|
||||
WorkflowLevel::Unassigned => 'spinner text-muted',
|
||||
WorkflowLevel::DraftAvailable => 'pen-to-square',
|
||||
WorkflowLevel::Finalized => 'badge-check',
|
||||
WorkflowLevel::Published => 'shield-check',
|
||||
default => 'spinner text-muted',
|
||||
WorkflowLevel::Received => 'download-2-line',
|
||||
WorkflowLevel::Unassigned => 'checkbox-indeterminate-line',
|
||||
WorkflowLevel::Assigned => 'hourglass-2-line',
|
||||
WorkflowLevel::Dictated => 'speak-line',
|
||||
WorkflowLevel::Transcribed => 'message-2-line',
|
||||
WorkflowLevel::Repetition => 'repeat-line',
|
||||
WorkflowLevel::ReadInProgress => 'battery-charge-line',
|
||||
WorkflowLevel::DraftAvailable => 'draft-line',
|
||||
WorkflowLevel::Finalized => 'folder-chart-line',
|
||||
WorkflowLevel::UnderReview => 'eye-line',
|
||||
WorkflowLevel::Published => 'graduation-cap-line',
|
||||
WorkflowLevel::Archived => 'archive-line',
|
||||
WorkflowLevel::Cancelled => 'close-circle-line',
|
||||
default => 'cog-6-tooth',
|
||||
};
|
||||
|
||||
return sprintf('<span class="badge badge-center rounded-pill %s"><i class="fa-solid fa-%s"></i></span>', $color, $icon);
|
||||
$descr = $this->workflow_level->describe();
|
||||
|
||||
return sprintf('<span class="text-gray" data-bs-toggle="tooltip" data-bs-placement="top" data-bs-original-title="%s" title="%s"><i class="ri-%s"></i></span>', $descr, $descr, $icon);
|
||||
}
|
||||
|
||||
public function getArchiveLink(): ?string
|
||||
@ -370,14 +370,14 @@ public function isUnlocked(): bool
|
||||
return $this->locked_at === null;
|
||||
}
|
||||
|
||||
public function lockStudy(User|int|null $user = null, ?WorkflowLevel $status = null): void
|
||||
public function lockStudy(User|int|null $user = null, ?WorkflowLevel $level = null): void
|
||||
{
|
||||
$params = [
|
||||
'locking_physician_id' => me($user)->id,
|
||||
'locked_at' => now(),
|
||||
];
|
||||
if ($status) {
|
||||
$params['workflow_level'] = $status->value;
|
||||
if ($level !== null) {
|
||||
$params['workflow_level'] = $level->value;
|
||||
}
|
||||
|
||||
$this->update($params);
|
||||
|
@ -112,7 +112,7 @@ public function check(): ?View
|
||||
public function lockStudyIfRequired(): void
|
||||
{
|
||||
if ($this->study->isUnlocked()) {
|
||||
$this->study->lockStudy();
|
||||
$this->study->lockStudy(level: WorkflowLevel::ReadInProgress);
|
||||
audit()
|
||||
->on($this->study)
|
||||
->did(Activity::Study_Lock)
|
||||
|
@ -88,7 +88,7 @@
|
||||
|
||||
<label class="form-check form-check-danger mt-4">
|
||||
<input name="cancel_read" type="checkbox" class="form-check-input"/>
|
||||
<span class="form-check-label">Cancel interpretation by radiologist</span>
|
||||
<span class="form-check-label">No interpretation required</span>
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
|
Loading…
Reference in New Issue
Block a user