table.blade.php 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <div class="d-flex align-items-center justify-content-between">
  2. <div class="d-flex align-items-center">
  3. <div class="my-2">Showing <b>{{ $rows->firstItem() }}</b> to <b>{{ $rows->lastItem() }}</b> of total
  4. <b>{{ $rows->total() }}</b> records
  5. </div>
  6. </div>
  7. <div>
  8. @if(@$ordersSummary)
  9. <div class="d-flex align-items-start">
  10. @foreach($ordersSummary as $k=>$v)
  11. <div class="ms-2"><b>{{ toHumanReadable($k) }}: </b> ${{ displayAmount('', $v) }}</div>
  12. @endforeach
  13. </div>
  14. @endif
  15. </div>
  16. </div>
  17. <div class="table-responsive scrollable">
  18. <table class="table table-sm table-hover table-bordered mb-0 bg-white">
  19. <thead>
  20. <tr>
  21. <th>#</th>
  22. <th>Invoice</th>
  23. <th>Name</th>
  24. <th class="text-nowrap">Created At</th>
  25. <th class="text-nowrap">Total Amount</th>
  26. <th>Orders</th>
  27. <th>Lab</th>
  28. <th>Lab Request</th>
  29. <th>Trx</th>
  30. </tr>
  31. </thead>
  32. <tbody>
  33. @foreach ($rows as $order)
  34. <?php
  35. $storeOrderDetailJson = $order->detailJson();
  36. $storeOrderSelectedOptions = json_decode(@$storeOrderDetailJson->selected_options ?? "{}");
  37. $selectedLab = @$storeOrderSelectedOptions->lab;
  38. $lab_tests_request_attachment = @$order->getDetailJsonValue('lab_tests_request_attachment');
  39. $results_attachment = @$order->getDetailJsonValue('results_attachment');
  40. $orderTotal = $order->order_total;
  41. ?>
  42. <tr @if ($order->is_cancelled) class="cancelled-order" @endif>
  43. <td class="text-nowrap" style="width:1px">
  44. <a href="{{ route('admin.orders.view.dashboard', $order) }}">{{ $order->orderNumber() }}</a>
  45. </td>
  46. <td style="width:4px;" class="text-center">
  47. <a href="{{ route('admin.orders.view.preview-invoice', $order) }}"><i class="fas fa-file-invoice"></i></a>
  48. </td>
  49. <td class="text-nowrap" style="width:1px">{{ $order->user->full_name }}</td>
  50. <td class="text-nowrap" style="width:1px">{{ friendly_date_time($order->created_at) }}</td>
  51. <td style="width:1px">{{ displayAmount('$', $order->total()) }}</td>
  52. <td style="width:550px">
  53. @if(@$storeOrderSelectedOptions->partner == 1)
  54. <p class="mt-2 mb-0"><b style="font-family:sans-serif">Partner: {{@$storeOrderSelectedOptions->partner_email}}</b></p>
  55. @endif
  56. @if(@$results_attachment)
  57. <p class="mt-2 p-1 bg-light border"><b>Lab Report: <a class="ms-2 text-sm text-success" href="{{ $results_attachment['attachmentAccessTokenUrl'] }}" target="_blank"><i class="fal fa-file-pdf"></i> Download PDF</a></b></p>
  58. @endif
  59. </td>
  60. <td>
  61. @if($selectedLab)
  62. <?= selected_lab_html_address($selectedLab); ?>
  63. @else
  64. ---
  65. @endif
  66. </td>
  67. <td style="width:1px">
  68. <div class="d-flex">
  69. <span class="me-2">@include("app.my-account.admin.orders.forms.upload-lab-tests-request-attachment", ['edit' => true])</span>
  70. @if(@$lab_tests_request_attachment)
  71. <a class="text-nowrap text-primary" href="{{ $lab_tests_request_attachment['attachmentAccessTokenUrl'] .'?fileType=lab_tests_request_attachment' }}" target="_blank"><i class="fal fa-file-pdf"></i> {{ $lab_tests_request_attachment['orginalFileName'] }}</a>
  72. @else
  73. <small class="text-muted">not uploaded</small>
  74. @endif
  75. </div>
  76. </td>
  77. <td class="text-nowrap">
  78. <?php $finalTrx = $order->finalFinancialTransaction(); ?>
  79. @if (@$finalTrx)
  80. @if ($finalTrx->charge_or_refund == 'CHARGE')
  81. <span><i class="fa-duotone fa-circle-check fa-fw text-success"></i> CHARGED</span>
  82. @else
  83. <span><i class="fa-duotone fa-circle-xmark fa-fw text-danger"></i> REFUNDED</span>
  84. @endif
  85. @else
  86. <span><i class="fa-duotone fa-circle-xmark fa-fw text-danger"></i> NOT CHARGED</span>
  87. @endif
  88. </td>
  89. </tr>
  90. @endforeach
  91. </tbody>
  92. </table>
  93. </div>
  94. <script>
  95. (function($) {
  96. var ordersTable = {
  97. checkedOrders: [],
  98. initSelectAll: function() {
  99. var self = this;
  100. var multiCheckbox = $('[multi-check]');
  101. var orderCheckboxes = $('[order-check]');
  102. multiCheckbox.click(function(e) {
  103. var isChecked = e.target.checked ? true : false;
  104. var checkedOrders = [];
  105. if (isChecked) {
  106. $.each(orderCheckboxes, function(i, order) {
  107. var orderID = $(order).data('id');
  108. checkedOrders.push(orderID);
  109. $(order).attr('checked', true);
  110. });
  111. } else {
  112. $.each(orderCheckboxes, function(i, order) {
  113. $(order).attr('checked', false);
  114. });
  115. }
  116. self.updateCheckedOrders(checkedOrders);
  117. });
  118. },
  119. initSingleOrderCheckbox: function() {
  120. var self = this;
  121. $('[order-check]').click(function(e) {
  122. var input = e.target;
  123. var orderID = $(input).data('id');
  124. var isChecked = input.checked ? true : false;
  125. var checkedOrders = [...self.checkedOrders];
  126. if (isChecked) {
  127. checkedOrders.push(orderID);
  128. } else {
  129. var index = checkedOrders.indexOf(orderID);
  130. checkedOrders.splice(index, 1);
  131. }
  132. self.updateCheckedOrders(checkedOrders);
  133. });
  134. },
  135. updateCheckedOrders: function(orders) {
  136. var self = this;
  137. self.checkedOrders = orders;
  138. if ($('[order-check]:checked').length === $('[order-check]').length) {
  139. $('[multi-check]').prop('checked', true);
  140. } else {
  141. $('[multi-check]').prop('checked', false);
  142. }
  143. $('input[name=selectedIDs]').val(JSON.stringify(self.checkedOrders));
  144. if (self.checkedOrders.length) {
  145. $('#GenerateInvoicesPdfForm').removeClass('d-none');
  146. } else {
  147. $('#GenerateInvoicesPdfForm').addClass('d-none');
  148. }
  149. },
  150. init: function() {
  151. this.initSelectAll();
  152. this.initSingleOrderCheckbox();
  153. }
  154. };
  155. ordersTable.init();
  156. })(jQuery);
  157. </script>