2016-05-04 10:07:13 +00:00
|
|
|
#if defined(Hiro_ListView)
|
|
|
|
|
|
|
|
mListView::mListView() {
|
2018-06-04 02:44:57 +00:00
|
|
|
mTableView::onActivate([&] {
|
|
|
|
doActivate();
|
|
|
|
});
|
|
|
|
mTableView::onChange([&] {
|
|
|
|
doChange();
|
|
|
|
});
|
2016-05-04 10:07:13 +00:00
|
|
|
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<ListViewItem> {
|
|
|
|
auto batched = mTableView::batched();
|
|
|
|
vector<ListViewItem> result;
|
|
|
|
for(auto item : batched) result.append(ListViewItem{item});
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2018-06-04 02:44:57 +00:00
|
|
|
auto mListView::doActivate() const -> void {
|
|
|
|
if(state.onActivate) state.onActivate();
|
|
|
|
}
|
|
|
|
|
|
|
|
auto mListView::doChange() const -> void {
|
|
|
|
if(state.onChange) state.onChange();
|
|
|
|
}
|
|
|
|
|
2016-05-04 10:07:13 +00:00
|
|
|
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<ListViewItem> {
|
|
|
|
auto items = mTableView::items();
|
|
|
|
vector<ListViewItem> result;
|
|
|
|
for(auto item : items) result.append(ListViewItem{item});
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2018-06-04 02:44:57 +00:00
|
|
|
auto mListView::onActivate(const function<void ()>& callback) -> type& {
|
|
|
|
state.onActivate = callback;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
auto mListView::onChange(const function<void ()>& callback) -> type& {
|
|
|
|
state.onChange = callback;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2016-05-04 10:07:13 +00:00
|
|
|
auto mListView::onToggle(const function<void (ListViewItem)>& 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
|