mirror of
https://github.com/xcp-ng/xenadmin.git
synced 2025-01-20 07:19:18 +01:00
213 lines
7.1 KiB
C#
213 lines
7.1 KiB
C#
/* Copyright (c) Cloud Software Group, Inc.
|
|
*
|
|
* Redistribution and use in source and binary forms,
|
|
* with or without modification, are permitted provided
|
|
* that the following conditions are met:
|
|
*
|
|
* * Redistributions of source code must retain the above
|
|
* copyright notice, this list of conditions and the
|
|
* following disclaimer.
|
|
* * Redistributions in binary form must reproduce the above
|
|
* copyright notice, this list of conditions and the
|
|
* following disclaimer in the documentation and/or other
|
|
* materials provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
|
|
* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
|
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
|
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*/
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.ComponentModel;
|
|
using System.Windows.Forms;
|
|
using System.Windows.Forms.Design;
|
|
using XenAdmin.Network;
|
|
|
|
|
|
namespace XenAdmin.Controls
|
|
{
|
|
[Designer(typeof(ParentControlDesigner))]
|
|
public partial class XenTabPage : UserControl
|
|
{
|
|
public IXenConnection Connection;
|
|
|
|
/// <summary>
|
|
/// Set this value to true to grey the step out in the wizard progress and mark it to be skipped
|
|
/// </summary>
|
|
public bool DisableStep;
|
|
|
|
/// <summary>
|
|
/// Gets or sets a value describing whether it is the first time the page is loaded after
|
|
/// a change in a previous page affecting this one has taken place. Default value is True.
|
|
/// </summary>
|
|
public bool IsFirstLoad { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gets or sets a value describing whether there are pending changes in the page.
|
|
/// Default value is True (so the page takes in the default values of the controls)
|
|
/// </summary>
|
|
protected bool IsDirty { get; set; }
|
|
|
|
/// <summary>
|
|
/// Does the page use IsDirty?
|
|
/// </summary>
|
|
protected virtual bool ImplementsIsDirty()
|
|
{
|
|
return false;
|
|
}
|
|
|
|
public XenTabPage()
|
|
{
|
|
InitializeComponent();
|
|
IsFirstLoad = true;
|
|
IsDirty = true;
|
|
}
|
|
|
|
public Action<XenTabPage> WizardContentUpdater { protected get; set; }
|
|
public Func<XenTabPage, bool> NextPagePrecheck { protected get; set; }
|
|
|
|
protected override bool ScaleChildren => false;
|
|
|
|
/// <summary>
|
|
/// Gets the page's label in the (left hand side) wizard progress panel
|
|
/// </summary>
|
|
[EditorBrowsable(EditorBrowsableState.Always)]
|
|
[Browsable(true)]
|
|
[DesignerSerializationVisibility(DesignerSerializationVisibility.Visible)]
|
|
[Bindable(true)]
|
|
public override string Text
|
|
{
|
|
get => base.Text;
|
|
set => base.Text = value;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the page's title (headline)
|
|
/// </summary>
|
|
public virtual string PageTitle => null;
|
|
|
|
/// <summary>
|
|
/// Gets the value by which the help files section for this page is identified
|
|
/// Most derived classes override it to return a fixed string
|
|
/// </summary>
|
|
public virtual string HelpID => string.Empty;
|
|
|
|
public virtual string NextText(bool isLastPage)
|
|
{
|
|
return isLastPage ? Messages.FINISH : Messages.WIZARD_BUTTON_NEXT;
|
|
}
|
|
|
|
public virtual List<KeyValuePair<string, string>> PageSummary { get { return new List<KeyValuePair<string, string>>(); } }
|
|
|
|
public virtual bool EnableNext()
|
|
{
|
|
return true;
|
|
}
|
|
|
|
public virtual bool EnablePrevious()
|
|
{
|
|
return true;
|
|
}
|
|
|
|
public virtual bool EnableCancel()
|
|
{
|
|
return true;
|
|
}
|
|
|
|
public void PageLoaded(PageLoadedDirection direction)
|
|
{
|
|
if (direction == PageLoadedDirection.Forward && IsFirstLoad)
|
|
{
|
|
if (ImplementsIsDirty())
|
|
IsDirty = true;
|
|
|
|
PopulatePage();
|
|
IsFirstLoad = false;
|
|
}
|
|
|
|
PageLoadedCore(direction);
|
|
}
|
|
|
|
protected virtual void PageLoadedCore(PageLoadedDirection direction)
|
|
{
|
|
}
|
|
|
|
public void PageLeave(PageLoadedDirection direction, ref bool cancel)
|
|
{
|
|
PageLeaveCore(direction, ref cancel);
|
|
|
|
if (direction == PageLoadedDirection.Forward && !cancel)
|
|
{
|
|
if (ImplementsIsDirty() && IsDirty && WizardContentUpdater != null)
|
|
{
|
|
WizardContentUpdater.Invoke(this);//notify the wizard that the page contents have been updated
|
|
IsDirty = false; //reset edited state
|
|
return;
|
|
}
|
|
|
|
if (NextPagePrecheck != null)
|
|
cancel = !NextPagePrecheck.Invoke(this);
|
|
|
|
if (!cancel && WizardContentUpdater != null)
|
|
WizardContentUpdater.Invoke(this);//notify the wizard that the page contents have been updated
|
|
}
|
|
}
|
|
|
|
protected virtual void PageLeaveCore(PageLoadedDirection direction, ref bool cancel)
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// Called when the wizard's Cancel button is hit while on this page
|
|
/// </summary>
|
|
public virtual void PageCancelled(ref bool cancel)
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// Fired when the page is ready (or not) for the user to advance to the next page).
|
|
/// Currently not implemented by all pages.
|
|
/// </summary>
|
|
public event Action<XenTabPage> StatusChanged;
|
|
|
|
/// <summary>
|
|
/// Not always overridden in derived classes
|
|
/// </summary>
|
|
public virtual void PopulatePage() { }
|
|
|
|
/// <summary>
|
|
/// Check whether this step needs to be disabled. Not always overridden in derived classes
|
|
/// </summary>
|
|
public virtual void CheckPageDisabled() { }
|
|
|
|
/// <summary>
|
|
/// Select a control on the page. Not always overridden in derived classes
|
|
/// </summary>
|
|
public virtual void SelectDefaultControl() { }
|
|
|
|
protected void OnPageUpdated()
|
|
{
|
|
if (StatusChanged != null)
|
|
StatusChanged(this);
|
|
}
|
|
}
|
|
|
|
public enum PageLoadedDirection
|
|
{
|
|
Forward,
|
|
Back
|
|
}
|
|
}
|