/* SPDX-FileCopyrightText: 2016 David Edmundson SPDX-License-Identifier: LGPL-2.0-or-later */ import QtQuick 2.2 import QtQuick.Layouts 1.1 import QtQuick.Controls 1.1 import org.kde.plasma.core 2.0 as PlasmaCore import org.kde.plasma.components 3.0 as PlasmaComponents3 import "../components" SessionManagementScreen { property Item mainPasswordBox: passwordBox property bool lockScreenUiVisible: false //the y position that should be ensured visible when the on screen keyboard is visible property int visibleBoundary: mapFromItem(loginButton, 0, 0).y onHeightChanged: visibleBoundary = mapFromItem(loginButton, 0, 0).y + loginButton.height + PlasmaCore.Units.smallSpacing /* * Login has been requested with the following username and password * If username field is visible, it will be taken from that, otherwise from the "name" property of the currentIndex */ signal loginRequest(string password) function startLogin() { const password = passwordBox.text // This is partly because it looks nicer, but more importantly it // works round a Qt bug that can trigger if the app is closed with a // TextField focused. // // See https://bugreports.qt.io/browse/QTBUG-55460 loginButton.forceActiveFocus(); loginRequest(password); } RowLayout { Layout.fillWidth: true PlasmaComponents3.TextField { id: passwordBox font.pointSize: PlasmaCore.Theme.defaultFont.pointSize + 1 Layout.fillWidth: true placeholderText: i18nd("plasma_lookandfeel_org.kde.lookandfeel", "Password") focus: true echoMode: TextInput.Password inputMethodHints: Qt.ImhHiddenText | Qt.ImhSensitiveData | Qt.ImhNoAutoUppercase | Qt.ImhNoPredictiveText enabled: !authenticator.graceLocked revealPasswordButtonShown: true // In Qt this is implicitly active based on focus rather than visibility // in any other application having a focussed invisible object would be weird // but here we are using to wake out of screensaver mode // We need to explicitly disable cursor flashing to avoid unnecessary renders cursorVisible: visible onAccepted: { if (lockScreenUiVisible) { startLogin(); } } //if empty and left or right is pressed change selection in user switch //this cannot be in keys.onLeftPressed as then it doesn't reach the password box Keys.onPressed: { if (event.key == Qt.Key_Left && !text) { userList.decrementCurrentIndex(); event.accepted = true } if (event.key == Qt.Key_Right && !text) { userList.incrementCurrentIndex(); event.accepted = true } } Connections { target: root function onClearPassword() { passwordBox.forceActiveFocus() passwordBox.text = ""; } } } PlasmaComponents3.Button { id: loginButton Accessible.name: i18nd("plasma_lookandfeel_org.kde.lookandfeel", "Unlock") Layout.preferredHeight: passwordBox.implicitHeight Layout.preferredWidth: loginButton.Layout.preferredHeight icon.name: LayoutMirroring.enabled ? "go-previous" : "go-next" onClicked: startLogin() } } }