Newer
Older
ClosedXML / ClosedXML / Excel / AutoFilters / XLFilteredColumn.cs
@Amir Amir on 9 Sep 2016 2 KB Project hierarchy cleanup
using System;
using System.Linq;

namespace ClosedXML.Excel
{
    internal class XLFilteredColumn : IXLFilteredColumn
    {
        private readonly XLAutoFilter _autoFilter;
        private readonly Int32 _column;

        public XLFilteredColumn(XLAutoFilter autoFilter, Int32 column)
        {
            _autoFilter = autoFilter;
            _column = column;
        }

        #region IXLFilteredColumn Members

        public IXLFilteredColumn AddFilter<T>(T value) where T: IComparable<T>
        {
            Func<Object, Boolean> condition;
            Boolean isText;
            if (typeof(T) == typeof(String))
            {
                condition = v => v.ToString().Equals(value.ToString(), StringComparison.InvariantCultureIgnoreCase);
                isText = true;
            }
            else
            {
                condition = v => v.CastTo<T>().CompareTo(value) == 0;
                isText = false;
            }

            _autoFilter.Filters[_column].Add(new XLFilter
                                                 {
                                                     Value = value,
                                                     Condition = condition,
                                                     Operator = XLFilterOperator.Equal,
                                                     Connector = XLConnector.Or
                                                 });

            using (var rows = _autoFilter.Range.Rows(2, _autoFilter.Range.RowCount()))
            {
                foreach (IXLRangeRow row in rows)
                {
                    if ((isText && condition(row.Cell(_column).GetString())) || (
                                                                                    !isText &&
                                                                                    row.Cell(_column).DataType ==
                                                                                    XLCellValues.Number &&
                                                                                    condition(
                                                                                        row.Cell(_column).GetValue<T>()))
                        )
                        row.WorksheetRow().Unhide().Dispose();
                }
            }
            return this;
        }

        #endregion
    }
}