/// <summary> /// F3 リボン 揚り入力 /// </summary> /// <param name="e"></param> public override void OnF3Key(object sender, KeyEventArgs e) { // 揚り入力画面を表示する DLY02010 agrForm = new DLY02010(); agrForm.ShowDialog(this); }
/// <summary> /// 入力内容の検証をおこなう /// </summary> /// <returns>bool</returns> private bool isFormValidation() { bool isResult = false; int intSyohinkeitaibunrui = 0; blnWarningFlg = false; // 揚り明細より情報を取得する foreach (DataRow row in SearchDetail.Rows) { intSyohinkeitaibunrui = int.Parse(row["商品形態分類"].ToString()); } // 現在の明細行を取得 var CurrentDetail = InnerDetail.Select("", "", DataViewRowState.CurrentRows).AsEnumerable(); // 【明細】詳細データが1件もない場合はエラー if (InnerDetail == null || CurrentDetail.Where(a => !string.IsNullOrEmpty(a.Field <string>("自社品番"))).Count() == 0) { gridDtb.SpreadGrid.Focus(); base.ErrorMessage = string.Format("明細情報が1件もありません。"); return(isResult); } // 【明細】品番の商品分類が食品(1)の場合は賞味期限が必須 int rIdx = 0; bool isDetailErr = false; foreach (DataRow row in InnerDetail.Rows) { // 削除行は検証対象外 if (row.RowState == DataRowState.Deleted) { continue; } // 追加行未入力レコードはスキップ if (row["品番コード"] == null || string.IsNullOrEmpty(row["品番コード"].ToString()) || row["品番コード"].ToString().Equals("0")) { rIdx++; continue; } // エラー情報をクリア gridDtb.ClearValidationErrors(rIdx); DateTime?row賞味期限 = DBNull.Value.Equals(row["賞味期限"]) ? (DateTime?)null : Convert.ToDateTime(row["賞味期限"]); int? row品番コード = DBNull.Value.Equals(row["品番コード"]) ? (int?)null : Convert.ToInt32(row["品番コード"]); if (CurrentDetail.Where(x => x.Field <int?>("品番コード") == row品番コード && x.Field <DateTime?>("賞味期限") == row賞味期限).Count() > 1) { gridDtb.SpreadGrid.Focus(); base.ErrorMessage = string.Format("同じ商品が存在するので、一つに纏めて下さい。"); gridDtb.AddValidationError(rIdx, (int)GridColumnsMapping.品番コード, "同じ商品が存在するので、一つに纏めて下さい。"); if (!isDetailErr) { gridDtb.SetCellFocus(rIdx, (int)GridColumnsMapping.品番コード); } isDetailErr = true; } if (string.IsNullOrEmpty(row["数量"].ToString())) { gridDtb.AddValidationError(rIdx, (int)GridColumnsMapping.数量, "数量が入力されていません。"); if (!isDetailErr) { gridDtb.SetCellFocus(rIdx, (int)GridColumnsMapping.数量); } isDetailErr = true; } int type = Convert.ToInt32(row["商品分類"]); DateTime date; if (!DateTime.TryParse(row["賞味期限"].ToString(), out date)) { // 変換に失敗かつ商品分類が「食品」かつ数量が0以外の場合はエラー if (type.Equals((int)商品分類.食品) && row["数量"].ToString().Equals("0.00") == false) { gridDtb.AddValidationError(rIdx, (int)GridColumnsMapping.賞味期限, "商品分類が『食品』の為、賞味期限の設定が必要です。"); isDetailErr = true; } } // 商品形態分類がセット品の場合、エラーチェックを行う if (intSyohinkeitaibunrui == 1) // No-279 Add { // セット品番マスタチェック(存在しない) if (DLY02010.isCheckShinNotExist(SetHin, row["品番コード"].ToString()) == false) { gridDtb.AddValidationError(rIdx, (int)GridColumnsMapping.品番コード, "製品を構成しない部材が入力されています。"); blnWarningFlg = true; } } rIdx++; } // 商品形態分類がセット品の場合、エラーチェックを行う if (intSyohinkeitaibunrui == 1) // No-279 Add { // セット品番マスタチェック(構成しない部材) if (DLY02010.isCheckShinUnnecessary(SetHin, InnerDetail) == false) { gridDtb.SpreadGrid.Focus(); base.ErrorMessage = string.Format("製品を構成する部材が入力されていません。"); blnWarningFlg = true; } // セット品番マスタチェック(数量) string strErrMsg = string.Empty; if (DLY02010.isCheckShinQuantity(SetHin, SearchDetail, InnerDetail, out strErrMsg) == false) { gridDtb.SpreadGrid.Focus(); base.ErrorMessage = string.Format(strErrMsg); blnWarningFlg = true; } } if (isDetailErr) { return(isResult); } isResult = true; return(isResult); }