|
1
|
|
|
<?php |
|
2
|
|
|
|
|
3
|
|
|
namespace App\Http\Controllers; |
|
4
|
|
|
|
|
5
|
|
|
use Illuminate\Support\Facades\Gate; |
|
6
|
|
|
use App\Models\JobPoster; |
|
7
|
|
|
use App\Models\Criteria; |
|
8
|
|
|
use App\Models\Assessment; |
|
9
|
|
|
use App\Models\RatingGuideQuestion; |
|
10
|
|
|
use App\Models\RatingGuideAnswer; |
|
11
|
|
|
use App\Models\Lookup\AssessmentType; |
|
12
|
|
|
|
|
13
|
|
|
class AssessmentPlanController extends Controller |
|
14
|
|
|
{ |
|
15
|
|
|
/** |
|
16
|
|
|
* Return all the criteria, Assessments, Assessments, |
|
17
|
|
|
* RatingGuideQuestions, and RatingGuideAnswers associated with a job, |
|
18
|
|
|
* as an array. |
|
19
|
|
|
* |
|
20
|
|
|
* @param JobPoster $jobPoster Job Poster to retrieve assessment plan for. |
|
21
|
|
|
* @return mixed[] |
|
22
|
|
|
*/ |
|
23
|
|
|
public function getForJob(JobPoster $jobPoster) |
|
|
|
|
|
|
24
|
|
|
{ |
|
25
|
|
|
if (Gate::denies('view-assessment-plan', $jobPoster)) { |
|
26
|
|
|
abort(403); |
|
27
|
|
|
} |
|
28
|
|
|
|
|
29
|
|
|
$criteria = Criteria::where('job_poster_id', $jobPoster->id)->get(); |
|
30
|
|
|
$criteriaTranslated = []; |
|
31
|
|
|
foreach ($criteria as $criterion) { |
|
32
|
|
|
// TODO: getTranslationsArray probably makes DB calls every loop. Find a way to profile & optimize. |
|
33
|
|
|
$criteriaTranslated[] = array_merge($criterion->toArray(), $criterion->getTranslationsArray()); |
|
34
|
|
|
} |
|
35
|
|
|
$criteriaIds = $criteria->pluck("id"); |
|
36
|
|
|
$assessments = Assessment::whereIn("criterion_id", $criteriaIds)->get(); |
|
37
|
|
|
// Check for newly created assessment plan, and initialize any empty criteria to have the |
|
38
|
|
|
// "Narrative Review" option set. |
|
39
|
|
|
$assessmentCriteriaIds = $assessments->pluck("criterion_id"); |
|
40
|
|
|
$emptyAssessments = array_diff($criteriaIds->toArray(), $assessmentCriteriaIds->toArray()); |
|
41
|
|
|
if (!empty($emptyAssessments)) { |
|
42
|
|
|
$narrativeReview = AssessmentType::where("key", "narrative_assessment")->first(); |
|
43
|
|
|
foreach ($emptyAssessments as $criterionId) { |
|
44
|
|
|
Assessment::create([ |
|
45
|
|
|
'criterion_id' => $criterionId, |
|
46
|
|
|
'assessment_type_id' => $narrativeReview->id |
|
47
|
|
|
]); |
|
48
|
|
|
} |
|
49
|
|
|
$assessments = Assessment::whereIn("criterion_id", $criteriaIds)->get(); |
|
50
|
|
|
} |
|
51
|
|
|
$questions = RatingGuideQuestion::where('job_poster_id', $jobPoster->id)->get(); |
|
52
|
|
|
$answers = RatingGuideAnswer::whereIn('rating_guide_question_id', $questions->pluck('id'))->get(); |
|
53
|
|
|
return [ |
|
54
|
|
|
'criteria' => $criteriaTranslated, |
|
55
|
|
|
'assessments' => $assessments->toArray(), |
|
56
|
|
|
'rating_guide_questions' => $questions->toArray(), |
|
57
|
|
|
'rating_guide_answers' => $answers->toArray() |
|
58
|
|
|
]; |
|
59
|
|
|
} |
|
60
|
|
|
} |
|
61
|
|
|
|