changed url bar behaviour. Failed attempt at icon

This commit is contained in:
Alexandre Van de Sande 2015-02-13 18:32:15 +01:00
parent d73dff4d5b
commit 7aef0fed29
3 changed files with 76 additions and 74 deletions

View File

@ -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

View File

@ -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);

View File

@ -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
} }