table.blade.php 6.9 KB

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