149 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	using System; using System.ComponentModel; using System.Collections.Generic; using System.Diagnostics; using System.Text; using System.Drawing; using System.Windows.Forms; using System.Text.RegularExpressions; using VEPROMS.CSLA.Library; using Volian.Base.Library; using JR.Utils.GUI.Forms;
namespace Volian.Controls.Library { #region Enums public enum ChildRelation : int { None = 0, After = 1, Before = 2, RNO = 3, SupInfo = 4 } public enum E_ChangeBarPosition : int { Left = 0, Right = 1 } #endregion public abstract partial class EditItem : UserControl { #region EditItemUnique //private static int _EditItemUnique = 0; //private static int EditItemUnique /{ / get / { / if (_EditItemUnique == 3) / Console.WriteLine("here"); / return ++_EditItemUnique; / } /} //private int _MyEditItemUnique = EditItemUnique;
//public int MyEditItemUnique /{ / get {return _MyEditItemUnique; } //} #endregion #region Constructor public EditItem() { InitializeComponent(); this.Enter += EditItem_Enter; }
// This event was added to better control enabling or disabling of the Insert and Copy Step buttons on the ribbon void EditItem_Enter(object sender, EventArgs e) { bool allow = (MyStepPanel.VwMode == E_ViewMode.Edit); StepTabRibbon str = MyStepPanel.MyStepTabPanel.MyStepTabRibbon; str.SiblingsButtonsEnabled = allow; str.InsertButtonsEnabled = allow && !(MyItemInfo.IsProcedure || MyItemInfo.IsSection || MyItemInfo.IsRNOPart || MyItemInfo.IsSupInfoPart); // do special case for cpystep button: cannot copy an enhanced step: if (MyItemInfo.IsEnhancedStep) str.SetCopyStepButton(false); }
public EditItem(IContainer container) { container.Add(this); InitializeComponent(); this.Enter += EditItem_Enter; } #endregion #region Properties private bool _RTBLastFocus = true; public bool RTBLastFocus { get { return _RTBLastFocus; } set { _RTBLastFocus = value; } } protected static readonly log4net.ILog _MyLog = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); protected ChildRelation _MyChildRelation; public ChildRelation MyChildRelation { get { return _MyChildRelation; } set { _MyChildRelation = value; } } protected bool _Loading = true; protected EditItem _MyParentEditItem = null; protected EditItem _MySectionRTBItem; protected EditItem _MyPreviousEditItem = null; protected EditItem _MyNextEditItem = null; private bool _ChildrenLoaded = false; public bool HasChildren { get { return _MyBeforeEditItems != null || _MyRNOEditItems != null || _MyAfterEditItems != null; } } internal List<EditItem> _MyBeforeEditItems; public List<EditItem> MyBeforeEditItems // MyBeforeEditItems are Cautions & Notes { get { return _MyBeforeEditItems; } set { _MyBeforeEditItems = value; } } internal List<EditItem> _MyAfterEditItems; public List<EditItem> MyAfterEditItems { get { return _MyAfterEditItems; } set { _MyAfterEditItems = value; } } internal List<EditItem> _MyRNOEditItems; public List<EditItem> MyRNOEditItems { get { return _MyRNOEditItems; } set { _MyRNOEditItems = value; } } internal List<EditItem> _MySupInfoEditItems; public List<EditItem> MySupInfoEditItems { get { return _MySupInfoEditItems; } set { _MySupInfoEditItems = value; } } private StepSectionLayoutData _MyStepSectionLayoutData; public StepSectionLayoutData MyStepSectionLayoutData { get { return _MyStepSectionLayoutData; } set { _MyStepSectionLayoutData = value; } } private StepData _MyStepData; public StepData MyStepData { get { return _MyStepData; } set { _MyStepData = value; } } private ItemInfo _MyItemInfo; private int _ExpandPrefix = 0; public int ExpandPrefix { get { return _ExpandPrefix; } set { _ExpandPrefix = value; } } private bool _Colapsing = false; / <summary> / Gets or sets colapsing / </summary> public bool Colapsing { get { return _Colapsing; } set { _Colapsing = value; } } private bool _Moving = false; private int _RNOLevel = 0; private int _SeqLevel = 0; private int _ContentType; public int ContentType { get { return _ContentType; } set { _ContentType = value; } } private bool _Circle = false; private bool _CheckOff = false; private bool _UserCheckOff = false; private bool _ChangeBar = false; private StepPanel _MyStepPanel; public StepPanel MyStepPanel { get { return _MyStepPanel; } set { _MyStepPanel = value; } }
private DisplayTags _MyStepPropertiesPanel; public DisplayTags MyStepPropertiesPanel // gives us access to the Step Properties panel - used with shortcut keystrokes { get { return _MyStepPropertiesPanel; } set { _MyStepPropertiesPanel = value; } }
/ <summary> / This returns the section or procedure for the current item. / If the item is a step or section, it returns the section / If it is a procedure, it returns the procedure / </summary> public EditItem MySectionRTBItem { get { if (_MySectionRTBItem == null) { if (MyItemInfo.IsSection || MyItemInfo.IsProcedure) _MySectionRTBItem = (RTBItem)this; else _MySectionRTBItem = MyParent.MySectionRTBItem; } return _MySectionRTBItem; } set { _MySectionRTBItem = value; } } / <summary> / Gets or Sets ItemInfo / </summary> public ItemInfo MyItemInfo { get { return _MyItemInfo; } set { _MyItemInfo = value; if (VlnSettings.StepTypeToolType) SetToolTip(_MyItemInfo.ToolTip); ChangeBar = _MyItemInfo.HasChangeBar; CheckOff co = _MyItemInfo.GetCheckOffStep(); if (co != null && co.UIMark != null) { UserCheckOff = true; UserCheckOffChar = (char)co.UIMark; } // Deal with changes in content data value.MyContent.Changed += new ContentInfoEvent(MyContent_Changed); value.MyProcedure.MyContent.Changed += new ContentInfoEvent(MyContent_Changed); // Deal with change in item data value.Changed += new ItemInfoEvent(value_Changed); value.OrdinalChanged += new ItemInfoEvent(value_OrdinalChanged); // do something like this to draw circle around step numbers - note got NULL reference error on NSP data //if (value.FormatStepData != null && value.FormatStepData.TabData.IdentPrint.Contains("C0")) Circle = true; } } private bool _ChangeBarForConfigItemChange = true;
public bool ChangeBarForConfigItemChange { get { return _ChangeBarForConfigItemChange; } set { _ChangeBarForConfigItemChange = value; } }
void value_Changed(object sender) { ChangeBar = _MyItemInfo.HasChangeBar; } protected void MyContent_Changed(object sender) { // Update the text to reflect the content change MyItemInfo.RefreshItemAnnotations(); ChangeBar = MyItemInfo.HasChangeBar; CheckOff co = _MyItemInfo.GetCheckOffStep(); if (co != null && co.UIMark != null) { UserCheckOff = true; UserCheckOffChar = (char)co.UIMark; } else UserCheckOff = false; RefreshContent();
   / see if change in subsections to be displayed, i.e. if the user made a change to editable data
   / on the section properties form, we may have to display steps or remove steps.  By design,
   / steps are the first children from a section. Also, this will only occur if the format has
   / metasections AND there are subsections.
   if (MyItemInfo.IsSection && MyItemInfo.ActiveFormat.PlantFormat.FormatData.SectData.UseMetaSections
    && MyItemInfo.Sections != null && MyItemInfo.Sections.Count > 0)
   {
    // find out what the editable flag is to determine if change.
    bool showSteps = MyItemInfo.MyConfig is SectionConfig && (MyItemInfo.MyConfig as SectionConfig).SubSection_Edit = "Y";
    if (showSteps && _MyAfterEditItems ! null && _MyAfterEditItems.Count > 0 && _MyAfterEditItems[0].MyItemInfo.IsSection)
    {
     // need to add steps in, i.e. they do not exist in step editor yet.
     _MyAfterEditItems[0].AddSiblingBeforeNoDataSave(MyItemInfo.Steps, false);
    }
    else if (!showSteps && _MyAfterEditItems != null && _MyAfterEditItems.Count > 0 && _MyAfterEditItems[0].MyItemInfo.IsStep)
    {
     // Remove steps - only want sections.  Put in a list for removal.
     List<EditItem> remEIs = new List<EditItem>();
     foreach (EditItem ei in _MyAfterEditItems)
     {
      if (!ei.MyItemInfo.IsSection) remEIs.Add(ei);
     }
     foreach (EditItem ei1 in remEIs)
     {
      ei1.RemoveItemWithoutDelete();
     }
     remEIs.Clear();
    }
   }
  }
  void value_OrdinalChanged(object sender)
  {
   RefreshOrdinal();
  }
  public EditItem ActiveParent
  {
   get { return _MyParentEditItem != null ? _MyParentEditItem : _MyPreviousEditItem.ActiveParent; }
  }
  / <summary>
  / Return the Parent EditItem
  / </summary>
  private EditItem UpOneEditItem
  {
   get
   {
    EditItem tmp = this;
    while (tmp != null && tmp.MyParentEditItem = null) tmp = tmp.MyPreviousEditItem;
    if (tmp ! null) return tmp.MyParentEditItem;
    return null;
   }
  }
  private Stack<string> _LastMethods = new Stack<string>();
  //private string _LastMethod = "";
  internal void LastMethodsPush(string str)
  {
   if(MyStepPanel != null)MyStepPanel._LastAdjust = str;
   _LastMethods.Push(str);
  }
  internal string LastMethodsPop()
  {
   //MyStepPanel._LastAdjust = "";
   return _LastMethods.Pop();
  }
  internal bool LastMethodsEmpty
  {
   get { return _LastMethods.Count == 0; }
  }
  / This should find the item that precedes the current item vertically in the supplemental information column
  / and then return the Bottom of that item.
  // It is used so that an edit item does not overlap in 'y-direction' any preceding items.
  internal int? FindTopSupInfo(bool useSuppInfoColBottom)
  {
   if (MyParentEditItem == null) return null;
   / on supplemental info item:  parent is item in left column.
   / return null if parent does not have previous siblings or parents that have supp info.  FindPreviousOrParentSupInfo looks above to
   // items that have supinfo.
   EditItem prevOrParSupInfo = MyParentEditItem.FindPreviousOrParentSupInfo();
   if (prevOrParSupInfo == null || !prevOrParSupInfo.Visible)
   {
    / Account for Expanded or collapsed.  note that BottomMostEditItem already accounts for
    / whether it is expanded or collapsed.
    if (MyParentEditItem.MyPreviousEditItem != null) return MyParentEditItem.MyPreviousEditItem.BottomMostEditItem.Bottom;
    if (MyParentEditItem.MyBeforeEditItems != null) return MyParentEditItem.MyBeforeEditItems[MyParentEditItem.MyBeforeEditItems.Count - 1].BottomMostEditItem.Bottom;
    return (MySectionRTBItem==null)?0:MySectionRTBItem.Bottom;
   }
   int b1 = prevOrParSupInfo.BottomMostEditItem.Bottom;
   int b2 = b1;
   if (prevOrParSupInfo.MyParentEditItem.MyItemInfo.StepLevel > MyParentEditItem.MyItemInfo.StepLevel)
    b2 = prevOrParSupInfo.MyParentEditItem.LastSiblingEditItem.BottomMostEditItem.Bottom;
/ if the current supinfo's parent (proc step) is same as the lastsibling bottom most, don't use its value - it puts the next step / down too far: if (this.MyParentEditItem.MyID == prevOrParSupInfo.MyParentEditItem.LastSiblingEditItem.BottomMostEditItem.MyID) b2 = b1; // if not in the same HLS, don't use the lastsibling either: if (this.MyParentEditItem.MyItemInfo.MyHLS.ItemID != prevOrParSupInfo.MyParentEditItem.LastSiblingEditItem.MyItemInfo.MyHLS.ItemID) b2 = b1; if (useSuppInfoColBottom) return b1; else return Math.Max(b1, b2); // look at both supinfo & parent column to determine bottom } / This goes up edititems, looking for the closest in 'y-direction' of any supplemental info items. EditItem FindPreviousOrParentSupInfo() / current edit item is parent of supplmental info item { EditItem prev = this; // First see if there are any Cautions or Notes before me that have supinfo: EditItem lastBefore = prev.FindLastBeforeWithSupInfo(); if (lastBefore != null) return lastBefore.MySupInfoEditItems[0];
   // There were no Cautions/Notes before me with supinfo, now see if there are previous items with supinfo:
   while (prev.MyPreviousEditItem != null)
   {
    prev = prev.MyPreviousEditItem;
    EditItem eiTmp = prev.FindLastSubstepWithSupInfo();
    / check for MySupInfoEditItems as null because the FindLastSubstepWithSupInfo checks for data, but the supinfo step may
    / not be displayed yet, i.e. the eiTmp.MySupInfoEditItems has an edititem defined only it if is displayed.
    if (eiTmp != null && eiTmp.MySupInfoEditItems != null) return eiTmp.MySupInfoEditItems[0];
   }
   // No previous items had supinfo, look up to the parent. But if on first before, i.e. first caution or note, there is nothing before (just the section)
   if (prev.MyParentEditItem.MyBeforeEditItems != null && prev.MyParentEditItem.MyBeforeEditItems.Count > 0 && prev.MyParentEditItem.MyBeforeEditItems[0] == prev)
   {
    EditItem eitmp = null;
    // if on a Note/Caution, need to be sure there isn't a step before me with supinfo (don't just assume going to Section)
    if (prev.MyParentEditItem.MyPreviousEditItem!=null)eitmp = prev.MyParentEditItem.MyPreviousEditItem.BottomMostEditItem.FindPreviousOrParentSupInfo();
    return eitmp;
   }
   if (prev.MyParentEditItem.MySupInfoEditItems != null) return prev.MyParentEditItem.MySupInfoEditItems[0];
   if (prev.MyItemInfo.IsSection) return null;
   return prev.MyParentEditItem.FindPreviousOrParentSupInfo();
  }
  private EditItem FindLastBeforeWithSupInfo()
  {
   if (MyBeforeEditItems = null || MyBeforeEditItems.Count = 0) return null;
for (int i = MyBeforeEditItems.Count - 1; i > -1; i–) { // Need to look at caution/note (mybeforeedititems) if they have substeps that have supinfo if (MyBeforeEditItems[i].MySupInfoEditItems != null && MyBeforeEditItems[i].MySupInfoEditItems.Count > 0) return MyBeforeEditItems[i]; } return null; } / The next 2 methods, FindLastSubstepWithSupInfo, FindLastItemWithSupInfo: / for the current item, get to its bottommost supplemental info, if any steps/substeps have it. // private EditItem FindLastSubstepWithSupInfo() { ItemInfo ii = FindLastItemWithSupInfo(MyItemInfo); if (ii == null) return null; return GetEditItemFromItemID(ii.ItemID); } private ItemInfo FindLastItemWithSupInfo(ItemInfo stp) { // first check substeps (& their substeps) of item passed in. if (stp.Steps != null && stp.Steps.Count > 0) { for (int i = stp.Steps.Count - 1; i > -1; i–) { ItemInfo tmp = FindLastItemWithSupInfo(stp.Steps[i]); if (tmp != null) return tmp; } } //now check the step that was passed in. if (stp.SupInfos != null && stp.SupInfos.Count > 0) return stp; if (stp.Notes != null && stp.Notes.Count > 0) { for (int j = stp.Notes.Count - 1; j > -1; j–) { if (stp.Notes[j].SupInfos != null && stp.Notes[j].SupInfos.Count > 0) return stp.Notes[j]; } } if (stp.Cautions != null && stp.Cautions.Count > 0) { for (int j = stp.Cautions.Count - 1; j > -1; j–) { if (stp.Cautions[j].SupInfos != null && stp.Cautions[j].SupInfos.Count > 0) return stp.Cautions[j]; } } return null; } / <summary> / This should find the item that precedes the current item vertically / and then return the Bottom of that item. / </summary> / <returns></returns> internal int FindTop(int bottom, bool test1) { // if on a supplemental info, use special code to find what steps are above the supplemental info if (MyItemInfo.MyDocStyle != null && MyItemInfo.MyDocStyle.SupplementalInformation) { if (MyItemInfo.IsSupInfoPart) { int? tmptop = FindTopSupInfo(test1); return tmptop == null ? bottom : Math.Max(bottom, (int)tmptop); } } int lastBottomPrev = bottom; // This is necessary if the value of bottom can be negative. if (_MyPreviousEditItem != null) lastBottomPrev = _MyPreviousEditItem.BottomMostEditItem.Bottom; int? bottomRNO = BottomOfParentRNO(); if (lastBottomPrev > bottom) bottom = (int)(lastBottomPrev); / RHM 20090615 ES02 Step8 / Moving from Step 8 to the Note preceeding step 8 caused the step 9 to be positioned in the wrong place. //if (lastBottomParent > bottom) bottom = lastBottomParent; //if (bottomRNO == null) return bottom; return (int)max(bottomRNO, bottom); } internal int FindTop(int bottom) { return FindTop(bottom, true); } / <summary> / The Top of the EditItem / </summary> public int ItemTop { get { return Top; } set { MyStepPanel.ItemMoving++; Top = value; MyStepPanel.ItemMoving–; } } private E_ChangeBarPosition _ChangeBarPosition = E_ChangeBarPosition.Right; public E_ChangeBarPosition ChangeBarPosition { get { return _ChangeBarPosition; } set { _ChangeBarPosition = value; } } / <summary> / Sets the next item and adjusts the location, / This also sets the previous for the "next" item / which adjusts other locations. / </summary> public EditItem MyNextEditItem { get { return _MyNextEditItem; } set { _MyNextEditItem = value; if (_MyNextEditItem != null) { if (_MyNextEditItem.MyPreviousEditItem != this) { _MyNextEditItem.MyPreviousEditItem = this; MyNextEditItem.Location = new Point(Left, Bottom); } } } } / <summary> / returns the TopMostChild / </summary> public EditItem TopMostEditItem { get { if (Expanded && _MyBeforeEditItems != null) return _MyBeforeEditItems[0].TopMostEditItem; return this; } } / <summary> / Returns the bottom location (Top + Height) / </summary> public new int Bottom { get { return Top + (Hidden ? 0 : Height); } } private bool _Hidden = false; public bool Hidden { get { return _Hidden; } set { _Hidden = value; Visible = !value; } } / <summary> / Bottom most child / </summary> public EditItem BottomMostEditItem { get { EditItem tmpr = null; // BottomMost RNO //int rnoOffset = 0; if ((MyExpandingStatus != ExpandingStatus.No || Expanded) && _MyRNOEditItems != null) { //rnoOffset = this.Top - _MyRNOEditItems[0].Top; tmpr = _MyRNOEditItems[_MyRNOEditItems.Count - 1].BottomMostEditItem; } EditItem tmpa = this; // BottomMost After if ((MyExpandingStatus != ExpandingStatus.No || Expanded) & _MyAfterEditItems != null) tmpa = _MyAfterEditItems[_MyAfterEditItems.Count - 1].BottomMostEditItem; // return the bottom most of the two results if (tmpr == null) return tmpa; //if (rnoOffset > 0) //Console.WriteLine("RNO Bottom Offset {0}", rnoOffset); //if (tmpa.Bottom >= (tmpr.Bottom + rnoOffset)) if (tmpa.Bottom >= (tmpr.Bottom)) return tmpa; return tmpr; } } / <summary> / Bottom most child excluding RNOs / </summary> public EditItem BottomMostEditItemNoRNOs { get { EditItem tmpa = this; // BottomMost After if ((MyExpandingStatus != ExpandingStatus.No || Expanded) & _MyAfterEditItems != null) tmpa = _MyAfterEditItems[_MyAfterEditItems.Count - 1].BottomMostEditItem; // return the bottom most return tmpa; } } / <summary> / First sibling / </summary> private EditItem FirstSiblingEditItem { get { EditItem tmp = this; while (tmp.MyPreviousEditItem != null) tmp = tmp.MyPreviousEditItem; return tmp; } } / <summary> / Last sibling / </summary> private EditItem LastSiblingEditItem { get { EditItem tmp = this; while (tmp.MyNextEditItem != null) tmp = tmp.MyNextEditItem; return tmp; } } private ExpandingStatus _MyExpandingStatus = ExpandingStatus.No; / <summary> / Sets or Gets expanding status / </summary> public ExpandingStatus MyExpandingStatus { get { return _MyExpandingStatus; } set { _MyExpandingStatus = value; } } / <summary> / Gets the ItemID from the ItemInfo / </summary> public int MyID { get { return _MyItemInfo == null ? 0 : _MyItemInfo.ItemID; } } / <summary> / Tracks when a EditItem is moving / </summary> public bool Moving { get { return _Moving; } set { _Moving = value; } } / <summary> / The RNO (Contingency) Level / </summary> public int RNOLevel { get { return _RNOLevel; } set { _RNOLevel = value; } } / <summary> / Sequential Level - Only counts levels of Sequential substeps / </summary> public int SeqLevel { get { return _SeqLevel; } set { _SeqLevel = value; } } / TODO: This should be changed to get the Circle format from the data // <summary> / Show a circle or not / </summary> public bool Circle { get { return _Circle; } set { _Circle = value; } } / TODO: This should be changed to get the Checkoff status from the data // <summary> / Has a check-off or not / </summary> public bool CheckOff { get { return _CheckOff; } set { _CheckOff = value; } } public bool UserCheckOff { get { return _UserCheckOff; } set { _UserCheckOff = value; } } private char _UserCheckOffChar; public char UserCheckOffChar { get { return _UserCheckOffChar; } set { _UserCheckOffChar = value; } } / TODO: This should be changed to get the ChangeBar status from the data // <summary> / Has a changebar or not / </summary> public bool ChangeBar { get { return _ChangeBar; } set { _ChangeBar = value; this.Invalidate(); } } #endregion // Properties #region AddItem / <summary> / Adds an item to a list / </summary> / <param name="parentEditItem">Parent Container</param> / <param name="siblingEditItems">EditItem List</param> public void AddItem(EditItem parentEditItem, ref List<EditItem> siblingEditItems, EditItem nextEditItem, bool addFirstChld) { if (siblingEditItems == null) // Create a list of siblings { siblingEditItems = new List<EditItem>(); siblingEditItems.Add(this); MyParentEditItem = parentEditItem; } else // Add to the existing list { / add first child, when there are other children already there. This is used / for metasection editable data changed from off to on so that the first step is located // in the editor correctly, i.e. right below the section & above the subsections. if (addFirstChld) { EditItem parent = siblingEditItems[0].MyParentEditItem; siblingEditItems.Insert(0, this); MyStepPanel.ItemMoving++; _MyNextEditItem = siblingEditItems[1]; _MyNextEditItem._MyPreviousEditItem = this; MyPreviousEditItem = null; _MyNextEditItem.MyParentEditItem = null; MyParentEditItem = parent; MyStepPanel.ItemMoving–; } else if (nextEditItem == null) // Add to the end of the list { EditItem lastChild = LastChild(siblingEditItems); siblingEditItems.Add(this); MyPreviousEditItem = lastChild; / RHM - The following line was remove for Facing Pages (Supplemental Information) / * / When MyPreviousEditItem is set, the location and size is set as a side-effect. / When MyParentEditItem is set, the location and size is set as a side effect. / Only Previous or Parent should be set, no both. / * /MyParentEditItem = MyPreviousEditItem.MyParentEditItem; / Farley - part of bug fix B2015-123 alignment of tabs on the edit screen } else // Add to the middle of the list before a particular item { EditItem prevChild = nextEditItem.MyPreviousEditItem; EditItem parent = nextEditItem.MyParentEditItem; if(siblingEditItems.Contains(nextEditItem)) siblingEditItems.Insert(siblingEditItems.IndexOf(nextEditItem), this); else siblingEditItems.Insert(0, this); MyStepPanel.ItemMoving++; _MyNextEditItem = nextEditItem; if(!MyItemInfo.IsNote || !MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format || MyPreviousEditItem == null) nextEditItem._MyPreviousEditItem = this; MyPreviousEditItem = prevChild;// If a previous exists - this will adjust the location and width of the EditItem if (MyItemInfo.IsNote && MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format && MyPreviousEditItem != null) nextEditItem.MyPreviousEditItem = this;//Position First Note in Dev Doc Format if (!MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format || !(nextEditItem.MyItemInfo.IsNote && MyItemInfo.IsCaution)) { // RHM 20170216 For Deviation Document don't set MyParentEditItem to null when Type Changes from Caution to Note nextEditItem.MyParentEditItem = null; MyParentEditItem = parent; // If a parent exists - this will adjust the location and width of the EditItem AdjustForDevDocStepHeight(); } //nextEditItem.MyPreviousEditItem = this; MyStepPanel.ItemMoving–; } } if (MyItemInfo.IsCaution || MyItemInfo.IsNote) { EditItem prev = this; while (prev.MyPreviousEditItem != null) prev = prev.MyPreviousEditItem; prev.SetAllTabs(); } else SetAllTabs(); } // clear tabs, clears then all so that next 'get' will calculate new. public void SetAllTabs() { RefreshTab();
   if (_MyAfterEditItems != null) foreach (EditItem chld in _MyAfterEditItems) chld.SetAllTabs();
   if (_MyNextEditItem != null) _MyNextEditItem.SetAllTabs();
   // Update the RNO tab if it exists - RHM 20100106
   if (_MyRNOEditItems != null) foreach (EditItem chld in _MyRNOEditItems) chld.SetAllTabs();
   if (_MySupInfoEditItems != null) foreach (EditItem chld in _MySupInfoEditItems) chld.SetAllTabs();
  }
  / <summary>
  / Add the next item to a list
  / </summary>
  / <param name="myItemInfo"></param>
  / <param name="expand"></param>
  / <returns></returns>
  //public EditItem AddNext(ItemInfo myItemInfo, bool expand)
  /{
  /  EditItem tmp = new EditItem(myItemInfo, MyStepPanel, MyParentEditItem, ChildRelation.None, expand);
  /  MyNextEditItem = tmp;
  /  return tmp;
  //}
  #endregion
  #region RemoveItem
  protected void ShowTops(string title)
  {
   int TopMostY = TopMostEditItem.Top;
   int? TopMostParentY = (MyParentEditItem = null ? null : (int?)(MyParentEditItem.TopMostEditItem.Top));
   int? ParentY = (MyParentEditItem = null ? null : (int?)(MyParentEditItem.Top));
   //Console.Write("{0}: TopMostY={1}, TopMostParentY={2}, ParentY = {3}",title, TopMostY, TopMostParentY, ParentY);
   Console.Write("{0}{1},{2},{3}", title, TopMostY, TopMostParentY.ToString() ?? "null", ParentY.ToString() ?? "null");
  }
  private bool _BeingRemoved = false;
  public bool BeingRemoved
  {
   get { return _BeingRemoved; }
   set { _BeingRemoved = value; }
  }
  public void RemoveItemWithoutDelete()
  {
   BeingRemoved = true;
   int TopMostYBefore = TopMostEditItem.Top;
   MyStepPanel._LookupEditItems.Remove(MyID);
   EditItem newFocus = null;
   int? TopMostParentY = (MyParentEditItem = null ? null : (int?)(MyParentEditItem.TopMostEditItem.Top));
   int? ParentY = (MyParentEditItem = null ? null : (int?)(MyParentEditItem.Top));
   RemoveFromParentsChildList();
   if (MyNextEditItem != null)
   {
    if (MyPreviousEditItem != null)
    {
     MyNextEditItem.MyPreviousEditItem = MyPreviousEditItem;
     MyPreviousEditItem = null;
     newFocus = MyNextEditItem;
    }
    else
    {
     MyNextEditItem.MyParentEditItem = MyParentEditItem;
     MyParentEditItem = null;
     MyNextEditItem.MyPreviousEditItem = null;
     newFocus = MyNextEditItem;
    }
    // Adjust the vertical locations of all of the items below the item deleted
    MyNextEditItem.TopMostEditItem.AdjustLocation();
    MyNextEditItem = null;
   }
   else if (MyPreviousEditItem != null)
   {
    MyPreviousEditItem.MyNextEditItem = null;
    newFocus = MyPreviousEditItem.BottomMostEditItem;
    MyPreviousEditItem = null;
   }
   else
   {
    newFocus = MyParentEditItem;
    MyParentEditItem = null;
   }
   Dispose();
   if (newFocus != null)
   {
    newFocus.SetFocus();
    newFocus.SetAllTabs();
    newFocus.AdjustLocation();
   }
  }
  private static int xOffset = 0;
  public void RemoveItem()
  {
   // if this item has enhanced edititems, remove them:
   StepConfig sc = MyItemInfo.MyConfig as StepConfig;
   List<EnhancedDocument> thisEnhs = null;
   if (sc != null)
    thisEnhs = sc.MyEnhancedDocuments;
   else
   {
    if (MyItemInfo.IsSection)
    {
     SectionConfig secc = MyItemInfo.MyConfig as SectionConfig;
     if (secc.Section_LnkEnh == "Y") thisEnhs = secc.MyEnhancedDocuments;
    }
   }
List<int> enhIds = new List<int>(); if (thisEnhs != null) { foreach (EnhancedDocument ed in thisEnhs) { if (ed.Type != 0) enhIds.Add(ed.ItemID); } } BeingRemoved = true; MyStepPanel.SelectedEditItem = null; // Unselect the item to be deleted //ShowTops("\r\n"); int TopMostYBefore = TopMostEditItem.Top; /_MyTimer.ActiveProcess = "DeleteItem"; / Add a Panel temporarily so that AutoScroll will not happen during the delete. Panel pnl = new Panel(); pnl.Size = new Size(10, 10); MyStepPanel.Controls.Add(pnl); pnl.BackColor = Color.Red; pnl.Location = new Point(xOffset += 15, MyStepPanel.ClientSize.Height + 10); EditItem newFocus = DeleteItem(); if (newFocus == null) { MyStepPanel.Controls.Remove(pnl); return; } //_MyTimer.ActiveProcess = "SetFocus";
int b4topadjust = newFocus.Top; newFocus.SetFocus(); /shifts edititem to center it / need to adjust the TopMostYBefore so that it accounts for any shifting that occurred when the // SetFocus was called. This fixes B2016-040. b4topadjust -= newFocus.Top; TopMostYBefore -= b4topadjust;
//_MyTimer.ActiveProcess = "Dispose"; Dispose(); //_MyTimer.ActiveProcess = "SetAllTabs"; newFocus.SetAllTabs(); //_MyTimer.ActiveProcess = "TopMostYAfter"; int TopMostYAfter = newFocus.TopMostEditItem.Top; if (TopMostYAfter > TopMostYBefore) newFocus.TopMostEditItem.Top = TopMostYBefore; //_MyTimer.ActiveProcess = "AdjustLocation"; newFocus.AdjustLocation(); //newFocus.ShowTops(""); //_MyTimer.ShowElapsedTimes("RemoveItem"); ForceEditItemRefresh(newFocus); MyStepPanel.Controls.Remove(pnl); foreach (int enhId in enhIds) { ItemInfo ii = ItemInfo.Get(enhId); bool success = this._MyStepPanel.MyStepTabPanel.MyDisplayTabControl.DeleteRTBItem(ii); if (!success) Item.DeleteItemAndChildren(ii); } if (MyItemInfo.MyDocStyle != null && MyItemInfo.MyDocStyle.SupplementalInformation) { if (newFocus.MyItemInfo.IsInSupInfo) newFocus.AdjustAllForSupInfoHeight(); else { EditItem prvOrParSupInfo = newFocus.FindPreviousOrParentSupInfo(); if (prvOrParSupInfo != null) prvOrParSupInfo.AdjustAllForSupInfoHeight(); } } }
  private static void ForceEditItemRefresh(EditItem newFocus)
  {
   / bug fix
   / need to force a refresh from the level above the step that was removed.
   / this fixes a problem where the following step/substep wasn't shown on the screen (but was there)
   / and fixes a problem where the sequence numbers were off by one
   // and fixes a problem where an edit window would end up on top of the ones above it
   EditItem ei = newFocus;
   while (ei.MyPreviousEditItem != null) ei = ei.MyPreviousEditItem;
   if (ei.MyParentEditItem != null && ei.MyParentEditItem.MyItemInfo.IsStep)
    ei.MyParentEditItem.Expand(true);
  }
  public EditItem DeleteItem()
  {
   //Volian.Base.Library.VlnTimer _MyTimer = new VlnTimer();
   //_MyTimer.ActiveProcess = "_LookupEditItems.Remove";
   MyStepPanel._LookupEditItems.Remove(MyID);
   EditItem newFocus = null;
   int? TopMostParentY = (MyParentEditItem = null ? null : (int?)(MyParentEditItem.TopMostEditItem.Top));
   int? ParentY = (MyParentEditItem = null ? null : (int?)(MyParentEditItem.Top));
   try
   {
    //_MyTimer.ActiveProcess = "DeleteItemAndChildren";
    Item.DeleteItemAndChildren(MyItemInfo);
   }
   catch (System.Data.SqlClient.SqlException ex)
   {
    HandleSqlExceptionOnDelete(ex);
    return null;
   }
   // Remove EditItems
   //_MyTimer.ActiveProcess = "RemoveFromParentsChildList";
   RemoveFromParentsChildList();
   //_MyTimer.ActiveProcess = "MyNextEditItem";
   if (MyNextEditItem != null)
   {
    if (MyPreviousEditItem != null)
    {
     MyNextEditItem.MyPreviousEditItem = MyPreviousEditItem;
     MyPreviousEditItem = null;
     newFocus = MyNextEditItem;
    }
    else
    {
     MyNextEditItem.MyParentEditItem = MyParentEditItem;
     MyParentEditItem = null;
     MyNextEditItem.MyPreviousEditItem = null;
     newFocus = MyNextEditItem;
    }
    // Adjust the vertical locations of all of the items below the item deleted
    if (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format && MyNextEditItem.MyPreviousEditItem == null  &&
     (MyNextEditItem.MyItemInfo.IsNote || MyNextEditItem.MyItemInfo.IsCaution))
    {
     MyNextEditItem.MyParentEditItem.Top = (MyNextEditItem.MyParentEditItem.MyPreviousEditItem != null ? 
      MyNextEditItem.MyParentEditItem.MyPreviousEditItem.FindBottomDevDoc: MyNextEditItem.MyParentEditItem.MyParentEditItem.Bottom);
     MyNextEditItem.Top = MyNextEditItem.MyParentEditItem.Top;
     MyNextEditItem.AdjustLocation();
    }
    else
    {
     MyNextEditItem.TopMostEditItem.AdjustLocation();
    }
    MyNextEditItem = null;
   }
   else if (MyPreviousEditItem != null)
   {
    MyPreviousEditItem.MyNextEditItem = null;
    /newFocus = MyPreviousEditItem.BottomMostEditItem;
    / bug fix  - when deleting an edit window in the AER, position to the bottom most in the AER - was jumping to RNO
    newFocus = MyPreviousEditItem.BottomMostEditItemNoRNOs;
    if (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format && MyPreviousEditItem.MyNextEditItem == null &&
     (MyPreviousEditItem.MyItemInfo.IsNote || MyPreviousEditItem.MyItemInfo.IsCaution))
    {
     MyPreviousEditItem.MyParent.Top = MyPreviousEditItem.MyParent.MyPreviousEditItem.FindBottomDevDoc;
     MyPreviousEditItem.Top = MyPreviousEditItem.MyParent.Top;
     MyPreviousEditItem.MyParent.AdjustLocation();
    }
    MyPreviousEditItem = null;
    //Console.Write(",\"Previous\",");
   }
   else
   {
    newFocus = MyParentEditItem;
    MyParentEditItem = null;
    //Console.Write(",\"Parent\",");
   }
   //_MyTimer.ShowElapsedTimes("DeleteItem");
   return newFocus;
  }
//private void HandleSqlExceptionOnDelete(System.Data.SqlClient.SqlException ex) private void HandleSqlExceptionOnDelete(Exception ex) { this.MyStepRTB.InsertSymbol(@"\u160?"); // since text was deleted, insert a hard space to prevent a looping effect B2016-082 using (Item itm = MyStepRTB.MyItemInfo.Get()) { Annotation x = Annotation.MakeAnnotation(itm, AnnotationType.GetByName("Verification Required"), null, "A Hard Space was put in to keep the Transitions referencing here valid. \nPlease remove or re-assign these transitions before deleting this step.", null); } if (ex.Message.Contains("has External Transitions and has no next step")) { using (TransitionInfoList exTrans = TransitionInfoList.GetExternalTransitions(MyID)) { DialogResult ans = FlexibleMessageBox.Show("Transitions exist to this step and cannot be adjusted automatically." + "\r\n\r\nDo you want to be placed on the " + (exTrans.Count > 1 ? "first " : "") + "substep with the problem Transition?" + "\r\n\r\nSubsteps with Problem Transitions" + exTrans.Summarize(), "Cannot Delete This Step", MessageBoxButtons.YesNo, MessageBoxIcon.Question); if (ans == DialogResult.Yes) { MyStepPanel.MyStepTabPanel.MyDisplayTabControl.OpenItem(exTrans[0].MyContent.ContentItems[0]); } else SetFocus(); } } else if (ex.Message.Contains("has External Transitions to Procedure")) { using (TransitionInfoList exTrans = TransitionInfoList.GetExternalTransitionsToChildren(MyID)) { DialogResult ans = FlexibleMessageBox.Show("Transitions exist to this procedure." + "\r\n\r\nDo you want to be placed on the " + (exTrans.Count > 1 ? "first " : "") + "substep with the problem Transition?" + "\r\n\r\nSubsteps with Problem Transitions" + exTrans.Summarize(), "Cannot Delete This Procedure", MessageBoxButtons.YesNo, MessageBoxIcon.Question); if (ans == DialogResult.Yes) { MyStepPanel.MyStepTabPanel.MyDisplayTabControl.OpenItem(exTrans[0].MyContent.ContentItems[0]);
     }
     else
      SetFocus();
    }
   }
   else if (ex.Message.Contains("has External Transitions to it's children"))
   {
    using (TransitionInfoList exTrans = TransitionInfoList.GetExternalTransitionsToChildren(MyID))
    {
     DialogResult ans = FlexibleMessageBox.Show("Transitions exist to substeps of this step and cannot be adjusted automatically." +
      "\r\n\r\nDo you want to be placed on the " + (exTrans.Count > 1 ? "first " : "") + "substep with the problem Transition?" +
      "\r\n\r\nSubsteps with Problem Transitions:" +
      exTrans.Summarize(),
      "Cannot Delete This Step", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
     if (ans == DialogResult.Yes)
     {
      MyStepPanel.MyStepTabPanel.MyDisplayTabControl.OpenItem(exTrans[0].MyContent.ContentItems[0]);
     }
    }
   }
   else
    MessageBox.Show(ex.Message, "SQL Exception", MessageBoxButtons.OK, MessageBoxIcon.Exclamation);
  }
  private void RemoveFromParentsChildList()
  {
   EditItem top = this;
   while (top.MyPreviousEditItem != null) top = top.MyPreviousEditItem;
   EditItem parentEditItem = top.MyParentEditItem;
   if (parentEditItem = null) return; // No parent, nothing to remove.
   if (parentEditItem.MyAfterEditItems ! null && parentEditItem.MyAfterEditItems.Contains(this))
   {
    parentEditItem.MyAfterEditItems.Remove(this);
    if (parentEditItem.MyAfterEditItems.Count == 0)
     parentEditItem.MyAfterEditItems = null;
   }
   else if (parentEditItem.MyBeforeEditItems != null && parentEditItem.MyBeforeEditItems.Contains(this))
   {
    parentEditItem.MyBeforeEditItems.Remove(this);
    if (parentEditItem.MyBeforeEditItems.Count == 0)
     parentEditItem.MyBeforeEditItems = null;
   }
   else if (parentEditItem.MyRNOEditItems != null && parentEditItem.MyRNOEditItems.Contains(this))
   {
    parentEditItem.MyRNOEditItems.Remove(this);
    if (parentEditItem.MyRNOEditItems.Count == 0)
     parentEditItem.MyRNOEditItems = null;
   }
   else if (parentEditItem.MySupInfoEditItems != null && parentEditItem.MySupInfoEditItems.Contains(this))
   {
    parentEditItem.MySupInfoEditItems.Remove(this);
    if (parentEditItem.MySupInfoEditItems.Count == 0)
     parentEditItem.MySupInfoEditItems = null;
   }
   if (parentEditItem.MyAfterEditItems = null && parentEditItem.MyBeforeEditItems = null && parentEditItem.MyRNOEditItems == null)
    parentEditItem.CanExpand = false;
  }
  //private void ShowSiblings(string title)
  /{
  /  Console.WriteLine("—{0} {1}—",title,MyID);
  /  EditItem top = this;
  /  while (top.MyPreviousEditItem != null) top = top.MyPreviousEditItem;
  /  do
  /  {
  /    Console.WriteLine("{0} EditItem - {1} {2}", top.MyID == MyID ? "*" : " ", top.MyID, top.MyItemInfo.MyContent.Text);
  /    top = top.MyNextEditItem;
  /  } while (top != null);
  /}
  #endregion
  #region Add Children
  / <summary>
  / Add a child before (Notes, Cautions, etc.)
  / </summary>
  / <param name="myItemInfo"></param>
  / <param name="expand"></param>
  public void AddChildBefore(ItemInfo myItemInfo, bool expand)
  {
   EditItem child = new RTBItem(myItemInfo, MyStepPanel, this, ChildRelation.Before, expand);
  }
  / <summary>
  / Add a list of children before
  / </summary>
  / <param name="myItemInfoList"></param>
  / <param name="expand"></param>
  public void AddChildBefore(ItemInfoList myItemInfoList, bool expand)
  {
   if (myItemInfoList != null)
    foreach (ItemInfo item in myItemInfoList)
     AddChildBefore(item, expand);
  }
  public EditItem AddChildBefore(ItemInfoList myItemInfoList, EditItem nextEditItem)
  {
   EditItem child = null;
   if (myItemInfoList != null)
    foreach (ItemInfo item in myItemInfoList)
     child = AddChildBefore(item, nextEditItem);
   return child;
  }
  / <summary>
  / Add an RNO (Contingency) child
  / </summary>
  / <param name="myItemInfo"></param>
  / <param name="expand"></param>
  public void AddChildRNO(ItemInfo myItemInfo, bool expand)
  {
   EditItem child = new RTBItem(myItemInfo, MyStepPanel, this, ChildRelation.RNO, expand);
  }
  public void AddChildSupInfo(ItemInfo myItemInfo, bool expand)
  {
   EditItem child = new RTBItem(myItemInfo, MyStepPanel, this, ChildRelation.SupInfo, expand);
  }
  / <summary>
  / Add a list of RNO (Contingency) children
  / </summary>
  / <param name="myItemInfoList"></param>
  / <param name="expand"></param>
  public void AddChildRNO(ItemInfoList myItemInfoList, bool expand)
  {
   if (myItemInfoList != null)
    foreach (ItemInfo item in myItemInfoList)
     AddChildRNO(item, expand);
  }
  public void AddChildSupInfo(ItemInfoList myItemInfoList, bool expand)
  {
   if (myItemInfoList != null)
    foreach (ItemInfo item in myItemInfoList)
     AddChildSupInfo(item, expand);
  }
  / <summary>
  / Add a child after
  / </summary>
  / <param name="MyItemInfo"></param>
  / <param name="expand"></param>
  public EditItem AddChildAfter(ItemInfo MyItemInfo, bool expand, bool addFirstChld)
  {
   EditItem child = null;
   if (MyItemInfo.IsFigure)
    child = new ImageItem(MyItemInfo, MyStepPanel, this, ChildRelation.After, expand);
   else if (MyItemInfo.IsRtfRaw)
    child = new RtfRawItem(MyItemInfo, MyStepPanel, this, ChildRelation.After, expand);
   else if (MyItemInfo.MyContent.MyGrid != null)
    child = new GridItem(MyItemInfo, MyStepPanel, this, ChildRelation.After, expand);
   else
    child = new RTBItem(MyItemInfo, MyStepPanel, this, ChildRelation.After, expand, addFirstChld);
   return child;
  }
  public EditItem AddChildAfter(ItemInfo MyItemInfo, EditItem nextEditItem)
  {
   EditItem child = null;
   if (MyItemInfo.IsFigure)
    child = new ImageItem(MyItemInfo, MyStepPanel, this, ChildRelation.After, true, nextEditItem, FigInsType);
   else if (MyItemInfo.IsRtfRaw)
    child = new RtfRawItem(MyItemInfo, MyStepPanel, this, ChildRelation.After, true, nextEditItem);
   else if (MyItemInfo.MyContent.MyGrid != null)
    child = new GridItem(MyItemInfo, MyStepPanel, this, ChildRelation.After, true, nextEditItem);
   else
    child = new RTBItem(MyItemInfo, MyStepPanel, this, ChildRelation.After, true, nextEditItem);
   return child;
  }
  public EditItem AddChildBefore(ItemInfo MyItemInfo, EditItem nextEditItem)
  {
   EditItem child = null;
   if (MyItemInfo.IsFigure)
    child = new ImageItem(MyItemInfo, MyStepPanel, this, ChildRelation.Before, true, nextEditItem, FigInsType);
   else if (MyItemInfo.IsRtfRaw)
    child = new RtfRawItem(MyItemInfo, MyStepPanel, this, ChildRelation.Before, true, nextEditItem);
   if(MyItemInfo.MyContent.MyGrid != null)
    child = new GridItem(MyItemInfo, MyStepPanel, this, ChildRelation.Before, true, nextEditItem);
   else
    child = new RTBItem(MyItemInfo, MyStepPanel, this, ChildRelation.Before, true, nextEditItem);
   return child;
  }
  public EditItem AddChildRNO(ItemInfo MyItemInfo, EditItem nextEditItem)
  {
   // not sure about this, i.e. whether a grid can be added here.
   EditItem child = null;
   //if (MyItemInfo.MyContent.ContentGridCount != 0)
   if (MyItemInfo.MyContent.MyGrid != null)
    child = new GridItem(MyItemInfo, MyStepPanel, this, ChildRelation.RNO, true, nextEditItem);
   else
    child = new RTBItem(MyItemInfo, MyStepPanel, this, ChildRelation.RNO, true, nextEditItem);
   return child;
  }
  public EditItem AddChildSupInfo(ItemInfo MyItemInfo, EditItem nextEditItem)
  {
   EditItem child = null;
   if (MyItemInfo.MyContent.MyGrid != null)
    child = new GridItem(MyItemInfo, MyStepPanel, this, ChildRelation.SupInfo, true, nextEditItem);
   else
    child = new RTBItem(MyItemInfo, MyStepPanel, this, ChildRelation.SupInfo, true, nextEditItem);
   return child;
  }
  / <summary>
  / Adds a sibling after the current EditItem
  / </summary>
  public void AddSiblingAfter()
  {
   AddSiblingAfter("", true);
  }
  public void AddSiblingAfter(string text, bool updateStatus)
  {
   SaveContents();
   ItemInfo newItemInfo = MyItemInfo.InsertSiblingAfter(text);
   AddGridIfNeeded(newItemInfo);
   AddImageIfNeeded(newItemInfo);
   DoAddSiblingAfter(newItemInfo, updateStatus);
   if (MyStepPanel.SelectedEditItem is RTBItem)
   {
    RTBItem rtbi = MyStepPanel.SelectedEditItem as RTBItem;
    / see if this step has associated enhanced step(s).  If it does, flag it so 
    / that the enhanced steps get inserted also.
    StepConfig sc = new StepConfig(MyItemInfo.MyContent.Config);
    if (sc.MyEnhancedDocuments.Count > 0)
    {
     rtbi.EnhAddFromItemInfo = MyItemInfo;
     rtbi.EnhAddType = EnhancedAddTypes.After;
    }
   }
  }
  / This logic allows us to do an Insert Before and Insert After while on a Table
  / if allowed by the format
  private void AddGridIfNeeded(ItemInfo newItemInfo)
  {
   if (this is GridItem)
   {
    GridItem gi = this as GridItem;
    VlnFlexGrid fg = new VlnFlexGrid(gi.MyFlexGrid.Rows.Count, gi.MyFlexGrid.Cols.Count);
    / bug fix B2015136
    / need to copy the font used in the table we are doing the Insert Previous/Next from.
    VE_Font vefont = MyItemInfo.ActiveFormat.PlantFormat.FormatData.StepDataList.Table.Font;
    Font GridFont = new Font(vefont.Family, (float)vefont.Size);
    fg.Font = GridFont;
    using (Item itm = newItemInfo.Get())
    {
     itm.MyContent.MyGrid.Data = fg.GetXMLData();
     itm.Save();
    }
   }
  }
  / This logic allows us to do an Insert Before and Insert After while on a Figure
  / if allowed by the format.  Note that Before/After for figures is only Clipboard (if
  / image data exists in clipboard), or file. Doing RO images will be added later if needed - 
  / this decision was made because of scope.
  private void AddImageIfNeeded(ItemInfo newItemInfo)
  {
   if (this is ImageItem) ImageItem.AddImageIfNeeded(newItemInfo);
  }
  public void AddSiblingAfter(int? type, bool updateStatus)
  {
   SaveContents();
   ItemInfo newItemInfo = MyItemInfo.InsertSiblingAfter("", "", type);
   AddGridIfNeeded(newItemInfo);
   AddImageIfNeeded(newItemInfo);
   DoAddSiblingAfter(newItemInfo, updateStatus);
   if (MyStepPanel.SelectedEditItem is RTBItem)
   {
    RTBItem rtbi = MyStepPanel.SelectedEditItem as RTBItem;
    / see if this step has associated enhanced step(s).  If it does, flag it so 
    / that the enhanced steps get inserted also.
    StepConfig sc = new StepConfig(MyItemInfo.MyContent.Config);
    if (sc.MyEnhancedDocuments.Count > 0)
    {
     rtbi.EnhAddFromItemInfo = MyItemInfo;
     rtbi.EnhAddType = EnhancedAddTypes.After;
    }
   }
  }
  private void DoAddSiblingAfter(ItemInfo newItemInfo, bool updateStatus)
  {
   EditItem newEditItem = null;
   switch (_MyChildRelation)
   {
    case ChildRelation.After:
     newEditItem = ActiveParent.AddChildAfter(newItemInfo, MyNextEditItem);
     break;
    case ChildRelation.Before:
     newEditItem = ActiveParent.AddChildBefore(newItemInfo, MyNextEditItem);
     break;
    case ChildRelation.RNO:
     newEditItem = ActiveParent.AddChildRNO(newItemInfo, MyNextEditItem);
     break;
    case ChildRelation.SupInfo:
     newEditItem = ActiveParent.AddChildSupInfo(newItemInfo, MyNextEditItem);
     break;
    default: // Need debug
     break;
   }
   //EditItem newEditItem = ActiveParent.AddChildAfter(newItemInfo, );
   if (updateStatus)
    MyStepPanel.SelectedEditItem = newEditItem;//Update Screen
  }
  protected static int _WatchThis = 1;
  public void AddSiblingBefore()
  {
   AddSiblingBefore("", true);
  }
  public void AddSiblingBefore(int? type, bool updateStatus)
  {
   SaveContents();
   ItemInfo newItemInfo = MyItemInfo.InsertSiblingBefore("", "",type);
   AddGridIfNeeded(newItemInfo);
   AddImageIfNeeded(newItemInfo);
   DoAddSiblingBefore(newItemInfo, updateStatus);
  }
  public void AddSiblingBefore(string text, bool updateSelection)
  {
   / Save RTB text before creating a new item because the process of creating 
   / a new item will save a change to iteminfo excluding text changes. This 
   / shouldn't be necessary for adding sibling after because the current step
   / doesn't get saved during the insert after because of the MyPrevious field
   / is only set on an insert before, which is what saves the item without
   / any updates from the richtextbox text.
   SaveContents();
   ItemInfo newItemInfo = MyItemInfo.InsertSiblingBefore(text);
   AddGridIfNeeded(newItemInfo);
   AddImageIfNeeded(newItemInfo);
   DoAddSiblingBefore(newItemInfo, updateSelection);
   if (MyStepPanel.SelectedEditItem is RTBItem)
   {
    RTBItem rtbi = MyStepPanel.SelectedEditItem as RTBItem;
    / see if this step has associated enhanced step(s).  If it does, flag it so 
    / that the enhanced steps get inserted also.
    StepConfig sc = new StepConfig(MyItemInfo.MyContent.Config);
    if (sc.MyEnhancedDocuments.Count > 0)
    {
     rtbi.EnhAddFromItemInfo = MyItemInfo;
     rtbi.EnhAddType = EnhancedAddTypes.Before;
    }
   }
  }
  public void DoAddSiblingBefore(ItemInfo newItemInfo, bool updateSelection)
  {
   EditItem newEditItem = null;
   switch (_MyChildRelation)
   {
    case ChildRelation.After:
     newEditItem = ActiveParent.AddChildAfter(newItemInfo, this);
     break;
    case ChildRelation.Before:
     newEditItem = ActiveParent.AddChildBefore(newItemInfo, this);
     break;
    case ChildRelation.RNO:
     newEditItem = ActiveParent.AddChildRNO(newItemInfo, this);
     break;
    case ChildRelation.SupInfo:
     newEditItem = ActiveParent.AddChildSupInfo(newItemInfo, this);
     break;
    default: // Need debug
     break;
   }
   if (updateSelection)
    MyStepPanel.SelectedEditItem = newEditItem;//Update Screen
  }
  public void AddSiblingBeforeNoDataSave(ItemInfo newItemInfo, bool updateSelection, EditItem tt)
  {
   EditItem newEditItem = null;
   newEditItem = ActiveParent.AddChildBefore(newItemInfo, this);
   //switch (_MyChildRelation)
   /{
   /    case ChildRelation.After:
   /        newEditItem = ActiveParent.AddChildAfter(newItemInfo, this);
   /        break;
   /    case ChildRelation.Before:
   /        newEditItem = ActiveParent.AddChildBefore(newItemInfo, this);
   /        break;
   /    case ChildRelation.RNO:
   /        newEditItem = ActiveParent.AddChildRNO(newItemInfo, this);
   /        break;
   /    default: / Need debug
   /        break;
   /}
   if (updateSelection)
    MyStepPanel.SelectedEditItem = newEditItem;//Update Screen
  }
  private bool specialAdd = false;
  public void AddSiblingBeforeNoDataSave(ItemInfoList newItemInfos, bool updateSelection)
  {
   specialAdd = true;
   EditItem newEditItem = null;
   newEditItem = ActiveParent.AddChildAfter(newItemInfos, false, true);
   if (updateSelection)
    MyStepPanel.SelectedEditItem = newEditItem;//Update Screen
   specialAdd = false;
  }
  private ImageItem.E_ImageSource FigInsType = ImageItem.E_ImageSource.None;
  public void AddChild(E_FromType fromType, int type, ImageItem.E_ImageSource newSource)
  {
   FigInsType = newSource;
   AddChild("", fromType, type, null);
   FigInsType = ImageItem.E_ImageSource.None;
  }
  public void AddChild(E_FromType fromType, int type)
  {
   AddChild("", fromType, type, null);
  }
  public void AddChild(E_FromType fromType, int type, VlnFlexGrid vfGrid)
  {
   AddChild("", fromType, type, vfGrid);
  }
  public void AddChild(string text, E_FromType fromType, int type, VlnFlexGrid vfGrid)
  {
   if ((_MyItemInfo.IsHigh && !MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format) || _MyItemInfo.IsSection)
    CanExpand = true;
   this.Expanded = true;
   _WatchThis = 1;
   ItemInfo newItemInfo = MyItemInfo.InsertChild(fromType, type, text);
   if (vfGrid != null)
   {
    string xml = vfGrid.GetXMLData();
    using (Item itm = newItemInfo.Get())
    {
     itm.MyContent.MyGrid.Data = xml;
     itm.Save();
     / newItemInfo.MyContent.MyGrid.ResetContent(itm.MyContent.MyGrid);  / Do I need this?
    }
   }
   // TODO: We need to determine where this will go in the stack of children
   EditItem nextItem = GetNextItem(fromType, newItemInfo);
   / TODO:  May need similar logic if a Table is being added to a step that has substeps
   /   else if (fromType = E_FromType.Table && ((ItemInfo)newItemInfo.ActiveParent).Steps ! null
   /&& ((ItemInfo)newItemInfo.ActiveParent).Steps.Count > 0)
   /     nextItem = MyStepPanel.FindItem(((ItemInfo)newItemInfo.ActiveParent).Steps[0]);
   EditItem newEditItem;
   switch (fromType)
   {
    case E_FromType.Caution:
     newEditItem = this.AddChildBefore(newItemInfo, nextItem);
     break;
    case E_FromType.Note:
     newEditItem = this.AddChildBefore(newItemInfo, nextItem);
     break;
    case E_FromType.Procedure:
     newEditItem = this.AddChildAfter(newItemInfo, nextItem);
     break;
    case E_FromType.RNO:
     newEditItem = this.AddChildRNO(newItemInfo, nextItem);
     break;
    case E_FromType.Section:
     newEditItem = this.AddChildAfter(newItemInfo, nextItem);
     break;
    case E_FromType.Step:
     newEditItem = this.AddChildAfter(newItemInfo, nextItem);
     break;
    case E_FromType.Table:
     newEditItem = this.AddChildAfter(newItemInfo, nextItem);
     break;
    case E_FromType.SupInfo:
     newEditItem = this.AddChildSupInfo(newItemInfo, nextItem);
     break;
    default:
     newEditItem = this.AddChildAfter(newItemInfo, nextItem);
     break;
   }
   MyStepPanel.SelectedEditItem = newEditItem;//Update Screen
   if (MyStepPanel.SelectedEditItem is RTBItem)
   {
    RTBItem rtbi = MyStepPanel.SelectedEditItem as RTBItem;
    / see if this step has associated enhanced step(s).  If it does, flag it so 
    / that the enhanced steps get inserted also.
    EnhancedDocuments cfgeds = null;
    if (MyItemInfo.IsStepSection)
    {
     SectionConfig scfg = MyItemInfo.MyConfig as SectionConfig;
     if (scfg.Section_LnkEnh != "Y") return;
     cfgeds = scfg.MyEnhancedDocuments;
    }
    else
    {
     StepConfig sc = new StepConfig(MyItemInfo.MyContent.Config);
     cfgeds = sc.MyEnhancedDocuments;
    }
    if (cfgeds != null && cfgeds.Count > 0)
    {
     rtbi.EnhAddFromItemInfo = MyItemInfo;
     rtbi.EnhAddType = EnhancedAddTypes.Child;
    }
   }
  }
  public EditItem GetNextItem(E_FromType fromType, ItemInfo newItemInfo)
  {
   EditItem nextItem = null;
   if (newItemInfo.NextItem != null)
    nextItem = MyStepPanel.FindItem(newItemInfo.NextItem);
   else if (fromType = E_FromType.Table && MyAfterEditItems ! null)
    nextItem = MyAfterEditItems[0];
   // Cautions come before notes, so if this is a Caution and there are Notes, put this first 
   else if (fromType = E_FromType.Caution && ((ItemInfo)newItemInfo.ActiveParent).Notes ! null
    && ((ItemInfo)newItemInfo.ActiveParent).Notes.Count > 0)
    nextItem = MyStepPanel.FindItem(((ItemInfo)newItemInfo.ActiveParent).Notes[0]);
   return nextItem;
  }
  / <summary>
  / Add a list of children after
  / </summary>
  / <param name="myItemInfoList"></param>
  / <param name="expand"></param>
  public EditItem AddChildAfter(ItemInfoList myItemInfoList, bool expand, bool addFirstChld)
  {
   EditItem child = null;
   int indx = 0;
   if (myItemInfoList != null)
    foreach (ItemInfo item in myItemInfoList)
    {
     if (addFirstChld)
     {
      // the first time add it as first child, the rest should be done in between.
      child = AddChildAfter(item, expand, addFirstChld);
      addFirstChld = false;
     }
     else
      child = AddChildAfter(item, this._MyAfterEditItems[indx]);
     indx++;
    }
   return child;
  }
  public EditItem AddChildAfter(ItemInfoList myItemInfoList, bool expand)
  {
   EditItem child = null;
   if (myItemInfoList != null)
    foreach (ItemInfo item in myItemInfoList)
     child = AddChildAfter(item, expand, false);
   return child;
  }
  public EditItem AddChildAfter(ItemInfoList myItemInfoList, EditItem nextEditItem)
  {
   EditItem child = null;
   if (myItemInfoList != null)
    foreach (ItemInfo item in myItemInfoList)
     child = AddChildAfter(item, nextEditItem);
   return child;
  }
  #endregion
  #region CopyPaste
  public void PasteSiblingBefore(int copyStartID)
  {
   ItemInfo newItemInfo = MyItemInfo.PasteSiblingBefore(copyStartID, GetChangeId(MyItemInfo));
if (newItemInfo.ItemID == MyItemInfo.ItemID) return;
EditItem newEditItem = null; switch (_MyChildRelation) { case ChildRelation.After: newEditItem = ActiveParent.AddChildAfter(newItemInfo, this); break; case ChildRelation.Before: newEditItem = ActiveParent.AddChildBefore(newItemInfo, this); break; case ChildRelation.RNO: newEditItem = ActiveParent.AddChildRNO(newItemInfo, this); break; case ChildRelation.SupInfo: newEditItem = ActiveParent.AddChildSupInfo(newItemInfo, this); break; default: // Need debug break; } if (newEditItem != null) MyStepPanel.SelectedEditItem = newEditItem;//Update Screen MyStepPanel.MyStepTabPanel.MyDisplayTabControl.OnItemPaste(this, new vlnTreeItemInfoPasteEventArgs(newItemInfo, copyStartID, ItemInfo.EAddpingPart.Before, newItemInfo.MyContent.Type));
// MyItemInfo is the 'paste from' item, if it has enhanced need to copy and paste the steps in enhanced. ItemInfo newEnh = newItemInfo.EnhancedPasteItem(copyStartID, MyItemInfo, ItemInfo.EAddpingPart.Before, GetChangeId(MyItemInfo)); // if enhanced items were created, then see if they need displayed: if (newEnh != null) AddAllEnhancedItemsToDisplay(newItemInfo); } private void AddAllEnhancedItemsToDisplay(ItemInfo newItemInfo) { EnhancedDocuments eds = newItemInfo.GetMyEnhancedDocuments(); if (eds != null && eds.Count > 0) { foreach (EnhancedDocument ed in eds) AddEnhancedItemToDisplayTabItem(ItemInfo.Get(ed.ItemID)); } } public void AddEnhancedItemToDisplayTabItem(ItemInfo newEnh) { / if tabcontrol was open for enhanced, display the steps: ItemInfo proc = newEnh.MyProcedure; / Find procedure Item string key = "Item - " + proc.ItemID.ToString(); if (MyStepPanel.MyStepTabPanel.MyDisplayTabControl._MyDisplayTabItems.ContainsKey(key)) { DisplayTabItem pg = MyStepPanel.MyStepTabPanel.MyDisplayTabControl._MyDisplayTabItems[key]; / _MyDisplayTabItems (in line above) had tabs that were closed, so use the next line / to validate that the tab is still open. foreach (DisplayTabItem ti in MyStepPanel.MyStepTabPanel.MyDisplayTabControl.MyBar.Items) { if (ti == pg) pg.MyStepTabPanel.MyStepPanel.GetEditItem(newEnh); } } } public void CreateLinksEnhancedSingleItem(ItemInfo srcII, ItemInfo enhII, int enhtype) { srcII.DoCreateLinksEnhancedSingleItem(enhII, enhtype); SetFocus(); } public void CreateLinksEnhancedAllInProcedure(ItemInfo srcII, ItemInfo enhII, int enhtype) { using (ContentInfoList cil = ContentInfoList.Convert16To32EnhancedContents(srcII.ItemID, enhII.ItemID, enhtype)) { foreach (ContentInfo ci in cil) { using (Content c = ci.Get()) { / first refresh configs because the ContentInfo.Refresh causes events to occur that refresh screen / and if configs aren't done first, the screen refresh, if based on config data, will not be correct. foreach (ItemInfo ii in ci.ContentItems) ii.RefreshConfig(); ContentInfo.Refresh(c); } } } } public void UnlinkEnhanced(ItemInfo enhII) { enhII.DoUnlinkEnhanced(enhII); SetFocus(); } public ItemInfo AddMissingEnhancedStep(ItemInfo ii, int EnhType) { / if the missing enhanced step is a caution or note, check that parent HLS has the needed / enhanced step to insert the caution/note from. If not, do a message. if (ii.IsCaution || ii.IsNote) { bool canMakeMissingStep = false; StepConfig sc = ii.MyHLS.MyConfig as StepConfig; foreach (EnhancedDocument ed in sc.MyEnhancedDocuments) { if (EnhType == ed.Type) // the hls has an enhanced linked step of this type, the caution/note can be made: { canMakeMissingStep = true; break; } } if (!canMakeMissingStep) { MessageBox.Show("Cannot create the missing enhanced step, the Enhanced Step for the High Level step must be created first."); return null; } } ItemInfo newEnh = ii.DoAddMissingEnhancedItems(EnhType); // if enhanced items were created, then see if they need displayed: if (newEnh != null) AddAllEnhancedItemsToDisplay(MyItemInfo); SetFocus(); return newEnh; } private string GetChangeId(ItemInfo iiDest) { // get the change id for the destination's procedure's change id. string chgid = null; if (iiDest.ActiveFormat.PlantFormat.FormatData.ProcData.ChangeBarData.ChangeIds) chgid = MyStepPanel.MyStepTabPanel.MyDisplayTabControl.ItemsChangeIds[iiDest.MyProcedure.ItemID]; return chgid; } public void PasteSiblingAfter(int copyStartID) { ItemInfo newItemInfo = MyItemInfo.PasteSiblingAfter(copyStartID, GetChangeId(MyItemInfo)); if (newItemInfo.ItemID == MyItemInfo.ItemID) return; EditItem newEditItem = null; switch (_MyChildRelation) { case ChildRelation.After: newEditItem = ActiveParent.AddChildAfter(newItemInfo, MyNextEditItem); break; case ChildRelation.Before: newEditItem = ActiveParent.AddChildBefore(newItemInfo, MyNextEditItem); break; case ChildRelation.RNO: newEditItem = ActiveParent.AddChildRNO(newItemInfo, MyNextEditItem); break; case ChildRelation.SupInfo: newEditItem = ActiveParent.AddChildSupInfo(newItemInfo, MyNextEditItem); break; default: // Need debug break; } MyStepPanel.SelectedEditItem = newEditItem;//Update Screen MyStepPanel.MyStepTabPanel.MyDisplayTabControl.OnItemPaste(this, new vlnTreeItemInfoPasteEventArgs(newItemInfo, copyStartID, ItemInfo.EAddpingPart.After, newItemInfo.MyContent.Type));
// MyItemInfo is the 'paste from' item, if it has enhanced need to copy and paste the steps in enhanced. ItemInfo newEnh = newItemInfo.EnhancedPasteItem(copyStartID, MyItemInfo, ItemInfo.EAddpingPart.After, GetChangeId(MyItemInfo)); if (newEnh != null) AddAllEnhancedItemsToDisplay(newItemInfo); } public void PasteChild(int copyStartID) { ItemInfo newItemInfo = MyItemInfo.PasteChild(copyStartID, GetChangeId(MyItemInfo));
E_FromType fromType = E_FromType.Step; if (MyItemInfo.MyContent.Type < 10000) fromType = E_FromType.Procedure; else if (MyItemInfo.MyContent.Type < 20000) fromType = E_FromType.Section; else if (MyItemInfo.MyContent.Type > 19999) { int tmptype = (int)MyItemInfo.MyContent.Type - 20000; if (MyItemInfo.IsCaution) fromType = E_FromType.Caution; else if (MyItemInfo.IsNote) fromType = E_FromType.Note; else if (MyItemInfo.IsTable) fromType = E_FromType.Table; else if (MyItemInfo.IsRNOPart) fromType = E_FromType.RNO; else if (MyItemInfo.IsSupInfoPart) fromType = E_FromType.SupInfo; } EditItem nextItem = GetNextItem(fromType, newItemInfo); EditItem newEditItem;
switch (fromType) { case E_FromType.Caution: newEditItem = this.AddChildBefore(newItemInfo, nextItem); break; case E_FromType.Note: newEditItem = this.AddChildBefore(newItemInfo, nextItem); break; case E_FromType.Procedure: newEditItem = this.AddChildAfter(newItemInfo, nextItem); break; case E_FromType.RNO: newEditItem = this.AddChildRNO(newItemInfo, nextItem); break; case E_FromType.Section: newEditItem = this.AddChildAfter(newItemInfo, nextItem); break; case E_FromType.Step: newEditItem = this.AddChildAfter(newItemInfo, nextItem); break; case E_FromType.Table: newEditItem = this.AddChildAfter(newItemInfo, nextItem); break; case E_FromType.SupInfo: newEditItem = this.AddChildSupInfo(newItemInfo, nextItem); break; default: newEditItem = this.AddChildAfter(newItemInfo, nextItem); break; } MyStepPanel.SelectedEditItem = newEditItem;//Update Screen
// MyItemInfo is the 'paste from' item, if it has enhanced need to copy and paste the steps in enhanced. ItemInfo newEnh = newItemInfo.EnhancedPasteItem(copyStartID, MyItemInfo, ItemInfo.EAddpingPart.Child, GetChangeId(MyItemInfo)); if (newEnh != null) AddAllEnhancedItemsToDisplay(newItemInfo); } public EditItem PasteReplace(int copyStartID) { / To allow a Paste Step into an empty (new) step/substep, we need to add a character to the the Text field / to simulate replacing an existing step - otherwise we will get null references. if (MyStepPanel.SelectedEditItem.Empty) MyStepPanel.SelectedEditItem.Empty=false; MyStepPanel.SelectedEditItem = null; // Unselect the item to be deleted ChildRelation childRelation = _MyChildRelation; EditItem newFocus = null; EditItem nextEditItem = MyNextEditItem; EditItem prevEditItem = MyPreviousEditItem; EditItem parentEditItem = ActiveParent;
   StepConfig savOrigPasteConfig = MyItemInfo.MyConfig as StepConfig;
   int TopMostYBefore = TopMostEditItem.Top;
   int? TopMostParentY = (MyParentEditItem = null ? null : (int?)(MyParentEditItem.TopMostEditItem.Top));
   int? ParentY = (MyParentEditItem = null ? null : (int?)(MyParentEditItem.Top));
   ItemInfo newItemInfo = null;
   try
   {
    newItemInfo = Item.PasteReplace(MyItemInfo, copyStartID, GetChangeId(MyItemInfo));
   }
   //catch (System.Data.SqlClient.SqlException ex)
   catch (Exception ex)
   {
        if (HandleSqlExceptionOnCopy(ex)) return this;
    HandleSqlExceptionOnDelete(ex);
    return this;
   }
   // Remove the EditItem that was the replaced item.
   RemoveFromParentsChildList();
if (MyNextEditItem != null) { if (MyPreviousEditItem != null) { MyNextEditItem.MyPreviousEditItem = MyPreviousEditItem; MyPreviousEditItem = null; } else { MyNextEditItem.MyParentEditItem = MyParentEditItem; MyParentEditItem = null; MyNextEditItem.MyPreviousEditItem = null; } MyNextEditItem = null; } else if (MyPreviousEditItem != null) { MyPreviousEditItem.MyNextEditItem = null; newFocus = MyPreviousEditItem; MyPreviousEditItem = null; } else { newFocus = MyParentEditItem; MyParentEditItem = null; }
// add copied item to ui where the replaced item was. EditItem newEditItem = null; switch (childRelation) { case ChildRelation.After: newEditItem = parentEditItem.AddChildAfter(newItemInfo, nextEditItem); break; case ChildRelation.Before: newEditItem = parentEditItem.AddChildBefore(newItemInfo, nextEditItem); break; case ChildRelation.RNO: newEditItem = parentEditItem.AddChildRNO(newItemInfo, nextEditItem); break; case ChildRelation.SupInfo: newEditItem = parentEditItem.AddChildSupInfo(newItemInfo, nextEditItem); break; default: // Need debug break; } MyStepPanel.SelectedEditItem = newEditItem; //Update Screen MyStepPanel.MyStepTabPanel.MyDisplayTabControl.OnItemPaste(this, new vlnTreeItemInfoPasteEventArgs(newItemInfo, copyStartID, ItemInfo.EAddpingPart.Replace, newItemInfo.MyContent.Type)); // MyItemInfo is the 'paste from' item, if it has enhanced need to copy and paste the steps in enhanced. ItemInfo newEnh = newItemInfo.PasteEnhancedItems(copyStartID, MyItemInfo, ItemInfo.EAddpingPart.Replace, GetChangeId(MyItemInfo)); if (newEnh != null) AddAllEnhancedItemsToDisplay(newItemInfo); // KBR - I think this won't work for replace!! return newEditItem; } private bool HandleSqlExceptionOnCopy(Exception ex) { if (ex.Message.Contains("This step has been deleted")) { MessageBox.Show("The step being pasted has been deleted", "Cannot Paste Step", MessageBoxButtons.OK, MessageBoxIcon.Hand); return true; } if(ex.Message.Contains("This current step has been deleted in another session")) { MessageBox.Show("The highlighted step has been deleted by another user.", "Cannot Paste Step", MessageBoxButtons.OK, MessageBoxIcon.Hand); return true; } return false; } public void IdentifyChildren(bool highlight) { // Highlight children of EditItem: if (MyAfterEditItems != null) { foreach (EditItem sia in MyAfterEditItems) { sia.IdentifyMe(highlight); sia.IdentifyChildren(highlight); } } if (MyBeforeEditItems != null) { foreach (EditItem sib in MyBeforeEditItems) { sib.IdentifyMe(highlight); sib.IdentifyChildren(highlight); } } if (MyRNOEditItems != null) { foreach (EditItem sir in MyRNOEditItems) { sir.IdentifyMe(highlight); sir.IdentifyChildren(highlight); } } if (MySupInfoEditItems != null) { foreach (EditItem sis in MySupInfoEditItems) { sis.IdentifyMe(highlight); sis.IdentifyChildren(highlight); } } } #endregion #region Event Handlers private string WatchThisIndent { get { return "".PadLeft(_WatchThis, '\t'); } } protected bool RNOBelow { get { if (_MyRNOEditItems != null) { return _MyRNOEditItems[0].RNOLevel > _MyItemInfo.ColumnMode; //return _MyRNOEditItems[0].Left == Left; } return false; } } protected bool RNORight { get { if (_MyRNOEditItems != null) { return _MyRNOEditItems[0].RNOLevel <= _MyItemInfo.ColumnMode; //return _MyRNOEditItems[0].Left != Left; } return false; } } protected void MoveRNO() { if (_MyRNOEditItems != null) { if (_MyRNOEditItems[0].TopMostEditItem.Top != Top) { //if(_MyLog.IsDebugEnabled)_MyLog.DebugFormat("\r\n'Adjust RNO',{0},'Move',{1}", MyID, _RNO[0].MyID); EditItem rnoTop = _MyRNOEditItems[0].TopMostEditItem; if (rnoTop.RNOLevel <= _MyItemInfo.ColumnMode) { //EditItem tmpBottom = this; //if (_MyAfterEditItems != null) tmpBottom = _MyAfterEditItems[_MyAfterEditItems.Count - 1].BottomMostEditItem; MyStepPanel.ItemMoving++; rnoTop.LastMethodsPush(string.Format("EditItem_Move RNO Right {0}", rnoTop.MyID)); //rnoTop.Top = tmpBottom.Bottom; if (rnoTop.Top != Top) rnoTop.Top = Top; rnoTop.LastMethodsPop(); MyStepPanel.ItemMoving–; } else { MyStepPanel.ItemMoving++; rnoTop.LastMethodsPush(string.Format("EditItem_Move RNO Below {0} {1} {2}", rnoTop.MyID, BottomMostEditItemNoRNOs.MyID, BottomMostEditItemNoRNOs.Bottom)); if (rnoTop.Top != BottomMostEditItemNoRNOs.Bottom) rnoTop.Top = BottomMostEditItemNoRNOs.Bottom; rnoTop.LastMethodsPop(); MyStepPanel.ItemMoving–; } } } } protected void MoveSupInfo() // If the current item has supplemental information, be sure its top location is that of the current item. { if (_MySupInfoEditItems != null && _MySupInfoEditItems.Count > 0) { EditItem supInfoTop = _MySupInfoEditItems[0].TopMostEditItem; if (supInfoTop.Top != Top + supInfoTop.SupInfoTopOffset) { MyStepPanel.ItemMoving++; supInfoTop.LastMethodsPush(string.Format("EditItem_Move SupInfo Right {0}", supInfoTop.MyID)); supInfoTop.Top = Top + supInfoTop.SupInfoTopOffset; supInfoTop.LastMethodsPop(); MyStepPanel.ItemMoving–; } } } private bool _TryAgainLater = false; public bool TryAgainLater { get { return _TryAgainLater; } set { _TryAgainLater = value; } } //static bool _ShowChanges=false; int _LastTop = 0;
  // Bug Fix:  B2017-059 only turn on the spellchecking if the RTB is visible.  This controls the number of windows handles created durning spellchecking
  private void TurnOnSpellCheckIfVisible()
  {
   if (MyStepRTB != null)
   {
    if (this.Top + this.Height > 0 && this.Top < MyStepPanel.Height)
     MyStepRTB.SpellCheckStatus = true;
    else
     MyStepRTB.SpellCheckStatus = false;
   }
  }
  / <summary>
  / Handles movement of the EditItems
  / </summary>
  / <param name="sender"></param>
  / <param name="e"></param>
  / use the following to debug if two steps are to be displayed one right after the other vertically, but they are getting separated, overwritten,
  / gaps.  See code below at the beginning of EditItem_Move that uses these.
  //static EditItem ei_below;
  //static EditItem ei_above;
  private void EditItem_Move(object sender, EventArgs e)
  {
   //if (MyID = 205300) ei_above = this;
   //if (MyID = 205306) ei_below = this;
   //if (ei_below != null && ei_above != null && MyID = ei_below.MyID && ei_below.Top ! ei_above.Bottom) Console.WriteLine("here");
   TurnOnSpellCheckIfVisible();
   int newTop = Top - MyStepPanel.TopMostEditItem.Top;
   //if(_ShowChanges && _LastTop != newTop && MyItemInfo.InList(134786))
   //Volian.Base.Library.vlnStackTrace.ShowStackLocal(2,10,"\"EditItem_Move\"\t\"\"\t\"{0}\"\t{1}\t{2}\t{3}",MyItemInfo.ShortPath, MyID, Top, _LastTop);
   if (_LastTop == newTop) return;
   _LastTop = newTop;
    int watchThis = _WatchThis;
    if (MyStepPanel.ItemMoving == 0 && !TryAgainLater)
    {
     /vlnStackTrace.ScrollInStack();
     return; / If 0 - Indicates scrolling which requires no action.
    }
    TryAgainLater = false;
    //ShowMe("Move");
    if (MyItemInfo == null)
     return;
    //if (_WatchThis > 0 && MyID > _StartingID)
    //{
    /  Console.WriteLine("{0}Start Move  {1},{2}", WatchThisIndent, MyID, this);
    /  if (MyID == _LookForID)
    /    Console.WriteLine("{0}—————", WatchThisIndent,MyID, this);
    /  _WatchThis++;
    //}
    if (MyExpandingStatus == ExpandingStatus.Expanding)
    {
     _WatchThis = watchThis;
     return;
    }
    Moving = true;
    EditItem tmp = (EditItem)sender;
    if (tmp.MyPreviousEditItem = null && tmp.MyParentEditItem = null)
    {
     _WatchThis = watchThis;
     return;
    }
    if (RNOBelow) // Adjust substeps first
    {
     //Console.WriteLine("RNOBelow"); 
     AdjustLocation();
     MoveRNO();
    }
    else // Adjust RNO First
    {
     if (RNORight)
     {
      //Console.WriteLine("RNORight");
      MoveRNO();
     }
     AdjustLocation();
    }
    Moving = false;
    EditItem btm = BottomMostEditItem;
    EditItem supinfo = null;
    if (MySupInfoEditItems != null && MySupInfoEditItems.Count > 0) supinfo = MySupInfoEditItems[0].BottomMostEditItem;
    if (supinfo != null && supinfo.Bottom > btm.Bottom) btm = supinfo;
    if (this != btm)
     btm.AdjustLocation();
    //if (_WatchThis > 0 && MyID > _StartingID)
    /{
    /  Console.WriteLine("{0}Finish Move  {1},{2}",WatchThisIndent, MyID, this);
    //}
    _WatchThis = watchThis;
   }
  / <summary>
  / Adjust the locations when the EditItem is resized
  / </summary>
  / <param name="sender"></param>
  / <param name="e"></param>
  private void EditItem_Resize(object sender, EventArgs e)
  {
   if (MyItemInfo == null) return;
   if (_IgnoreResize) return;
   AdjustLocation();
   HandleResize();
   AdjustAllForSupInfoHeight();
  }
  #endregion // Event Handlers
  #region Private and Protected Methods
  / <summary>
  / Calculates the table location
  / </summary>
  / <param name="myParentEditItem"></param>
  / <param name="myStepSectionLayoutData"></param>
  / <param name="width"></param>
  / <returns></returns>
  protected Point TableLocation(StepSectionLayoutData myStepSectionLayoutData, int width)
  {
   // bug fix: B2016-111 - myParentEditItem was getting a null reference error when inserting a figure before/after a figure
   EditItem myParentEditItem = _MyParentEditItem;
   if (myParentEditItem == null)
   {
    EditItem parentEI = _MyPreviousEditItem;
    while (parentEI._MyPreviousEditItem != null)
     parentEI = parentEI._MyPreviousEditItem;
    myParentEditItem = parentEI._MyParentEditItem;
   }
   / Should center on parent unless it is a centered table type in the AER column or parent is another table type, then
   / walk up until finding a non-table type step'.  (B2016-264: insert of centered eq off centered eq was not locating child equation correctly)
   EditItem aboveForLocation = myParentEditItem;
   if (aboveForLocation.MyItemInfo.IsTable || aboveForLocation.MyItemInfo.IsRtfRaw || aboveForLocation.MyItemInfo.IsFigure)
   {
    while (aboveForLocation.MyItemInfo.IsFigure || aboveForLocation.MyItemInfo.IsRtfRaw || aboveForLocation.MyItemInfo.IsTable) aboveForLocation = aboveForLocation.MyParentEditItem;
   }
   int center = aboveForLocation.ContentLeft + aboveForLocation.ContentWidth / 2;
   int rightLimit = aboveForLocation.Right;
   // Then should center on the wid Limit
   if ((MyItemInfo.FormatStepData.Type.Contains("AER") = false && MyItemInfo.RNOLevel = 0 ) && !MyItemInfo.IsInSupInfo)
   {
    // B2017-043 COLR is used as a Width
    int colR = MyStepPanel.ToDisplay(MyStepSectionLayoutData.ColRTable, MyItemInfo.ColumnMode);
    rightLimit += colR * MyItemInfo.ColumnMode;
    center += (colR * MyItemInfo.ColumnMode) / 2;
    center -= (aboveForLocation.ContentLeft - (int)MyItemInfo.MyDocStyle.Layout.LeftMargin) / 2;
   }
// Calulate the x location //int x = myParentEditItem.TextLeft; int x = center - width / 2; if (x + width > rightLimit) x = rightLimit - width; // B2017-043 account for Horizontal Scroll int colT =MyStepPanel.DisplayRectangle.X + MyStepPanel.ToDisplay((int)myStepSectionLayoutData.ColT); if (x < colT) x = colT; int y = FindTop(myParentEditItem.Bottom); return new Point(x, y); } protected void DoMouseWheel(MouseEventArgs e) { MyStepPanel.MouseWheel(e); } protected void InsertPgBrk() { MyStepPanel.MyStepTabPanel.MyStepTabRibbon.btnInsPgBrk_Click(this, new EventArgs()); MyStepPropertiesPanel.UpdatePageBreakCheckBox(); // update the checkbox on the Step Properties panel if (!MyStepRTB.ContainsFocus) MyStepRTB.Focus(); } protected void ToggleChangeBar() { MyStepPropertiesPanel.ToggleChangeBar(); // update the checkbox on the Step Properties panel if (!MyStepRTB.ContainsFocus) MyStepRTB.Focus(); } protected void ToggleContinuousActionSummary() { if (MyStepPropertiesPanel != null) / bug fix B2016-256 check for a null reference incase we are not on a step element MyStepPropertiesPanel.ToggleContActSummary(); / update the checkbox on the Step Properties panel if (!MyStepRTB.ContainsFocus) MyStepRTB.Focus(); } protected void TogglePlaceKeeper() { MyStepPropertiesPanel.TogglePlaceKeeper(); // update the checkbox on the Step Properties panel if (!MyStepRTB.ContainsFocus) MyStepRTB.Focus(); } protected void TogglePlaceKeeperContAct() { MyStepPropertiesPanel.TogglePlaceKeeperContAct(); // update the checkbox on the Step Properties panel if (!MyStepRTB.ContainsFocus) MyStepRTB.Focus(); } protected void ToggleSuperScript() { MyStepPanel.MyStepTabPanel.MyStepTabRibbon.btnSuperscript_Click(this, new EventArgs()); // click the Superscrpt button on the ribbon if (!MyStepRTB.ContainsFocus) MyStepRTB.Focus(); } protected void ToggleSubScript() { MyStepPanel.MyStepTabPanel.MyStepTabRibbon.btnSubscript_Click(this, new EventArgs()); // click the Subscrpt button on the ribbon if (!MyStepRTB.ContainsFocus) MyStepRTB.Focus(); } protected void OpenAnnotations() { MyStepPanel.MyStepTabPanel.MyStepTabRibbon.btnAnnots_Click(this, new EventArgs()); } protected bool CheckClipboard() { return (MyStepPanel.MyStepTabPanel.MyDisplayTabControl.MyCopyStep != null); } protected void CopyStep() { MyStepPanel.MyStepTabPanel.MyStepTabRibbon.DoCopyStep(); } / <summary> / Finds the last child in a list / </summary> / <param name="childEditItems"></param> / <returns></returns> private static EditItem LastChild(List<EditItem> childEditItems) { return childEditItems[childEditItems.Count - 1]; } / <summary> / If the selected EditItem is within the window leave it as it is. / If not, scroll so that the selected window is centered. / </summary> protected void ScrollToCenter() { vlnStackTrace.ShowStack("CenterScroll {0} Current {1} Top {2} Bottom {3} Limit {4}", _MyItem.ItemID, _Panel.VerticalScroll.Value, Top, Bottom, _Panel.Height); Show StackTrace Console.WriteLine("CenterScroll {0} Current {1} Top {2} Bottom {3} Limit {4}", _MyItem.ItemID, _Panel.VerticalScroll.Value, Top, Bottom, _Panel.Height); if (Top >= 0 && Bottom <= MyStepPanel.Height) return; Don't move if within screen. int scrollValue = MyStepPanel.VerticalScroll.Value + (Top - (MyStepPanel.Height / 2)); / calculate scroll center for the item / Limit scroll location within allowable values scrollValue = Math.Max(MyStepPanel.VerticalScroll.Minimum,Math.Min(MyStepPanel.VerticalScroll.Maximum,scrollValue)); /Console.WriteLine("CenterScroll {0} Current {1} New {2} Min {3} Max {4}", _MyItem.ItemID, _Panel.VerticalScroll.Value, scrollValue, _Panel.VerticalScroll.Minimum, _Panel.VerticalScroll.Maximum); //if (scrollValue >= MyStepPanel.VerticalScroll.Minimum && scrollValue <= MyStepPanel.VerticalScroll.Maximum) / If it is within range MyStepPanel.VerticalScroll.Value = scrollValue; // Center the item }
/ <summary> / Hide a Items Children - Part of colapsing / </summary> protected void HideChildren() { HideChildren(_MyBeforeEditItems); HideChildren(_MyRNOEditItems); HideChildren(_MySupInfoEditItems); HideChildren(_MyAfterEditItems); } / <summary> / Hide a list of children - Part of colapsing / </summary> / <param name="childEditItems"></param> private void HideChildren(List<EditItem> childEditItems) { if (childEditItems != null) { foreach (EditItem child in childEditItems) { if (child.Expanded) child.HideChildren(); child.Hidden = true; } } } / <summary> / Unhide an items Children - Part of expanding / </summary> / <param name="expand"></param> protected void UnhideChildren(bool expand) { UnhideChildren(_MyBeforeEditItems, expand); UnhideChildren(_MyRNOEditItems, expand); UnhideChildren(_MySupInfoEditItems, expand); UnhideChildren(_MyAfterEditItems, expand); MatchExpanded();
  }
  / <summary>
  / Unhide a list of children - part of expanding
  / </summary>
  / <param name="childEditItems"></param>
  / <param name="expand"></param>
  private void UnhideChildren(List<EditItem> childEditItems, bool expand)
  {
   if (childEditItems != null)
   {
    foreach (EditItem child in childEditItems)
    {
     if (child.Expanded)
      child.UnhideChildren(expand);
     else if (expand)
      child.Expand(expand);
     child.Hidden = false;
    }
   }
  }
  / <summary>
  / Move children as necessary
  / </summary>
  protected void AdjustChildren()
  {
   AdjustChildren(_MyBeforeEditItems);
   AdjustChildren(_MyRNOEditItems);
   AdjustChildren(_MySupInfoEditItems);
   AdjustChildren(_MyAfterEditItems);
  }
  / <summary>
  / Move a list of children
  / </summary>
  / <param name="childEditItems"></param>
  private void AdjustChildren(List<EditItem> childEditItems)
  {
   if (childEditItems != null)
   {
    foreach (EditItem child in childEditItems)
    {
     child.AdjustLocation();
     if (child.Expanded) child.AdjustChildren();
    }
   }
  }
  / <summary>
  / Expand a list of children
  / </summary>
  / <param name="childEditItems"></param>
  private void ExpandChildren(List<EditItem> childEditItems)
  {
   if (childEditItems != null)
   {
    foreach (EditItem child in childEditItems)
    {
     if (child.CanExpand)
     {
      child.Expand(true);
     }
     child.Hidden = false;
    }
   }
  }
  / <summary>
  / Expand children
  / </summary>
  private void ExpandChildren()
  {
   // Walk though Children performing Expand
   ExpandChildren(_MyBeforeEditItems);
   ExpandChildren(_MyRNOEditItems);
   ExpandChildren(_MySupInfoEditItems);
   ExpandChildren(_MyAfterEditItems);
  }
  private string MyPath
  {
   get
   {
    if (MyItemInfo.MyContent.Type >= 20000)
     return MyItemInfo.Path.Substring(MyItemInfo.ActiveSection.Path.Length);
    return MyItemInfo.MyContent.ToString();
   }
  }
  private EditItem AEREditItem
  {
   get
   {
    if (RNOLevel = 0) return null;
    if (MyParentEditItem ! null)
    {
     if (MyParentEditItem.RNOLevel < RNOLevel)
      return MyParentEditItem;
     else
      return MyParentEditItem.AEREditItem;
    }
    else if (MyPreviousEditItem != null)
    {
     return MyPreviousEditItem.AEREditItem;
    }
    //Volian.Base.Library.vlnStackTrace.ShowStackLocal("'AEREditItem',{0},{1}", MyID, MyItemInfo.DBSequence);
    return null;
   }
  }
   / <summary>
   / Adjust the Location of all items below the current item.
   / </summary>
  internal void AdjustLocation()
  {
   if (RNORight) MoveRNO(); / This is needed when an AER is Deleted that has an RNO.
   MoveSupInfo();		/ If the current item has supplemental information, be sure its top location is that of the current item.
   if (RNOLevel > 0 && AEREditItem != null)
    AEREditItem.AdjustLocation();
   EditItem nextEditItem = NextDownEditItem;
   /if(_LookForID.Contains(MyID))
   /  Console.WriteLine("{0}AdjustLocation {1},{2},{3} -> {4},{5} ({6}) {7}", WatchThisIndent, MyID, MyItemInfo.Ordinal, MyPath,
   /    nextEditItem = null ? 0 : nextEditItem.MyID, nextEditItem = null ? 0 : nextEditItem.MyItemInfo.Ordinal, nextEditItem == null ? "Null" : nextEditItem.MyPath,
   /    _NextDownEditItemPath);
   if (nextEditItem != null)
   {
    if (MyStepPanel.ExpandingHLS != null && nextEditItem.MyItemInfo.IsSection) return;   // without this, if next item is section, it crashes on null reference
    if (MyStepPanel.ExpandingHLS != null && nextEditItem.MyItemInfo.MyHLS.ItemID != MyStepPanel.ExpandingHLS.ItemID)
     return;
    int bottom = nextEditItem.FindTop(Bottom);
    if (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format)
    {
     if (MyItemInfo.IsCaution || MyItemInfo.IsNote)
     {
      if (nextEditItem.MyItemInfo.IsHigh || (nextEditItem.MyItemInfo.IsNote && MyItemInfo.IsCaution))
      {
       bottom = FirstSiblingEditItem.Top;
      }
      / RHM 20170216
      / MyParent will walk back MyPrevious to find Parent
      // NextDevDocStep will find the first part of a Dev Doc HLS
      AdjustForDevDocStepHeight();
     }
    }
    // SameRowAsParent - Comanche Peak Step Designator
    //FormatData fmtdata = MyItemInfo.ActiveFormat.PlantFormat.FormatData;
    //int formatSteptype = MyItemInfo.FormatStepType;
    //if (fmtdata.StepDataList[formatSteptype].SameRowAsParent)
    /if (MyItemInfo.SameRowAsParent && MyItemInfo.IsCaution2)
    /    bottom = Top;
/ If this is a "TitleWithTextRight", don't move down on the screen but only if it has a / child, i.e. want the child to be positioned on line, but if no child, move down on screen: int newTop = bottom; if (MyItemInfo.IsSupInfoPart) newTop = Math.Max(bottom, nextEditItem.BottomOfStepImmediatelyAbove()); if (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format) / Deviation Document Format if (MyItemInfo.IsStep && nextEditItem.MyItemInfo.IsStep && nextEditItem.MyItemInfo.MyHLS.ItemID != MyItemInfo.MyHLS.ItemID)/ Move from one step to another newTop = FindBottomDevDoc;// Use the bottom most caution or note
if (MyItemInfo.FormatStepData != null && MyItemInfo.FormatStepData.Type == "TitleWithTextRight" && MyItemInfo.HasChildren) newTop = Top; //This was useful to find the code that was positioning the Deviationn Document steps /if (MyItemInfo.InList(134782, 134783) || nextEditItem.MyItemInfo.InList(134782, 134783)) / Console.WriteLine("\"AdjustLocation\"\t\"{0}\"\t\"{1}\"\t{2}\t{3}\t{4}\t{5}", MyItemInfo.ShortPath, nextEditItem.MyItemInfo.ShortPath, nextEditItem.MyID, newTop, FindBottom, FindBottom - Top); if (nextEditItem.Top != newTop) { MyStepPanel.ItemMoving++; nextEditItem.LastMethodsPush(string.Format("AdjustLocation {0}", MyID)); nextEditItem._NextDownEditItemPath = _NextDownEditItemPath; float oldTop = nextEditItem.Top; nextEditItem.ExpandPrefix = 0;// If I move then I have to move my children when I expand / it appears that setting the top doesn't always work. The logic below checks to see if it does / not work and trys some other things so that the EditItem will be moved to the correct place. // As a last attempt, the EditItem is added to a list to be refreshed from a timer on MyStepPanel. if (nextEditItem.MySupInfoEditItems != null && nextEditItem.MySupInfoEditItems.Count > 0) newTop = nextEditItem.MySupInfoEditItems[0].FindTop(newTop); nextEditItem.Top = newTop; if (nextEditItem.Top != newTop) { /_MyLog.InfoFormat("'TryAgainLater',{0},{1},{2},{3},{4},'{5}'", / oldTop, nextEditItem.Top, newTop, MyStepPanel.Height, nextEditItem.MyID, nextEditItem.MyItemInfo.ShortPath); nextEditItem.TryAgainLater = true; } nextEditItem.LastMethodsPop(); MyStepPanel.ItemMoving–; } } } private int _DevDocHeight = 0; // Deviation Document Step Height B2016-123, B2017-020, B2017-021 public int DevDocHeight { get { return _DevDocHeight; } set { _DevDocHeight = value; } } public void TryAgainNow(int bottom) { TryToSetTop(bottom-10); //TryToSetTop(bottom+10); TryToSetTop(bottom); } private void TryToSetTop(int offset) { Top = offset; if (Top != offset) _MyLog.InfoFormat("Didn't work - Top {0} != offset {1} {2}", Top, offset,MyStepPanel.VerticalScroll.Value); } / <summary> / Automatically expands Steps if not currently expanded / </summary> internal void AutoExpand() { if (CanExpand && Expanded == false)// TODO: May need to do some additional checking for subsections { if(MyStepPanel.AutoExpand) Expand((_ContentType >= 20000) || MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format); else Expand(false); //Console.WriteLine("<AutoExpand ID {0} - Can {1} Expanded {2}",_MyItem.ItemID, CanExpand, Expanded); } } #endregion // Private Methods #region Public Methods / <summary> / Expand an item and it's children / <para/>If the children have been loaded then just expand them / <para/>If not, load the children and expand their children etc. / </summary> / <param name="expand">normally equal to _Type > = 20000 (Step)</param> public void Expand(bool expand) { // TIMING: DisplayItem.TimeIt("Expand Start"); if (_ChildrenLoaded) { // Unhide Children MyExpandingStatus = ExpandingStatus.Showing; UnhideChildren(expand); if (ExpandPrefix != 0) { MyStepPanel.ItemMoving++; if (TopMostEditItem.Top != Top) TopMostEditItem.Top = Top; MyStepPanel.ItemMoving–; } else TopMostEditItem.AdjustLocation(); //_ShowChanges = true; AdjustChildren(); //_ShowChanges = false; /if(_Before != null ) / Top = _Before[_Before.Count - 1].BottomMost.Bottom; } else { if (MyItemInfo.IsHigh) MyStepPanel.ExpandingHLS = MyItemInfo; MyExpandingStatus = ExpandingStatus.Expanding; _ChildrenLoaded = true; //_Panel.SuspendLayout(); AddChildBefore(MyItemInfo.Cautions, expand); AddChildBefore(MyItemInfo.Notes, expand); AddChildAfter(MyItemInfo.Procedures, expand); if (MyItemInfo.RNOs != null && MyItemInfo.RNOLevel < MyItemInfo.ColumnMode) AddChildRNO(MyItemInfo.RNOs, expand); if (MyItemInfo.RNOs != null && ((MyItemInfo.ActiveFormat.PlantFormat.FormatData.PurchaseOptions.Value & E_PurchaseOptions.EnhancedBackgrounds) == E_PurchaseOptions.EnhancedBackgrounds)) AddChildAfter(MyItemInfo.RNOs, expand); AddChildSupInfo(MyItemInfo.SupInfos, expand); AddChildAfter(MyItemInfo.Tables, expand); / get the config item for the steps section. there is an 'editable' / flag used in metasections to define whether the steps should print. / this flag can be toggle on the section's properties dialog. / Only check the flag if the section has subsections because the / default for the flag is not editable, and this would make non-metasections / not editable. bool hasMetaSubs = MyItemInfo.IsSection && MyItemInfo.Sections != null && MyItemInfo.Sections.Count>0; bool EditSteps = !hasMetaSubs || (MyItemInfo.MyConfig is SectionConfig && (MyItemInfo.MyConfig as SectionConfig).SubSection_Edit == "Y"); if (EditSteps) AddChildAfter(MyItemInfo.Steps, expand);
    if (MyItemInfo.RNOs != null && MyItemInfo.RNOLevel >= MyItemInfo.ColumnMode &&
     !((MyItemInfo.ActiveFormat.PlantFormat.FormatData.PurchaseOptions.Value & E_PurchaseOptions.EnhancedBackgrounds) == E_PurchaseOptions.EnhancedBackgrounds))
     AddChildRNO(MyItemInfo.RNOs, expand);
    AddChildAfter(MyItemInfo.Sections, expand);
    MatchExpanded();
    if (MyItemInfo.IsHigh) MyStepPanel.ExpandingHLS = null;
   }
   MyExpandingStatus = ExpandingStatus.Done;
   BottomMostEditItem.AdjustLocation();
   MyExpandingStatus = ExpandingStatus.No;
   // TIMING: DisplayItem.TimeIt("Expand End");
  }
  public EditItem BeforeItem
  {
   get
   {
    if (_MyAfterEditItems != null)
    {
     foreach (EditItem EditItem in _MyAfterEditItems)
     {
      if (EditItem._MyBeforeEditItems != null)
       return EditItem.TopMostEditItem;
      EditItem beforeItem = EditItem.BeforeItem;
      if (beforeItem != null) return beforeItem;
     }
    }
    return null;
   }
  }
  public EditItem ItemAbove
  {
   get
   {
    if (_MyChildRelation = ChildRelation.Before) return _MyParentEditItem.ItemAbove;
    if (_MyPreviousEditItem ! null) return _MyPreviousEditItem.BottomMostEditItem;
    if (_MyChildRelation = ChildRelation.After) return _MyParentEditItem;
    if (_MyChildRelation = ChildRelation.RNO) return _MyParentEditItem;
    if (_MyChildRelation == ChildRelation.SupInfo) return _MyParentEditItem;
    return null;
   }
  }
  private static int? max(int? value1, int value2)
  {
   if (value1 == null || value2 > value1) return value2;
   return value1;
  }
  private static int min(int value1, int value2)
  {
   if (value2 < value1) return value2;
   return value1;
  }
  public int FindRight()
  {
   if (!RNORight) return Right;
   return _MyRNOEditItems[0].FindRight();
  }
  public int? BottomOfParentRNO()
  {
   int? bottom = null;
   EditItem EditItem = this;
   if (!MyItemInfo.IsTablePart)
   {
    if (EditItem._MyChildRelation == ChildRelation.None)
     return null;
    if (EditItem._MyChildRelation == ChildRelation.After && !RNORight)
     return null;
   }
   while (EditItem != null && EditItem._MyChildRelation != ChildRelation.None && EditItem._MyChildRelation != ChildRelation.After)
    EditItem = EditItem.UpOneEditItem;
   if (EditItem = null || EditItem._MyChildRelation = ChildRelation.None)
    return null;
   EditItem parent = EditItem.UpOneEditItem;
   int right = FindRight();
   bool centeredTable = (MyItemInfo.IsTablePart && MyItemInfo.FormatStepData.Type.Contains("AER") = false && MyItemInfo.RNOLevel = 0);
   while (parent != null && parent.MyItemInfo.IsSection = false && parent._MyChildRelation ! ChildRelation.Before)
   {
    if (parent._MyRNOEditItems != null)
    {
     if (centeredTable || right > parent._MyRNOEditItems[0].Left)
     {
      if (parent._MyRNOEditItems[0].BottomMostEditItem.RNOLevel > RNOLevel && RNOLevel < _MyItemInfo.ColumnMode)
       bottom = max(bottom, parent._MyRNOEditItems[0].BottomMostEditItem.Bottom);
     }
    }
    parent = parent.UpOneEditItem;
   }
   return bottom;
  }
  public int? BottomOfParentSupInfo()
  {
   int? bottom = null;
   if (Colapsing) return null;
   EditItem parent = this;
   while (parent != null && parent.MyItemInfo.IsSection = false && parent._MyChildRelation ! ChildRelation.Before)
   {
    if (parent._MySupInfoEditItems != null) return parent._MySupInfoEditItems[0].BottomMostEditItem.Bottom;
    parent = parent.UpOneEditItem;
   }
   return bottom;
  }
  private string _NextDownEditItemPath = "None";
  public string NextDownEditItemPath
  {
   get { return _NextDownEditItemPath; }
  }
  / <summary>
  / This finds the next EditItem down.
  / </summary>
  public EditItem NextDownEditItem
  {
   get
   {
    EditItem EditItem = this;
    _NextDownEditItemPath = "Path 1";
    // If this item appears before it's parent, and it doesn't have anything below it, return the parent
    if (MyNextEditItem = null && MyAfterEditItems = null && FirstSiblingEditItem._MyChildRelation == ChildRelation.Before)
     return UpOneEditItem;
    _NextDownEditItemPath = "Path 2";
    if (Expanded && _MyAfterEditItems != null)// check to see if there is a _After
     return MyAfterEditItems[0].TopMostEditItem;// if there is, go that way
    _NextDownEditItemPath = "Path 3";
    if (Expanded && MyRNOEditItems != null && MyItemInfo.RNOLevel >= MyItemInfo.ColumnMode)// check to see if there is a _After
     return MyRNOEditItems[0].TopMostEditItem;// if there is, go that way
    while (EditItem != null && EditItem.MyNextEditItem == null) // if no Next walk up the parent path
    {
     bool lastWasRNO = (EditItem._MyChildRelation == ChildRelation.RNO);
     EditItem = EditItem.UpOneEditItem;
     _NextDownEditItemPath = "Path 4";
     if (EditItem == null) // No Parent
      return null;
     _NextDownEditItemPath = string.Format("Path 5 {0}, {1}", EditItem.MyExpandingStatus, EditItem.Moving);
     if (EditItem.MyExpandingStatus == ExpandingStatus.Expanding || EditItem.Moving) // Parent Expanding or Moving - Wait
      return null;
     _NextDownEditItemPath = "Path 5 RNO";
     if (EditItem.RNOBelow && !Ancestor(EditItem.MyRNOEditItems[0]))
      return EditItem.MyRNOEditItems[0];
     _NextDownEditItemPath = "Path 6";
     if (EditItem.MyNextEditItem = null && EditItem.FirstSiblingEditItem._MyChildRelation = ChildRelation.Before)
      return EditItem.UpOneEditItem;
     EditItem btm = EditItem.BottomMostEditItem; // Find the Bottom EditItem of this ancestor
     EditItem beforeItem = EditItem.BeforeItem;
     if (lastWasRNO && beforeItem != null)
     {
      _NextDownEditItemPath = "Path 7";
      if (beforeItem.ItemAbove.Bottom > this.Bottom) return null;
      _NextDownEditItemPath = "Path 8";
      return beforeItem;
     }
     if (this != btm) // If this is not the bottom, then just adjust things with respect to the bottom
     {
      EditItem btmNext = btm.NextDownEditItem;
      //if (EditItem.MyNextEditItem != null && EditItem.MyNextEditItem.TopMostEditItem.Top != btm.Bottom)
      if (btmNext != null)
      {
       int bottom = btmNext.FindTop(btm.Bottom);
       if (btmNext.MySupInfoEditItems != null && btmNext.MySupInfoEditItems.Count > 0)  
       {
        int btmSupInfo = btmNext.MySupInfoEditItems[0].FindTop(btm.Bottom);
        if (btmSupInfo > bottom) bottom = btmSupInfo;
       }
       if (btmNext.Top != bottom)
       {
        MyStepPanel.ItemMoving++;
        //EditItem.MyNextEditItem.TopMostEditItem.Top = btm.Bottom;
        //Console.WriteLine("{0}***Move in NextDownEditItem {1},{2} From {3} To {4}",WatchThisIndent, btmNext.MyID, btmNext, btmNext.Top, btm.Bottom);
        btmNext.LastMethodsPush(string.Format("NextDownEditItem {0} {1}", MyID, EditItem.MyID));
        //ShowMe(string.Format("FindTop = {0}", btmNext.FindTop(btm.Bottom)));
        if (btmNext.Top != bottom)
         btmNext.Top = bottom;
        btmNext.LastMethodsPop();
        MyStepPanel.ItemMoving–;
       }
      }
      _NextDownEditItemPath = string.Format("Path 9 {0}", btm);
      return null; // Not the bottom - don't adjust anything else
     }
     //else
     /{
     /}
    }
    if (EditItem != null)
    {
     // Need to verify that the bottom of the parents RNO does not excede the bottom of this item.
     EditItem next = EditItem.MyNextEditItem.TopMostEditItem;
     _NextDownEditItemPath = "Path A";
     if (Bottom >= (BottomOfParentRNO(next) ?? Bottom))
     return next; if no _After - check to see if there is a Next
     //_NextDownEditItemPath = "Path B";
     //return null;
    }
    _NextDownEditItemPath = "Path C";
    return null;
   }
  }
private bool Ancestor(EditItem EditItem) { if (MyID == EditItem.MyID) return true; if (MyItemInfo.IsHigh) return false; return UpOneEditItem.Ancestor(EditItem); } public override string ToString() { return _MyItemInfo == null ? base.ToString() : string.Format("{0},'{1}',{2},{3}", MyID, MyPath, Top, Bottom); // + "-" + MyItemInfo.MyContent.Text; } #endregion #region Abstract Methods and Properties public abstract int TableWidth { get; } public abstract int BorderWidth { get; } public abstract Point ContentLocation { get; set; } public abstract string TabFormat { get; set; } public abstract void AdjustTableWidthAndLocation(); public abstract void SetToolTip(string tip); public abstract void RefreshContent(); //public abstract EditItem MyPreviousEditItem { get; set; } public abstract int ItemLeft { get; set; } public abstract int ContentLeft { get; } public abstract int ContentWidth { get; set; } public abstract Point ItemLocation { get; set; } public abstract int ItemWidth { get; set; } public abstract void RefreshOrdinal(); public abstract bool Expanded { get; set; } public abstract void RefreshTab(); public abstract void SetFocus(); public abstract void SaveContents(); public abstract bool CanExpand { get; set; } public abstract void HandleResize(); public abstract void MatchExpanded(); public abstract void ItemSelect(); public abstract void ItemShow(); public abstract StepRTB MyStepRTB { get; } public abstract DialogResult ReplaceText(string rpltxt, string fndstr, bool caseSensitive, bool matchWholeWord, bool reverse, bool prompt, IWin32Window fndrpldlg); public abstract bool FindText(string str, bool caseSensitive, bool matchWholeWord, bool reverse); public abstract void PositionToEnd(); public abstract void PositionToStart(); public abstract string SelectedTextForFind { get;} public abstract bool SpellCheckNext(); public abstract void IdentifyMe(bool highlight); public abstract void SetActive(); public abstract bool Empty { get; set; } //public abstract bool IsEmpty(); //public abstract void MakeNotEmpty(); public abstract void RefreshDisplay(bool activeMode); public abstract void ToggleEditView(E_ViewMode vwMode); public abstract int TabLeft { get; set; } public abstract Font TabFont { get; set; } public abstract string TabText { get; } public abstract Point TabLocation { get; } public abstract Font ContentFont { get; set; } public abstract float ContentTop { get; } public abstract void SetupHeader(ItemInfo itemInfo); public abstract void ShowExpanded(); public abstract void SetText(); public abstract void SetExpandAndExpander(ItemInfo itemInfo); public abstract void SaveCurrentAndContents(); #endregion private int SupInfoTopOffset { get { return _MyParentEditItem.MyStepRTB.Location.Y - MyStepRTB.Location.Y; } } protected string _TabFormat; private static int _WidthAdjust = 5; protected bool _IgnoreResize = false; private int FindBottomDevDoc // Find Bottom of a Deviation Document Step { get { int y = BottomMostEditItem.Bottom;// RHM 20170216 Get the bottom most step of a High Level step (RNOs and Substeps) if (MyParentEditItem == null || MyParentEditItem.MyItemInfo.IsSection) { EditItem eitm2 = this; if (eitm2 != null && eitm2.MyBeforeEditItems != null) foreach (EditItem eitm2Tmp in eitm2.MyBeforeEditItems) y = Math.Max(y, eitm2Tmp.Bottom); return y; } y = Math.Max(y, MyParentEditItem.Bottom); EditItem eitm = MyParentEditItem; while (eitm != null && !eitm.MyItemInfo.IsHigh) eitm = eitm.MyParent; if (eitm != null && eitm.MyBeforeEditItems != null) foreach (EditItem eitmTmp in eitm.MyBeforeEditItems) y = Math.Max(y, eitmTmp.Bottom); return y; } } / <summary> / Sets the parent and postions the item with respect to the parent / </summary> public EditItem MyParentEditItem { get { return _MyParentEditItem; } set { LastMethodsPush("set_MyParentRTBItem"); _MyParentEditItem = value; if (_MyParentEditItem != null) { switch (_MyChildRelation) { case ChildRelation.None: / Same as after case ChildRelation.After: / Procedures, sections, substeps, and tables/figures // The size depends upon the parent type int iType = (int)_MyParentEditItem.ContentType;
       switch (iType / 10000)
       {
        case 0: // Procedure
         ItemLocation = new Point(_MyParentEditItem.ItemLocation.X + 20, _MyParentEditItem.Bottom);
         int widt = MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidT);
         int wids = MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidSTableEdit, 0);
         int width = Math.Max(widt, wids);
         ItemWidth = MyStepPanel.ToDisplay(MyStepSectionLayoutData.ColT) + width;
         break;
        case 1: // Section
         if (this == TopMostEditItem)
         {
          if (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format)
          {
           if (MyPreviousEditItem != null)
           {
            EditItem ei = MyPreviousEditItem.BottomMostEditItem;
            if (ei.MyItemInfo.IsHigh && (ei.MyItemInfo.Cautions !=null || ei.MyItemInfo.Notes!=null))
            {
             if (ei.MyItemInfo.Cautions!= null)// Look at cautions
             {
              EditItem eic = MyStepPanel._LookupEditItems[ei.MyItemInfo.Cautions[0].ItemID].BottomMostEditItem;
              if (eic.Bottom > ei.Bottom) ei = eic;
             }
             if (ei.MyItemInfo.Notes!= null)//Look at notes
             {
              EditItem ein = MyStepPanel._LookupEditItems[ei.MyItemInfo.Notes[0].ItemID].BottomMostEditItem;
              if (ein.Bottom > ei.Bottom) ei = ein;
             }
            }
            // B2017-043 Account for the Horizonal Scroll position when locating the step
            ItemLocation = new Point(MyStepPanel.DisplayRectangle.X + MyStepPanel.ToDisplay(MyItemInfo.ActiveFormat.MyStepSectionLayoutData.ColS) + 50, ei.Bottom);
           }
           else
            // B2017-043 Account for the Horizonal Scroll position when locating the step
            ItemLocation = new Point(MyStepPanel.DisplayRectangle.X + MyStepPanel.ToDisplay(MyItemInfo.ActiveFormat.MyStepSectionLayoutData.ColS) + 50, _MyParentEditItem.Bottom);
          }
          else
           ItemLocation = new Point(_MyParentEditItem.ItemLocation.X + 20, _MyParentEditItem.Bottom);
         }
         else
          TopMostEditItem.ItemLocation = new Point(TopMostEditItem.ItemLocation.X, _MyParentEditItem.Bottom);
         //TextWidth = _WidthAdjust + borderWidth + MyStepPanel.ToDisplay(_MyStepSectionLayoutData.WidSTableEdit, Convert.ToInt32(_MyStepSectionLayoutData.PMode) - 1);
         ContentWidth = _WidthAdjust + BorderWidth + MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidSTableEdit, MyItemInfo.ColumnMode);
         //ContentWidth = _WidthAdjust + BorderWidth;
         /if (MyItemInfo.FormatStepData.WidthOverrideEdit != null && MyItemInfo.FormatStepData.WidthOverrideEdit > 0)
         /    ContentWidth += MyStepPanel.ToDisplay(MyItemInfo.FormatStepData.WidthOverrideEdit);
         /else 
         /    ContentWidth += MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidSTableEdit, MyItemInfo.ColumnMode);
         break;
        case 2: / Step
         / if Table then determine width and location based upon it's parent's location
         if (MyStepData.Type = "Table" || MyStepData.ParentType = "Table")
         {
          AdjustTableWidthAndLocation();
         }
         else if (MyStepData.Type.Contains("Figure"))
         {
          AdjustTableWidthAndLocation();
         }
         else if (MyItemInfo.IsRtfRaw)
         {
          AdjustTableWidthAndLocation();
         }
         else
         {
          if (MyItemInfo.FormatStepData.StepLayoutData.AlignWithParentTab)
           / Paul Linn made the request on 6/4/12 to align the Component Description &
           / Required Position under the Component Number.
           ItemLocation = new Point(_MyParentEditItem.ItemLocation.X, _MyParentEditItem.Bottom);
           / part of F2017-011, for enhanced backgrounds, always align the TitleWithTextRight and TitleWithTextBelow with the parent tab (on the screen)
          else if ((MyItemInfo.FormatStepData.Type = "TitleWithTextRight" || MyItemInfo.FormatStepData.Type = "TitleWithTextBelow") && ((MyItemInfo.ActiveFormat.PlantFormat.FormatData.PurchaseOptions.Value & E_PurchaseOptions.EnhancedBackgrounds) == E_PurchaseOptions.EnhancedBackgrounds)) / align with parent tab if in background document
           ItemLocation = new Point(_MyParentEditItem.ItemLocation.X, _MyParentEditItem.Bottom);
          else if (MyItemInfo.FormatStepData.Type = "TitleWithTextRight" && (MyItemInfo.Steps = null || MyItemInfo.Steps.Count == 0))  // this code is run for siblings within a HLS (but not last sibling).
           ItemLocation = new Point(_MyParentEditItem.ItemLocation.X, _MyParentEditItem.Bottom);
          else if (MyItemInfo.MyParent.FormatStepData.Type == "TitleWithTextRight")
           ItemLocation = new Point(_MyParentEditItem.ItemLocation.X + _MyParentEditItem.ItemWidth + 10, _MyParentEditItem.ItemLocation.Y); // F2017-011 added 10 to fix positoning of Purpose text on sceen (enhanced backgrounds)
          else if (MyItemInfo.MyTab.Offset != 0)
           ContentLocation = new Point(_MyParentEditItem.ContentLocation.X + 10, _MyParentEditItem.Bottom);
          //ItemLocation = new Point(_MyParentEditItem.ItemLocation.X+10, _MyParentEditItem.Bottom);
          else
          {
           // B2016-134 Fix - If a previous step exists, use it to locate the current step
           if (_MyPreviousEditItem != null)
            ItemLocation = new Point(_MyParentEditItem.ContentLeft, _MyPreviousEditItem.BottomMostEditItem.Bottom);
           else
           {
            ItemLocation = new Point(_MyParentEditItem.ContentLeft, _MyParentEditItem.Bottom);
            // if inserting a substep within supplemental information, then may  have to adjust steps too:
            if (MyItemInfo.IsInSupInfo)  
            {
             AdjustLocation();
             // find parent of supinfo & adjust its location:
             ItemInfo supInfoPart = MyItemInfo;
             while (!supInfoPart.IsSupInfoPart) supInfoPart = supInfoPart.MyParent;
             EditItem eitmp = MyStepPanel._LookupEditItems[supInfoPart.ItemID];
             eitmp.MyParentEditItem.AdjustLocation();
            }
           }
          }
          bool specialTplSupport = ((MyItemInfo.MyDocStyle.StructureStyle.Style & E_DocStructStyle.DSS_PageListSpBckgrnd) == E_DocStructStyle.DSS_PageListSpBckgrnd) ||
           (MyItemInfo.MyDocStyle.LandscapePageList && MyItemInfo.MyDocStyle.ComponentList);
          bool wecTplSupport = ((MyItemInfo.MyDocStyle.StructureStyle.Style & E_DocStructStyle.DSS_ChklstEditSize) == E_DocStructStyle.DSS_ChklstEditSize);
          if (MyItemInfo.FormatStepData.ReadOnly)
          {
           Graphics g = CreateGraphics();
           SizeF sz = g.MeasureString(MyItemInfo.MyContent.Text, MyItemInfo.FormatStepData.Font.WindowsFont);
           ItemWidth = (int)sz.Width;
          }
          else if (MyItemInfo.FormatStepData.Type == "TitleWithTextRight" && specialTplSupport)
          {
           Graphics g = CreateGraphics();
           SizeF sz = g.MeasureString(MyItemInfo.MyContent.Text, MyItemInfo.FormatStepData.Font.WindowsFont);
           ItemWidth = (int)sz.Width + 5;
          }
          else if (MyItemInfo.FormatStepData.Type == "TitleWithTextBelow" && specialTplSupport)
          {
           ItemWidth = MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidSTableEdit, 0);
          }
          else if (wecTplSupport || (MyItemInfo.MyParent.FormatStepData.Type == "TitleWithTextBelow" && specialTplSupport))
          {
           ItemWidth = MyParentEditItem.ItemWidth - RTBItem.RTBMargin;
          }
          else if (MyItemInfo.MyParent.FormatStepData.Type = "TitleWithTextRight" &&
          ((MyItemInfo.MyDocStyle.StructureStyle.Style & E_DocStructStyle.DSS_PageListSpBckgrnd) = E_DocStructStyle.DSS_PageListSpBckgrnd))
          {
           ItemWidth = MyParentEditItem.MyParentEditItem.ContentWidth - MyParentEditItem.ItemWidth;
          }
          else if (MyItemInfo.MyParent.FormatStepData.Type == "TitleWithTextRight")
          {
           ItemWidth = MyStepPanel.ToDisplay(MyStepSectionLayoutData.ColT) + MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidSTableEdit, 0);
           ItemWidth = ItemWidth - ItemLocation.X;
          }
          else if (MyParentEditItem != null && MyParentEditItem.MyItemInfo.FormatStepData.ReadOnly)
           ItemWidth = MyStepPanel.ToDisplay(MyStepSectionLayoutData.ColT) + MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidSTableEdit, 0);
          else if (MyItemInfo.MyTab != null && MyItemInfo.MyTab.Offset != 0)
          {
            // Farley - part of bug fix B2015-123 alignment of tabs on the edit screen (Farly is only one using tab offset)
            ContentWidth = _MyParentEditItem.ContentWidth;
            int xOffTabNew = (MyItemInfo.MyParent.MyTab != null ? MyItemInfo.MyParent.MyTab.Offset : MyItemInfo.MyParent.OffsetTab) + MyItemInfo.MyTab.Offset;
            xOffTabNew += MyItemInfo.MyParent.MyTab == null ? 0 : MyItemInfo.MyParent.MyTab.Offset;
            int xIncrement = xOffTabNew - MyItemInfo.MyTab.Offset;
            MyStepRTB.Location = new Point(MyStepRTB.Location.X + xIncrement, MyStepRTB.Location.Y);
          }
          else
           ItemWidth = _MyParentEditItem.ContentWidth;
         }
         break;
       }
       break;
      case ChildRelation.SupInfo:		// on a supplemental info item
       EditItem high = MyStepPanel._LookupEditItems[MyItemInfo.MyHLS.ItemID];
       if (_MyParentEditItem.MyItemInfo.IsNote || _MyParentEditItem.MyItemInfo.IsCaution)
       {
        ContentWidth = high.ContentWidth - high.ContentLocation.X;
       }
       else
        ContentWidth = _MyParentEditItem.ContentWidth;
       / Currently on the supinfo, so MyParentEditItem is the step the supinfo is related to.  
       / From this MyParentEditItem, need to find what is the bottom of the 'previous step' on the screen where 'previous step' can be: 
       /	1) The bottom most EditItem from a caution/note, i.e. MyBeforeEditItems.  This must be checked first.
       /	2) If there is a MyParentEditItem, use it (only MyParentEditItem or MyPreviousEditItem can be set), if going to parent don't use
       /			BottomMostEditItem because that will take it onto this step or subsequent substeps. So just use its bottom.  Note that there
       /			are special cases if on a Note/Caution (see below for comments)
       /	3) If there is no MyBeforeEditItems & no MyParentEditItems, there must be a MyPreviousEditItems.  Use its MyBottomMostEditItem's bottom
       /		  since this previous may have substeps.
       int btm = MyParentEditItem.BottomOfStepImmediatelyAbove();
       int topp = FindTop(btm, false);
       if (topp != 0)
       {
        MyStepPanel.ItemMoving++;
        _MyParentEditItem.Top = (int)topp;
        if (_MyParentEditItem.MyItemInfo.Steps != null && _MyParentEditItem.MyItemInfo.Steps.Count > 0)
        {
         EditItem chtmp = GetEditItemFromItemID(_MyParentEditItem.MyItemInfo.Steps[0].ItemID);
         if (chtmp != null && chtmp._MyParentEditItem != null)
         {
          chtmp.Top = chtmp._MyParentEditItem.Bottom;
          chtmp.AdjustLocation();
         }
        }
        _MyParentEditItem.AdjustLocation();
        MyStepPanel.ItemMoving–;
       }
       ContentLocation = new Point(high.ContentLeft + high.Width + 36, (int)_MyParentEditItem.Top + SupInfoTopOffset);  // account for Caution/Note tab above caution/note
       break;
      case ChildRelation.RNO:
       / this is set so that TextWidth command below will be correct.  TextWidth uses
       / the tab start & tab width to calculate the overall width.
       TabFormat = "";	// this is set so that TextWidth command below will be correct
       _IgnoreResize = true;
       / Use the RNOWidthAlt value if it exists instead of the default RNO width
       / Note that I needed to add 1 to the ToDisplay() value to be closer to the needed
       / width for the screen (this does not affect the printout)
       / If in single column, don't make this adjustment:
       string[] splitRNOWidthAlt = MyStepSectionLayoutData.RNOWidthAlt.Split(',');
       int ovrRNOWidth = (RNOLevel < splitRNOWidthAlt.Length)?MyStepPanel.ToDisplay(float.Parse(splitRNOWidthAlt[RNOLevel])+1) : 0;
       if (MyStepSectionLayoutData.RNOWidthAlt != null && ovrRNOWidth > 1 && MyItemInfo.ColumnMode != 0)
        ContentWidth = ovrRNOWidth;
       else
       ContentWidth = _MyParentEditItem.ContentWidth;
       _IgnoreResize = false;
       if (RNOLevel <= MyItemInfo.ColumnMode)
       {
        //int colR = MyStepPanel.ToDisplay(_MyStepSectionLayoutData.ColRTable, Convert.ToInt32(_MyStepSectionLayoutData.PMode) - 1);
        int colR = MyStepPanel.ToDisplay(MyStepSectionLayoutData.ColRTable, MyItemInfo.ColumnMode);
        if (colR - _MyParentEditItem.Width < 0) colR = _MyParentEditItem.Width + 0;
        MyStepPanel.ItemMoving++;
        //Left = _MyParentRTBItem.ItemLeft + RNOLevel * colR;
        //ItemLocation = new Point(_MyParentRTBItem.ItemLeft + RNOLevel * colR, _MyParentRTBItem.Top);
        LastMethodsPush(string.Format("set_MyParentRTBItem RNO Right {0}", MyID));
        ItemLocation = new Point(_MyParentEditItem.ItemLeft + RNOLevel * colR, _MyParentEditItem.Top);
        int top = _MyParentEditItem.FindTop(_MyParentEditItem.Top);
        if (top != _MyParentEditItem.Top)
        {
         _MyParentEditItem.LastMethodsPush(string.Format("set_MyParentRTBItem RNO Right {0}", MyID));
         if (_MyParentEditItem.Top != top)
          _MyParentEditItem.Top = top;
         _MyParentEditItem.LastMethodsPop();
         Top = top;
        }
        LastMethodsPop();
        MyStepPanel.ItemMoving–;
       }
       else
       {
        MyStepPanel.ItemMoving++;
        LastMethodsPush(string.Format("set_MyParentRTBItem RNO Below {0} {1} {2}", MyID, _MyParentEditItem.BottomMostEditItem.MyID, _MyParentEditItem.BottomMostEditItem.Bottom));
        ContentLocation = new Point(_MyParentEditItem.ContentLeft, _MyParentEditItem.BottomMostEditItem.Bottom);
        LastMethodsPop();
        //TextLocation = new Point(_MyParentRTBItem.TextLeft, FindTop(_MyParentRTBItem.Top));
        MyStepPanel.ItemMoving–;
       }
       // Same size as the Parent
       break;
      case ChildRelation.Before:		// Cautions and Notes
       /if(_WatchThis > 0 && MyID > 2111)
       /  Console.WriteLine("Setting MyParent: \r\n\tParent {0},{1} \r\n\tTopMostItem {2},{3} \r\n\tNext {4}, {5}", _MyParentRTBItem.MyID, _MyParentRTBItem
       /    ,_MyParentRTBItem.TopMostRTBItem.MyID,_MyParentRTBItem.TopMostRTBItem
       /    , _MyNextRTBItem = null ? 0 : _MyNextRTBItem.MyID, _MyNextRTBItem = null ? "None"  : _MyNextRTBItem.ToString());
//Location = new Point(_MyParentRTBItem.Left + 20, max(_MyParentRTBItem.Top, (_MyNextRTBItem == null ? 0 : _MyNextRTBItem.Top )) ?? 0); _IgnoreResize = true; int spaceToRTB = 23; _IgnoreResize = false; MyStepPanel.ItemMoving++; //Location = new Point(_MyParentRTBItem.Left + 20, FindTop(_MyParentRTBItem.Top)); int myTop = 0; if (MyNextEditItem == null) myTop = _MyParentEditItem.Top; else myTop = MyNextEditItem.Top;
//if (MyItemInfo.SameRowAsParent && MyItemInfo.IsCaution2) /{ / if (MyItemInfo.WidthOverride > 0) / Width = MyStepPanel.ToDisplay(MyItemInfo.WidthOverride) + spaceToRTB; /} if (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format && (MyItemInfo.IsCaution || MyItemInfo.IsNote)) { // B2017-043 account for Horizontal Scroll int x = MyStepPanel.DisplayRectangle.X + MyStepPanel.ToDisplay(MyItemInfo.ActiveFormat.MyStepSectionLayoutData.ColT); int y = Top; if (MyPreviousEditItem == null || !MyPreviousEditItem.MyItemInfo.IsCaution || !MyItemInfo.IsNote) y = FindTop(myTop); / Get the "bottom" number of the longest Caution/Note on the step/substep above so that / we can position properly on the screen. // EX. Catawba Deviations E-1 step deviation for step 10 EditItem eitm = (MyParentEditItem.MyPreviousEditItem != null) ? MyParentEditItem.MyPreviousEditItem : MyParentEditItem.MyParentEditItem; if (eitm != null && eitm.MyBeforeEditItems != null) foreach (EditItem eitmTmp in eitm.MyBeforeEditItems) y = Math.Max(y, eitmTmp.Bottom); if (MyItemInfo.IsNote) / Move to the right based upon the Width of the Caution which is the same as the width of the note. { / AdjustChildren width BeforeItem setting Left offset int width = MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidT) + spaceToRTB; x += width + 6;//Account for the width of the Caution in the Deviation Document } Location = new Point(x, y); } else Location = new Point(_MyParentEditItem.Left + 20, FindTop(myTop)); // ip2bck's needed the width to be set slightly differently to get the correct width. int widthtpl = MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidT) + spaceToRTB; if (MyItemInfo.FormatStepData != null && MyItemInfo.FormatStepData.UseOldTemplate && ((MyItemInfo.MyDocStyle.StructureStyle.Style & E_DocStructStyle.DSS_PageListSpBckgrnd) == E_DocStructStyle.DSS_PageListSpBckgrnd)) widthtpl = MyParentEditItem.Width + MyParentEditItem.Left - Left; Width = widthtpl; // MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidT) + spaceToRTB; MyStepPanel.ItemMoving–; /_MyParentRTBItem.Top = Bottom; / Could be a Caution or Note - Need to get WidT break; } } LastMethodsPop(); } } private int BottomOfStepImmediatelyAbove() { int btm = 0; if (MyBeforeEditItems != null && MyBeforeEditItems.Count > 0) // Notes & Cautions before btm = MyBeforeEditItems[MyBeforeEditItems.Count - 1].BottomMostEditItem.Bottom; else { / if on a caution or note, (the first one), need to go up to either previous step or the section to find its bottom / _MyParentEditItem is a way to find that the structure supports this, i.e. there can be a caution or note: if (_MyParentEditItem != null && _MyParentEditItem.MyBeforeEditItems != null && _MyParentEditItem.MyBeforeEditItems.Count > 0 / this part checks that there are cautions/notes && _MyParentEditItem.MyBeforeEditItems[0].MyID == MyID) / first caution or note, i.e. index of MyBeforeItems == 0 { if (_MyParentEditItem._MyPreviousEditItem == null) / this part checks for first HLS btm = _MyParentEditItem._MyParentEditItem.Bottom; / bottom of the section else btm = _MyParentEditItem._MyPreviousEditItem.BottomMostEditItem.Bottom; // bottom of previous step } else { btm = MyParentEditItem != null ? MyParentEditItem.Bottom : MyPreviousEditItem.BottomMostEditItem.Bottom; } } return btm; } / <summary> / Sets the previous item and adjusts locations / </summary> public override EditItem MyPreviousEditItem { get { return _MyPreviousEditItem; } set { LastMethodsPush("set_MyPreviousRTBItem"); _MyPreviousEditItem = value; if (_MyPreviousEditItem != null) { _IgnoreResize = true; // the table code goes through the following, rather than 'istablepart' if (MyStepData != null && ((MyStepData.Type.ToLower().Contains("table") || MyStepData.ParentType.ToLower().Contains("table")) || (MyStepData.Type.ToLower().Contains("figure") || MyStepData.ParentType.ToLower().Contains("figure")) || (MyStepData.Type.ToLower().Contains("equation") || MyStepData.ParentType.ToLower().Contains("equation")))) { ItemWidth = TableWidth; Location = new Point(_MyPreviousEditItem.Left, FindTop(_MyPreviousEditItem.BottomMostEditItem.Bottom)); } else if (value.MyItemInfo.IsTablePart) { ItemLocation = new Point(value.MyParentEditItem.ContentLeft, value.Bottom); ItemWidth = value.MyParentEditItem.ContentWidth; } else { if (MyItemInfo.FormatStepData != null && MyItemInfo.FormatStepData.ReadOnly) { Graphics g = CreateGraphics(); SizeF sz = g.MeasureString(MyItemInfo.MyContent.Text, MyItemInfo.FormatStepData.Font.WindowsFont); ItemWidth = (int)sz.Width; } else if (MyPreviousEditItem != null && MyPreviousEditItem.MyItemInfo.FormatStepData != null && MyPreviousEditItem.MyItemInfo.FormatStepData.ReadOnly) ItemWidth = MyStepPanel.ToDisplay(MyStepSectionLayoutData.ColT) + MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidSTableEdit, 0); / RHM The following lines were commented-out for Facing Pages (Supplemental Information) to test follow the instructions //else if (MyItemInfo.MyTab.Offset != 0) / Farley - part of bug fix B2015-123 alignment of tabs on the edit screen (Farly is only one using tab offset) // ContentWidth = (MyPreviousEditItem.MyItemInfo.MyTab.Offset != 0) ? MyPreviousEditItem.ContentWidth : MyPreviousEditItem.ContentWidth + 10; else Width = MyPreviousEditItem.Width;
if (TopMostEditItem == this) { if (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format && (MyItemInfo.IsNote || MyItemInfo.IsCaution) && (MyPreviousEditItem == null || (MyPreviousEditItem.MyItemInfo.IsCaution && MyItemInfo.IsNote))) //if ((MyItemInfo.SameRowAsParent && MyItemInfo.IsCaution2) || (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format && (MyItemInfo.IsNote || MyItemInfo.IsCaution))) { // B2017-043 account for Horizontal Scroll int x = MyStepPanel.DisplayRectangle.X + MyStepPanel.ToDisplay(MyItemInfo.ActiveFormat.MyStepSectionLayoutData.ColT); if (MyItemInfo.IsNote) x += Width + 6; //Find first sibling EditItem prev = _MyPreviousEditItem; while (prev._MyPreviousEditItem != null) prev = prev._MyPreviousEditItem; Location = new Point(x, prev.Top);// Use the top of the first sibling } else { int top = FindTop(_MyPreviousEditItem.BottomMostEditItem.Bottom); if (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format && _MyPreviousEditItem.MyItemInfo.IsHigh) //if (MyItemInfo.SameRowAsParent || (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format && _MyPreviousEditItem.MyItemInfo.IsHigh)) { if (_MyPreviousEditItem.MyBeforeEditItems != null) foreach (EditItem ei in _MyPreviousEditItem.MyBeforeEditItems) top = Math.Max(top, ei.Bottom); } Location = new Point(_MyPreviousEditItem.Left, top); // B2017-029 only do this if this is a the deviation document AdjustForDevDocStepHeight(); AdjustAllForSupInfoHeight(); } } else TopMostEditItem.Location = new Point(TopMostEditItem.Left, FindTop(_MyPreviousEditItem.BottomMostEditItem.Bottom)); } _IgnoreResize = false; //ShowMe(""); /if (MyID > _StartingID) / Console.WriteLine("{0}–>Setting MyPreviousRTBItem {1},{2},{3},{4},{5},{6},{7}", WatchThisIndent, MyID, this / , _MyPreviousRTBItem / ,Top / , _MyPreviousRTBItem.BottomMostRTBItem.Bottom / , FindTop(_MyPreviousRTBItem.BottomMostRTBItem.Bottom) // , _MyPreviousRTBItem.Bottom); //Location = new Point(_MyPreviousRTBItem.Left, _MyPreviousRTBItem.BottomMostRTBItem.Bottom); switch (_MyChildRelation) { case ChildRelation.None: break; case ChildRelation.After: break; case ChildRelation.RNO: break; case ChildRelation.SupInfo: break; case ChildRelation.Before: //MyStepPanel.ItemMoving++; //UpOneRTBItem.Top = BottomMostRTBItem.Bottom; //MyStepPanel.ItemMoving–; break; } if (_MyPreviousEditItem.MyNextEditItem != this) _MyPreviousEditItem.MyNextEditItem = this; } LastMethodsPop(); } } / AdjustAllForSupInfoHeight & AdjustFOrSupInfoHeight go from current edit item down, adjusting any of the edit items' top / location to account for any supplemental informations that items may have so that either the step or its supplemental information // does not overwrite other steps on screen. private void AdjustAllForSupInfoHeight() { EditItem ei = this; while (ei != null) { ei = ei.AdjustForSupInfoHeight(); } } private EditItem AdjustForSupInfoHeight() { if (MyStepPanel._LookupEditItems.ContainsKey(MyID) && MyItemInfo.IsInSupInfo) // only do this if it is displayed (in LookupEditItems and in sup info column { ItemInfo supInfoPart = MyItemInfo; while (!supInfoPart.IsSupInfoPart) supInfoPart = supInfoPart.MyParent; EditItem EIsupInfoPartAbove = MyStepPanel._LookupEditItems[supInfoPart.ItemID];
/ find first edititem below this (EIWsupInfoBelow) or a sibling or child child that have sup info / if found, adjust top of this item to the bottommost edititem above this EditItem EIWsupInfoBelow = null; EIWsupInfoBelow = EIsupInfoPartAbove.MyParentEditItem.FindFirstChildWithSupInfo(EIsupInfoPartAbove.MyParentEditItem.MyItemInfo); if (EIWsupInfoBelow == null) EIWsupInfoBelow = EIsupInfoPartAbove.MyParentEditItem.FindSiblingOrParentSiblingWithSupInfo(EIsupInfoPartAbove.MyParentEditItem.MyItemInfo);
    if (EIWsupInfoBelow != null)		// for editiem below, find bottom of step & subinfo column and take the max of these:
    {
     int bottomOfAboveSupInfoColumn = EIsupInfoPartAbove.BottomMostEditItem.Bottom;
     int bottomOfImmediatelyAbove = EIWsupInfoBelow.BottomOfStepImmediatelyAbove();
     MyStepPanel.ItemMoving++;
     EIWsupInfoBelow.Top = Math.Max(bottomOfAboveSupInfoColumn, bottomOfImmediatelyAbove);
     EIWsupInfoBelow.AdjustLocation();
     MyStepPanel.ItemMoving–;
     return EIWsupInfoBelow.MySupInfoEditItems==null?null:EIWsupInfoBelow.MySupInfoEditItems[0];
    }
   }
   return null;
  }
  private EditItem CheckForExpanded(EditItem ei)
  {
   ItemInfo hls = ei.MyItemInfo.MyHLS;
   EditItem hlsEI = GetEditItemFromItemID(hls.ItemID);
   if (hlsEI==null) return null;
   return ei;
  }
  // FindSiblingOrParentSiblingWithSupInfo will find the next edititem below me on the screen that has a supinfo
  private EditItem FindSiblingOrParentSiblingWithSupInfo(ItemInfo itm)
  {
   if (itm = null || itm.IsProcedure) return null;
   if (itm.NextItem = null)
   {
    return FindSiblingOrParentSiblingWithSupInfo(itm.ActiveParent as ItemInfo);
   }
   EditItem chldOfNext = null;
   // if section, handle notes/cautions on section and if none, look for hls (children of section)
   if (itm.NextItem.IsSection) 
   {
    if (itm.NextItem.Steps = null || itm.NextItem.Steps.Count = 0) return null;
    chldOfNext = FindFirstCautionOrNoteWithSupInfo(itm.NextItem);
    if (chldOfNext != null) return CheckForExpanded(chldOfNext);
    chldOfNext = FindFirstChildWithSupInfo(itm.NextItem);
    if (chldOfNext != null) return CheckForExpanded(chldOfNext);
    return null;
   }
   // Handle caution/note off of itm.nextitem.  See if any of those have supinfos.
   chldOfNext = FindFirstCautionOrNoteWithSupInfo(itm.NextItem);
   if (chldOfNext != null) return CheckForExpanded(chldOfNext);
   / this is step side (parent) of supinfo part.  This step does not have any children with supinfo.
   / See if any of my next siblings have supinfo
   if (itm.NextItem.SupInfos != null && itm.NextItem.SupInfos.Count > 0)
   {
    return GetEditItemFromItemID(itm.NextItem.ItemID);
   }
   // no longer looking at next, go to children.
   chldOfNext = FindFirstChildWithSupInfo(itm.NextItem);  
   if (chldOfNext != null) return CheckForExpanded(chldOfNext);
   return FindSiblingOrParentSiblingWithSupInfo(itm.NextItem);
  }
  / FindFirstChildWithSupinfo finds the first child going down the screen that has a supinfo.  It checks for cautions and
  / notes first.
  private EditItem FindFirstChildWithSupInfo(ItemInfo itm)
  {
   // If on a caution, see if there are any notes below me on the screen that have supinfo.
   if (itm.IsCaution && (itm.ActiveParent as ItemInfo).Notes != null && (itm.ActiveParent as ItemInfo).Notes.Count > 0)
   {
    foreach (ItemInfo inote in (itm.ActiveParent as ItemInfo).Notes)
    {
     if (inote.SupInfos != null && inote.SupInfos.Count > 0)
      return GetEditItemFromItemID(inote.ItemID);
     EditItem chld = FindFirstChildWithSupInfo(inote);
     if (chld != null) return CheckForExpanded(chld);
    }
   }
   // if on a caution or note check the step below me, which is really my activeparent (cautions/notes are above their respective parent)
   if ((itm.IsCaution || itm.IsNote)  && (itm.NextItem = null || itm.NextItemCount = 0) && (itm.ActiveParent as ItemInfo).SupInfos != null && (itm.ActiveParent as ItemInfo).SupInfos.Count > 0)
    return GetEditItemFromItemID((itm.ActiveParent as ItemInfo).ItemID);
   // Finally check substeps:
   if (itm.Steps = null || itm.Steps.Count = 0) return null;
   foreach (ItemInfo ii in itm.Steps)
   {
    if (ii.SupInfos != null && ii.SupInfos.Count > 0)		
     return GetEditItemFromItemID(ii.ItemID);
    EditItem chld = FindFirstChildWithSupInfo(ii);
    if (chld != null) return CheckForExpanded(chld);
   }
   return null;
  }
  // FindFirstCautionOrNoteWithSupInfo looks for first caution or note going down the screen that has supInfo 
  private EditItem FindFirstCautionOrNoteWithSupInfo(ItemInfo itm)
  {
   if (itm.Cautions != null && itm.Cautions.Count > 0)
   {
    foreach (ItemInfo ii in itm.Cautions)
    {
     if (ii.SupInfos != null && ii.SupInfos.Count > 0)
      return GetEditItemFromItemID(ii.ItemID);
     EditItem chld = FindFirstChildWithSupInfo(ii);
     if (chld != null) return CheckForExpanded(chld);
    }
   }
   if (itm.Notes != null && itm.Notes.Count > 0)
   {
    foreach (ItemInfo ii in itm.Notes)
    {
     if (ii.SupInfos != null && ii.SupInfos.Count > 0)
      return GetEditItemFromItemID(ii.ItemID);
     EditItem chld = FindFirstChildWithSupInfo(ii);
     if (chld != null) return CheckForExpanded(chld);
    }
   }
   return null;
  }
  private EditItem GetEditItemFromItemID(int itemid)
  {
   if (!MyStepPanel._LookupEditItems.ContainsKey(itemid)) return null;
   return MyStepPanel._LookupEditItems[itemid];
  }
  / <summary>
  / Adjust the height of a Deviation Document Step Including the Cautions and Notes B2016-123, B2017-020, B2017-021
  / </summary>
  private void AdjustForDevDocStepHeight()
  {
   if (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format && MyParent.MyItemInfo.IsHigh)
   {
    int bot = MyParent.FindBottomDevDoc;
    int DDHeight = bot - FirstSiblingEditItem.Top;//Determine the height of the step including cautions and notes
    if (MyParent.DevDocHeight != DDHeight)
    {
     MyParent.DevDocHeight = DDHeight;// If the height has changed adjust the top of the next item down
     EditItem ei = NextDevDocStep;// RHM 20170216 Locate Next Dev Doc Step
     if (ei != null)
     {
      ei.Top = bot;
      ei.AdjustLocation();
     }
    }
   }
  }
  / RHM 20170216 - Find Next Dev Doc High Level Step
  / If caution Exists return caution
  // If note exists return note
  private EditItem NextDevDocStep
  {
   get
   {
    EditItem ei = this;
    while (ei != null && !ei.MyItemInfo.IsHigh) ei = ei.MyParent;// Get High Level Step
    if(ei != null) ei=ei.MyNextEditItem;// Get Next High Level Step
    if (ei != null)
    {
     if (ei.MyItemInfo.IsHigh && (ei.MyItemInfo.Cautions != null || ei.MyItemInfo.Notes != null))
     {
      if (ei.MyItemInfo.Cautions != null)// Look at cautions
      {
       EditItem eic = MyStepPanel._LookupEditItems[ei.MyItemInfo.Cautions[0].ItemID].BottomMostEditItem;
       ei = eic;
      }
      else if (ei.MyItemInfo.Notes != null)//Look at notes
      {
       EditItem ein = MyStepPanel._LookupEditItems[ei.MyItemInfo.Notes[0].ItemID].BottomMostEditItem;
       ei = ein;
      }
     }
    }
    return ei;
   }
  }
  // RHM 20170216 Find Parent by walking up MyPrevious
  private EditItem MyParent
  {
   get
   {
    if (MyParentEditItem != null) return MyParentEditItem;
    return MyPreviousEditItem.MyParent;
   }
  }
  protected void SetupEditItem(ItemInfo itemInfo, StepPanel myStepPanel, EditItem myParentEditItem, ChildRelation myChildRelation, bool expand, EditItem nextEditItem, bool addFirstChld)
  {
   if (myStepPanel.TopMostEditItem = null) myStepPanel.TopMostEditItem = this;
   //if (itemInfo.ItemID = 10366) Console.WriteLine("Here");
   //if (itemInfo.ItemID = 225) _MyStepRTB.Resize + new EventHandler(_MyStepRTB_Resize);
   _MyStepRTB.MyRTBItem = this;
   // TIMING: DisplayItem.TimeIt("CSLARTB InitComp");
   BackColor = myStepPanel.PanelColor;
   /_MyStepRTB.BackColor = myStepPanel.InactiveColor;
   / TODO: Adjust top based upon format
   // TODO: Remove Label and just output ident on the paint event
   TabLeft = 20;
   SetupHeader(itemInfo);
   this.Paint += new PaintEventHandler(EditItem_Paint);
   this.BackColorChanged += new EventHandler(EditItem_BackColorChanged);
   this.Move += new EventHandler(EditItem_Move);
   this.Resize += new EventHandler(EditItem_Resize);
   if (itemInfo != null)
   {
    ContentType = (int)itemInfo.MyContent.Type;
    switch (ContentType / 10000)
    {
     case 0: / Procedure
      ContentFont = myStepPanel.ProcFont;/ lblTab.Font = myStepPanel.ProcFont;
      TabFont = itemInfo.MyTab.MyFont.WindowsFont;
      break;
     case 1: / Section
      ContentFont = myStepPanel.SectFont;/ lblTab.Font = myStepPanel.SectFont;
      TabFont = itemInfo.MyTab.MyFont.WindowsFont;
      break;
     case 2: / Steps
      / Fix for B2016-037: there were '<NewID>'s in saved content text.  This was caused by a bug in code that
      / did not resolve these correctly if there was more than 1 in the text.  So if, when loading the text, this
      / is found, resolve them:
      if (itemInfo.MyContent.Text.Contains("<NewID>"))
      {
       DisplayText vlntxt = new DisplayText(itemInfo, E_EditPrintMode.Edit, E_ViewMode.Edit, false, E_FieldToEdit.StepText, true, null, null, false);
       vlntxt.SetDTS = false;
       vlntxt.CleanUpNewIDs();
       vlntxt = null;
      }
      ContentFont = myStepPanel.StepFont;//lblTab.Font = myStepPanel.StepFont;
      if (itemInfo.MyTab != null ) TabFont = itemInfo.MyTab.MyFont.WindowsFont;
      MyStepData = itemInfo.ActiveFormat.PlantFormat.FormatData.StepDataList[ContentType % 10000];
      break;
    }
    //this.Move += new EventHandler(DisplayItem_Move);
   }
   else
   {
    if (myStepPanel.MyFont != null) ContentFont = TabFont = myStepPanel.MyFont;
   }
   if (expand) ShowExpanded();
   MyStepPanel = myStepPanel;
   if (itemInfo != null && !myStepPanel._LookupEditItems.ContainsKey(itemInfo.ItemID)) myStepPanel._LookupEditItems.Add(itemInfo.ItemID, this);
   _MyChildRelation = myChildRelation;
   if (myParentEditItem != null) RNOLevel = myParentEditItem.RNOLevel;
   if (itemInfo != null)
   {
    // TIMING: DisplayItem.TimeIt("CSLARTB before _Layout");
    MyStepSectionLayoutData = itemInfo.ActiveFormat.MyStepSectionLayoutData;
    // TIMING: DisplayItem.TimeIt("CSLARTB _Layout");
    if (myParentEditItem != null)
     SeqLevel = myParentEditItem.SeqLevel + ((myChildRelation = ChildRelation.After || myChildRelation = ChildRelation.Before) && itemInfo.IsSequential ? 1 : 0);
    // TIMING: DisplayItem.TimeIt("CSLARTB seqLevel");
    MyItemInfo = itemInfo;
    MyItemInfo.MyConfig.PropertyChanged += new PropertyChangedEventHandler(MyConfig_PropertyChanged);
   }
   // TIMING: DisplayItem.TimeIt("CSLARTB MyItem");
   myStepPanel.Controls.Add(this);
   switch (myChildRelation)
   {
    case ChildRelation.After:
     AddItem(myParentEditItem, ref myParentEditItem._MyAfterEditItems, nextEditItem, addFirstChld);
     break;
    case ChildRelation.Before:
     AddItem(myParentEditItem, ref myParentEditItem._MyBeforeEditItems, nextEditItem, addFirstChld);
     break;
    case ChildRelation.RNO:
     RNOLevel = myParentEditItem.RNOLevel + 1;
     AddItem(myParentEditItem, ref myParentEditItem._MyRNOEditItems, nextEditItem, addFirstChld);
     break;
    case ChildRelation.SupInfo:
     AddItem(myParentEditItem, ref myParentEditItem._MySupInfoEditItems, nextEditItem, addFirstChld);
     break;
    case ChildRelation.None:
     break;
   }
   if (itemInfo != null)
   {
    // ip2bck's needed the ContentWidth set to get the edit windows to size correctly.
    if (itemInfo.IsStep && itemInfo.FormatStepData.Type = "TitleWithTextBelow" &&
     ((itemInfo.MyDocStyle.StructureStyle.Style & E_DocStructStyle.DSS_PageListSpBckgrnd) = E_DocStructStyle.DSS_PageListSpBckgrnd))
     ContentWidth = myParentEditItem.ContentWidth;
    if (itemInfo.IsStep && itemInfo.MyParent.IsFigure)
    {
     ContentWidth = myParentEditItem.MyParentEditItem.ContentWidth;
     Left = MyParentEditItem.MyParentEditItem.Left + MyParentEditItem.MyParentEditItem.TabLeft;
    }
    if (myChildRelation == ChildRelation.None)
    {
     if (ContentType = 0 && MyStepSectionLayoutData ! null)
     {
      LastMethodsPush(string.Format("SetupRTBItem {0}", MyID));
      int widt = MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidT);
      int wids = MyStepPanel.ToDisplay(MyStepSectionLayoutData.WidSTableEdit, 0);
      ItemWidth = Math.Max(widt, wids);
     }
    }
   }
   // TIMING: DisplayItem.TimeIt("CSLARTB Parent");
   SetText();
   if (itemInfo.IsSupInfoPart)
   {
    EditItem high = MyStepPanel._LookupEditItems[itemInfo.MyHLS.ItemID];
    ContentLocation = new Point(high.ContentLeft + high.Width + 36, (int)_MyParentEditItem.Top + SupInfoTopOffset);  
   }
   // TIMING: DisplayItem.TimeIt("CSLARTB SetText");
   if (itemInfo != null)
   {
    Name = string.Format("Item-{0}", itemInfo.ItemID);
    SetExpandAndExpander(itemInfo);
    if (expand && (itemInfo.MyContent.ContentPartCount != 0)) // If it should expand and it can expand
     Expand(true);
    else
     if (myParentEditItem = null)// If it is the top node
      if (ContentType > 20000) // and it is a step - fully expand
       Expand(true);
      else // otherwise only expand one level
       Expand(false);
   }
   // TIMING: DisplayItem.TimeIt("CSLARTB before Controls Add");
   /myStepPanel.Controls.Add(this);
   / If on the first Caution/Note and the parent has a previous, for example a caution off of 5th HLS, go to the
   // bottom on the previous parent.  In the example, the bottom of the 4th HLS.
   int btm = myStepPanel.DisplayRectangle.Y;
   int top = FindTop(btm);
   if (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format)
    if (MyItemInfo.IsCaution || MyItemInfo.IsNote)
     top = myParentEditItem.TopMostEditItem.Top;
   /if ((MyItemInfo.SameRowAsParent && MyItemInfo.IsCaution2) || (MyItemInfo.ActiveFormat.MyStepSectionLayoutData.Dev_Format && (MyItemInfo.IsCaution || MyItemInfo.IsNote)))
   /        top = myParentEditItem.TopMostEditItem.Top;
   if (Top < top)
   {
    LastMethodsPush("SetupRTBItem");
    MyStepPanel.ItemMoving++;
    Top = top;
    MyStepPanel.ItemMoving–;
    LastMethodsPop();
   }
   this.Enabled = this.MyItemInfo.IsApplicable(MyStepPanel.ApplDisplayMode);
   _Loading = false;
   // TIMING: DisplayItem.TimeIt("CSLARTB Controls Add");
  }
  void MyConfig_PropertyChanged(object sender, PropertyChangedEventArgs e)
  {
   SaveConfig();
  }
  public void SaveConfig()
  {
   if (!MyItemInfo.MyConfig.IsDirty) return;
   using (Item itm = MyItemInfo.Get())
   {
    itm.MyContent.Config = MyItemInfo.MyConfig.ToString();
    if (ChangeBarForConfigItemChange)
     itm.MyContent.DTS = DateTime.Now;
    itm.MyContent.UserID = Volian.Base.Library.VlnSettings.UserID;
    itm.Save();
   }
   MyItemInfo.MyConfig.IsDirty = false;
  }
  / <summary>
  / If the background changes, change the background of the RichTextBox
  / </summary>
  / <param name="sender"></param>
  / <param name="e"></param>
  void EditItem_BackColorChanged(object sender, EventArgs e)
  {
   //IdentifyMe(false);
  }
  / TODO: the format of the circles, Checkoffs and Changebars should come from the format file
  // <summary>
  / This adds drawing items to the RTBItem as needed including
  / Circle around the Tab Number
  / Check-Offs
  / Change Bars
  / </summary>
  / <param name="sender"></param>
  / <param name="e"></param>
  private void EditItem_Paint(object sender, PaintEventArgs e)
  {
   Graphics g = e.Graphics;
   g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.AntiAlias;
   /g.DrawString(lblTab.Text, MyItemInfo.MyTab.MyFont.WindowsFont, Brushes.Red, new RectangleF(new PointF(MyStepPanel.MyStepPanelSettings.NumberLocationX, MyStepPanel.MyStepPanelSettings.NumberLocationY), MyStepPanel.MyStepPanelSettings.NumberSize), StringFormat.GenericDefault);
   / adjust x location of label by 7, to position correctly.
   //g.DrawString(lblTab.Text, MyItemInfo.MyTab.MyFont.WindowsFont, Brushes.Blue, new RectangleF(new PointF(Convert.ToSingle(lblTab.Location.X-7), Convert.ToSingle(lblTab.Location.Y)), MyStepPanel.MyStepPanelSettings.NumberSize), StringFormat.GenericDefault);
   /g.DrawLine(Pens.DarkGreen, lblTab.Location.X-7, 0, lblTab.Location.X-7, this.Height);
   / Show a small E to indicate Enhanced Steps
   DVEnhancedDocuments dveds = MyItemInfo.MyDocVersion.DocVersionConfig.MyEnhancedDocuments;
   float x = 0;
   float y = 0;
   foreach (EnhancedDocument ed in MyItemInfo.GetMyEnhancedDocuments())
   {
    DVEnhancedDocument dved = dveds.GetByType(ed.Type);
    Font fnt = new System.Drawing.Font("Arial", 5);
    //g.DrawLine(Pens.DarkGreen, 18, 1, 18, 6);
    //g.DrawLine(Pens.DarkGreen, 18, 1, 21, 1);
    //g.DrawLine(Pens.DarkGreen, 18, 3, 21, 3); 
    //g.DrawLine(Pens.DarkGreen, 18, 6, 21, 6);
    //g.DrawString("B", fnt, Brushes.Green, new RectangleF(new PointF(0,0), this.Size), StringFormat.GenericDefault);
    g.DrawString(dved.PdfToken, fnt, Brushes.Green, new RectangleF(new PointF(x,y), this.Size), StringFormat.GenericDefault);
    if (y > 0)
    {
     x += 18;
     y = 0;
    }
    else
     y = 14;
   }
   //g.DrawLine(Pens.DarkGreen, MyStepRTB.Location.X - 7, 0, MyStepRTB.Location.X - 7, this.Height);
   //g.DrawString(TabText, MyItemInfo.MyTab.MyFont.WindowsFont, Brushes.Black, new RectangleF(new PointF(Convert.ToSingle(TabLocation.X), Convert.ToSingle(TabLocation.Y)), MyStepPanel.MyStepPanelSettings.NumberSize), StringFormat.GenericDefault);
   Font myWFont = (MyItemInfo.MyTab != null) ? MyItemInfo.MyTab.MyFont.WindowsFont : MyItemInfo.FormatStepData.Font.WindowsFont;
   g.DrawString(TabText, myWFont, Brushes.Black, new RectangleF(new PointF(Convert.ToSingle(TabLocation.X), Convert.ToSingle(TabLocation.Y)), this.Size), StringFormat.GenericDefault);
//g.DrawLine(Pens.DarkGreen, lblTab.Location.X, 0, lblTab.Location.X, this.Height); //g.DrawLine(Pens.DarkGreen, MyStepRTB.Location.X, 0, MyStepRTB.Location.X, this.Height); if (Circle) { Pen penC = new Pen(MyStepPanel.MyStepPanelSettings.CircleColor, MyStepPanel.MyStepPanelSettings.CircleWeight); g.DrawArc(penC, TabLeft + 1, 0, MyStepPanel.MyStepPanelSettings.CircleDiameter, MyStepPanel.MyStepPanelSettings.CircleDiameter, 0F, 360F); } if (CheckOff) { Pen penCO = new Pen(MyStepPanel.MyStepPanelSettings.CheckOffColor, MyStepPanel.MyStepPanelSettings.CheckOffWeight); g.DrawRectangle(penCO, MyStepPanel.MyStepPanelSettings.CheckOffX, MyStepPanel.MyStepPanelSettings.CheckOffY, MyStepPanel.MyStepPanelSettings.CheckOffSize, MyStepPanel.MyStepPanelSettings.CheckOffSize); } if (ChangeBar) { Pen penCB = new Pen(MyStepPanel.MyStepPanelSettings.ChangeBarColor, MyStepPanel.MyStepPanelSettings.ChangeBarWeight); if (ChangeBarPosition == E_ChangeBarPosition.Left) g.DrawLine(penCB, 0, ContentTop, 0, Height); // left, top, right, bottom. else { float X; float H; if (this is GridItem) { GridItem gi = this as GridItem; X = gi.MyFlexGrid.Right+2; H = gi.MyFlexGrid.Height; } else if (this is RtfRawItem) { RtfRawItem ri = this as RtfRawItem; X = ri.MyStepRTB.Right + 4; H = ri.MyStepRTB.Height; } else if (this is ImageItem) { ImageItem ii = this as ImageItem; X = ii.MyPictureBox.Right + 4; H = ii.MyPictureBox.Height; } else { RTBItem ri = this as RTBItem; X = ri.MyStepRTB.Right + 2; H = ri.MyStepRTB.Height; } g.DrawLine(penCB, X, ContentTop, X, ContentTop+H); //Height); } } if (UserCheckOff) { PointF location; if (this is GridItem) { GridItem gi = this as GridItem; location = new PointF(gi.MyFlexGrid.Left + gi.MyFlexGrid.Width + 2, gi.MyFlexGrid.Top); } else if (this is RtfRawItem) { RtfRawItem rr = this as RtfRawItem; / SkipSpaces puts the checkoff macro (if specified in the format) next to the step tab / this is used for Bryon and Braidwood if (MyItemInfo.ActiveFormat.PlantFormat.FormatData.ProcData.CheckOffData.SkipSpaces) location = new PointF(rr.MyStepRTB.Left - 50, rr.MyStepRTB.Top); else location = new PointF(rr.MyStepRTB.Left + rr.MyStepRTB.Width + 2, rr.MyStepRTB.Top); } else if (this is ImageItem) { ImageItem ii = this as ImageItem; if (MyItemInfo.ActiveFormat.PlantFormat.FormatData.ProcData.CheckOffData.SkipSpaces) location = new PointF(ii.MyPictureBox.Left - 50, ii.MyPictureBox.Top); else location = new PointF(ii.MyPictureBox.Left + ii.MyPictureBox.Width + 2, ii.MyPictureBox.Top); } else { RTBItem ri = this as RTBItem; / SkipSpaces puts the checkoff macro (if specified in the format) next to the step tab / this is used for Bryon and Braidwood if (MyItemInfo.ActiveFormat.PlantFormat.FormatData.ProcData.CheckOffData.SkipSpaces) location = new PointF(ri.MyStepRTB.Left - 50, ri.MyStepRTB.Top); else location = new PointF(ri.MyStepRTB.Left + ri.MyStepRTB.Width + 2, ri.MyStepRTB.Top); } CheckOff co = MyItemInfo.GetCheckOffStep(); / There may have been a data change in the setting of which checkoff to use (property / change in the config data), or whether a checkoff is used at all. Need to set the // 'UserCheckOff' or 'UserCheckOffChar' properties to reflect that. if (co != null && co.UIMark != null) { UserCheckOffChar = (char)co.UIMark; Font myFont = new Font("VolianDraw", MyItemInfo.MyTab.MyFont.WindowsFont.Size); g.DrawString(UserCheckOffChar.ToString(), myFont, Brushes.DarkGreen, new RectangleF(location, MyStepPanel.MyStepPanelSettings.NumberSize), StringFormat.GenericDefault); } else if (co == null) UserCheckOff = false; } } } }