858 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			858 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
// ========================================================================
 | 
						|
// Copyright 2006 - Volian Enterprises, Inc. All rights reserved.          
 | 
						|
// Volian Enterprises - Proprietary Information - DO NOT COPY OR DISTRIBUTE
 | 
						|
// ------------------------------------------------------------------------
 | 
						|
// $Workfile: $     $Revision: $                                           
 | 
						|
// $Author: $   $Date: $                                                   
 | 
						|
//                                                                         
 | 
						|
// $History: $                                                             
 | 
						|
// ========================================================================
 | 
						|
 | 
						|
using System;
 | 
						|
using System.Data;
 | 
						|
using System.Data.SqlClient;
 | 
						|
using Csla;
 | 
						|
using Csla.Data;
 | 
						|
using System.Configuration;
 | 
						|
using System.IO;
 | 
						|
using System.Xml;
 | 
						|
using System.Drawing;
 | 
						|
using System.ComponentModel;
 | 
						|
using System.Collections.Generic;
 | 
						|
using Volian.Base.Library;
 | 
						|
 | 
						|
namespace VEPROMS.CSLA.Library
 | 
						|
{
 | 
						|
	// B2018-078 Update Formats needs to include unused formats
 | 
						|
	[Serializable()]
 | 
						|
	public class CriteriaAllFormats
 | 
						|
	{
 | 
						|
		bool _AllFormats;
 | 
						|
		public bool AllFormats
 | 
						|
		{
 | 
						|
			get { return _AllFormats; }
 | 
						|
			set { _AllFormats = value; }
 | 
						|
		}
 | 
						|
		public CriteriaAllFormats(bool allFormats)
 | 
						|
		{
 | 
						|
			_AllFormats = allFormats;
 | 
						|
		}
 | 
						|
	}
 | 
						|
	public partial class Format
 | 
						|
	{
 | 
						|
		public static Format GetJustFormat(int formatID)
 | 
						|
		{
 | 
						|
			if (!CanGetObject())
 | 
						|
				throw new System.Security.SecurityException("User not authorized to view a Format");
 | 
						|
			try
 | 
						|
			{
 | 
						|
				Format tmp = GetCachedByPrimaryKey(formatID);
 | 
						|
				if (tmp == null)
 | 
						|
				{
 | 
						|
					tmp = DataPortal.Fetch<Format>(new PKCriteriaJustFormat(formatID));
 | 
						|
					AddToCache(tmp);
 | 
						|
				}
 | 
						|
				if (tmp.ErrorMessage == "No Record Found")
 | 
						|
				{
 | 
						|
					tmp.Dispose(); // Clean-up Format
 | 
						|
					tmp = null;
 | 
						|
				}
 | 
						|
				return tmp;
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				throw new DbCslaException("Error on Format.GetJustFormat", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
		[Serializable()]
 | 
						|
		protected class PKCriteriaJustFormat
 | 
						|
		{
 | 
						|
			private int _FormatID;
 | 
						|
			public int FormatID
 | 
						|
			{ get { return _FormatID; } }
 | 
						|
			public PKCriteriaJustFormat(int formatID)
 | 
						|
			{
 | 
						|
				_FormatID = formatID;
 | 
						|
			}
 | 
						|
		}
 | 
						|
		private void DataPortal_Fetch(PKCriteriaJustFormat criteria)
 | 
						|
		{
 | 
						|
			if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] Format.DataPortal_Fetch JustFormat", GetHashCode());
 | 
						|
			try
 | 
						|
			{
 | 
						|
				using (SqlConnection cn = Database.VEPROMS_SqlConnection)
 | 
						|
				{
 | 
						|
					ApplicationContext.LocalContext["cn"] = cn;
 | 
						|
					using (SqlCommand cm = cn.CreateCommand())
 | 
						|
					{
 | 
						|
						cm.CommandType = CommandType.StoredProcedure;
 | 
						|
						cm.CommandText = "getJustFormat";
 | 
						|
						cm.Parameters.AddWithValue("@FormatID", criteria.FormatID);
 | 
						|
						cm.CommandTimeout = Database.DefaultTimeout;
 | 
						|
						using (SafeDataReader dr = new SafeDataReader(cm.ExecuteReader()))
 | 
						|
						{
 | 
						|
							if (!dr.Read())
 | 
						|
							{
 | 
						|
								_ErrorMessage = "No Record Found";
 | 
						|
								return;
 | 
						|
							}
 | 
						|
							ReadData(dr);
 | 
						|
						}
 | 
						|
					}
 | 
						|
					// removing of item only needed for local data portal
 | 
						|
					if (ApplicationContext.ExecutionLocation == ApplicationContext.ExecutionLocations.Client)
 | 
						|
						ApplicationContext.LocalContext.Remove("cn");
 | 
						|
				}
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				if (_MyLog.IsErrorEnabled) _MyLog.Error("Format.DataPortal_Fetch JustFormat", ex);
 | 
						|
				_ErrorMessage = ex.Message;
 | 
						|
				throw new DbCslaException("Format.DataPortal_Fetch JustFormat", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
	}
 | 
						|
	public partial interface IFormatOrFormatInfo
 | 
						|
	{
 | 
						|
		PlantFormat PlantFormat { get;}
 | 
						|
		IFormatOrFormatInfo MyIParent { get;}
 | 
						|
		string Data { get; }
 | 
						|
		string ToString();
 | 
						|
		string FullName { get; }
 | 
						|
	}
 | 
						|
	public class FormatEventArgs
 | 
						|
	{
 | 
						|
		private string _Status;
 | 
						|
		public string Status
 | 
						|
		{
 | 
						|
			get { return _Status; }
 | 
						|
			set { _Status = value; }
 | 
						|
		}
 | 
						|
		public FormatEventArgs(string status)
 | 
						|
		{
 | 
						|
			_Status = status;
 | 
						|
		}
 | 
						|
	}
 | 
						|
	public delegate void FormatEvent(object sender,FormatEventArgs args);
 | 
						|
	public partial class Format:IFormatOrFormatInfo
 | 
						|
	{
 | 
						|
		#region PlantFormat
 | 
						|
		[NonSerialized]
 | 
						|
		private PlantFormat _PlantFormat;
 | 
						|
		public PlantFormat PlantFormat
 | 
						|
		{ get { return (_PlantFormat != null ? _PlantFormat : _PlantFormat = new PlantFormat(this, Config)); } }
 | 
						|
		#endregion
 | 
						|
		public static event FormatEvent FormatLoaded;
 | 
						|
		private static void OnFormatLoaded(object sender, FormatEventArgs args)
 | 
						|
		{
 | 
						|
			if (FormatLoaded != null)
 | 
						|
				FormatLoaded(sender, args);
 | 
						|
		}
 | 
						|
		public IFormatOrFormatInfo MyIParent { get { return MyParent; } }
 | 
						|
		public override string ToString()
 | 
						|
		{
 | 
						|
			//return Name;
 | 
						|
			//return PlantFormat.FormatData.Name;
 | 
						|
			return FullName;
 | 
						|
		}
 | 
						|
		public string FullName
 | 
						|
		{
 | 
						|
			get
 | 
						|
			{
 | 
						|
				if (ParentID == 1) return Description + " (" + Name + ")";
 | 
						|
				if (Description.StartsWith("*")) return Description.Substring(1) + " (" + Name + ")";
 | 
						|
				// C2019-029: if UCF, just use description & name, using parent is confusing
 | 
						|
				if (Config != null && Config != "") return Description + " (" + Name + ")";
 | 
						|
				return MyParent.Description + " - " + Description + " (" + Name + ")";
 | 
						|
			}
 | 
						|
		}
 | 
						|
		
 | 
						|
		public static void UpdateFormats(string fmtPath, string genmacPath)
 | 
						|
		{
 | 
						|
			Format basefmt = null;
 | 
						|
			Format parent = null;
 | 
						|
 | 
						|
 | 
						|
			// Load base format.
 | 
						|
			basefmt = AddFormatToDB(null, "base", false, DateTime.Now, "Migration", fmtPath, genmacPath);
 | 
						|
			if (basefmt == null) return;
 | 
						|
			// now loop through all files... If there is an _ in the name, it's a subformat
 | 
						|
			// (for example, AEP_00.xml) skip it in main loop, it's handled for each format. 
 | 
						|
			DirectoryInfo di = new DirectoryInfo(fmtPath); //(@"c:\development\fmtall");
 | 
						|
			FileInfo[] fis = di.GetFiles("*.xml");
 | 
						|
			OnFormatLoaded(null, new FormatEventArgs(fis.Length.ToString() + " Formats to Load"));
 | 
						|
			foreach (FileInfo fi in fis)
 | 
						|
			{
 | 
						|
				//if (fi.Name.ToUpper() == "WCN2ALL.XML"|| fi.Name.ToUpper() == "OHLPALL.XML")
 | 
						|
				//{
 | 
						|
				bool issub = (fi.Name.IndexOf("_") > 0) ? true : false;
 | 
						|
				if (!issub && fi.Name.ToLower() != "baseall.xml")
 | 
						|
				{
 | 
						|
					string fmtname = fi.Name.Substring(0, fi.Name.Length - 7);
 | 
						|
					// remove the all.xml part of the filename.
 | 
						|
					try
 | 
						|
					{
 | 
						|
						parent = AddFormatToDB(basefmt, fmtname, issub, DateTime.Now, "Migration", fmtPath, genmacPath);
 | 
						|
						if (parent != null)
 | 
						|
						{
 | 
						|
							// now see if there are any subformats associated with this, if so
 | 
						|
							// add them here... 
 | 
						|
							DirectoryInfo sdi = new DirectoryInfo(fmtPath); //("c:\\development\\fmtall");
 | 
						|
							FileInfo[] sfis = di.GetFiles(fmtname + "_*.xml");
 | 
						|
							foreach (FileInfo sfi in sfis)
 | 
						|
							{
 | 
						|
								string nm = sfi.Name.Substring(0, sfi.Name.Length - 7);
 | 
						|
								OnFormatLoaded(null, new FormatEventArgs("Loading SubFormat " + sfi.Name));
 | 
						|
								//Console.WriteLine("Processing {0}", sfi.Name);
 | 
						|
								//frmMain.Status = string.Format("Processing Format {0}", sfi.Name);
 | 
						|
								try
 | 
						|
								{
 | 
						|
									AddFormatToDB(parent, nm, true, DateTime.Now, "Migration",fmtPath,genmacPath);
 | 
						|
								}
 | 
						|
								catch (Exception ex)
 | 
						|
								{
 | 
						|
									//frmMain.AddError(ex, "LoadAllFormats() '{0}'", sfi.Name);
 | 
						|
									Console.WriteLine("{0} - {1}", ex.GetType().Name, ex.Message);
 | 
						|
								}
 | 
						|
							}
 | 
						|
						}
 | 
						|
					}
 | 
						|
					catch (Exception ex)
 | 
						|
					{
 | 
						|
						//frmMain.AddError(ex, "LoadAllFormats() '{0}'", fi.Name);
 | 
						|
						Console.WriteLine("{0} - {1}", ex.GetType().Name, ex.Message);
 | 
						|
					}
 | 
						|
				}
 | 
						|
				//}
 | 
						|
			}
 | 
						|
			OnFormatLoaded(null, new FormatEventArgs("Formats Updated"));
 | 
						|
 | 
						|
			//C2025-023 - Electronic Procedures - Modifications to PROMS
 | 
						|
			//Begin section for processing Electronic Procedure (EP) Format Files
 | 
						|
			// now loop through all EP format files
 | 
						|
			string epPath = fmtPath.Replace("\\fmtall", "\\epall");
 | 
						|
			DirectoryInfo diEP = new DirectoryInfo(epPath);
 | 
						|
			if (diEP.Exists)
 | 
						|
			{
 | 
						|
				FileInfo[] fisEP = diEP.GetFiles("*.xml");
 | 
						|
				OnFormatLoaded(null, new FormatEventArgs(fisEP.Length.ToString() + " EP Formats to Load"));
 | 
						|
				foreach (FileInfo fi in fisEP)
 | 
						|
				{
 | 
						|
					string fmtname = Path.GetFileNameWithoutExtension(fi.Name);
 | 
						|
					try
 | 
						|
					{
 | 
						|
						AddEPFormatToDB(fmtname, DateTime.Now, VlnSettings.UserID, epPath);
 | 
						|
					}
 | 
						|
					catch (Exception ex)
 | 
						|
					{
 | 
						|
						Console.WriteLine("{0} - {1}", ex.GetType().Name, ex.Message);
 | 
						|
					}
 | 
						|
				}
 | 
						|
				OnFormatLoaded(null, new FormatEventArgs("EP Formats Updated"));
 | 
						|
 | 
						|
				// update all in-use annotation types that have Electronic Procedures
 | 
						|
				EPFormatFile.UpdateAllInUseEPAnnotationTypes();
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
		private static Dictionary<string, int> _LookupFormats;
 | 
						|
		public static Dictionary<string, int> LookupFormats
 | 
						|
		{
 | 
						|
			get
 | 
						|
			{
 | 
						|
				if (_LookupFormats == null)
 | 
						|
				{
 | 
						|
					_LookupFormats = new Dictionary<string, int>();
 | 
						|
					FormatInfoList allFormats = FormatInfoList.GetAll(); // B2018-078 Update Formats needs to include unused formats
 | 
						|
					foreach (FormatInfo myFormat in allFormats)
 | 
						|
					{
 | 
						|
						_LookupFormats.Add(myFormat.Name.ToUpper(), myFormat.FormatID);
 | 
						|
					}
 | 
						|
				}
 | 
						|
				return _LookupFormats;
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		private static Format AddFormatToDB(Format parent, string format, bool issub, DateTime Dts, string Userid, string fmtPath, string genmacPath)
 | 
						|
		{
 | 
						|
			string fmtdata = null;
 | 
						|
			FileInfo fmtfi = null;
 | 
						|
			string genmacdata = null;
 | 
						|
			XmlDocument xd = null;
 | 
						|
 | 
						|
			OnFormatLoaded(null, new FormatEventArgs("Loading Format "+format));
 | 
						|
			//string path = "c:\\development\\fmtall\\" + format + "all.xml";
 | 
						|
			string path = fmtPath + "\\" + format + "all.xml";
 | 
						|
			if (File.Exists(path))
 | 
						|
			{
 | 
						|
				try
 | 
						|
				{
 | 
						|
					StreamReader srf = new StreamReader(path);
 | 
						|
					fmtfi = new FileInfo(path);
 | 
						|
					xd = new XmlDocument();
 | 
						|
					xd.Load(srf);
 | 
						|
					//xd.Load(path);
 | 
						|
					fmtdata = xd.OuterXml;
 | 
						|
				}
 | 
						|
				catch (Exception ex)
 | 
						|
				{
 | 
						|
					OnFormatLoaded(null, new FormatEventArgs("Error Loading Format " + format));
 | 
						|
					_MyLog.ErrorFormat("AddFormatToDB('{0}','{1}')", (parent == null)?"Base": parent.Name, path);
 | 
						|
					return null;
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			// Do we need genmac - only if non-subformat
 | 
						|
			if (!issub)
 | 
						|
			{
 | 
						|
				//path = "c:\\development\\genmacall\\" + format + ".svg";
 | 
						|
				path = genmacPath + "\\" + format + ".svg";
 | 
						|
				if (File.Exists(path))
 | 
						|
				{
 | 
						|
					try
 | 
						|
					{
 | 
						|
						StreamReader sr = new StreamReader(path);
 | 
						|
						XmlDocument xdg = new XmlDocument();
 | 
						|
						xdg.Load(sr);
 | 
						|
						//xdg.Load(path);
 | 
						|
						genmacdata = xdg.OuterXml;
 | 
						|
					}
 | 
						|
					catch (Exception ex)
 | 
						|
					{
 | 
						|
						//frmMain.AddError(ex, "AddFormatToDB('{0}','{1}')", parent.Name, path);
 | 
						|
						_MyLog.ErrorFormat("AddFormatToDB('{0}','{1}')", parent.Name, path);
 | 
						|
						return null;
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
			// Get the name & then create the record.
 | 
						|
			if (Userid == null || Userid == "") Userid = "Migration";
 | 
						|
 | 
						|
			string nmattr = "Default";
 | 
						|
 | 
						|
			// use xpath to get name.
 | 
						|
			if (parent != null)
 | 
						|
			{
 | 
						|
				XmlNode nmnode = xd.SelectSingleNode("//FormatData");
 | 
						|
				if (nmnode is XmlElement)
 | 
						|
				{
 | 
						|
					XmlElement xm = (XmlElement)nmnode;
 | 
						|
					nmattr = xm.GetAttribute("Name");
 | 
						|
				}
 | 
						|
			}
 | 
						|
			// use the format name if base or non sub.  If it's a sub, remove the "_".
 | 
						|
			string fname = issub ? format.Replace("_", "") : format;
 | 
						|
			Format rec = null;
 | 
						|
			try
 | 
						|
			{
 | 
						|
				if (!LookupFormats.ContainsKey(fname.ToUpper()))
 | 
						|
				{
 | 
						|
						rec = Format.MakeFormat(parent, fname, nmattr, fmtdata, genmacdata, fmtfi.LastWriteTimeUtc, Userid);
 | 
						|
					}
 | 
						|
				else
 | 
						|
				{
 | 
						|
					rec = Format.Get(LookupFormats[fname.ToUpper()]);
 | 
						|
					rec.Data = fmtdata;
 | 
						|
					rec.GenMac = genmacdata;
 | 
						|
					rec.DTS = fmtfi.LastWriteTimeUtc;
 | 
						|
					rec.Description = nmattr;
 | 
						|
					rec = rec.Save();
 | 
						|
				}
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				//frmMain.AddError(ex, "AddFormatToDB-make format('{0}','{1}')", parent.Name, path);
 | 
						|
			}
 | 
						|
			return rec;
 | 
						|
		}
 | 
						|
 | 
						|
		//C2025-023 - Electronic Procedures - Modifications to PROMS
 | 
						|
		//Procedure to load the EP format fiels into the DB
 | 
						|
		private static void AddEPFormatToDB(string formatname, DateTime Dts, string Userid, string epPath)
 | 
						|
		{
 | 
						|
			string fmtdata = null;
 | 
						|
			FileInfo fmtfi = null;
 | 
						|
			XmlDocument xd = null;
 | 
						|
 | 
						|
			OnFormatLoaded(null, new FormatEventArgs("Loading Format " + formatname));
 | 
						|
 | 
						|
			string path = Path.Combine(epPath, formatname + ".xml");
 | 
						|
			if (File.Exists(path))
 | 
						|
			{
 | 
						|
				try
 | 
						|
				{
 | 
						|
					using (StreamReader srf = new StreamReader(path))
 | 
						|
                    {
 | 
						|
						fmtfi = new FileInfo(path);
 | 
						|
						xd = new XmlDocument();
 | 
						|
						xd.XmlResolver = null;
 | 
						|
						xd.Load(srf);
 | 
						|
						fmtdata = xd.OuterXml;
 | 
						|
					}
 | 
						|
				}
 | 
						|
				catch (Exception ex)
 | 
						|
				{
 | 
						|
					OnFormatLoaded(null, new FormatEventArgs("Error Loading Format " + formatname));
 | 
						|
					_MyLog.ErrorFormat($"AddEPFormatToDB('{path}')");
 | 
						|
					return;
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			if (string.IsNullOrEmpty(Userid)) Userid = "Migration";
 | 
						|
 | 
						|
			try
 | 
						|
			{
 | 
						|
				EPFormatFile.UpdateEPFormat(formatname, fmtdata, Userid);
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				_MyLog.ErrorFormat($"AddFormatToDB-make format('{path}')");
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
public partial class FormatInfo : IFormatOrFormatInfo
 | 
						|
	{
 | 
						|
		//transition report stuff
 | 
						|
		private static Dictionary<int, string> _TransitionTypes;
 | 
						|
		public static Dictionary<int, string> GetTransitionTypesByFormatID(int formatID)
 | 
						|
		{
 | 
						|
			try
 | 
						|
			{
 | 
						|
				DataPortal.Fetch(new FormatIDCriteria(formatID));
 | 
						|
				return _TransitionTypes;
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				throw new DbCslaException("Error on FormatInfo.GetTransitionTypesByFormatID", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
		[Serializable()]
 | 
						|
		private class FormatIDCriteria
 | 
						|
		{
 | 
						|
			private int _FormatID;
 | 
						|
			public int FormatID { get { return _FormatID; } }
 | 
						|
			public FormatIDCriteria(int formatID)
 | 
						|
			{
 | 
						|
				_FormatID = formatID;
 | 
						|
			}
 | 
						|
		}
 | 
						|
		private void DataPortal_Fetch(FormatIDCriteria criteria)
 | 
						|
		{
 | 
						|
			if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] TransitionInfoList.DataPortal_Fetch", GetHashCode());
 | 
						|
			try
 | 
						|
			{
 | 
						|
				using (SqlConnection cn = Database.VEPROMS_SqlConnection)
 | 
						|
				{
 | 
						|
					using (SqlCommand cm = cn.CreateCommand())
 | 
						|
					{
 | 
						|
						cm.CommandType = CommandType.StoredProcedure;
 | 
						|
						cm.CommandText = "vesp_GetTranTypesByFormatID";
 | 
						|
						cm.Parameters.AddWithValue("@FormatID", criteria.FormatID);
 | 
						|
						cm.CommandTimeout = Database.DefaultTimeout;
 | 
						|
						using (SafeDataReader dr = new SafeDataReader(cm.ExecuteReader()))
 | 
						|
						{
 | 
						|
							_TransitionTypes = new Dictionary<int, string>();
 | 
						|
							while (dr.Read())
 | 
						|
							{
 | 
						|
								_TransitionTypes.Add(dr.GetInt32(0), dr.GetString(1));
 | 
						|
							}
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				if (_MyLog.IsErrorEnabled) _MyLog.Error("FormatInfo.DataPortal_Fetch", ex);
 | 
						|
				throw new DbCslaException("FormatInfo.DataPortal_Fetch", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
		//end transition report stuff
 | 
						|
		public virtual Format GetJustFormat()
 | 
						|
		{
 | 
						|
			return _Editable = Format.GetJustFormat(_FormatID);
 | 
						|
		}
 | 
						|
		public static bool HasLatestChanges()
 | 
						|
		{
 | 
						|
			if (!HasSeqTabFmtTabToken()) return false;
 | 
						|
			return true;
 | 
						|
		}
 | 
						|
		private static bool HasSeqTabFmtTabToken()
 | 
						|
		{
 | 
						|
			using (FormatInfo fi = FormatInfo.Get("WCN2"))
 | 
						|
			{
 | 
						|
				XmlDocument xd = new XmlDocument();
 | 
						|
				xd.LoadXml(fi.Data);
 | 
						|
				XmlNodeList xl = xd.SelectNodes("//FormatData/SectData/StepSectionData/SequentialTabFormat/SeqTabFmt/@TabToken");//"//DocStyle/Layout/@TopMargin");
 | 
						|
				if (xl.Count == 0)
 | 
						|
				{
 | 
						|
					System.Windows.Forms.MessageBox.Show("FormatData SeqTab/TabToken is missing", "Inconsistent Format Files", System.Windows.Forms.MessageBoxButtons.OK, System.Windows.Forms.MessageBoxIcon.Error);
 | 
						|
					return false;
 | 
						|
				}
 | 
						|
				return true;
 | 
						|
			}
 | 
						|
		}
 | 
						|
		// return the base PROMS format (BASEall.xml)
 | 
						|
		// this was but in for bug fix B2014-057 so that we can get to the symbol list when no DocVersion is selected (Search All Procedure Sets)
 | 
						|
		private static PlantFormat _PROMSBaseFormat = null;
 | 
						|
		public static PlantFormat PROMSBaseFormat
 | 
						|
		{
 | 
						|
			get 
 | 
						|
			{ 
 | 
						|
				if (_PROMSBaseFormat == null)
 | 
						|
				{
 | 
						|
					_PROMSBaseFormat = FormatList.ToFormat("Default (base)").PlantFormat;
 | 
						|
				}
 | 
						|
				return _PROMSBaseFormat; 
 | 
						|
			}
 | 
						|
		}
 | 
						|
		public static FormatInfo Get(string name)
 | 
						|
		{
 | 
						|
			try
 | 
						|
			{
 | 
						|
				FormatInfo tmp = DataPortal.Fetch<FormatInfo>(new NameCriteria(name));
 | 
						|
				//AddToCache(tmp);
 | 
						|
				if (tmp.ErrorMessage == "No Record Found")
 | 
						|
				{
 | 
						|
					tmp.Dispose(); // Clean-up FormatInfo
 | 
						|
					tmp = null;
 | 
						|
				}
 | 
						|
				return tmp;
 | 
						|
			}
 | 
						|
			catch (Exception ex1)
 | 
						|
			{
 | 
						|
				Exception ex = ex1;
 | 
						|
				while (ex.InnerException != null)
 | 
						|
					ex = ex.InnerException;
 | 
						|
				if (ex.Message.StartsWith("Could not find stored procedure"))
 | 
						|
				{
 | 
						|
					int formatID = 0;
 | 
						|
					using (FormatInfoList fil = FormatInfoList.Get())
 | 
						|
					{
 | 
						|
						foreach (FormatInfo fi in fil)
 | 
						|
						{
 | 
						|
							if (fi.Name == name)
 | 
						|
							{
 | 
						|
								formatID = fi.FormatID;
 | 
						|
								break;
 | 
						|
							}
 | 
						|
						}
 | 
						|
					}
 | 
						|
					if (formatID != 0) return FormatInfo.Get(formatID);
 | 
						|
					throw new DbCslaException("Format not found " + name, ex);
 | 
						|
				}
 | 
						|
				else
 | 
						|
					throw new DbCslaException("Error on FormatInfo.Get By Name", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
		protected class NameCriteria
 | 
						|
		{
 | 
						|
			private string _Name;
 | 
						|
			public string Name
 | 
						|
			{ get { return _Name; } }
 | 
						|
			public NameCriteria(string name)
 | 
						|
			{
 | 
						|
				_Name = name;
 | 
						|
			}
 | 
						|
		}
 | 
						|
		private void DataPortal_Fetch(NameCriteria criteria)
 | 
						|
		{
 | 
						|
			if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] FormatInfo.DataPortal_Fetch", GetHashCode());
 | 
						|
			try
 | 
						|
			{
 | 
						|
				using (SqlConnection cn = Database.VEPROMS_SqlConnection)
 | 
						|
				{
 | 
						|
					ApplicationContext.LocalContext["cn"] = cn;
 | 
						|
					using (SqlCommand cm = cn.CreateCommand())
 | 
						|
					{
 | 
						|
						cm.CommandType = CommandType.StoredProcedure;
 | 
						|
						cm.CommandText = "getFormatByName";
 | 
						|
						cm.Parameters.AddWithValue("@Name", criteria.Name);
 | 
						|
						cm.CommandTimeout = Database.DefaultTimeout;
 | 
						|
						using (SafeDataReader dr = new SafeDataReader(cm.ExecuteReader()))
 | 
						|
						{
 | 
						|
							if (!dr.Read())
 | 
						|
							{
 | 
						|
								_ErrorMessage = "No Record Found";
 | 
						|
								return;
 | 
						|
							}
 | 
						|
							ReadData(dr);
 | 
						|
						}
 | 
						|
					}
 | 
						|
					// removing of item only needed for local data portal
 | 
						|
					if (ApplicationContext.ExecutionLocation == ApplicationContext.ExecutionLocations.Client)
 | 
						|
						ApplicationContext.LocalContext.Remove("cn");
 | 
						|
				}
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				if (_MyLog.IsErrorEnabled) _MyLog.Error("FormatInfo.DataPortal_Fetch", ex);
 | 
						|
				_ErrorMessage = ex.Message;
 | 
						|
				throw new DbCslaException("FormatInfo.DataPortal_Fetch", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
        // Get format data, but do not resolve the 'Data' and 'Genmac' fields, i.e. keep empty if they are
 | 
						|
        // empty.
 | 
						|
        public static FormatInfo GetFormatNoUCFByFormatID(int formatID)
 | 
						|
        {
 | 
						|
            try
 | 
						|
            {
 | 
						|
                FormatInfo tmp = DataPortal.Fetch<FormatInfo>(new FormatIDNoUCFCriteria(formatID));
 | 
						|
                if (tmp.ErrorMessage == "No Record Found")
 | 
						|
                {
 | 
						|
                    tmp.Dispose(); // Clean-up FormatInfo
 | 
						|
                    tmp = null;
 | 
						|
                }
 | 
						|
                return tmp;
 | 
						|
            }
 | 
						|
            catch (Exception ex)
 | 
						|
            {
 | 
						|
                throw new DbCslaException("Error on FormatInfo.GetFormatNoUCFByFormatID", ex);
 | 
						|
            }
 | 
						|
        }
 | 
						|
        protected class FormatIDNoUCFCriteria
 | 
						|
        {
 | 
						|
            private int _FormatID;
 | 
						|
            public int FormatID { get { return _FormatID; } }
 | 
						|
            public FormatIDNoUCFCriteria(int formatID)
 | 
						|
            {
 | 
						|
                _FormatID = formatID;
 | 
						|
            }
 | 
						|
        }
 | 
						|
        private void DataPortal_Fetch(FormatIDNoUCFCriteria criteria)
 | 
						|
        {
 | 
						|
            if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] FormatInfo.DataPortal_Fetch", GetHashCode());
 | 
						|
            try
 | 
						|
            {
 | 
						|
                using (SqlConnection cn = Database.VEPROMS_SqlConnection)
 | 
						|
                {
 | 
						|
                    ApplicationContext.LocalContext["cn"] = cn;
 | 
						|
                    using (SqlCommand cm = cn.CreateCommand())
 | 
						|
                    {
 | 
						|
                        cm.CommandType = CommandType.StoredProcedure;
 | 
						|
                        cm.CommandText = "getFormatNoUCF";
 | 
						|
                        cm.Parameters.AddWithValue("@FormatID", criteria.FormatID);
 | 
						|
                        cm.CommandTimeout = Database.DefaultTimeout;
 | 
						|
                        using (SafeDataReader dr = new SafeDataReader(cm.ExecuteReader()))
 | 
						|
                        {
 | 
						|
                            if (!dr.Read())
 | 
						|
                            {
 | 
						|
                                _ErrorMessage = "No Record Found";
 | 
						|
                                return;
 | 
						|
                            }
 | 
						|
                            ReadData(dr);
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                    // removing of item only needed for local data portal
 | 
						|
                    if (ApplicationContext.ExecutionLocation == ApplicationContext.ExecutionLocations.Client)
 | 
						|
                        ApplicationContext.LocalContext.Remove("cn");
 | 
						|
                }
 | 
						|
            }
 | 
						|
            catch (Exception ex)
 | 
						|
            {
 | 
						|
                if (_MyLog.IsErrorEnabled) _MyLog.Error("FormatInfo.DataPortal_Fetch", ex);
 | 
						|
                _ErrorMessage = ex.Message;
 | 
						|
                throw new DbCslaException("FormatInfo.DataPortal_Fetch", ex);
 | 
						|
            }
 | 
						|
        }
 | 
						|
		#region PlantFormat
 | 
						|
		[NonSerialized]
 | 
						|
		private PlantFormat _PlantFormat;
 | 
						|
		public PlantFormat PlantFormat
 | 
						|
		{ get { return (_PlantFormat != null ? _PlantFormat : _PlantFormat = new PlantFormat(this, Config)); } }
 | 
						|
		#endregion
 | 
						|
		public IFormatOrFormatInfo MyIParent { get { return MyParent; } }
 | 
						|
		public override string ToString()
 | 
						|
		{
 | 
						|
			//return Name;
 | 
						|
			//return PlantFormat.FormatData.Name;
 | 
						|
			return FullName;
 | 
						|
		}
 | 
						|
		public string FullName
 | 
						|
		{
 | 
						|
			get
 | 
						|
			{
 | 
						|
				if (ParentID == 1) return Description + " (" + Name + ")";
 | 
						|
				if (Description.StartsWith("*")) return Description.Substring(1) + " (" + Name + ")";
 | 
						|
				// C2019-029: if UCF, just use description & name, using parent is confusing
 | 
						|
				if (Config != null && Config != "") return Description + " (" + Name + ")";	
 | 
						|
				return MyParent.Description + " - " + Description + " (" + Name + ")";
 | 
						|
			}
 | 
						|
		}
 | 
						|
		public StepSectionLayoutData MyStepSectionLayoutData
 | 
						|
		{
 | 
						|
			get { return PlantFormat.FormatData.SectData.StepSectionData.StepSectionLayoutData; }
 | 
						|
		}
 | 
						|
		public StepSectionPrintData MyStepSectionPrintData
 | 
						|
		{
 | 
						|
			get { return PlantFormat.FormatData.SectData.StepSectionData.StepSectionPrintData; }
 | 
						|
		}
 | 
						|
	}
 | 
						|
	public partial class FormatInfoList
 | 
						|
	{
 | 
						|
		/// <summary>
 | 
						|
		/// B2018-078 Return a list of all FormatInfo Including Unused.
 | 
						|
		/// </summary>
 | 
						|
		public static FormatInfoList GetAll()
 | 
						|
		{
 | 
						|
			try
 | 
						|
			{
 | 
						|
				FormatInfoList tmp = DataPortal.Fetch<FormatInfoList>(new CriteriaAllFormats(true));
 | 
						|
				return tmp;
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				throw new DbCslaException("Error on FormatInfoList.GetAll", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
		private void DataPortal_Fetch(CriteriaAllFormats myCrit)
 | 
						|
		{
 | 
						|
			this.RaiseListChangedEvents = false;
 | 
						|
			if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] FormatInfoList.DataPortal_Fetch", GetHashCode());
 | 
						|
			try
 | 
						|
			{
 | 
						|
				using (SqlConnection cn = Database.VEPROMS_SqlConnection)
 | 
						|
				{
 | 
						|
					using (SqlCommand cm = cn.CreateCommand())
 | 
						|
					{
 | 
						|
						cm.CommandType = CommandType.StoredProcedure;
 | 
						|
						cm.CommandText = "getAllFormats";
 | 
						|
						cm.CommandTimeout = Database.DefaultTimeout;
 | 
						|
						using (SafeDataReader dr = new SafeDataReader(cm.ExecuteReader()))
 | 
						|
						{
 | 
						|
							IsReadOnly = false;
 | 
						|
							while (dr.Read()) this.Add(new FormatInfo(dr));
 | 
						|
							IsReadOnly = true;
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				if (_MyLog.IsErrorEnabled) _MyLog.Error("FormatInfoList.DataPortal_Fetch", ex);
 | 
						|
				throw new DbCslaException("FormatInfoList.DataPortal_Fetch", ex);
 | 
						|
			}
 | 
						|
			this.RaiseListChangedEvents = true;
 | 
						|
		}
 | 
						|
 | 
						|
		private static Csla.SortedBindingList<FormatInfo> _SortedFormatInfoList;
 | 
						|
		public static Csla.SortedBindingList<FormatInfo> SortedFormatInfoList
 | 
						|
		{
 | 
						|
			get
 | 
						|
			{
 | 
						|
				if (_SortedFormatInfoList == null)
 | 
						|
				{
 | 
						|
					_SortedFormatInfoList = new SortedBindingList<FormatInfo>(FormatInfoList.Get());
 | 
						|
					_SortedFormatInfoList.ApplySort("FullName", ListSortDirection.Ascending);
 | 
						|
				}
 | 
						|
				return _SortedFormatInfoList;
 | 
						|
			}
 | 
						|
		}
 | 
						|
		public static FormatInfoList GetFormatInfoListUsed()
 | 
						|
		{
 | 
						|
			try
 | 
						|
			{
 | 
						|
				FormatInfoList fvl = (FormatInfoList)DataPortal.Fetch(new FormatInfoListUsedCriteria());
 | 
						|
				return fvl;
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				throw new DbCslaException("FormatVersionList.DataPortal_Fetch GetFormatVersions", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
		protected class FormatInfoListUsedCriteria
 | 
						|
		{
 | 
						|
		}
 | 
						|
		private void DataPortal_Fetch(FormatInfoListUsedCriteria criteria)
 | 
						|
		{
 | 
						|
			try
 | 
						|
			{
 | 
						|
				using (SqlConnection cn = Database.VEPROMS_SqlConnection)
 | 
						|
				{
 | 
						|
					using (SqlCommand cm = cn.CreateCommand())
 | 
						|
					{
 | 
						|
						cm.CommandType = CommandType.StoredProcedure;
 | 
						|
						cm.CommandText = "getFormatListUsed";
 | 
						|
						cm.CommandTimeout = Database.DefaultTimeout;
 | 
						|
						using (SafeDataReader dr = new SafeDataReader(cm.ExecuteReader()))
 | 
						|
						{
 | 
						|
							while (dr.Read())
 | 
						|
							{
 | 
						|
								FormatInfo formatInfo = new FormatInfo(dr);
 | 
						|
								IsReadOnly = false;
 | 
						|
								this.Add(formatInfo);
 | 
						|
								IsReadOnly = true;
 | 
						|
							}
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				Database.LogException("FormatInfoList.DataPortal_Fetch", ex);
 | 
						|
				throw new DbCslaException("FormatInfoList.DataPortal_Fetch", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
	public class FormatVersion
 | 
						|
	{
 | 
						|
		private string _Title;
 | 
						|
		public string Title { get { return _Title; } }
 | 
						|
		private int _FormatID;
 | 
						|
		public int FormatID { get { return _FormatID; } }
 | 
						|
		private int _VersionID;
 | 
						|
		public int VersionID { get { return _VersionID; } }
 | 
						|
		public FormatVersion(string title, int formatID, int versionID)
 | 
						|
		{
 | 
						|
			_Title = title;
 | 
						|
			_FormatID = formatID;
 | 
						|
			_VersionID = versionID;
 | 
						|
		}
 | 
						|
	}
 | 
						|
	public class FormatVersionList : List<FormatVersion>
 | 
						|
	{
 | 
						|
		public static FormatVersionList GetFormatVersions()
 | 
						|
		{
 | 
						|
			try
 | 
						|
			{
 | 
						|
				FormatVersionList fvl = DataPortal.Fetch<FormatVersionList>();
 | 
						|
				return fvl;
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				throw new DbCslaException("FormatVersionList.DataPortal_Fetch GetFormatVersions", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
		private void DataPortal_Fetch()
 | 
						|
		{
 | 
						|
			try
 | 
						|
			{
 | 
						|
				using (SqlConnection cn = Database.VEPROMS_SqlConnection)
 | 
						|
				{
 | 
						|
					using (SqlCommand cm = cn.CreateCommand())
 | 
						|
					{
 | 
						|
						cm.CommandType = CommandType.StoredProcedure;
 | 
						|
						cm.CommandText = "vesp_GetFormatVersions";
 | 
						|
						cm.CommandTimeout = Database.DefaultTimeout;
 | 
						|
						using (SafeDataReader dr = new SafeDataReader(cm.ExecuteReader()))
 | 
						|
						{
 | 
						|
							while (dr.Read())
 | 
						|
							{
 | 
						|
								this.Add(new FormatVersion(dr.GetString(0), dr.GetInt32(1), dr.GetInt32(2)));
 | 
						|
							}
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				Database.LogException("FormatVersionList.DataPortal_Fetch", ex);
 | 
						|
				throw new DbCslaException("FormatVersionList.DataPortal_Fetch", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 |