Line data Source code
1 : /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 : /* vim: set ts=2 et sw=2 tw=80: */
3 : /* This Source Code Form is subject to the terms of the Mozilla Public
4 : * License, v. 2.0. If a copy of the MPL was not distributed with this file,
5 : * You can obtain one at http://mozilla.org/MPL/2.0/. */
6 :
7 : #ifndef TABLE_ACCESSIBLE_H
8 : #define TABLE_ACCESSIBLE_H
9 :
10 : #include "nsString.h"
11 : #include "nsTArray.h"
12 :
13 : namespace mozilla {
14 : namespace a11y {
15 :
16 : class Accessible;
17 :
18 : /**
19 : * Accessible table interface.
20 : */
21 0 : class TableAccessible
22 : {
23 : public:
24 :
25 : /**
26 : * Return the caption accessible if any for this table.
27 : */
28 0 : virtual Accessible* Caption() const { return nullptr; }
29 :
30 : /**
31 : * Get the summary for this table.
32 : */
33 0 : virtual void Summary(nsString& aSummary) { aSummary.Truncate(); }
34 :
35 : /**
36 : * Return the number of columns in the table.
37 : */
38 0 : virtual uint32_t ColCount() { return 0; }
39 :
40 : /**
41 : * Return the number of rows in the table.
42 : */
43 0 : virtual uint32_t RowCount() { return 0; }
44 :
45 : /**
46 : * Return the accessible for the cell at the given row and column indices.
47 : */
48 0 : virtual Accessible* CellAt(uint32_t aRowIdx, uint32_t aColIdx) { return nullptr; }
49 :
50 : /**
51 : * Return the index of the cell at the given row and column.
52 : */
53 0 : virtual int32_t CellIndexAt(uint32_t aRowIdx, uint32_t aColIdx)
54 0 : { return ColCount() * aRowIdx + aColIdx; }
55 :
56 : /**
57 : * Return the column index of the cell with the given index.
58 : */
59 0 : virtual int32_t ColIndexAt(uint32_t aCellIdx)
60 0 : { return aCellIdx % ColCount(); }
61 :
62 : /**
63 : * Return the row index of the cell with the given index.
64 : */
65 0 : virtual int32_t RowIndexAt(uint32_t aCellIdx)
66 0 : { return aCellIdx / ColCount(); }
67 :
68 : /**
69 : * Get the row and column indices for the cell at the given index.
70 : */
71 0 : virtual void RowAndColIndicesAt(uint32_t aCellIdx, int32_t* aRowIdx,
72 : int32_t* aColIdx)
73 : {
74 0 : uint32_t colCount = ColCount();
75 0 : *aRowIdx = aCellIdx / colCount;
76 0 : *aColIdx = aCellIdx % colCount;
77 0 : }
78 :
79 : /**
80 : * Return the number of columns occupied by the cell at the given row and
81 : * column indices.
82 : */
83 0 : virtual uint32_t ColExtentAt(uint32_t aRowIdx, uint32_t aColIdx) { return 1; }
84 :
85 : /**
86 : * Return the number of rows occupied by the cell at the given row and column
87 : * indices.
88 : */
89 0 : virtual uint32_t RowExtentAt(uint32_t aRowIdx, uint32_t aColIdx) { return 1; }
90 :
91 : /**
92 : * Get the description of the given column.
93 : */
94 0 : virtual void ColDescription(uint32_t aColIdx, nsString& aDescription)
95 0 : { aDescription.Truncate(); }
96 :
97 : /**
98 : * Get the description for the given row.
99 : */
100 0 : virtual void RowDescription(uint32_t aRowIdx, nsString& aDescription)
101 0 : { aDescription.Truncate(); }
102 :
103 : /**
104 : * Return true if the given column is selected.
105 : */
106 0 : virtual bool IsColSelected(uint32_t aColIdx) { return false; }
107 :
108 : /**
109 : * Return true if the given row is selected.
110 : */
111 0 : virtual bool IsRowSelected(uint32_t aRowIdx) { return false; }
112 :
113 : /**
114 : * Return true if the given cell is selected.
115 : */
116 0 : virtual bool IsCellSelected(uint32_t aRowIdx, uint32_t aColIdx) { return false; }
117 :
118 : /**
119 : * Return the number of selected cells.
120 : */
121 0 : virtual uint32_t SelectedCellCount() { return 0; }
122 :
123 : /**
124 : * Return the number of selected columns.
125 : */
126 0 : virtual uint32_t SelectedColCount() { return 0; }
127 :
128 : /**
129 : * Return the number of selected rows.
130 : */
131 0 : virtual uint32_t SelectedRowCount() { return 0; }
132 :
133 : /**
134 : * Get the set of selected cells.
135 : */
136 : virtual void SelectedCells(nsTArray<Accessible*>* aCells) = 0;
137 :
138 : /**
139 : * Get the set of selected cell indices.
140 : */
141 : virtual void SelectedCellIndices(nsTArray<uint32_t>* aCells) = 0;
142 :
143 : /**
144 : * Get the set of selected column indices.
145 : */
146 : virtual void SelectedColIndices(nsTArray<uint32_t>* aCols) = 0;
147 :
148 : /**
149 : * Get the set of selected row indices.
150 : */
151 : virtual void SelectedRowIndices(nsTArray<uint32_t>* aRows) = 0;
152 :
153 : /**
154 : * Select the given column unselecting any other selected columns.
155 : */
156 0 : virtual void SelectCol(uint32_t aColIdx) {}
157 :
158 : /**
159 : * Select the given row unselecting all other previously selected rows.
160 : */
161 0 : virtual void SelectRow(uint32_t aRowIdx) {}
162 :
163 : /**
164 : * Unselect the given column leaving other selected columns selected.
165 : */
166 0 : virtual void UnselectCol(uint32_t aColIdx) {}
167 :
168 : /**
169 : * Unselect the given row leaving other selected rows selected.
170 : */
171 0 : virtual void UnselectRow(uint32_t aRowIdx) {}
172 :
173 : /**
174 : * Return true if the table is probably for layout.
175 : */
176 0 : virtual bool IsProbablyLayoutTable() { return false; }
177 :
178 : /**
179 : * Convert the table to an Accessible*.
180 : */
181 : virtual Accessible* AsAccessible() = 0;
182 : };
183 :
184 : } // namespace a11y
185 : } // namespace mozilla
186 :
187 : #endif
|