Point.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291
  1. <?php
  2. namespace App\Models;
  3. # use Illuminate\Database\Eloquent\Model;
  4. class Point extends Model
  5. {
  6. protected $table = 'point';
  7. public function childReviews()
  8. {
  9. return $this->hasMany(Point::class, 'parent_point_id', 'id')
  10. ->where('category', 'REVIEW')
  11. ->orderBy('created_at', 'DESC');
  12. }
  13. public function childReviewAddedInNote($_note)
  14. {
  15. $review = Point::where('added_in_note_id', $_note->id)
  16. ->where('category', 'REVIEW')
  17. ->where('parent_point_id', $this->id)
  18. ->orderBy('created_at', 'DESC')
  19. ->first();
  20. if(!!$review) {
  21. $review->data = json_decode($review->data);
  22. }
  23. return $review;
  24. }
  25. public function childPlanAddedInNote($_note)
  26. {
  27. $review = Point::where('added_in_note_id', $_note->id)
  28. ->where('category', 'PLAN')
  29. ->where('parent_point_id', $this->id)
  30. ->orderBy('created_at', 'DESC')
  31. ->first();
  32. if(!!$review) {
  33. $review->data = json_decode($review->data);
  34. }
  35. return $review;
  36. }
  37. public function lastChildReview()
  38. {
  39. return $this->hasOne(Point::class, 'id', 'last_child_review_point_id');
  40. }
  41. public function lastChildReviewNote()
  42. {
  43. return $this->hasOne(Note::class, 'id', 'last_child_review_point_scoped_note_id');
  44. }
  45. public function childPlans()
  46. {
  47. return $this->hasMany(Point::class, 'parent_point_id', 'id')
  48. ->where('category', 'PLAN')
  49. ->orderBy('created_at', 'DESC');
  50. }
  51. public function lastChildPlan()
  52. {
  53. return $this->hasOne(Point::class, 'id', 'last_child_plan_point_id');
  54. }
  55. public function lastChildPlanNote()
  56. {
  57. return $this->hasOne(Note::class, 'id', 'last_child_plan_point_scoped_note_id');
  58. }
  59. public function coreChildReview()
  60. {
  61. return $this->hasOne(Point::class, 'id', 'core_child_review_point_id');
  62. }
  63. public function coreChildPlan()
  64. {
  65. return $this->hasOne(Point::class, 'id', 'core_child_plan_point_id');
  66. }
  67. public function parentPoint()
  68. {
  69. return $this->hasOne(Point::class, 'id', 'parent_point_id');
  70. }
  71. public function client()
  72. {
  73. return $this->hasOne(Client::class, 'id', 'client_id');
  74. }
  75. public function note()
  76. {
  77. return $this->hasOne(Note::class, 'id', 'added_in_note_id');
  78. }
  79. public function relevanceToNote($_note) {
  80. return NotePoint
  81. ::where('is_active', true)
  82. ->where('note_id', $_note->id)
  83. ->where('point_id', $this->id)
  84. ->first();
  85. }
  86. public static function getGlobalSingletonOfCategory(Client $_patient, String $_category, $_assoc = false) {
  87. $point = Point
  88. ::where('client_id', $_patient->id)
  89. ->where('category', $_category)
  90. ->orderBy('created_at', 'DESC')
  91. ->first();
  92. if ($point && @$point->data) {
  93. $point->data = json_decode($point->data, $_assoc);
  94. }
  95. return $point;
  96. }
  97. public static function getIntakePointsOfCategory(Client $_patient, String $_category, Note $_note, $_assoc = false) {
  98. $points = Point
  99. ::where('client_id', $_patient->id)
  100. ->where('category', $_category)
  101. ->where('is_removed_due_to_entry_error', false)
  102. ->where(function ($query1) use ($_note) {
  103. $query1
  104. ->where(function ($query2) use ($_note) {
  105. $query2->where('is_removed', false)
  106. ->where('addition_reason_category', 'ON_INTAKE')
  107. ->where('added_in_note_id', $_note->id);
  108. })
  109. ->orWhere(function ($query2) use ($_note) {
  110. $query2->where('is_removed', true)
  111. ->where('removal_reason_category', 'ON_INTAKE')
  112. ->where('removed_in_note_id', $_note->id);
  113. })
  114. ->orWhere('last_child_review_point_scoped_note_id', $_note->id)
  115. ->orWhereRaw("(SELECT count(id) from note_point WHERE is_active Is TRUE AND note_id = {$_note->id} AND point_id = point.id) > 0");
  116. })
  117. ->orderBy('created_at')
  118. ->get();
  119. foreach ($points as $point) {
  120. if ($point->data) {
  121. $point->data = json_decode($point->data, $_assoc);
  122. }
  123. }
  124. return $points;
  125. }
  126. public static function getPlanPointsOfCategory(Client $_patient, String $_category, Note $_note, $_assoc = false) {
  127. $points = Point
  128. ::where('client_id', $_patient->id)
  129. ->where('category', $_category)
  130. ->where('is_removed_due_to_entry_error', false)
  131. ->where(function ($query1) use ($_note) {
  132. $query1
  133. ->where(function ($query2) use ($_note) {
  134. $query2->where('is_removed', false)
  135. ->where('addition_reason_category', 'DURING_VISIT')
  136. ->where('added_in_note_id', $_note->id);
  137. })
  138. ->orWhere(function ($query2) use ($_note) {
  139. $query2->where('is_removed', true)
  140. ->where('removal_reason_category', 'DURING_VISIT')
  141. ->where('removed_in_note_id', $_note->id);
  142. })
  143. ->orWhere('last_child_plan_point_scoped_note_id', $_note->id)
  144. ->orWhereRaw("(SELECT count(id) from note_point WHERE is_active IS TRUE AND note_id = {$_note->id} AND point_id = point.id) > 0");
  145. })
  146. ->orderBy('created_at')
  147. ->get();
  148. foreach ($points as $point) {
  149. if ($point->data) {
  150. $point->data = json_decode($point->data, $_assoc);
  151. }
  152. }
  153. return $points;
  154. }
  155. public static function getPointsOfCategory(Client $_patient, String $_category, $_assoc = false) {
  156. $points = Point
  157. ::where('client_id', $_patient->id)
  158. ->where('category', $_category)
  159. ->where('is_removed', false)
  160. ->orderBy('created_at')
  161. ->get();
  162. foreach ($points as $point) {
  163. if ($point->data) {
  164. $point->data = json_decode($point->data, $_assoc);
  165. }
  166. }
  167. return $points;
  168. }
  169. public static function getNumPointsOfCategory(Client $_patient, String $_category) {
  170. return Point
  171. ::where('client_id', $_patient->id)
  172. ->where('category', $_category)
  173. ->where('is_removed', false)
  174. ->count();
  175. }
  176. public static function getPointsOfCategoryExtended(Client $_patient, String $_category, Note $_note) {
  177. $points = Point
  178. ::where('client_id', $_patient->id)
  179. ->where('category', $_category);
  180. if($_category !== 'GOAL') {
  181. $points = $points->orderByRaw("((data)::json->'name')::text ASC");
  182. }
  183. else {
  184. $points = $points->orderByRaw("((data)::json->'goal')::text ASC");
  185. }
  186. $points = $points->get();
  187. $pointsByType = [
  188. "ACTIVE" => [],
  189. "HISTORIC" => [],
  190. "ENTRY_ERROR" => [],
  191. ];
  192. foreach ($points as $point) {
  193. if ($point->data) {
  194. $point->data = json_decode($point->data);
  195. }
  196. if(!$point->is_removed) {
  197. $point->state = "ACTIVE";
  198. $pointsByType["ACTIVE"][] = $point;
  199. }
  200. elseif($point->is_removed) {
  201. if(!$point->is_removed_due_to_entry_error) {
  202. $point->state = "HISTORIC";
  203. $pointsByType["HISTORIC"][] = $point;
  204. }
  205. else {
  206. $point->state = "ENTRY_ERROR";
  207. $pointsByType["ENTRY_ERROR"][] = $point;
  208. }
  209. }
  210. }
  211. $points = array_merge($pointsByType["ACTIVE"], $pointsByType["HISTORIC"], $pointsByType["ENTRY_ERROR"]);
  212. return [
  213. $points,
  214. [
  215. "ACTIVE" => count($pointsByType["ACTIVE"]),
  216. "HISTORIC" => count($pointsByType["HISTORIC"]),
  217. "ENTRY_ERROR" => count($pointsByType["ENTRY_ERROR"]),
  218. ]
  219. ];
  220. }
  221. public static function fillPointStateAndBadge(Point $point, Note $note)
  222. {
  223. // state
  224. if (!$point->is_removed) {
  225. $point->state = "ACTIVE";
  226. } elseif ($point->is_removed) {
  227. if (!$point->is_removed_due_to_entry_error) {
  228. $point->state = "HISTORIC";
  229. } else {
  230. $point->state = "ENTRY_ERROR";
  231. }
  232. }
  233. // added/removed info
  234. if ($point->state === 'ACTIVE') {
  235. if ($point->added_in_note_id === $note->id && $point->addition_reason_category === 'DURING_VISIT') {
  236. $point->badge = 'Added During Visit';
  237. } elseif ($point->added_in_note_id === $note->id && $point->addition_reason_category === 'ON_INTAKE') {
  238. $point->badge = 'New Record - Pre-existing';
  239. } elseif ($point->added_in_note_id !== $note->id) {
  240. $point->badge = 'Record Present Before Visit';
  241. }
  242. } elseif ($point->state === 'HISTORIC') {
  243. if ($point->removed_in_note_id === $note->id && $point->removal_reason_category === 'DURING_VISIT') {
  244. $point->badge = 'Removed During Visit';
  245. } elseif ($point->removed_in_note_id === $note->id && $point->removal_reason_category === 'ON_INTAKE') {
  246. $point->badge = 'Marked Removed on Intake';
  247. } elseif ($point->removed_in_note_id !== $note->id) {
  248. $point->badge = 'Historic Record Removed In Previous Visit';
  249. }
  250. } elseif ($point->state === 'ENTRY_ERROR') {
  251. if ($point->removed_in_note_id === $note->id) {
  252. $point->badge = 'Marked as Entry Error During Visit';
  253. }
  254. }
  255. return $point;
  256. }
  257. }