설명 없음

NewsController.php 11KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306
  1. <?php
  2. namespace App\Http\Controllers\Admin\Raharja;
  3. use App\Http\Controllers\Controller;
  4. use Illuminate\Support\Facades\DB;
  5. use Illuminate\Http\Request;
  6. use App\Helpers\Helper;
  7. use App\Model\Raharja\News;
  8. use Yajra\Datatables\Datatables;
  9. use Auth;
  10. use Illuminate\Support\Facades\Storage;
  11. use Validator;
  12. use Hashids;
  13. //load modelmu
  14. class NewsController extends Controller
  15. {
  16. /**
  17. * Title untuk judul di web
  18. * route digunakan untuk tempat resource (file path) + routing (route/web) diusahain sama ya biar gak ngubah"
  19. */
  20. private $title = 'News'; /**jangan lupa diganti*/
  21. private $route = 'admin.news.'; //path awal foldernya ajah (misal folder di admin/dashboard) => 'admin.dashboard' | jangan lupa diganti
  22. private $header = 'News';
  23. private $sub_header = 'News';
  24. private $url = 'admin.raharja.news.';
  25. public function __construct()
  26. {
  27. DB::enableQueryLog();
  28. /** nyalakan jika sudah set rolenya, jika ini dinyalakan halaman ini tidak akan keluar */
  29. // $this->middleware('permission:searching-list|searching-create|searching-update|searching-delete', ['only' => ['index', 'create', 'update']]);
  30. // $this->middleware('permission:searching-create', ['only' => ['create', 'create_action']]);
  31. // $this->middleware('permission:searching-update', ['only' => ['update', 'update_action']]);
  32. // $this->middleware('permission:searching-delete', ['only' => ['delete']]);
  33. }
  34. /**
  35. * Ini contoh crud yang sudah jalan
  36. * index digunakna untuk tampilan awal dari menu yang akan dibuat
  37. * Untuk CRUD Biar cepat
  38. * Silahkan ganti
  39. * EloquentMu:: => dengan model anda
  40. * $id_modelmu => ganti dengan id di model anda
  41. * id_di_routenya => jangan lupa disesuaikan dengan yang dideclare di route
  42. */
  43. public function index()
  44. {
  45. Helper::swal();
  46. $data = [
  47. //bawaan
  48. 'title' => $this->title,
  49. 'route' => $this->route,
  50. 'header' => $this->header,
  51. 'sub_header' => $this->sub_header,
  52. ];
  53. // dd($data);
  54. return view($this->url . 'index', $data);
  55. }
  56. public function getData($udd_id = null)
  57. {
  58. $query = News::query();
  59. return Datatables::of($query)
  60. ->addIndexColumn()
  61. ->addColumn('count_like', function($query){
  62. return count($query->newsLikes);
  63. })
  64. ->addColumn('aksi', function ($query) {
  65. /**cek role */
  66. $aksi = '';
  67. // if (Auth::user()->can('master-jenis-kantong-update')) {
  68. $aksi .= "<a href='" . route($this->route . 'update', ['news_id' => Hashids::encode($query->id)]) . "' class='btn btn-sm btn-primary btn-edit'>Edit</a>";
  69. // }
  70. // if (Auth::user()->can('master-jenis-kantong-delete')) {
  71. $aksi .= "<a href='javascript:;' data-route='" . route($this->route . 'delete_action', ['news_id' => Hashids::encode($query->id)]) . "' class='btn btn-danger btn-sm btn-delete'>Delete</a>";
  72. // }
  73. return $aksi;
  74. })
  75. ->rawColumns(['aksi'])
  76. ->toJson();
  77. }
  78. public function create()
  79. {
  80. $data = [
  81. //bawaan
  82. 'title' => $this->title,
  83. 'route' => $this->route,
  84. 'header' => $this->header,
  85. 'sub_header' => $this->sub_header,
  86. ];
  87. Helper::swal();
  88. return view($this->url . 'create', $data);
  89. }
  90. public function create_action(Request $request)
  91. {
  92. //declare post untuk simpan semua request yang diinputkan oleh form name=""
  93. $post = $request->all();
  94. $file = $request->file('gambar');
  95. //dd($post);
  96. /**digunakan untuk set rule validator */
  97. $rules = [
  98. 'title' => 'required',
  99. 'gambar' => 'required|file|max:1000',
  100. 'content' => 'required',
  101. 'sub_title' => 'required',
  102. 'date_publish' => 'required',
  103. ];
  104. /**digunakan untuk set message dari validatornya yang akan keluar gimna, :attribue itu udah langsung mendeteksi inputtan dari name="attribue" */
  105. $alert = [
  106. 'file' => 'File maksimal 1MB'
  107. ];
  108. $validator = Validator::make($post, $rules, $alert);
  109. if ($validator->passes()) {
  110. /**menggunakan transaction */
  111. DB::beginTransaction();
  112. $nama_file = time()."_".$file->getClientOriginalName();
  113. $tujuan_upload = 'gambar';
  114. //$file->move($tujuan_upload,$nama_file);
  115. Storage::putFileAs('public/images/news/', $file, $nama_file );
  116. $query = new News();
  117. $query->title = $request->title;
  118. $query->content = Helper::input_summernote($request->content);
  119. $query->sub_title = Helper::input_summernote($request->sub_title);
  120. $query->date_publish = $request->date_publish;
  121. $query->user_id = Auth::user()->id;
  122. $query->thumbnail = $nama_file;
  123. $query->save();
  124. if ($query) {
  125. DB::commit();
  126. $message = 'Berhasil';
  127. return redirect(route($this->route . 'index'))->with('success', Helper::parsing_alert($message));
  128. } else {
  129. DB::rollback();
  130. $message = 'Gagal';
  131. return redirect()->back()->with('error', Helper::parsing_alert($message));
  132. }
  133. }
  134. /**kenapa menggunakan back ? karena baliknya pasti ke halaman sebelumnya */
  135. $message = Helper::parsing_alert($validator->errors()->all());
  136. return redirect()->back()->with('error', $message)->withInput();
  137. }
  138. public function update($data_id)
  139. {
  140. Helper::swal();
  141. $data_id = Hashids::decode($data_id);
  142. if (!empty($data_id)) {
  143. $cek_data = News::where('id', $data_id[0])->first();
  144. if ($cek_data) {
  145. $data = [
  146. //bawaan
  147. 'title' => $this->title,
  148. 'route' => $this->route,
  149. 'header' => $this->header,
  150. 'sub_header' => $this->sub_header,
  151. 'data' => $cek_data
  152. ];
  153. return view($this->url . 'update', $data);
  154. }
  155. $message = 'Id tidak ditemukan atau sudah dihapus';
  156. return redirect()->back()->with('error', $message);
  157. }
  158. $message = 'Id tdak ditemukan';
  159. return redirect()->back()->with('error', $message);
  160. }
  161. public function update_action(Request $request)
  162. {
  163. $post = $request->all();
  164. /**digunakan untuk set rule validator */
  165. $rules = [
  166. 'title' => 'required',
  167. 'content' => 'required',
  168. 'sub_title' => 'required',
  169. 'date_publish' => 'required',
  170. ];
  171. /**digunakan untuk set message dari validatornya yang akan keluar gimna, :attribue itu udah langsung mendeteksi inputtan dari name="attribue" */
  172. $alert = [];
  173. $validator = Validator::make($post, $rules, $alert);
  174. $data_id = Hashids::decode($request['id']);
  175. if (!empty($data_id)) {
  176. /**cek apakah data_idnya ada ? */
  177. $query = News::find($data_id[0]);
  178. if ($query) {
  179. /**cek apakah id data benar" ada di DB ? */
  180. if ($validator->passes()) {
  181. /**validatornya */
  182. DB::beginTransaction();
  183. $file = $request->file('gambar');
  184. if($file){
  185. $nama_file = time()."_".$file->getClientOriginalName();
  186. $tujuan_upload = 'gambar';
  187. //$file->move($tujuan_upload,$nama_file);
  188. Storage::putFileAs('public/images/news/', $file, $nama_file );
  189. //File::delete('gambar/'.$query->gambar);
  190. Storage::delete('public/images/news/'.$query->thumbnail);
  191. $query->thumbnail = $nama_file;
  192. }
  193. $query->title = $request->title;
  194. $query->content = Helper::input_summernote($request->content);
  195. $query->sub_title = Helper::input_summernote($request->sub_title);
  196. $query->date_publish = $request->date_publish;
  197. $query->save();
  198. if ($query) {
  199. DB::commit();
  200. $message = 'Berhasil';
  201. return redirect(route($this->route . 'index'))->with('success', Helper::parsing_alert($message));
  202. } else {
  203. DB::rollback();
  204. $message = 'Gagal';
  205. return redirect()->back()->with('error', Helper::parsing_alert($message));
  206. }
  207. }
  208. $message = Helper::parsing_alert($validator->errors()->all());
  209. return redirect()->back()->with('error', $message);
  210. } else {
  211. $message = 'Id tdak ditemukan';
  212. return redirect()->back()->with('error', $message);
  213. }
  214. } else {
  215. $message = 'Id tidak boleh kosong';
  216. return redirect()->back()->with('error', $message);
  217. }
  218. }
  219. public function delete_action($id_modelmu)
  220. {
  221. $id = Hashids::decode($id_modelmu);
  222. /**cek idnya apakah ada ? */
  223. if (!empty($id)) {
  224. $cek_data = News::find($id[0]);
  225. if ($cek_data) {
  226. DB::beginTransaction();
  227. try {
  228. //File::delete('gambar/'.$cek_data->gambar);
  229. $arr_likes = $cek_data->newsLikes;
  230. foreach($arr_likes as $like){
  231. $like->delete();
  232. }
  233. Storage::delete('public/images/news/'.$cek_data->thumbnail);
  234. $delete = $cek_data->delete();
  235. DB::commit();
  236. $message = 'Sukses';
  237. $response = [
  238. 'message' => $message,
  239. 'status' => true,
  240. ];
  241. return response()->json($response);
  242. } catch (Exception $e) {
  243. DB::rollback();
  244. $message = 'Gagal';
  245. $response = [
  246. 'message' => $message,
  247. 'status' => false,
  248. ];
  249. return response()->json($response);
  250. }
  251. }
  252. $message = 'Id tidak ditemukan atau sudah dihapus';
  253. $response = [
  254. 'message' => $message,
  255. 'status' => false,
  256. ];
  257. return response()->json($response);
  258. }
  259. $message = 'Id tdak ditemukan';
  260. $response = [
  261. 'message' => $message,
  262. 'status' => false,
  263. ];
  264. return response()->json($response);
  265. }
  266. }