UltimateZoneBuilder/Source/Plugins/CommentsPanel/BuilderPlug.cs

139 lines
3.7 KiB
C#
Executable file

#region ================== Copyright (c) 2010 Pascal vd Heiden
/*
* Copyright (c) 2010 Pascal vd Heiden
* This program is released under GNU General Public License
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
*/
#endregion
#region ================== Namespaces
using CodeImp.DoomBuilder.Controls;
using CodeImp.DoomBuilder.Editing;
using CodeImp.DoomBuilder.Plugins;
using CodeImp.DoomBuilder.Config;
#endregion
namespace CodeImp.DoomBuilder.CommentsPanel
{
//
// MANDATORY: The plug!
// This is an important class to the Doom Builder core. Every plugin must
// have exactly 1 class that inherits from Plug. When the plugin is loaded,
// this class is instantiated and used to receive events from the core.
// Make sure the class is public, because only public classes can be seen
// by the core.
//
public class BuilderPlug : Plug
{
// Static instance. We can't use a real static class, because BuilderPlug must
// be instantiated by the core, so we keep a static reference. (this technique
// should be familiar to object-oriented programmers)
private static BuilderPlug me;
// Docker
private CommentsDocker dockerpanel;
private Docker commentsdocker;
// Static property to access the BuilderPlug
public static BuilderPlug Me { get { return me; } }
// This event is called when the plugin is initialized
public override void OnInitialize()
{
base.OnInitialize();
// Keep a static reference
me = this;
}
// When a map is created
public override void OnMapNewEnd()
{
OnMapOpenEnd();
}
// This is called after a map has been successfully opened
public override void OnMapOpenEnd()
{
// If we just opened a UDMF format map, we want to create the Comments panel!
if(General.Map.Config.FormatInterface == "UniversalMapSetIO")
{
dockerpanel = new CommentsDocker();
commentsdocker = new Docker("commentsdockerpanel", "Comments", dockerpanel);
General.Interface.AddDocker(commentsdocker);
dockerpanel.Setup();
dockerpanel.UpdateListSoon();
}
}
// Occurs before the map is closed
public override void OnMapCloseBegin()
{
// If we have a Comments panel, remove it
if(dockerpanel != null)
{
dockerpanel.Terminate();
General.Interface.RemoveDocker(commentsdocker);
commentsdocker = null;
dockerpanel.Dispose();
dockerpanel = null;
}
}
// Geometry pasted
public override void OnPasteEnd(PasteOptions options)
{
if(dockerpanel != null)
dockerpanel.UpdateListSoon();
}
// Undo performed
public override void OnUndoEnd()
{
if(dockerpanel != null)
dockerpanel.UpdateListSoon();
}
// Redo performed
public override void OnRedoEnd()
{
if(dockerpanel != null)
dockerpanel.UpdateListSoon();
}
// Edit performed
public override void OnEditAccept()
{
dockerpanel?.UpdateListSoon();
}
// Mode changes
public override bool OnModeChange(EditMode oldmode, EditMode newmode)
{
if(dockerpanel != null)
dockerpanel.UpdateListSoon();
return base.OnModeChange(oldmode, newmode);
}
/// <summary>
/// Checks if the currently active docker is the Comments docker.
/// </summary>
/// <returns>true if the Comments docker is active, otherwise false</returns>
public bool IsDockerActive()
{
return General.Interface.ActiveDockerTabName == commentsdocker.Title;
}
}
}