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.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  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. $allowedNumbers = range(0, 9);
  27. shuffle($allowedNumbers);
  28. $digits = array_rand($allowedNumbers, $limit);
  29. $number = '';
  30. foreach($digits as $d){
  31. $number .= $allowedNumbers[$d];
  32. }
  33. $unique_id = $number;
  34. return $unique_id;
  35. }
  36. public function viewCoverageR()
  37. {
  38. $id = Auth::guard('cs')->id();
  39. $user = Staff::with('StaffDetail')->find($id);
  40. $pp = count(WorkOrder::where('status','Pending Non Prelaid')->get());
  41. $sp = count(WorkOrder::where('status','Success Non Prelaid')->get());
  42. $rs = count(WorkOrder::where('status','Reschedule')->get());
  43. $ss = count(WorkOrder::where('status','Suspend')->get());
  44. $cm = count(WorkOrder::where('status','Completed')->get());
  45. return view('customer-service.view_coverageR', compact('user','pp','sp','rs','ss','cm'));
  46. }
  47. public function viewCoverageB()
  48. {
  49. $id = Auth::guard('cs')->id();
  50. $user = Staff::with('StaffDetail')->find($id);
  51. $pp = count(WorkOrder::where('status','Pending Non Prelaid')->get());
  52. $sp = count(WorkOrder::where('status','Success Non Prelaid')->get());
  53. $rs = count(WorkOrder::where('status','Reschedule')->get());
  54. $ss = count(WorkOrder::where('status','Suspend')->get());
  55. $cm = count(WorkOrder::where('status','Completed')->get());
  56. return view('customer-service.view_coverageB', compact('user','pp','sp','rs','ss','cm'));
  57. }
  58. public function viewCoverageForm()
  59. {
  60. $id = Auth::guard('cs')->id();
  61. $user = Staff::with('StaffDetail')->find($id);
  62. $pp = count(WorkOrder::where('status','Pending Non Prelaid')->get());
  63. $sp = count(WorkOrder::where('status','Success Non Prelaid')->get());
  64. $rs = count(WorkOrder::where('status','Reschedule')->get());
  65. $ss = count(WorkOrder::where('status','Suspend')->get());
  66. $cm = count(WorkOrder::where('status','Completed')->get());
  67. return view('customer-service.view_coverage_form',compact('user','pp','sp','rs','ss','cm'));
  68. }
  69. public function editCoverage($cov)
  70. {
  71. $id = Auth::guard('cs')->id();
  72. $user = Staff::with('StaffDetail')->find($id);
  73. $pp = count(WorkOrder::where('status','Pending Non Prelaid')->get());
  74. $sp = count(WorkOrder::where('status','Success Non Prelaid')->get());
  75. $rs = count(WorkOrder::where('status','Reschedule')->get());
  76. $ss = count(WorkOrder::where('status','Suspend')->get());
  77. $cm = count(WorkOrder::where('status','Completed')->get());
  78. $coverage = Coverage::where('_id', $cov)->first();
  79. return view('customer-service.view_coverage_edit', compact('user','pp','sp','rs','ss','cm','coverage'));
  80. }
  81. public function getCoverageR()
  82. {
  83. $coverage = Coverage::where('Type', 'R')->get();
  84. $i=0;
  85. $curr = Carbon::now()->getTimestamp();
  86. $nested_data = array();
  87. foreach ($coverage as $a) {
  88. $i++; $n1 = '';
  89. $reg_time = $a->created_at;
  90. $expiry_date = $reg_time->addDays(3);
  91. $expiry_date = $expiry_date->getTimestamp();
  92. if($curr < $expiry_date) {
  93. $n1 = "New/";
  94. }
  95. array_push($nested_data, array(
  96. 'index' => $n1.$i,
  97. 'address' => $a->building_name,
  98. // 'street' => $a->street,
  99. 'city' => $a->city,
  100. 'state' => $a->state,
  101. 'postcode' => $a->postcode,
  102. 'status_building' => $a->status_building,
  103. 'action' => $a->_id
  104. ));
  105. }
  106. return \DataTables::of($nested_data)->make(true);
  107. }
  108. public function getCoverageB()
  109. {
  110. $coverage = Coverage::where('Type', 'B')->get();
  111. $i=0;
  112. $curr = Carbon::now()->getTimestamp();
  113. $nested_data = array();
  114. foreach ($coverage as $a) {
  115. $i++; $n1 = '';
  116. $reg_time = $a->created_at;
  117. $expiry_date = $reg_time->addDays(3);
  118. $expiry_date = $expiry_date->getTimestamp();
  119. if($curr < $expiry_date) {
  120. $n1 = "New/";
  121. }
  122. array_push($nested_data, array(
  123. 'index' => $n1.$i,
  124. 'address' => $a->building_name,
  125. // 'street' => $a->street,
  126. 'city' => $a->city,
  127. 'state' => $a->state,
  128. 'postcode' => $a->postcode,
  129. 'status_building' => $a->status_building,
  130. 'action' => $a->_id
  131. ));
  132. }
  133. return \DataTables::of($nested_data)->make(true);
  134. }
  135. public function addCoverage(Request $request)
  136. {
  137. $coverage = [
  138. 'Type' => $request->get('tapp'),
  139. 'building_name' => $request->get('name'),
  140. 'city' => $request->get('city'),
  141. 'state' => $request->get('state'),
  142. 'postcode' => $request->get('postcode'),
  143. 'installation_fee' => $request->get('fee'),
  144. 'status_building' => $request->get('status'),
  145. 'jmb_email' => $request->get('jmb'),
  146. ];
  147. $coverageUpdate = Coverage::create($coverage);
  148. return redirect()->back()->with('success_msg', 'message');
  149. }
  150. public function updateCoverage(Request $request)
  151. {
  152. $coverage = Coverage::where('_id', $request->get('coverage_id'))->first();
  153. $coverage->building_name = $request->get('name');
  154. $coverage->city = $request->get('city');
  155. $coverage->state = $request->get('state');
  156. $coverage->status_building = $request->get('status');
  157. $coverage->postcode = $request->get('postcode');
  158. $coverage->save();
  159. return redirect()->back()->with('success_msg', 'Success! Update coverage '.$request->get('name'));
  160. }
  161. public function deleteCoverage(Request $request)
  162. {
  163. $coverage = Coverage::where('_id',$request->id)->first();
  164. if(!empty($coverage)){
  165. $coverage->delete();
  166. return 'true';
  167. }else {
  168. return 'false';
  169. }
  170. }
  171. }