MafOrderController.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Requests\StoreMafOrderRequest;
  4. use App\Models\MafOrder;
  5. use App\Models\MafOrdersView;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Facades\DB;
  8. use Illuminate\Validation\ValidationException;
  9. class MafOrderController extends Controller
  10. {
  11. protected array $data = [
  12. 'active' => 'maf_order',
  13. 'title' => 'Заказы МАФ',
  14. 'id' => 'maf_order',
  15. 'header' => [
  16. 'product-image' => 'Картинка',
  17. 'id' => 'ID',
  18. 'order_number' => '№ заказа',
  19. 'status' => 'Статус',
  20. 'user_name' => 'Менеджер',
  21. 'article' => 'Артикул',
  22. 'nomenclature_number' => 'Номер номенклатуры',
  23. 'quantity' => 'Заказано',
  24. 'in_stock' => 'Остаток',
  25. 'created_at' => 'Дата создания',
  26. ],
  27. 'searchFields' => [
  28. 'order_number',
  29. 'nomenclature_number',
  30. 'article',
  31. ],
  32. ];
  33. public function index(Request $request)
  34. {
  35. $model = new MafOrdersView;
  36. session(['gp_maf_order' => $request->all()]);
  37. $this->createDateFilters($model, 'created_at');
  38. $this->createFilters($model, 'user_name');
  39. $this->createRangeFilters($model, 'in_stock');
  40. $q = $model::query();
  41. $this->acceptFilters($q, $request);
  42. $this->acceptSearch($q, $request);
  43. $this->setSortAndOrderBy($model, $request);
  44. $this->applyStableSorting($q);
  45. $this->data['maf_orders'] = $q->paginate($this->data['per_page'])->withQueryString();
  46. $this->data['order_numbers'] = MafOrder::query()
  47. ->whereNotNull('order_number')
  48. ->where('order_number', '!=', '')
  49. ->orderBy('order_number')
  50. ->distinct()
  51. ->pluck('order_number');
  52. return view('maf_orders.index', $this->data);
  53. }
  54. public function store(StoreMafOrderRequest $request)
  55. {
  56. MafOrder::query()->create($request->validated() + ['user_id' => $request->user()->id, 'in_stock' => 0]);
  57. return redirect()->route('maf_order.index', session('gp_maf_order'));
  58. }
  59. public function show(Request $request, int $maf_order)
  60. {
  61. $this->data['maf_order'] = MafOrder::query()->withoutGlobalScope(\App\Models\Scopes\YearScope::class)->find($maf_order);
  62. $this->data['previous_url'] = $this->resolvePreviousUrl(
  63. $request,
  64. 'previous_url_maf_order',
  65. route('maf_order.index', session('gp_maf_order'))
  66. );
  67. return view('maf_orders.edit', $this->data);
  68. }
  69. public function update(StoreMafOrderRequest $request, MafOrder $maf_order)
  70. {
  71. MafOrder::query()->where('id', $maf_order->id)->update($request->validated());
  72. return redirect()->route('maf_order.index', session('gp_maf_order'));
  73. }
  74. public function destroy(MafOrder $maf_order)
  75. {
  76. $maf_order->delete();
  77. return redirect()->route('maf_order.index', session('gp_maf_order'));
  78. }
  79. public function setInStock(MafOrder $maf_order)
  80. {
  81. $maf_order->update(['in_stock' => $maf_order->quantity, 'status' => 'на складе']);
  82. return redirect()->route('maf_order.show', $maf_order);
  83. }
  84. public function setOrderInStock(Request $request)
  85. {
  86. $validated = $request->validate([
  87. 'bulk_order_number' => 'required|string',
  88. ]);
  89. $orderNumber = trim((string) $validated['bulk_order_number']);
  90. $query = MafOrder::query()->where('order_number', $orderNumber);
  91. if (!$query->exists()) {
  92. throw ValidationException::withMessages([
  93. 'bulk_order_number' => 'Заказ не найден в выбранном году.',
  94. ]);
  95. }
  96. $query->update([
  97. 'in_stock' => DB::raw('quantity'),
  98. 'status' => 'на складе',
  99. ]);
  100. return redirect()->route('maf_order.index', session('gp_maf_order'));
  101. }
  102. }