changed url bar behaviour. Failed attempt at icon
This commit is contained in:
parent
d73dff4d5b
commit
7aef0fed29
|
@ -59,13 +59,13 @@ ApplicationWindow {
|
||||||
|
|
||||||
function activeView(view, menuItem) {
|
function activeView(view, menuItem) {
|
||||||
mainSplit.setView(view, menuItem)
|
mainSplit.setView(view, menuItem)
|
||||||
if (view.hideUrl) {
|
/*if (view.hideUrl) {
|
||||||
urlPane.visible = false;
|
urlPane.visible = false;
|
||||||
mainView.anchors.top = rootView.top
|
mainView.anchors.top = rootView.top
|
||||||
} else {
|
} else {
|
||||||
urlPane.visible = true;
|
urlPane.visible = true;
|
||||||
mainView.anchors.top = divider.bottom
|
mainView.anchors.top = divider.bottom
|
||||||
}
|
}*/
|
||||||
}
|
}
|
||||||
|
|
||||||
function addViews(view, path, options) {
|
function addViews(view, path, options) {
|
||||||
|
@ -120,13 +120,10 @@ ApplicationWindow {
|
||||||
|
|
||||||
var domainAlreadyOpen = false;
|
var domainAlreadyOpen = false;
|
||||||
|
|
||||||
console.log("requested: " + requestedDomain )
|
|
||||||
|
|
||||||
for(var i = 0; i < mainSplit.views.length; i++) {
|
for(var i = 0; i < mainSplit.views.length; i++) {
|
||||||
if (mainSplit.views[i].view.url) {
|
if (mainSplit.views[i].view.url) {
|
||||||
var matches = mainSplit.views[i].view.url.toString().match(/^[a-z]*\:\/\/(?:www\.)?([^\/?#]+)(?:[\/?#]|$)/i);
|
var matches = mainSplit.views[i].view.url.toString().match(/^[a-z]*\:\/\/(?:www\.)?([^\/?#]+)(?:[\/?#]|$)/i);
|
||||||
var existingDomain = matches && matches[1];
|
var existingDomain = matches && matches[1];
|
||||||
console.log("exists: " + existingDomain);
|
|
||||||
if (requestedDomain == existingDomain) {
|
if (requestedDomain == existingDomain) {
|
||||||
domainAlreadyOpen = true;
|
domainAlreadyOpen = true;
|
||||||
mainSplit.views[i].view.url = url;
|
mainSplit.views[i].view.url = url;
|
||||||
|
@ -567,7 +564,9 @@ ApplicationWindow {
|
||||||
if (parent.closable == true) {
|
if (parent.closable == true) {
|
||||||
closeIcon.visible = sel.visible
|
closeIcon.visible = sel.visible
|
||||||
}
|
}
|
||||||
|
/*if(view.hasOwnProperty("iconSource")) {
|
||||||
|
icon.source = view.iconSource;
|
||||||
|
}*/
|
||||||
}
|
}
|
||||||
onExited: {
|
onExited: {
|
||||||
closeIcon.visible = false
|
closeIcon.visible = false
|
||||||
|
@ -600,10 +599,13 @@ ApplicationWindow {
|
||||||
id: label
|
id: label
|
||||||
font.family: sourceSansPro.name
|
font.family: sourceSansPro.name
|
||||||
font.weight: Font.DemiBold
|
font.weight: Font.DemiBold
|
||||||
|
elide: Text.ElideRight
|
||||||
anchors {
|
anchors {
|
||||||
left: icon.right
|
left: icon.right
|
||||||
|
right: parent.right
|
||||||
verticalCenter: parent.verticalCenter
|
verticalCenter: parent.verticalCenter
|
||||||
leftMargin: 6
|
leftMargin: 6
|
||||||
|
rightMargin: 8
|
||||||
// verticalCenterOffset: -10
|
// verticalCenterOffset: -10
|
||||||
}
|
}
|
||||||
x:250
|
x:250
|
||||||
|
|
|
@ -64,23 +64,15 @@ Rectangle {
|
||||||
}
|
}
|
||||||
|
|
||||||
function showFullUrlBar(on){
|
function showFullUrlBar(on){
|
||||||
if (on) {
|
if (uriNav.focus == false ) {
|
||||||
//appTitle.visible = false
|
if (on == false) {
|
||||||
//appDomain.visible = false
|
clickAnywhereOnApp.visible = false
|
||||||
|
navBar.state = "titleVisible"
|
||||||
//uriNav.visible = true
|
} else {
|
||||||
clickAnywhereOnApp.visible = true
|
clickAnywhereOnApp.visible = true
|
||||||
|
navBar.state = "fullUrlVisible"
|
||||||
navBar.state = "fullUrlVisible"
|
}
|
||||||
} else {
|
}
|
||||||
//appTitle.visible = true
|
|
||||||
//appDomain.visible = true
|
|
||||||
//uriNav.visible = false
|
|
||||||
clickAnywhereOnApp.visible = false
|
|
||||||
|
|
||||||
navBar.state = "titleVisible"
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,24 +82,40 @@ Rectangle {
|
||||||
Item {
|
Item {
|
||||||
objectName: "root"
|
objectName: "root"
|
||||||
id: root
|
id: root
|
||||||
anchors.fill: parent
|
anchors {
|
||||||
|
fill: parent
|
||||||
|
}
|
||||||
|
|
||||||
state: "inspectorShown"
|
state: "inspectorShown"
|
||||||
|
|
||||||
MouseArea {
|
MouseArea {
|
||||||
id: clickAnywhereOnApp
|
id: clickAnywhereOnApp
|
||||||
z:15
|
z:15
|
||||||
//hoverEnabled: true
|
// Using a secondary screen to catch on mouse exits for the area, because
|
||||||
anchors.fill: parent
|
// there are many hover actions conflicting
|
||||||
/*hoverEnabled: true*/
|
|
||||||
|
anchors {
|
||||||
|
top: parent.top
|
||||||
|
topMargin: 50
|
||||||
|
right: parent.right
|
||||||
|
bottom: parent.bottom
|
||||||
|
left: parent.left
|
||||||
|
}
|
||||||
|
hoverEnabled: true
|
||||||
|
|
||||||
onClicked: {
|
onEntered: {
|
||||||
showFullUrlBar(false);
|
showFullUrlBar(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*Rectangle {
|
onClicked: {
|
||||||
anchors.fill: parent
|
uriNav.focus = false
|
||||||
color: "#88888888"
|
showFullUrlBar(false);
|
||||||
}*/
|
}
|
||||||
|
|
||||||
|
// Rectangle {
|
||||||
|
// anchors.fill: parent
|
||||||
|
// color: "#88888888"
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
RowLayout {
|
RowLayout {
|
||||||
|
@ -126,7 +134,7 @@ Rectangle {
|
||||||
webview.goBack()
|
webview.goBack()
|
||||||
}
|
}
|
||||||
|
|
||||||
anchors{
|
anchors {
|
||||||
left: parent.left
|
left: parent.left
|
||||||
leftMargin: 6
|
leftMargin: 6
|
||||||
}
|
}
|
||||||
|
@ -146,15 +154,17 @@ Rectangle {
|
||||||
color: "#FFFFFF"
|
color: "#FFFFFF"
|
||||||
radius: 6
|
radius: 6
|
||||||
|
|
||||||
|
|
||||||
MouseArea {
|
MouseArea {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
z: 10
|
z: 10
|
||||||
hoverEnabled: true
|
hoverEnabled: true
|
||||||
|
|
||||||
onEntered: {
|
onEntered: {
|
||||||
showFullUrlBar(true);
|
showFullUrlBar(true);
|
||||||
}
|
}
|
||||||
|
/*onExited: {
|
||||||
|
showFullUrlBar(false);
|
||||||
|
}*/
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -171,14 +181,15 @@ Rectangle {
|
||||||
font.bold: true
|
font.bold: true
|
||||||
font.capitalization: Font.AllUppercase
|
font.capitalization: Font.AllUppercase
|
||||||
horizontalAlignment: Text.AlignRight
|
horizontalAlignment: Text.AlignRight
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
|
elide: Text.ElideRight
|
||||||
|
|
||||||
anchors {
|
anchors {
|
||||||
left: parent.left
|
left: parent.left
|
||||||
right: parent.horizontalCenter
|
right: parent.horizontalCenter
|
||||||
top: parent.top
|
top: parent.top
|
||||||
bottom: parent.bottom
|
bottom: parent.bottom
|
||||||
rightMargin: 10
|
leftMargin: 32
|
||||||
}
|
}
|
||||||
color: "#928484"
|
color: "#928484"
|
||||||
}
|
}
|
||||||
|
@ -189,13 +200,15 @@ Rectangle {
|
||||||
font.bold: false
|
font.bold: false
|
||||||
horizontalAlignment: Text.AlignLeft
|
horizontalAlignment: Text.AlignLeft
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
|
elide: Text.ElideLeft
|
||||||
|
|
||||||
anchors {
|
anchors {
|
||||||
left: parent.horizontalCenter
|
left: parent.horizontalCenter
|
||||||
right: parent.right
|
right: parent.right
|
||||||
top: parent.top
|
top: parent.top
|
||||||
bottom: parent.bottom
|
bottom: parent.bottom
|
||||||
leftMargin: 10
|
leftMargin: 32
|
||||||
|
|
||||||
}
|
}
|
||||||
color: "#C0AFAF"
|
color: "#C0AFAF"
|
||||||
}
|
}
|
||||||
|
@ -212,7 +225,7 @@ Rectangle {
|
||||||
}
|
}
|
||||||
|
|
||||||
horizontalAlignment: Text.AlignHCenter
|
horizontalAlignment: Text.AlignHCenter
|
||||||
|
|
||||||
style: TextFieldStyle {
|
style: TextFieldStyle {
|
||||||
textColor: "#928484"
|
textColor: "#928484"
|
||||||
background: Rectangle {
|
background: Rectangle {
|
||||||
|
@ -227,11 +240,6 @@ Rectangle {
|
||||||
Keys.onReturnPressed: {
|
Keys.onReturnPressed: {
|
||||||
webview.url = this.text;
|
webview.url = this.text;
|
||||||
}
|
}
|
||||||
/* onFocusedChanged: {
|
|
||||||
if (focused) {
|
|
||||||
//uriNav.selectAll();
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
z:2
|
z:2
|
||||||
|
@ -332,18 +340,19 @@ Rectangle {
|
||||||
bottom: parent.bottom
|
bottom: parent.bottom
|
||||||
top: navBar.bottom
|
top: navBar.bottom
|
||||||
}
|
}
|
||||||
z: 10
|
|
||||||
|
z: 10
|
||||||
onLoadingChanged: {
|
|
||||||
|
onLoadingChanged: {
|
||||||
|
|
||||||
|
// this checks if your app has special header tags
|
||||||
if (loadRequest.status == WebEngineView.LoadSucceededStatus) {
|
if (loadRequest.status == WebEngineView.LoadSucceededStatus) {
|
||||||
webview.runJavaScript("document.title", function(pageTitle) {
|
webview.runJavaScript("document.title", function(pageTitle) {
|
||||||
menuItem.title = pageTitle;
|
menuItem.title = pageTitle;
|
||||||
});
|
});
|
||||||
|
|
||||||
//var topBarStyle
|
|
||||||
webView.runJavaScript("document.querySelector(\"meta[name='ethereum-dapp-url-bar-style']\").getAttribute(\"content\")", function(topBarStyle){
|
webView.runJavaScript("document.querySelector(\"meta[name='ethereum-dapp-url-bar-style']\").getAttribute(\"content\")", function(topBarStyle){
|
||||||
if (topBarStyle=="transparent") {
|
if (topBarStyle=="transparent") {
|
||||||
|
|
||||||
// Adjust for a transparent sidebar Dapp
|
// Adjust for a transparent sidebar Dapp
|
||||||
navBarBackground.visible = false;
|
navBarBackground.visible = false;
|
||||||
back.visible = false;
|
back.visible = false;
|
||||||
|
@ -362,8 +371,13 @@ Rectangle {
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// webView.runJavaScript("document.querySelector(\"link[rel='icon']\").getAttribute(\"href\")", function(sideIcon){
|
||||||
|
// if(sideIcon){
|
||||||
|
// window.iconSource = "http://localhost:3000/whisper-icon@2x.png" //webview.url + sideIcon
|
||||||
|
// console.log(iconSource)
|
||||||
|
// };
|
||||||
|
// });
|
||||||
|
|
||||||
webview.runJavaScript(eth.readFile("bignumber.min.js"));
|
webview.runJavaScript(eth.readFile("bignumber.min.js"));
|
||||||
webview.runJavaScript(eth.readFile("ethereum.js/dist/ethereum.js"));
|
webview.runJavaScript(eth.readFile("ethereum.js/dist/ethereum.js"));
|
||||||
|
|
||||||
|
@ -371,7 +385,7 @@ Rectangle {
|
||||||
var matches = cleanTitle.match(/^[a-z]*\:\/\/([^\/?#]+)(?:[\/?#]|$)/i);
|
var matches = cleanTitle.match(/^[a-z]*\:\/\/([^\/?#]+)(?:[\/?#]|$)/i);
|
||||||
var domain = matches && matches[1];
|
var domain = matches && matches[1];
|
||||||
|
|
||||||
appDomain.text = domain //webview.url.replace("a", "z")
|
appDomain.text = domain
|
||||||
appTitle.text = webview.title
|
appTitle.text = webview.title
|
||||||
|
|
||||||
showFullUrlBar(false);
|
showFullUrlBar(false);
|
||||||
|
|
|
@ -85,35 +85,21 @@ Rectangle {
|
||||||
property var domain: "ethereum-dapp-catalog.meteor.com"
|
property var domain: "ethereum-dapp-catalog.meteor.com"
|
||||||
url: protocol + domain
|
url: protocol + domain
|
||||||
|
|
||||||
//navigationRequest: WebEngineView.IgnoreRequest
|
|
||||||
// onLoadingChanged: {
|
|
||||||
// if (loadRequest.status == WebEngineView.LoadSucceededStatus) {
|
|
||||||
// webview.runJavaScript(eth.readFile("bignumber.min.js"));
|
|
||||||
// webview.runJavaScript(eth.readFile("ethereum.js/dist/ethereum.js"));
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
||||||
//onNavigationRequested: {
|
|
||||||
// detect URL scheme prefix, most likely an external link
|
|
||||||
//var schemaRE = /^\w+:/;
|
|
||||||
//if (schemaRE.test(request.url)) {
|
|
||||||
// request.action = WebView.AcceptRequest;
|
|
||||||
//} else {
|
|
||||||
//request.action = WebView.IgnoreRequest;
|
|
||||||
// delegate request.url here
|
|
||||||
//}
|
|
||||||
//}
|
|
||||||
|
|
||||||
onJavaScriptConsoleMessage: {
|
onJavaScriptConsoleMessage: {
|
||||||
console.log(sourceID + ":" + lineNumber + ":" + JSON.stringify(message));
|
console.log(sourceID + ":" + lineNumber + ":" + JSON.stringify(message));
|
||||||
}
|
}
|
||||||
|
|
||||||
onNavigationRequested: {
|
onNavigationRequested: {
|
||||||
|
// this checks if the domain of the requested link is the same as the catalog's
|
||||||
|
// If it is, it opens on the same window, if it's not it opens a new tab
|
||||||
|
|
||||||
var cleanTitle = request.url.toString()
|
var cleanTitle = request.url.toString()
|
||||||
var matches = cleanTitle.match(/^[a-z]*\:\/\/([^\/?#]+)(?:[\/?#]|$)/i);
|
var matches = cleanTitle.match(/^[a-z]*\:\/\/([^\/?#]+)(?:[\/?#]|$)/i);
|
||||||
var requestedDomain = matches && matches[1];
|
var requestedDomain = matches && matches[1];
|
||||||
|
|
||||||
console.debug ("NavigationRequested: " + request.url + " navigationType=" + request.navigationType)
|
|
||||||
|
|
||||||
if(request.navigationType==0){
|
if(request.navigationType==0){
|
||||||
|
|
||||||
|
@ -137,7 +123,7 @@ Rectangle {
|
||||||
anchors {
|
anchors {
|
||||||
left: root.left
|
left: root.left
|
||||||
right: root.right
|
right: root.right
|
||||||
top: sizeGrip.bottom
|
top: root.top
|
||||||
bottom: root.bottom
|
bottom: root.bottom
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue