//[ValidateAntiForgeryToken] public ActionResult Edit(string id) { var viewMode = "update"; AL_AssmblingRow row = null; if (id.isNullOrEmpty()) { row = AlDataService.Instance.AlAssmbling_create().FirstRow; viewMode = "create"; } else { row = AlDataService.Instance.AlAssmbling_getById(id).FirstRow; viewMode = "update"; } ViewBag.ViewMode = viewMode; return(View(row)); }
public ActionResult Edit(FormCollection collection) { var token = collection["__RequestVerificationToken"]; var mode = collection["ViewMode"]; var id = collection[AppDataName.ALA_AssmblingId]; var msgOK = "OK"; AL_AssmblingDataTable dt = null; AL_AssmblingRow row = null; try { if (mode.equalIgnoreCase("create")) { dt = AlDataService.Instance.AlAssmbling_create(); msgOK = FtdStatus.InsertSuccess.ToString(); } else { //找出該筆資料 dt = AlDataService.Instance.AlAssmbling_getById(id); if (dt == null || dt.Count == 0) { return(Json(new { Result = jTable_ERROR_CODE, Message = "資料不存在" })); } msgOK = FtdStatus.UpdateSuccess.ToString(); } //將Form sumit的資料更新至DataRow row = dt.FirstRow; var isOK = this.TryUpdateModel(row); //若驗證失敗-->回傳錯誤訊息 if (!ModelState.IsValid) { var errors = ModelState.Values.Where(x => x.Errors.Count > 0).SelectMany(x => x.Errors.Select(y => y.ErrorMessage)).ToArray(); return(Json(new { Result = jTable_ERROR_CODE, Message = string.Join("<br/>", errors) })); } #region //驗證欄位 List <string> lstError = new List <string>(); if (row.ALA_AssmblingId.isNullOrEmpty()) { lstError.Add("後工程組立ID不能為空"); } if (row.ALA_MCID.isNullOrEmpty()) { lstError.Add("機臺編碼不能為空"); } if (!row.ALA_SEQRow.HasValue) { lstError.Add("列位置不能為空"); } if (!row.ALA_SEQCol.HasValue) { lstError.Add("行位置不能為空"); } if (row.ALA_MCCode.isNullOrEmpty()) { lstError.Add("工程代碼不能為空"); } if (row.ALA_MCName.isNullOrEmpty()) { lstError.Add("工程描述不能為空"); } //回傳錯誤訊息 if (lstError.Count > 0) { return(Json(new { Result = jTable_ERROR_CODE, Message = string.Join("<br/>", lstError.ToArray()) })); } //檢查鍵值是否重覆 #endregion dt.ns_update(); dt.AcceptChanges(); return(Json(new { Result = msgOK })); } catch (Exception ex) { return(Json(new { Result = jTable_ERROR_CODE, Message = ex.Message })); } }