* Licence details can be found in the file COPYING.
*
* \author Angus Leeming
- * \author Jürgen Spitzmüller
+ * \author Jürgen Spitzmüller
*
* Full author contact details are available in file CREDITS.
*/
#include <config.h>
#include "GuiSendto.h"
+#include "qt_helpers.h"
#include "Buffer.h"
+#include "BufferParams.h"
#include "Converter.h"
#include "Format.h"
#include "FuncRequest.h"
-#include "LyXRC.h"
-#include "qt_helpers.h"
#include "support/filetools.h"
-#include "support/lstrings.h"
+#include "support/gettext.h"
+#include "support/qstring_helpers.h"
+
+#include <algorithm>
+#include <QLineEdit>
#include <QListWidget>
#include <QPushButton>
GuiSendTo::GuiSendTo(GuiView & lv)
- : GuiDialog(lv, "sendto", qt_("Send Document to Command"))
+ : GuiDialog(lv, "sendto", qt_("Export or Send Document")), format_(0)
{
setupUi(this);
this, SLOT(slotFormatSelected(QListWidgetItem *)));
connect(formatLW, SIGNAL(itemClicked(QListWidgetItem *)),
this, SLOT(changed_adaptor()));
- connect(commandCO, SIGNAL(textChanged(QString)),
+ connect(formatLW, SIGNAL(itemSelectionChanged()),
+ this, SLOT(changed_adaptor()));
+ connect(commandCO, SIGNAL(editTextChanged(QString)),
this, SLOT(changed_adaptor()));
bc().setPolicy(ButtonPolicy::OkApplyCancelPolicy);
void GuiSendTo::updateContents()
{
- all_formats_ = allFormats();
-
- // Check whether the current contents of the browser will be
- // changed by loading the contents of formats
- vector<string> keys;
- keys.resize(all_formats_.size());
-
- 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)
- *result = (*it)->prettyname();
-
- // Reload the browser
+ FormatList const & all_formats =
+ buffer().params().exportableFormats(false);
+ // Save the current selection if any
+ Format const * current_format = nullptr;
+ int const line = formatLW->currentRow();
+ if (line >= 0 && static_cast<unsigned int>(line) < all_formats.size()
+ && formatLW->selectedItems().size() > 0)
+ current_format = all_formats[line];
+ // Reset the list widget
formatLW->clear();
-
- for (vector<string>::const_iterator it = keys.begin();
- it != keys.end(); ++it) {
- formatLW->addItem(toqstr(*it));
+ for (Format const * f : all_formats) {
+ formatLW->addItem(toqstr(translateIfPossible(f->prettyname())));
+ // Restore the selection
+ if (current_format && f->prettyname() == current_format->prettyname())
+ formatLW->setCurrentRow(formatLW->count() - 1);
}
-
- commandCO->addItem(toqstr(command_));
}
void GuiSendTo::applyView()
{
int const line = formatLW->currentRow();
+ QString const command = commandCO->currentText().trimmed();
- if (line < 0 || line > int(formatLW->count()))
+ if (commandCO->findText(command) == -1)
+ commandCO->insertItem(0, command);
+
+ if (line < 0 || line > formatLW->count())
return;
- format_ = all_formats_[line];
- command_ = trim(fromqstr(commandCO->currentText()));
+ FormatList const & all_formats =
+ buffer().params().exportableFormats(false);
+ format_ = all_formats[line];
+ command_ = command;
}
if (line < 0 || line > int(formatLW->count()))
return false;
- return formatLW->count() != 0 &&
- !commandCO->currentText().isEmpty();
+ return (formatLW->selectedItems().size() > 0
+ && formatLW->count() != 0);
}
bool GuiSendTo::initialiseParams(string const &)
{
format_ = 0;
- command_ = lyxrc.custom_export_command;
+ paramsToDialog(format_, command_);
return true;
}
-void GuiSendTo::dispatchParams()
+void GuiSendTo::paramsToDialog(Format const * /*format*/, QString const & command)
{
- if (command_.empty() || !format_ || format_->name().empty())
- return;
+ if (!command.isEmpty())
+ commandCO->addItem(command);
- string const data = format_->name() + " " + command_;
- dispatch(FuncRequest(getLfun(), data));
+ bc().setValid(isValid());
}
-// FIXME: Move to Converters?
-vector<Format const *> GuiSendTo::allFormats() const
+
+void GuiSendTo::dispatchParams()
{
- // 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));
- }
- }
+ if (!format_ || format_->name().empty())
+ return;
- // Remove repeated formats.
- sort(to.begin(), to.end());
- to.erase(unique(to.begin(), to.end()), to.end());
+ string data = format_->name();
+ if (!command_.isEmpty())
+ data += " " + fromqstr(command_);
- return to;
-}
+ FuncCode const lfun = command_.isEmpty() ?
+ LFUN_BUFFER_EXPORT : getLfun();
+ dispatch(FuncRequest(lfun, data));
+}
Dialog * createGuiSendTo(GuiView & lv) { return new GuiSendTo(lv); }
} // namespace frontend
} // namespace lyx
-#include "GuiSendto_moc.cpp"
+#include "moc_GuiSendto.cpp"