3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
6 * \author Angus Leeming
7 * \author Jürgen Spitzmüller
9 * Full author contact details are available in file CREDITS.
14 #include "GuiSendto.h"
15 #include "qt_helpers.h"
18 #include "BufferParams.h"
19 #include "Converter.h"
21 #include "FuncRequest.h"
23 #include "support/filetools.h"
24 #include "support/gettext.h"
25 #include "support/qstring_helpers.h"
30 #include <QListWidget>
31 #include <QPushButton>
34 using namespace lyx::support;
40 GuiSendTo::GuiSendTo(GuiView & lv)
41 : GuiDialog(lv, "sendto", qt_("Export or Send Document")), format_(0)
45 connect(buttonBox, SIGNAL(clicked(QAbstractButton *)),
46 this, SLOT(slotButtonBox(QAbstractButton *)));
48 connect(formatLW, SIGNAL(itemClicked(QListWidgetItem *)),
49 this, SLOT(slotFormatHighlighted(QListWidgetItem *)));
50 connect(formatLW, SIGNAL(itemActivated(QListWidgetItem *)),
51 this, SLOT(slotFormatSelected(QListWidgetItem *)));
52 connect(formatLW, SIGNAL(itemClicked(QListWidgetItem *)),
53 this, SLOT(changed_adaptor()));
54 connect(formatLW, SIGNAL(itemSelectionChanged()),
55 this, SLOT(changed_adaptor()));
56 connect(commandCO, SIGNAL(editTextChanged(QString)),
57 this, SLOT(changed_adaptor()));
59 bc().setPolicy(ButtonPolicy::OkApplyCancelPolicy);
60 bc().setOK(buttonBox->button(QDialogButtonBox::Ok));
61 bc().setApply(buttonBox->button(QDialogButtonBox::Apply));
62 bc().setCancel(buttonBox->button(QDialogButtonBox::Cancel));
66 void GuiSendTo::changed_adaptor()
72 void GuiSendTo::updateContents()
74 FormatList const & all_formats =
75 buffer().params().exportableFormats(false);
76 // Save the current selection if any
77 Format const * current_format = nullptr;
78 int const line = formatLW->currentRow();
79 if (line >= 0 && static_cast<unsigned int>(line) < all_formats.size()
80 && formatLW->selectedItems().size() > 0)
81 current_format = all_formats[line];
82 // Reset the list widget
84 for (Format const * f : all_formats) {
85 formatLW->addItem(toqstr(translateIfPossible(f->prettyname())));
86 // Restore the selection
87 if (current_format && f->prettyname() == current_format->prettyname())
88 formatLW->setCurrentRow(formatLW->count() - 1);
93 void GuiSendTo::applyView()
95 int const line = formatLW->currentRow();
96 QString const command = commandCO->currentText().trimmed();
98 if (commandCO->findText(command) == -1)
99 commandCO->insertItem(0, command);
101 if (line < 0 || line > formatLW->count())
104 FormatList const & all_formats =
105 buffer().params().exportableFormats(false);
106 format_ = all_formats[line];
111 bool GuiSendTo::isValid()
113 int const line = formatLW->currentRow();
115 if (line < 0 || (line > int(formatLW->count())))
118 return (formatLW->selectedItems().size() > 0
119 && formatLW->count() != 0);
123 bool GuiSendTo::initialiseParams(string const &)
126 paramsToDialog(format_, command_);
131 void GuiSendTo::paramsToDialog(Format const * /*format*/, QString const & command)
133 if (!command.isEmpty())
134 commandCO->addItem(command);
136 bc().setValid(isValid());
140 void GuiSendTo::dispatchParams()
142 if (!format_ || format_->name().empty())
145 string sdata = format_->name();
146 if (!command_.isEmpty())
147 sdata += " " + fromqstr(command_);
149 FuncCode const lfun = command_.isEmpty() ?
150 LFUN_BUFFER_EXPORT : getLfun();
152 dispatch(FuncRequest(lfun, sdata));
155 Dialog * createGuiSendTo(GuiView & lv) { return new GuiSendTo(lv); }
158 } // namespace frontend
161 #include "moc_GuiSendto.cpp"