checkParamSv=new CheckParamService(); $this->trackManagementSv = new TrackManagementService(); } public function index() { // 渲染 return view('admin.DataManagement.TrackManagement'); } public function grid() { // 取得參數 $param = $_GET; if ($param == null) exit(); $draw = $param["draw"]; //客戶端傳來的查詢次數,無條件回傳用以核對 $orderColumn = $param["order"][0]["column"] + 1; //前端從 0 開始送,但 mysql 從 1 開始算 $orderDir = $param["order"][0]["dir"]; $start = $param["start"]; // 頁碼 $length = $param["length"]; // 一頁多大 $searchValue = $param["search"]["value"]; //客製化搜尋欄位 $keyword = $param["columns"][1]["search"]["value"] ?? null ; // 驗證 if ($keyword != filter_var($keyword, FILTER_SANITIZE_SPECIAL_CHARS)) $keyword = "___CANNOT_FIND_STRING___"; if (!$this->checkParamSv->LenMToN($keyword, 0, 50)) $keyword = "___CANNOT_FIND_STRING___"; //資料庫 $recordsTotal = 0; $result=$this->trackManagementSv->getList($recordsTotal, $orderColumn, $orderDir, $start, $length, $searchValue, $keyword); // 整理返回資料 $data = array(); $registeredSession = ''; $lunchOptions = ''; for ($i = 0; $i < count($result); $i++) { $result[$i]["ctrEdit"]=' 編輯 刪除 '; $data[] = array( //一般資料 $result[$i]["id"], htmlspecialchars($result[$i]["trackNo"]), htmlspecialchars($result[$i]["trackTitle"]), htmlspecialchars($result[$i]["trackLimit"]), $result[$i]["createDate"], $result[$i]["ctrEdit"], ); } $json = array( "draw" => $draw, "recordsTotal" => $recordsTotal, "recordsFiltered" => $recordsTotal, //其實還是填入所有筆數,本次筆數可從陣列取得 "data" => $data, ); // 返回 return json_decode(json_encode($json), true); } public function create() { // 渲染 return view('admin.DataManagement.TrackManagementEdit', [ 'operdata' => '', 'id' => '', ]); } public function edit($id) { // 取得參數與驗證 // 服務層取得資料(以及實現各種業務上的邏輯) $res = $this->trackManagementSv->getTrackDataById($id); // 渲染 return view('admin.DataManagement.TrackManagementEdit', [ 'operdata' => $res, 'id' => $id, ]); } public function store(Request $request) { // 取得參數(由於是內部系統因此不做後端驗證) try { $mode = $request->operateMode; $id = $request->id ?? null; $trackNo = $request->trackNo; $trackTitle = $request->trackTitle; $trackLimit = $request->trackLimit; \DB::beginTransaction(); // 服務層設置(以及實現各種業務上的邏輯) if ($mode=='insert') { $this->trackManagementSv->insert( $trackNo, $trackTitle, $trackLimit, ); } elseif ($mode=='edit') { $this->trackManagementSv->store( $id, $trackNo, $trackTitle, $trackLimit, ); } \DB::commit(); return response()->json([ 'code' => 0, 'message' => 'ok', 'data' => [], ]); } catch (\Exception $e) { \DB::rollBack(); return response()->json([ 'code' => 99, 'message' => $e->getMessage().'/'.$e->getLine().'/'.$e->getFile(), 'data' => [], ]); } // $this->referralTagManagementSv->modifyreferralTagByReferralAndTagIds($id, $hidTag); // 跳轉 return redirect('/backend/dataManagement/track'); } public function delete($id) { // 取得參數與驗證 // 服務層取得資料(以及實現各種業務上的邏輯) $this->trackManagementSv->deleteDataById($id); // 跳轉 return redirect('/backend/dataManagement/track'); } }