-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathWebPageEdit.cpp
91 lines (79 loc) · 3.4 KB
/
WebPageEdit.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/************************************************************************
**
** Copyright (C) 2019-2024 Kevin B. Hendricks, Stratford Ontario Canada
** Copyright (C) 2020 Doug Massay
**
** This file is part of PageEdit.
**
** PageEdit is free software: you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation, either version 3 of the License, or
** (at your option) any later version.
**
** PageEdit is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with PageEdit. If not, see <http://www.gnu.org/licenses/>.
**
*************************************************************************/
#include <QTimer>
#include <QtWebEngineCore>
#include <QWebEnginePage>
#include <QWebEngineProfile>
#include <QDebug>
#include "Utility.h"
#include "WebPageEdit.h"
#define DBG if(0)
static const QString BASIC_HTML =
"<html><head><title></title></head>"
"<body style=\"background-color: %1\"></body></html>";
WebPageEdit::WebPageEdit(QWebEngineProfile *profile, QObject *parent)
: QWebEnginePage(profile, parent)
{
setBackgroundColor(Utility::WebViewBackgroundColor(true));
setUrl(QUrl("about:blank"));
}
// Because you can not delegate all links in QtWebEngine we must override
// here and generate our own link requests
// BUT a loadStarted signal is emitted by this page **before** this is called
// Even **before** it knows how we want to handle it!
// Once we "return false" from this a loadFinished with okay **false** is generated.
// These false loadStart and LoadFinished greatly confuse our model
// Therefore do NOT emit a signal from this method as it can create huge delays in when
// loadFinished(okay) returns (with okay as false)
bool WebPageEdit::acceptNavigationRequest(const QUrl & url, QWebEnginePage::NavigationType type, bool isMainFrame)
{
if ((type == QWebEnginePage::NavigationTypeLinkClicked) || (type == QWebEnginePage::NavigationTypeOther)) {
DBG qDebug() << "acceptNavigationRequest " << url.toString() << " , " << type << " , " << isMainFrame;
if (isMainFrame) {
m_url = url;
QTimer::singleShot(20,this,SLOT(EmitLinkClicked()));
return false;
}
// allow secondary frames such as iframes to be loaded automatically
return true;
}
if (type == QWebEnginePage::NavigationTypeTyped) {
DBG qDebug() << "acceptNavigationRequest from scheme handler load" << url.toString();
return true;
}
if (type == QWebEnginePage::NavigationTypeRedirect) {
DBG qDebug() << "acceptNavigationRequest from scheme handler redirect" << url.toString();
return true;
}
qDebug() << " Unhandled acceptNavigationRequest with type: " << type;
return true;
}
void WebPageEdit::EmitLinkClicked()
{
emit LinkClicked(m_url);
}
void WebPageEdit::javaScriptConsoleMessage(QWebEnginePage::JavaScriptConsoleMessageLevel level,
const QString & message, int lineNumber, const QString & sourceID)
{
const QString logEntry = message + " on line: " + QString::number(lineNumber) + " Source:" + sourceID;
qDebug() << "Javascript error: " << level << logEntry;
}