table.blade.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  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>Lab</th>
  27. <th>Lab Request</th>
  28. <th>Trx</th>
  29. </tr>
  30. </thead>
  31. <tbody>
  32. @foreach ($rows as $order)
  33. <?php
  34. $storeOrderDetailJson = $order->detailJson();
  35. $storeOrderSelectedOptions = json_decode(@$storeOrderDetailJson->selected_options ?? "{}");
  36. $selectedLab = @$storeOrderSelectedOptions->lab;
  37. $lab_tests_request_attachment = @$order->getDetailJsonValue('lab_tests_request_attachment');
  38. $results_attachment = @$order->getDetailJsonValue('results_attachment');
  39. $orderTotal = $order->order_total;
  40. ?>
  41. <tr @if ($order->is_cancelled) class="cancelled-order" @endif>
  42. <td class="text-nowrap" style="width:1px">
  43. <a href="{{ route('admin.orders.view.dashboard', $order) }}">{{ $order->orderNumber() }}</a>
  44. </td>
  45. <td style="width:4px;" class="text-center">
  46. <a href="{{ route('admin.orders.view.preview-invoice', $order) }}"><i class="fas fa-file-invoice"></i></a>
  47. </td>
  48. <td class="text-nowrap" style="width:1px">{{ $order->user->displayName() }}</td>
  49. <td class="text-nowrap" style="width:1px">{{ friendly_date_time($order->created_at) }}</td>
  50. <td style="width:1px">
  51. <?php
  52. $amountFromClientBalance = $order->amountDeductedFromAccountBalance();
  53. ?>
  54. {{ displayAmount('$', $order->total()) }}
  55. @if($amountFromClientBalance)
  56. <div>
  57. <span><i class="fas fa-info-circle"></i> Deduction from client balance: <b>{{ displayAmount('$', $amountFromClientBalance) }}</b></span>
  58. </div>
  59. @endif
  60. </td>
  61. <td>
  62. @if($selectedLab)
  63. <?= selected_lab_html_address($selectedLab); ?>
  64. @else
  65. ---
  66. @endif
  67. </td>
  68. <td style="width:1px">
  69. <div class="d-flex">
  70. <span class="me-2">@include("app.my-account.admin.orders.forms.upload-lab-tests-request-attachment", ['edit' => true])</span>
  71. @if(@$lab_tests_request_attachment)
  72. <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>
  73. @else
  74. <small class="text-muted">not uploaded</small>
  75. @endif
  76. </div>
  77. </td>
  78. <td class="text-nowrap">
  79. <?php $finalTrx = $order->finalFinancialTransaction(); ?>
  80. @if (@$finalTrx)
  81. @if ($finalTrx->charge_or_refund == 'CHARGE')
  82. <span><i class="fa-duotone fa-circle-check fa-fw text-success"></i> CHARGED</span>
  83. @else
  84. <span><i class="fa-duotone fa-circle-xmark fa-fw text-danger"></i> REFUNDED</span>
  85. @endif
  86. @else
  87. <span><i class="fa-duotone fa-circle-xmark fa-fw text-danger"></i> NOT CHARGED</span>
  88. @endif
  89. </td>
  90. </tr>
  91. @endforeach
  92. </tbody>
  93. </table>
  94. </div>
  95. <script>
  96. (function($) {
  97. var ordersTable = {
  98. checkedOrders: [],
  99. initSelectAll: function() {
  100. var self = this;
  101. var multiCheckbox = $('[multi-check]');
  102. var orderCheckboxes = $('[order-check]');
  103. multiCheckbox.click(function(e) {
  104. var isChecked = e.target.checked ? true : false;
  105. var checkedOrders = [];
  106. if (isChecked) {
  107. $.each(orderCheckboxes, function(i, order) {
  108. var orderID = $(order).data('id');
  109. checkedOrders.push(orderID);
  110. $(order).attr('checked', true);
  111. });
  112. } else {
  113. $.each(orderCheckboxes, function(i, order) {
  114. $(order).attr('checked', false);
  115. });
  116. }
  117. self.updateCheckedOrders(checkedOrders);
  118. });
  119. },
  120. initSingleOrderCheckbox: function() {
  121. var self = this;
  122. $('[order-check]').click(function(e) {
  123. var input = e.target;
  124. var orderID = $(input).data('id');
  125. var isChecked = input.checked ? true : false;
  126. var checkedOrders = [...self.checkedOrders];
  127. if (isChecked) {
  128. checkedOrders.push(orderID);
  129. } else {
  130. var index = checkedOrders.indexOf(orderID);
  131. checkedOrders.splice(index, 1);
  132. }
  133. self.updateCheckedOrders(checkedOrders);
  134. });
  135. },
  136. updateCheckedOrders: function(orders) {
  137. var self = this;
  138. self.checkedOrders = orders;
  139. if ($('[order-check]:checked').length === $('[order-check]').length) {
  140. $('[multi-check]').prop('checked', true);
  141. } else {
  142. $('[multi-check]').prop('checked', false);
  143. }
  144. $('input[name=selectedIDs]').val(JSON.stringify(self.checkedOrders));
  145. if (self.checkedOrders.length) {
  146. $('#GenerateInvoicesPdfForm').removeClass('d-none');
  147. } else {
  148. $('#GenerateInvoicesPdfForm').addClass('d-none');
  149. }
  150. },
  151. init: function() {
  152. this.initSelectAll();
  153. this.initSingleOrderCheckbox();
  154. }
  155. };
  156. ordersTable.init();
  157. })(jQuery);
  158. </script>