private void 動品検索() { //アクティブボタン = 在庫検索ボタンEnum.不動品; dg現在庫.Visible = false; dg使用量.Visible = false; dg不動品.Visible = true; dg後発品.Visible = false; // 空文字ならば、検索しない。 if (tb検索キーワード.Text.Replace(" ", "").Replace(" ", "").Equals("")) { //// カーソルをもとの状態にする //this.SetCursorDefault(); return; } bool 全期限 = false; bool 期限内 = false; bool 期限切 = false; bool 期限指定 = false; bool 以内指定か = false; int 期限加算月 = 0; if (ddl使用期限日.SelectedIndex == 0) { 全期限 = true; } else if (ddl使用期限日.SelectedIndex == 1) { 期限内 = true; } else if (ddl使用期限日.SelectedIndex == 2) { 期限切 = true; } else if (3 <= ddl使用期限日.SelectedIndex) { 期限指定 = true; Tuple <int, bool> tp = Set期限加算月(); 期限加算月 = tp.Value1; 以内指定か = tp.Value2; } Service.File.Reader.FileReaderClient client = ReferenceCreater.GetFileReaderClient(); var rdataset = client.Open不動品CSV(tb検索キーワード.Text, 全期限, 期限内, 期限切, 期限指定, 以内指定か, 期限加算月); if (string.IsNullOrEmpty(rdataset.エラーメッセージ)) { var dataList = rdataset.検索結果データlist.ToList(); var 表示順序dic = Session["店舗名List"] as Dictionary <int, string>; if (表示順序dic == null) { return; } // 表示順序に登録されていない店舗があった場合に使用する臨時dic var CopyDic = GenericUtil.Copy(表示順序dic); int cnt = CopyDic.Count + 1; dataList.Sort( delegate(動品データ x, 動品データ y) { int xValue = 0; int yValue = 0; foreach (var d in CopyDic) { if (d.Value.Equals(x.店名)) { xValue = d.Key; } if (d.Value.Equals(y.店名)) { yValue = d.Key; } } // 一致するものがなかったら、臨時のcntの番号にする(表示順序が後ろ) bool xy店名が等しい = false; if (xValue == 0) { if (x.店名.Equals(y.店名)) { xy店名が等しい = true; } xValue = cnt; CopyDic.Add(cnt, x.店名); cnt++; } if (yValue == 0) { if (xy店名が等しい) { yValue = xValue; } else { yValue = cnt; CopyDic.Add(cnt, y.店名); cnt++; } } // 店名が等しい場合は、医薬品名のアイウエオ順 if (xValue == yValue) { return(x.医薬品名.CompareTo(y.医薬品名)); } return(xValue - yValue); } ); dg不動品.DataSource = dataList; dg不動品.DataBind(); Set在庫検索結果Result(dataList.Count, rdataset.検索キーワード); } else { // メッセージボックスを出すとXPだとIMEが利かなくなるので中止 //MessageBox.Show(rdataset.エラーメッセージ, "検索結果", MessageBoxButton.OK); lbSearchResult.Text = rdataset.エラーメッセージ; } }