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"
22 #include <QPushButton>
28 GuiHyperlink::GuiHyperlink(GuiView & lv)
29 : GuiDialog(lv, "href", qt_("Hyperlink")),
30 params_(insetCode("href"))
34 connect(okPB, SIGNAL(clicked()), this, SLOT(slotOK()));
35 connect(closePB, SIGNAL(clicked()), this, SLOT(slotClose()));
36 connect(targetED, SIGNAL(textChanged(const QString &)),
37 this, SLOT(changed_adaptor()));
38 connect(nameED, SIGNAL(textChanged(const QString &)),
39 this, SLOT(changed_adaptor()));
40 connect(webRB, SIGNAL(clicked()),
41 this, SLOT(changed_adaptor()));
42 connect(emailRB, SIGNAL(clicked()),
43 this, SLOT(changed_adaptor()));
44 connect(fileRB, SIGNAL(clicked()),
45 this, SLOT(changed_adaptor()));
47 setFocusProxy(targetED);
49 bc().setPolicy(ButtonPolicy::OkCancelReadOnlyPolicy);
52 bc().setCancel(closePB);
53 bc().addReadOnly(targetED);
54 bc().addReadOnly(nameED);
55 bc().addReadOnly(webRB);
56 bc().addReadOnly(emailRB);
57 bc().addReadOnly(fileRB);
61 void GuiHyperlink::changed_adaptor()
67 void GuiHyperlink::paramsToDialog(InsetCommandParams const & /*icp*/)
69 targetED->setText(toqstr(params_["target"]));
70 nameED->setText(toqstr(params_["name"]));
71 if (params_["type"] == "")
72 webRB->setChecked(true);
73 else if (params_["type"] == "mailto:")
74 emailRB->setChecked(true);
75 else if (params_["type"] == "file:")
76 fileRB->setChecked(true);
77 bc().setValid(isValid());
81 void GuiHyperlink::applyView()
83 params_["target"] = qstring_to_ucs4(targetED->text());
84 params_["name"] = qstring_to_ucs4(nameED->text());
85 if (webRB->isChecked())
86 params_["type"] = qstring_to_ucs4("");
87 else if (emailRB->isChecked())
88 params_["type"] = qstring_to_ucs4("mailto:");
89 else if (fileRB->isChecked())
90 params_["type"] = qstring_to_ucs4("file:");
91 params_.setCmdName("href");
95 bool GuiHyperlink::isValid()
97 return !targetED->text().isEmpty() || !nameED->text().isEmpty();
101 bool GuiHyperlink::initialiseParams(std::string const & data)
103 // The name passed with LFUN_INSET_APPLY is also the name
104 // used to identify the mailer.
105 InsetCommand::string2params("href", data, params_);
106 paramsToDialog(params_);
111 void GuiHyperlink::dispatchParams()
113 std::string const lfun = InsetCommand::params2string("href", params_);
114 dispatch(FuncRequest(getLfun(), lfun));
118 Dialog * createGuiHyperlink(GuiView & lv) { return new GuiHyperlink(lv); }
121 } // namespace frontend
125 #include "moc_GuiHyperlink.cpp"