2017-09-13 22:26:14 +02:00
|
|
|
From 84c17bc232a7721ab0687228af5b3acfba12ad75 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Jan Engelhardt <jengelh@inai.de>
|
|
|
|
Date: Fri, 8 Sep 2017 01:55:57 +0200
|
|
|
|
Subject: [PATCH] MGR: support wxWidgets without webview
|
|
|
|
|
|
|
|
If wxWidgets is built without support for the webview widget, make do
|
|
|
|
with a wxHtmlWindow instead.
|
|
|
|
---
|
|
|
|
clientgui/NoticeListCtrl.cpp | 25 +++++++++++++++++++++++++
|
|
|
|
clientgui/NoticeListCtrl.h | 8 ++++++++
|
|
|
|
2 files changed, 33 insertions(+)
|
|
|
|
|
2017-10-27 01:01:55 +02:00
|
|
|
Index: boinc-client_release-7.8-7.8.3/clientgui/NoticeListCtrl.cpp
|
2017-09-13 22:26:14 +02:00
|
|
|
===================================================================
|
2017-10-27 01:01:55 +02:00
|
|
|
--- boinc-client_release-7.8-7.8.3.orig/clientgui/NoticeListCtrl.cpp
|
|
|
|
+++ boinc-client_release-7.8-7.8.3/clientgui/NoticeListCtrl.cpp
|
2017-09-13 22:26:14 +02:00
|
|
|
@@ -49,10 +49,14 @@ IMPLEMENT_DYNAMIC_CLASS( CNoticeListCtrl
|
|
|
|
|
|
|
|
BEGIN_EVENT_TABLE( CNoticeListCtrl, wxWindow )
|
|
|
|
|
|
|
|
+#if wxUSE_WEBVIEW
|
|
|
|
////@begin CNoticeListCtrl event table entries
|
|
|
|
EVT_WEBVIEW_NAVIGATING(ID_LIST_NOTIFICATIONSVIEW, CNoticeListCtrl::OnLinkClicked)
|
|
|
|
EVT_WEBVIEW_ERROR(ID_LIST_NOTIFICATIONSVIEW, CNoticeListCtrl::OnWebViewError)
|
|
|
|
////@end CNoticeListCtrl event table entries
|
|
|
|
+#else
|
|
|
|
+ EVT_HTML_LINK_CLICKED(ID_LIST_NOTIFICATIONSVIEW, CNoticeListCtrl::OnLinkClicked)
|
|
|
|
+#endif
|
|
|
|
|
|
|
|
END_EVENT_TABLE()
|
|
|
|
|
|
|
|
@@ -84,7 +88,11 @@ bool CNoticeListCtrl::Create( wxWindow*
|
|
|
|
wxWindow::Create( parent, ID_LIST_NOTIFICATIONSVIEW, wxDefaultPosition, wxDefaultSize,
|
|
|
|
wxSUNKEN_BORDER | wxTAB_TRAVERSAL );
|
|
|
|
|
|
|
|
+#if wxUSE_WEBVIEW
|
|
|
|
m_browser = wxWebView::New( this, ID_LIST_NOTIFICATIONSVIEW );
|
|
|
|
+#else
|
|
|
|
+ m_browser = new wxHtmlWindow(this, ID_LIST_NOTIFICATIONSVIEW);
|
|
|
|
+#endif
|
|
|
|
////@end CNoticeListCtrl creation
|
|
|
|
|
|
|
|
wxBoxSizer *topsizer;
|
2017-10-27 00:08:40 +02:00
|
|
|
@@ -238,7 +246,11 @@ void CNoticeListCtrl::SetItemCount(int n
|
2017-09-13 22:26:14 +02:00
|
|
|
m_noticesBody += wxT("</font></body></html>");
|
2017-10-27 00:08:40 +02:00
|
|
|
// baseURL is not needed here (see comments above) and it
|
|
|
|
// must be an empty string for this to work under OS 10.12.4
|
2017-09-13 22:26:14 +02:00
|
|
|
+#if wxUSE_WEBVIEW
|
2017-10-27 00:08:40 +02:00
|
|
|
m_browser->SetPage(m_noticesBody, wxEmptyString);
|
2017-09-13 22:26:14 +02:00
|
|
|
+#else
|
|
|
|
+ m_browser->SetPage(m_noticesBody);
|
|
|
|
+#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-10-27 00:08:40 +02:00
|
|
|
@@ -248,6 +260,7 @@ void CNoticeListCtrl::Clear() {
|
2017-09-13 22:26:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
+#if wxUSE_WEBVIEW
|
|
|
|
void CNoticeListCtrl::OnLinkClicked( wxWebViewEvent& event ) {
|
|
|
|
if (event.GetURL().StartsWith(wxT("http://")) || event.GetURL().StartsWith(wxT("https://"))) {
|
|
|
|
event.Veto(); // Tell wxWebView not to follow link
|
2017-10-27 00:08:40 +02:00
|
|
|
@@ -264,6 +277,18 @@ void CNoticeListCtrl::OnWebViewError( wx
|
2017-09-13 22:26:14 +02:00
|
|
|
|
|
|
|
event.Skip();
|
|
|
|
}
|
|
|
|
+#else
|
|
|
|
+void CNoticeListCtrl::OnLinkClicked(wxHtmlLinkEvent &event)
|
|
|
|
+{
|
|
|
|
+ wxString url = event.GetLinkInfo().GetHref();
|
|
|
|
+ if (!url.StartsWith(wxT("http://")) && !url.StartsWith(wxT("https://"))) {
|
|
|
|
+ event.Skip();
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ event.Skip(); // Tell element not to follow link
|
|
|
|
+ wxLaunchDefaultBrowser(url);
|
|
|
|
+}
|
|
|
|
+#endif
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
2017-10-27 01:01:55 +02:00
|
|
|
Index: boinc-client_release-7.8-7.8.3/clientgui/NoticeListCtrl.h
|
2017-09-13 22:26:14 +02:00
|
|
|
===================================================================
|
2017-10-27 01:01:55 +02:00
|
|
|
--- boinc-client_release-7.8-7.8.3.orig/clientgui/NoticeListCtrl.h
|
|
|
|
+++ boinc-client_release-7.8-7.8.3/clientgui/NoticeListCtrl.h
|
2017-09-13 22:26:14 +02:00
|
|
|
@@ -45,8 +45,12 @@ public:
|
|
|
|
|
|
|
|
////@begin CNoticeListCtrl event handler declarations
|
|
|
|
|
|
|
|
+#if defined(wxUSE_WEBVIEW) && wxUSE_WEBVIEW
|
|
|
|
void OnLinkClicked( wxWebViewEvent& event );
|
|
|
|
void OnWebViewError( wxWebViewEvent& event );
|
|
|
|
+#else
|
|
|
|
+ void OnLinkClicked(wxHtmlLinkEvent &);
|
|
|
|
+#endif
|
|
|
|
|
|
|
|
////@end CNoticeListCtrl event handler declarations
|
|
|
|
|
|
|
|
@@ -56,7 +60,11 @@ public:
|
|
|
|
bool m_bDisplayFetchingNotices;
|
|
|
|
bool m_bDisplayEmptyNotice;
|
|
|
|
private:
|
|
|
|
+#if wxUSE_WEBVIEW
|
|
|
|
wxWebView* m_browser;
|
|
|
|
+#else
|
|
|
|
+ wxHtmlWindow *m_browser;
|
|
|
|
+#endif
|
|
|
|
bool m_bNeedsReloading;
|
|
|
|
int m_itemCount;
|
|
|
|
wxString m_noticesBody;
|