2014-05-24 17:07:03 +12:00
|
|
|
|
#region License Information (GPL v3)
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
ShareX - A program that allows you to take screenshots and share any file type
|
2022-01-12 05:32:17 +13:00
|
|
|
|
Copyright (c) 2007-2022 ShareX Team
|
2014-05-24 17:07:03 +12:00
|
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
|
|
|
modify it under the terms of the GNU General Public License
|
|
|
|
|
as published by the Free Software Foundation; either version 2
|
|
|
|
|
of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
|
|
|
|
|
|
Optionally you can also view the license at <http://www.gnu.org/licenses/>.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#endregion License Information (GPL v3)
|
|
|
|
|
|
2017-10-23 07:57:06 +13:00
|
|
|
|
using System;
|
2014-05-24 17:07:03 +12:00
|
|
|
|
using System.Collections;
|
|
|
|
|
using System.Windows.Forms;
|
|
|
|
|
|
2014-12-11 09:25:20 +13:00
|
|
|
|
namespace ShareX.HelpersLib
|
2014-05-24 17:07:03 +12:00
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// This class is an implementation of the 'IComparer' interface.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public class ListViewColumnSorter : IComparer
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Specifies the column to be sorted
|
|
|
|
|
/// </summary>
|
|
|
|
|
private int ColumnToSort;
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Specifies the order in which to sort (i.e. 'Ascending').
|
|
|
|
|
/// </summary>
|
|
|
|
|
private SortOrder OrderOfSort;
|
|
|
|
|
/// <summary>
|
2017-10-23 07:57:06 +13:00
|
|
|
|
/// Specifies whether to sort as a date
|
|
|
|
|
/// </summary>
|
|
|
|
|
public bool SortByDate { get; set; }
|
|
|
|
|
/// <summary>
|
2014-05-24 17:07:03 +12:00
|
|
|
|
/// Case insensitive comparer object
|
|
|
|
|
/// </summary>
|
|
|
|
|
private CaseInsensitiveComparer ObjectCompare;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Class constructor. Initializes various elements
|
|
|
|
|
/// </summary>
|
|
|
|
|
public ListViewColumnSorter()
|
|
|
|
|
{
|
|
|
|
|
// Initialize the column to '0'
|
|
|
|
|
ColumnToSort = 0;
|
|
|
|
|
|
|
|
|
|
// Initialize the sort order to 'none'
|
|
|
|
|
OrderOfSort = SortOrder.None;
|
|
|
|
|
|
2017-10-23 07:57:06 +13:00
|
|
|
|
SortByDate = false;
|
|
|
|
|
|
2014-05-24 17:07:03 +12:00
|
|
|
|
// Initialize the CaseInsensitiveComparer object
|
|
|
|
|
ObjectCompare = new CaseInsensitiveComparer();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// This method is inherited from the IComparer interface. It compares the two objects passed using a case insensitive comparison.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="x">First object to be compared</param>
|
|
|
|
|
/// <param name="y">Second object to be compared</param>
|
|
|
|
|
/// <returns>The result of the comparison. "0" if equal, negative if 'x' is less than 'y' and positive if 'x' is greater than 'y'</returns>
|
|
|
|
|
public int Compare(object x, object y)
|
|
|
|
|
{
|
|
|
|
|
int compareResult;
|
|
|
|
|
ListViewItem listviewX, listviewY;
|
|
|
|
|
|
|
|
|
|
// Cast the objects to be compared to ListViewItem objects
|
|
|
|
|
listviewX = (ListViewItem)x;
|
|
|
|
|
listviewY = (ListViewItem)y;
|
|
|
|
|
|
|
|
|
|
// Compare the two items
|
2017-10-23 07:57:06 +13:00
|
|
|
|
if (SortByDate)
|
2017-10-24 08:04:19 +13:00
|
|
|
|
{
|
2017-10-23 07:57:06 +13:00
|
|
|
|
compareResult = DateTime.Compare((DateTime)listviewX.SubItems[ColumnToSort].Tag, (DateTime)listviewY.SubItems[ColumnToSort].Tag);
|
2017-10-24 08:04:19 +13:00
|
|
|
|
}
|
2017-10-23 07:57:06 +13:00
|
|
|
|
else
|
2017-10-24 08:04:19 +13:00
|
|
|
|
{
|
2017-10-23 07:57:06 +13:00
|
|
|
|
compareResult = ObjectCompare.Compare(listviewX.SubItems[ColumnToSort].Text, listviewY.SubItems[ColumnToSort].Text);
|
2017-10-24 08:04:19 +13:00
|
|
|
|
}
|
2014-05-24 17:07:03 +12:00
|
|
|
|
|
|
|
|
|
// Calculate correct return value based on object comparison
|
|
|
|
|
if (OrderOfSort == SortOrder.Ascending)
|
|
|
|
|
{
|
|
|
|
|
// Ascending sort is selected, return normal result of compare operation
|
|
|
|
|
return compareResult;
|
|
|
|
|
}
|
|
|
|
|
else if (OrderOfSort == SortOrder.Descending)
|
|
|
|
|
{
|
|
|
|
|
// Descending sort is selected, return negative result of compare operation
|
2015-11-29 01:53:16 +13:00
|
|
|
|
return -compareResult;
|
2014-05-24 17:07:03 +12:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// Return '0' to indicate they are equal
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the number of the column to which to apply the sorting operation (Defaults to '0').
|
|
|
|
|
/// </summary>
|
|
|
|
|
public int SortColumn
|
|
|
|
|
{
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
ColumnToSort = value;
|
|
|
|
|
}
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return ColumnToSort;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the order of sorting to apply (for example, 'Ascending' or 'Descending').
|
|
|
|
|
/// </summary>
|
|
|
|
|
public SortOrder Order
|
|
|
|
|
{
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
OrderOfSort = value;
|
|
|
|
|
}
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return OrderOfSort;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|