GroupsController.php
3.03 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use App\Models\Group_user;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Validator;
class GroupsController extends Controller
{
// индексная страница
public function index() {
$groups = Group_user::query()->active()->paginate(15);
return view('admin.groups.index', compact('groups'));
}
// форма добавления группы
public function add() {
$editor = Auth::user()->id;
$users = User::query()->get();
return view('admin.groups.add', compact('editor', 'users'));
}
// форма сохранения добавленной группы
public function store(Request $request) {
$rules = [
'name_group' => 'required|min:3',
];
$messages = [
'required' => 'Укажите обязательное поле',
];
$validator = Validator::make($request->all(), $rules, $messages);
if ($validator->fails()) {
return redirect()->route('admin.add-group')
->withErrors($validator);
} else {
Group_user::create($request->all());
return redirect()->route('admin.groups')
->with('success', 'Данные были успешно сохранены');
}
return redirect()->route('admin.groups');
}
// форма редактирования группы
public function edit(Group_user $group, Request $request) {
$editor = Auth::user()->id;
$users = User::query()->get();
return view('admin.groups.edit', compact('editor', 'group', 'users'));
}
// форма сохранения редактированной группы
public function update(Group_user $group, Request $request) {
$params = $request->all();
unset($params['usergroup']);
$rules = [
'name_group' => 'required|min:3',
];
$messages = [
'required' => 'Укажите обязательное поле',
];
$validator = Validator::make($request->all(), $rules, $messages);
if ($validator->fails()) {
return redirect()->route('admin.edit-group', ['group' => $group->id])
->withErrors($validator);
} else {
$group->update($request->all());
$group->ingroup()->sync($request->usergroup);
/*if ($request->usergroup->count()) {
foreach ($request->usergroup as $us) {
Group_works
}
}*/
return redirect()->route('admin.groups')
->with('success', 'Данные были успешно сохранены');
}
return redirect()->route('admin.groups');
}
public function destroy(Group_user $group) {
$group->update(['is_remove' => 1]);
return redirect()->route('admin.groups');
}
}