/* * Copyright 2014 Sebastian Kügler * SPDX-FileCopyrightText: (C) 2020 Carl Schwan * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ import QtQuick 2.12 import QtQuick.Layouts 1.12 import org.kde.plasma.core as PlasmaCore import org.kde.kirigami as Kirigami import org.kde.plasma.components 3.0 as PlasmaComponents import org.kde.plasma.extras as PlasmaExtras import org.kde.coreaddons 1.0 as KCoreAddons // While using Kirigami in applets is normally a no, we // use Avatar, which doesn't need to read the colour scheme // at all to function, so there won't be any oddities with colours. import org.kde.kirigami 2.20 as Kirigami import org.kde.kirigamiaddons.components as KirigamiAddons import org.kde.kquickcontrolsaddons 2.0 import Qt5Compat.GraphicalEffects 1.0 PlasmaExtras.PlasmoidHeading { id: header implicitHeight: Kirigami.Units.gridUnit * 5 property alias query: queryField.text property Item input: queryField KCoreAddons.KUser { id: kuser } state: "name" states: [ State { name: "name" PropertyChanges { target: nameLabel opacity: 1 } PropertyChanges { target: infoLabel opacity: 0 } }, State { name: "info" PropertyChanges { target: nameLabel opacity: 0 } PropertyChanges { target: infoLabel opacity: 1 } } ] // states RowLayout { anchors.fill: parent PlasmaComponents.RoundButton { visible: KCMShell.authorize("kcm_users.desktop").length > 0 flat: true Layout.preferredWidth: Kirigami.Units.gridUnit * 3 Layout.preferredHeight: Kirigami.Units.gridUnit * 3 KirigamiAddons.Avatar { source: kuser.faceIconUrl name: nameLabel anchors { fill: parent margins: Kirigami.Units.smallSpacing } } onClicked: { KCMShell.openSystemSettings("kcm_users") } } ColumnLayout { Layout.fillWidth: true Layout.rightMargin: Kirigami.Units.gridUnit Item { Layout.fillWidth: true Layout.preferredHeight: Kirigami.Units.gridUnit Kirigami.Heading { id: nameLabel anchors.fill: parent level: 2 text: kuser.fullName elide: Text.ElideRight horizontalAlignment: Text.AlignLeft verticalAlignment: Text.AlignBottom Behavior on opacity { NumberAnimation { duration: Kirigami.Units.longDuration; easing.type: Easing.InOutQuad; } } // Show the info instead of the user's name when hovering over it MouseArea { anchors.fill: nameLabel hoverEnabled: true onEntered: { header.state = "info" } onExited: { header.state = "name" } } } Kirigami.Heading { id: infoLabel anchors.fill: parent level: 5 opacity: 0 text: kuser.os !== "" ? i18n("%2@%3 (%1)", kuser.os, kuser.loginName, kuser.host) : i18n("%1@%2", kuser.loginName, kuser.host) elide: Text.ElideRight horizontalAlignment: Text.AlignLeft verticalAlignment: Text.AlignBottom Behavior on opacity { NumberAnimation { duration: Kirigami.Units.longDuration; easing.type: Easing.InOutQuad; } } } } PlasmaComponents.TextField { id: queryField Layout.fillWidth: true placeholderText: i18n("Search...") clearButtonShown: true onTextChanged: { if (root.state != "Search") { root.previousState = root.state; root.state = "Search"; } if (text == "") { root.state = root.previousState; } } } } } }