table.blade.php 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  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. </td>
  54. <td>
  55. @if($selectedLab)
  56. <?= selected_lab_html_address($selectedLab); ?>
  57. @else
  58. ---
  59. @endif
  60. </td>
  61. <td style="width:1px">
  62. <div class="d-flex">
  63. <span class="me-2">@include("app.my-account.admin.orders.forms.upload-lab-tests-request-attachment", ['edit' => true])</span>
  64. @if(@$lab_tests_request_attachment)
  65. <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>
  66. @else
  67. <small class="text-muted">not uploaded</small>
  68. @endif
  69. </div>
  70. </td>
  71. <td class="text-nowrap">
  72. <?php $finalTrx = $order->finalFinancialTransaction(); ?>
  73. @if (@$finalTrx)
  74. @if ($finalTrx->charge_or_refund == 'CHARGE')
  75. <span><i class="fa-duotone fa-circle-check fa-fw text-success"></i> CHARGED</span>
  76. @else
  77. <span><i class="fa-duotone fa-circle-xmark fa-fw text-danger"></i> REFUNDED</span>
  78. @endif
  79. @else
  80. <span><i class="fa-duotone fa-circle-xmark fa-fw text-danger"></i> NOT CHARGED</span>
  81. @endif
  82. </td>
  83. </tr>
  84. @endforeach
  85. </tbody>
  86. </table>
  87. </div>
  88. <script>
  89. (function($) {
  90. var ordersTable = {
  91. checkedOrders: [],
  92. initSelectAll: function() {
  93. var self = this;
  94. var multiCheckbox = $('[multi-check]');
  95. var orderCheckboxes = $('[order-check]');
  96. multiCheckbox.click(function(e) {
  97. var isChecked = e.target.checked ? true : false;
  98. var checkedOrders = [];
  99. if (isChecked) {
  100. $.each(orderCheckboxes, function(i, order) {
  101. var orderID = $(order).data('id');
  102. checkedOrders.push(orderID);
  103. $(order).attr('checked', true);
  104. });
  105. } else {
  106. $.each(orderCheckboxes, function(i, order) {
  107. $(order).attr('checked', false);
  108. });
  109. }
  110. self.updateCheckedOrders(checkedOrders);
  111. });
  112. },
  113. initSingleOrderCheckbox: function() {
  114. var self = this;
  115. $('[order-check]').click(function(e) {
  116. var input = e.target;
  117. var orderID = $(input).data('id');
  118. var isChecked = input.checked ? true : false;
  119. var checkedOrders = [...self.checkedOrders];
  120. if (isChecked) {
  121. checkedOrders.push(orderID);
  122. } else {
  123. var index = checkedOrders.indexOf(orderID);
  124. checkedOrders.splice(index, 1);
  125. }
  126. self.updateCheckedOrders(checkedOrders);
  127. });
  128. },
  129. updateCheckedOrders: function(orders) {
  130. var self = this;
  131. self.checkedOrders = orders;
  132. if ($('[order-check]:checked').length === $('[order-check]').length) {
  133. $('[multi-check]').prop('checked', true);
  134. } else {
  135. $('[multi-check]').prop('checked', false);
  136. }
  137. $('input[name=selectedIDs]').val(JSON.stringify(self.checkedOrders));
  138. if (self.checkedOrders.length) {
  139. $('#GenerateInvoicesPdfForm').removeClass('d-none');
  140. } else {
  141. $('#GenerateInvoicesPdfForm').addClass('d-none');
  142. }
  143. },
  144. init: function() {
  145. this.initSelectAll();
  146. this.initSingleOrderCheckbox();
  147. }
  148. };
  149. ordersTable.init();
  150. })(jQuery);
  151. </script>