-int EditPopupFindAsset::handle_event()
-{
- Edit *edit = popup->edit;
- if( edit ) {
- Indexable *idxbl = (Indexable *)edit->asset;
- if( !idxbl ) idxbl = (Indexable *)edit->nested_edl;
- if( idxbl ) {
- AWindowGUI *agui = mwindow->awindow->gui;
- agui->lock_window("EditPopupFindAsset::handle_event");
- AssetPicon *picon = 0;
- for( int i=0, n=agui->assets.size(); i<n; ++i ) {
- AssetPicon *ap = (AssetPicon *)agui->assets[i];
- int found = ap->indexable && ( idxbl == ap->indexable ||
- !strcmp(idxbl->path, ap->indexable->path) );
- if( found && !picon ) picon = ap;
- ap->set_selected(found);
- }
- if( picon ) {
- int selected_folder = picon->indexable->folder_no;
- mwindow->edl->session->awindow_folder = selected_folder;
- for( int i=0,n=agui->folders.size(); i<n; ++i ) {
- AssetPicon *folder_item = (AssetPicon *)agui->folders[i];
- int selected = folder_item->foldernum == selected_folder ? 1 : 0;
- folder_item->set_selected(selected);
- }
- }
- agui->unlock_window();
- agui->async_update_assets();
- }
- }
- return 1;
-}
-
-
-EditPopupTitle::EditPopupTitle(MWindow *mwindow, EditPopup *popup)
- : BC_MenuItem(_("User title..."))
-{
- this->mwindow = mwindow;
- this->popup = popup;
- dialog_thread = new EditTitleDialogThread(this);
-}
-
-EditPopupTitle::~EditPopupTitle()
-{
- delete dialog_thread;
-}
-
-int EditPopupTitle::handle_event()
-{
- if( popup->edit ) {
- dialog_thread->close_window();
- int wx = mwindow->gui->get_abs_cursor_x(0) - 400 / 2;
- int wy = mwindow->gui->get_abs_cursor_y(0) - 500 / 2;
- dialog_thread->start(wx, wy);
- }
- return 1;
-}
-
-void EditTitleDialogThread::start(int wx, int wy)
-{
- this->wx = wx; this->wy = wy;
- BC_DialogThread::start();
-}
-
-EditTitleDialogThread::EditTitleDialogThread(EditPopupTitle *edit_title)
-{
- this->edit_title = edit_title;
- window = 0;
-}
-EditTitleDialogThread::~EditTitleDialogThread()
-{
- close_window();
-}
-
-BC_Window* EditTitleDialogThread::new_gui()
-{
- MWindow *mwindow = edit_title->mwindow;
- EditPopup *popup = edit_title->popup;
- window = new EditPopupTitleWindow(mwindow, popup, wx, wy);
- window->create_objects();
- return window;
-}
-
-void EditTitleDialogThread::handle_close_event(int result)
-{
- window = 0;
-}
-
-void EditTitleDialogThread::handle_done_event(int result)
-{
- if( result ) return;
- MWindow *mwindow = edit_title->mwindow;
- EditPopup *popup = edit_title->popup;
- strcpy(popup->edit->user_title, window->title_text->get_text());
- mwindow->gui->lock_window("EditTitleDialogThread::handle_done_event");
- mwindow->gui->draw_canvas(1, 0);
- mwindow->gui->flash_canvas(1);
- mwindow->gui->unlock_window();
-}
-
-EditPopupTitleWindow::EditPopupTitleWindow(MWindow *mwindow,
- EditPopup *popup, int wx, int wy)
- : BC_Window(_(PROGRAM_NAME ": Set edit title"), wx, wy,
- 300, 130, 300, 130, 0, 0, 1)
-{
- this->mwindow = mwindow;
- this->popup = popup;
- strcpy(new_text, !popup->edit ? "" : popup->edit->user_title);
-}
-
-EditPopupTitleWindow::~EditPopupTitleWindow()
-{
-}
-
-void EditPopupTitleWindow::create_objects()
-{
- lock_window("EditPopupTitleWindow::create_objects");
- int x = 10, y = 10;
- add_subwindow(new BC_Title(x, y, _("User title:")));
- title_text = new EditPopupTitleText(this, mwindow, x+15, y+20, new_text);
- add_subwindow(title_text);
- add_tool(new BC_OKButton(this));
- add_tool(new BC_CancelButton(this));
-
-
- show_window();
- flush();
- unlock_window();
-}
-
-
-EditPopupTitleText::EditPopupTitleText(EditPopupTitleWindow *window,
- MWindow *mwindow, int x, int y, const char *text)
- : BC_TextBox(x, y, 250, 1, text)
-{
- this->window = window;
- this->mwindow = mwindow;
-}
-
-EditPopupTitleText::~EditPopupTitleText()
-{
-}
-
-int EditPopupTitleText::handle_event()
-{
- if( get_keypress() == RETURN )
- window->set_done(0);
- return 1;
-}
-
-
-EditPopupShow::EditPopupShow(MWindow *mwindow, EditPopup *popup)
- : BC_MenuItem(_("Show edit"))
-{
- this->mwindow = mwindow;
- this->popup = popup;
- dialog_thread = new EditShowDialogThread(this);
-}
-
-EditPopupShow::~EditPopupShow()
-{
- delete dialog_thread;
-}
-
-int EditPopupShow::handle_event()