protected void Page_Load(object sender, EventArgs e) { // отключение кэширования страницы ScadaUtils.DisablePageCache(Response); // получение данных пользователя UserData userData = UserData.GetUserData(); // проверка входа в систему userData.CheckLoggedOn(Context, false); if (!userData.LoggedOn) { throw new Exception(WebPhrases.NotLoggedOn); } // перевод веб-страницы Localization.TranslatePage(this, "Scada.Web.WFrmTableView"); // определение индексов выбранного представления int viewSetIndex, viewIndex; if (!int.TryParse(Request["viewSet"], out viewSetIndex)) { viewSetIndex = -1; } if (!int.TryParse(Request["view"], out viewIndex)) { viewIndex = -1; } // получение табличного представления и прав пользователя на него BaseView baseView; MainData.Right right; TableView tableView = userData.GetView(typeof(TableView), viewSetIndex, viewIndex, out baseView, out right) ? (TableView)baseView : null; // проверка загрузки представления и прав на просмотр информации if (tableView == null) { throw new Exception(WebPhrases.UnableLoadView); } else if (!right.ViewRight) { throw new Exception(CommonPhrases.NoRights); } // определение параметров запроса int year, month, day, stage; int.TryParse(Request["year"], out year); int.TryParse(Request["month"], out month); int.TryParse(Request["day"], out day); int.TryParse(Request["stage"], out stage); DateTime reqDate; try { reqDate = new DateTime(year, month, day); } catch { throw new Exception(WebPhrases.IncorrectDate); } // формирование таблицы отображаемых элементов представления int itemCnt = tableView.VisibleCount; int itemLastInd = itemCnt - 1; if (itemCnt > 0) { // формирование таблицы обозначений элементов представления TableRow row = new TableRow(); row.CssClass = "hdr"; NewCell(row, WebPhrases.ItemColumn); tblCap.Rows.Add(row); const string textHtmlTempl = "<table class=\"cap\" cellpadding=\"0\" cellspacing=\"0\"><tr>" + "<td>{0}</td><td>{1}</td><td>{2}</td></tr></table>"; const string hintHtmlTempl = "<div class=\"hint\">{0}</div>"; const string iconHtmlTempl = "<img src=\"images/paramIcons/{0}\" alt=\"\" />"; const string capHtmlTempl = "<span>{0}</span>"; const string diagHtmlTempl = "<a href=\"javascript:ShowDiag({0}, {1}, {2}, {3}, {4}, {5})\">"; const string cmdHtmlTempl = "<a href=\"javascript:SendCmd({0}, {1}, {2})\">" + "<img src=\"images/cmd.gif\" alt=\"\" /></a>"; bool canSendCmd = AppData.WebSettings.CmdEnabled && right.CtrlRight; for (int itemInd = 0; itemInd < itemCnt; itemInd++) { TableView.Item item = tableView.VisibleItems[itemInd]; int cnlNum = item.CnlNum; int cntrlCnlNum = item.CtrlCnlNum; string text; if (cnlNum > 0 || cntrlCnlNum > 0) { CnlProps cnlProps = item.CnlProps; List <string> hintLines = new List <string>(); if (cnlNum > 0) { hintLines.Add(WebPhrases.InCnlNumHint + cnlNum); } if (cntrlCnlNum > 0) { hintLines.Add(WebPhrases.OutCnlNumHint + cntrlCnlNum); } if (cnlProps != null) { hintLines.Add(WebPhrases.ObjectHint + cnlProps.ObjName); hintLines.Add(WebPhrases.KPHint + cnlProps.KPName); hintLines.Add(WebPhrases.ParamHint + cnlProps.ParamName); if (cnlProps.ShowNumber && cnlProps.UnitArr != null && cnlProps.UnitArr.Length > 0) { hintLines.Add(WebPhrases.UnitHint + cnlProps.UnitArr[0]); } } string hint = string.Join("<br />", hintLines.ToArray()); string hintHtml = string.Format(hintHtmlTempl, hint); string iconFileName = cnlProps == null || cnlProps.IconFileName == "" ? "undef.gif" : cnlProps.IconFileName; string iconHtml = string.Format(iconHtmlTempl, iconFileName); string capHtml = string.Format(capHtmlTempl, item.Caption); string cmdHtml = canSendCmd && cntrlCnlNum > 0 ? string.Format(cmdHtmlTempl, viewSetIndex, viewIndex, cntrlCnlNum) : ""; if (cnlNum > 0) { string diagHtml = string.Format(diagHtmlTempl, viewSetIndex, viewIndex, year, month, day, cnlNum); iconHtml = diagHtml + iconHtml + "</a>"; capHtml = diagHtml + capHtml + "</a>"; } text = string.Format(textHtmlTempl, iconHtml + hintHtml, capHtml, cmdHtml); } else { text = item.Caption == "" ? "<p> </p>" : "<p>" + item.Caption + "</p>"; } row = new TableRow(); SetCssClass(row, itemInd % 3 == 2, itemInd == itemLastInd); NewCell(row, text); tblCap.Rows.Add(row); } // получение обновлённых данных часовых срезов SrezTableLight hourTable; AppData.MainData.RefreshData(reqDate, out hourTable); // формирование ячейки текущего среза row = new TableRow(); row.CssClass = "hdr"; NewCell(row, WebPhrases.CurColumn); tblCur.Rows.Add(row); row = new TableRow(); NewCell(row, "<iframe id=\"frameCurVal\" src=\"" + "CurVals.aspx?viewSet=" + viewSetIndex + "&view=" + viewIndex + "&year=" + year + "&month=" + month + "&day=" + day + "&hourStamp=" + hourTable.FileModTime.Ticks + "\" frameborder=\"0\" scrolling=\"no\"></iframe>"); tblCur.Rows.Add(row); // формирование заголовка таблицы часовых значений int firstHour = stage == 2 ? 12 : 0; int lastHour = stage == 1 ? 11 : 23; row = new TableRow(); row.CssClass = "hdr"; tblHour.Rows.Add(row); for (int hour = firstHour; hour <= lastHour; hour++) { NewCell(row, hour.ToString()); } // формирование содержимого таблицы часовых значений // для оптимизации доступа к данным порядок заполнения следующий: по часам, по элементам for (int hour = firstHour; hour <= lastHour; hour++) { bool isFirstHour = hour == firstHour; DateTime dateTime = new DateTime(year, month, day, hour, 0, 0); int rowInd = 1; for (int itemInd = 0; itemInd < itemCnt; itemInd++) { TableView.Item item = tableView.VisibleItems[itemInd]; string text; string color; if (item.CnlNum > 0) { text = AppData.MainData.GetCnlVal(hourTable, item.CnlNum, dateTime, false, out color); } else { text = ""; color = ""; } if (isFirstHour) { row = new TableRow(); SetCssClass(row, itemInd % 3 == 2, itemInd == itemLastInd); tblHour.Rows.Add(row); text = text == "" ? "<p> </p>" : "<p>" + text + "</p>"; } else { row = tblHour.Rows[rowInd++]; } TableCell cell = NewCell(row, text); if (!(color == "" || color.ToLower() == "black")) { cell.ForeColor = Color.FromName(color); } } } } else { tblCap.Visible = false; tblCur.Visible = false; tblHour.Visible = false; lblNoData.Visible = true; } }
protected void Page_Load(object sender, EventArgs e) { // получение данных пользователя UserData userData = UserData.GetUserData(); // проверка входа в систему if (!userData.LoggedOn) { throw new Exception(WebPhrases.NotLoggedOn); } // определение индексов выбранного представления int viewSetIndex, viewIndex; if (!int.TryParse(Request["viewSet"], out viewSetIndex)) { viewSetIndex = -1; } if (!int.TryParse(Request["view"], out viewIndex)) { viewIndex = -1; } // определение номера канала управления int ctrlCnlNum; int.TryParse(Request["ctrlCnlNum"], out ctrlCnlNum); // получение представления и прав пользователя на него BaseView view; MainData.Right right; userData.GetView(null, viewSetIndex, viewIndex, out view, out right); // проверка загрузки представления и прав на отправку команды if (view == null) { throw new Exception(WebPhrases.UnableLoadView); } else if (!right.CtrlRight || !AppData.WebSettings.CmdEnabled || !view.ContainsCtrlCnl(ctrlCnlNum)) { throw new Exception(CommonPhrases.NoRights); } // очистка сообщения об ошибке lblMessage.Text = ""; lblMessage.Visible = false; // установка кнопки по умолчанию Form.DefaultButton = btnExecute.UniqueID; if (IsPostBack) { // восстановление заголовка страницы Title = (string)ViewState["Title"]; // установка активного элемента формы по умолчанию if (pnlPassword.Visible) { Form.DefaultFocus = txtPassword.ClientID; } else { View activeView = mvCommand.Visible ? mvCommand.GetActiveView() : null; if (activeView == viewStandCmd2) { Form.DefaultFocus = txtCmdVal.ClientID; } else if (activeView == viewBinCmd) { Form.DefaultFocus = txtCmdData.ClientID; } } } else { // перевод веб-страницы Translator.TranslatePage(this, "Scada.Web.WFrmCmdSend"); ViewState["Title"] = Title; // вывод свойств канала управления CtrlCnlProps ctrlCnlProps = AppData.MainData.GetCtrlCnlProps(ctrlCnlNum); if (ctrlCnlProps == null) { throw new Exception(string.Format(WebPhrases.OutCnlNotFound, ctrlCnlNum)); } else { lblCtrlCnl.Text = ctrlCnlProps.CtrlCnlName; lblObj.Text = ctrlCnlProps.ObjName; lblKP.Text = ctrlCnlProps.KPName; ViewState.Add("CtrlCnlNum", ctrlCnlProps.CtrlCnlNum); ViewState.Add("KPNum", ctrlCnlProps.KPNum); // установка видимости поля для ввода пароля pnlPassword.Visible = !AppData.WebSettings.SimpleCmd; // установка типа команды и определение фокуса по умолчанию string defaultFocus = ""; if (ctrlCnlProps.CmdTypeID == 0 /*стандартная команда*/) { if (ctrlCnlProps.CmdValArr == null) { // установка представления для ввода значения команды вручную mvCommand.SetActiveView(viewStandCmd2); defaultFocus = txtCmdVal.ClientID; } else if (AppData.WebSettings.SimpleCmd) { // настройка элементов для выполнения команды по нажатию кнопки со значением List <CmdValInfo> cmdValInfoList = new List <CmdValInfo>(); for (int i = 0; i < ctrlCnlProps.CmdValArr.Length; i++) { string cmdText = ctrlCnlProps.CmdValArr[i]; if (cmdText != "") { cmdValInfoList.Add(new CmdValInfo() { CndInd = cmdValInfoList.Count, CmdVal = i, CmdText = cmdText }); } } mvCommand.SetActiveView(viewStandCmd1Simple); repCmdVal.DataSource = cmdValInfoList; repCmdVal.DataBind(); btnExecute.Visible = false; } else { // настройка элементов для выбора значения команды с помощью радиокнопок mvCommand.SetActiveView(viewStandCmd1); for (int i = 0; i < ctrlCnlProps.CmdValArr.Length; i++) { string cmdVal = ctrlCnlProps.CmdValArr[i]; if (cmdVal != "") { rblCmdVal.Items.Add(new ListItem(cmdVal, i.ToString())); } } } } else if (ctrlCnlProps.CmdTypeID == 1 /*бинарная команда*/) { mvCommand.SetActiveView(viewBinCmd); defaultFocus = txtCmdData.ClientID; } else // команда опроса КП { mvCommand.Visible = false; } // установка активного элемента формы по умолчанию if (pnlPassword.Visible) { Form.DefaultFocus = txtPassword.ClientID; } else if (defaultFocus != "") { Form.DefaultFocus = defaultFocus; } } } }
protected void Page_Load(object sender, EventArgs e) { // отключение кэширования страницы ScadaUtils.DisablePageCache(Response); // получение данных пользователя UserData userData = UserData.GetUserData(); // проверка входа в систему if (!userData.LoggedOn) { throw new Exception(WebPhrases.NotLoggedOn); } // определение индексов выбранного представления int viewSetIndex, viewIndex; if (!int.TryParse(Request["viewSet"], out viewSetIndex)) { viewSetIndex = -1; } if (!int.TryParse(Request["view"], out viewIndex)) { viewIndex = -1; } // получение представления и прав пользователя на него BaseView baseView; MainData.Right right; TableView tableView = userData.GetView(null, viewSetIndex, viewIndex, out baseView, out right) ? baseView as TableView : null; // определение типа вывода событий int eventOut; string eventOutStr = Request["eventOut"]; if (eventOutStr == "all") { eventOut = 1; // все события } else if (eventOutStr == "view") { eventOut = 2; // по представлению } else { eventOut = 0; // не выводить } // проверка параметров генерации отчёта if (tableView == null && eventOut == 0) { throw new Exception(WebPhrases.NoReportData); } // проверка загрузки представления и прав на получение информации if (baseView == null) { throw new Exception(WebPhrases.UnableLoadView); } else if (!right.ViewRight || eventOut == 1 && userData.Role == ServerComm.Roles.Custom) { throw new Exception(CommonPhrases.NoRights); } // определение даты, за которую формируется отчёт int year, month, day; int.TryParse(Request["year"], out year); int.TryParse(Request["month"], out month); int.TryParse(Request["day"], out day); DateTime reqDate; try { reqDate = new DateTime(year, month, day); } catch { throw new Exception(WebPhrases.IncorrectDate); } // создание отчёта RepBuilder rep = new RepHrEvTable(); try { // вывод в журнал AppData.Log.WriteAction(string.Format(WebPhrases.GenReport, rep.RepName, userData.UserLogin), Log.ActTypes.Action); // установка типа страницы и имени файла отчёта Response.ClearHeaders(); Response.ContentType = "application/octet-stream"; Response.AppendHeader("Content-Disposition", "attachment;filename=\"" + Path.GetFileNameWithoutExtension(baseView.FileName) + reqDate.ToString(" yyyy-MM-dd") + ".xml\""); // установка параметров отчёта rep.SetParams(baseView, reqDate, eventOut); // генерация отчёта rep.Make(Response.OutputStream, Request.PhysicalApplicationPath + @"templates\"); } catch (Exception ex) { string errMsg = string.Format(WebPhrases.GenReportError, rep.RepName, ex.Message); AppData.Log.WriteAction(errMsg, Log.ActTypes.Exception); Response.ClearHeaders(); Response.ContentType = "text/html"; Response.Write(ScadaUtils.HtmlEncodeWithBreak(errMsg)); } }
protected void Page_Load(object sender, EventArgs e) { // отключение кэширования страницы ScadaUtils.DisablePageCache(Response); // получение данных пользователя UserData userData = UserData.GetUserData(); // проверка входа в систему userData.CheckLoggedOn(Context, false); if (!userData.LoggedOn) { throw new Exception(WebPhrases.NotLoggedOn); } // перевод веб-страницы Localization.TranslatePage(this, "Scada.Web.WFrmEvTable"); // определение индексов выбранного представления int viewSetIndex, viewIndex; if (!int.TryParse(Request["viewSet"], out viewSetIndex)) { viewSetIndex = -1; } if (!int.TryParse(Request["view"], out viewIndex)) { viewIndex = -1; } // получение представления и прав пользователя на него BaseView view; MainData.Right right; userData.GetView(null, viewSetIndex, viewIndex, out view, out right); // вывод сообщения о загрузке if (view == null && right.ViewRight) { lblLoading.Visible = true; tblEv.Visible = false; hidEvStamp.Value = "-1"; return; } // определение фильтра событий bool showAllEvents = Request["filter"] == "all"; // проверка загрузки представления и прав на просмотр информации if (view == null) { throw new Exception(WebPhrases.UnableLoadView); } else if (!right.ViewRight || showAllEvents && userData.Role == ServerComm.Roles.Custom) { throw new Exception(CommonPhrases.NoRights); } // определение параметров запроса int year, month, day; int.TryParse(Request["year"], out year); int.TryParse(Request["month"], out month); int.TryParse(Request["day"], out day); DateTime reqDate; try { reqDate = new DateTime(year, month, day); } catch { throw new Exception(WebPhrases.IncorrectDate); } // получение обновлённых данных событий EventTableLight eventTable; AppData.MainData.RefreshEvents(reqDate, out eventTable); hidEvStamp.Value = eventTable.FileModTime.Ticks.ToString(); List <int> cnlList = showAllEvents ? null : view.CnlList; List <MainData.EventView> events = AppData.MainData.ConvertEvents( AppData.MainData.GetLastEvents(eventTable, cnlList, AppData.WebSettings.EventCnt)); if (events.Count > 0) { for (int eventInd = events.Count - 1; eventInd >= 0; eventInd--) { MainData.EventView eventView = events[eventInd]; TableRow row = new TableRow(); WFrmTableView.NewCell(row, eventView.Num, "c"); WFrmTableView.NewCell(row, eventView.Date, "c"); WFrmTableView.NewCell(row, eventView.Time, "c"); WFrmTableView.NewCell(row, eventView.Obj); WFrmTableView.NewCell(row, eventView.KP); WFrmTableView.NewCell(row, eventView.Cnl); WFrmTableView.NewCell(row, eventView.Text); // установка номера события для воспроизведения звука при загрузке страницы if (eventView.Sound && string.IsNullOrEmpty(hidSndEvNum.Value)) { hidSndEvNum.Value = eventView.Num; } // формирование ячейки квитирования if (right.CtrlRight && !eventView.Check) { string chkCellText = "<a href=\"javascript:CheckEvent(" + viewSetIndex + ", " + viewIndex + ", " + year + ", " + month + ", " + day + ", " + eventView.Num + ")\" style=\"color: " + eventView.Color + "\">" + eventView.User + "</a>"; WFrmTableView.NewCell(row, chkCellText, "c"); } else { WFrmTableView.NewCell(row, eventView.User, "c"); } // установка свойств строки таблицы WFrmTableView.SetCssClass(row, eventInd % 3 == 2, eventInd == 0); string color = eventView.Color; if (!(color == "" || color.ToLower() == "black")) { row.ForeColor = Color.FromName(color); } tblEv.Rows.Add(row); } } else { lblNoData.Visible = true; tblEv.Visible = false; } }
protected void Page_Load(object sender, EventArgs e) { // отключение кэширования страницы ScadaUtils.DisablePageCache(Response); // получение данных пользователя UserData userData = UserData.GetUserData(); // определение индексов выбранного представления int viewSetIndex, viewIndex; if (!int.TryParse(Request["viewSet"], out viewSetIndex)) { viewSetIndex = -1; } if (!int.TryParse(Request["view"], out viewIndex)) { viewIndex = -1; } // получение табличного представления и прав пользователя на него BaseView baseView; MainData.Right right; TableView tableView = userData.GetView(typeof(TableView), viewSetIndex, viewIndex, out baseView, out right) ? (TableView)baseView : null; // проверка входа в систему и прав на просмотр информации if (userData.LoggedOn && tableView != null && right.ViewRight) { // определение параметров запроса int year, month, day; int.TryParse(Request["year"], out year); int.TryParse(Request["month"], out month); int.TryParse(Request["day"], out day); string hourStamp = Request["hourStamp"]; DateTime reqDate; try { reqDate = new DateTime(year, month, day); } catch { throw new Exception(WebPhrases.IncorrectDate); } // обновление данных SrezTableLight hourTable; AppData.MainData.RefreshData(reqDate, out hourTable); // формирование таблицы текущих значений элементов представления int itemCnt = tableView.VisibleCount; int itemLastInd = itemCnt - 1; for (int itemInd = 0; itemInd < itemCnt; itemInd++) { TableView.Item item = tableView.VisibleItems[itemInd]; string text; string color; if (item.CnlNum > 0) { text = AppData.MainData.GetCnlVal(item.CnlNum, false, out color); } else { text = ""; color = ""; } TableRow row = new TableRow(); TableCell cell = WFrmTableView.NewCell(row, text == "" ? "<p> </p>" : "<p>" + text + "</p>"); WFrmTableView.SetCssClass(row, itemInd % 3 == 2, itemInd == itemLastInd); tblCurVals.Rows.Add(row); if (!(color == "" || color.ToLower() == "black")) { cell.ForeColor = Color.FromName(color); } } if (string.IsNullOrEmpty(hourStamp) || hourStamp == hourTable.FileModTime.Ticks.ToString()) { // добавление скрипта обновления текущих значений по таймауту AddRefreshCurValsScript(AppData.WebSettings.SrezRefrFreq * 1000); } else { // добавление скрипта обновления часовых значений при загрузке AddRefreshHourValsScript(); } } else { // добавление скрипта обновления часовых значений при загрузке // для перехода на страницу входа в систему AddRefreshHourValsScript(); } }
protected void Page_Load(object sender, EventArgs e) { // получение данных пользователя UserData userData = UserData.GetUserData(); // проверка входа в систему if (!userData.LoggedOn) { throw new Exception(WebPhrases.NotLoggedOn); } // очистка сообщения об ошибке lblMessage.Text = ""; lblMessage.Visible = false; // установка активного элемента формы и кнопки по умолчанию Form.DefaultFocus = btnCheck.ClientID; Form.DefaultButton = btnCheck.UniqueID; if (IsPostBack) { Title = (string)ViewState["Title"]; } else { // перевод веб-страницы Localization.TranslatePage(this, "Scada.Web.WFrmEvCheck"); // определение параметров квитирования DateTime date; int evNum; try { date = new DateTime(int.Parse(Request["year"]), int.Parse(Request["month"]), int.Parse(Request["day"])); ViewState.Add("Date", date); } catch { throw new Exception(WebPhrases.IncorrectEvDate); } try { evNum = int.Parse(Request["evNum"]); ViewState.Add("EvNum", evNum); } catch { throw new Exception(WebPhrases.IncorrectEvNum); } // вывод номера и даты события lblNum.Text = evNum.ToString(); lblDate.Text = date.ToString("d", Localization.Culture); // получение квитируемого события EventTableLight eventTable; AppData.MainData.RefreshEvents(date, out eventTable); EventTableLight.Event ev = AppData.MainData.GetEventByNum(eventTable, evNum); if (ev == null) { lblMessage.Text = string.Format(WebPhrases.ErrorFormat, WebPhrases.EventNotFound); lblMessage.Visible = true; lblTime.Text = lblObj.Text = lblKP.Text = lblCnl.Text = lblEvent.Text = ""; btnCheck.Enabled = false; } else { // определение индексов выбранного представления int viewSetIndex, viewIndex; if (!int.TryParse(Request["viewSet"], out viewSetIndex)) { viewSetIndex = -1; } if (!int.TryParse(Request["view"], out viewIndex)) { viewIndex = -1; } // получение представления и прав пользователя на него BaseView view; MainData.Right right; userData.GetView(null, viewSetIndex, viewIndex, out view, out right); // проверка загрузки представления и прав на квитирование if (view == null) { throw new Exception(WebPhrases.UnableLoadView); } else if (!right.CtrlRight || userData.Role == ServerComm.Roles.Custom && !view.CnlList.Contains(ev.CnlNum)) { throw new Exception(CommonPhrases.NoRights); } MainData.EventView eventView = AppData.MainData.ConvertEvent(ev); lblTime.Text = eventView.Time; lblObj.Text = eventView.Obj; lblKP.Text = eventView.KP; lblCnl.Text = eventView.Cnl; lblEvent.Text = eventView.Text; lblNum.ForeColor = lblDate.ForeColor = lblTime.ForeColor = lblObj.ForeColor = lblCnl.ForeColor = lblEvent.ForeColor = Color.FromName(eventView.Color); } } }