FrontController.php 4.32 KB
Newer Older
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
<?php

namespace App\Http\Controllers\Webprofile\Front;

use App\Http\Controllers\Controller;
use App\Models\Webprofile\Design;
use App\Models\Webprofile\Gallery;
use App\Models\Webprofile\Information;
use App\Models\Webprofile\Menu;
use App\Models\Webprofile\Posts;
use App\Models\Webprofile\Slider;
use Session;

class FrontController extends Controller
{
    public function index()
    {
        $setting = webprofilesetting();

        if (!Session::has('selected_language')) {
            session(['selected_language' => 'id']);
        }

        if (Session::get('selected_language') == 'id') {
            $data = $this->getDataId($setting);
            return view('webprofile.front.' . $setting['theme'] . '.index', $data);
        } else if (Session::get('selected_language') == 'en') {
            $data = $this->getDataEn($setting);
            return view('webprofile.front.' . $setting['theme'] . '.en.index', $data);
        }
    }

    private function getDataId($setting)
    {
Aan Choesni Herlingga committed
35 36 37 38 39 40 41 42 43 44 45
        $posts          = Posts::where('post_status', '1')->orderby('post_date', 'desc')->paginate($setting['post_per_page']);
        $resend         = Posts::where('post_status', '1')->orderby('post_date', 'desc')->limit('5')->get();
        $hot            = Posts::where('post_status', '1')->orderby('viewer', 'desc')->limit('5')->get();
        $info           = Information::where('info_status', '1')->where('event_date', '>=', Date('Y-m-d'))->orderby('event_date', 'asc')->get();
        $slider         = Slider::where('is_active', '1')->orderby('created_at', 'desc')->get();
        $menu           = Menu::orderby('urutan', 'asc')->get();
        $gallery        = Gallery::where('is_active', '1')->orderBy('created_at', 'asc')->limit('4')->get();
        $quote          = Design::where('name_design', 'quote')->get();
        $widget_right   = Design::where('name_design', 'widget_right')->orderBy('urutan', 'ASC')->get();
        $widget_left    = Design::where('name_design', 'widget_left')->orderBy('urutan', 'ASC')->get();
        $body           = Design::where('name_design', 'body')->get();
46 47

        $data = [
Aan Choesni Herlingga committed
48 49 50 51 52 53 54 55 56 57 58 59
            'posts'         => $posts,
            'resend'        => $resend,
            'hot'           => $hot,
            'info'          => $info,
            'slider'        => $slider,
            'menu'          => $menu,
            'gallery'       => $gallery,
            'quote'         => $quote,
            'widget_right'  => $widget_right,
            'widget_left'   => $widget_left,
            'body'          => $body,
            'setting'       => $setting,
60 61 62 63 64 65 66
        ];

        return $data;
    }

    private function getDataEn($setting)
    {
Aan Choesni Herlingga committed
67 68 69 70 71 72 73 74 75 76 77
        $posts          = Posts::with(['rEn'])->where('post_status', '1')->orderby('post_date', 'desc')->paginate($setting['post_per_page']);
        $resend         = Posts::with(['rEn'])->where('post_status', '1')->orderby('post_date', 'desc')->limit('5')->get();
        $hot            = Posts::with(['rEn'])->where('post_status', '1')->orderby('viewer', 'desc')->limit('5')->get();
        $info           = Information::with(['rEn'])->where('info_status', '1')->where('event_date', '>=', Date('Y-m-d'))->orderby('event_date', 'asc')->get();
        $slider         = Slider::where('is_active', '1')->orderby('created_at', 'desc')->get();
        $menu           = Menu::with(['rEn'])->orderby('urutan', 'asc')->get();
        $gallery        = Gallery::where('is_active', '1')->orderBy('created_at', 'asc')->limit('4')->get();
        $quote          = Design::where('name_design', 'quote')->get();
        $widget_right   = Design::where('name_design', 'widget_right')->orderBy('urutan', 'ASC')->get();
        $widget_left    = Design::where('name_design', 'widget_left')->orderBy('urutan', 'ASC')->get();
        $body           = Design::where('name_design', 'body')->get();
78 79

        $data = [
Aan Choesni Herlingga committed
80 81 82 83 84 85 86 87 88 89 90 91
            'posts'         => $posts,
            'resend'        => $resend,
            'hot'           => $hot,
            'info'          => $info,
            'slider'        => $slider,
            'menu'          => $menu,
            'gallery'       => $gallery,
            'quote'         => $quote,
            'widget_right'  => $widget_right,
            'widget_left'   => $widget_left,
            'body'          => $body,
            'setting'       => $setting,
92 93 94 95 96
        ];

        return $data;
    }
}