* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
+ * \author Angus Leeming
* \author Jürgen Spitzmüller
*
* Full author contact details are available in file CREDITS.
#include <config.h>
#include "GuiSendto.h"
-#include "Qt2BC.h"
#include "qt_helpers.h"
+#include "Buffer.h"
+#include "Converter.h"
#include "Format.h"
+#include "FuncRequest.h"
+#include "LyXRC.h"
-#include "controllers/ControlSendto.h"
+#include "support/qstring_helpers.h"
+#include "support/filetools.h"
#include <QListWidget>
#include <QPushButton>
-#include <QCloseEvent>
-
-using std::vector;
-using std::string;
+using namespace std;
+using namespace lyx::support;
namespace lyx {
namespace frontend {
-/////////////////////////////////////////////////////////////////////
-//
-// GuiSendtoDialog
-//
-/////////////////////////////////////////////////////////////////////
-GuiSendtoDialog::GuiSendtoDialog(GuiSendto * form)
- : form_(form)
+GuiSendTo::GuiSendTo(GuiView & lv)
+ : GuiDialog(lv, "sendto", qt_("Send Document to Command"))
{
setupUi(this);
- connect(okPB, SIGNAL(clicked()),
- form, SLOT(slotOK()));
- connect(applyPB, SIGNAL(clicked()),
- form, SLOT(slotApply()));
- connect(closePB, SIGNAL(clicked()),
- form, SLOT(slotClose()));
-
- connect( formatLW, SIGNAL( itemClicked(QListWidgetItem *) ),
- this, SLOT( slotFormatHighlighted(QListWidgetItem *) ) );
- connect( formatLW, SIGNAL( itemActivated(QListWidgetItem *) ),
- this, SLOT( slotFormatSelected(QListWidgetItem *) ) );
- connect( formatLW, SIGNAL( itemClicked(QListWidgetItem *) ),
- this, SLOT( changed_adaptor() ) );
- connect( commandCO, SIGNAL( textChanged(const QString&) ),
- this, SLOT( changed_adaptor() ) );
-}
-
-
-void GuiSendtoDialog::changed_adaptor()
-{
- form_->changed();
-}
-
-
-void GuiSendtoDialog::closeEvent(QCloseEvent * e)
-{
- form_->slotWMHide();
- e->accept();
-}
-
-
-/////////////////////////////////////////////////////////////////////
-//
-// GuiSendto
-//
-/////////////////////////////////////////////////////////////////////
-
-typedef QController<ControlSendto, GuiView<GuiSendtoDialog> > SendtoBase;
-
-
-GuiSendto::GuiSendto(Dialog & parent)
- : SendtoBase(parent, _("Send Document to Command"))
-{
+ connect(okPB, SIGNAL(clicked()), this, SLOT(slotOK()));
+ connect(applyPB, SIGNAL(clicked()), this, SLOT(slotApply()));
+ connect(closePB, SIGNAL(clicked()), this, SLOT(slotClose()));
+
+ connect(formatLW, SIGNAL(itemClicked(QListWidgetItem *)),
+ this, SLOT(slotFormatHighlighted(QListWidgetItem *)));
+ connect(formatLW, SIGNAL(itemActivated(QListWidgetItem *)),
+ this, SLOT(slotFormatSelected(QListWidgetItem *)));
+ connect(formatLW, SIGNAL(itemClicked(QListWidgetItem *)),
+ this, SLOT(changed_adaptor()));
+ connect(commandCO, SIGNAL(textChanged(QString)),
+ this, SLOT(changed_adaptor()));
+
+ bc().setPolicy(ButtonPolicy::OkApplyCancelPolicy);
+ bc().setOK(okPB);
+ bc().setApply(applyPB);
+ bc().setCancel(closePB);
}
-void GuiSendto::build_dialog()
+void GuiSendTo::changed_adaptor()
{
- dialog_.reset(new GuiSendtoDialog(this));
-
- // Manage the ok, apply, restore and cancel/close buttons
- bcview().setOK(dialog_->okPB);
- bcview().setApply(dialog_->applyPB);
- bcview().setCancel(dialog_->closePB);
+ changed();
}
-void GuiSendto::update_contents()
+void GuiSendTo::updateContents()
{
- all_formats_ = controller().allFormats();
+ all_formats_ = allFormats();
// Check whether the current contents of the browser will be
// changed by loading the contents of formats
vector<string>::iterator result = keys.begin();
vector<Format const *>::const_iterator it = all_formats_.begin();
vector<Format const *>::const_iterator end = all_formats_.end();
- for (; it != end; ++it, ++result) {
+ for (; it != end; ++it, ++result)
*result = (*it)->prettyname();
- }
// Reload the browser
- dialog_->formatLW->clear();
+ formatLW->clear();
for (vector<string>::const_iterator it = keys.begin();
- it < keys.end(); ++it) {
- dialog_->formatLW->addItem(toqstr(*it));
+ it != keys.end(); ++it) {
+ formatLW->addItem(qt_(*it));
}
- dialog_->commandCO->addItem(toqstr(controller().getCommand()));
+ commandCO->addItem(command_);
}
-void GuiSendto::apply()
+void GuiSendTo::applyView()
{
- int const line(dialog_->formatLW->currentRow());
+ int const line = formatLW->currentRow();
- if (line < 0 || line > int(dialog_->formatLW->count()))
+ if (line < 0 || line > formatLW->count())
return;
- string const cmd(fromqstr(dialog_->commandCO->currentText()));
-
- controller().setFormat(all_formats_[line]);
- controller().setCommand(cmd);
+ format_ = all_formats_[line];
+ command_ = commandCO->currentText().trimmed();
}
-bool GuiSendto::isValid()
+bool GuiSendTo::isValid()
{
- int const line(dialog_->formatLW->currentRow());
+ int const line = formatLW->currentRow();
- if (line < 0 || line > int(dialog_->formatLW->count()))
+ if (line < 0 || line > int(formatLW->count()))
return false;
- else return dialog_->formatLW->count() != 0 &&
- !dialog_->commandCO->currentText().isEmpty();
+ return formatLW->count() != 0 &&
+ !commandCO->currentText().isEmpty();
}
+
+bool GuiSendTo::initialiseParams(string const &)
+{
+ format_ = 0;
+ command_ = toqstr(lyxrc.custom_export_command);
+ return true;
+}
+
+
+void GuiSendTo::dispatchParams()
+{
+ if (command_.isEmpty() || !format_ || format_->name().empty())
+ return;
+
+ string const data = format_->name() + " " + fromqstr(command_);
+ dispatch(FuncRequest(getLfun(), data));
+}
+
+// FIXME: Move to Converters?
+vector<Format const *> GuiSendTo::allFormats() const
+{
+ // What formats can we output natively?
+ vector<string> exports;
+ exports.push_back("lyx");
+ exports.push_back("text");
+
+ if (buffer().isLatex()) {
+ exports.push_back("latex");
+ exports.push_back("pdflatex");
+ }
+ else if (buffer().isDocBook())
+ exports.push_back("docbook");
+ else if (buffer().isLiterate())
+ exports.push_back("literate");
+
+ // Loop over these native formats and ascertain what formats we
+ // can convert to
+ vector<Format const *> to;
+
+ vector<string>::const_iterator ex_it = exports.begin();
+ vector<string>::const_iterator ex_end = exports.end();
+ for (; ex_it != ex_end; ++ex_it) {
+ // Start off with the native export format.
+ // "formats" is LyX's list of recognised formats
+ to.push_back(formats.getFormat(*ex_it));
+
+ Formats::const_iterator fo_it = formats.begin();
+ Formats::const_iterator fo_end = formats.end();
+ for (; fo_it != fo_end; ++fo_it) {
+ // we need to hide the default graphic export formats
+ // from the external menu, because we need them only
+ // for the internal lyx-view and external latex run
+ string const name = fo_it->name();
+ if (name != "eps" && name != "xpm" && name != "png" &&
+ theConverters().isReachable(*ex_it, name))
+ to.push_back(&(*fo_it));
+ }
+ }
+
+ // Remove repeated formats.
+ sort(to.begin(), to.end());
+ to.erase(unique(to.begin(), to.end()), to.end());
+
+ return to;
+}
+
+
+Dialog * createGuiSendTo(GuiView & lv) { return new GuiSendTo(lv); }
+
+
} // namespace frontend
} // namespace lyx