]> git.lyx.org Git - lyx.git/blobdiff - src/frontends/qt4/GuiEmbeddedFiles.cpp
Embedding: mark buffer dirty after changing embedding status
[lyx.git] / src / frontends / qt4 / GuiEmbeddedFiles.cpp
index 9f48afc489e0a82610cd0cd185dbed6fc481d0b9..fc8c112d3eaf27ad083095a46069ab3e11dfdc17 100644 (file)
 
 #include "GuiEmbeddedFiles.h"
 #include "debug.h"
-#include "support/convert.h"
 
-using std::string;
 
 namespace lyx {
-
 namespace frontend {
 
-
-GuiEmbeddedFilesDialog::GuiEmbeddedFilesDialog(LyXView & lv)
-       : GuiDialog(lv, "embedding")
+GuiEmbeddedFilesDialog::GuiEmbeddedFilesDialog
+               (ControlEmbeddedFiles & controller)
+       : controller_(controller)
 {
        setupUi(this);
-       setController(new ControlEmbeddedFiles(*this));
-       setViewTitle(_("Embedded Files"));
-
-       //setView(new DockView<GuiEmbeddedFiles, GuiEmbeddedFilesDialog>(
-       //              *dialog, qef, &gui_view, _("Embedded Files"), Qt::RightDockWidgetArea));
-       
-       bc().setPolicy(ButtonPolicy::OkCancelPolicy);
-
+       setWindowTitle("LyX: " + qt_("Embedded Files"));
        updateView();
 }
 
 
-ControlEmbeddedFiles & GuiEmbeddedFilesDialog::controller() const
-{
-       return static_cast<ControlEmbeddedFiles &>(Dialog::controller());
-}
-
-
 void GuiEmbeddedFilesDialog::on_filesLW_itemChanged(QListWidgetItem* item)
 {
-       EmbeddedFiles & files = controller().embeddedFiles();
+       EmbeddedFiles & files = controller_.embeddedFiles();
        if (item->checkState() == Qt::Checked) {
                if (files[filesLW->row(item)].embedded())
                        return;
-               controller().setEmbed(files[filesLW->row(item)], true);
-               controller().dispatchMessage("Embed file " + fromqstr(item->text()));
+               // this should not be needed after EmbeddedFiles are updated correctly.
+               files.update();
+               controller_.setEmbed(files[filesLW->row(item)], true, files.enabled());
        } else {
                if (!files[filesLW->row(item)].embedded())
                        return;
-               controller().setEmbed(files[filesLW->row(item)], false);
-               controller().dispatchMessage("Stop embedding file " + fromqstr(item->text()));
+               // this should not be needed after EmbeddedFiles are updated correctly.
+               files.update();
+               controller_.setEmbed(files[filesLW->row(item)], false, files.enabled());
        }
 }
 
 
 void GuiEmbeddedFilesDialog::on_filesLW_itemSelectionChanged()
 {
-       EmbeddedFiles & files = controller().embeddedFiles();
-
        QList<QListWidgetItem *> selection = filesLW->selectedItems();
 
        if (selection.empty()) {
@@ -95,45 +79,43 @@ void GuiEmbeddedFilesDialog::on_filesLW_itemSelectionChanged()
 
 void GuiEmbeddedFilesDialog::on_filesLW_itemClicked(QListWidgetItem* item)
 {
-       EmbeddedFiles & files = controller().embeddedFiles();
+       EmbeddedFiles & files = controller_.embeddedFiles();
        int idx = filesLW->row(item);
        fullpathLE->setText(toqstr(files[idx].absFilename()));
        if (files[idx].refCount() > 1) {
                // if multiple insets are referred, click again will move
                // to another inset
                int k = item->data(Qt::UserRole).toInt();
-               controller().goTo(files[idx], k);
+               controller_.goTo(files[idx], k);
                k = (k + 1) % files[idx].refCount();
                item->setData(Qt::UserRole, k);
                // update label
-               string label = files[idx].inzipName() + " ("
-                       + convert<string>(k + 1)  + "/"
-                       + convert<string>(files[idx].refCount()) + ")";
-               item->setText(toqstr(label));
+               QString label = toqstr(files[idx].inzipName())
+                       + QString(" (%1/%2)").arg(k + 1).arg(files[idx].refCount());
+               item->setText(label);
        } else
-               controller().goTo(files[idx], 0);
+               controller_.goTo(files[idx], 0);
 }
 
 
 void GuiEmbeddedFilesDialog::on_filesLW_itemDoubleClicked(QListWidgetItem* item)
 {
-       EmbeddedFiles & files = controller().embeddedFiles();
-       controller().view(files[filesLW->row(item)]);
+       EmbeddedFiles & files = controller_.embeddedFiles();
+       controller_.view(files[filesLW->row(item)]);
 }
 
 
 void GuiEmbeddedFilesDialog::updateView()
 {
        filesLW->clear();
-       //
-       EmbeddedFiles const & files = controller().embeddedFiles();
+       EmbeddedFiles const & files = controller_.embeddedFiles();
        EmbeddedFiles::EmbeddedFileList::const_iterator it = files.begin();
        EmbeddedFiles::EmbeddedFileList::const_iterator it_end = files.end();
        for (; it != it_end; ++it) {
-               string label = it->inzipName();
+               QString label = toqstr(it->inzipName());
                if (it->refCount() > 1)
-                       label += " (1/" + convert<string>(it->refCount()) + ")";
-               QListWidgetItem * item = new QListWidgetItem(toqstr(label));
+                       label += " (1/" + QString::number(it->refCount()) + ")";
+               QListWidgetItem * item = new QListWidgetItem(label);
                Qt::ItemFlags flag = Qt::ItemIsUserCheckable | Qt::ItemIsSelectable;
                if (it->valid())
                        flag |= Qt::ItemIsEnabled;
@@ -151,62 +133,66 @@ void GuiEmbeddedFilesDialog::updateView()
 
 void GuiEmbeddedFilesDialog::on_selectPB_clicked()
 {
-       EmbeddedFiles & files = controller().embeddedFiles();
+       EmbeddedFiles & files = controller_.embeddedFiles();
+       // this should not be needed after EmbeddedFiles are updated correctly.
+       files.update();
        QList<QListWidgetItem *> selection = filesLW->selectedItems();
        for (QList<QListWidgetItem*>::iterator it = selection.begin(); 
                it != selection.end(); ++it) {
                (*it)->setCheckState(Qt::Checked);
-               controller().setEmbed(files[filesLW->row(*it)], true);
+               controller_.setEmbed(files[filesLW->row(*it)], true, files.enabled());
        }
-       controller().dispatchMessage("Embedding files");
+       controller_.dispatchMessage("Embedding files");
 }
 
 
 void GuiEmbeddedFilesDialog::on_unselectPB_clicked()
 {
-       EmbeddedFiles & files = controller().embeddedFiles();
+       EmbeddedFiles & files = controller_.embeddedFiles();
+       // this should not be needed after EmbeddedFiles are updated correctly.
+       files.update();
        QList<QListWidgetItem *> selection = filesLW->selectedItems();
        for (QList<QListWidgetItem*>::iterator it = selection.begin(); 
                it != selection.end(); ++it) {
                (*it)->setCheckState(Qt::Checked);
-               controller().setEmbed(files[filesLW->row(*it)], false);
+               controller_.setEmbed(files[filesLW->row(*it)], false, files.enabled());
        }
-       controller().dispatchMessage("Stop embedding files");
+       controller_.dispatchMessage("Stop embedding files");
 }
 
 
 void GuiEmbeddedFilesDialog::on_addPB_clicked()
 {
-       docstring const file = controller().browseFile();
+       docstring const file = controller_.browseFile();
        if (!file.empty()) {
-               EmbeddedFiles & files = controller().embeddedFiles();
+               EmbeddedFiles & files = controller_.embeddedFiles();
                files.registerFile(to_utf8(file), true);
        }
-       controller().dispatchMessage("Add an embedded file");
+       controller_.dispatchMessage("Add an embedded file");
 }
 
 
 void GuiEmbeddedFilesDialog::on_extractPB_clicked()
 {
-       EmbeddedFiles const & files = controller().embeddedFiles();
+       EmbeddedFiles const & files = controller_.embeddedFiles();
        QList<QListWidgetItem *> selection = filesLW->selectedItems();
        for (QList<QListWidgetItem*>::iterator it = selection.begin(); 
                it != selection.end(); ++it)
-               controller().extract(files[filesLW->row(*it)]);
+               controller_.extract(files[filesLW->row(*it)]);
        // FIXME: collect extraction status and display a dialog
-       controller().dispatchMessage("Extract embedded files");
+       controller_.dispatchMessage("Extract embedded files");
 }
 
 
 void GuiEmbeddedFilesDialog::on_updatePB_clicked()
 {
-       EmbeddedFiles const & files = controller().embeddedFiles();
+       EmbeddedFiles const & files = controller_.embeddedFiles();
        QList<QListWidgetItem *> selection = filesLW->selectedItems();
        for (QList<QListWidgetItem*>::iterator it = selection.begin(); 
                it != selection.end(); ++it)
-               controller().update(files[filesLW->row(*it)]);
+               controller_.update(files[filesLW->row(*it)]);
        // 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 +200,12 @@ void GuiEmbeddedFilesDialog::on_updatePB_clicked()
 void GuiEmbeddedFilesDialog::on_enableCB_toggled(bool enable)
 {
        //
-       controller().embeddedFiles().enable(enable);
+       controller_.embeddedFiles().enable(enable);
        // immediately post the change to buffer (and bufferView)
        if (enable)
-               controller().dispatchMessage("Enable file embedding");
+               controller_.dispatchMessage("Enable file embedding");
        else
-               controller().dispatchMessage("Disable file embedding");
+               controller_.dispatchMessage("Disable file embedding");
 }