You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CoverageController.php 6.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. <?php
  2. namespace App\Http\Controllers\CustomerService;
  3. use Illuminate\Http\Request;
  4. use App\Http\Controllers\Controller;
  5. use Illuminate\Support\Facades\Auth;
  6. use LynX39\LaraPdfMerger\Facades\PdfMerger;
  7. use Carbon\Carbon;
  8. use Validator;
  9. use PDF;
  10. use App\Staff;
  11. use App\Model\StaffDetail;
  12. use App\Model\Form;
  13. use App\Model\Subscriber;
  14. use App\Model\WorkOrder;
  15. use App\Model\PackageDetail;
  16. use App\Model\Company;
  17. use App\Model\Coverage;
  18. use App\Model\Product;
  19. use App\Model\Docket;
  20. class CoverageController extends Controller
  21. {
  22. function random_code($limit) {
  23. return substr(base_convert(sha1(uniqid(mt_rand())), 16, 36), 0, $limit);
  24. }
  25. // function createWorkID($limit) {
  26. // $number = WorkOrder::select('id','wo')->orderBy('created_at','DESC')->first();
  27. // $numberOnly = str_replace('WO-','',$number->wo);
  28. // $numberOnly++;
  29. // return $numberOnly;
  30. // $allowedNumbers = range(0, 9);
  31. // shuffle($allowedNumbers);
  32. // $digits = array_rand($allowedNumbers, $limit);
  33. // $number = '';
  34. // foreach($digits as $d){
  35. // $number .= $allowedNumbers[$d];
  36. // }
  37. // $unique_id = $number;
  38. // return $unique_id;
  39. // }
  40. public function viewCoverageR()
  41. {
  42. $id = Auth::guard('cs')->id();
  43. $user = Staff::with('StaffDetail')->find($id);
  44. $pp = count(WorkOrder::where('status','Pending Non Prelaid')->get());
  45. $sp = count(WorkOrder::where('status','Success Non Prelaid')->get());
  46. $rs = count(WorkOrder::where('status','Reschedule')->get());
  47. $ss = count(WorkOrder::where('status','Suspend')->get());
  48. $cm = count(WorkOrder::where('status','Completed')->get());
  49. return view('customer-service.view_coverageR', compact('user','pp','sp','rs','ss','cm'));
  50. }
  51. public function viewCoverageB()
  52. {
  53. $id = Auth::guard('cs')->id();
  54. $user = Staff::with('StaffDetail')->find($id);
  55. $pp = count(WorkOrder::where('status','Pending Non Prelaid')->get());
  56. $sp = count(WorkOrder::where('status','Success Non Prelaid')->get());
  57. $rs = count(WorkOrder::where('status','Reschedule')->get());
  58. $ss = count(WorkOrder::where('status','Suspend')->get());
  59. $cm = count(WorkOrder::where('status','Completed')->get());
  60. return view('customer-service.view_coverageB', compact('user','pp','sp','rs','ss','cm'));
  61. }
  62. public function viewCoverageForm()
  63. {
  64. $id = Auth::guard('cs')->id();
  65. $user = Staff::with('StaffDetail')->find($id);
  66. $pp = count(WorkOrder::where('status','Pending Non Prelaid')->get());
  67. $sp = count(WorkOrder::where('status','Success Non Prelaid')->get());
  68. $rs = count(WorkOrder::where('status','Reschedule')->get());
  69. $ss = count(WorkOrder::where('status','Suspend')->get());
  70. $cm = count(WorkOrder::where('status','Completed')->get());
  71. return view('customer-service.view_coverage_form',compact('user','pp','sp','rs','ss','cm'));
  72. }
  73. public function editCoverage($cov)
  74. {
  75. $id = Auth::guard('cs')->id();
  76. $user = Staff::with('StaffDetail')->find($id);
  77. $pp = count(WorkOrder::where('status','Pending Non Prelaid')->get());
  78. $sp = count(WorkOrder::where('status','Success Non Prelaid')->get());
  79. $rs = count(WorkOrder::where('status','Reschedule')->get());
  80. $ss = count(WorkOrder::where('status','Suspend')->get());
  81. $cm = count(WorkOrder::where('status','Completed')->get());
  82. $coverage = Coverage::where('_id', $cov)->first();
  83. return view('customer-service.view_coverage_edit', compact('user','pp','sp','rs','ss','cm','coverage'));
  84. }
  85. public function getCoverageR()
  86. {
  87. $coverage = Coverage::where('Type', 'R')->get();
  88. $i=0;
  89. $curr = Carbon::now()->getTimestamp();
  90. $nested_data = array();
  91. foreach ($coverage as $a) {
  92. $i++; $n1 = '';
  93. $reg_time = $a->created_at;
  94. $expiry_date = $reg_time->addDays(3);
  95. $expiry_date = $expiry_date->getTimestamp();
  96. if($curr < $expiry_date) {
  97. $n1 = "New/";
  98. }
  99. $ptype= '';
  100. if(!empty($a->project_type)){
  101. $ptype = $a->project_type;
  102. }
  103. array_push($nested_data, array(
  104. 'index' => $n1.$i,
  105. 'address' => $a->building_name,
  106. 'street' => $a->street,
  107. 'city' => $a->city,
  108. 'state' => $a->state,
  109. 'postcode' => $a->postcode,
  110. 'status_building' => $a->status_building,
  111. 'project_type' => $ptype,
  112. 'action' => $a->_id
  113. ));
  114. }
  115. return \DataTables::of($nested_data)->make(true);
  116. }
  117. public function getCoverageB()
  118. {
  119. $coverage = Coverage::where('Type', 'B')->get();
  120. $i=0;
  121. $curr = Carbon::now()->getTimestamp();
  122. $nested_data = array();
  123. foreach ($coverage as $a) {
  124. $i++; $n1 = '';
  125. $reg_time = $a->created_at;
  126. $expiry_date = $reg_time->addDays(3);
  127. $expiry_date = $expiry_date->getTimestamp();
  128. if($curr < $expiry_date) {
  129. $n1 = "New/";
  130. }
  131. $ptype= '';
  132. if(!empty($a->project_type)){
  133. $ptype = $a->project_type;
  134. }
  135. array_push($nested_data, array(
  136. 'index' => $n1.$i,
  137. 'address' => $a->building_name,
  138. 'street' => $a->street,
  139. 'city' => $a->city,
  140. 'state' => $a->state,
  141. 'postcode' => $a->postcode,
  142. 'status_building' => $a->status_building,
  143. 'project_type' => $a->project_type,
  144. 'action' => $a->_id
  145. ));
  146. }
  147. return \DataTables::of($nested_data)->make(true);
  148. }
  149. public function addCoverage(Request $request)
  150. {
  151. $coverage = [
  152. 'Type' => $request->get('tapp'),
  153. 'building_name' => strtoupper($request->get('name')),
  154. 'project_type' => $request->get('ptype'),
  155. 'street' => strtoupper($request->get('street')),
  156. 'city' => strtoupper($request->get('city')),
  157. 'state' => strtoupper($request->get('state')),
  158. 'postcode' => $request->get('postcode'),
  159. 'installation_fee' => $request->get('fee'),
  160. 'status_building' => $request->get('status'),
  161. 'jmb_email' => $request->get('jmb'),
  162. ];
  163. $coverageUpdate = Coverage::create($coverage);
  164. return redirect()->back()->with('success_msg', 'message');
  165. }
  166. public function updateCoverage(Request $request)
  167. {
  168. $coverage = Coverage::where('_id', $request->get('coverage_id'))->first();
  169. $coverage->building_name = strtoupper($request->get('name'));
  170. $coverage->city = strtoupper($request->get('city'));
  171. $coverage->state = strtoupper($request->get('state'));
  172. $coverage->street = strtoupper($request->get('street'));
  173. $coverage->status_building = $request->get('status');
  174. $coverage->postcode = $request->get('postcode');
  175. $coverage->project_type = $request->get('ptype');
  176. $coverage->save();
  177. return redirect()->back()->with('success_msg', 'Success! Update coverage '.$request->get('name'));
  178. }
  179. public function deleteCoverage(Request $request)
  180. {
  181. $coverage = Coverage::where('_id',$request->id)->first();
  182. if(!empty($coverage)){
  183. $coverage->delete();
  184. return 'true';
  185. }else {
  186. return 'false';
  187. }
  188. }
  189. }