mirror of
https://github.com/nextcloud/desktop.git
synced 2024-12-22 05:34:33 +03:00
14cbd836ab
Qt Quick Controls 1 where deprecated with Qt 5.11 [1]. Nextcloud still depends on Quick Controls 1 by importing QtQuick.Dialogs. Removing those imports will cause the QMl script to use the according API from Quick Controls 2, which are, fortunately largely API-comptible. This helps distribution to deprecate and remove Quick Controls 1 [2]. 1: https://doc.qt.io/qt-6/qtquickcontrols-changes-qt6.html#migrating-from-qt-quick-controls-1 2: https://bugs.gentoo.org/889772 Signed-off-by: Florian Schmaus <flo@geekplace.eu>
104 lines
3.4 KiB
QML
104 lines
3.4 KiB
QML
/*
|
|
* Copyright (C) by Claudio Cambra <claudio.cambra@nextcloud.com>
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
import QtQuick 2.15
|
|
import QtQuick.Layouts 1.15
|
|
import QtQuick.Controls 2.15
|
|
import QtGraphicalEffects 1.0
|
|
|
|
import Style 1.0
|
|
import "./tray"
|
|
|
|
ComboBox {
|
|
id: clearComboBox
|
|
|
|
topPadding: Style.smallSpacing + topInset
|
|
leftPadding: Style.smallSpacing + leftInset
|
|
rightPadding: Style.smallSpacing + rightInset
|
|
bottomPadding: Style.smallSpacing + bottomInset
|
|
|
|
background: Rectangle {
|
|
radius: Style.slightlyRoundedButtonRadius
|
|
color: Style.buttonBackgroundColor
|
|
opacity: clearComboBox.hovered ? Style.hoverOpacity : 1.0
|
|
}
|
|
|
|
contentItem: EnforcedPlainTextLabel {
|
|
leftPadding: clearComboBox.leftPadding
|
|
rightPadding: clearComboBox.indicator.width + clearComboBox.spacing
|
|
|
|
text: clearComboBox.displayText
|
|
color: Style.ncTextColor
|
|
verticalAlignment: Text.AlignVCenter
|
|
elide: Text.ElideRight
|
|
}
|
|
|
|
indicator: ColorOverlay {
|
|
anchors.right: clearComboBox.right
|
|
anchors.rightMargin: clearComboBox.rightPadding
|
|
anchors.verticalCenter: clearComboBox.verticalCenter
|
|
|
|
cached: true
|
|
color: Style.ncTextColor
|
|
width: source.width
|
|
height: source.height
|
|
source: Image {
|
|
horizontalAlignment: Qt.AlignRight
|
|
verticalAlignment: Qt.AlignVCenter
|
|
source: "qrc:///client/theme/white/caret-down.svg"
|
|
sourceSize.width: Style.accountDropDownCaretSize
|
|
sourceSize.height: Style.accountDropDownCaretSize
|
|
Accessible.role: Accessible.PopupMenu
|
|
Accessible.name: qsTr("Clear status message menu")
|
|
}
|
|
}
|
|
|
|
popup: Popup {
|
|
y: clearComboBox.height - Style.normalBorderWidth
|
|
width: clearComboBox.width
|
|
implicitHeight: contentItem.implicitHeight
|
|
padding: Style.normalBorderWidth
|
|
|
|
contentItem: ListView {
|
|
clip: true
|
|
implicitHeight: contentHeight
|
|
model: clearComboBox.popup.visible ? clearComboBox.delegateModel : null
|
|
currentIndex: clearComboBox.highlightedIndex
|
|
|
|
ScrollIndicator.vertical: ScrollIndicator { }
|
|
}
|
|
|
|
background: Rectangle {
|
|
color: Style.backgroundColor
|
|
border.color: Style.menuBorder
|
|
radius: Style.slightlyRoundedButtonRadius
|
|
}
|
|
}
|
|
|
|
|
|
delegate: ItemDelegate {
|
|
id: clearStatusDelegate
|
|
width: clearComboBox.width
|
|
contentItem: EnforcedPlainTextLabel {
|
|
text: modelData.display
|
|
color: Style.ncTextColor
|
|
elide: Text.ElideRight
|
|
verticalAlignment: Text.AlignVCenter
|
|
}
|
|
highlighted: clearComboBox.highlightedIndex === index
|
|
background: Rectangle {
|
|
color: clearStatusDelegate.highlighted || clearStatusDelegate.hovered ? Style.lightHover : Style.backgroundColor
|
|
}
|
|
}
|
|
}
|