1023 lines
		
	
	
		
			41 KiB
		
	
	
	
		
			C#
		
	
	
	
			
		
		
	
	
			1023 lines
		
	
	
		
			41 KiB
		
	
	
	
		
			C#
		
	
	
	
using BLL;
 | 
						||
using Newtonsoft.Json.Linq;
 | 
						||
using System;
 | 
						||
using System.Collections.Generic;
 | 
						||
using System.Data;
 | 
						||
using System.Data.OleDb;
 | 
						||
using System.IO;
 | 
						||
using System.Linq;
 | 
						||
using System.Text;
 | 
						||
using WIA;
 | 
						||
 | 
						||
namespace FineUIPro.Web.AttachFile
 | 
						||
{
 | 
						||
    public partial class webuploader : PageBase
 | 
						||
    {
 | 
						||
        private static readonly string sessionName = "AttachFile.webuploader";
 | 
						||
        protected string ParamStr;
 | 
						||
 | 
						||
        #region 定义项
 | 
						||
        public string ToKeyId
 | 
						||
        {
 | 
						||
            get
 | 
						||
            {
 | 
						||
                return (string)ViewState["ToKeyId"];
 | 
						||
            }
 | 
						||
            set
 | 
						||
            {
 | 
						||
                ViewState["ToKeyId"] = value;
 | 
						||
            }
 | 
						||
        }
 | 
						||
 | 
						||
        public string AttachPath
 | 
						||
        {
 | 
						||
            get
 | 
						||
            {
 | 
						||
                return (string)ViewState["AttachPath"];
 | 
						||
            }
 | 
						||
            set
 | 
						||
            {
 | 
						||
                ViewState["AttachPath"] = value;
 | 
						||
            }
 | 
						||
        }
 | 
						||
 | 
						||
        public string MenuId
 | 
						||
        {
 | 
						||
            get
 | 
						||
            {
 | 
						||
                return (string)ViewState["MenuId"];
 | 
						||
            }
 | 
						||
            set
 | 
						||
            {
 | 
						||
                ViewState["MenuId"] = value;
 | 
						||
            }
 | 
						||
        }
 | 
						||
        public string Type
 | 
						||
        {
 | 
						||
            get
 | 
						||
            {
 | 
						||
                return (string)ViewState["Type"];
 | 
						||
            }
 | 
						||
            set
 | 
						||
            {
 | 
						||
                ViewState["Type"] = value;
 | 
						||
            }
 | 
						||
        }
 | 
						||
 | 
						||
        public string Source
 | 
						||
        {
 | 
						||
            get
 | 
						||
            {
 | 
						||
                return (string)ViewState["Source"];
 | 
						||
            }
 | 
						||
            set
 | 
						||
            {
 | 
						||
                ViewState["Source"] = value;
 | 
						||
            }
 | 
						||
        }
 | 
						||
        public string JointCheck
 | 
						||
        {
 | 
						||
            get
 | 
						||
            {
 | 
						||
                return (string)ViewState["JointCheck"];
 | 
						||
            }
 | 
						||
            set
 | 
						||
            {
 | 
						||
                ViewState["JointCheck"] = value;
 | 
						||
            }
 | 
						||
        }
 | 
						||
        public string editorMode
 | 
						||
        {
 | 
						||
            get
 | 
						||
            {
 | 
						||
                return (string)ViewState["editorMode"];
 | 
						||
            }
 | 
						||
            set
 | 
						||
            {
 | 
						||
                ViewState["editorMode"] = value;
 | 
						||
            }
 | 
						||
        }
 | 
						||
        #endregion
 | 
						||
 | 
						||
        #region 加载页面
 | 
						||
        /// <summary>
 | 
						||
        /// 加载页面
 | 
						||
        /// </summary>
 | 
						||
        /// <param name="sender"></param>
 | 
						||
        /// <param name="e"></param>
 | 
						||
        protected void Page_Load(object sender, EventArgs e)
 | 
						||
        {
 | 
						||
            if (!IsPostBack)
 | 
						||
            {
 | 
						||
                // 删除选中行
 | 
						||
                this.btnDelete.OnClientClick = Grid1.GetNoSelectionAlertReference("请至少选择一项!");
 | 
						||
                this.btnDelete.ConfirmText = String.Format("你确定要删除选中的 <b><script>{0}</script></b> 个文件吗?", Grid1.GetSelectedCountReference());
 | 
						||
                Session[sessionName] = null;
 | 
						||
                this.ToKeyId = Request.QueryString["toKeyId"];
 | 
						||
                if (!string.IsNullOrEmpty(Request.QueryString["strParam"]))
 | 
						||
                {
 | 
						||
                    this.ToKeyId = this.ToKeyId + "#" + Request.QueryString["strParam"];
 | 
						||
                }
 | 
						||
 | 
						||
                this.AttachPath = Request.QueryString["path"];
 | 
						||
                this.ParamStr = sessionName + "|" + AttachPath;
 | 
						||
                this.MenuId = Request.QueryString["menuId"];
 | 
						||
                this.Type = Request.Params["type"];
 | 
						||
                JointCheck = Request.Params["JointCheck"];//是否共检页面
 | 
						||
                Source = Request.QueryString["source"];//如果等于1则是文件柜
 | 
						||
 | 
						||
                editorMode = Request.Params["editorMode"];
 | 
						||
                if (string.IsNullOrEmpty(editorMode))
 | 
						||
                {
 | 
						||
                    editorMode = "edit";
 | 
						||
                }
 | 
						||
                //Request.QueryString["type"]; ////类型:0时是上传资源页面,附件权限不需要判断 -1时只查看权限 -2查看集团公司
 | 
						||
                this.GetButtonPower();
 | 
						||
                this.BindGrid();
 | 
						||
 | 
						||
                //用于开车总结签字版附件,不可编辑
 | 
						||
                if (Request.QueryString["strParam"] == "2" && (this.MenuId == BLL.Const.SpecialSummaryMenuId || this.MenuId == BLL.Const.PersonalSummaryMenuId || this.MenuId == BLL.Const.CompleteSummaryMenuId))
 | 
						||
                {
 | 
						||
                    btnOnlineEdit.Hidden = true;
 | 
						||
                }
 | 
						||
            }
 | 
						||
            else
 | 
						||
            {
 | 
						||
                if (GetRequestEventArgument() == "RebindGrid")
 | 
						||
                {
 | 
						||
                    this.BindGrid();
 | 
						||
                }
 | 
						||
            }
 | 
						||
        }
 | 
						||
        #endregion
 | 
						||
 | 
						||
        #region BindGrid
 | 
						||
        /// <summary>
 | 
						||
        /// 绑定GV
 | 
						||
        /// </summary>
 | 
						||
        private void BindGrid()
 | 
						||
        {
 | 
						||
            if (Source == "1")  //文件柜
 | 
						||
            {
 | 
						||
                if (!string.IsNullOrWhiteSpace(JointCheck))
 | 
						||
                {
 | 
						||
                    if (JointCheck.Equals("JointCheck"))
 | 
						||
                    {
 | 
						||
                        Grid1.DataSource = JointData();
 | 
						||
                    }
 | 
						||
                }
 | 
						||
                else
 | 
						||
                {
 | 
						||
                    Grid1.DataSource = SourceData();
 | 
						||
                }
 | 
						||
            }
 | 
						||
            else
 | 
						||
            {
 | 
						||
                Grid1.DataSource = GetSourceData();
 | 
						||
            }
 | 
						||
            Grid1.DataBind();
 | 
						||
        }
 | 
						||
 | 
						||
        #endregion
 | 
						||
 | 
						||
        private JArray JointData()
 | 
						||
        {
 | 
						||
            if (Session[sessionName] == null && !string.IsNullOrEmpty(ToKeyId))
 | 
						||
            {
 | 
						||
                //Session[sessionName] = new JArray();
 | 
						||
                StringBuilder stxt = new StringBuilder();
 | 
						||
                var jointChecks = JointCheckDetailService.GetViewLists(ToKeyId);
 | 
						||
                var liststr = new List<string>();
 | 
						||
                if (jointChecks.Count > 0)
 | 
						||
                {
 | 
						||
                    foreach (var itemjointChecks in jointChecks)
 | 
						||
                    {
 | 
						||
                        liststr.Add(itemjointChecks.JointCheckDetailId);
 | 
						||
                        liststr.Add(itemjointChecks.JointCheckDetailId + "r");
 | 
						||
                    }
 | 
						||
 | 
						||
                }
 | 
						||
                var sourlist = AttachFileService.GetfileDetaillist(liststr, MenuId);
 | 
						||
                if (sourlist.Count > 0)
 | 
						||
                {
 | 
						||
                    stxt.Append("[");
 | 
						||
 | 
						||
                    foreach (var sour in sourlist)
 | 
						||
                    {
 | 
						||
                        int index = sourlist.IndexOf(sour);
 | 
						||
                        string str = string.Empty;
 | 
						||
                        if (sour != null)
 | 
						||
                        {
 | 
						||
                            string url = sour.AttachUrl.Replace('\\', '/');
 | 
						||
 | 
						||
                            List<string> list = Funs.GetStrListByStr(url, ',');
 | 
						||
                            if (list.Count() > 0)
 | 
						||
                            {
 | 
						||
                                int i = 0;
 | 
						||
                                foreach (var item in list)
 | 
						||
                                {
 | 
						||
                                    string atturl = Funs.RootPath + item.Replace(';', ' ').Trim();
 | 
						||
                                    if (File.Exists(atturl))
 | 
						||
                                    {
 | 
						||
                                        i += 1;
 | 
						||
                                        break;
 | 
						||
                                    }
 | 
						||
                                }
 | 
						||
                                if (i > 0)
 | 
						||
                                {
 | 
						||
                                    if (sourlist.Count == 1)
 | 
						||
                                    {
 | 
						||
                                        str = sour.AttachSource.Substring(0, sour.AttachSource.Length - 1);
 | 
						||
                                        str = str.Substring(1);
 | 
						||
                                    }
 | 
						||
                                    else if (sourlist.Count > 1)
 | 
						||
                                    {
 | 
						||
 | 
						||
                                        var st = sour.AttachSource.Substring(0, sour.AttachSource.Length - 1);
 | 
						||
                                        st = st.Substring(1);
 | 
						||
                                        if (sourlist.Count - 1 != index)
 | 
						||
                                        {
 | 
						||
                                            st += ",";
 | 
						||
                                        }
 | 
						||
                                        str += st;
 | 
						||
 | 
						||
                                    }
 | 
						||
 | 
						||
                                }
 | 
						||
                            }
 | 
						||
                            stxt.Append(str);
 | 
						||
                        }
 | 
						||
                    }
 | 
						||
 | 
						||
                    stxt.Append("]");
 | 
						||
 | 
						||
                    Session[sessionName] = JArray.Parse(stxt.ToString());
 | 
						||
 | 
						||
                }
 | 
						||
            }
 | 
						||
 | 
						||
            return (JArray)Session[sessionName];
 | 
						||
        }
 | 
						||
 | 
						||
        /// <summary>
 | 
						||
        /// 文件柜专用
 | 
						||
        /// </summary>
 | 
						||
        /// <returns></returns>
 | 
						||
        private JArray SourceData()
 | 
						||
        {
 | 
						||
 | 
						||
            if (Session[sessionName] == null && !string.IsNullOrEmpty(ToKeyId))
 | 
						||
            {
 | 
						||
                //Session[sessionName] = new JArray();
 | 
						||
                StringBuilder stxt = new StringBuilder();
 | 
						||
                IList<Model.AttachFile> sourlist = AttachFileService.Getfilelist(ToKeyId, MenuId);
 | 
						||
                if (sourlist.Count > 0)
 | 
						||
                {
 | 
						||
                    stxt.Append("[");
 | 
						||
 | 
						||
                    foreach (var sour in sourlist)
 | 
						||
                    {
 | 
						||
                        int index = sourlist.IndexOf(sour);
 | 
						||
                        string str = string.Empty;
 | 
						||
                        if (sour != null)
 | 
						||
                        {
 | 
						||
                            string url = sour.AttachUrl.Replace('\\', '/');
 | 
						||
 | 
						||
                            List<string> list = Funs.GetStrListByStr(url, ',');
 | 
						||
                            if (list.Count() > 0)
 | 
						||
                            {
 | 
						||
                                int i = 0;
 | 
						||
                                foreach (var item in list)
 | 
						||
                                {
 | 
						||
                                    string atturl = Funs.RootPath + item.Replace(';', ' ').Trim();
 | 
						||
                                    if (File.Exists(atturl))
 | 
						||
                                    {
 | 
						||
                                        i += 1;
 | 
						||
                                        break;
 | 
						||
                                    }
 | 
						||
                                }
 | 
						||
                                if (i > 0)
 | 
						||
                                {
 | 
						||
                                    if (sourlist.Count == 1)
 | 
						||
                                    {
 | 
						||
                                        str = sour.AttachSource.Substring(0, sour.AttachSource.Length - 1);
 | 
						||
                                        str = str.Substring(1);
 | 
						||
                                    }
 | 
						||
                                    else if (sourlist.Count > 1)
 | 
						||
                                    {
 | 
						||
 | 
						||
                                        var st = sour.AttachSource.Substring(0, sour.AttachSource.Length - 1);
 | 
						||
                                        st = st.Substring(1);
 | 
						||
                                        if (sourlist.Count - 1 != index)
 | 
						||
                                        {
 | 
						||
                                            st += ",";
 | 
						||
                                        }
 | 
						||
                                        str += st;
 | 
						||
 | 
						||
                                    }
 | 
						||
 | 
						||
                                }
 | 
						||
                            }
 | 
						||
                            stxt.Append(str);
 | 
						||
                        }
 | 
						||
                    }
 | 
						||
 | 
						||
                    stxt.Append("]");
 | 
						||
 | 
						||
                    Session[sessionName] = JArray.Parse(stxt.ToString());
 | 
						||
 | 
						||
                }
 | 
						||
            }
 | 
						||
 | 
						||
            return (JArray)Session[sessionName];
 | 
						||
        }
 | 
						||
 | 
						||
        #region Events
 | 
						||
        /// <summary>
 | 
						||
        /// 删除按钮
 | 
						||
        /// </summary>
 | 
						||
        /// <param name="sender"></param>
 | 
						||
        /// <param name="e"></param>
 | 
						||
        protected void btnDelete_Click(object sender, EventArgs e)
 | 
						||
        {
 | 
						||
            foreach (string rowId in Grid1.SelectedRowIDArray)
 | 
						||
            {
 | 
						||
                DeleteRow(rowId);
 | 
						||
            }
 | 
						||
 | 
						||
            BindGrid();
 | 
						||
        }
 | 
						||
 | 
						||
        /// <summary>
 | 
						||
        /// 行事件
 | 
						||
        /// </summary>
 | 
						||
        /// <param name="sender"></param>
 | 
						||
        /// <param name="e"></param>
 | 
						||
        protected void Grid1_RowCommand(object sender, GridCommandEventArgs e)
 | 
						||
        {
 | 
						||
            if (e.CommandName == "Delete")
 | 
						||
            {
 | 
						||
                DeleteRow(e.RowID);
 | 
						||
                BindGrid();
 | 
						||
            }
 | 
						||
            if (e.CommandName == "Preview")
 | 
						||
            {
 | 
						||
                JArray source = GetSourceData();
 | 
						||
                for (int i = 0, count = source.Count; i < count; i++)
 | 
						||
                {
 | 
						||
                    JObject item = source[i] as JObject;
 | 
						||
                    if (item.Value<string>("id") == e.RowID)
 | 
						||
                    {
 | 
						||
                        try
 | 
						||
                        {
 | 
						||
                            string savedName = item.Value<string>("savedName");
 | 
						||
                            string folder = item.Value<string>("folder");
 | 
						||
                            string xnUrl = AttachPath + "\\" + savedName;
 | 
						||
                            if (!string.IsNullOrEmpty(folder))
 | 
						||
                            {
 | 
						||
                                xnUrl = folder + savedName;
 | 
						||
                            }
 | 
						||
 | 
						||
                            string url = Funs.RootPath + xnUrl;
 | 
						||
                            if (savedName.Contains("FileUpLoad"))
 | 
						||
                            {
 | 
						||
                                url = Funs.RootPath + savedName.Replace('/', '\\');
 | 
						||
                            }
 | 
						||
                            FileInfo info = new FileInfo(url);
 | 
						||
                            if (!info.Exists || string.IsNullOrEmpty(savedName))
 | 
						||
                            {
 | 
						||
                                url = Funs.RootPath + "Images//Null.jpg";
 | 
						||
                                info = new FileInfo(url);
 | 
						||
                            }
 | 
						||
                            var FiletExtension = Path.GetExtension(savedName);
 | 
						||
                            bool isSupportType = AttachFileService.IsSupportFileType(FiletExtension);
 | 
						||
                            if (isSupportType)
 | 
						||
                            {
 | 
						||
                                PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("../AttachFile/Look.aspx?fileUrl={0}", url, "查看  -")));
 | 
						||
                            }
 | 
						||
                            else
 | 
						||
                            {
 | 
						||
                                ShowNotify("不支持预览", MessageBoxIcon.Warning);
 | 
						||
 | 
						||
                            }
 | 
						||
                            //if (FiletExtension == ".docx" || FiletExtension == ".pdf")
 | 
						||
                            //{
 | 
						||
                            //    string httpUrl = BLL.AsposeWordHelper.WordToHtml(url);
 | 
						||
                            //    PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("../AttachFile/Look.aspx?fileUrl={0}", httpUrl, "查看  -")));
 | 
						||
 | 
						||
                            //}
 | 
						||
                            //else if (FiletExtension == ".txt")
 | 
						||
                            //{
 | 
						||
 | 
						||
                            //    PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("../AttachFile/Look.aspx?fileUrl={0}", url, "查看  -")));
 | 
						||
                            //}
 | 
						||
                            //else if (FiletExtension == ".xls")
 | 
						||
                            //{
 | 
						||
                            //    string httpUrl = BLL.AsposeWordHelper.PriviewExcel(url);
 | 
						||
 | 
						||
                            //    PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("../AttachFile/Look.aspx?fileUrl={0}", httpUrl, "查看  -")));
 | 
						||
                            //}
 | 
						||
                            //else
 | 
						||
                            //{
 | 
						||
                            //    ShowNotify("不支持预览", MessageBoxIcon.Warning);
 | 
						||
                            //}
 | 
						||
                        }
 | 
						||
                        catch (Exception)
 | 
						||
                        {
 | 
						||
 | 
						||
                        }
 | 
						||
                    }
 | 
						||
                }
 | 
						||
            }
 | 
						||
            if (e.CommandName == "Attach")
 | 
						||
            {
 | 
						||
                JArray source = GetSourceData();
 | 
						||
                for (int i = 0, count = source.Count; i < count; i++)
 | 
						||
                {
 | 
						||
                    JObject item = source[i] as JObject;
 | 
						||
                    if (item.Value<string>("id") == e.RowID)
 | 
						||
                    {
 | 
						||
                        try
 | 
						||
                        {
 | 
						||
 | 
						||
                            string savedName = item.Value<string>("savedName");
 | 
						||
                            string folder = item.Value<string>("folder");
 | 
						||
                            string xnUrl = AttachPath + "\\" + savedName;
 | 
						||
                            if (!string.IsNullOrEmpty(folder))
 | 
						||
                            {
 | 
						||
                                xnUrl = folder + savedName;
 | 
						||
                            }
 | 
						||
 | 
						||
                            string url = Funs.RootPath + xnUrl;
 | 
						||
                            if (savedName.Contains("FileUpLoad"))
 | 
						||
                            {
 | 
						||
                                url = Funs.RootPath + savedName.Replace('/', '\\');
 | 
						||
                            }
 | 
						||
                            FileInfo info = new FileInfo(url);
 | 
						||
                            if (!info.Exists || string.IsNullOrEmpty(savedName))
 | 
						||
                            {
 | 
						||
                                url = Funs.RootPath + "Images//Null.jpg";
 | 
						||
                                info = new FileInfo(url);
 | 
						||
                            }
 | 
						||
 | 
						||
                            if (Path.GetExtension(savedName) == ".mp4" || Path.GetExtension(savedName).ToLower() == ".mp4" || Path.GetExtension(savedName) == ".m4v")
 | 
						||
                            {
 | 
						||
                                PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("../AttachFile/player.aspx?url={0}", xnUrl.Replace('\\', '/'), "播放 - ")));
 | 
						||
                            }
 | 
						||
                            else
 | 
						||
                            {
 | 
						||
                                if (Path.GetExtension(savedName) == ".gif" || Path.GetExtension(savedName) == ".jpg" || Path.GetExtension(savedName) == ".jpeg" || Path.GetExtension(savedName) == ".bmp" || Path.GetExtension(savedName) == ".png")
 | 
						||
                                {
 | 
						||
                                    string httpUrl = Funs.SGGLUrl + xnUrl;
 | 
						||
                                    ClientScript.RegisterStartupScript(ClientScript.GetType(), "myscript", "<script type='text/javascript'>window.open('" + httpUrl + "');</script>");
 | 
						||
                                }
 | 
						||
                                else
 | 
						||
                                {
 | 
						||
                                    string fileName = Path.GetFileName(url);
 | 
						||
                                    long fileSize = info.Length;
 | 
						||
                                    System.Web.HttpContext.Current.Response.Clear();
 | 
						||
                                    //System.Web.HttpContext.Current.Response.ContentType = "application/x-zip-compressed";
 | 
						||
                                    System.Web.HttpContext.Current.Response.ContentType = "application/octet-stream";
 | 
						||
                                    System.Web.HttpContext.Current.Response.AddHeader("Content-Disposition", "attachment;filename=" + System.Web.HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8));
 | 
						||
                                    System.Web.HttpContext.Current.Response.AddHeader("Content-Length", fileSize.ToString());
 | 
						||
                                    System.Web.HttpContext.Current.Response.TransmitFile(url, 0, fileSize);
 | 
						||
                                    System.Web.HttpContext.Current.Response.Flush();
 | 
						||
                                    System.Web.HttpContext.Current.Response.End();
 | 
						||
                                    break;
 | 
						||
                                }
 | 
						||
                            }
 | 
						||
                        }
 | 
						||
                        catch (Exception ex)
 | 
						||
                        {
 | 
						||
 | 
						||
                        }
 | 
						||
                    }
 | 
						||
                }
 | 
						||
            }
 | 
						||
        }
 | 
						||
        #endregion
 | 
						||
 | 
						||
        #region GetSourceData
 | 
						||
        /// <summary>
 | 
						||
        /// 得到Session
 | 
						||
        /// </summary>
 | 
						||
        /// <returns></returns>
 | 
						||
        private JArray GetSourceData()
 | 
						||
        {
 | 
						||
            if (Session[sessionName] == null && !string.IsNullOrEmpty(ToKeyId))
 | 
						||
            {
 | 
						||
                Session[sessionName] = new JArray();
 | 
						||
                Model.AttachFile sour = new Model.AttachFile();
 | 
						||
                if (this.MenuId == Const.ProjectPunishNoticeMenuId || this.MenuId == Const.ProjectPunishNoticeStatisticsMenuId)
 | 
						||
                {
 | 
						||
                    sour = Funs.DB.AttachFile.FirstOrDefault(x => x.ToKeyId == ToKeyId && x.MenuId == this.MenuId);
 | 
						||
                }
 | 
						||
                else
 | 
						||
                {
 | 
						||
                    sour = Funs.DB.AttachFile.FirstOrDefault(x => x.ToKeyId == ToKeyId);
 | 
						||
                }
 | 
						||
 | 
						||
                if (sour != null)
 | 
						||
                {
 | 
						||
                    string url = sour.AttachUrl.Replace('\\', '/');
 | 
						||
                    List<string> list = Funs.GetStrListByStr(url, ',');
 | 
						||
                    if (list.Count() > 0)
 | 
						||
                    {
 | 
						||
                        int i = 0;
 | 
						||
                        foreach (var item in list)
 | 
						||
                        {
 | 
						||
                            string atturl = Funs.RootPath + item.Replace(';', ' ').Trim();
 | 
						||
                            if (File.Exists(atturl))
 | 
						||
                            {
 | 
						||
                                i += 1;
 | 
						||
                                break;
 | 
						||
                            }
 | 
						||
                        }
 | 
						||
                        if (i > 0)
 | 
						||
                        {
 | 
						||
                            Session[sessionName] = JArray.Parse(sour.AttachSource);
 | 
						||
                        }
 | 
						||
                    }
 | 
						||
                }
 | 
						||
            }
 | 
						||
 | 
						||
            return (JArray)Session[sessionName];
 | 
						||
        }
 | 
						||
 | 
						||
        /// <summary>
 | 
						||
        /// 
 | 
						||
        /// </summary>
 | 
						||
        /// <param name="rowId"></param>
 | 
						||
        private void DeleteRow(string rowId)
 | 
						||
        {
 | 
						||
            JArray source = GetSourceData();
 | 
						||
            for (int i = 0, count = source.Count; i < count; i++)
 | 
						||
            {
 | 
						||
                JObject item = source[i] as JObject;
 | 
						||
                if (item.Value<string>("id") == rowId)
 | 
						||
                {
 | 
						||
                    try
 | 
						||
                    {
 | 
						||
                        string savedName = item.Value<string>("savedName");
 | 
						||
                        string attachUrl = AttachPath + "\\" + savedName;
 | 
						||
                        if (!string.IsNullOrEmpty(item.Value<string>("folder")))
 | 
						||
                        {
 | 
						||
                            attachUrl = item.Value<string>("folder") + savedName;
 | 
						||
                        }
 | 
						||
                        if (this.AttachPath.Contains("DriverRunPlanK"))
 | 
						||
                        {
 | 
						||
                            ImportXlsToData(Server.MapPath("~/" + attachUrl));
 | 
						||
                        }
 | 
						||
                        File.Delete(Server.MapPath("~/" + attachUrl));
 | 
						||
                        BLL.LogService.AddSys_Log(this.CurrUser, "删除附件!", null, this.MenuId, BLL.Const.BtnDelete);
 | 
						||
 | 
						||
                    }
 | 
						||
                    catch (Exception)
 | 
						||
                    {
 | 
						||
                        // 尝试删除物理文件失败,不做处理
 | 
						||
                    }
 | 
						||
                    source.RemoveAt(i);
 | 
						||
                    break;
 | 
						||
                }
 | 
						||
            }
 | 
						||
            Session[sessionName] = source;
 | 
						||
 | 
						||
            //删除附件后,修改附件表数据
 | 
						||
            string attachUrlNew = string.Empty;
 | 
						||
            for (int i = 0, count = source.Count; i < count; i++)
 | 
						||
            {
 | 
						||
                JObject item = source[i] as JObject;
 | 
						||
                if (!string.IsNullOrEmpty(item.Value<string>("folder")))
 | 
						||
                {
 | 
						||
                    attachUrlNew += item.Value<string>("folder") + item.Value<string>("savedName") + ",";
 | 
						||
                }
 | 
						||
                else
 | 
						||
                {
 | 
						||
                    attachUrlNew += AttachPath + "/" + DateTime.Now.ToString("yyyy-MM") + "/" + item.Value<string>("savedName") + ",";
 | 
						||
                }
 | 
						||
            }
 | 
						||
            if (!string.IsNullOrEmpty(attachUrlNew))
 | 
						||
            {
 | 
						||
                attachUrlNew = attachUrlNew.Substring(0, attachUrlNew.LastIndexOf(",")).Replace('\\', '/');
 | 
						||
            }
 | 
						||
            ///保存方法
 | 
						||
            this.SaveData(source.ToString(), attachUrlNew);
 | 
						||
        }
 | 
						||
 | 
						||
        #region 读Excel提取数据
 | 
						||
        /// <summary>
 | 
						||
        /// 从Excel提取数据--》Dataset
 | 
						||
        /// </summary>
 | 
						||
        /// <param name="filename">Excel文件路径名</param>
 | 
						||
        private void ImportXlsToData(string fileName)
 | 
						||
        {
 | 
						||
            try
 | 
						||
            {
 | 
						||
                string oleDBConnString = String.Empty;
 | 
						||
                oleDBConnString = "Provider=Microsoft.Jet.OLEDB.4.0;";
 | 
						||
                oleDBConnString += "Data Source=";
 | 
						||
                oleDBConnString += fileName;
 | 
						||
                oleDBConnString += ";Extended Properties=Excel 8.0;";
 | 
						||
                OleDbConnection oleDBConn = null;
 | 
						||
                OleDbDataAdapter oleAdMaster = null;
 | 
						||
                DataTable m_tableName = new DataTable();
 | 
						||
                DataSet ds = new DataSet();
 | 
						||
 | 
						||
                oleDBConn = new OleDbConnection(oleDBConnString);
 | 
						||
                oleDBConn.Open();
 | 
						||
                m_tableName = oleDBConn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
 | 
						||
 | 
						||
                if (m_tableName != null && m_tableName.Rows.Count > 0)
 | 
						||
                {
 | 
						||
 | 
						||
                    m_tableName.TableName = m_tableName.Rows[0]["TABLE_NAME"].ToString().Trim();
 | 
						||
 | 
						||
                }
 | 
						||
                string sqlMaster;
 | 
						||
                sqlMaster = " SELECT *  FROM [" + m_tableName.TableName + "]";
 | 
						||
                oleAdMaster = new OleDbDataAdapter(sqlMaster, oleDBConn);
 | 
						||
                oleAdMaster.Fill(ds, "m_tableName");
 | 
						||
                oleAdMaster.Dispose();
 | 
						||
                oleDBConn.Close();
 | 
						||
                oleDBConn.Dispose();
 | 
						||
 | 
						||
                AddDatasetToSQL(ds.Tables[0], 35);
 | 
						||
            }
 | 
						||
            catch (Exception exc)
 | 
						||
            {
 | 
						||
                //return null;
 | 
						||
                // return dt;
 | 
						||
            }
 | 
						||
            finally
 | 
						||
            {
 | 
						||
            }
 | 
						||
        }
 | 
						||
        #endregion
 | 
						||
 | 
						||
        #region 将Dataset的数据导入数据库
 | 
						||
        /// <summary>
 | 
						||
        /// 将Dataset的数据导入数据库
 | 
						||
        /// </summary>
 | 
						||
        /// <param name="pds">数据集</param>
 | 
						||
        /// <param name="Cols">数据集行数</param>
 | 
						||
        /// <returns></returns>
 | 
						||
        private bool AddDatasetToSQL(DataTable pds, int Cols)
 | 
						||
        {
 | 
						||
            string result = string.Empty;
 | 
						||
            int ic, ir;
 | 
						||
            ic = pds.Columns.Count;
 | 
						||
            if (ic < Cols)
 | 
						||
            {
 | 
						||
                return false;
 | 
						||
            }
 | 
						||
 | 
						||
            ir = pds.Rows.Count;
 | 
						||
            if (pds != null && ir > 0)
 | 
						||
            {
 | 
						||
                var driverRunPlan = (from x in Funs.DB.DriverRun_DriverRunPlan
 | 
						||
                                     where x.ProjectId == this.CurrUser.LoginProjectId
 | 
						||
                                     select x).FirstOrDefault();
 | 
						||
                int usedDays = 0;
 | 
						||
                if (driverRunPlan != null)
 | 
						||
                {
 | 
						||
                    for (int i = 0; i < ir; i++)
 | 
						||
                    {
 | 
						||
                        string row34 = pds.Rows[i][34].ToString().Trim();
 | 
						||
                        if (!string.IsNullOrEmpty(row34))
 | 
						||
                        {
 | 
						||
                            usedDays += Funs.GetNewIntOrZero(row34);
 | 
						||
                        }
 | 
						||
                    }
 | 
						||
                    driverRunPlan.UsedDays -= usedDays;
 | 
						||
                    Funs.DB.SubmitChanges();
 | 
						||
                }
 | 
						||
            }
 | 
						||
            else
 | 
						||
            {
 | 
						||
 | 
						||
            }
 | 
						||
            return true;
 | 
						||
        }
 | 
						||
        #endregion
 | 
						||
        #endregion
 | 
						||
 | 
						||
        #region 保存按钮事件
 | 
						||
        /// <summary>
 | 
						||
        /// 保存按钮事件
 | 
						||
        /// </summary>
 | 
						||
        /// <param name="sender"></param>
 | 
						||
        /// <param name="e"></param>
 | 
						||
        protected void btnSave_Click(object sender, EventArgs e)
 | 
						||
        {
 | 
						||
            JArray source = GetSourceData();
 | 
						||
            if (!string.IsNullOrEmpty(source.ToString()))
 | 
						||
            {
 | 
						||
                string attachUrl = string.Empty;
 | 
						||
                for (int i = 0, count = source.Count; i < count; i++)
 | 
						||
                {
 | 
						||
                    JObject item = source[i] as JObject;
 | 
						||
                    if (!string.IsNullOrEmpty(item.Value<string>("folder")))
 | 
						||
                    {
 | 
						||
                        attachUrl += item.Value<string>("folder") + item.Value<string>("savedName") + ",";
 | 
						||
                    }
 | 
						||
                    else
 | 
						||
                    {
 | 
						||
                        attachUrl += AttachPath + "/" + DateTime.Now.ToString("yyyy-MM") + "/" + item.Value<string>("savedName") + ",";
 | 
						||
                    }
 | 
						||
                }
 | 
						||
                if (!string.IsNullOrEmpty(attachUrl))
 | 
						||
                {
 | 
						||
                    attachUrl = attachUrl.Substring(0, attachUrl.LastIndexOf(",")).Replace('\\', '/');
 | 
						||
                }
 | 
						||
                ///保存方法
 | 
						||
                this.SaveData(source.ToString(), attachUrl);
 | 
						||
                ShowNotify("保存成功!", MessageBoxIcon.Success);
 | 
						||
 | 
						||
                #region 统一人员资质上传功能2024-7-1
 | 
						||
                if (MenuId== BLL.Const.PersonListMenuId && Request.QueryString["strParam"]=="4")
 | 
						||
                {
 | 
						||
                    //如果是人员信息修改安全生产考核合格证书/特种作业操作证(同步 特种作业人员资质、安管人员资质)
 | 
						||
                    var personId = ToKeyId.Split('#')[0].ToString();
 | 
						||
                    var PersonQualityModel = Funs.DB.QualityAudit_PersonQuality.FirstOrDefault(x => x.PersonId == personId);
 | 
						||
                    if (PersonQualityModel!=null)
 | 
						||
                    {
 | 
						||
                        UploadFileService.SaveAttachUrl(source.ToString(), attachUrl, 
 | 
						||
                            BLL.Const.PersonQualityMenuId, PersonQualityModel.PersonQualityId);
 | 
						||
                    }
 | 
						||
 | 
						||
                    var SafePersonQualityModel = Funs.DB.QualityAudit_SafePersonQuality.FirstOrDefault(x => x.PersonId == personId);
 | 
						||
                    if (SafePersonQualityModel != null)
 | 
						||
                    {
 | 
						||
                        UploadFileService.SaveAttachUrl(source.ToString(), attachUrl,
 | 
						||
                            BLL.Const.SafePersonQualityMenuId, SafePersonQualityModel.SafePersonQualityId);
 | 
						||
                    }
 | 
						||
                }
 | 
						||
 | 
						||
                if (MenuId== BLL.Const.PersonQualityMenuId)
 | 
						||
                {
 | 
						||
                    var PersonQualityModel = Funs.DB.QualityAudit_PersonQuality.FirstOrDefault(x => x.PersonQualityId == ToKeyId);
 | 
						||
                    if (PersonQualityModel!=null)
 | 
						||
                    {
 | 
						||
                        var personId = PersonQualityModel.PersonId;
 | 
						||
 | 
						||
                        var SafePersonQualityModel = Funs.DB.QualityAudit_SafePersonQuality.FirstOrDefault(x => x.PersonId == personId);
 | 
						||
                        if (SafePersonQualityModel != null)
 | 
						||
                        {
 | 
						||
                            UploadFileService.SaveAttachUrl(source.ToString(), attachUrl,
 | 
						||
                                BLL.Const.SafePersonQualityMenuId, SafePersonQualityModel.SafePersonQualityId);
 | 
						||
                        }
 | 
						||
 | 
						||
                        var SitepersonModel = Funs.DB.SitePerson_Person.FirstOrDefault(x => x.PersonId == personId);
 | 
						||
                        if (SitepersonModel!=null)
 | 
						||
                        {
 | 
						||
                            UploadFileService.SaveAttachUrl(source.ToString(), attachUrl,
 | 
						||
                               BLL.Const.PersonListMenuId, SitepersonModel.PersonId+"#4");
 | 
						||
                        }
 | 
						||
                    }
 | 
						||
                }
 | 
						||
 | 
						||
                if (MenuId== BLL.Const.SafePersonQualityMenuId)
 | 
						||
                {
 | 
						||
                    var SafePersonQualityModel = Funs.DB.QualityAudit_SafePersonQuality.FirstOrDefault(x => x.SafePersonQualityId == ToKeyId);
 | 
						||
                    if (SafePersonQualityModel!=null)
 | 
						||
                    {
 | 
						||
                        var personId = SafePersonQualityModel.PersonId;
 | 
						||
                        var PersonQualityModel = Funs.DB.QualityAudit_PersonQuality.FirstOrDefault(x => x.PersonId == personId);
 | 
						||
                        if (PersonQualityModel != null)
 | 
						||
                        {
 | 
						||
                            UploadFileService.SaveAttachUrl(source.ToString(), attachUrl,
 | 
						||
                                BLL.Const.PersonQualityMenuId, PersonQualityModel.PersonQualityId);
 | 
						||
                        }
 | 
						||
 | 
						||
                        var SitepersonModel = Funs.DB.SitePerson_Person.FirstOrDefault(x => x.PersonId == personId);
 | 
						||
                        if (SitepersonModel != null)
 | 
						||
                        {
 | 
						||
                            UploadFileService.SaveAttachUrl(source.ToString(), attachUrl,
 | 
						||
                               BLL.Const.PersonListMenuId, SitepersonModel.PersonId + "#4");
 | 
						||
                        }
 | 
						||
 | 
						||
                    }
 | 
						||
                }
 | 
						||
                #endregion
 | 
						||
 | 
						||
                //#region PunchlistFrom附件保存成功后处理事件
 | 
						||
                //if (MenuId == BLL.Const.PunchlistFromMenuId)
 | 
						||
                //{
 | 
						||
                //    PageContext.RegisterStartupScript(ActiveWindow.GetHidePostBackReference());
 | 
						||
                //}
 | 
						||
                //#endregion
 | 
						||
 | 
						||
                PageContext.RegisterStartupScript(ActiveWindow.GetHidePostBackReference());
 | 
						||
            }
 | 
						||
        }
 | 
						||
        #endregion
 | 
						||
 | 
						||
        /// <summary>
 | 
						||
        ///  保存附件
 | 
						||
        /// </summary>
 | 
						||
        /// <param name="source"></param>
 | 
						||
        /// <param name="attachUrl"></param>
 | 
						||
        private void SaveData(string source, string attachUrl)
 | 
						||
        {
 | 
						||
            UploadFileService.SaveAttachUrl(source, attachUrl, MenuId, ToKeyId);
 | 
						||
        }
 | 
						||
 | 
						||
        /// <summary>
 | 
						||
        /// 扫描文件
 | 
						||
        /// </summary>
 | 
						||
        /// <param name="sender"></param>
 | 
						||
        /// <param name="e"></param>
 | 
						||
        protected void btnImageMagnify_Click(object sender, EventArgs e)
 | 
						||
        {
 | 
						||
            try
 | 
						||
            {
 | 
						||
                DeviceManager manager = new DeviceManagerClass();
 | 
						||
                Device device = null;
 | 
						||
                foreach (DeviceInfo info in manager.DeviceInfos)
 | 
						||
                {
 | 
						||
                    if (info.Type != WiaDeviceType.ScannerDeviceType)
 | 
						||
                        continue;
 | 
						||
                    device = info.Connect();
 | 
						||
                    break;
 | 
						||
                }
 | 
						||
                Item item = device.Items[1];
 | 
						||
                CommonDialogClass cdc = new WIA.CommonDialogClass();
 | 
						||
                ImageFile imageFile = null;
 | 
						||
                imageFile = cdc.ShowAcquireImage(WIA.WiaDeviceType.ScannerDeviceType,
 | 
						||
                                                 WIA.WiaImageIntent.TextIntent,
 | 
						||
                                                 WIA.WiaImageBias.MaximizeQuality,
 | 
						||
                                                 "{00000000-0000-0000-0000-000000000000}",
 | 
						||
                                                 true,
 | 
						||
                                                 true,
 | 
						||
                                                 false);
 | 
						||
                if (imageFile != null)
 | 
						||
                {
 | 
						||
                    var buffer = imageFile.FileData.get_BinaryData() as byte[];
 | 
						||
                    using (MemoryStream ms = new MemoryStream())
 | 
						||
                    {
 | 
						||
                        ms.Write(buffer, 0, buffer.Length);
 | 
						||
                        string filePath = Server.MapPath("~/") + AttachPath;  ///文件夹
 | 
						||
                        if (!Directory.Exists(filePath))
 | 
						||
                        {
 | 
						||
                            Directory.CreateDirectory(filePath);
 | 
						||
                        }
 | 
						||
                        string name = "\\";
 | 
						||
                        var menu = BLL.SysMenuService.GetSysMenuByMenuId(this.MenuId);
 | 
						||
                        if (menu != null)
 | 
						||
                        {
 | 
						||
                            name += menu.MenuName;
 | 
						||
 | 
						||
                        }
 | 
						||
                        name += Funs.GetNewFileName() + ".jpg";
 | 
						||
                        string url = filePath + name;
 | 
						||
                        if (!string.IsNullOrEmpty(url))
 | 
						||
                        {
 | 
						||
                            using (FileStream fs = new FileStream(url, FileMode.Create, FileAccess.Write))
 | 
						||
                            {
 | 
						||
                                ms.WriteTo(fs);
 | 
						||
                                string attachUrl = AttachPath + name;
 | 
						||
                                if (!string.IsNullOrEmpty(attachUrl))
 | 
						||
                                {
 | 
						||
                                    attachUrl = attachUrl.Replace('/', '\\');
 | 
						||
                                }
 | 
						||
                                string oldSrouce = string.Empty;
 | 
						||
                                string FullPath = string.Empty;
 | 
						||
                                Model.AttachFile att = Funs.DB.AttachFile.FirstOrDefault(x => x.ToKeyId == this.ToKeyId);
 | 
						||
                                if (att != null && !string.IsNullOrEmpty(att.AttachUrl))
 | 
						||
                                {
 | 
						||
                                    FullPath = att.AttachUrl + "," + attachUrl;
 | 
						||
                                    oldSrouce = att.AttachSource;
 | 
						||
                                }
 | 
						||
                                else
 | 
						||
                                {
 | 
						||
                                    FullPath = attachUrl;
 | 
						||
                                }
 | 
						||
                                string source = BLL.UploadFileService.GetSourceByAttachUrl(attachUrl, buffer.Length, oldSrouce);
 | 
						||
                                //this.SaveData(source, FullPath); ///保存方法
 | 
						||
                                Session[sessionName] = JArray.Parse(source);
 | 
						||
                            }
 | 
						||
 | 
						||
                            this.BindGrid();
 | 
						||
                            ShowNotify("扫描完成!", MessageBoxIcon.Success);
 | 
						||
 | 
						||
                        }
 | 
						||
                    }
 | 
						||
                }
 | 
						||
            }
 | 
						||
            catch
 | 
						||
            {
 | 
						||
                ShowNotify("请检查扫描仪是否连接正确!", MessageBoxIcon.Warning);
 | 
						||
            }
 | 
						||
        }
 | 
						||
 | 
						||
        #region 获取权限按钮
 | 
						||
        /// <summary>
 | 
						||
        /// 获取按钮权限
 | 
						||
        /// </summary>
 | 
						||
        /// <param name="button"></param>
 | 
						||
        /// <returns></returns>
 | 
						||
        private void GetButtonPower()
 | 
						||
        {
 | 
						||
            if (this.Type == "0")
 | 
						||
            {
 | 
						||
                this.toolBar.Hidden = false;
 | 
						||
            }
 | 
						||
            else if (this.Type == "-1")
 | 
						||
            {
 | 
						||
                this.toolBar.Hidden = true;
 | 
						||
            }
 | 
						||
            else if (this.Type == "-2")  //方案审核只保留文档编辑
 | 
						||
            {
 | 
						||
                this.toolBar.Hidden = false;
 | 
						||
                btnImageMagnify.Hidden = true;
 | 
						||
                btnSelectFiles.Hidden = true;
 | 
						||
                btnDelete.Hidden = true;
 | 
						||
                btnSave.Hidden = true;
 | 
						||
            }
 | 
						||
            else
 | 
						||
            {
 | 
						||
                if (this.CurrUser != null && this.MenuId != Const.ProjectPunishNoticeStatisticsMenuId)
 | 
						||
                {
 | 
						||
                    var buttonList = CommonService.GetAllButtonList(this.CurrUser.LoginProjectId, this.CurrUser.UserId, MenuId);
 | 
						||
                    if (buttonList.Count > 0)
 | 
						||
                    {
 | 
						||
                        if (buttonList.Contains(Const.BtnSave) || buttonList.Contains(Const.BtnAuditing))
 | 
						||
                        {
 | 
						||
                            this.toolBar.Hidden = false;
 | 
						||
                        }
 | 
						||
                    }
 | 
						||
                }
 | 
						||
            }
 | 
						||
        }
 | 
						||
        #endregion
 | 
						||
 | 
						||
        protected void btnPlay_Click(object sender, EventArgs e)
 | 
						||
        {
 | 
						||
 | 
						||
        }
 | 
						||
 | 
						||
        protected void btnOnlineEdit_OnClick(object sender, EventArgs e)
 | 
						||
        {
 | 
						||
            JArray source = GetSourceData();
 | 
						||
            for (int i = 0, count = source.Count; i < count; i++)
 | 
						||
            {
 | 
						||
                JObject item = source[i] as JObject;
 | 
						||
                if (item.Value<string>("id") == Grid1.SelectedRowID)
 | 
						||
                {
 | 
						||
                    try
 | 
						||
                    {
 | 
						||
                        string savedName = item.Value<string>("savedName");
 | 
						||
                        string folder = item.Value<string>("folder");
 | 
						||
                        string xnUrl = AttachPath + "\\" + savedName;
 | 
						||
                        if (!string.IsNullOrEmpty(folder))
 | 
						||
                        {
 | 
						||
                            xnUrl = folder + savedName;
 | 
						||
                        }
 | 
						||
 | 
						||
                        string url = Funs.RootPath + xnUrl;
 | 
						||
                        if (savedName.Contains("FileUpLoad"))
 | 
						||
                        {
 | 
						||
                            url = Funs.RootPath + savedName.Replace('/', '\\');
 | 
						||
                        }
 | 
						||
                        FileInfo info = new FileInfo(url);
 | 
						||
                        if (!info.Exists || string.IsNullOrEmpty(savedName))
 | 
						||
                        {
 | 
						||
                            url = Funs.RootPath + "Images//Null.jpg";
 | 
						||
                            info = new FileInfo(url);
 | 
						||
                        }
 | 
						||
                        var FiletExtension = Path.GetExtension(savedName);
 | 
						||
                        bool isSupportType = FiletExtension.Equals(".docx");
 | 
						||
                        if (isSupportType)
 | 
						||
                        {
 | 
						||
                            url = url.Replace(Funs.RootPath, "");
 | 
						||
                            var sysSet4 = (from x in Funs.DB.Sys_Const where x.ConstText == "IsUseLoaclService" select x).ToList().FirstOrDefault();
 | 
						||
                            if (sysSet4!=null&& sysSet4.ConstValue=="1")
 | 
						||
                            {
 | 
						||
                                PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("../AttachFile/OnlineEditingPrivate.aspx?fileUrl={0}&&editorMode={1}", url, editorMode, "编辑  -")));
 | 
						||
 | 
						||
                            }
 | 
						||
                            else
 | 
						||
                            {
 | 
						||
                                PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("../AttachFile/OnlineEditing.aspx?fileUrl={0}&&editorMode={1}", url, editorMode, "编辑  -")));
 | 
						||
 | 
						||
                            }
 | 
						||
                        }
 | 
						||
                        else
 | 
						||
                        {
 | 
						||
                            ShowNotify("不支持在线编辑", MessageBoxIcon.Warning);
 | 
						||
 | 
						||
                        }
 | 
						||
 | 
						||
                    }
 | 
						||
                    catch (Exception)
 | 
						||
                    {
 | 
						||
 | 
						||
                    }
 | 
						||
 | 
						||
                }
 | 
						||
            }
 | 
						||
        }
 | 
						||
 | 
						||
    }
 | 
						||
}
 |