PersonDesiController   A
last analyzed

Complexity

Total Complexity 16

Size/Duplication

Total Lines 137
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 44
dl 0
loc 137
rs 10
c 1
b 0
f 0
wmc 16

7 Methods

Rating   Name   Duplication   Size   Complexity  
A create() 0 2 1
A show() 0 3 1
A edit() 0 2 1
A destroy() 0 10 2
B index() 0 35 9
A store() 0 12 1
A update() 0 15 1
1
<?php
2
3
namespace App\Http\Controllers;
4
5
use App\Models\PersonDesi;
6
use Illuminate\Http\Request;
7
8
class PersonDesiController extends Controller
9
{
10
    /**
11
     * Display a listing of the resource.
12
     *
13
     * @return \Illuminate\Http\Response
14
     */
15
    public function index(Request $request)
16
    {
17
        $query = PersonDesi::query();
18
19
        if ($request->has('searchTerm')) {
20
            $columnsToSearch = ['name', 'email', 'phone'];
21
            $search_term = json_decode($request->searchTerm)->searchTerm;
22
            if (! empty($search_term)) {
23
                $searchQuery = '%'.$search_term.'%';
24
                foreach ($columnsToSearch as $column) {
25
                    $query->orWhere($column, 'LIKE', $searchQuery);
26
                }
27
            }
28
        }
29
30
        if ($request->has('columnFilters')) {
31
            $filters = get_object_vars(json_decode($request->columnFilters));
32
33
            foreach ($filters as $key => $value) {
34
                if (! empty($value)) {
35
                    $query->orWhere($key, 'like', '%'.$value.'%');
36
                }
37
            }
38
        }
39
40
        if ($request->has('sort.0')) {
41
            $sort = json_decode($request->sort[0]);
42
            $query->orderBy($sort->field, $sort->type);
43
        }
44
45
        if ($request->has('perPage')) {
46
            $rows = $query->paginate($request->perPage);
47
        }
48
49
        return $rows;
0 ignored issues
show
Comprehensibility Best Practice introduced by
The variable $rows does not seem to be defined for all execution paths leading up to this point.
Loading history...
50
    }
51
52
    /**
53
     * Show the form for creating a new resource.
54
     *
55
     * @return \Illuminate\Http\Response
56
     */
57
    public function create()
58
    {
59
        //
60
    }
61
62
    /**
63
     * Store a newly created resource in storage.
64
     *
65
     * @param  \Illuminate\Http\Request  $request
66
     * @return \Illuminate\Http\Response
67
     */
68
    public function store(Request $request)
69
    {
70
        $request->validate([
71
            'group' => 'required',
72
            'gid' => 'required',
73
            'desi' => 'required',
74
        ]);
75
76
        return PersonDesi::create([
0 ignored issues
show
Bug Best Practice introduced by
The expression return App\Models\Person...si' => $request->name)) also could return the type App\Models\PersonDesi which is incompatible with the documented return type Illuminate\Http\Response.
Loading history...
77
            'group' => $request->name,
78
            'gid' => $request->name,
79
            'desi' => $request->name,
80
        ]);
81
    }
82
83
    /**
84
     * Display the specified resource.
85
     *
86
     * @param  int  $id
87
     * @return \Illuminate\Http\Response
88
     */
89
    public function show($id)
90
    {
91
        return PersonDesi::find($id);
0 ignored issues
show
Bug Best Practice introduced by
The expression return App\Models\PersonDesi::find($id) also could return the type App\Models\PersonDesi which is incompatible with the documented return type Illuminate\Http\Response.
Loading history...
92
    }
93
94
    /**
95
     * Show the form for editing the specified resource.
96
     *
97
     * @param  int  $id
98
     * @return \Illuminate\Http\Response
99
     */
100
    public function edit($id)
0 ignored issues
show
Unused Code introduced by
The parameter $id is not used and could be removed. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-unused  annotation

100
    public function edit(/** @scrutinizer ignore-unused */ $id)

This check looks for parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
101
    {
102
        //
103
    }
104
105
    /**
106
     * Update the specified resource in storage.
107
     *
108
     * @param  \Illuminate\Http\Request  $request
109
     * @param  int  $id
110
     * @return \Illuminate\Http\Response
111
     */
112
    public function update(Request $request, $id)
113
    {
114
        $request->validate([
115
            'group' => 'required',
116
            'gid' => 'required',
117
            'desi' => 'required',
118
        ]);
119
120
        $persondesi = PersonDesi::find($id);
121
        $persondesi->group = $request->group;
122
        $persondesi->gid = $request->gid;
123
        $persondesi->desi = $request->desi;
124
        $persondesi->save();
125
126
        return $persondesi;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $persondesi also could return the type App\Models\PersonDesi which is incompatible with the documented return type Illuminate\Http\Response.
Loading history...
127
    }
128
129
    /**
130
     * Remove the specified resource from storage.
131
     *
132
     * @param  int  $id
133
     * @return \Illuminate\Http\Response
134
     */
135
    public function destroy($id)
136
    {
137
        $persondesi = PersonDesi::find($id);
138
        if ($persondesi) {
139
            $persondesi->delete();
140
141
            return 'true';
0 ignored issues
show
Bug Best Practice introduced by
The expression return 'true' returns the type string which is incompatible with the documented return type Illuminate\Http\Response.
Loading history...
142
        }
143
144
        return 'false';
0 ignored issues
show
Bug Best Practice introduced by
The expression return 'false' returns the type string which is incompatible with the documented return type Illuminate\Http\Response.
Loading history...
145
    }
146
}
147