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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  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. array_push($nested_data, array(
  100. 'index' => $n1.$i,
  101. 'address' => $a->building_name,
  102. // 'street' => $a->street,
  103. 'city' => $a->city,
  104. 'state' => $a->state,
  105. 'postcode' => $a->postcode,
  106. 'status_building' => $a->status_building,
  107. 'action' => $a->_id
  108. ));
  109. }
  110. return \DataTables::of($nested_data)->make(true);
  111. }
  112. public function getCoverageB()
  113. {
  114. $coverage = Coverage::where('Type', 'B')->get();
  115. $i=0;
  116. $curr = Carbon::now()->getTimestamp();
  117. $nested_data = array();
  118. foreach ($coverage as $a) {
  119. $i++; $n1 = '';
  120. $reg_time = $a->created_at;
  121. $expiry_date = $reg_time->addDays(3);
  122. $expiry_date = $expiry_date->getTimestamp();
  123. if($curr < $expiry_date) {
  124. $n1 = "New/";
  125. }
  126. array_push($nested_data, array(
  127. 'index' => $n1.$i,
  128. 'address' => $a->building_name,
  129. // 'street' => $a->street,
  130. 'city' => $a->city,
  131. 'state' => $a->state,
  132. 'postcode' => $a->postcode,
  133. 'status_building' => $a->status_building,
  134. 'action' => $a->_id
  135. ));
  136. }
  137. return \DataTables::of($nested_data)->make(true);
  138. }
  139. public function addCoverage(Request $request)
  140. {
  141. $coverage = [
  142. 'Type' => $request->get('tapp'),
  143. 'building_name' => $request->get('name'),
  144. 'city' => $request->get('city'),
  145. 'state' => $request->get('state'),
  146. 'postcode' => $request->get('postcode'),
  147. 'installation_fee' => $request->get('fee'),
  148. 'status_building' => $request->get('status'),
  149. 'jmb_email' => $request->get('jmb'),
  150. ];
  151. $coverageUpdate = Coverage::create($coverage);
  152. return redirect()->back()->with('success_msg', 'message');
  153. }
  154. public function updateCoverage(Request $request)
  155. {
  156. $coverage = Coverage::where('_id', $request->get('coverage_id'))->first();
  157. $coverage->building_name = $request->get('name');
  158. $coverage->city = $request->get('city');
  159. $coverage->state = $request->get('state');
  160. $coverage->status_building = $request->get('status');
  161. $coverage->postcode = $request->get('postcode');
  162. $coverage->save();
  163. return redirect()->back()->with('success_msg', 'Success! Update coverage '.$request->get('name'));
  164. }
  165. public function deleteCoverage(Request $request)
  166. {
  167. $coverage = Coverage::where('_id',$request->id)->first();
  168. if(!empty($coverage)){
  169. $coverage->delete();
  170. return 'true';
  171. }else {
  172. return 'false';
  173. }
  174. }
  175. }