FrontController.php 12.3 KB
Newer Older
1 2 3 4 5 6 7 8
<?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;
Bagus Pambudi committed
9
use App\Models\Webprofile\Agenda;
10 11 12 13 14 15 16 17 18 19 20 21
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')) {
22
            session(['selected_language' => $setting['default_language']]);
23 24 25 26
        }

        if (Session::get('selected_language') == 'id') {
            $data = $this->getDataId($setting);
Bagus Pambudi committed
27 28 29
            if(isset($setting['ppid']) )
            return view('webprofile.front.'.$setting['theme'].'.indexcustom', $data);
            else
30 31
            return view('webprofile.front.'.$setting['theme'].'.index', $data);
        } elseif (Session::get('selected_language') == 'en') {
32
            $data = $this->getDataEn($setting);
Bagus Pambudi committed
33 34 35
            if(isset($setting['ppid']) )
            return view('webprofile.front.'.$setting['theme'].'.en.indexcustom', $data);
            else
36
            return view('webprofile.front.'.$setting['theme'].'.en.index', $data);
37 38
        } elseif (Session::get('selected_language') == 'de') {
            $data = $this->getDataDe($setting);
Bagus Pambudi committed
39 40 41
            if(isset($setting['ppid']) )
            return view('webprofile.front.'.$setting['theme'].'.de.indexcustom', $data);
            else
42
            return view('webprofile.front.'.$setting['theme'].'.de.index', $data);
43 44
        } elseif (Session::get('selected_language') == 'ar') {
            $data = $this->getDataSa($setting);
Bagus Pambudi committed
45 46 47
            if(isset($setting['ppid']) )
            return view('webprofile.front.'.$setting['theme'].'.ar.indexcustom', $data);
            else
48
            return view('webprofile.front.'.$setting['theme'].'.ar.index', $data);
49 50
        } elseif (Session::get('selected_language') == 'zh') {
            $data = $this->getDataZh($setting);
Bagus Pambudi committed
51 52 53
            if(isset($setting['ppid']) )
            return view('webprofile.front.'.$setting['theme'].'.zh.indexcustom', $data);
            else
54
            return view('webprofile.front.'.$setting['theme'].'.zh.index', $data);
55 56 57 58 59
        }
    }

    private function getDataId($setting)
    {
60
        $posts = Posts::where('post_status', '1')->orderby('post_date', 'desc')->paginate($setting['post_per_page']);
Bagus Pambudi committed
61
        $posthome = Posts::where('post_status', '1')->orderby('post_date', 'desc')->paginate(isset($setting['post_home'])?$setting['post_home']:'6');
62
        $resend = Posts::where('post_status', '1')->orderby('post_date', 'desc')->limit(isset($setting['limit_terkini'])?$setting['limit_terkini']:'5')->get();
63
        $hot = Posts::where('post_status', '1')->orderby('viewer', 'desc')->limit(isset($setting['limit_populer'])?$setting['limit_populer']:'5')->get();
64
        $info = Information::where('info_status', '1')->where('event_date', '>=', date('Y-m-d'))->orderby('event_date', 'asc')->get();
Bagus Pambudi committed
65
        $agenda = Agenda::where('info_status', '1')->where('event_date', '>=', date('Y-m-d'))->orderby('event_date', 'asc')->get();
66 67
        $slider = Slider::where('is_active', '1')->orderby('created_at', 'desc')->get();
        $menu = Menu::orderby('urutan', 'asc')->get();
Bagus Pambudi committed
68
        $gallery = Gallery::where('is_active', '1')->orderBy('created_at', 'asc')->get();
69 70 71
        $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();
72
        $body = Design::where('name_design', 'body')->where('title_show' , 't')->get();
73
        $footer = Design::where('name_design', 'like', '%footer_row%')->get();
74 75

        $data = [
76
            'posts' => $posts,
77
            'posthome' => $posthome,
78 79 80
            'resend' => $resend,
            'hot' => $hot,
            'info' => $info,
Bagus Pambudi committed
81
            'agenda' => $agenda,
82 83 84 85 86 87 88 89 90
            'slider' => $slider,
            'menu' => $menu,
            'gallery' => $gallery,
            'quote' => $quote,
            'widget_right' => $widget_right,
            'widget_left' => $widget_left,
            'body' => $body,
            'setting' => $setting,
            'footer' => $footer,
91 92 93 94 95 96 97
        ];

        return $data;
    }

    private function getDataEn($setting)
    {
98
        $posts = Posts::with(['rEn'])->where('post_status', '1')->orderby('post_date', 'desc')->paginate($setting['post_per_page']);
99 100
        $resend = Posts::with(['rEn'])->where('post_status', '1')->orderby('post_date', 'desc')->limit(isset($setting['limit_terkini'])?$setting['limit_terkini']:'5')->get();
        $hot = Posts::with(['rEn'])->where('post_status', '1')->orderby('viewer', 'desc')->limit(isset($setting['limit_populer'])?$setting['limit_populer']:'5')->get();
101
        $info = Information::with(['rEn'])->where('info_status', '1')->where('event_date', '>=', date('Y-m-d'))->orderby('event_date', 'asc')->get();
Bagus Pambudi committed
102
        $agenda = Agenda::with(['rEn'])->where('info_status', '1')->where('event_date', '>=', date('Y-m-d'))->orderby('event_date', 'asc')->get();
103 104
        $slider = Slider::where('is_active', '1')->orderby('created_at', 'desc')->get();
        $menu = Menu::with(['rEn'])->orderby('urutan', 'asc')->get();
Bagus Pambudi committed
105
        $gallery = Gallery::where('is_active', '1')->orderBy('created_at', 'asc')->get();
Bagus Pambudi committed
106
        $quote = Design::with(['rEn'])->where('name_design', 'quote')->get();
107 108
        $widget_right = Design::where('name_design', 'widget_right')->orderBy('urutan', 'ASC')->get();
        $widget_left = Design::where('name_design', 'widget_left')->orderBy('urutan', 'ASC')->get();
Bagus Pambudi committed
109
        $body = Design::with(['rEn'])->where('name_design', 'body')->get();
110 111 112 113 114 115 116
        $footer = Design::where('name_design', 'like', '%footer_row%')->get();

        $data = [
            'posts' => $posts,
            'resend' => $resend,
            'hot' => $hot,
            'info' => $info,
Bagus Pambudi committed
117
            'agenda' => $agenda,
118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134
            'slider' => $slider,
            'menu' => $menu,
            'gallery' => $gallery,
            'quote' => $quote,
            'widget_right' => $widget_right,
            'widget_left' => $widget_left,
            'body' => $body,
            'setting' => $setting,
            'footer' => $footer,
        ];

        return $data;
    }

    private function getDataDe($setting)
    {
        $posts = Posts::with(['rDe'])->where('post_status', '1')->orderby('post_date', 'desc')->paginate($setting['post_per_page']);
135 136
        $resend = Posts::with(['rDe'])->where('post_status', '1')->orderby('post_date', 'desc')->limit(isset($setting['limit_terkini'])?$setting['limit_terkini']:'5')->get();
        $hot = Posts::with(['rDe'])->where('post_status', '1')->orderby('viewer', 'desc')->limit(isset($setting['limit_populer'])?$setting['limit_populer']:'5')->get();
137
        $info = Information::with(['rDe'])->where('info_status', '1')->where('event_date', '>=', date('Y-m-d'))->orderby('event_date', 'asc')->get();
Bagus Pambudi committed
138
        $agenda = Agenda::with(['rDe'])->where('info_status', '1')->where('event_date', '>=', date('Y-m-d'))->orderby('event_date', 'asc')->get();
139 140
        $slider = Slider::where('is_active', '1')->orderby('created_at', 'desc')->get();
        $menu = Menu::with(['rDe'])->orderby('urutan', 'asc')->get();
Bagus Pambudi committed
141
        $gallery = Gallery::where('is_active', '1')->orderBy('created_at', 'asc')->get();
Bagus Pambudi committed
142
        $quote = Design::with(['rDe'])->where('name_design', 'quote')->get();
143 144
        $widget_right = Design::where('name_design', 'widget_right')->orderBy('urutan', 'ASC')->get();
        $widget_left = Design::where('name_design', 'widget_left')->orderBy('urutan', 'ASC')->get();
Bagus Pambudi committed
145
        $body = Design::with(['rDe'])->where('name_design', 'body')->get();
146 147 148 149 150 151 152
        $footer = Design::where('name_design', 'like', '%footer_row%')->get();

        $data = [
            'posts' => $posts,
            'resend' => $resend,
            'hot' => $hot,
            'info' => $info,
Bagus Pambudi committed
153
            'agenda' => $agenda,
154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170
            'slider' => $slider,
            'menu' => $menu,
            'gallery' => $gallery,
            'quote' => $quote,
            'widget_right' => $widget_right,
            'widget_left' => $widget_left,
            'body' => $body,
            'setting' => $setting,
            'footer' => $footer,
        ];

        return $data;
    }

    private function getDataSa($setting)
    {
        $posts = Posts::with(['rSa'])->where('post_status', '1')->orderby('post_date', 'desc')->paginate($setting['post_per_page']);
171 172
        $resend = Posts::with(['rSa'])->where('post_status', '1')->orderby('post_date', 'desc')->limit(isset($setting['limit_terkini'])?$setting['limit_terkini']:'5')->get();
        $hot = Posts::with(['rSa'])->where('post_status', '1')->orderby('viewer', 'desc')->limit(isset($setting['limit_populer'])?$setting['limit_populer']:'5')->get();
173
        $info = Information::with(['rSa'])->where('info_status', '1')->where('event_date', '>=', date('Y-m-d'))->orderby('event_date', 'asc')->get();
Bagus Pambudi committed
174
        $agenda = Agenda::with(['rSa'])->where('info_status', '1')->where('event_date', '>=', date('Y-m-d'))->orderby('event_date', 'asc')->get();
175 176
        $slider = Slider::where('is_active', '1')->orderby('created_at', 'desc')->get();
        $menu = Menu::with(['rSa'])->orderby('urutan', 'asc')->get();
Bagus Pambudi committed
177
        $gallery = Gallery::where('is_active', '1')->orderBy('created_at', 'asc')->get();
Bagus Pambudi committed
178
        $quote = Design::with(['rSa'])->where('name_design', 'quote')->get();
179 180
        $widget_right = Design::where('name_design', 'widget_right')->orderBy('urutan', 'ASC')->get();
        $widget_left = Design::where('name_design', 'widget_left')->orderBy('urutan', 'ASC')->get();
Bagus Pambudi committed
181
        $body = Design::with(['rSa'])->where('name_design', 'body')->get();
182 183 184 185 186 187 188
        $footer = Design::where('name_design', 'like', '%footer_row%')->get();

        $data = [
            'posts' => $posts,
            'resend' => $resend,
            'hot' => $hot,
            'info' => $info,
Bagus Pambudi committed
189
            'agenda' => $agenda,
190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206
            'slider' => $slider,
            'menu' => $menu,
            'gallery' => $gallery,
            'quote' => $quote,
            'widget_right' => $widget_right,
            'widget_left' => $widget_left,
            'body' => $body,
            'setting' => $setting,
            'footer' => $footer,
        ];

        return $data;
    }

    private function getDataZh($setting)
    {
        $posts = Posts::with(['rZh'])->where('post_status', '1')->orderby('post_date', 'desc')->paginate($setting['post_per_page']);
207 208
        $resend = Posts::with(['rZh'])->where('post_status', '1')->orderby('post_date', 'desc')->limit(isset($setting['limit_terkini'])?$setting['limit_terkini']:'5')->get();
        $hot = Posts::with(['rZh'])->where('post_status', '1')->orderby('viewer', 'desc')->limit(isset($setting['limit_populer'])?$setting['limit_populer']:'5')->get();
209
        $info = Information::with(['rZh'])->where('info_status', '1')->where('event_date', '>=', date('Y-m-d'))->orderby('event_date', 'asc')->get();
Bagus Pambudi committed
210
        $agenda = Agenda::with(['rZh'])->where('info_status', '1')->where('event_date', '>=', date('Y-m-d'))->orderby('event_date', 'asc')->get();
211 212
        $slider = Slider::where('is_active', '1')->orderby('created_at', 'desc')->get();
        $menu = Menu::with(['rZh'])->orderby('urutan', 'asc')->get();
Bagus Pambudi committed
213
        $gallery = Gallery::where('is_active', '1')->orderBy('created_at', 'asc')->get();
Bagus Pambudi committed
214
        $quote = Design::with(['rZh'])->where('name_design', 'quote')->get();
215 216
        $widget_right = Design::where('name_design', 'widget_right')->orderBy('urutan', 'ASC')->get();
        $widget_left = Design::where('name_design', 'widget_left')->orderBy('urutan', 'ASC')->get();
Bagus Pambudi committed
217
        $body = Design::with(['rZh'])->where('name_design', 'body')->get();
218
        $footer = Design::where('name_design', 'like', '%footer_row%')->get();
219 220

        $data = [
221 222 223 224
            'posts' => $posts,
            'resend' => $resend,
            'hot' => $hot,
            'info' => $info,
Bagus Pambudi committed
225
            'agenda' => $agenda,
226 227 228 229 230 231 232 233
            'slider' => $slider,
            'menu' => $menu,
            'gallery' => $gallery,
            'quote' => $quote,
            'widget_right' => $widget_right,
            'widget_left' => $widget_left,
            'body' => $body,
            'setting' => $setting,
234
            'footer' => $footer,
235 236 237 238 239
        ];

        return $data;
    }
}