Controller.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\AppSession;
  4. use App\Models\Note;
  5. use App\Models\NoteTemplate;
  6. use App\Models\Pro;
  7. use App\Models\ProProAccess;
  8. use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
  9. use Illuminate\Foundation\Bus\DispatchesJobs;
  10. use Illuminate\Foundation\Validation\ValidatesRequests;
  11. use Illuminate\Http\Request;
  12. use Illuminate\Routing\Controller as BaseController;
  13. use Illuminate\Support\Facades\Cookie;
  14. use Illuminate\Support\Facades\Http;
  15. class Controller extends BaseController
  16. {
  17. use AuthorizesRequests, DispatchesJobs, ValidatesRequests;
  18. protected $performer = null;
  19. protected $pro = null;
  20. protected $pros = null;
  21. protected $domains = [];
  22. public function __construct()
  23. {
  24. $this->performer = get_current_session();
  25. if($this->performer && $this->performer->pro) {
  26. $this->pro = $this->performer->pro;
  27. view()->share('pro', $this->performer->pro);
  28. }
  29. view()->share('performer', $this->performer);
  30. $this->pros = [];
  31. /*$this->pros = Pro::all();
  32. if($this->pro && $this->pro->pro_type != 'ADMIN'){
  33. $accessiblePros = ProProAccess::where('owner_pro_id', $this->pro->id);
  34. $accessibleProIds = [];
  35. foreach($accessiblePros as $accessiblePro){
  36. $accessibleProIds[] = $accessiblePro->id;
  37. }
  38. $accessibleProIds[] = $this->pro->id;
  39. $this->pros = Pro::whereIn('id', $accessibleProIds)->get();
  40. }*/
  41. view()->share('pros',$this->pros);
  42. // view()->share('notes', Note::all());
  43. // $noteTemplates = NoteTemplate::all();
  44. // view()->share('noteTemplates', $noteTemplates);
  45. $initiatives = ['LHI', 'BHI'];
  46. view()->share('intiatives', $initiatives);
  47. $rmCodes = ['RMB','RM20', 'RM40','RM60'];
  48. view()->share('rmCodes', $rmCodes);
  49. $this->domains = config('constants.domains');
  50. view()->share('domains', $this->domains);
  51. }
  52. public function performer(){
  53. $sessionKey = Cookie::get('sessionKey');
  54. if ($sessionKey == null){
  55. throw new \Exception('No session key in cookie.');
  56. }
  57. $performer = AppSession::where('session_key', $sessionKey)->first();
  58. return $performer;
  59. }
  60. public function getMyClientIds(){
  61. if($this->pro == null){
  62. return [];
  63. }
  64. return $this->pro->getMyClientIds();
  65. }
  66. public function pass($data = null): array
  67. {
  68. return [
  69. 'success' => true,
  70. 'data' => $data,
  71. ];
  72. }
  73. public function fail($message): array
  74. {
  75. return [
  76. 'success' => false,
  77. 'message' => $message
  78. ];
  79. }
  80. public function filterMultiQuery(Request $request, $query, $columnName, $keyName, $valueName1, $valueName2, $onlyDate = true) {
  81. switch($request->input($keyName)) {
  82. case 'EXACTLY':
  83. if($request->input($valueName1)) {
  84. if($onlyDate){
  85. $query->whereDate($columnName, $request->input($valueName1));
  86. }else{
  87. $query->where($columnName, $request->input($valueName1));
  88. }
  89. }
  90. break;
  91. case 'LESS_THAN':
  92. if($request->input($valueName1)) {
  93. $query->where($columnName, '<', $request->input($valueName1));
  94. }
  95. break;
  96. case 'GREATER_THAN':
  97. if($request->input($valueName1)) {
  98. $query->where($columnName, '>', $request->input($valueName1));
  99. }
  100. break;
  101. case 'BETWEEN':
  102. if($request->input($valueName1) && $request->input($valueName2)) {
  103. $query
  104. ->where($columnName, '>=', $request->input($valueName1))
  105. ->where($columnName, '<=', $request->input($valueName2));
  106. }
  107. break;
  108. case 'NOT_BETWEEN':
  109. if($request->input($valueName1) && $request->input($valueName2)) {
  110. $query
  111. ->where(function ($q) use ($request, $columnName, $valueName1, $valueName2) {
  112. $q->where($columnName, '<', $request->input($valueName1))
  113. ->orWhere($columnName, '>', $request->input($valueName2));
  114. });
  115. }
  116. break;
  117. }
  118. }
  119. public function filterSimpleQuery(Request $request, $query, $columnName, $valueName) {
  120. if($request->input($valueName)) {
  121. $query->where($columnName, $request->input($valueName));
  122. }
  123. }
  124. // TODO move to utility
  125. public function callJavaApi($endPoint, $data)
  126. {
  127. $sessionKey = Cookie::get('sessionKey');
  128. $url = config('stag.backendUrl') . $endPoint;
  129. $response = Http::asForm()
  130. ->withHeaders([
  131. 'sessionKey' => $sessionKey
  132. ])
  133. ->post($url, $data)
  134. ->json();
  135. return $response;
  136. }
  137. }