table.blade.php 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  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>Created At</th>
  23. <th>Total Amount</th>
  24. <th>Orders</th>
  25. <th>Lab</th>
  26. <th>Trx</th>
  27. </tr>
  28. </thead>
  29. <tbody>
  30. @foreach ($rows as $order)
  31. <?php
  32. $storeOrderDetailJson = $order->detailJson();
  33. $storeOrderSelectedOptions = json_decode(@$storeOrderDetailJson->selected_options ?? "{}");
  34. $selectedLab = @$storeOrderSelectedOptions->lab;
  35. ?>
  36. <tr @if ($order->is_cancelled) class="cancelled-order" @endif>
  37. <td class="text-nowrap">
  38. <a href="{{ route('admin.orders.view.dashboard', $order) }}"
  39. class="me-2">{{ $order->orderNumber() }}</a>
  40. <a href="{{ route('admin.orders.view.preview-invoice', $order) }}"
  41. class="me-2">Invoice</a>
  42. </td>
  43. <td class="text-nowrap">{{ friendly_date_time($order->created_at) }}</td>
  44. <td>{{ displayAmount('$', $order->total()) }}</td>
  45. <td>
  46. @include('app.my-account.admin.orders.partials.order-tests-summary')
  47. </td>
  48. <td>
  49. @if($selectedLab)
  50. <?= selected_lab_html_address($selectedLab); ?>
  51. @else
  52. ---
  53. @endif
  54. </td>
  55. <td class="text-nowrap">
  56. <?php $finalTrx = $order->finalFinancialTransaction(); ?>
  57. @if (@$finalTrx)
  58. @if ($finalTrx->charge_or_refund == 'CHARGE')
  59. <span><i class="fa-duotone fa-circle-check fa-fw text-success"></i> CHARGED</span>
  60. @else
  61. <span><i class="fa-duotone fa-circle-xmark fa-fw text-danger"></i> REFUNDED</span>
  62. @endif
  63. @else
  64. <span><i class="fa-duotone fa-circle-xmark fa-fw text-danger"></i> NOT CHARGED</span>
  65. @endif
  66. </td>
  67. </tr>
  68. @endforeach
  69. </tbody>
  70. </table>
  71. </div>
  72. <script>
  73. (function($) {
  74. var ordersTable = {
  75. checkedOrders: [],
  76. initSelectAll: function() {
  77. var self = this;
  78. var multiCheckbox = $('[multi-check]');
  79. var orderCheckboxes = $('[order-check]');
  80. multiCheckbox.click(function(e) {
  81. var isChecked = e.target.checked ? true : false;
  82. var checkedOrders = [];
  83. if (isChecked) {
  84. $.each(orderCheckboxes, function(i, order) {
  85. var orderID = $(order).data('id');
  86. checkedOrders.push(orderID);
  87. $(order).attr('checked', true);
  88. });
  89. } else {
  90. $.each(orderCheckboxes, function(i, order) {
  91. $(order).attr('checked', false);
  92. });
  93. }
  94. self.updateCheckedOrders(checkedOrders);
  95. });
  96. },
  97. initSingleOrderCheckbox: function() {
  98. var self = this;
  99. $('[order-check]').click(function(e) {
  100. var input = e.target;
  101. var orderID = $(input).data('id');
  102. var isChecked = input.checked ? true : false;
  103. var checkedOrders = [...self.checkedOrders];
  104. if (isChecked) {
  105. checkedOrders.push(orderID);
  106. } else {
  107. var index = checkedOrders.indexOf(orderID);
  108. checkedOrders.splice(index, 1);
  109. }
  110. self.updateCheckedOrders(checkedOrders);
  111. });
  112. },
  113. updateCheckedOrders: function(orders) {
  114. var self = this;
  115. self.checkedOrders = orders;
  116. if ($('[order-check]:checked').length === $('[order-check]').length) {
  117. $('[multi-check]').prop('checked', true);
  118. } else {
  119. $('[multi-check]').prop('checked', false);
  120. }
  121. $('input[name=selectedIDs]').val(JSON.stringify(self.checkedOrders));
  122. if (self.checkedOrders.length) {
  123. $('#GenerateInvoicesPdfForm').removeClass('d-none');
  124. } else {
  125. $('#GenerateInvoicesPdfForm').addClass('d-none');
  126. }
  127. },
  128. init: function() {
  129. this.initSelectAll();
  130. this.initSingleOrderCheckbox();
  131. }
  132. };
  133. ordersTable.init();
  134. })(jQuery);
  135. </script>