2020-10-07 16:14:55 -04:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
import Qt.labs.settings 1.0
|
|
|
|
import QtQuick.Controls.Styles 1.0
|
2020-10-08 11:31:53 -04:00
|
|
|
import QtWebEngine 1.10
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2021-09-30 11:43:29 +02:00
|
|
|
import "../../../../shared"
|
|
|
|
import "../../../../shared/status"
|
|
|
|
import "../popups"
|
|
|
|
import "../controls"
|
2020-10-07 16:14:55 -04:00
|
|
|
|
2020-10-08 11:31:53 -04:00
|
|
|
Rectangle {
|
2021-09-30 11:43:29 +02:00
|
|
|
id: browserHeader
|
|
|
|
|
|
|
|
property alias favoriteComponent: favoritesBarLoader.sourceComponent
|
2020-10-08 14:08:50 -04:00
|
|
|
property alias addressBar: addressBar
|
2021-09-30 11:43:29 +02:00
|
|
|
|
2020-10-08 11:31:53 -04:00
|
|
|
readonly property int innerMargin: 12
|
2021-09-30 11:43:29 +02:00
|
|
|
property var currentFavorite
|
2020-10-09 13:56:42 -04:00
|
|
|
property var addNewTab: function () {}
|
2021-09-30 11:43:29 +02:00
|
|
|
property string dappBrowserAccName: ""
|
|
|
|
property string dappBrowserAccIcon: ""
|
|
|
|
|
|
|
|
signal addNewFavoritelClicked(var xPos)
|
2020-10-07 16:14:55 -04:00
|
|
|
|
|
|
|
width: parent.width
|
2020-12-29 12:10:22 -05:00
|
|
|
height: barRow.height + favoritesBarLoader.height
|
2020-10-08 11:31:53 -04:00
|
|
|
color: Style.current.background
|
|
|
|
border.width: 0
|
2020-10-07 16:14:55 -04:00
|
|
|
|
|
|
|
RowLayout {
|
2020-12-29 12:10:22 -05:00
|
|
|
id: barRow
|
|
|
|
width: parent.width
|
|
|
|
height: 45
|
2021-09-30 11:43:29 +02:00
|
|
|
spacing: browserHeader.innerMargin
|
2020-10-07 16:14:55 -04:00
|
|
|
|
|
|
|
Menu {
|
|
|
|
id: historyMenu
|
|
|
|
Instantiator {
|
|
|
|
model: currentWebView && currentWebView.navigationHistory.items
|
|
|
|
MenuItem {
|
|
|
|
text: model.title
|
|
|
|
onTriggered: currentWebView.goBackOrForward(model.offset)
|
|
|
|
checkable: !enabled
|
|
|
|
checked: !enabled
|
|
|
|
enabled: model.offset
|
|
|
|
}
|
|
|
|
onObjectAdded: function(index, object) {
|
|
|
|
historyMenu.insertItem(index, object)
|
|
|
|
}
|
|
|
|
onObjectRemoved: function(index, object) {
|
|
|
|
historyMenu.removeItem(object)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-08 11:31:53 -04:00
|
|
|
StatusIconButton {
|
2020-10-07 16:14:55 -04:00
|
|
|
id: backButton
|
2020-10-08 11:31:53 -04:00
|
|
|
icon.name: "leave_chat"
|
|
|
|
disabledColor: Style.current.lightGrey
|
2020-10-07 16:14:55 -04:00
|
|
|
onClicked: currentWebView.goBack()
|
|
|
|
onPressAndHold: {
|
|
|
|
if (currentWebView && (currentWebView.canGoBack || currentWebView.canGoForward)){
|
|
|
|
historyMenu.popup(backButton.x, backButton.y + backButton.height)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
enabled: currentWebView && currentWebView.canGoBack
|
2020-10-08 11:31:53 -04:00
|
|
|
width: 24
|
|
|
|
height: 24
|
2021-09-30 11:43:29 +02:00
|
|
|
Layout.leftMargin: browserHeader.innerMargin
|
2020-10-08 11:31:53 -04:00
|
|
|
padding: 6
|
2020-10-07 16:14:55 -04:00
|
|
|
}
|
|
|
|
|
2020-10-08 11:31:53 -04:00
|
|
|
StatusIconButton {
|
2020-10-07 16:14:55 -04:00
|
|
|
id: forwardButton
|
2020-10-08 11:31:53 -04:00
|
|
|
icon.name: "leave_chat"
|
|
|
|
iconRotation: 180
|
|
|
|
disabledColor: Style.current.lightGrey
|
2020-10-07 16:14:55 -04:00
|
|
|
onClicked: currentWebView.goForward()
|
|
|
|
onPressAndHold: {
|
|
|
|
if (currentWebView && (currentWebView.canGoBack || currentWebView.canGoForward)){
|
|
|
|
historyMenu.popup(forwardButton.x, forwardButton.y + forwardButton.height)
|
|
|
|
}
|
|
|
|
}
|
2020-10-08 11:31:53 -04:00
|
|
|
enabled: currentWebView && currentWebView.canGoForward
|
|
|
|
width: 24
|
|
|
|
height: 24
|
2021-09-30 11:43:29 +02:00
|
|
|
Layout.leftMargin: -browserHeader.innerMargin/2
|
2020-10-29 15:02:32 -04:00
|
|
|
}
|
|
|
|
|
2020-10-07 16:14:55 -04:00
|
|
|
StyledTextField {
|
|
|
|
id: addressBar
|
2020-10-08 11:31:53 -04:00
|
|
|
height: 40
|
2020-10-07 16:14:55 -04:00
|
|
|
Layout.fillWidth: true
|
|
|
|
background: Rectangle {
|
2020-10-08 11:31:53 -04:00
|
|
|
color: Style.current.inputBackground
|
|
|
|
border.color: Style.current.inputBorderFocus
|
|
|
|
border.width: activeFocus ? 1 : 0
|
|
|
|
radius: 20
|
2020-10-07 16:14:55 -04:00
|
|
|
}
|
2020-10-08 11:31:53 -04:00
|
|
|
leftPadding: Style.current.padding
|
2021-02-18 11:36:05 -05:00
|
|
|
//% "Enter URL"
|
|
|
|
placeholderText: qsTrId("enter-url")
|
2020-10-07 16:14:55 -04:00
|
|
|
focus: true
|
|
|
|
text: ""
|
2020-10-08 11:31:53 -04:00
|
|
|
color: Style.current.textColor
|
2021-04-19 17:02:59 +03:00
|
|
|
onActiveFocusChanged: {
|
|
|
|
if (activeFocus) {
|
|
|
|
addressBar.selectAll()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-07 16:14:55 -04:00
|
|
|
Keys.onPressed: {
|
|
|
|
// TODO: disable browsing local files? file://
|
2021-01-04 16:32:36 -05:00
|
|
|
if (event.key === Qt.Key_Enter || event.key === Qt.Key_Return) {
|
2021-03-16 12:24:35 -04:00
|
|
|
if (appSettings.useBrowserEthereumExplorer !== Constants.browserEthereumExplorerNone && text.startsWith("0x")) {
|
|
|
|
switch (appSettings.useBrowserEthereumExplorer) {
|
2021-01-04 16:32:36 -05:00
|
|
|
case Constants.browserEthereumExplorerEtherscan:
|
|
|
|
if (text.length > 42) {
|
|
|
|
currentWebView.url = "https://etherscan.io/tx/" + text; break;
|
|
|
|
} else {
|
|
|
|
currentWebView.url = "https://etherscan.io/address/" + text; break;
|
|
|
|
}
|
|
|
|
case Constants.browserEthereumExplorerEthplorer:
|
|
|
|
if (text.length > 42) {
|
|
|
|
currentWebView.url = "https://ethplorer.io/tx/" + text; break;
|
|
|
|
} else {
|
|
|
|
currentWebView.url = "https://ethplorer.io/address/" + text; break;
|
|
|
|
}
|
|
|
|
case Constants.browserEthereumExplorerBlockchair:
|
|
|
|
if (text.length > 42) {
|
|
|
|
currentWebView.url = "https://blockchair.com/ethereum/transaction/" + text; break;
|
|
|
|
} else {
|
|
|
|
currentWebView.url = "https://blockchair.com/ethereum/address/" + text; break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
2021-04-19 13:34:03 +03:00
|
|
|
if (appSettings.shouldShowBrowserSearchEngine !== Constants.browserSearchEngineNone && !Utils.isURL(text) && !Utils.isURLWithOptionalProtocol(text)) {
|
2021-03-16 12:24:35 -04:00
|
|
|
switch (appSettings.shouldShowBrowserSearchEngine) {
|
2021-01-04 16:13:41 -05:00
|
|
|
case Constants.browserSearchEngineGoogle: currentWebView.url = "https://www.google.com/search?q=" + text; break;
|
|
|
|
case Constants.browserSearchEngineYahoo: currentWebView.url = "https://search.yahoo.com/search?p=" + text; break;
|
|
|
|
case Constants.browserSearchEngineDuckDuckGo: currentWebView.url = "https://duckduckgo.com/?q=" + text; break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return
|
2021-04-19 13:34:03 +03:00
|
|
|
} else if (Utils.isURLWithOptionalProtocol(text)) {
|
|
|
|
text = "https://" + text
|
2021-01-04 16:13:41 -05:00
|
|
|
}
|
|
|
|
|
2020-10-07 16:14:55 -04:00
|
|
|
currentWebView.url = determineRealURL(text);
|
|
|
|
}
|
|
|
|
}
|
2020-10-08 11:31:53 -04:00
|
|
|
|
|
|
|
StatusIconButton {
|
2020-10-29 15:02:32 -04:00
|
|
|
id: addFavoriteBtn
|
|
|
|
visible: !!currentWebView && !!currentWebView.url
|
2021-09-30 11:43:29 +02:00
|
|
|
icon.name: !!browserHeader.currentFavorite ? "browser/favoriteActive" : "browser/favorite"
|
2020-10-29 15:02:32 -04:00
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.right: reloadBtn.left
|
|
|
|
anchors.rightMargin: Style.current.halfPadding
|
2021-09-30 11:43:29 +02:00
|
|
|
onClicked: addNewFavoritelClicked(addFavoriteBtn.x)
|
2020-10-29 15:02:32 -04:00
|
|
|
width: 24
|
|
|
|
height: 24
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusIconButton {
|
|
|
|
id: reloadBtn
|
2020-10-08 11:31:53 -04:00
|
|
|
icon.name: currentWebView && currentWebView.loading ? "close" : "browser/refresh"
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: Style.current.halfPadding
|
|
|
|
onClicked: currentWebView && currentWebView.loading ? currentWebView.stop() : currentWebView.reload()
|
|
|
|
width: 24
|
|
|
|
height: 24
|
|
|
|
}
|
2020-10-07 16:14:55 -04:00
|
|
|
}
|
|
|
|
|
2020-10-15 13:05:34 -04:00
|
|
|
BrowserWalletMenu {
|
|
|
|
id: browserWalletMenu
|
2021-09-30 11:43:29 +02:00
|
|
|
y: browserHeader.height + browserHeader.anchors.topMargin
|
2020-10-15 13:05:34 -04:00
|
|
|
x: parent.width - width - Style.current.halfPadding
|
|
|
|
}
|
|
|
|
|
2020-10-19 16:26:16 -04:00
|
|
|
Loader {
|
|
|
|
active: true
|
|
|
|
sourceComponent: currentTabConnected ? connectedBtnComponent : notConnectedBtnCompoent
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: notConnectedBtnCompoent
|
|
|
|
StatusIconButton {
|
|
|
|
id: accountBtn
|
|
|
|
icon.name: "walletIcon"
|
|
|
|
onClicked: {
|
|
|
|
if (browserWalletMenu.opened) {
|
|
|
|
browserWalletMenu.close()
|
|
|
|
} else {
|
|
|
|
browserWalletMenu.open()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
width: 24
|
|
|
|
height: 24
|
|
|
|
padding: 6
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: connectedBtnComponent
|
|
|
|
StatusButton {
|
|
|
|
id: accountBtnConnected
|
2021-09-28 18:04:06 +03:00
|
|
|
icon.source: Style.svg("walletIcon")
|
2020-10-19 16:26:16 -04:00
|
|
|
icon.width: 18
|
|
|
|
icon.height: 18
|
2021-09-30 11:43:29 +02:00
|
|
|
icon.color: dappBrowserAccIcon
|
|
|
|
text: dappBrowserAccName
|
2020-10-19 16:26:16 -04:00
|
|
|
implicitHeight: 32
|
|
|
|
type: "secondary"
|
|
|
|
onClicked: {
|
|
|
|
if (browserWalletMenu.opened) {
|
|
|
|
browserWalletMenu.close()
|
|
|
|
} else {
|
|
|
|
browserWalletMenu.open()
|
|
|
|
}
|
2020-10-15 13:05:34 -04:00
|
|
|
}
|
|
|
|
}
|
2020-10-07 16:14:55 -04:00
|
|
|
}
|
|
|
|
|
2020-10-09 13:56:42 -04:00
|
|
|
BrowserSettingsMenu {
|
|
|
|
id: settingsMenu
|
2021-09-30 11:43:29 +02:00
|
|
|
addNewTab: browserHeader.addNewTab
|
2020-10-09 13:56:42 -04:00
|
|
|
x: parent.width - width
|
|
|
|
y: parent.height
|
|
|
|
}
|
|
|
|
|
2020-10-08 11:31:53 -04:00
|
|
|
StatusIconButton {
|
2020-10-07 16:14:55 -04:00
|
|
|
id: settingsMenuButton
|
2020-10-08 11:31:53 -04:00
|
|
|
icon.name: "dots-icon"
|
2020-10-09 13:56:42 -04:00
|
|
|
onClicked: {
|
|
|
|
if (settingsMenu.opened) {
|
|
|
|
settingsMenu.close()
|
|
|
|
} else {
|
|
|
|
settingsMenu.open()
|
|
|
|
}
|
|
|
|
}
|
2020-10-08 11:31:53 -04:00
|
|
|
width: 24
|
|
|
|
height: 24
|
2021-09-30 11:43:29 +02:00
|
|
|
Layout.rightMargin: browserHeader.innerMargin
|
2020-10-08 11:31:53 -04:00
|
|
|
padding: 6
|
2020-10-07 16:14:55 -04:00
|
|
|
}
|
|
|
|
}
|
2020-12-29 12:10:22 -05:00
|
|
|
|
|
|
|
Loader {
|
|
|
|
id: favoritesBarLoader
|
2021-03-16 12:13:25 -04:00
|
|
|
active: appSettings.shouldShowFavoritesBar
|
2020-12-29 12:10:22 -05:00
|
|
|
height: active ? item.height : 0
|
|
|
|
anchors.top: barRow.bottom
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: Style.current.smallPadding
|
|
|
|
}
|
2020-10-07 16:14:55 -04:00
|
|
|
}
|