#if defined(Hiro_ListView) mListView::mListView() { mTableView::onActivate([&] { doActivate(); }); mTableView::onChange([&] { doChange(); }); mTableView::onToggle([&](TableViewCell cell) { if(auto item = cell->parentTableViewItem()) { if(auto shared = item->instance.acquire()) { doToggle(ListViewItem{shared}); } } }); append(TableViewHeader().setVisible(false).append(TableViewColumn().setExpandable())); } auto mListView::batched() const -> vector { auto batched = mTableView::batched(); vector result; for(auto item : batched) result.append(ListViewItem{item}); return result; } auto mListView::doActivate() const -> void { if(state.onActivate) state.onActivate(); } auto mListView::doChange() const -> void { if(state.onChange) state.onChange(); } auto mListView::doToggle(ListViewItem item) const -> void { if(state.onToggle) state.onToggle(item); } auto mListView::item(uint position) const -> ListViewItem { return ListViewItem{mTableView::item(position)}; } auto mListView::items() const -> vector { auto items = mTableView::items(); vector result; for(auto item : items) result.append(ListViewItem{item}); return result; } auto mListView::onActivate(const function& callback) -> type& { state.onActivate = callback; return *this; } auto mListView::onChange(const function& callback) -> type& { state.onChange = callback; return *this; } auto mListView::onToggle(const function& callback) -> type& { state.onToggle = callback; return *this; } auto mListView::reset() -> type& { mTableView::reset(); append(TableViewHeader().setVisible(false).append(TableViewColumn().setExpandable())); return *this; } auto mListView::selected() const -> ListViewItem { return ListViewItem{mTableView::selected()}; } #endif