/*
* Copyright � 2005, Mathew Hall
* All rights reserved.
*
* 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 OWNER 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 XPTable.Models;
namespace XPTable.Events
{
#region Delegates
/// <summary>
/// Represents the methods that will handle the PropertyChanged event of a Cell
/// </summary>
public delegate void CellEventHandler(object sender, CellEventArgs e);
#endregion
#region CellEventArgs
/// <summary>
/// Provides data for a Cell's PropertyChanged event
/// </summary>
public class CellEventArgs : CellEventArgsBase
{
#region Class Data
/// <summary>
/// The type of event
/// </summary>
private CellEventType eventType;
/// <summary>
/// The old value of the property
/// </summary>
private object oldValue;
#endregion
#region Constructor
/// <summary>
/// Initializes a new instance of the CellEventArgs class with
/// the specified Cell source and event type
/// </summary>
/// <param name="source">The Cell that Raised the event</param>
/// <param name="eventType">The type of event</param>
/// <param name="oldValue">The old value of the property</param>
public CellEventArgs(Cell source, CellEventType eventType, object oldValue) : this(source, -1, -1, eventType, oldValue)
{
}
/// <summary>
/// Initializes a new instance of the CellEventArgs class with
/// the specified Cell source, column index, row index and event type
/// </summary>
/// <param name="source">The Cell that Raised the event</param>
/// <param name="column">The Column index of the Cell</param>
/// <param name="row">The Row index of the Cell</param>
/// <param name="eventType">The type of event</param>
/// <param name="oldValue">The old value of the property</param>
public CellEventArgs(Cell source, int column, int row, CellEventType eventType, object oldValue) : base(source, column, row)
{
this.eventType = eventType;
this.oldValue = oldValue;
}
#endregion
#region Properties
/// <summary>
/// Gets or sets the type of event
/// </summary>
public CellEventType EventType
{
get
{
return this.eventType;
}
}
/// <summary>
/// Gets the old value of the property
/// </summary>
public object OldValue
{
get
{
return this.oldValue;
}
}
#endregion
}
#endregion
}