2 * \file GuiHyperlink.cpp
3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
6 * \author Angus Leeming
9 * Full author contact details are available in file CREDITS.
14 #include "GuiHyperlink.h"
16 #include "qt_helpers.h"
17 #include "FuncRequest.h"
18 #include "insets/InsetCommand.h"
21 #include <QCloseEvent>
23 #include <QPushButton>
29 GuiHyperlink::GuiHyperlink(LyXView & lv)
30 : GuiCommand(lv, "href")
33 setViewTitle( _("Hyperlink"));
35 connect(okPB, SIGNAL(clicked()), this, SLOT(slotOK()));
36 connect(closePB, SIGNAL(clicked()), this, SLOT(slotClose()));
37 connect(urlED, SIGNAL(textChanged(const QString &)),
38 this, SLOT(changed_adaptor()));
39 connect(nameED, SIGNAL(textChanged(const QString &)),
40 this, SLOT(changed_adaptor()));
45 bc().setCancel(closePB);
46 bc().addReadOnly(urlED);
47 bc().addReadOnly(nameED);
51 void GuiHyperlink::changed_adaptor()
57 void GuiHyperlink::closeEvent(QCloseEvent * e)
64 void GuiHyperlink::updateContents()
66 urlED->setText(toqstr(params_["target"]));
67 nameED->setText(toqstr(params_["name"]));
68 bc().setValid(isValid());
72 void GuiHyperlink::applyView()
74 params_["target"] = qstring_to_ucs4(urlED->text());
75 params_["name"] = qstring_to_ucs4(nameED->text());
76 params_.setCmdName("href");
80 bool GuiHyperlink::isValid()
82 QString const u = urlED->text();
83 QString const n = nameED->text();
85 return !u.isEmpty() || !n.isEmpty();
89 Dialog * createGuiHyperlink(LyXView & lv) { return new GuiHyperlink(lv); }
92 } // namespace frontend
96 #include "GuiHyperlink_moc.cpp"