BC_MenuItem *menu_item;
BC_SubMenu *submenu;
add_item(info = new AssetPopupInfo(mwindow, this));
- add_item(format = new AWindowListFormat(mwindow));
+ add_item(format = new AWindowListFormat(mwindow, gui));
add_item(new AssetPopupSort(mwindow, this));
add_item(index = new AssetPopupBuildIndex(mwindow, this));
add_item(view = new AssetPopupView(mwindow, this));
int AssetPopupInfo::handle_event()
{
- if(mwindow->session->drag_assets->total)
- {
+ int cur_x, cur_y;
+ popup->gui->get_abs_cursor_xy(cur_x, cur_y, 0);
+
+ if( mwindow->session->drag_assets->total ) {
mwindow->awindow->asset_edit->edit_asset(
- mwindow->session->drag_assets->values[0]);
+ mwindow->session->drag_assets->values[0], cur_x, cur_y);
}
else
- if(mwindow->session->drag_clips->total)
- {
+ if( mwindow->session->drag_clips->total ) {
popup->gui->awindow->clip_edit->edit_clip(
- mwindow->session->drag_clips->values[0]);
+ mwindow->session->drag_clips->values[0], cur_x, cur_y);
}
return 1;
}
VWindow *vwindow = mwindow->get_viewer(1, DEFAULT_VWINDOW);
vwindow->gui->lock_window("AssetPopupView::handle_event");
- if(mwindow->session->drag_assets->total)
+ if( mwindow->session->drag_assets->total )
vwindow->change_source(
mwindow->session->drag_assets->values[0]);
else
- if(mwindow->session->drag_clips->total)
+ if( mwindow->session->drag_clips->total )
vwindow->change_source(
mwindow->session->drag_clips->values[0]);
// TODO: create new vwindow or change current vwindow
vwindow->gui->lock_window("AssetPopupView::handle_event");
- if(mwindow->session->drag_assets->total)
+ if( mwindow->session->drag_assets->total )
vwindow->change_source(
mwindow->session->drag_assets->values[0]);
else
- if(mwindow->session->drag_clips->total)
+ if( mwindow->session->drag_clips->total )
vwindow->change_source(
mwindow->session->drag_clips->values[0]);
void AssetListMenu::create_objects()
{
- add_item(format = new AWindowListFormat(mwindow));
- add_item(new AWindowListSort(mwindow));
- add_item(new AssetListCopy(mwindow));
- add_item(new AssetListPaste(mwindow));
+ add_item(format = new AWindowListFormat(mwindow, gui));
+ add_item(new AWindowListSort(mwindow, gui));
+ add_item(new AssetListCopy(mwindow, gui));
+ add_item(new AssetListPaste(mwindow, gui));
update_titles();
}
format->update();
}
-AssetListCopy::AssetListCopy(MWindow *mwindow)
+AssetListCopy::AssetListCopy(MWindow *mwindow, AWindowGUI *gui)
: BC_MenuItem(_("Copy file list"))
{
this->mwindow = mwindow;
+ this->gui = gui;
copy_dialog = 0;
}
AssetListCopy::~AssetListCopy()
cp += sprintf(cp, "%s\n", path);
}
*cp = 0;
+ int cur_x, cur_y;
+ gui->get_abs_cursor_xy(cur_x, cur_y, 0);
gui->unlock_window();
if( n ) {
if( !copy_dialog )
copy_dialog = new AssetCopyDialog(this);
- copy_dialog->start(text);
+ copy_dialog->start(text, cur_x, cur_y);
}
else {
eprintf(_("Nothing selected"));
copy_window = 0;
}
-void AssetCopyDialog::start(char *text)
+void AssetCopyDialog::start(char *text, int x, int y)
{
close_window();
this->text = text;
+ this->x = x; this->y = y;
BC_DialogThread::start();
}
BC_Window* AssetCopyDialog::new_gui()
{
BC_DisplayInfo display_info;
- int x = display_info.get_abs_cursor_x();
- int y = display_info.get_abs_cursor_y();
- copy_window = new AssetCopyWindow(this, x, y);
+ copy_window = new AssetCopyWindow(this);
copy_window->create_objects();
return copy_window;
}
}
-AssetCopyWindow::AssetCopyWindow(AssetCopyDialog *copy_dialog, int x, int y)
- : BC_Window(_(PROGRAM_NAME ": Copy File List"), x, y, 500, 200, 500, 200, 0, 0, 1)
+AssetCopyWindow::AssetCopyWindow(AssetCopyDialog *copy_dialog)
+ : BC_Window(_(PROGRAM_NAME ": Copy File List"),
+ copy_dialog->x - 500/2, copy_dialog->y - 200/2,
+ 500, 200, 500, 200, 0, 0, 1)
{
this->copy_dialog = copy_dialog;
}
}
-AssetListPaste::AssetListPaste(MWindow *mwindow)
+AssetListPaste::AssetListPaste(MWindow *mwindow, AWindowGUI *gui)
: BC_MenuItem(_("Paste file list"))
{
this->mwindow = mwindow;
+ this->gui = gui;
paste_dialog = 0;
}
AssetListPaste::~AssetListPaste()
{
if( !paste_dialog )
paste_dialog = new AssetPasteDialog(this);
- paste_dialog->start();
+ else
+ paste_dialog->close_window();
+ int cur_x, cur_y;
+ gui->get_abs_cursor_xy(cur_x, cur_y, 0);
+ paste_dialog->start(cur_x, cur_y);
return 1;
}
BC_Window* AssetPasteDialog::new_gui()
{
- BC_DisplayInfo display_info;
- int x = display_info.get_abs_cursor_x();
- int y = display_info.get_abs_cursor_y();
-
- paste_window = new AssetPasteWindow(this, x, y);
+ paste_window = new AssetPasteWindow(this);
paste_window->create_objects();
return paste_window;
}
paste_window = 0;
}
+void AssetPasteDialog::start(int x, int y)
+{
+ this->x = x; this->y = y;
+ BC_DialogThread::start();
+}
-AssetPasteWindow::AssetPasteWindow(AssetPasteDialog *paste_dialog, int x, int y)
- : BC_Window(_(PROGRAM_NAME ": Paste File List"), x, y, 500, 200, 500, 200, 0, 0, 1)
+AssetPasteWindow::AssetPasteWindow(AssetPasteDialog *paste_dialog)
+ : BC_Window(_(PROGRAM_NAME ": Paste File List"),
+ paste_dialog->x - 500/2, paste_dialog->y - 200/2,
+ 500, 200, 500, 200, 0, 0, 1)
{
this->paste_dialog = paste_dialog;
}