/[RomCheater]/trunk/RomCheater.RVAScratchPad/Form1.cs
ViewVC logotype

Diff of /trunk/RomCheater.RVAScratchPad/Form1.cs

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

--- trunk/RomCheater.RVAScratchPad/Form1.cs	2013/06/18 10:59:36	716
+++ trunk/RomCheater.RVAScratchPad/Form1.cs	2013/06/19 01:37:36	727
@@ -11,11 +11,13 @@
 using System.IO;
 using RomCheater.PluginFramework.Core;
 using RomCheater.Core;
+using RomCheater.UserSettingsSupport;
 
 namespace RomCheater.RVAScratchPad
 {
     public partial class Form1 : Form
     {
+        private SettingSubscriber SettingsSubscriber = null;
         private bool m_bSaveLayout = true;
         PluginLoader loader = null;
         IConfigPlugin ConfigPlugin = null;
@@ -27,6 +29,10 @@
         private FloatingLogWindow m_LogWindow = new FloatingLogWindow();
         private FloatingWebBrowser m_wb = new FloatingWebBrowser();
 
+        public IWebBrowserProvider WebBrowserProvider
+        {
+            get { return new WebBrowserProvider(m_wb); }
+        }
         #region LogWriterSupport
         static LogWriter _LoggerInstance;
         static LogWriter LoggerInstance
@@ -40,8 +46,10 @@
         public Form1(bool no_console_redirect)
         {
             InitializeComponent();
+            SettingsSubscriber = new SettingSubscriber();
+            SettingsSubscriber.AddSubscriber(this, RomCheater.Properties.Settings.Default);              
             load_loggerflags();
-            //SetupDocks();
+            SetupDocks();
             LoggerInstance = m_LogWindow.Logwriter;
             LoggerInstance.CreateNewLog(false);
             logger.ForceLog.Info.WriteLine("LoggingFlags = 0x{0:x4} ({1})", logger.GetLoggingFlags().Value, logger.GetLoggingFlags().Name);
@@ -62,51 +70,54 @@
         {
             loader = new PluginLoader();
             loader.LoadPlugins(silent);
-            var config = PluginCollection.GetPluginByName(PluginNames.GenericConfig);
+
+            var LastConfigPlugin = SettingsSubscriber.GetValue("LastConfigPlugin").ToString();
+            if (LastConfigPlugin != null)
+            {
+                ConfigPlugin = loader.GetConfigPlugin(LastConfigPlugin.ToString());
+            }
+            else
+            {
+                var config = PluginCollection.GetPluginByName(PluginNames.GenericConfig);
+                ConfigPlugin = loader.GetPluginByGuid<IConfigPlugin>(config.ID.ToString());
+            }
+
+            // update the Config plugin's reference to the webbrowswer
+            ConfigPlugin.WebBrowserProvider = this.WebBrowserProvider;
+
+            SettingsSubscriber.SetValue("LastConfigPlugin", ConfigPlugin.ToString());
+
             var scratchpad = PluginCollection.GetPluginByName(PluginNames.ScratchPadPlugin);
-            var rvacalc = PluginCollection.GetPluginByName(PluginNames.RVACalculatorPlugin);
-            ConfigPlugin = loader.GetPluginByGuid<IConfigPlugin>(config.ID.ToString());
+            var rvacalc = PluginCollection.GetPluginByName(PluginNames.RVACalculatorPlugin);            
             ScratchPadPlugin = loader.GetPluginByGuid<IUserControlPlugin>(scratchpad.ID.ToString());
             RVACalcPlugin = loader.GetPluginByGuid<IUserControlPlugin>(rvacalc.ID.ToString());
+
+            // update config of each plugin
+            ScratchPadPlugin.SetAcceptedConfig(ConfigPlugin);
+            RVACalcPlugin.SetAcceptedConfig(ConfigPlugin);
         }
 
 
 
         #region Dock Support
-        //void AddDockToWindowList(object sender, EventArgs e)
-        //{
-        //    DockContent dc;
-        //    TypeBinder.Bind(sender, out dc);
-        //    ToolStripMenuItem tsmi = new ToolStripMenuItem(dc.Text);
-        //    tsmi.Name = dc.Name;
-        //    tsmi.Tag = dc;
-        //    tsmi.Click += new EventHandler(tsmi_Click);
-        //    mnuWindows.DropDownItems.Add(tsmi);
-        //}
-        //void tsmi_Click(object sender, EventArgs e)
-        //{
-        //    ToolStripMenuItem tsmi;
-        //    TypeBinder.Bind(sender, out tsmi);
-        //    DockContent dc;
-        //    TypeBinder.Bind(tsmi.Tag, out dc);
-        //    dc.Activate();
-        //}
-        //void RemoveDockFromWindowList(object sender, FormClosedEventArgs e)
-        //{
-        //    DockContent dc;
-        //    TypeBinder.Bind(sender, out dc);
-        //    mnuWindows.DropDownItems.RemoveByKey(dc.Name);
-        //}
         private IDockContent GetContentFromPersistString(string persistString)
         {
             if (persistString == typeof(FloatingLogWindow).ToString()) { return m_LogWindow; }
             if (persistString == typeof(FloatingWebBrowser).ToString()) { return m_wb; }
-            else { return null; }
+            if (RVACalcPlugin != null) { if (persistString == RVACalcPlugin.IDockContentTypeName) { return RVACalcPlugin.DockContent; } }
+            if (ScratchPadPlugin != null) { if (persistString == ScratchPadPlugin.IDockContentTypeName) { return ScratchPadPlugin.DockContent; } }            
+            return null;
         }
         public void SetupDocks()
         {
             m_LogWindow = new FloatingLogWindow();
+            //m_LogWindow.CloseButton = false;
+            //m_LogWindow.CloseButtonVisible = false;
+
             m_wb = new FloatingWebBrowser();
+            //m_wb.CloseButton = false;
+            //m_wb.CloseButtonVisible = false;
+
             m_deserializeDockContent = new DeserializeDockContent(GetContentFromPersistString);
         }
         #region SetupDockWindowHandler support
@@ -118,13 +129,14 @@
         }
         private void SetupPluginWindowHandlers()
         {
-            //if (RVACalcPlugin != null)
-            //{
-                
-            //}
-            //if (ScratchPadPlugin != null)
-            //{
-            //}
+            if (RVACalcPlugin != null)
+            {
+                RVACalcPlugin.Activate();
+            }
+            if (ScratchPadPlugin != null)
+            {
+                ScratchPadPlugin.Activate();
+            }
         }
         private void SetupLogWindowHandler()
         {
@@ -149,14 +161,21 @@
             SetupWebBrowserWindowHandler();
             ShowPluginWindows();
             SetupPluginWindowHandlers();
+
+            if (RVACalcPlugin != null)
+                RVACalcPlugin.Activate();
         }
         public void ShowLogWindow()
         {
             if (m_LogWindow == null || m_LogWindow.IsDisposed) { m_LogWindow = new FloatingLogWindow(); }
-            LoggerInstance = m_LogWindow.Logwriter;
-            LoggerInstance.CreateNewLog(false);
-            m_LogWindow.CloseButton = false;
-            m_LogWindow.CloseButtonVisible = false;
+            if (LoggerInstance == null)
+            {
+                LoggerInstance = m_LogWindow.Logwriter;
+                LoggerInstance.CreateNewLog(false);
+            }
+            //m_LogWindow.AllowEndUserDocking = true;
+            //m_LogWindow.CloseButton = false;
+            //m_LogWindow.CloseButtonVisible = false;
             m_LogWindow.Show(dockPanel, DockState.DockBottom);
         }
 
@@ -165,21 +184,35 @@
         {
             //load_plugins_silent();
             m_wb = new FloatingWebBrowser();
-            m_wb.CloseButton = false;
-            m_wb.CloseButtonVisible = false;
-            m_wb.Show(dockPanel);
+            //m_wb.AllowEndUserDocking = true;
+            //m_wb.CloseButton = false;
+            //m_wb.CloseButtonVisible = false;
+            m_wb.Show(dockPanel, DockState.Document);
         }
         public void ShowPluginWindows()
         {
-            // RVA Calc
-            RVACalcPlugin.Show(dockPanel);
-            // ScratchPad
-            ScratchPadPlugin.Show(dockPanel);
+            if (RVACalcPlugin != null)
+            {
+                // RVA Calc                
+                //RVACalcPlugin.DockHandler.CloseButton = false;                
+                //RVACalcPlugin.DockHandler.CloseButtonVisible = false;
+                //RVACalcPlugin.DockHandler.AllowEndUserDocking = true;
+                RVACalcPlugin.Show(dockPanel);
+            }
+            if (ScratchPadPlugin != null)
+            {
+                // ScratchPad                
+                //ScratchPadPlugin.DockHandler.CloseButton = false;
+                //ScratchPadPlugin.DockHandler.CloseButtonVisible = false;
+                //ScratchPadPlugin.DockHandler.AllowEndUserDocking = true;
+                ScratchPadPlugin.Show(dockPanel, DockState.Document);
+            }
         }
         #endregion
 
         private void Form1_FormClosing(object sender, FormClosingEventArgs e)
         {
+            SettingsSubscriber.SaveSettings();
             string configFile = Path.Combine(Path.GetDirectoryName(Application.ExecutablePath), "RVAScratchPad-DockPanel.config");
             if (m_bSaveLayout)
                 dockPanel.SaveAsXml(configFile);
@@ -219,6 +252,8 @@
                 ShowDocks();
             }
 
+            if (RVACalcPlugin != null)
+                RVACalcPlugin.Activate();
             //dockPanel.ResumeLayout(true, true);
         }
 
@@ -226,5 +261,7 @@
         {
             this.Close();
         }
+
+        private void Form1_Load(object sender, EventArgs e) { }
     }
 }

 

  ViewVC Help
Powered by ViewVC 1.1.22