show.blade.php 22 KB

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