using System; using System.Collections.Generic; using System.Text; using System.IO; using Csla; using Csla.Data; using System.Data; using System.Data.SqlClient; //----------------- using System.Drawing; using System.Text.RegularExpressions; using LBWordLibrary; using System.Drawing.Imaging; using Volian.Base.Library; using System.Diagnostics; namespace VEPROMS.CSLA.Library { public partial class Document { public string DocumentTitle { get { if (_LibTitle == "") return string.Format("Document {0}", _DocID); return _LibTitle; } } public void UpdateDRoUsages(List roids) { if (DocumentDROUsageCount > 0) { foreach (DocumentDROUsage myUsage in DocumentDROUsages) { string roidkey = string.Format("{0}:{1}", myUsage.RODbID, myUsage.ROID); if (roids.Contains(roidkey)) roids.Remove(roidkey);// If in both, nothing to do else myUsage.Delete(); // If only in old, remove it } } foreach (string roidkey in roids) { string [] parts = roidkey.Split(":".ToCharArray()); DocumentDROUsages.Add(parts[1], RODb.Get(int.Parse(parts[0]))); } } /// /// FixString processes the string returned and changes any symbols (0xF0??) to normal characters /// /// /// //private static string FixString(string str) //{ // StringBuilder results = new StringBuilder(); // foreach (char c in str) // { // if ((c & 0xFF00) == 0xF000) // results.Append((char)(c & 0xFF)); // else // results.Append((char)(c)); // } // return results.ToString(); //} } public partial class DocumentInfo { public string DocumentTitle { get { if (_LibTitle == "") return string.Format("Document {0}", _DocID); return _LibTitle; } } public string LibraryDocumentUsage { get { StringBuilder sb = new StringBuilder(); string sep = "\r\nUsed In:\r\n "; if (DocumentEntries == null) sb.Append("None"); else { foreach (EntryInfo myEntry in DocumentEntries) { foreach (ItemInfo myItem in myEntry.MyContent.ContentItems) { ItemInfo proc = myItem.MyProcedure; sb.Append(sep + proc.DisplayNumber + " - " + proc.DisplayText); sep = "\r\n "; } } } return sb.ToString(); } } public ItemInfoList LibraryDocumentUsageList { get { bool first = true; ItemInfoList iil = null; if (DocumentEntries == null) return null; foreach (EntryInfo myEntry in DocumentEntries) { foreach (ItemInfo myitem in myEntry.MyContent.ContentItems) { if (first) { iil = new ItemInfoList(myitem); first = false; } else iil.AddItem(myitem); } } return iil; } } #region DocumentConfig [NonSerialized] private DocumentConfig _DocumentConfig; public DocumentConfig DocumentConfig { get { return (_DocumentConfig != null ? _DocumentConfig : _DocumentConfig = new DocumentConfig(this)); } } public void RefreshConfig() { _DocumentConfig = null; } #endregion } public partial class DocumentInfoList { public static DocumentInfoList GetLibraries(bool forceload) { try { if (!forceload && _DocumentInfoList != null) return _DocumentInfoList; DocumentInfoList tmp = DataPortal.Fetch(new LibraryCriteria(true)); DocumentInfo.AddList(tmp); tmp.AddEvents(); _DocumentInfoList = tmp; return tmp; } catch (Exception ex) { throw new DbCslaException("Error on DocumentInfoList.Get", ex); } } [Serializable()] protected class LibraryCriteria { private bool _IsLibrary; public bool IsLibrary { get { return _IsLibrary; } set { _IsLibrary = value; } } public LibraryCriteria(bool islibrary) { _IsLibrary = islibrary; } } private void DataPortal_Fetch(LibraryCriteria criteria) { this.RaiseListChangedEvents = false; if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] DocumentInfoList.DataPortal_Fetch", GetHashCode()); try { using (SqlConnection cn = Database.VEPROMS_SqlConnection) { using (SqlCommand cm = cn.CreateCommand()) { cm.CommandType = CommandType.StoredProcedure; cm.CommandText = "getLibraryDocuments"; using (SafeDataReader dr = new SafeDataReader(cm.ExecuteReader())) { IsReadOnly = false; while (dr.Read()) this.Add(new DocumentInfo(dr)); IsReadOnly = true; } } } } catch (Exception ex) { if (_MyLog.IsErrorEnabled) _MyLog.Error("DocumentInfoList.DataPortal_Fetch", ex); throw new DbCslaException("DocumentInfoList.DataPortal_Fetch", ex); } this.RaiseListChangedEvents = true; } } public class DSOFile : IDisposable { private static readonly log4net.ILog _MyLog = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); #region Fields private bool _IsDisposed; private DocumentInfo _MyDocument = null; private FileInfo _MyFile = null; private string _Extension = "DOC"; #endregion #region Properties public DocumentInfo MyDocument { get { return _MyDocument; } set { TryDelete(); _MyDocument = value; CreateFile(); } } public FileInfo MyFile { get { return _MyFile; } } public string Extension { get { return _Extension; } set { _Extension = value; } } #endregion #region Private Methods private void TryDelete() { if (_MyDocument == null) return; if (_MyFile == null) return; if (_MyFile.Exists) { try { _MyFile.Delete(); } catch (IOException ex) { // _MyLog.Error("TryDelete", ex); } finally { _MyFile = null; _MyDocument = null; } } } private bool _Created = false; private int _Unique = 0; private string Unique { get { string retval = ""; if (_Unique != 0) retval = "_" + _Unique.ToString(); _Unique++; return retval; } } private void CreateFile() { while (!_Created) CreateTemporaryFile(); } private void CreateTemporaryFile() { try { if (_MyDocument != null) { _MyFile = new FileInfo(string.Format(@"{0}\tmp_{1}{2}{3}", VlnSettings.TemporaryFolder, MyDocument.DocID, Unique, MyDocument.FileExtension)); FileStream fs = _MyFile.Create(); if(MyDocument.DocContent != null)fs.Write(MyDocument.DocContent, 0, MyDocument.DocContent.Length); fs.Close(); _MyFile.CreationTime = _MyDocument.DTS; _MyFile.LastWriteTime = _MyDocument.DTS; _Created = true; } } catch (Exception ex) { Console.WriteLine(ex.Message); } } public string FullName { get { return _MyFile.FullName; } set { if(FullName != value) _MyFile = new FileInfo(value); } } public void SaveFile(float length,string ascii) { // TODO: Add Try & Catch logic if (_MyDocument == null) return; Document doc = _MyDocument.Get(); FileStream fs = _MyFile.Open(FileMode.Open, FileAccess.Read, FileShare.ReadWrite); Byte[] buf = new byte[_MyFile.Length]; fs.Read(buf,0,buf.Length); fs.Close(); doc.FileExtension = MyFile.Extension; doc.DocContent = buf; doc.DocAscii = ascii; //doc.UpdateDocAscii(_MyFile.FullName); DocumentConfig cfg = new DocumentConfig(doc); cfg.Printing_Length = length; cfg.Printing_Color = MSWordToPDF.OverrideColor; doc.Config = cfg.ToString(); doc.UserID = Volian.Base.Library.VlnSettings.UserID; doc.DTS = _MyFile.LastWriteTime; doc.Save(); List roids = new List(); string pdfTmp = MSWordToPDF.ToPDFReplaceROs(_MyDocument,roids); FileInfo pdfFile = new FileInfo(pdfTmp); fs = pdfFile.Open(FileMode.Open, FileAccess.Read, FileShare.ReadWrite); buf = new byte[pdfFile.Length]; fs.Read(buf, 0, buf.Length); fs.Close(); pdfFile.Delete(); doc.DocPdf = buf; doc.UpdateDRoUsages(roids); doc.Save(); } #endregion #region Constructors public DSOFile(DocumentInfo myDocument) { MyDocument = myDocument; } #endregion #region Destructor ~DSOFile() { Dispose(false); } public void Dispose() { Dispose(false); GC.SuppressFinalize(this); } protected void Dispose(bool disposing) { if (!_IsDisposed) { _IsDisposed = true; TryDelete(); } } #endregion } public static class MSWordToPDF { private static bool _CloseWordWhenDone = true; public static bool CloseWordWhenDone { get { return MSWordToPDF._CloseWordWhenDone; } set { MSWordToPDF._CloseWordWhenDone = value; } } private static LBApplicationClass _MyApp = null; public static LBApplicationClass MyApp { get { if (_MyApp == null) _MyApp = new LBApplicationClass(); return _MyApp; } } private static System.Drawing.Color _OverrideColor = System.Drawing.Color.Transparent; public static System.Drawing.Color OverrideColor { get { return MSWordToPDF._OverrideColor; } set { MSWordToPDF._OverrideColor = value; } } private static System.Windows.Forms.Form _FormForPlotGraphics=null; public static System.Windows.Forms.Form FormForPlotGraphics { get { return MSWordToPDF._FormForPlotGraphics; } set { MSWordToPDF._FormForPlotGraphics = value; } } public static string GetDocPdf(SectionInfo sect, Color overrideColor) { DocumentInfo mydoc = sect.MyContent.MyEntry.MyDocument; UpdateDocPdf(mydoc, overrideColor); string fileName = GetFileName(sect); FileInfo fi = new FileInfo(fileName); FileStream fs = fi.Create(); if (mydoc.DocPdf!=null)fs.Write(mydoc.DocPdf, 0, mydoc.DocPdf.Length); fs.Close(); return fileName; } public static bool UpdateDocPdf(DocumentInfo mydoc, Color overrideColor) { if (mydoc.DocPdf == null || overrideColor.ToArgb() != mydoc.DocumentConfig.Printing_Color.ToArgb()) { MSWordToPDF.OverrideColor = overrideColor; return SetDocPdf(mydoc); } return true; } public static bool SetDocPdf(DocumentInfo docInfo) { string pdfTmp = null; List roids = new List(); try { pdfTmp = MSWordToPDF.ToPDFReplaceROs(docInfo,roids); } catch (Exception ex) { return false; } if (pdfTmp == null) return false; FileInfo pdfFile = new FileInfo(pdfTmp); FileStream fs = pdfFile.Open(FileMode.Open, FileAccess.Read, FileShare.ReadWrite); Byte[] buf = new byte[pdfFile.Length]; fs.Read(buf, 0, buf.Length); fs.Close(); pdfFile.Delete(); using (Document doc = docInfo.Get()) { DocumentConfig dc = new DocumentConfig(doc); dc.Printing_Color = MSWordToPDF.OverrideColor; doc.Config = dc.ToString(); doc.DocPdf = buf; doc.UpdateDRoUsages(roids); doc.Save(); } docInfo.RefreshConfig(); return true; } public static string ToPDFReplaceROs(DocumentInfo doc,List roids) { ItemInfo sect = doc.DocumentEntries[0].MyContent.ContentItems[0]; return ToPDFReplaceROs(sect, false, roids); } public static string ToPDFReplaceROs(ItemInfo sect, bool openPdf, List roids) //, System.Drawing.Color overrideColor, System.Windows.Forms.Form myForm) { string fileName = GetFileName(sect); // TODO: do we want to cache the word pdfs //if (System.IO.File.Exists(@"C:\Temp\" + fileName + ".pdf")) // return @"C:\Temp\" + fileName + ".pdf"; //int docStyleIndex = ((int)sect.MyContent.Type) % 10000; //DocStyle myDocStyle = sect.ActiveFormat.PlantFormat.DocStyles.DocStyleList[docStyleIndex]; DocStyle myDocStyle = sect.MyDocStyle; //PageStyle myPageStyle = myDocStyle.pagestyle; ProcedureInfo proc = sect.MyProcedure; DocVersionInfo dvi = proc.ActiveParent as DocVersionInfo; ROFstInfo rofst = dvi.DocVersionAssociations[0].MyROFst; ROFSTLookup lookup = rofst.ROFSTLookup; string igPrefix = dvi.DocVersionConfig.RODefaults_graphicsprefix; string spPrefix = dvi.DocVersionConfig.RODefaults_setpointprefix; // string AccPageID = string.Format("<{0}-{1}>", accPrefix, roch.appid); using (DSOFile myFile = new DSOFile(sect.MyContent.MyEntry.MyDocument)) { // Increase the priority of the Word Process so that the pdf creation happens quickly Process[] myProcessess = Process.GetProcessesByName("winword"); foreach (Process myProcess in myProcessess) { try { if (myProcess.PriorityClass != ProcessPriorityClass.High && myProcess.MainWindowTitle == "") myProcess.PriorityClass = ProcessPriorityClass.High; } catch (Exception ex) { while (ex != null) { Console.WriteLine("{0} - {1}", ex.GetType().Name, ex.Message); ex = ex.InnerException; } } } LBDocumentClass myDoc = MyApp.Documents.Open(myFile.FullName, false); AdjustMargins(myDocStyle, myDoc, true); LBSelection sel = FindRO(); while (sel != null) { string val = lookup.GetROValueByAccPagID(sel.Text, spPrefix, igPrefix); int? type = lookup.GetROTypeByAccPagID(sel.Text, spPrefix, igPrefix); // if type is null, then set type to zero so that InsertROValue will put in "RO Not Found" for the value if (type == null) type = 0; string roid = lookup.GetROIDByAccPagID(sel.Text, spPrefix, igPrefix); if (roid != null) { string roidkey = string.Format("{0}:{1}",rofst.RODbID, roid); if (!roids.Contains(roidkey)) roids.Add(roidkey); } if ((int)type == 8) // Image { //Console.WriteLine("Image: {0} - {1}", sect.MyContent.Number, sect.MyContent.Text); bool imageROTokenReplaced = false; string[] vals = val.Split("\n".ToCharArray()); ROImageInfo roImage = ROImageInfo.GetByROFstID_FileName(rofst.ROFstID, vals[0]); if (roImage != null) { ROImageFile roImageFile = new ROImageFile(roImage); float width = 72 * Int32.Parse(vals[3], System.Globalization.NumberStyles.AllowHexSpecifier) / 12.0F; int lines = Int32.Parse(vals[2], System.Globalization.NumberStyles.AllowHexSpecifier); float height = 72 * lines / 6.0F; //sel.MoveEnd(LBWdUnits.wdLine, lines);// The number of lines depends on the third parameter //sel.EndKey(LBWdUnits.wdLine, true); //sel.MoveEnd(LBWdUnits.wdCharacter, -1); //Console.WriteLine("Lines = {0}", lines); sel.Text = ""; // TODO: Need to create a temporary file for printing. // TODO: Need a way to eliminate the temporary file when done printing. // LBInlineShape shape = sel.InlineShapes.AddPicture(@"C:\Plant\HLP\VEHLP\ro\No1Seal.bmp"); float x = (float)sel.get_Information(LBWdInformation.wdHorizontalPositionRelativeToPage); float y = (float)sel.get_Information(LBWdInformation.wdVerticalPositionRelativeToPage); //LBInlineShape shape = sel.InlineShapes.AddPicture(pngFile); LBRange myRange = sel.Paragraphs.First.Range; float yTop = (float)myRange.get_Information(LBWdInformation.wdVerticalPositionRelativeToPage); LBShape shape = myDoc.Shapes.AddPicture(roImageFile.MyFile.FullName, x, y - yTop, sel.Range); // LBInlineShape shape = sel.InlineShapes.AddPicture(roImageFile.MyFile.FullName); //Console.WriteLine("{0} Shape Width {1} Height {2}", val.Replace("\n", "','"), shape.Width, shape.Height); shape.Width = width; shape.Height = height; //Console.WriteLine("{0} Shape Width {1} Height {2}", val.Replace("\n", "','"), shape.Width, shape.Height); imageROTokenReplaced = true; } if (!imageROTokenReplaced) sel.Text = string.Format("Bad Image Link (Missing Image File:{0})", vals[0]); } else if ((int)type == 4) // X-Y Plot { try { val = val.Replace("`", "\xB0"); //AddInfo("\tRO Found {0} = '{1}'", sel.Text, val); sel.Text = ""; //float width = 72 * Int32.Parse(vals[3], System.Globalization.NumberStyles.AllowHexSpecifier) / 12.0F; //float height = 72 * lines / 6.0F; string pngFile = VlnSettings.TemporaryFolder + @"\XYPlot1.png"; //@"C:\Temp\XYPlot1.png"; RectangleF plotRect = CreatePlot(pngFile, val, 600F, FormForPlotGraphics); //LBShape shape = myDoc.Shapes.AddPicture(@"C:\Temp\XYPlot.png", 0, 0, sel.Range); float x = (float)sel.get_Information(LBWdInformation.wdHorizontalPositionRelativeToPage); float y = (float)sel.get_Information(LBWdInformation.wdVerticalPositionRelativeToPage); //LBInlineShape shape = sel.InlineShapes.AddPicture(pngFile); LBRange myRange = sel.Paragraphs.First.Range; float yTop = (float)myRange.get_Information(LBWdInformation.wdVerticalPositionRelativeToPage); float xAdjust = -29.3F; // TODO: Check this value float yAdjust = 9.1F; // TODO: Check this value LBShape shape = myDoc.Shapes.AddPicture(pngFile, x + xAdjust + plotRect.X, yAdjust + y - yTop + plotRect.Y, sel.Range); File.Delete(pngFile); //Console.WriteLine(",{0},{1},{2},{3}", x, y - yTop, xAdjust,yAdjust); shape.LockAspectRatio = LBMsoTriState.msoTrue; //shape.Width = .89F * shape.Width; //shape.Width = float.Parse(tbAdjust.Text) * shape.Width; shape.Width = plotRect.Width; //shape.Height = .89F * shape.Height; sel.WholeStory(); // TODO: Do we want to color code ROs //sel.Range.Font.Color = LBWdColor.wdColorRed; //Console.WriteLine("{0} Shape Width {1} Height {2}", val.Replace("\n", "','"), shape.Width, shape.Height); //shape.Width = width; //shape.Height = height; //Console.WriteLine("{0} Shape Width {1} Height {2}", val.Replace("\n", "','"), shape.Width, shape.Height); //imageROTokenReplaced = true; } catch (Exception ex) { return null; } } else { if (val != null) val = val.Replace("`", "\xB0"); //AddInfo("\tRO Found {0} = '{1}'", sel.Text, val); // if val is null, then InsertROValue will put in "RO Not Found" for the value InsertROValue(sel, val, sect.ActiveFormat.PlantFormat.FormatData.ROData.UpRoIfPrevUpper); } sel = FindRO(); } sel = MyApp.Selection; sel.WholeStory(); //sel.Range.Font.Color = (LBWdColor)WordColor(PrintOverride.OverrideTextColor(System.Drawing.Color.Black)); sel.Range.Font.Color = (LBWdColor)WordColor(OverrideColor == System.Drawing.Color.Transparent ? System.Drawing.Color.Black : OverrideColor); sel.ParagraphFormat.LineSpacingRule = LBWdLineSpacing.wdLineSpaceExactly; sel.ParagraphFormat.LineSpacing = 12; fileName = CreatePDF(fileName, openPdf); MyApp.ActiveDocument.Close(false); if (CloseWordWhenDone) { CloseApp(); } return fileName; } } public static void AdjustMargins(DocStyle myDocStyle, LBDocumentClass myDoc, bool printingMode) { float newTop = (float)myDocStyle.Layout.TopRow; float newLeft = (float)myDocStyle.Layout.LeftMargin; float newLength = (float)myDocStyle.Layout.PageLength; float newWidth = (float)myDocStyle.Layout.PageWidth; float oldTop = myDoc.PageSetup.TopMargin; float oldLeft = myDoc.PageSetup.LeftMargin; float oldBottom = myDoc.PageSetup.BottomMargin; float oldRight = myDoc.PageSetup.RightMargin; float oldHeight = myDoc.PageSetup.PageHeight; float oldWidth = myDoc.PageSetup.PageWidth; float newRight = oldWidth - (newWidth + newLeft); if (newRight < 0) newRight = 0; float newBottom = oldBottom - newTop; //Console.WriteLine("{0},{1},{2},{3},{4},{5},{6},{7},{8},{9}", newTop, newLeft, newLength, newWidth, oldTop, oldLeft, oldBottom, oldRight,oldHeight,oldWidth); if (printingMode) { myDoc.PageSetup.BottomMargin = 0;// 11 * 72 - (newTop + newLength); myDoc.PageSetup.RightMargin = newRight; myDoc.PageSetup.LeftMargin = newLeft; myDoc.PageSetup.TopMargin = newTop; } else { myDoc.PageSetup.TopMargin = 0; myDoc.PageSetup.LeftMargin = 0; myDoc.PageSetup.RightMargin = (8.5F * 72) - newWidth + newLeft; // For OHLP, docstyle (ohlpdoc.in) in 16-bit for "Cover Page", pagelen seems to be incorrect. It would // put out text on a second page. The following code is to catch this condition and reset the bottom margin. // 11 * 72 -> 11 inches converted to points. newLength is printable part so BottomMargin is unprintable part if (newTop + 36 > ((11 * 72) - newLength)) // 36 is 1/2 inch myDoc.PageSetup.BottomMargin = newTop + 36; // makes an 1/2 inch bottom margin else myDoc.PageSetup.BottomMargin = (11 * 72) - newLength; } } public static void CloseApp() { WaitMS(300);// This was added because MSWord will sometimes get the error below // Microsoft Office Word has stopped working // It appears that this is caused by quiting the MS Word application // to soon after closing the document or doing an export. MyApp.Quit(false); _MyApp = null; } private static void WaitMS(int n) { DateTime dtw = DateTime.Now.AddMilliseconds(n); while (DateTime.Now < dtw) { System.Windows.Forms.Application.DoEvents(); } } private static int WordColor(System.Drawing.Color color) { System.Drawing.Color c1 = System.Drawing.Color.FromArgb(0, color.B, color.G, color.R); return c1.ToArgb(); } private static string GetFileName(ItemInfo sect) { string fileName = VlnSettings.TemporaryFolder + @"\Doc " + sect.MyContent.MyEntry.DocID.ToString(); // +" " + (sect.DisplayNumber == "" ? sect.DisplayText : sect.DisplayNumber); return fileName; } private static RectangleF CreatePlot(string pngFile, string xyPlot, float resolution, System.Windows.Forms.Form myForm) { RectangleF retval = new RectangleF(0, 0, 0, 0); //Form frm = Application.OpenForms[0]; System.Windows.Forms.Form frm = myForm; Graphics grfx = frm.CreateGraphics(); string emfFile = pngFile.Replace(".png", ".emf"); Metafile mf = new Metafile(emfFile, grfx.GetHdc()); grfx.Dispose(); grfx = Graphics.FromImage(mf); float dpi = grfx.DpiX; //grfx.ScaleTransform(resolution / grfx.DpiX, (resolution +1F) / grfx.DpiY); grfx.ScaleTransform(resolution / grfx.DpiX, resolution / grfx.DpiY); grfx.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.NearestNeighbor; grfx.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality; grfx.TextRenderingHint = System.Drawing.Text.TextRenderingHint.AntiAlias; grfx.Clear(System.Drawing.Color.Transparent); XYPlots.XYPlot.BlackColor = VlnSettings.DebugMode ? System.Drawing.Color.Red : System.Drawing.Color.Black; XYPlots.XYPlot myPlot = new XYPlots.XYPlot(xyPlot); myPlot.SetMargins(0, 0, 0, 0); myPlot.Process(new VG.VGOut_Graphics(grfx)); grfx.Dispose(); GraphicsUnit gu = new GraphicsUnit(); retval = mf.GetBounds(ref gu); retval.Width *= dpi / resolution; retval.Height *= dpi / resolution; retval.X *= dpi / resolution; retval.Y *= dpi / resolution; //retval.X = myPlot.Width-retval.Width; //AddInfo("{0},{1},{2},{3},{4},{5}", myPlot.Width, myPlot.Height, retval.Width, retval.Height,retval.X,retval.Y); //Console.Write("{0},{1},{2},{3}", myPlot.Width, myPlot.Height, retval.Width, retval.Height); mf.Save(pngFile, ImageFormat.Png); //Console.WriteLine("'pngfile','{0}'", pngFile); mf.Dispose(); FileInfo myFile = new System.IO.FileInfo(emfFile); myFile.Delete(); return retval; } private static void InsertROValue(LBSelection sel, string roValue, bool upRoIfPrevUpper) { if (roValue == null) { sel.Text = "RO Not Found"; sel.Font.Color = LBWdColor.wdColorRed; } else { if (upRoIfPrevUpper && sel.LastWasUpper) roValue = roValue.ToUpper(); // Convert fortran formatted numbers to scientific notation. //string tmp = DisplayRO.ConvertFortranFormatToScienctificNotation(roValue); string tmp = ROFSTLookup.ConvertFortranFormatToScienctificNotation(roValue); // Look for superscript or subscript and insert the appropriate commands Match roMatch = Regex.Match(tmp, @"(.*?)\\(up2|dn2) (.*?)\\(up0|dn0) "); if (roMatch.Groups.Count == 5)// Superscript or subscript found { sel.Font.Color = LBWdColor.wdColorRed; while (roMatch.Groups.Count == 5) { sel.TypeText(roMatch.Groups[1].Value); // output the text preceeding the super or sub command sel.Font.Position = roMatch.Groups[2].Value == "up2" ? 2 : -2; // Shift the vertical position for super or sub sel.TypeText(roMatch.Groups[3].Value); // output the superscript or subscript sel.Font.Position = 0; // restore the vertical position tmp = tmp.Substring(roMatch.Length); // remove the processed text roMatch = Regex.Match(tmp, @"(.*?)\\(up2|dn2) (.*?)\\(up0|dn0) "); // check to see if the text contain another super or sub } if (tmp != "")// Add any remaining text sel.TypeText(tmp); sel.Font.Color = LBWdColor.wdColorAutomatic; } else // if no superscripts or subscripts just output the text { sel.Text = roValue; sel.Font.Color = LBWdColor.wdColorRed; } } } private static LBSelection FindRO() { LBSelection sel = MyApp.Selection; LBFind find = sel.Find; find.ClearFormatting(); // Search string format - this is MSWord wildcard format // If you do a search in MSWord, make sure wildcard box is checked and then press the // Special button to see the definitions of the various wildcards // [<] - Less-Than Character // [!<> ]@ - 1 or more characters not including Less-Than, Greater-Than or Space // - Dash // [!<> ]@ - 1 or more characters not including Less-Than, Greater-Than or Space // [>] - Greater-Than Character find.Text = "[<][!<> ]@-[!<> ]@[>]"; //find.Wrap = LBWdFindWrap.wdFindStop; find.Wrap = LBWdFindWrap.wdFindContinue; find.MatchCase = false; find.MatchWholeWord = false; find.MatchWildcards = true; find.MatchSoundsLike = false; find.MatchAllWordForms = false; if (find.Execute()) return sel; return null; } private static string CreatePDF(string fileName, bool openPdf) { //return MyApp.CreatePDF(@"C:\Temp\" + fileName + ".pdf", openPdf); //return MyApp.CreatePDF(VlnSettings.TemporaryFolder + "\\" + fileName + ".pdf", openPdf); return MyApp.CreatePDF(fileName + ".pdf", openPdf); } } }