table.blade.php 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  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. <div class="table-responsive scrollable">
  9. <table class="table table-sm table-hover table-bordered mb-0 bg-white">
  10. <thead>
  11. <tr>
  12. <th>#</th>
  13. <th>Created At</th>
  14. <th>Total Amount</th>
  15. <th>Orders</th>
  16. <th>Trx</th>
  17. </tr>
  18. </thead>
  19. <tbody>
  20. @foreach ($rows as $order)
  21. <tr @if ($order->is_cancelled) class="cancelled-order" @endif>
  22. <td class="text-nowrap">
  23. <a href="{{ route('admin.orders.view.dashboard', $order) }}"
  24. class="me-2">{{ $order->orderNumber() }}</a>
  25. </td>
  26. <td class="text-nowrap">{{ friendly_date_time($order->created_at) }}</td>
  27. <td>{{ displayAmount('$', $order->total()) }}</td>
  28. <td>
  29. @include('app.my-account.admin.orders.partials.order-tests-summary')
  30. </td>
  31. <td class="text-nowrap">
  32. <?php $finalTrx = $order->finalFinancialTransaction(); ?>
  33. @if (@$finalTrx)
  34. @if ($finalTrx->charge_or_refund == 'CHARGE')
  35. <span><i class="fa-duotone fa-circle-check fa-fw text-success"></i> CHARGED</span>
  36. @else
  37. <span><i class="fa-duotone fa-circle-xmark fa-fw text-danger"></i> REFUNDED</span>
  38. @endif
  39. @else
  40. <span><i class="fa-duotone fa-circle-xmark fa-fw text-danger"></i> NOT CHARGED</span>
  41. @endif
  42. </td>
  43. </tr>
  44. @endforeach
  45. </tbody>
  46. </table>
  47. </div>
  48. <script>
  49. (function($) {
  50. var ordersTable = {
  51. checkedOrders: [],
  52. initSelectAll: function() {
  53. var self = this;
  54. var multiCheckbox = $('[multi-check]');
  55. var orderCheckboxes = $('[order-check]');
  56. multiCheckbox.click(function(e) {
  57. var isChecked = e.target.checked ? true : false;
  58. var checkedOrders = [];
  59. if (isChecked) {
  60. $.each(orderCheckboxes, function(i, order) {
  61. var orderID = $(order).data('id');
  62. checkedOrders.push(orderID);
  63. $(order).attr('checked', true);
  64. });
  65. } else {
  66. $.each(orderCheckboxes, function(i, order) {
  67. $(order).attr('checked', false);
  68. });
  69. }
  70. self.updateCheckedOrders(checkedOrders);
  71. });
  72. },
  73. initSingleOrderCheckbox: function() {
  74. var self = this;
  75. $('[order-check]').click(function(e) {
  76. var input = e.target;
  77. var orderID = $(input).data('id');
  78. var isChecked = input.checked ? true : false;
  79. var checkedOrders = [...self.checkedOrders];
  80. if (isChecked) {
  81. checkedOrders.push(orderID);
  82. } else {
  83. var index = checkedOrders.indexOf(orderID);
  84. checkedOrders.splice(index, 1);
  85. }
  86. self.updateCheckedOrders(checkedOrders);
  87. });
  88. },
  89. updateCheckedOrders: function(orders) {
  90. var self = this;
  91. self.checkedOrders = orders;
  92. if ($('[order-check]:checked').length === $('[order-check]').length) {
  93. $('[multi-check]').prop('checked', true);
  94. } else {
  95. $('[multi-check]').prop('checked', false);
  96. }
  97. $('input[name=selectedIDs]').val(JSON.stringify(self.checkedOrders));
  98. if (self.checkedOrders.length) {
  99. $('#GenerateInvoicesPdfForm').removeClass('d-none');
  100. } else {
  101. $('#GenerateInvoicesPdfForm').addClass('d-none');
  102. }
  103. },
  104. init: function() {
  105. this.initSelectAll();
  106. this.initSingleOrderCheckbox();
  107. }
  108. };
  109. ordersTable.init();
  110. })(jQuery);
  111. </script>