CategoryController.php 11.1 KB
Newer Older
1 2 3 4 5 6
<?php

namespace App\Http\Controllers\Webprofile\Backend;

use App\Http\Controllers\Controller;
use App\Repositories\Webprofile\CategoryRepository;
7
use App\Repositories\Webprofile\De\CategoryRepository as DeCategoryRepository;
8
use App\Repositories\Webprofile\En\CategoryRepository as EnCategoryRepository;
9
use App\Repositories\Webprofile\Sa\CategoryRepository as SaCategoryRepository;
10
use App\Repositories\Webprofile\Zh\CategoryRepository as ZhCategoryRepository;
11
use Illuminate\Http\Request;
12
use Statickidz\GoogleTranslate;
13 14 15 16

class CategoryController extends Controller
{
    private $repo;
17
    private $repoEn;
18
    private $repoDe;
19
    private $repoSa;
20
    private $repoZh;
21

22 23
    private $SOURCE = 'id';
    private $TARGET = 'en';
24
    private $TARGETDE = 'de';
25
    private $TARGETSA = 'ar';
26
    private $TARGETZH = 'zh';
27 28 29

    public function __construct(
        CategoryRepository $repo,
30
        EnCategoryRepository $repoEn,
31
        DeCategoryRepository $repoDe,
32 33
        SaCategoryRepository $repoSa,
        ZhCategoryRepository $repoZh
34
    ) {
35
        $this->repo = $repo;
36
        $this->repoEn = $repoEn;
37
        $this->repoDe = $repoDe;
38
        $this->repoSa = $repoSa;
39
        $this->repoZh = $repoZh;
40
    }
41

42 43 44 45 46 47 48 49
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index(Request $request)
    {
        if ($request->ajax()) {
Aan Choesni Herlingga committed
50
            $data = $this->repo->get(['rEn']);
51

52
            return $this->repo->datatable($data);
53 54
        }

55
        return view('webprofile.backend.categories.index')->withTitle(trans('feature.category'));
56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        return view('webprofile.backend.categories.create')->withTitle(trans('feature.create_category'));
    }

    /**
     * Store a newly created resource in storage.
     *
     * @return \Illuminate\Http\Response
     */
    public function store(Request $request)
    {
75 76 77 78 79 80 81 82 83
        // dd($request);
        $request->validate([
            'name' => 'required'
        ], [
            'name.required' => 'Kategori wajib diisi',
            // 'name.regex' => 'Kategori tidak valid! Kategori hanya berupa angka dan huruf',
            // 'name.max' => 'Kategori terlalu panjang'
        ]);

84 85 86 87
        $data = $request->except('_token');

        array_key_exists('is_active', $data) ? $data['is_active'] = 1 : $data['is_active'] = 0;

88 89 90
        $category = $this->repo->store($data);

        $this->createEn($data, $category);
91
        $this->createDe($data, $category);
92
        $this->createSa($data, $category);
93
        $this->createZh($data, $category);
94 95

        return redirect()->route('category.index');
96 97
    }

98 99 100 101 102 103 104 105 106 107 108
    private function createEn($data, $category)
    {
        $trans = new GoogleTranslate();
        $name = $trans->translate($this->SOURCE, $this->TARGET, $data['name']);

        $dataEn['category_id'] = $category->id;
        $dataEn['name'] = $name;

        $this->repoEn->store($dataEn);
    }

109 110 111 112 113 114 115 116 117 118 119
    private function createDe($data, $category)
    {
        $trans = new GoogleTranslate();
        $name = $trans->translate($this->SOURCE, $this->TARGETDE, $data['name']);

        $dataDe['category_id'] = $category->id;
        $dataDe['name'] = $name;

        $this->repoDe->store($dataDe);
    }

120 121 122 123 124 125 126 127 128 129 130
    private function createSa($data, $category)
    {
        $trans = new GoogleTranslate();
        $name = $trans->translate($this->SOURCE, $this->TARGETSA, $data['name']);

        $dataSa['category_id'] = $category->id;
        $dataSa['name'] = $name;

        $this->repoSa->store($dataSa);
    }

131 132 133 134 135 136 137 138 139 140 141
    private function createZh($data, $category)
    {
        $trans = new GoogleTranslate();
        $name = $trans->translate($this->SOURCE, $this->TARGETZH, $data['name']);

        $dataZh['category_id'] = $category->id;
        $dataZh['name'] = $name;

        $this->repoZh->store($dataZh);
    }

142 143 144
    /**
     * Display the specified resource.
     *
145 146
     * @param int $id
     *
147 148 149 150 151 152 153 154 155
     * @return \Illuminate\Http\Response
     */
    public function show($id)
    {
    }

    /**
     * Show the form for editing the specified resource.
     *
156 157
     * @param int $id
     *
158 159 160 161
     * @return \Illuminate\Http\Response
     */
    public function edit($id)
    {
162
        $data = $this->repo->findId($id, ['rEn', 'rDe', 'rSa', 'rZh']);
163
        $manual=0;
164 165 166

        $data = [
            'data' => $data,
167
            'manual' => $manual,
168 169
        ];

170
        return view('webprofile.backend.categories.edit', $data)->withTitle(trans('feature.edit_category'));
171 172
    }

173 174 175 176 177 178 179 180 181 182 183 184 185 186
    public function editPerBahasa($id)
    {
        $data = $this->repo->findId($id, ['rEn', 'rDe', 'rSa', 'rZh']);
        $manual=1;

        $data = [
            'data' => $data,
            'manual' => $manual,
        ];
        // dd($data);

        return view('webprofile.backend.categories.edit_per_bahasa', $data)->withTitle(trans('feature.edit_category'));
    }

187 188 189
    /**
     * Update the specified resource in storage.
     *
190
     * @param int $id
191
     *
192 193 194 195
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id)
    {
196 197 198 199 200 201 202 203 204
        // dd($request);
        $request->validate([
            'name' => 'required',
        ], [
            'name.required' => 'Kategori wajib diisi',
            // 'name.regex' => 'Kategori tidak valid! Kategori hanya berupa angka dan huruf',
            // 'name.max' => 'Kategori terlalu panjang',
        ]);
        // dd($request);
205
        $data = $request->except(['_token', 'manual', 'id', 'name_en', 'name_de', 'name_sa', 'name_zh']);
206
        // // $dataEn = $request->except(['_token', 'id', 'name_de']);
207
        $dataEn = $request->except(['_token','id', 'manual']);
208 209 210 211 212 213 214
        // $dataEn = $request->except(['_token', 'manual', 'id', 'name_en', 'name_de', 'name_sa', 'name_zh']);
        // $dataEn['name_en'] = htmlspecialchars($request->name_en);
        // $dataEn['name_de'] = htmlspecialchars($request->name_de);
        // $dataEn['name_sa'] = htmlspecialchars($request->name_sa);
        // $dataEn['name_zh'] = htmlspecialchars($request->name_zh);
        // // $dataDe = $request->except(['_token', 'id', 'name', 'name_en']);
        // // dd($request, $dataEn);
215 216
        array_key_exists('is_active', $data) ? $data['is_active'] = 1 : $data['is_active'] = 0;

217
        $category = $this->repo->findId($id, ['rEn', 'rDe', 'rSa', 'rZh']);
218 219 220 221 222 223 224 225 226 227
        // $edit = $this->repo->update($data, $category);
        // dd($dataEn, $category, $request->manual);
        
        
        $this->updateEn($dataEn, $category, $request->manual);
        $this->updateDe($dataEn, $category, $request->manual);
        $this->updateSa($dataEn, $category, $request->manual);
        $this->updateZh($dataEn, $category, $request->manual);
        $this->repo->update($data, $category);
        // dd($data, $category, $request->manual);
228
        return redirect()->route('category.index');
229 230
    }

231
    public function updateEn($data, $category, $manual)
232
    {
233 234 235 236 237 238 239 240 241 242 243
        // $dataEn['name'] = $data['name_en'];

        // if ($category->rEn) {
        //     $this->repoDe->update($dataEn, $category->rEn);
        // } else {
        //     $dataEn['category_id'] = $category->id;
        //     $dataEn['name'] = $data['name_en'];

        //     $this->repoEn->store($dataEn);
        // }
            // dd($data, $category, $manual);
244 245 246
            
            // dd($data, $category, $manual);
    
247 248 249 250 251 252 253 254 255 256 257 258 259 260 261
            if($manual==1){
                $dataEn['name'] = $data['name_en'];
            }
            else{
                if (strip_tags($data['name']) == null) {
                    $data['name'] = 'kosong';
                }

                $trans = new GoogleTranslate();
                $name = $trans->translate($this->SOURCE, $this->TARGET, $data['name']);
                $dataEn['name'] = $name;
                // dd($dataEn);
            }
            // dd($category);
            $this->repoEn->update($dataEn, $category);
262 263
    }

264
    public function updateDe($data, $category, $manual)
265
    {
266 267 268 269 270 271 272 273 274 275
        // $dataDe['name'] = $data['name_de'];

        // if ($category->rDe) {
        //     $this->repoDe->update($dataDe, $category->rDe);
        // } else {
        //     $dataDe['category_id'] = $category->id;
        //     $dataDe['name'] = $data['name_de'];

        //     $this->repoDe->store($dataDe);
        // }
276

277
        if($manual==1){
278
            $dataDe['name'] = $data['name_de'];
279 280 281 282 283
        }
        else{
            if (strip_tags($data['name']) == null) {
                $data['name'] = 'kosong';
            }
284

285 286 287
            $trans = new GoogleTranslate();
            $name = $trans->translate($this->SOURCE, $this->TARGETDE, $data['name']);
            $dataDe['name'] = $name;
288
        }
289
        $this->repoDe->update($dataDe, $category);
290 291
    }

292
    public function updateSa($data, $category, $manual)
293
    {
294 295 296 297 298 299 300
        // $dataSa['name'] = $data['name_sa'];

        // if ($category->rSa) {
        //     $this->repoSa->update($dataSa, $category->rSa);
        // } else {
        //     $dataSa['category_id'] = $category->id;
        //     $dataSa['name'] = $data['name_sa'];
301

302 303 304 305
        //     $this->repoSa->store($dataSa);
        // }

        if($manual==1){
306
            $dataSa['name'] = $data['name_sa'];
307 308 309 310 311
        }
        else{
            if (strip_tags($data['name']) == null) {
                $data['name'] = 'kosong';
            }
312

313 314 315
            $trans = new GoogleTranslate();
            $name = $trans->translate($this->SOURCE, $this->TARGETSA, $data['name']);
            $dataSa['name'] = $name;
316
        }
317
        $this->repoSa->update($dataSa, $category);
318 319
    }

320
    public function updateZh($data, $category, $manual)
321
    {
322 323 324 325 326 327 328
        // $dataZh['name'] = $data['name_zh'];

        // if ($category->rZh) {
        //     $this->repoZh->update($dataZh, $category->rZh);
        // } else {
        //     $dataZh['category_id'] = $category->id;
        //     $dataZh['name'] = $data['name_zh'];
329

330 331 332 333
        //     $this->repoZh->store($dataZh);
        // }

        if($manual==1){
334
            $dataZh['name'] = $data['name_zh'];
335 336 337 338 339
        }
        else{
            if (strip_tags($data['name']) == null) {
                $data['name'] = 'kosong';
            }
340

341 342 343
            $trans = new GoogleTranslate();
            $name = $trans->translate($this->SOURCE, $this->TARGETZH, $data['name']);
            $dataZh['name'] = $name;
344
        }
345
        $this->repoZh->update($dataZh, $category);
346 347
    }

348 349 350
    /**
     * Remove the specified resource from storage.
     *
351 352
     * @param int $id
     *
353 354 355 356
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
Bagus Pambudi committed
357
        $data = $this->repo->findId($id, ['rEn', 'rDe', 'rSa', 'rZh', 'berita']);
358
        if (count($data->berita) <= 0) {
359
            $this->repo->destroy($data);
360

361 362 363
            if ($data->rEn) {
                $this->repoEn->destroy($data->rEn);
            }
364 365 366 367 368 369 370 371

            if ($data->rDe) {
                $this->repoDe->destroy($data->rDe);
            }

            if ($data->rSa) {
                $this->repoSa->destroy($data->rSa);
            }
372 373 374 375

            if ($data->rZh) {
                $this->repoZh->destroy($data->rZh);
            }
376 377
        }

378
        return response()->json(['done']);
379 380
    }
}