diff --git a/components/RadioButton.qml b/components/RadioButton.qml new file mode 100644 index 00000000..dbf8e865 --- /dev/null +++ b/components/RadioButton.qml @@ -0,0 +1,98 @@ +// Copyright (c) 2014-2018, The Monero Project +// +// All rights reserved. +// +// Redistribution and use in source and binary forms, with or without modification, are +// permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, this list of +// conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright notice, this list +// of conditions and the following disclaimer in the documentation and/or other +// materials provided with the distribution. +// +// 3. Neither the name of the copyright holder nor the names of its contributors may be +// used to endorse or promote products derived from this software without specific +// prior written permission. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY +// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL +// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, +// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, +// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF +// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +import QtQuick 2.0 +import QtQuick.Layouts 1.1 + +import "../components" as MoneroComponents + +RowLayout { + id: radioButton + property alias text: label.text + property bool checked: false + property int fontSize: 14 * scaleRatio + property alias fontColor: label.color + signal clicked() + height: 26 * scaleRatio + + function toggle(){ + radioButton.checked = !radioButton.checked + radioButton.clicked() + } + + RowLayout { + Layout.fillWidth: true + Rectangle { + id: button + anchors.left: parent.left + y: 0 + color: "transparent" + border.color: radioButton.checked ? Qt.rgba(1, 1, 1, 0.35) : Qt.rgba(1, 1, 1, 0.25) + width: radioButton.height + height: radioButton.height + radius: radioButton.height + + Rectangle { + visible: radioButton.checked + anchors.horizontalCenter: parent.horizontalCenter + anchors.verticalCenter: parent.verticalCenter + color: "white" + width: 10 * scaleRatio + height: 10 * scaleRatio + radius: 10 + opacity: 0.8 + } + + MouseArea { + anchors.fill: parent + cursorShape: Qt.PointingHandCursor + onClicked: { + toggle() + } + } + } + + Text { + id: label + anchors.left: button.right + anchors.leftMargin: !isMobile ? 10 : 8 + color: MoneroComponents.Style.defaultFontColor + font.family: MoneroComponents.Style.fontRegular.name + font.pixelSize: radioButton.fontSize + wrapMode: Text.Wrap + + MouseArea { + anchors.fill: parent + cursorShape: Qt.PointingHandCursor + onClicked: { + toggle() + } + } + } + } +} diff --git a/pages/Settings.qml b/pages/Settings.qml index 0b27c898..50fd0c85 100644 --- a/pages/Settings.qml +++ b/pages/Settings.qml @@ -209,7 +209,7 @@ Rectangle { } ColumnLayout { - CheckBox { + RadioButton { id: remoteDisconnect checked: !persistentSettings.useRemoteNode text: qsTr("Local Node") + translationManager.emptyString @@ -220,7 +220,7 @@ Rectangle { } } - CheckBox { + RadioButton { id: remoteConnect checked: persistentSettings.useRemoteNode text: qsTr("Remote Node") + translationManager.emptyString diff --git a/qml.qrc b/qml.qrc index a396747f..1e730ff3 100644 --- a/qml.qrc +++ b/qml.qrc @@ -207,5 +207,6 @@ images/rightArrowInactive.png js/Windows.js js/Utils.js + components/RadioButton.qml