aboutsummaryrefslogtreecommitdiff
path: root/RhSolutions.ExcelExtensions/Column.cs
blob: 53a1f3db8873314e4cc5cd305471bf40e767fa53 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
using System.Collections;

namespace RhSolutions.ExcelExtensions;

public sealed class Column : Table, IEnumerable<TableCell>
{
    public string Header
    {
        get => Range.Cells[1, 1].Value.ToString();
    }
    public int Index
    {
        get => Range.Column - ParentTable.Range.Column;
    }
    public int Length
    {
        get => Range.Rows.Count;
    }

    public Column(Range range, Table table) : base(range, table)
    {
        Range = range;
        ParentTable = table;
    }

    public TableCell this[int index]
    {
        get => new(Range.Cells[index + 1, 1], ParentTable);
    }

    public IEnumerator<TableCell> GetEnumerator()
    {
        return new ColumnEnumerator(Range, ParentTable);
    }

    IEnumerator IEnumerable.GetEnumerator() => GetEnumerator();


    public Column AddLeft()
    {
        Range.EntireColumn
            .Insert(XlInsertShiftDirection.xlShiftToRight,
                XlInsertFormatOrigin.xlFormatFromRightOrBelow);

        return ParentTable.Columns[this.Index - 1];
    }
}