mirror of
https://github.com/xiaoyifang/goldendict-ng.git
synced 2024-11-27 15:24:05 +00:00
opt: website dictionary render html
This commit is contained in:
parent
6edfd15962
commit
9e99389cc3
|
@ -24,7 +24,6 @@ class WebSiteDictionary: public Dictionary::Class
|
||||||
{
|
{
|
||||||
string name;
|
string name;
|
||||||
QByteArray urlTemplate;
|
QByteArray urlTemplate;
|
||||||
bool experimentalIframe;
|
|
||||||
QString iconFilename;
|
QString iconFilename;
|
||||||
bool inside_iframe;
|
bool inside_iframe;
|
||||||
QNetworkAccessManager & netMgr;
|
QNetworkAccessManager & netMgr;
|
||||||
|
@ -41,12 +40,8 @@ public:
|
||||||
name( name_ ),
|
name( name_ ),
|
||||||
iconFilename( iconFilename_ ),
|
iconFilename( iconFilename_ ),
|
||||||
inside_iframe( inside_iframe_ ),
|
inside_iframe( inside_iframe_ ),
|
||||||
netMgr( netMgr_ ),
|
netMgr( netMgr_ )
|
||||||
experimentalIframe( false )
|
|
||||||
{
|
{
|
||||||
if ( urlTemplate_.startsWith( "http://" ) || urlTemplate_.startsWith( "https://" ) ) {
|
|
||||||
experimentalIframe = true;
|
|
||||||
}
|
|
||||||
//else file:/// local dictionary file path
|
//else file:/// local dictionary file path
|
||||||
|
|
||||||
urlTemplate = QUrl( urlTemplate_ ).toEncoded();
|
urlTemplate = QUrl( urlTemplate_ ).toEncoded();
|
||||||
|
@ -335,14 +330,12 @@ sptr< DataRequest > WebSiteDictionary::getArticle( wstring const & str,
|
||||||
QUrl url( urlString );
|
QUrl url( urlString );
|
||||||
GlobalBroadcaster::instance()->addWhitelist( url.host() );
|
GlobalBroadcaster::instance()->addWhitelist( url.host() );
|
||||||
|
|
||||||
QString encodeUrl;
|
QString encodeUrl=encodeUrl = urlString;
|
||||||
if ( experimentalIframe ) {
|
|
||||||
encodeUrl = "ifr://localhost?url=" + QUrl::toPercentEncoding( urlString );
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
encodeUrl = urlString;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if ( GlobalBroadcaster::instance()->getPreference()->openWebSiteInNewTab ){
|
||||||
|
result += string("<div><span>this website dictionary is opened in the new tab</span></div>");
|
||||||
|
}
|
||||||
|
else{
|
||||||
fmt::format_to( std::back_inserter( result ),
|
fmt::format_to( std::back_inserter( result ),
|
||||||
R"(<iframe id="gdexpandframe-{}" src="{}"
|
R"(<iframe id="gdexpandframe-{}" src="{}"
|
||||||
onmouseover="processIframeMouseOver('gdexpandframe-{}');"
|
onmouseover="processIframeMouseOver('gdexpandframe-{}');"
|
||||||
|
@ -352,7 +345,7 @@ sandbox="allow-same-origin allow-scripts allow-popups"></iframe>)",
|
||||||
getId(),
|
getId(),
|
||||||
encodeUrl.toStdString(),
|
encodeUrl.toStdString(),
|
||||||
getId() );
|
getId() );
|
||||||
|
}
|
||||||
auto dr = std::make_shared< DataRequestInstant >( true );
|
auto dr = std::make_shared< DataRequestInstant >( true );
|
||||||
dr->appendString( result );
|
dr->appendString( result );
|
||||||
return dr;
|
return dr;
|
||||||
|
|
Loading…
Reference in a new issue