void radio_group::add(checkbox& uiobj) { uiobj.radio(true); uiobj.check(false); uiobj.react(false); element_tag el; el.uiobj = &uiobj; el.eh_checked = uiobj.events().click.connect_unignorable([this](const arg_click& arg) { for (auto & i : ui_container_) i.uiobj->check(arg.window_handle == i.uiobj->handle()); }, true); el.eh_destroy = uiobj.events().destroy.connect_unignorable([this](const arg_destroy& arg) { for (auto i = ui_container_.begin(); i != ui_container_.end(); ++i) { if (arg.window_handle == i->uiobj->handle()) { ui_container_.erase(i); return; } } }); ui_container_.push_back(el); }
void register_event_handlers() { lst_songs.events().dbl_click([&](const nana::arg_mouse & e) { static match_dialog dialog{}; auto selected = lst_songs.selected(); if (selected.size() > 0) { auto item = lst_songs.at(0).at(selected.front().item); const auto & info = item.value<map_info_ptr>(); dialog.src_file(info->full_path()); dialog.show_dialog(fm); info->matched = matcher::has_matched(info->full_path()); item.resolve_from(info); } }); auto filter = bind(&impl::filter_maps, this); chk_matched.events().click(filter); txt_search.events().key_press([this](const arg_keyboard & arg){ if (arg.key == '\r') filter_maps(); }); btn_search.events().click(filter); }