show.blade.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. @extends('layouts.app')
  2. @section('content')
  3. <div class="px-3">
  4. <div class="row mb-2">
  5. <div class="col-6">
  6. <h3>Площадка {{ $order->object_address }}</h3>
  7. </div>
  8. <div class="col-6 text-end">
  9. <a href="{{ route('order.edit', $order) }}" class="btn btn-primary">Редактировать</a>
  10. @if(hasRole('admin') && ($order->order_status_id == App\Models\Order::STATUS_NEW))
  11. <a href="#" onclick="if(confirm('Удалить площадку?')) $('form#destroy').submit();"
  12. class="btn btn-danger">Удалить</a>
  13. <form action="{{ route('order.destroy', $order) }}" method="post" class="d-none" id="destroy">
  14. @csrf
  15. @method('DELETE')
  16. </form>
  17. @endif
  18. </div>
  19. </div>
  20. <div class="row">
  21. <div class="col-xl-3">
  22. <h4>Общая информация об объекте</h4>
  23. <div>Название: {{ $order->name }}</div>
  24. <div>ID площадки: {{ $order->id }}</div>
  25. <div>
  26. Адрес: {{ $order->common_name }}
  27. </div>
  28. <div>Тип объекта: {{ $order->objectType->name }}</div>
  29. <div>Статус объекта: {{ $order->orderStatus->name }}</div>
  30. <div>Комментарий: {{ $order->comment }}</div>
  31. <div>Дата выхода на монтаж: {{ $order->installation_date }}</div>
  32. <div>Дата готовности площадки: {{ $order->ready_date }}</div>
  33. <div>Бригадир: {{ $order?->brigadier?->name }}, тел. {{ $order?->brigadier?->phone }}</div>
  34. <div>Менеджер: {{ $order->user->name }}, тел. {{ $order->user->phone }}</div>
  35. <div>Название группы в ТГ: {{ $order->tg_group_name }}</div>
  36. <div>Ссылка на группу в ТГ: {{ $order->tg_group_link }}</div>
  37. <hr>
  38. <div class="photo">
  39. Фотографии <button class="btn btn-sm text-success" onclick="$('#upl-photo').trigger('click');"><i class="bi bi-plus-circle-fill"></i> Загрузить</button>
  40. <form action="{{ route('order.upload-photo', $order) }}" enctype="multipart/form-data" method="post" class="visually-hidden">
  41. @csrf
  42. <input required type="file" id="upl-photo" onchange="$(this).parent().submit()" multiple name="photo[]" class="form-control form-control-sm" accept=".jpg,.jpeg,.png">
  43. </form>
  44. <div class="row my-2 g-1">
  45. @foreach($order->photos as $photo)
  46. <div class="col-4">
  47. <a href="{{ $photo->link }}"
  48. data-toggle="lightbox" data-gallery="photos" data-size="fullscreen">
  49. <img class="img-thumbnail" src="{{ $photo->link }}" alt="">
  50. </a>
  51. @if(hasRole('admin'))
  52. <i class="bi bi-x-circle-fill fs-6 text-danger cursor-pointer rm-but"
  53. onclick="if(confirm('Удалить фото?')) $('#photo-{{ $photo->id }}').submit()"
  54. title="Удалить"></i>
  55. @endif
  56. <form action="{{ route('order.delete-photo', [$order, $photo]) }}" method="POST" id="photo-{{ $photo->id }}" class="visually-hidden">
  57. @csrf
  58. @method('DELETE')
  59. </form>
  60. </div>
  61. @endforeach
  62. </div>
  63. </div>
  64. </div>
  65. <div class="col-xl-9">
  66. <h4>МАФы заказа</h4>
  67. <div id="selected_maf">
  68. @if(isset($order) && $order->products_sku)
  69. <table class="table">
  70. <thead>
  71. <tr>
  72. <th><input type="checkbox" class="form-check" id="check-all-maf"></th>
  73. <th>МАФ</th>
  74. <th>Тип</th>
  75. <th>Статус</th>
  76. <th>Номер заказа МАФ</th>
  77. <th>RFID</th>
  78. <th>Заводской номер</th>
  79. <th>Дата производства</th>
  80. <th>Срок эксплуатации</th>
  81. <th>Склад</th>
  82. </tr>
  83. </thead>
  84. <tbody>
  85. @php
  86. $needs = $order->getNeeds();
  87. @endphp
  88. @foreach($order->products_sku as $p)
  89. <tr>
  90. <td>
  91. <input type="checkbox" class="form-check check-maf" data-maf-id="{{ $p->id }}">
  92. </td>
  93. <td>
  94. <a href="{{ route('product_sku.show', $p) }}">
  95. {!! $p->product->article !!}
  96. </a>
  97. </td>
  98. <td>{!! $p->product->nomenclature_number !!}</td>
  99. <td>{{ $p->status }}</td>
  100. <td>{{ $p->maf_order?->order_number }}</td>
  101. <td>{{ $p->rfid }}</td>
  102. <td>{{ $p->factory_number }}</td>
  103. <td>{{ $p->manufacture_date }}</td>
  104. <td>{{ $p->service_life }}</td>
  105. <td class="text-center">
  106. @if($p->maf_order?->order_number)
  107. <i class="bi bi-check-all text-success fw-bold"></i>
  108. @else
  109. @if($needs[$p->product_id]['sku']-- > 0)
  110. <i class="bi bi-check text-success fw-bold"></i>
  111. @else
  112. <i class="bi bi-x text-danger fw-bold"></i>
  113. @endif
  114. @endif
  115. </td>
  116. </tr>
  117. @endforeach
  118. </tbody>
  119. </table>
  120. <div>
  121. <a href="{{ route('order.get-maf', $order) }}" class="btn btn-primary btn-sm @disabled($order->ready_to_mount == 'Нет' )">Привязать все МАФы</a>
  122. <a href="{{ route('order.revert-maf', $order) }}" class="btn btn-primary btn-sm">Отвязать все МАФы</a>
  123. <button class="btn btn-primary btn-sm" data-bs-toggle="modal" data-bs-target="#moveModal">Перенести МАФы</button>
  124. </div>
  125. @endif
  126. </div>
  127. </div>
  128. </div>
  129. </div>
  130. <!-- Модальное окно переноса -->
  131. <div class="modal fade" id="moveModal" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
  132. <div class="modal-dialog modal-fullscreen-sm-down modal-lg">
  133. <div class="modal-content">
  134. <div class="modal-header">
  135. <h1 class="modal-title fs-5" id="addModalLabel">Выбрать площадку, куда переносим</h1>
  136. <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Закрыть"></button>
  137. </div>
  138. <div class="modal-body">
  139. <form action="{{ route('order.move-maf') }}" method="post">
  140. @csrf
  141. <div id="select_maf_form">
  142. <input type="text" class="form-control mb-2" placeholder="Поиск площадки" id="search_order">
  143. <select id="select_order" name="new_order_id" class="form-select mb-3" size="30" multiple required></select>
  144. <a href="#" class="btn btn-primary" id="moveMaf">Перенести</a>
  145. </div>
  146. </form>
  147. </div>
  148. </div>
  149. </div>
  150. </div>
  151. @endsection
  152. @push('scripts')
  153. <script type="module">
  154. // select order
  155. $('#search_order').on('keyup', function () {
  156. // search products on backend
  157. $.get('{{ route('order.search') }}?s=' + $(this).val(),
  158. function (data) {
  159. $('#select_order').children().remove()
  160. $.each(data, function (id, name) {
  161. $('#select_order').append('<option value=\'' + id + '\'>' + name + '</option>');
  162. });
  163. }
  164. );
  165. }).trigger('keyup');
  166. $('#check-all-maf').on('change', function () {
  167. $('input:checkbox.check-maf').not(this).prop('checked', this.checked);
  168. });
  169. // move maf
  170. $('#moveMaf').on('click', function () {
  171. let ids = Array();
  172. $('.check-maf').each(function () {
  173. if ($(this).prop('checked')) {
  174. ids.push($(this).attr('data-maf-id'));
  175. }
  176. });
  177. $.post('{{ route('order.move-maf') }}',
  178. {
  179. '_token': $('meta[name=csrf-token]').attr('content'),
  180. ids: JSON.stringify(ids),
  181. 'new_order_id': $('#select_order').find(":selected").val()
  182. },
  183. function () {
  184. // console.log(data);
  185. location.reload();
  186. }
  187. );
  188. });
  189. </script>
  190. @endpush