Controller.php 5.0 KB

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