show.blade.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333
  1. @php
  2. use App\Models\Order;
  3. @endphp
  4. @extends('layouts.app')
  5. @section('content')
  6. <div class="px-3">
  7. <div class="row mb-2">
  8. <div class="col-6">
  9. <h3>
  10. Площадка {{ $order->object_address }}
  11. <div class="badge text-bg-{{ Order::STATUS_COLOR[$order->order_status_id] }}" >{{ $order->orderStatus->name }}</div>
  12. </h3>
  13. </div>
  14. <div class="col-6 text-end">
  15. <a href="{{ route('order.edit', $order) }}" class="btn btn-primary">Редактировать</a>
  16. @if(hasRole('admin') && ($order->order_status_id == Order::STATUS_NEW))
  17. <a href="#" onclick="if(confirm('Удалить площадку?')) $('form#destroy').submit();"
  18. class="btn btn-danger">Удалить</a>
  19. <form action="{{ route('order.destroy', $order) }}" method="post" class="d-none" id="destroy">
  20. @csrf
  21. @method('DELETE')
  22. </form>
  23. @endif
  24. @if(in_array($order->order_status_id, [Order::STATUS_READY_TO_MOUNT, Order::STATUS_IN_MOUNT]) && $order->isAllMafConnected())
  25. <a href="{{ route('order.generate-installation-pack', $order) }}" class="btn btn-primary">Документы для монтажа</a>
  26. @endif
  27. @if($order->canCreateHandover())
  28. <a href="{{ route('order.generate-handover-pack', $order) }}" class="btn btn-primary">Документы для сдачи</a>
  29. @endif
  30. </div>
  31. </div>
  32. <div class="row">
  33. <div class="col-xl-3 border-end">
  34. <h4>Общая информация об объекте</h4>
  35. <div>Название: {{ $order->name }}</div>
  36. <div>ID площадки: {{ $order->id }}</div>
  37. <div>
  38. Адрес: {{ $order->common_name }}
  39. </div>
  40. <div>Тип объекта: {{ $order->objectType->name }}</div>
  41. <div class="text-{{ Order::STATUS_COLOR[$order->order_status_id] }}" >Статус объекта: {{ $order->orderStatus->name }}</div>
  42. <div>Комментарий: {{ $order->comment }}</div>
  43. <div>Дата выхода на монтаж: {{ $order->installation_date }}</div>
  44. <div>Дата готовности площадки: {{ $order->ready_date }}</div>
  45. <div>Бригадир: {{ $order?->brigadier?->name }}, тел. {{ $order?->brigadier?->phone }}</div>
  46. <div>Менеджер: {{ $order->user->name }}, тел. {{ $order->user->phone }}</div>
  47. <div>Название группы в ТГ: {{ $order->tg_group_name }}</div>
  48. <div>Ссылка на группу в ТГ: {{ $order->tg_group_link }}</div>
  49. <hr>
  50. <div class="reclamations">
  51. Рекламации
  52. @foreach($order->reclamations as $reclamation)
  53. <div>
  54. <a href="{{ route('reclamations.show', $reclamation) }}">
  55. Рекламация № {{ $reclamation->id }} от {{ $reclamation->create_date }}
  56. </a>
  57. </div>
  58. @endforeach
  59. </div>
  60. <hr>
  61. <div class="documents">
  62. Документы <button class="btn btn-sm text-success" onclick="$('#upl-documents').trigger('click');"><i class="bi bi-plus-circle-fill"></i> Загрузить</button>
  63. <form action="{{ route('order.upload-document', $order) }}" enctype="multipart/form-data" method="post" class="visually-hidden">
  64. @csrf
  65. <input required type="file" id="upl-documents" onchange="$(this).parent().submit()" multiple name="document[]" class="form-control form-control-sm">
  66. </form>
  67. <div class="row my-2 g-1">
  68. @foreach($order->documents as $document)
  69. <div class="col-12">
  70. <a href="{{ $document->link }}" target="_blank">
  71. {{ $document->original_name }}
  72. </a>
  73. @if(hasRole('admin'))
  74. <i class="bi bi-x-circle-fill fs-6 text-danger cursor-pointer ms-2"
  75. onclick="if(confirm('Удалить?')) $('#document-{{ $document->id }}').submit()"
  76. title="Удалить"></i>
  77. @endif
  78. <form action="{{ route('order.delete-document', [$order, $document]) }}" method="POST" id="document-{{ $document->id }}" class="visually-hidden">
  79. @csrf
  80. @method('DELETE')
  81. </form>
  82. </div>
  83. @endforeach
  84. </div>
  85. </div>
  86. <hr>
  87. <div class="statements">
  88. Ведомости <button class="btn btn-sm text-success" onclick="$('#upl-statements').trigger('click');"><i class="bi bi-plus-circle-fill"></i> Загрузить</button>
  89. <form action="{{ route('order.upload-statement', $order) }}" enctype="multipart/form-data" method="post" class="visually-hidden">
  90. @csrf
  91. <input required type="file" id="upl-statements" onchange="$(this).parent().submit()" multiple name="statement[]" class="form-control form-control-sm">
  92. </form>
  93. <div class="row my-2 g-1">
  94. @foreach($order->statements as $statement)
  95. <div class="col-12">
  96. <a href="{{ $statement->link }}" target="_blank">
  97. {{ $statement->original_name }}
  98. </a>
  99. @if(hasRole('admin'))
  100. <i class="bi bi-x-circle-fill fs-6 text-danger cursor-pointer ms-2"
  101. onclick="if(confirm('Удалить?')) $('#statement-{{ $statement->id }}').submit()"
  102. title="Удалить"></i>
  103. @endif
  104. <form action="{{ route('order.delete-statement', [$order, $statement]) }}" method="POST" id="statement-{{ $statement->id }}" class="visually-hidden">
  105. @csrf
  106. @method('DELETE')
  107. </form>
  108. </div>
  109. @endforeach
  110. </div>
  111. </div>
  112. <hr>
  113. <div class="photo">
  114. <a href="#photos" data-bs-toggle="collapse">Фотографии ({{ $order->photos->count() }})</a>
  115. <button class="btn btn-sm text-success" onclick="$('#upl-photo').trigger('click');"><i class="bi bi-plus-circle-fill"></i> Загрузить</button>
  116. @if($order->photos->count())
  117. <a href="{{ route('order.generate-photos-pack', $order) }}" class="btn btn-sm text-primary" ><i
  118. class="bi bi-download"></i> Скачать все
  119. </a>
  120. @endif
  121. <form action="{{ route('order.upload-photo', $order) }}" enctype="multipart/form-data" method="post" class="visually-hidden">
  122. @csrf
  123. <input required type="file" id="upl-photo" onchange="$(this).parent().submit()" multiple name="photo[]" class="form-control form-control-sm" accept=".jpg,.jpeg,.png">
  124. </form>
  125. <div class="row my-2 g-1 collapse" id="photos">
  126. @foreach($order->photos as $photo)
  127. <div class="col-4">
  128. <a href="{{ $photo->link }}"
  129. data-toggle="lightbox" data-gallery="photos" data-size="fullscreen">
  130. <img class="img-thumbnail" src="{{ $photo->link }}" alt="">
  131. </a>
  132. @if(hasRole('admin'))
  133. <i class="bi bi-x-circle-fill fs-6 text-danger cursor-pointer rm-but"
  134. onclick="if(confirm('Удалить фото?')) $('#photo-{{ $photo->id }}').submit()"
  135. title="Удалить"></i>
  136. @endif
  137. <form action="{{ route('order.delete-photo', [$order, $photo]) }}" method="POST" id="photo-{{ $photo->id }}" class="visually-hidden">
  138. @csrf
  139. @method('DELETE')
  140. </form>
  141. </div>
  142. @endforeach
  143. </div>
  144. </div>
  145. </div>
  146. <div class="col-xl-9">
  147. <h4>МАФы заказа</h4>
  148. <div id="selected_maf">
  149. @if(isset($order) && $order->products_sku)
  150. <table class="table">
  151. <thead>
  152. <tr>
  153. <th><input type="checkbox" class="form-check" id="check-all-maf"></th>
  154. <th>Картинка</th>
  155. <th>МАФ</th>
  156. <th>Тип</th>
  157. <th>Статус</th>
  158. <th>Номер заказа МАФ</th>
  159. <th>RFID</th>
  160. <th>Заводской номер</th>
  161. <th>Дата производства</th>
  162. <th>Склад</th>
  163. <th>Паспорт</th>
  164. </tr>
  165. </thead>
  166. <tbody>
  167. @php
  168. $needs = $order->getNeeds();
  169. @endphp
  170. @foreach($order->products_sku as $p)
  171. <tr>
  172. <td>
  173. <input type="checkbox" class="form-check check-maf" data-maf-id="{{ $p->id }}">
  174. </td>
  175. <td>
  176. @if($p->product->image)
  177. <a href="{{ $p->product->image }}" data-toggle="lightbox" data-gallery="maf" data-size="fullscreen">
  178. <img src="{{ $p->product->image }}" alt="" class="img-thumbnail maf-img">
  179. </a>
  180. @endif
  181. </td>
  182. <td>
  183. <a href="{{ route('product_sku.show', $p) }}">
  184. {!! $p->product->article !!}
  185. </a>
  186. <br>
  187. <a class="small" href="{{ route('catalog.show', $p->product) }}">каталог</a>
  188. </td>
  189. <td>{!! $p->product->nomenclature_number !!}</td>
  190. <td>{{ $p->status }}</td>
  191. <td>
  192. @if($p->maf_order_id)
  193. <a href="{{ route('maf_order.show', $p->maf_order) }}">{{ $p->maf_order->order_number }}</a>
  194. @endif
  195. </td>
  196. <td>{{ $p->rfid }}</td>
  197. <td>{{ $p->factory_number }}</td>
  198. <td>{{ $p->manufacture_date }}</td>
  199. <td class="text-center">
  200. @if($p->maf_order?->order_number)
  201. <i class="bi bi-check-all text-success fw-bold"></i>
  202. @else
  203. @if($needs[$p->product_id]['sku']-- > 0)
  204. <i class="bi bi-check text-success fw-bold"></i>
  205. @else
  206. <i class="bi bi-x text-danger fw-bold"></i>
  207. @endif
  208. @endif
  209. </td>
  210. <td class="text-center">
  211. @if($p->passport)
  212. <i class="bi bi-check text-success fw-bold"></i>
  213. @else
  214. <i class="bi bi-x text-danger fw-bold"></i>
  215. @endif
  216. </td>
  217. </tr>
  218. @endforeach
  219. </tbody>
  220. </table>
  221. <div>
  222. <a href="{{ route('order.get-maf', $order) }}" class="btn btn-primary btn-sm @disabled($order->ready_to_mount == 'Нет' )">Привязать все МАФы</a>
  223. <a href="{{ route('order.revert-maf', $order) }}" class="btn btn-primary btn-sm">Отвязать все МАФы</a>
  224. <button class="btn btn-primary btn-sm" data-bs-toggle="modal" data-bs-target="#moveModal">Перенести МАФы</button>
  225. <button class="btn btn-sm btn-warning" id="create-reclamation-button">Создать рекламацию</button>
  226. <form action="{{ route('reclamations.create', $order) }}" method="post" class="visually-hidden" id="create-reclamation-form">
  227. @csrf
  228. </form>
  229. </div>
  230. @endif
  231. </div>
  232. </div>
  233. </div>
  234. </div>
  235. <!-- Модальное окно переноса -->
  236. <div class="modal fade" id="moveModal" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
  237. <div class="modal-dialog modal-fullscreen-sm-down modal-lg">
  238. <div class="modal-content">
  239. <div class="modal-header">
  240. <h1 class="modal-title fs-5" id="addModalLabel">Выбрать площадку, куда переносим</h1>
  241. <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Закрыть"></button>
  242. </div>
  243. <div class="modal-body">
  244. <form action="{{ route('order.move-maf') }}" method="post">
  245. @csrf
  246. <div id="select_maf_form">
  247. <input type="text" class="form-control mb-2" placeholder="Поиск площадки" id="search_order">
  248. <select id="select_order" name="new_order_id" class="form-select mb-3" size="30" multiple required></select>
  249. <a href="#" class="btn btn-primary" id="moveMaf">Перенести</a>
  250. </div>
  251. </form>
  252. </div>
  253. </div>
  254. </div>
  255. </div>
  256. @endsection
  257. @push('scripts')
  258. <script type="module">
  259. // select order
  260. $('#search_order').on('keyup', function () {
  261. // search products on backend
  262. $.get('{{ route('order.search') }}?s=' + $(this).val(),
  263. function (data) {
  264. $('#select_order').children().remove()
  265. $.each(data, function (id, name) {
  266. $('#select_order').append('<option value=\'' + id + '\'>' + name + '</option>');
  267. });
  268. }
  269. );
  270. }).trigger('keyup');
  271. $('#check-all-maf').on('change', function () {
  272. $('input:checkbox.check-maf').not(this).prop('checked', this.checked);
  273. });
  274. // move maf
  275. $('#moveMaf').on('click', function () {
  276. let ids = Array();
  277. $('.check-maf').each(function () {
  278. if ($(this).prop('checked')) {
  279. ids.push($(this).attr('data-maf-id'));
  280. }
  281. });
  282. $.post('{{ route('order.move-maf') }}',
  283. {
  284. '_token': $('meta[name=csrf-token]').attr('content'),
  285. ids: JSON.stringify(ids),
  286. 'new_order_id': $('#select_order').find(":selected").val()
  287. },
  288. function () {
  289. location.reload();
  290. }
  291. );
  292. });
  293. $('#create-reclamation-button').on('click', function () {
  294. let ids = Array();
  295. $('.check-maf').each(function () {
  296. if ($(this).prop('checked')) {
  297. ids.push($(this).attr('data-maf-id'));
  298. $('#create-reclamation-form').append('<input type="hidden" name="skus[]" value="'+$(this).attr('data-maf-id')+'">');
  299. }
  300. });
  301. if(ids.length) {
  302. $('#create-reclamation-form').submit();
  303. }
  304. });
  305. </script>
  306. @endpush