New attempt on #9906: allow following hyperlinks via context menu.

Now safer version with the help of Qt.
This commit is contained in:
Pavel Sanda 2020-08-14 19:46:13 +02:00
parent 836300cd33
commit 48b1e8a0ac
2 changed files with 18 additions and 3 deletions

View File

@ -673,6 +673,8 @@ Menuset
#
Menu "context-hyperlink"
Item "Settings...|S" "inset-settings"
Separator
Item "Open Target...|O" "inset-edit"
End
#

View File

@ -12,6 +12,9 @@
#include <config.h>
#include "InsetHyperlink.h"
#include <QtGui/QDesktopServices>
#include <QUrl>
#include "Buffer.h"
#include "DispatchResult.h"
#include "Encoding.h"
@ -30,6 +33,7 @@
#include "support/filetools.h"
#include "support/gettext.h"
#include "support/lstrings.h"
#include "support/qstring_helpers.h"
#include "frontends/alert.h"
@ -106,9 +110,13 @@ bool InsetHyperlink::getStatus(Cursor & cur, FuncRequest const & cmd,
FuncStatus & flag) const
{
switch (cmd.action()) {
case LFUN_INSET_EDIT:
flag.setEnabled(getParam("type").empty() || getParam("type") == "file:");
case LFUN_INSET_EDIT: {
QUrl url(toqstr(getParam("target")),QUrl::StrictMode);
bool url_valid = getParam("type").empty() && url.isValid();
flag.setEnabled(url_valid || getParam("type") == "file:");
return true;
}
default:
return InsetCommand::getStatus(cur, cmd, flag);
@ -118,7 +126,12 @@ bool InsetHyperlink::getStatus(Cursor & cur, FuncRequest const & cmd,
void InsetHyperlink::viewTarget() const
{
if (getParam("type") == "file:") {
if (getParam("type").empty()) { //==Web
QUrl url(toqstr(getParam("target")),QUrl::StrictMode);
if (!QDesktopServices::openUrl(url))
LYXERR0("Unable to open URL!");
} else if (getParam("type") == "file:") {
FileName url = makeAbsPath(to_utf8(getParam("target")), buffer().filePath());
string const format = theFormats().getFormatFromFile(url);
theFormats().view(buffer(), url, format);