1 #include "kitemlistviewaccessible.h"
2 #include "kitemlistcontroller.h"
3 #include "kitemlistselectionmanager.h"
4 #include "private/kitemlistviewlayouter.h"
6 #include <QtGui/qtableview.h>
7 #include <QtGui/qaccessible2.h>
11 #ifndef QT_NO_ACCESSIBILITY
13 #ifndef QT_NO_ITEMVIEWS
15 KItemListView
*KItemListViewAccessible::view() const
17 return qobject_cast
<KItemListView
*>(object());
20 KItemListViewAccessible::KItemListViewAccessible(KItemListView
*view_
)
21 : QAccessibleObjectEx(view_
)
25 /*if (qobject_cast<const QTableView*>(view())) {
26 m_role = QAccessible::Table;
27 } else if (qobject_cast<const QTreeView*>(view())) {
28 m_role = QAccessible::Tree;
29 } else if (qobject_cast<const QListView*>(view())) {
30 m_role = QAccessible::List;
32 // is this our best guess?
33 m_role = QAccessible::Table;
37 KItemListViewAccessible::~KItemListViewAccessible()
41 void KItemListViewAccessible::modelReset()
44 QAccessibleTable2CellInterface
*KItemListViewAccessible::cell(int index
) const
47 return new KItemListAccessibleCell(view(), index
);
51 QAccessibleTable2CellInterface
*KItemListViewAccessible::cellAt(int row
, int column
) const
53 /*Q_ASSERT(role(0) != QAccessible::Tree);
54 QModelIndex index = view()->model()->index(row, column);
55 //Q_ASSERT(index.isValid());
56 if (!index.isValid()) {
57 qWarning() << "QAccessibleTable2::cellAt: invalid index: " << index << " for " << view();
67 QAccessibleInterface
*KItemListViewAccessible::caption() const
72 QString
KItemListViewAccessible::columnDescription(int) const
75 return QObject::tr("No Column Description");
78 int KItemListViewAccessible::columnCount() const
80 return view()->layouter()->columnCount();
83 int KItemListViewAccessible::rowCount() const
85 int itemCount
= view()->model()->count();
86 int rowCount
= itemCount
/ columnCount();
87 if (itemCount
% rowCount
)
92 int KItemListViewAccessible::selectedCellCount() const
94 return view()->controller()->selectionManager()->selectedItems().size();
97 int KItemListViewAccessible::selectedColumnCount() const
102 int KItemListViewAccessible::selectedRowCount() const
107 QString
KItemListViewAccessible::rowDescription(int) const
109 return "No Row Description";
112 QList
<QAccessibleTable2CellInterface
*> KItemListViewAccessible::selectedCells() const
114 QList
<QAccessibleTable2CellInterface
*> cells
;
115 Q_FOREACH (int index
, view()->controller()->selectionManager()->selectedItems()) {
116 cells
.append(cell(index
));
121 QList
<int> KItemListViewAccessible::selectedColumns() const
124 /*Q_FOREACH (const QModelIndex &index, view()->selectionModel()->selectedColumns()) {
125 columns.append(index.column());
130 QList
<int> KItemListViewAccessible::selectedRows() const
133 /*Q_FOREACH (const QModelIndex &index, view()->selectionModel()->selectedRows()) {
134 rows.append(index.row());
139 QAccessibleInterface
*KItemListViewAccessible::summary() const
144 bool KItemListViewAccessible::isColumnSelected(int) const
146 return false; //view()->selectionModel()->isColumnSelected(column, QModelIndex());
149 bool KItemListViewAccessible::isRowSelected(int) const
151 return false; //view()->selectionModel()->isRowSelected(row, QModelIndex());
154 bool KItemListViewAccessible::selectRow(int)
156 /*QModelIndex index = view()->model()->index(row, 0);
157 if (!index.isValid() || view()->selectionMode() & QAbstractItemView::NoSelection)
159 view()->selectionModel()->select(index, QItemSelectionModel::Select);*/
163 bool KItemListViewAccessible::selectColumn(int)
165 /*QModelIndex index = view()->model()->index(0, column);
166 if (!index.isValid() || view()->selectionMode() & QAbstractItemView::NoSelection)
168 view()->selectionModel()->select(index, QItemSelectionModel::Select);*/
172 bool KItemListViewAccessible::unselectRow(int)
174 /*QModelIndex index = view()->model()->index(row, 0);
175 if (!index.isValid() || view()->selectionMode() & QAbstractItemView::NoSelection)
177 view()->selectionModel()->select(index, QItemSelectionModel::Deselect);*/
181 bool KItemListViewAccessible::unselectColumn(int)
183 /*QModelIndex index = view()->model()->index(0, column);
184 if (!index.isValid() || view()->selectionMode() & QAbstractItemView::NoSelection)
186 view()->selectionModel()->select(index, QItemSelectionModel::Columns & QItemSelectionModel::Deselect);*/
190 QAccessible2::TableModelChange
KItemListViewAccessible::modelChange() const
192 QAccessible2::TableModelChange change
;
197 QAccessible::Role
KItemListViewAccessible::role(int child
) const
199 Q_ASSERT(child
>= 0);
201 return QAccessible::Cell
;
202 return QAccessible::Table
;
205 QAccessible::State
KItemListViewAccessible::state(int child
) const
207 Q_ASSERT(child
== 0);
208 return QAccessible::Normal
;
211 int KItemListViewAccessible::childAt(int x
, int y
) const
213 QPointF point
= QPointF(x
,y
);
214 return view()->itemAt(view()->mapFromScene(point
));
217 int KItemListViewAccessible::childCount() const
219 return rowCount() * columnCount();
222 int KItemListViewAccessible::indexOfChild(const QAccessibleInterface
*iface
) const
224 /*Q_ASSERT(iface->role(0) != QAccessible::TreeItem); // should be handled by tree class
225 if (iface->role(0) == QAccessible::Cell || iface->role(0) == QAccessible::ListItem) {
226 const QAccessibleTable2Cell* cell = static_cast<const QAccessibleTable2Cell*>(iface);
227 return logicalIndex(cell->m_index);
228 } else if (iface->role(0) == QAccessible::ColumnHeader){
229 const QAccessibleTable2HeaderCell* cell = static_cast<const QAccessibleTable2HeaderCell*>(iface);
230 return cell->index + (verticalHeader() ? 1 : 0) + 1;
231 } else if (iface->role(0) == QAccessible::RowHeader){
232 const QAccessibleTable2HeaderCell* cell = static_cast<const QAccessibleTable2HeaderCell*>(iface);
233 return (cell->index+1) * (view()->model()->rowCount()+1) + 1;
234 } else if (iface->role(0) == QAccessible::Pane) {
235 return 1; // corner button
237 qWarning() << "WARNING QAccessibleTable2::indexOfChild Fix my children..."
238 << iface->role(0) << iface->text(QAccessible::Name, 0);
240 // FIXME: we are in denial of our children. this should stop.
243 const KItemListAccessibleCell
*widget
= static_cast<const KItemListAccessibleCell
*>(iface
);
244 return widget
->getIndex();
247 QString
KItemListViewAccessible::text(Text t
, int child
) const
249 Q_ASSERT(child
== 0);
250 // FIXME: I don't think this is needed, but if at all it needs i18n
251 if (t
== QAccessible::Description
)
252 return QObject::tr("List of files present in the current directory");
253 return QObject::tr("File List");
256 QRect
KItemListViewAccessible::rect(int child
) const
259 if (!view()->isVisible())
261 // FIXME: map to global
262 return view()->rect().toRect();
265 int KItemListViewAccessible::navigate(RelationFlag relation
, int index
, QAccessibleInterface
**iface
) const
270 if (index == 1 && view()->parent()) {
271 *iface = QAccessible::queryAccessibleInterface(view()->parent());
277 case QAccessible::Child
: {
279 *iface
= cell(index
);
291 QAccessible::Relation
KItemListViewAccessible::relationTo(int, const QAccessibleInterface
*, int) const
293 return QAccessible::Unrelated
;
297 int KItemListViewAccessible::userActionCount(int) const
301 QString
KItemListViewAccessible::actionText(int, Text
, int) const
305 bool KItemListViewAccessible::doAction(int, int, const QVariantList
&)
313 KItemListAccessibleCell::KItemListAccessibleCell(KItemListView
*view_
, int index_
)
314 : /* QAccessibleSimpleEditableTextInterface(this), */ view(view_
)
317 Q_ASSERT(index_
> 0);
320 int KItemListAccessibleCell::columnExtent() const
325 int KItemListAccessibleCell::rowExtent() const
330 QList
<QAccessibleInterface
*> KItemListAccessibleCell::rowHeaderCells() const
332 QList
<QAccessibleInterface
*> headerCell
;
333 /*if (verticalHeader()) {
334 headerCell.append(new QAccessibleTable2HeaderCell(view, m_index.row(), Qt::Vertical));
339 QList
<QAccessibleInterface
*> KItemListAccessibleCell::columnHeaderCells() const
341 QList
<QAccessibleInterface
*> headerCell
;
342 /*if (horizontalHeader()) {
343 headerCell.append(new QAccessibleTable2HeaderCell(view, m_index.column(), Qt::Horizontal));
348 int KItemListAccessibleCell::columnIndex() const
350 return view
->layouter()->itemColumn(index
);
353 int KItemListAccessibleCell::rowIndex() const
355 /*if (role(0) == QAccessible::TreeItem) {
356 const QTreeView *treeView = qobject_cast<const QTreeView*>(view);
358 int row = treeView->d_func()->viewIndex(m_index);
361 return view
->layouter()->itemRow(index
);
365 bool KItemListAccessibleCell::isSelected() const
367 //return widget->isSelected();
372 void KItemListAccessibleCell::rowColumnExtents(int *row
, int *column
, int *rowExtents
, int *columnExtents
, bool *selected
) const
374 KItemListViewLayouter
* layouter
= view
->layouter();
375 *row
= layouter
->itemRow(index
);
376 *column
= layouter
->itemColumn(index
);
379 *selected
= isSelected();
382 QAccessibleTable2Interface
* KItemListAccessibleCell::table() const
384 return QAccessible::queryAccessibleInterface(view
)->table2Interface();
387 QAccessible::Role
KItemListAccessibleCell::role(int child
) const
389 Q_ASSERT(child
== 0);
390 return QAccessible::Cell
;
393 QAccessible::State
KItemListAccessibleCell::state(int child
) const
395 Q_ASSERT(child
== 0);
396 QAccessible::State st
= Normal
;
398 //QRect globalRect = view->rect();
399 //globalRect.translate(view->mapToGlobal(QPoint(0,0)));
400 //if (!globalRect.intersects(rect(0)))
403 // if (widget->isSelected())
405 if (view
->controller()->selectionManager()->currentItem() == index
)
408 //if (m_index.model()->data(m_index, Qt::CheckStateRole).toInt() == Qt::Checked)
410 //if (flags & Qt::ItemIsSelectable) {
413 if (view
->controller()->selectionBehavior() == KItemListController::MultiSelection
)
414 st
|= MultiSelectable
;
416 //if (view->selectionMode() == QAbstractItemView::ExtendedSelection)
417 //st |= ExtSelectable;
419 //if (m_role == QAccessible::TreeItem) {
420 // const QTreeView *treeView = qobject_cast<const QTreeView*>(view);
421 // if (treeView->isExpanded(m_index))
429 bool KItemListAccessibleCell::isExpandable() const
431 return false; //view->model()->hasChildren(m_index);
435 QRect
KItemListAccessibleCell::rect(int child
) const
437 // Q_ASSERT(child == 0);
443 //r = view->visualRect(m_index);
446 // r.translate(view->viewport()->mapTo(view, QPoint(0,0)));
447 // r.translate(view->mapToGlobal(QPoint(0, 0)));
448 //return widget->textRect().toRect();
451 QString
KItemListAccessibleCell::text(QAccessible::Text t
, int child
) const
453 //Q_ASSERT(child == 0)
455 QHash
<QByteArray
, QVariant
> data
= view
->model()->data(index
);
457 case QAccessible::Value
:
458 case QAccessible::Name
:
459 return data
["text"].toString();
460 case QAccessible::Description
:
461 return data
["text"].toString() + " : " + data
["group"].toString();
468 void KItemListAccessibleCell::setText(QAccessible::Text
/*t*/, int child
, const QString
&text
)
470 Q_ASSERT(child
== 0);
471 // FIXME - is this even allowed on the KItemListWidget?
474 bool KItemListAccessibleCell::isValid() const
477 kDebug() << "Interface is not valid";
483 int KItemListAccessibleCell::navigate(RelationFlag relation
, int index
, QAccessibleInterface
**iface
) const
485 if (relation
== Ancestor
&& index
== 1) {
486 //if (m_role == QAccessible::TreeItem) {
487 // *iface = new QAccessibleTree(view);
489 *iface
= new KItemListViewAccessible(view
);
504 QAccessibleInterface
*parent
= queryAccessibleInterface(view
);
505 int ret
= parent
->navigate(QAccessible::Child
, index
, iface
);
512 // From table1 implementation:
517 // // This is in the "not so nice" category. In order to find out which item
518 // // is geometrically around, we have to set the current index, navigate
519 // // and restore the index as well as the old selection
520 // view()->setUpdatesEnabled(false);
521 // const QModelIndex oldIdx = view()->currentIndex();
522 // QList<QModelIndex> kids = children();
523 // const QModelIndex currentIndex = index ? kids.at(index - 1) : QModelIndex(row);
524 // const QItemSelection oldSelection = view()->selectionModel()->selection();
525 // view()->setCurrentIndex(currentIndex);
526 // const QModelIndex idx = view()->moveCursor(toCursorAction(relation), Qt::NoModifier);
527 // view()->setCurrentIndex(oldIdx);
528 // view()->selectionModel()->select(oldSelection, QItemSelectionModel::ClearAndSelect);
529 // view()->setUpdatesEnabled(true);
530 // if (!idx.isValid())
533 // if (idx.parent() != row.parent() || idx.row() != row.row())
534 // *iface = cell(idx);
535 // return index ? kids.indexOf(idx) + 1 : 0; }
543 QAccessible::Relation
KItemListAccessibleCell::relationTo(int child
, const QAccessibleInterface
*, int otherChild
) const
545 Q_ASSERT(child
== 0);
546 Q_ASSERT(otherChild
== 0);
547 /* we only check for parent-child relationships in trees
548 if (m_role == QAccessible::TreeItem && other->role(0) == QAccessible::TreeItem) {
549 QModelIndex otherIndex = static_cast<const QAccessibleTable2Cell*>(other)->m_index;
550 // is the other our parent?
551 if (otherIndex.parent() == m_index)
552 return QAccessible::Ancestor;
553 // are we the other's child?
554 if (m_index.parent() == otherIndex)
555 return QAccessible::Child;
557 return QAccessible::Unrelated
;
561 int KItemListAccessibleCell::userActionCount(int) const
566 QString
KItemListAccessibleCell::actionText(int, Text
, int) const
571 bool KItemListAccessibleCell::doAction(int, int, const QVariantList
&)
578 KItemListContainerAccessible::KItemListContainerAccessible(KItemListContainer
*container
)
579 : QAccessibleWidgetEx(container
)
582 KItemListContainerAccessible::~KItemListContainerAccessible ()
585 int KItemListContainerAccessible::childCount () const
590 int KItemListContainerAccessible::indexOfChild ( const QAccessibleInterface
* child
) const
592 if(child
== QAccessible::queryAccessibleInterface(container()->controller()->view()))
597 int KItemListContainerAccessible::navigate ( QAccessible::RelationFlag relation
, int index
, QAccessibleInterface
** target
) const
599 if (relation
== QAccessible::Child
) {
600 *target
= new KItemListViewAccessible(container()->controller()->view());
603 return QAccessibleWidgetEx::navigate(relation
, index
, target
);
606 #endif // QT_NO_ITEMVIEWS
608 #endif // QT_NO_ACCESSIBILITY