
* add focusController class * add more key handlers * add focus navigation to qml * fixed language selector * add reverse focus change to FocusController * add default focus item * update transitions * update pages * add ListViewFocusController * fix ListView navigation * update CardType for using with focus navigation * remove useless key navigation * remove useless slots, logs, Drawer open and close * fix reverse focus move on listView * fix drawer radio buttons selection * fix drawer layout and focus move * fix PageSetupWizardProtocolSettings focus move * fix back navigation on default focus item * fix crashes after ListView navigation * fix protocol settings focus move * fix focus on users on page share * clean up page share * fix server rename * fix page share default server selection * refactor about page for correct focus move * fix focus move on list views with header and-or footer * minor fixes * fix server list back button handler * fix spawn signals on switch * fix share details drawer * fix drawer open close usage * refactor listViewFocusController * refactor focusController to make the logic more straightforward * fix focus on notification * update config page for scrolling with tab * fix crash on return with esc key * fix focus navigation in dynamic delegate of list view * fix focus move on qr code on share page * refactor page logging settings for focus navigation * update popup * Bump version * Add mandatory requirement for android.software.leanback. * Fix importing files on TVs * fix: add separate method for reading files to fix file reading on Android TV * fix(android): add CHANGE_NETWORK_STATE permission for all Android versions * Fix connection check for AWG/WG * chore: minor fixes (#1235) * fix: add a workaround to open files on Android TV due to lack of SAF * fix: change the banner format for TV * refactor: make TvFilePicker activity more sustainable * fix: add the touch emulation method for Android TV * fix: null uri processing * fix: add the touch emulation method for Android TV * fix: hide UI elements that use file saving * chore: bump version code * add `ScrollBarType` * update initial config page * refactor credentials setup page to handle the focus navigation * add `setDelegateIndex` method to `listViewFocusController` * fix focus behavior on new page/popup * make minor fixes and clean up * fix: get rid of the assign function call * Scrollbar is on if the content is larger than a screen * Fix selection in language change list * Update select language list * update logging settings page * fix checked item in lists * fix split tunneling settings * make unchangable properties readonly * refactor SwitcherType * fix hide/unhide password * `PageShare` readonly properties * Fix list view focus moving on `PageShare` * remove manual focus control on `PageShare` * format `ListViewFocusController` * format `FocusController` * add `focusControl` with utility functions for focus control * refactor `listViewFocusController` acoording to `focusControl` * refactor `focusConroller` according to `focusControl` * add `printSectionName` method to `listViewController` * remove arrow from `Close application` item * fix focus movement in `ServersListView` * `Restore from backup` is visible only on start screen * `I have nothing` is visible only on start screen * fix back button on `SelectLanguageDrawer` * rename `focusControl` to `qmlUtils` * fix `CMakeLists.txt` * fix `ScrollBarType` * fix `PageSetupWizardApiServicesList` * fix focus movement on dynamic delegates in listView * refactor `PageSetupWizardProtocols` * remove comments and clean up * fix `ListViewWithLabelsType` * fix `PageProtocolCloakSettings` * fix `PageSettingsAppSplitTunneling` * fix `PageDevMenu` * remove debug output from `FocusController` * remove debug output from `ListViewFocusController` * remove debug output from `focusControl` * `focusControl` => `FocusControl` --------- Co-authored-by: albexk <albexk@proton.me> Co-authored-by: Nethius <nethiuswork@gmail.com>
191 lines
5.5 KiB
QML
191 lines
5.5 KiB
QML
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Layouts
|
|
import QtQuick.Shapes
|
|
import Qt5Compat.GraphicalEffects
|
|
|
|
import ConnectionState 1.0
|
|
import PageEnum 1.0
|
|
import Style 1.0
|
|
|
|
Button {
|
|
id: root
|
|
|
|
property string defaultButtonColor: AmneziaStyle.color.paleGray
|
|
property string progressButtonColor: AmneziaStyle.color.paleGray
|
|
property string connectedButtonColor: AmneziaStyle.color.goldenApricot
|
|
property bool buttonActiveFocus: activeFocus && (Qt.platform.os !== "android" || SettingsController.isOnTv())
|
|
|
|
property bool isFocusable: true
|
|
|
|
Keys.onTabPressed: {
|
|
FocusController.nextKeyTabItem()
|
|
}
|
|
|
|
Keys.onBacktabPressed: {
|
|
FocusController.previousKeyTabItem()
|
|
}
|
|
|
|
Keys.onUpPressed: {
|
|
FocusController.nextKeyUpItem()
|
|
}
|
|
|
|
Keys.onDownPressed: {
|
|
FocusController.nextKeyDownItem()
|
|
}
|
|
|
|
Keys.onLeftPressed: {
|
|
FocusController.nextKeyLeftItem()
|
|
}
|
|
|
|
Keys.onRightPressed: {
|
|
FocusController.nextKeyRightItem()
|
|
}
|
|
|
|
implicitWidth: 190
|
|
implicitHeight: 190
|
|
|
|
text: ConnectionController.connectionStateText
|
|
|
|
Connections {
|
|
target: ConnectionController
|
|
|
|
function onPreparingConfig() {
|
|
PageController.showNotificationMessage(qsTr("Unable to disconnect during configuration preparation"))
|
|
}
|
|
}
|
|
|
|
// enabled: !ConnectionController.isConnectionInProgress
|
|
|
|
background: Item {
|
|
implicitWidth: parent.width
|
|
implicitHeight: parent.height
|
|
transformOrigin: Item.Center
|
|
|
|
Shape {
|
|
id: backgroundCircle
|
|
width: parent.implicitWidth
|
|
height: parent.implicitHeight
|
|
anchors.bottom: parent.bottom
|
|
anchors.right: parent.right
|
|
layer.enabled: true
|
|
layer.samples: 4
|
|
layer.smooth: true
|
|
layer.effect: DropShadow {
|
|
anchors.fill: backgroundCircle
|
|
horizontalOffset: 0
|
|
verticalOffset: 0
|
|
radius: 10
|
|
samples: 25
|
|
color: root.buttonActiveFocus ? AmneziaStyle.color.paleGray : AmneziaStyle.color.goldenApricot
|
|
source: backgroundCircle
|
|
}
|
|
|
|
ShapePath {
|
|
fillColor: AmneziaStyle.color.transparent
|
|
strokeColor: AmneziaStyle.color.paleGray
|
|
strokeWidth: root.buttonActiveFocus ? 1 : 0
|
|
capStyle: ShapePath.RoundCap
|
|
|
|
PathAngleArc {
|
|
centerX: backgroundCircle.width / 2
|
|
centerY: backgroundCircle.height / 2
|
|
radiusX: 94
|
|
radiusY: 94
|
|
startAngle: 0
|
|
sweepAngle: 360
|
|
}
|
|
}
|
|
|
|
ShapePath {
|
|
fillColor: AmneziaStyle.color.transparent
|
|
strokeColor: {
|
|
if (ConnectionController.isConnectionInProgress) {
|
|
return AmneziaStyle.color.darkCharcoal
|
|
} else if (ConnectionController.isConnected) {
|
|
return connectedButtonColor
|
|
} else {
|
|
return defaultButtonColor
|
|
}
|
|
}
|
|
strokeWidth: root.buttonActiveFocus ? 2 : 3
|
|
capStyle: ShapePath.RoundCap
|
|
|
|
PathAngleArc {
|
|
centerX: backgroundCircle.width / 2
|
|
centerY: backgroundCircle.height / 2
|
|
radiusX: 93 - (root.buttonActiveFocus ? 2 : 0)
|
|
radiusY: 93 - (root.buttonActiveFocus ? 2 : 0)
|
|
startAngle: 0
|
|
sweepAngle: 360
|
|
}
|
|
}
|
|
|
|
MouseArea {
|
|
anchors.fill: parent
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
enabled: false
|
|
}
|
|
}
|
|
|
|
Shape {
|
|
id: shape
|
|
width: parent.implicitWidth
|
|
height: parent.implicitHeight
|
|
anchors.bottom: parent.bottom
|
|
anchors.right: parent.right
|
|
layer.enabled: true
|
|
layer.samples: 4
|
|
|
|
visible: ConnectionController.isConnectionInProgress
|
|
|
|
ShapePath {
|
|
fillColor: AmneziaStyle.color.transparent
|
|
strokeColor: AmneziaStyle.color.paleGray
|
|
strokeWidth: 3
|
|
capStyle: ShapePath.RoundCap
|
|
|
|
PathAngleArc {
|
|
centerX: shape.width / 2
|
|
centerY: shape.height / 2
|
|
radiusX: 93
|
|
radiusY: 93
|
|
startAngle: 245
|
|
sweepAngle: -180
|
|
}
|
|
}
|
|
|
|
RotationAnimator {
|
|
target: shape
|
|
running: ConnectionController.isConnectionInProgress
|
|
from: 0
|
|
to: 360
|
|
loops: Animation.Infinite
|
|
duration: 1000
|
|
}
|
|
}
|
|
}
|
|
|
|
contentItem: Text {
|
|
height: 24
|
|
|
|
font.family: "PT Root UI VF"
|
|
font.weight: 700
|
|
font.pixelSize: 20
|
|
|
|
color: ConnectionController.isConnected ? connectedButtonColor : defaultButtonColor
|
|
text: root.text
|
|
|
|
horizontalAlignment: Text.AlignHCenter
|
|
verticalAlignment: Text.AlignVCenter
|
|
}
|
|
|
|
onClicked: {
|
|
ServersModel.setProcessedServerIndex(ServersModel.defaultIndex)
|
|
ConnectionController.connectButtonClicked()
|
|
}
|
|
|
|
Keys.onEnterPressed: this.clicked()
|
|
Keys.onReturnPressed: this.clicked()
|
|
}
|