ok
Direktori : /home2/selectio/www/fms-worksuite/app/Http/Controllers/ |
Current File : /home2/selectio/www/fms-worksuite/app/Http/Controllers/NoticeController.php |
<?php namespace App\Http\Controllers; use App\DataTables\NoticeBoardDataTable; use App\Helper\Reply; use App\Http\Requests\Notice\StoreNotice; use App\Models\Notice; use App\Models\Team; use Illuminate\Http\Request; class NoticeController extends AccountBaseController { public function __construct() { parent::__construct(); $this->pageTitle = 'app.menu.noticeBoard'; } /** * Display a listing of the resource. * * @return \Illuminate\Http\Response */ public function index(NoticeBoardDataTable $dataTable) { $viewPermission = user()->permission('view_notice'); abort_403(!in_array($viewPermission, ['all', 'added', 'owned', 'both'])); return $dataTable->render('notices.index', $this->data); } /** * Show the form for creating a new resource. * * @return \Illuminate\Http\Response */ public function create() { $this->addPermission = user()->permission('add_notice'); abort_403(!in_array($this->addPermission, ['all', 'added'])); $this->teams = Team::all(); $this->pageTitle = __('modules.notices.addNotice'); if (request()->ajax()) { $html = view('notices.ajax.create', $this->data)->render(); return Reply::dataOnly(['status' => 'success', 'html' => $html, 'title' => $this->pageTitle]); } $this->view = 'notices.ajax.create'; return view('notices.create', $this->data); } /** * @param StoreNotice $request * @return array|void * @throws \Froiden\RestAPI\Exceptions\RelatedResourceNotFoundException */ public function store(StoreNotice $request) { $this->addPermission = user()->permission('add_notice'); abort_403(!in_array($this->addPermission, ['all', 'added'])); $notice = new Notice(); $notice->heading = $request->heading; $notice->description = trim_editor($request->description); $notice->to = $request->to; $notice->department_id = $request->team_id; $notice->save(); return Reply::successWithData(__('messages.recordSaved'), ['redirectUrl' => route('notices.index')]); } /** * Display the specified resource. * * @param int $id * @return \Illuminate\Http\Response */ public function show($id) { $this->notice = Notice::with('member', 'member.user')->findOrFail($id); $this->viewPermission = user()->permission('view_notice'); abort_403(!( $this->viewPermission == 'all' || ($this->viewPermission == 'added' && $this->notice->added_by == user()->id) || ($this->viewPermission == 'owned' && in_array($this->notice->to, user_roles())) || ($this->viewPermission == 'both' && (in_array($this->notice->to, user_roles()) || $this->notice->added_by == user()->id)) )); $readUser = $this->notice->member->filter(function ($value, $key) { return $value->user_id == $this->user->id && $value->notice_id == $this->notice->id; })->first(); if ($readUser) { $readUser->read = 1; $readUser->save(); } $this->readMembers = $this->notice->member->filter(function ($value, $key) { return $value->read == 1; }); $this->unReadMembers = $this->notice->member->filter(function ($value, $key) { return $value->read == 0; }); if (request()->ajax()) { $this->pageTitle = __('app.menu.noticeBoard'); $html = view('notices.ajax.show', $this->data)->render(); return Reply::dataOnly(['status' => 'success', 'html' => $html, 'title' => $this->pageTitle]); } $this->view = 'notices.ajax.show'; return view('notices.create', $this->data); } /** * Show the form for editing the specified resource. * * @param int $id * @return \Illuminate\Http\Response */ public function edit($id) { $this->notice = Notice::findOrFail($id); $this->editPermission = user()->permission('edit_notice'); abort_403(!( $this->editPermission == 'all' || ($this->editPermission == 'added' && $this->notice->added_by == user()->id) || ($this->editPermission == 'owned' && in_array($this->notice->to, user_roles())) || ($this->editPermission == 'both' && (in_array($this->notice->to, user_roles()) || $this->notice->added_by == user()->id)) )); $this->teams = Team::all(); $this->pageTitle = __('modules.notices.updateNotice'); if (request()->ajax()) { $html = view('notices.ajax.edit', $this->data)->render(); return Reply::dataOnly(['status' => 'success', 'html' => $html, 'title' => $this->pageTitle]); } $this->view = 'notices.ajax.edit'; return view('notices.create', $this->data); } /** * @param StoreNotice $request * @param int $id * @return array|void * @throws \Froiden\RestAPI\Exceptions\RelatedResourceNotFoundException */ public function update(StoreNotice $request, $id) { $notice = Notice::findOrFail($id); $this->editPermission = user()->permission('edit_notice'); abort_403(!( $this->editPermission == 'all' || ($this->editPermission == 'added' && $this->notice->added_by == user()->id) || ($this->editPermission == 'owned' && in_array($this->notice->to, user_roles())) || ($this->editPermission == 'both' && (in_array($this->notice->to, user_roles()) || $this->notice->added_by == user()->id)) )); $notice->heading = $request->heading; $notice->description = trim_editor($request->description); $notice->to = $request->to; $notice->department_id = $request->team_id; $notice->save(); return Reply::successWithData(__('messages.updateSuccess'), ['redirectUrl' => route('notices.index')]); } /** * Remove the specified resource from storage. * * @param int $id * @return \Illuminate\Http\Response */ public function destroy($id) { $notice = Notice::findOrFail($id); $this->deletePermission = user()->permission('delete_notice'); abort_403(!( $this->deletePermission == 'all' || ($this->deletePermission == 'added' && $notice->added_by == user()->id) || ($this->deletePermission == 'owned' && in_array($notice->to, user_roles())) || ($this->deletePermission == 'both' && (in_array($notice->to, user_roles()) || $notice->added_by == user()->id)) )); Notice::destroy($id); return Reply::successWithData(__('messages.deleteSuccess'), ['redirectUrl' => route('notices.index')]); } public function applyQuickAction(Request $request) { switch ($request->action_type) { case 'delete': $this->deleteRecords($request); return Reply::success(__('messages.deleteSuccess')); default: return Reply::error(__('messages.selectAction')); } } protected function deleteRecords($request) { abort_403(user()->permission('delete_notice') != 'all'); Notice::whereIn('id', explode(',', $request->row_ids))->forceDelete(); } }