コード例 #1
0
        /// <summary>
        /// 将DataRedar转换为List
        /// </summary>
        private List <BizProcess.Data.Model.WorkFlowForm> DataReaderToList(SqlDataReader dataReader)
        {
            List <BizProcess.Data.Model.WorkFlowForm> List = new List <BizProcess.Data.Model.WorkFlowForm>();

            BizProcess.Data.Model.WorkFlowForm model = null;
            while (dataReader.Read())
            {
                model                = new BizProcess.Data.Model.WorkFlowForm();
                model.ID             = dataReader.GetGuid(0);
                model.Name           = dataReader.GetString(1);
                model.Type           = dataReader.GetGuid(2);
                model.CreateUserID   = dataReader.GetGuid(3);
                model.CreateUserName = dataReader.GetString(4);
                model.CreateTime     = dataReader.GetDateTime(5);
                model.LastModifyTime = dataReader.GetDateTime(6);
                if (!dataReader.IsDBNull(7))
                {
                    model.Html = dataReader.GetString(7);
                }
                if (!dataReader.IsDBNull(8))
                {
                    model.SubTableJson = dataReader.GetString(8);
                }
                if (!dataReader.IsDBNull(9))
                {
                    model.EventsJson = dataReader.GetString(9);
                }
                if (!dataReader.IsDBNull(10))
                {
                    model.Attribute = dataReader.GetString(10);
                }
                model.Status = dataReader.GetInt32(11);
                List.Add(model);
            }
            return(List);
        }
コード例 #2
0
        /// <summary>
        /// 更新记录
        /// </summary>
        /// <param name="model">BizProcess.Data.Model.WorkFlowForm实体类</param>
        public int Update(BizProcess.Data.Model.WorkFlowForm model)
        {
            string sql = @"UPDATE WorkFlowForm SET 
				Name=@Name,Type=@Type,CreateUserID=@CreateUserID,CreateUserName=@CreateUserName,CreateTime=@CreateTime,LastModifyTime=@LastModifyTime,Html=@Html,SubTableJson=@SubTableJson,EventsJson=@EventsJson,Attribute=@Attribute,Status=@Status
				WHERE ID=@ID"                ;

            SqlParameter[] parameters = new SqlParameter[] {
                new SqlParameter("@Name", SqlDbType.NVarChar, 1000)
                {
                    Value = model.Name
                },
                new SqlParameter("@Type", SqlDbType.UniqueIdentifier, -1)
                {
                    Value = model.Type
                },
                new SqlParameter("@CreateUserID", SqlDbType.UniqueIdentifier, -1)
                {
                    Value = model.CreateUserID
                },
                new SqlParameter("@CreateUserName", SqlDbType.NVarChar, 100)
                {
                    Value = model.CreateUserName
                },
                new SqlParameter("@CreateTime", SqlDbType.DateTime, 8)
                {
                    Value = model.CreateTime
                },
                new SqlParameter("@LastModifyTime", SqlDbType.DateTime, 8)
                {
                    Value = model.LastModifyTime
                },
                model.Html == null ? new SqlParameter("@Html", SqlDbType.Text, -1)
                {
                    Value = DBNull.Value
                } : new SqlParameter("@Html", SqlDbType.Text, -1)
                {
                    Value = model.Html
                },
                model.SubTableJson == null ? new SqlParameter("@SubTableJson", SqlDbType.Text, -1)
                {
                    Value = DBNull.Value
                } : new SqlParameter("@SubTableJson", SqlDbType.Text, -1)
                {
                    Value = model.SubTableJson
                },
                model.EventsJson == null ? new SqlParameter("@EventsJson", SqlDbType.Text, -1)
                {
                    Value = DBNull.Value
                } : new SqlParameter("@EventsJson", SqlDbType.Text, -1)
                {
                    Value = model.EventsJson
                },
                model.Attribute == null ? new SqlParameter("@Attribute", SqlDbType.VarChar, -1)
                {
                    Value = DBNull.Value
                } : new SqlParameter("@Attribute", SqlDbType.VarChar, -1)
                {
                    Value = model.Attribute
                },
                new SqlParameter("@Status", SqlDbType.Int, -1)
                {
                    Value = model.Status
                },
                new SqlParameter("@ID", SqlDbType.UniqueIdentifier, -1)
                {
                    Value = model.ID
                }
            };
            return(dbHelper.Execute(sql, parameters));
        }
コード例 #3
0
        /// <summary>
        /// 添加记录
        /// </summary>
        /// <param name="model">BizProcess.Data.Model.WorkFlowForm实体类</param>
        /// <returns>操作所影响的行数</returns>
        public int Add(BizProcess.Data.Model.WorkFlowForm model)
        {
            string sql = @"INSERT INTO WorkFlowForm
				(ID,Name,Type,CreateUserID,CreateUserName,CreateTime,LastModifyTime,Html,SubTableJson,EventsJson,Attribute,Status) 
				VALUES(@ID,@Name,@Type,@CreateUserID,@CreateUserName,@CreateTime,@LastModifyTime,@Html,@SubTableJson,@EventsJson,@Attribute,@Status)"                ;

            SqlParameter[] parameters = new SqlParameter[] {
                new SqlParameter("@ID", SqlDbType.UniqueIdentifier, -1)
                {
                    Value = model.ID
                },
                new SqlParameter("@Name", SqlDbType.NVarChar, 1000)
                {
                    Value = model.Name
                },
                new SqlParameter("@Type", SqlDbType.UniqueIdentifier, -1)
                {
                    Value = model.Type
                },
                new SqlParameter("@CreateUserID", SqlDbType.UniqueIdentifier, -1)
                {
                    Value = model.CreateUserID
                },
                new SqlParameter("@CreateUserName", SqlDbType.NVarChar, 100)
                {
                    Value = model.CreateUserName
                },
                new SqlParameter("@CreateTime", SqlDbType.DateTime, 8)
                {
                    Value = model.CreateTime
                },
                new SqlParameter("@LastModifyTime", SqlDbType.DateTime, 8)
                {
                    Value = model.LastModifyTime
                },
                model.Html == null ? new SqlParameter("@Html", SqlDbType.Text, -1)
                {
                    Value = DBNull.Value
                } : new SqlParameter("@Html", SqlDbType.Text, -1)
                {
                    Value = model.Html
                },
                model.SubTableJson == null ? new SqlParameter("@SubTableJson", SqlDbType.Text, -1)
                {
                    Value = DBNull.Value
                } : new SqlParameter("@SubTableJson", SqlDbType.Text, -1)
                {
                    Value = model.SubTableJson
                },
                model.EventsJson == null ? new SqlParameter("@EventsJson", SqlDbType.Text, -1)
                {
                    Value = DBNull.Value
                } : new SqlParameter("@EventsJson", SqlDbType.Text, -1)
                {
                    Value = model.EventsJson
                },
                model.Attribute == null ? new SqlParameter("@Attribute", SqlDbType.VarChar, -1)
                {
                    Value = DBNull.Value
                } : new SqlParameter("@Attribute", SqlDbType.VarChar, -1)
                {
                    Value = model.Attribute
                },
                new SqlParameter("@Status", SqlDbType.Int, -1)
                {
                    Value = model.Status
                }
            };
            return(dbHelper.Execute(sql, parameters));
        }
コード例 #4
0
        public string Publish()
        {
            string html = Request["html"];
            string name = Request["name"];
            string att  = Request["att"];
            string id   = Request["id"];

            Guid gid;

            if (!id.IsGuid(out gid) || name.IsNullOrEmpty() || att.IsNullOrEmpty() || html.IsNullOrEmpty())
            {
                return("参数错误!");
            }
            BizProcess.Platform.WorkFlowForm WFF = new BizProcess.Platform.WorkFlowForm();

            BizProcess.Data.Model.WorkFlowForm wff = WFF.Get(gid);
            if (wff == null)
            {
                return("未找到表单!");
            }

            string fileName = id + ".cshtml";

            System.Text.StringBuilder serverScript = new System.Text.StringBuilder("@{\r\n");
            var attrJSON = LitJson.JsonMapper.ToObject(att);

            serverScript.Append("\tstring FlowID = Request.QueryString[\"flowid\"];\r\n");
            serverScript.Append("\tstring StepID = Request.QueryString[\"stepid\"];\r\n");
            serverScript.Append("\tstring GroupID = Request.QueryString[\"groupid\"];\r\n");
            serverScript.Append("\tstring TaskID = Request.QueryString[\"taskid\"];\r\n");
            serverScript.Append("\tstring InstanceID = Request.QueryString[\"instanceid\"];\r\n");
            serverScript.Append("\tstring DisplayModel = Request.QueryString[\"display\"] ?? \"0\";\r\n");
            serverScript.AppendFormat("\tstring DBConnID = \"{0}\";\r\n", attrJSON["dbconn"].ToString());
            serverScript.AppendFormat("\tstring DBTable = \"{0}\";\r\n", attrJSON["dbtable"].ToString());
            serverScript.AppendFormat("\tstring DBTablePK = \"{0}\";\r\n", attrJSON["dbtablepk"].ToString());
            serverScript.AppendFormat("\tstring DBTableTitle = \"{0}\";\r\n", attrJSON["dbtabletitle"].ToString());

            serverScript.Append("\tBizProcess.Platform.Dictionary BDictionary = new BizProcess.Platform.Dictionary();\r\n");
            serverScript.Append("\tBizProcess.Platform.WorkFlow BWorkFlow = new BizProcess.Platform.WorkFlow();\r\n");
            serverScript.Append("\tBizProcess.Platform.WorkFlowTask BWorkFlowTask = new BizProcess.Platform.WorkFlowTask();\r\n");
            serverScript.Append("\tstring fieldStatus = BWorkFlow.GetFieldStatus(FlowID, StepID);\r\n");
            serverScript.Append("\tLitJson.JsonData initData = BWorkFlow.GetFormData(DBConnID, DBTable, DBTablePK, InstanceID, fieldStatus);\r\n");
            serverScript.Append("\tstring TaskTitle = BWorkFlow.GetFromFieldData(initData, DBTable, DBTableTitle);\r\n");

            serverScript.Append("}\r\n");
            serverScript.Append("<link href=\"~/Scripts/FlowRun/Forms/flowform.css\" rel=\"stylesheet\" type=\"text/css\" />\r\n");
            serverScript.Append("<script src=\"~/Scripts/FlowRun/Forms/common.js\" type=\"text/javascript\" ></script>\r\n");

            if (attrJSON.ContainsKey("hasEditor") && "1" == attrJSON["hasEditor"].ToString())
            {
                serverScript.Append("<script src=\"~/Scripts/Ueditor/ueditor.config.js\" type=\"text/javascript\" ></script>\r\n");
                serverScript.Append("<script src=\"~/Scripts/Ueditor/ueditor.all.min.js\" type=\"text/javascript\" ></script>\r\n");
                serverScript.Append("<script src=\"~/Scripts/Ueditor/lang/zh-cn/zh-cn.js\" type=\"text/javascript\" ></script>\r\n");
                serverScript.Append("<input type=\"hidden\" id=\"Form_HasUEditor\" name=\"Form_HasUEditor\" value=\"1\" />\r\n");
            }
            string validatePropType = attrJSON.ContainsKey("validatealerttype") ? attrJSON["validatealerttype"].ToString() : "2";

            serverScript.Append("<input type=\"hidden\" id=\"Form_ValidateAlertType\" name=\"Form_ValidateAlertType\" value=\"" + validatePropType + "\" />\r\n");
            if (attrJSON.ContainsKey("autotitle") && attrJSON["autotitle"].ToString().ToLower() == "true")
            {
                serverScript.AppendFormat("<input type=\"hidden\" id=\"{0}\" name=\"{0}\" value=\"{1}\" />\r\n",
                                          string.Concat(attrJSON["dbtable"].ToString(), ".", attrJSON["dbtabletitle"].ToString()),
                                          "@(TaskTitle.IsNullOrEmpty() ? BWorkFlow.GetAutoTaskTitle(FlowID, StepID, Request.QueryString[\"groupid\"]) : TaskTitle)"
                                          );
            }
            serverScript.AppendFormat("<input type=\"hidden\" id=\"Form_TitleField\" name=\"Form_TitleField\" value=\"{0}\" />\r\n", string.Concat(attrJSON["dbtable"].ToString(), ".", attrJSON["dbtabletitle"].ToString()));
            //serverScript.AppendFormat("<input type=\"hidden\" id=\"Form_Name\" name=\"Form_Name\" value=\"{0}\" />\r\n", attrJSON["name"].ToString());
            serverScript.AppendFormat("<input type=\"hidden\" id=\"Form_DBConnID\" name=\"Form_DBConnID\" value=\"{0}\" />\r\n", attrJSON["dbconn"].ToString());
            serverScript.AppendFormat("<input type=\"hidden\" id=\"Form_DBTable\" name=\"Form_DBTable\" value=\"{0}\" />\r\n", attrJSON["dbtable"].ToString());
            serverScript.AppendFormat("<input type=\"hidden\" id=\"Form_DBTablePk\" name=\"Form_DBTablePk\" value=\"{0}\" />\r\n", attrJSON["dbtablepk"].ToString());
            serverScript.AppendFormat("<input type=\"hidden\" id=\"Form_DBTableTitle\" name=\"Form_DBTableTitle\" value=\"{0}\" />\r\n", attrJSON["dbtabletitle"].ToString());
            serverScript.AppendFormat("<input type=\"hidden\" id=\"Form_AutoSaveData\" name=\"Form_AutoSaveData\" value=\"{0}\" />\r\n", "1");
            serverScript.Append("<script type=\"text/javascript\">\r\n");
            serverScript.Append("\tvar initData = @Html.Raw(BWorkFlow.GetFormDataJsonString(initData));\r\n");
            serverScript.Append("\tvar fieldStatus = @Html.Raw(fieldStatus);\r\n");
            serverScript.Append("\tvar displayModel = '@DisplayModel';\r\n");
            serverScript.Append("\t$(window).load(function (){\r\n");
            serverScript.AppendFormat("\t\tformrun.initData(initData, \"{0}\", fieldStatus, displayModel);\r\n", attrJSON["dbtable"].ToString());
            serverScript.Append("\t});\r\n");
            serverScript.Append("</script>\r\n");


            string file = Server.MapPath("~/Views/WorkFlowFormDesigner/Forms/" + fileName);

            System.IO.Stream stream = System.IO.File.Open(file, FileMode.OpenOrCreate, FileAccess.Write, FileShare.None);
            stream.SetLength(0);

            StreamWriter sw = new StreamWriter(stream, System.Text.Encoding.UTF8);

            sw.Write(serverScript.ToString());
            sw.Write(Server.HtmlDecode(html));

            sw.Close();
            stream.Close();


            string attr    = wff.Attribute;
            string appType = LitJson.JsonMapper.ToObject(attr)["apptype"].ToString();

            BizProcess.Platform.AppLibrary App = new BizProcess.Platform.AppLibrary();
            var  app   = App.GetByCode(id);
            bool isAdd = false;

            if (app == null)
            {
                app      = new BizProcess.Data.Model.AppLibrary();
                app.ID   = Guid.NewGuid();
                app.Code = id;
                isAdd    = true;
            }
            app.Address  = "/Views/WorkFlowFormDesigner/Forms/" + fileName;
            app.Note     = "流程表单";
            app.OpenMode = 0;
            app.Params   = "";
            app.Title    = name.Trim();
            app.Type     = appType.IsGuid() ? appType.ToGuid() : new BizProcess.Platform.Dictionary().GetIDByCode("FormTypes");
            if (isAdd)
            {
                App.Add(app);
            }
            else
            {
                App.Update(app);
            }

            BizProcess.Platform.Log.Add("发布了流程表单", app.Serialize() + "内容:" + html, BizProcess.Platform.Log.Types.流程相关);
            wff.Status = 1;
            WFF.Update(wff);
            return("发布成功!");
        }
コード例 #5
0
        public string Save()
        {
            string html       = Request["html"];
            string name       = Request["name"];
            string att        = Request["att"];
            string id         = Request["id"];
            string type       = Request["type"];
            string subtable   = Request["subtable"];
            string formEvents = Request["formEvents"];

            if (name.IsNullOrEmpty())
            {
                return("表单名称不能为空!");
            }

            Guid formID;

            if (!id.IsGuid(out formID))
            {
                return("表单ID无效!");
            }

            BizProcess.Platform.WorkFlowForm   WFF = new BizProcess.Platform.WorkFlowForm();
            BizProcess.Data.Model.WorkFlowForm wff = WFF.Get(formID);
            bool   isAdd  = false;
            string oldXML = string.Empty;

            if (wff == null)
            {
                wff                = new BizProcess.Data.Model.WorkFlowForm();
                wff.ID             = formID;
                wff.Type           = type.ToGuid();
                wff.CreateUserID   = BizProcess.Platform.Users.CurrentUserID;
                wff.CreateUserName = BizProcess.Platform.Users.CurrentUserName;
                wff.CreateTime     = BizProcess.Utility.DateTimeNew.Now;
                wff.Status         = 0;
                isAdd              = true;
            }
            else
            {
                oldXML = wff.Serialize();
            }

            wff.Attribute      = att;
            wff.Html           = html;
            wff.LastModifyTime = BizProcess.Utility.DateTimeNew.Now;
            wff.Name           = name;
            wff.SubTableJson   = subtable;
            wff.EventsJson     = formEvents;

            if (isAdd)
            {
                WFF.Add(wff);
                BizProcess.Platform.Log.Add("添加了流程表单", wff.Serialize(), BizProcess.Platform.Log.Types.流程相关);
            }
            else
            {
                WFF.Update(wff);
                BizProcess.Platform.Log.Add("修改了流程表单", "", BizProcess.Platform.Log.Types.流程相关, oldXML, wff.Serialize());
            }
            return("保存成功!");
        }
コード例 #6
0
 /// <summary>
 /// 更新
 /// </summary>
 public int Update(BizProcess.Data.Model.WorkFlowForm model)
 {
     return(dataWorkFlowForm.Update(model));
 }
コード例 #7
0
 /// <summary>
 /// 新增
 /// </summary>
 public int Add(BizProcess.Data.Model.WorkFlowForm model)
 {
     return(dataWorkFlowForm.Add(model));
 }
コード例 #8
0
        /// <summary>
        /// 更新记录
        /// </summary>
        /// <param name="model">BizProcess.Data.Model.WorkFlowForm实体类</param>
        public int Update(BizProcess.Data.Model.WorkFlowForm model)
        {
            string sql = @"UPDATE WorkFlowForm SET 
				Name=:Name,Type=:Type,CreateUserID=:CreateUserID,CreateUserName=:CreateUserName,CreateTime=:CreateTime,LastModifyTime=:LastModifyTime,Html=:Html,SubTableJson=:SubTableJson,EventsJson=:EventsJson,Attribute=:Attribute,Status=:Status
				WHERE ID=:ID"                ;

            OracleParameter[] parameters = new OracleParameter[] {
                new OracleParameter(":Name", OracleDbType.NVarchar2, 1000)
                {
                    Value = model.Name
                },
                new OracleParameter(":Type", OracleDbType.Char, 36)
                {
                    Value = model.Type
                },
                new OracleParameter(":CreateUserID", OracleDbType.Char, 36)
                {
                    Value = model.CreateUserID
                },
                new OracleParameter(":CreateUserName", OracleDbType.NVarchar2, 100)
                {
                    Value = model.CreateUserName
                },
                new OracleParameter(":CreateTime", OracleDbType.Date)
                {
                    Value = model.CreateTime
                },
                new OracleParameter(":LastModifyTime", OracleDbType.Date)
                {
                    Value = model.LastModifyTime
                },
                model.Html == null ? new OracleParameter(":Html", OracleDbType.Clob)
                {
                    Value = DBNull.Value
                } : new OracleParameter(":Html", OracleDbType.Clob)
                {
                    Value = model.Html
                },
                model.SubTableJson == null ? new OracleParameter(":SubTableJson", OracleDbType.Clob)
                {
                    Value = DBNull.Value
                } : new OracleParameter(":SubTableJson", OracleDbType.Clob)
                {
                    Value = model.SubTableJson
                },
                model.EventsJson == null ? new OracleParameter(":EventsJson", OracleDbType.Clob)
                {
                    Value = DBNull.Value
                } : new OracleParameter(":EventsJson", OracleDbType.Clob)
                {
                    Value = model.EventsJson
                },
                model.Attribute == null ? new OracleParameter(":Attribute", OracleDbType.Clob)
                {
                    Value = DBNull.Value
                } : new OracleParameter(":Attribute", OracleDbType.Clob)
                {
                    Value = model.Attribute
                },
                new OracleParameter(":Status", OracleDbType.Int32)
                {
                    Value = model.Status
                },
                new OracleParameter(":ID", OracleDbType.Char, 36)
                {
                    Value = model.ID
                }
            };
            return(dbHelper.Execute(sql, parameters));
        }
コード例 #9
0
        /// <summary>
        /// 添加记录
        /// </summary>
        /// <param name="model">BizProcess.Data.Model.WorkFlowForm实体类</param>
        /// <returns>操作所影响的行数</returns>
        public int Add(BizProcess.Data.Model.WorkFlowForm model)
        {
            string sql = @"INSERT INTO WorkFlowForm
				(ID,Name,Type,CreateUserID,CreateUserName,CreateTime,LastModifyTime,Html,SubTableJson,EventsJson,Attribute,Status) 
				VALUES(:ID,:Name,:Type,:CreateUserID,:CreateUserName,:CreateTime,:LastModifyTime,:Html,:SubTableJson,:EventsJson,:Attribute,:Status)"                ;

            OracleParameter[] parameters = new OracleParameter[] {
                new OracleParameter(":ID", OracleDbType.Char, 36)
                {
                    Value = model.ID
                },
                new OracleParameter(":Name", OracleDbType.NVarchar2, 1000)
                {
                    Value = model.Name
                },
                new OracleParameter(":Type", OracleDbType.Char, 36)
                {
                    Value = model.Type
                },
                new OracleParameter(":CreateUserID", OracleDbType.Char, 36)
                {
                    Value = model.CreateUserID
                },
                new OracleParameter(":CreateUserName", OracleDbType.NVarchar2, 100)
                {
                    Value = model.CreateUserName
                },
                new OracleParameter(":CreateTime", OracleDbType.Date)
                {
                    Value = model.CreateTime
                },
                new OracleParameter(":LastModifyTime", OracleDbType.Date)
                {
                    Value = model.LastModifyTime
                },
                model.Html == null ? new OracleParameter(":Html", OracleDbType.Clob)
                {
                    Value = DBNull.Value
                } : new OracleParameter(":Html", OracleDbType.Clob)
                {
                    Value = model.Html
                },
                model.SubTableJson == null ? new OracleParameter(":SubTableJson", OracleDbType.Clob)
                {
                    Value = DBNull.Value
                } : new OracleParameter(":SubTableJson", OracleDbType.Clob)
                {
                    Value = model.SubTableJson
                },
                model.EventsJson == null ? new OracleParameter(":EventsJson", OracleDbType.Clob)
                {
                    Value = DBNull.Value
                } : new OracleParameter(":EventsJson", OracleDbType.Clob)
                {
                    Value = model.EventsJson
                },
                model.Attribute == null ? new OracleParameter(":Attribute", OracleDbType.Clob)
                {
                    Value = DBNull.Value
                } : new OracleParameter(":Attribute", OracleDbType.Clob)
                {
                    Value = model.Attribute
                },
                new OracleParameter(":Status", OracleDbType.Int32)
                {
                    Value = model.Status
                }
            };
            return(dbHelper.Execute(sql, parameters));
        }