コード例 #1
0
ファイル: RPCATEGORY.cs プロジェクト: lsfv/queryreport
 /// <summary>
 /// 得到一个对象实体
 /// </summary>
 public CUSTOMRP.Model.RPCATEGORY DataRowToModel(DataRow row)
 {
     CUSTOMRP.Model.RPCATEGORY model = new CUSTOMRP.Model.RPCATEGORY();
     if (row != null)
     {
         if (row["ID"] != null && row["ID"].ToString() != "")
         {
             model.ID = Int32.Parse(row["ID"].ToString());
         }
         if (row["NAME"] != null)
         {
             model.NAME = row["NAME"].ToString();
         }
         if (row["DATABASEID"] != null && row["DATABASEID"].ToString() != "")
         {
             model.DATABASEID = Int32.Parse(row["DATABASEID"].ToString());
         }
         if (row["AUDODATE"] != null && row["AUDODATE"].ToString() != "")
         {
             model.AUDODATE = DateTime.Parse(row["AUDODATE"].ToString());
         }
         if (row["DESCRIPTION"] != null)
         {
             model.DESCRIPTION = row["DESCRIPTION"].ToString();
         }
     }
     return(model);
 }
コード例 #2
0
        protected void Button1_Click(object sender, EventArgs e)
        {
            string name        = this.TextBox1.Text.Trim();
            string description = this.TextBox2.Text.Trim();


            if (myCategory == null)
            {
                if (WebHelper.bllcategory.GetList(me.ID, "NAME='" + name + "'").Tables[0].Rows.Count > 0)
                {
                    //Common.JScript.Alert(AppNum.Commonexits);
                    //Common.JScript.GoHistory(-1);
                    Common.JScript.AlertAndRedirect(AppNum.ErrorMsg.Commonexits, "Category.aspx");
                    Response.End();
                }

                CUSTOMRP.Model.RPCATEGORY mylevel = new CUSTOMRP.Model.RPCATEGORY();
                mylevel.DATABASEID  = me.DatabaseID;
                mylevel.DESCRIPTION = description;
                mylevel.NAME        = name;

                WebHelper.bllcategory.Add(me.ID, mylevel);
            }
            else
            {
                myCategory.DESCRIPTION = description;
                myCategory.NAME        = name;;

                WebHelper.bllcategory.Update(me.ID, myCategory);
            }

            Common.JScript.AlertAndRedirect(AppNum.ErrorMsg.success, "Category.aspx");
            Response.End();
        }
コード例 #3
0
 protected void Page_Init(object sender, EventArgs e)
 {
     if (string.IsNullOrEmpty(Request.QueryString["id"]))
     {
         if (me.checkUserGroupRight(CUSTOMRP.Model.APPModuleID.usergroupright_reportcategory, "Add", me.LoginID) == false)
         {
             Common.JScript.AlertAndRedirect(AppNum.ErrorMsg.accesserror, "Category.aspx");
             Response.End();
         }
     }
     else
     {
         if (me.checkUserGroupRight(CUSTOMRP.Model.APPModuleID.usergroupright_reportcategory, "Modify", me.LoginID) == false)
         {
             Common.JScript.AlertAndRedirect(AppNum.ErrorMsg.accesserror, "Category.aspx");
             Response.End();
         }
         int id = Int32.Parse(Request.QueryString["id"]);
         myCategory = WebHelper.bllcategory.GetModel(me.ID, id);
         if (myCategory == null)
         {
             Common.JScript.AlertAndRedirect(AppNum.ErrorMsg.parameter_error, "Category.aspx");
             Response.End();
         }
     }
 }
コード例 #4
0
ファイル: RPCATEGORY.cs プロジェクト: lsfv/queryreport
        /// <summary>
        /// 增加一条数据
        /// </summary>
        public int Add(int UserID, CUSTOMRP.Model.RPCATEGORY model)
        {
            StringBuilder strSql = new StringBuilder();

            strSql.Append("insert into RPCATEGORY(");
            strSql.Append("NAME,DATABASEID,AUDODATE,DESCRIPTION)");
            strSql.Append(" values (");
            strSql.Append("@NAME,@DATABASEID,@AUDODATE,@DESCRIPTION)");
            strSql.Append(";select @@IDENTITY");
            SqlParameter[] parameters =
            {
                new SqlParameter("@NAME",        SqlDbType.NVarChar,  50),
                new SqlParameter("@DATABASEID",  SqlDbType.Int,        4),
                new SqlParameter("@AUDODATE",    SqlDbType.DateTime),
                new SqlParameter("@DESCRIPTION", SqlDbType.NVarChar, -1)
            };
            parameters[0].Value = model.NAME;
            parameters[1].Value = model.DATABASEID;
            parameters[2].Value = model.AUDODATE;
            parameters[3].Value = model.DESCRIPTION;

            object obj = DbHelperSQL.GetSingle(UserID, strSql.ToString(), parameters);

            if (obj == null)
            {
                return(0);
            }
            else
            {
                model.ID = Convert.ToInt32(obj);

                Model.AUDITLOG auditobj = model.GetAuditLogObject(null);
                auditobj.UserID      = UserID;
                auditobj.CreateDate  = DateTime.Now;
                auditobj.MessageType = Model.AUDITLOG.Severity.Audit;
                auditobj.ModuleName  = "DAL.RPCATEGORY.Add";
                auditobj.Message     = String.Format(AppNum.AuditMessage.RPCategoryInsertSuccess, model.ID);

                AUDITLOG.Add(auditobj);

                return(model.ID);
            }
        }
コード例 #5
0
ファイル: RPCATEGORY.cs プロジェクト: lsfv/queryreport
        /// <summary>
        /// 更新一条数据
        /// </summary>
        public bool Update(int UserID, CUSTOMRP.Model.RPCATEGORY model)
        {
            StringBuilder strSql = new StringBuilder();

            strSql.Append("update RPCATEGORY set ");
            strSql.Append("AUDODATE=@AUDODATE,");
            strSql.Append("DESCRIPTION=@DESCRIPTION");
            strSql.Append(" where ID=@ID");
            SqlParameter[] parameters =
            {
                new SqlParameter("@AUDODATE",    SqlDbType.DateTime),
                new SqlParameter("@DESCRIPTION", SqlDbType.NVarChar,  -1),
                new SqlParameter("@ID",          SqlDbType.Int,        4),
                new SqlParameter("@NAME",        SqlDbType.NVarChar,  50),
                new SqlParameter("@DATABASEID",  SqlDbType.Int, 4)
            };
            parameters[0].Value = model.AUDODATE;
            parameters[1].Value = model.DESCRIPTION;
            parameters[2].Value = model.ID;
            parameters[3].Value = model.NAME;
            parameters[4].Value = model.DATABASEID;

            int rows = DbHelperSQL.ExecuteSql(UserID, strSql.ToString(), parameters);

            if (rows > 0)
            {
                Model.AUDITLOG auditobj = model.GetAuditLogObject(null);
                auditobj.UserID      = UserID;
                auditobj.CreateDate  = DateTime.Now;
                auditobj.MessageType = Model.AUDITLOG.Severity.Audit;
                auditobj.ModuleName  = "DAL.RPCATEGORY.Update";
                auditobj.Message     = String.Format(AppNum.AuditMessage.RPCategoryUpdateSuccess, model.ID);

                AUDITLOG.Add(auditobj);

                return(true);
            }
            else
            {
                return(false);
            }
        }
コード例 #6
0
ファイル: RPCATEGORY.cs プロジェクト: lsfv/queryreport
        //public bool Delete(int UserID, string NAME, int DATABASEID)
        //{
        //    StringBuilder strSql=new StringBuilder();
        //    strSql.Append("delete from RPCATEGORY ");
        //    strSql.Append(" where NAME=@NAME and DATABASEID=@DATABASEID ");
        //    SqlParameter[] parameters = {
        //            new SqlParameter("@NAME", SqlDbType.NVarChar,50),
        //            new SqlParameter("@DATABASEID", SqlDbType.Int,4)			};
        //    parameters[0].Value = NAME;
        //    parameters[1].Value = DATABASEID;

        //    int rows=DbHelperSQL.ExecuteSql(UserID, strSql.ToString(),parameters);
        //    if (rows > 0)
        //    {
        //        return true;
        //    }
        //    else
        //    {
        //        return false;
        //    }
        //}

        /// <summary>
        /// 批量删除数据
        /// </summary>
        //public bool DeleteList(int UserID, string IDlist)
        //{
        //    StringBuilder strSql=new StringBuilder();
        //    strSql.Append("delete from RPCATEGORY ");
        //    strSql.Append(" where ID in ("+IDlist + ")  ");
        //    int rows=DbHelperSQL.ExecuteSql(UserID, strSql.ToString());
        //    if (rows > 0)
        //    {
        //        return true;
        //    }
        //    else
        //    {
        //        return false;
        //    }
        //}


        /// <summary>
        /// 得到一个对象实体
        /// </summary>
        public CUSTOMRP.Model.RPCATEGORY GetModel(int UserID, int ID)
        {
            StringBuilder strSql = new StringBuilder();

            strSql.Append("select  top 1 ID,NAME,DATABASEID,AUDODATE,DESCRIPTION from RPCATEGORY ");
            strSql.Append(" where ID=@ID");
            SqlParameter[] parameters =
            {
                new SqlParameter("@ID", SqlDbType.Int, 4)
            };
            parameters[0].Value = ID;

            CUSTOMRP.Model.RPCATEGORY model = new CUSTOMRP.Model.RPCATEGORY();
            DataSet ds = DbHelperSQL.Query(UserID, strSql.ToString(), parameters);

            if (ds.Tables[0].Rows.Count > 0)
            {
                return(DataRowToModel(ds.Tables[0].Rows[0]));
            }
            else
            {
                return(null);
            }
        }
コード例 #7
0
ファイル: rpword.aspx.cs プロジェクト: lsfv/queryreport
        protected void btnNext_Click(object sender, EventArgs e)
        {
            if (!this.ValidateParameters())
            {
                return;
            }

            CUSTOMRP.Model.REPORT            myReport    = null;
            List <CUSTOMRP.Model.ColumnInfo> columninfos = null;

            string path          = g_Config["WordTemplatePath"];
            string savedFileName = String.Empty;

            try
            {
                savedFileName = this.SaveTemplateFile();
            }
            catch
            {
                this.lblJavascript.Text = String.Format("<script type=\"text/javascript\">alert(\"{0}\");</script>", AppNum.ErrorMsg.uploadFailed);
                return;
            }

            string strReportName = this.txtReportName.Text.Trim();
            int    svID          = Convert.ToInt32(this.ddlQueryName.SelectedValue);

            #region Read CustomProps from file

            System.Collections.Specialized.NameValueCollection nvc = QueryReport.Code.MailMerge.ReadCustomPropsFromFile(path + savedFileName);
            if (String.IsNullOrWhiteSpace(strReportName))
            {
                strReportName = nvc["RptName"];
                if (strReportName != null)
                {
                    strReportName = strReportName.Trim();
                }
            }
            string strQueryName = nvc["QueryName"];
            if (!String.IsNullOrWhiteSpace(strQueryName))
            {
                CUSTOMRP.Model.SOURCEVIEW svFromFile = WebHelper.bllSOURCEVIEW.GetModelByQueryName(me.ID, strQueryName.Trim(), me.DatabaseID);
                svID = (svFromFile != null) ? svFromFile.ID : -1;
            }

            #endregion

            if (String.IsNullOrWhiteSpace(strReportName))
            {
                this.lblJavascript.Text = String.Format("<script type=\"text/javascript\">alert(\"{0}\");</script>",
                                                        String.Format(AppNum.ErrorMsg.fieldcannotbeempty, "Report Name"));
                return;
            }

            if (svID == -1)
            {
                this.lblJavascript.Text = String.Format("<script type=\"text/javascript\">alert(\"{0}\");</script>",
                                                        String.Format(AppNum.ErrorMsg.pleaseselectvalidvaluefrom, "Query Name"));
                return;
            }

            CUSTOMRP.Model.RPCATEGORY  rpcat = WebHelper.bllcategory.GetModelList(me.ID, "DATABASEID='" + me.DatabaseID + "'").FirstOrDefault();
            CUSTOMRP.Model.REPORTGROUP rpgrp = WebHelper.bllrpGroup.GetModelList(me.ID, "DATABASEID='" + me.DatabaseID + "'").FirstOrDefault();

            #region Save columninfos

            CUSTOMRP.Model.SOURCEVIEW sv = WebHelper.bllSOURCEVIEW.GetModel(me.ID, svID);
            List <CUSTOMRP.Model.SOURCEVIEWCOLUMN> svclist = WebHelper.bllSOURCEVIEWCOLUMN.GetModelsForSourceView(me.ID, sv.ID).OrderBy(x => x.DisplayName).ToList();
            string[] colnames = svclist.Select(x => x.DisplayName).ToArray();

            switch (sv.SourceType)
            {
            case CUSTOMRP.Model.SOURCEVIEW.SourceViewType.View:
            case CUSTOMRP.Model.SOURCEVIEW.SourceViewType.Table:
            {
                try
                {
                    columninfos = CUSTOMRP.BLL.AppHelper.GetColumnInfoForTblView(me.ID, me.DatabaseNAME, sv.TBLVIEWNAME);
                }
                catch (Exception ex)
                {
                    System.Diagnostics.Debug.WriteLine(ex.ToString());
                    columninfos             = new List <CUSTOMRP.Model.ColumnInfo>();
                    this.lblJavascript.Text = String.Format("<script type=\"text/javascript\">alert('Error in retrieving columns for [{0}]. Please check view defination.');</script>", sv.TBLVIEWNAME);
                }
                if (colnames == null)
                {
                    colnames = CUSTOMRP.BLL.AppHelper.GetColumnNamesForTblView(me.ID, me.DatabaseNAME, sv.TBLVIEWNAME);
                }
            }
            break;

            case CUSTOMRP.Model.SOURCEVIEW.SourceViewType.StoredProc:
            {
                try
                {
                    columninfos = CUSTOMRP.BLL.AppHelper.GetColumnInfoForStoredProc(me.ID, me.DatabaseNAME, sv.ID);
                }
                catch (Exception ex)
                {
                    System.Diagnostics.Debug.WriteLine(ex.ToString());
                    columninfos             = new List <CUSTOMRP.Model.ColumnInfo>();
                    this.lblJavascript.Text = String.Format("<script type=\"text/javascript\">alert('Error in retrieving columns for [{0}]. Please check stored proc defination.');</script>", sv.TBLVIEWNAME);
                }
                if (colnames == null)
                {
                    colnames = CUSTOMRP.BLL.AppHelper.GetColumnNamesForStoredProc(me.ID, me.DatabaseNAME, sv.TBLVIEWNAME);
                }
            }
            break;
            }
            // Filter result to only columns that is requested
            columninfos = columninfos.Where(x => colnames.Contains(x.ColName)).ToList();

            #endregion Save columninfos

            #region myReport
            DateTime currTime = DateTime.Now;
            int      UserID   = me.ID;

            myReport                 = new CUSTOMRP.Model.REPORT();
            myReport.REPORTNAME      = strReportName;
            myReport.RPTITLE         = myReport.REPORTNAME;
            myReport.DATABASEID      = me.DatabaseID;
            myReport.SVID            = svID;
            myReport.CATEGORY        = rpcat != null ? rpcat.ID : -1;
            myReport.REPORTGROUPLIST = rpgrp != null ? rpgrp.ID : -1;
            myReport.DEFAULTFORMAT   = 0;
            myReport.ADDUSER         = UserID;
            myReport.AUDODATE        = currTime;
            myReport.ADDUSER         = UserID;

            myReport.ReportColumns = new List <CUSTOMRP.Model.REPORTCOLUMN>();
            foreach (CUSTOMRP.Model.ColumnInfo c in columninfos)
            {
                CUSTOMRP.Model.SOURCEVIEWCOLUMN svc = svclist.Where(x => x.COLUMNNAME == c.ColName).First();
                myReport.ReportColumns.Add(new CUSTOMRP.Model.REPORTCOLUMN()
                {
                    COLUMNNAME         = c.ColName,
                    COLUMNFUNC         = (int)CUSTOMRP.Model.REPORTCOLUMN.ColumnFuncs.Content,
                    CRITERIA1          = String.Empty,
                    CRITERIA2          = String.Empty,
                    CRITERIA3          = String.Empty,
                    CRITERIA4          = String.Empty,
                    AUDODATE           = currTime,
                    SOURCEVIEWCOLUMNID = svc.ID,
                    DISPLAYNAME        = svc.DISPLAYNAME,
                    COLUMNTYPE         = (int)CUSTOMRP.Model.REPORTCOLUMN.ColumnTypes.Normal,
                    COLUMNCOMMENT      = String.Empty,
                    HIDDEN             = false,
                });
            }

            myReport.WordFile              = new CUSTOMRP.Model.WORDFILE();
            myReport.WordFile.Description  = String.Format("Word file for {0}", myReport.RPTITLE);
            myReport.WordFile.OrigFileName = Path.GetFileName(fUploadTemplate.PostedFile.FileName).Replace(' ', '_');
            myReport.WordFile.WordFileName = savedFileName;
            myReport.WordFile.CreateDate   = currTime;
            myReport.WordFile.CreateUser   = UserID;
            myReport.WordFile.ModifyDate   = currTime;
            myReport.WordFile.ModifyUser   = UserID;

            #endregion myReport

            Session[rpexcel.strSessionKeyMyReport]   = myReport;
            Session[rpexcel.strSessionKeyColumnInfo] = columninfos;

            Response.Redirect("rpworddetail.aspx");
        }