Dock the Embedding dialog (code copied from the ViewSource dialog and I do not really know what I am doing)

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@20156 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Bo Peng 2007-09-08 20:04:28 +00:00
parent 7510c9f39d
commit b0d904a2cc
3 changed files with 38 additions and 49 deletions

View File

@ -136,7 +136,8 @@ Dialog * Dialogs::build(string const & name)
} else if (name == "document") { } else if (name == "document") {
dialog = new GuiDocumentDialog(lyxview_); dialog = new GuiDocumentDialog(lyxview_);
} else if (name == "embedding") { } else if (name == "embedding") {
dialog = new GuiEmbeddedFilesDialog(lyxview_); dialog = new DockView<ControlEmbeddedFiles, GuiEmbeddedFilesDialog>(
guiview, name, Qt::RightDockWidgetArea);
} else if (name == "errorlist") { } else if (name == "errorlist") {
dialog = new GuiErrorListDialog(lyxview_); dialog = new GuiErrorListDialog(lyxview_);
} else if (name == "ert") { } else if (name == "ert") {

View File

@ -21,48 +21,36 @@ namespace lyx {
namespace frontend { namespace frontend {
GuiEmbeddedFilesDialog::GuiEmbeddedFilesDialog(LyXView & lv) GuiEmbeddedFilesDialog::GuiEmbeddedFilesDialog(ControlEmbeddedFiles & controller)
: GuiDialog(lv, "embedding") : controller_(controller)
{ {
setupUi(this); setupUi(this);
setController(new ControlEmbeddedFiles(*this)); setWindowTitle(qt_("Embedded Files"));
setViewTitle(_("Embedded Files"));
//setView(new DockView<GuiEmbeddedFiles, GuiEmbeddedFilesDialog>(
// *dialog, qef, &gui_view, _("Embedded Files"), Qt::RightDockWidgetArea));
bc().setPolicy(ButtonPolicy::OkCancelPolicy);
updateView(); updateView();
} }
ControlEmbeddedFiles & GuiEmbeddedFilesDialog::controller() const
{
return static_cast<ControlEmbeddedFiles &>(Dialog::controller());
}
void GuiEmbeddedFilesDialog::on_filesLW_itemChanged(QListWidgetItem* item) void GuiEmbeddedFilesDialog::on_filesLW_itemChanged(QListWidgetItem* item)
{ {
EmbeddedFiles & files = controller().embeddedFiles(); EmbeddedFiles & files = controller_.embeddedFiles();
if (item->checkState() == Qt::Checked) { if (item->checkState() == Qt::Checked) {
if (files[filesLW->row(item)].embedded()) if (files[filesLW->row(item)].embedded())
return; return;
controller().setEmbed(files[filesLW->row(item)], true); controller_.setEmbed(files[filesLW->row(item)], true);
controller().dispatchMessage("Embed file " + fromqstr(item->text())); controller_.dispatchMessage("Embed file " + fromqstr(item->text()));
} else { } else {
if (!files[filesLW->row(item)].embedded()) if (!files[filesLW->row(item)].embedded())
return; return;
controller().setEmbed(files[filesLW->row(item)], false); controller_.setEmbed(files[filesLW->row(item)], false);
controller().dispatchMessage("Stop embedding file " + fromqstr(item->text())); controller_.dispatchMessage("Stop embedding file " + fromqstr(item->text()));
} }
} }
void GuiEmbeddedFilesDialog::on_filesLW_itemSelectionChanged() void GuiEmbeddedFilesDialog::on_filesLW_itemSelectionChanged()
{ {
EmbeddedFiles & files = controller().embeddedFiles(); EmbeddedFiles & files = controller_.embeddedFiles();
QList<QListWidgetItem *> selection = filesLW->selectedItems(); QList<QListWidgetItem *> selection = filesLW->selectedItems();
@ -95,14 +83,14 @@ void GuiEmbeddedFilesDialog::on_filesLW_itemSelectionChanged()
void GuiEmbeddedFilesDialog::on_filesLW_itemClicked(QListWidgetItem* item) void GuiEmbeddedFilesDialog::on_filesLW_itemClicked(QListWidgetItem* item)
{ {
EmbeddedFiles & files = controller().embeddedFiles(); EmbeddedFiles & files = controller_.embeddedFiles();
int idx = filesLW->row(item); int idx = filesLW->row(item);
fullpathLE->setText(toqstr(files[idx].absFilename())); fullpathLE->setText(toqstr(files[idx].absFilename()));
if (files[idx].refCount() > 1) { if (files[idx].refCount() > 1) {
// if multiple insets are referred, click again will move // if multiple insets are referred, click again will move
// to another inset // to another inset
int k = item->data(Qt::UserRole).toInt(); int k = item->data(Qt::UserRole).toInt();
controller().goTo(files[idx], k); controller_.goTo(files[idx], k);
k = (k + 1) % files[idx].refCount(); k = (k + 1) % files[idx].refCount();
item->setData(Qt::UserRole, k); item->setData(Qt::UserRole, k);
// update label // update label
@ -111,14 +99,14 @@ void GuiEmbeddedFilesDialog::on_filesLW_itemClicked(QListWidgetItem* item)
+ convert<string>(files[idx].refCount()) + ")"; + convert<string>(files[idx].refCount()) + ")";
item->setText(toqstr(label)); item->setText(toqstr(label));
} else } else
controller().goTo(files[idx], 0); controller_.goTo(files[idx], 0);
} }
void GuiEmbeddedFilesDialog::on_filesLW_itemDoubleClicked(QListWidgetItem* item) void GuiEmbeddedFilesDialog::on_filesLW_itemDoubleClicked(QListWidgetItem* item)
{ {
EmbeddedFiles & files = controller().embeddedFiles(); EmbeddedFiles & files = controller_.embeddedFiles();
controller().view(files[filesLW->row(item)]); controller_.view(files[filesLW->row(item)]);
} }
@ -126,7 +114,7 @@ void GuiEmbeddedFilesDialog::updateView()
{ {
filesLW->clear(); filesLW->clear();
// //
EmbeddedFiles const & files = controller().embeddedFiles(); EmbeddedFiles const & files = controller_.embeddedFiles();
EmbeddedFiles::EmbeddedFileList::const_iterator it = files.begin(); EmbeddedFiles::EmbeddedFileList::const_iterator it = files.begin();
EmbeddedFiles::EmbeddedFileList::const_iterator it_end = files.end(); EmbeddedFiles::EmbeddedFileList::const_iterator it_end = files.end();
for (; it != it_end; ++it) { for (; it != it_end; ++it) {
@ -151,62 +139,62 @@ void GuiEmbeddedFilesDialog::updateView()
void GuiEmbeddedFilesDialog::on_selectPB_clicked() void GuiEmbeddedFilesDialog::on_selectPB_clicked()
{ {
EmbeddedFiles & files = controller().embeddedFiles(); EmbeddedFiles & files = controller_.embeddedFiles();
QList<QListWidgetItem *> selection = filesLW->selectedItems(); QList<QListWidgetItem *> selection = filesLW->selectedItems();
for (QList<QListWidgetItem*>::iterator it = selection.begin(); for (QList<QListWidgetItem*>::iterator it = selection.begin();
it != selection.end(); ++it) { it != selection.end(); ++it) {
(*it)->setCheckState(Qt::Checked); (*it)->setCheckState(Qt::Checked);
controller().setEmbed(files[filesLW->row(*it)], true); controller_.setEmbed(files[filesLW->row(*it)], true);
} }
controller().dispatchMessage("Embedding files"); controller_.dispatchMessage("Embedding files");
} }
void GuiEmbeddedFilesDialog::on_unselectPB_clicked() void GuiEmbeddedFilesDialog::on_unselectPB_clicked()
{ {
EmbeddedFiles & files = controller().embeddedFiles(); EmbeddedFiles & files = controller_.embeddedFiles();
QList<QListWidgetItem *> selection = filesLW->selectedItems(); QList<QListWidgetItem *> selection = filesLW->selectedItems();
for (QList<QListWidgetItem*>::iterator it = selection.begin(); for (QList<QListWidgetItem*>::iterator it = selection.begin();
it != selection.end(); ++it) { it != selection.end(); ++it) {
(*it)->setCheckState(Qt::Checked); (*it)->setCheckState(Qt::Checked);
controller().setEmbed(files[filesLW->row(*it)], false); controller_.setEmbed(files[filesLW->row(*it)], false);
} }
controller().dispatchMessage("Stop embedding files"); controller_.dispatchMessage("Stop embedding files");
} }
void GuiEmbeddedFilesDialog::on_addPB_clicked() void GuiEmbeddedFilesDialog::on_addPB_clicked()
{ {
docstring const file = controller().browseFile(); docstring const file = controller_.browseFile();
if (!file.empty()) { if (!file.empty()) {
EmbeddedFiles & files = controller().embeddedFiles(); EmbeddedFiles & files = controller_.embeddedFiles();
files.registerFile(to_utf8(file), true); files.registerFile(to_utf8(file), true);
} }
controller().dispatchMessage("Add an embedded file"); controller_.dispatchMessage("Add an embedded file");
} }
void GuiEmbeddedFilesDialog::on_extractPB_clicked() void GuiEmbeddedFilesDialog::on_extractPB_clicked()
{ {
EmbeddedFiles const & files = controller().embeddedFiles(); EmbeddedFiles const & files = controller_.embeddedFiles();
QList<QListWidgetItem *> selection = filesLW->selectedItems(); QList<QListWidgetItem *> selection = filesLW->selectedItems();
for (QList<QListWidgetItem*>::iterator it = selection.begin(); for (QList<QListWidgetItem*>::iterator it = selection.begin();
it != selection.end(); ++it) it != selection.end(); ++it)
controller().extract(files[filesLW->row(*it)]); controller_.extract(files[filesLW->row(*it)]);
// FIXME: collect extraction status and display a dialog // FIXME: collect extraction status and display a dialog
controller().dispatchMessage("Extract embedded files"); controller_.dispatchMessage("Extract embedded files");
} }
void GuiEmbeddedFilesDialog::on_updatePB_clicked() void GuiEmbeddedFilesDialog::on_updatePB_clicked()
{ {
EmbeddedFiles const & files = controller().embeddedFiles(); EmbeddedFiles const & files = controller_.embeddedFiles();
QList<QListWidgetItem *> selection = filesLW->selectedItems(); QList<QListWidgetItem *> selection = filesLW->selectedItems();
for (QList<QListWidgetItem*>::iterator it = selection.begin(); for (QList<QListWidgetItem*>::iterator it = selection.begin();
it != selection.end(); ++it) it != selection.end(); ++it)
controller().update(files[filesLW->row(*it)]); controller_.update(files[filesLW->row(*it)]);
// FIXME: collect update status and display a dialog // FIXME: collect update status and display a dialog
controller().dispatchMessage("Update embedded files from external file"); controller_.dispatchMessage("Update embedded files from external file");
} }
@ -214,12 +202,12 @@ void GuiEmbeddedFilesDialog::on_updatePB_clicked()
void GuiEmbeddedFilesDialog::on_enableCB_toggled(bool enable) void GuiEmbeddedFilesDialog::on_enableCB_toggled(bool enable)
{ {
// //
controller().embeddedFiles().enable(enable); controller_.embeddedFiles().enable(enable);
// immediately post the change to buffer (and bufferView) // immediately post the change to buffer (and bufferView)
if (enable) if (enable)
controller().dispatchMessage("Enable file embedding"); controller_.dispatchMessage("Enable file embedding");
else else
controller().dispatchMessage("Disable file embedding"); controller_.dispatchMessage("Disable file embedding");
} }

View File

@ -20,12 +20,12 @@
namespace lyx { namespace lyx {
namespace frontend { namespace frontend {
class GuiEmbeddedFilesDialog : public GuiDialog, public Ui::GuiEmbeddedFilesUi class GuiEmbeddedFilesDialog : public QWidget, public Ui::GuiEmbeddedFilesUi
{ {
Q_OBJECT Q_OBJECT
public: public:
GuiEmbeddedFilesDialog(LyXView & lv); GuiEmbeddedFilesDialog(ControlEmbeddedFiles &);
public Q_SLOTS: public Q_SLOTS:
/// ///
@ -45,7 +45,7 @@ public Q_SLOTS:
void on_updatePB_clicked(); void on_updatePB_clicked();
private: private:
ControlEmbeddedFiles & controller() const; ControlEmbeddedFiles & controller_;
void set_embedding_status(bool embed); void set_embedding_status(bool embed);
}; };