mirror of
https://invent.kde.org/marcoa/shift-shell.git
synced 2026-04-26 14:23:09 +00:00
homescreens/halcyon: Add folder text editing
This commit is contained in:
parent
c3fd538dd5
commit
88417b3e0a
3 changed files with 79 additions and 22 deletions
|
|
@ -21,7 +21,7 @@
|
||||||
class ApplicationFolder : public QObject
|
class ApplicationFolder : public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY(QString name READ name NOTIFY nameChanged)
|
Q_PROPERTY(QString name READ name WRITE setName NOTIFY nameChanged)
|
||||||
Q_PROPERTY(QList<Application *> appPreviews READ appPreviews NOTIFY applicationsChanged)
|
Q_PROPERTY(QList<Application *> appPreviews READ appPreviews NOTIFY applicationsChanged)
|
||||||
Q_PROPERTY(QList<Application *> applications READ applications NOTIFY applicationsChanged)
|
Q_PROPERTY(QList<Application *> applications READ applications NOTIFY applicationsChanged)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -170,6 +170,7 @@ Item {
|
||||||
PlasmaComponents.Label {
|
PlasmaComponents.Label {
|
||||||
id: label
|
id: label
|
||||||
visible: text.length > 0
|
visible: text.length > 0
|
||||||
|
textFormat: Text.MarkdownText
|
||||||
|
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.leftMargin: PlasmaCore.Units.smallSpacing * 2
|
Layout.leftMargin: PlasmaCore.Units.smallSpacing * 2
|
||||||
|
|
|
||||||
|
|
@ -32,6 +32,8 @@ MobileShell.GridView {
|
||||||
signal openConfigureRequested()
|
signal openConfigureRequested()
|
||||||
signal closeRequested()
|
signal closeRequested()
|
||||||
|
|
||||||
|
property bool inFolderTitleEditMode: false
|
||||||
|
|
||||||
TapHandler {
|
TapHandler {
|
||||||
onLongPressed: root.openConfigureRequested()
|
onLongPressed: root.openConfigureRequested()
|
||||||
onTapped: root.closeRequested()
|
onTapped: root.closeRequested()
|
||||||
|
|
@ -51,10 +53,77 @@ MobileShell.GridView {
|
||||||
onTapped: root.closeRequested()
|
onTapped: root.closeRequested()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Component {
|
||||||
|
id: folderTitleEdit
|
||||||
|
|
||||||
|
TextEdit {
|
||||||
|
text: root.folderName
|
||||||
|
color: "white"
|
||||||
|
selectByMouse: true
|
||||||
|
wrapMode: TextEdit.Wrap
|
||||||
|
|
||||||
|
Component.onCompleted: forceActiveFocus()
|
||||||
|
|
||||||
|
font.weight: Font.Bold
|
||||||
|
font.pointSize: 18
|
||||||
|
layer.enabled: true
|
||||||
|
layer.effect: DropShadow {
|
||||||
|
verticalOffset: 1
|
||||||
|
radius: 4
|
||||||
|
samples: 6
|
||||||
|
color: Qt.rgba(0, 0, 0, 0.5)
|
||||||
|
}
|
||||||
|
|
||||||
|
onTextChanged: {
|
||||||
|
if (text.includes('\n')) {
|
||||||
|
// exit text edit mode when new line is entered
|
||||||
|
root.inFolderTitleEditMode = false;
|
||||||
|
} else {
|
||||||
|
root.folder.name = text;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
onEditingFinished: root.inFolderTitleEditMode = false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Component {
|
||||||
|
id: folderTitleLabel
|
||||||
|
|
||||||
|
QQC2.Label {
|
||||||
|
text: root.folderName
|
||||||
|
color: "white"
|
||||||
|
style: Text.Normal
|
||||||
|
styleColor: "transparent"
|
||||||
|
horizontalAlignment: Text.AlignLeft
|
||||||
|
textFormat: Text.MarkdownText
|
||||||
|
|
||||||
|
elide: Text.ElideRight
|
||||||
|
wrapMode: Text.Wrap
|
||||||
|
maximumLineCount: 2
|
||||||
|
|
||||||
|
font.weight: Font.Bold
|
||||||
|
font.pointSize: 18
|
||||||
|
layer.enabled: true
|
||||||
|
layer.effect: DropShadow {
|
||||||
|
verticalOffset: 1
|
||||||
|
radius: 4
|
||||||
|
samples: 6
|
||||||
|
color: Qt.rgba(0, 0, 0, 0.5)
|
||||||
|
}
|
||||||
|
|
||||||
|
MouseArea {
|
||||||
|
anchors.fill: parent
|
||||||
|
onClicked: root.inFolderTitleEditMode = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
contentItem: RowLayout {
|
contentItem: RowLayout {
|
||||||
|
id: rowLayout
|
||||||
spacing: PlasmaCore.Units.smallSpacing * 2
|
spacing: PlasmaCore.Units.smallSpacing * 2
|
||||||
|
|
||||||
// close button
|
// close folder button
|
||||||
MouseArea {
|
MouseArea {
|
||||||
id: button
|
id: button
|
||||||
Layout.alignment: Qt.AlignVCenter
|
Layout.alignment: Qt.AlignVCenter
|
||||||
|
|
@ -64,12 +133,14 @@ MobileShell.GridView {
|
||||||
cursorShape: Qt.PointingHandCursor
|
cursorShape: Qt.PointingHandCursor
|
||||||
onClicked: root.closeRequested()
|
onClicked: root.closeRequested()
|
||||||
|
|
||||||
|
// button background
|
||||||
Rectangle {
|
Rectangle {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
color: Qt.rgba(255, 255, 255, button.pressed ? 0.2 : 0)
|
color: Qt.rgba(255, 255, 255, button.pressed ? 0.2 : 0)
|
||||||
radius: button.width / 2
|
radius: button.width / 2
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// button icon
|
||||||
Kirigami.Icon {
|
Kirigami.Icon {
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
implicitHeight: PlasmaCore.Units.iconSizes.small
|
implicitHeight: PlasmaCore.Units.iconSizes.small
|
||||||
|
|
@ -88,27 +159,12 @@ MobileShell.GridView {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
QQC2.Label {
|
// folder title
|
||||||
|
Loader {
|
||||||
|
Layout.alignment: Qt.AlignVCenter
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
text: root.folderName
|
Layout.maximumWidth: rowLayout.width - button.width - rowLayout.spacing
|
||||||
color: "white"
|
sourceComponent: root.inFolderTitleEditMode ? folderTitleEdit : folderTitleLabel
|
||||||
style: Text.Normal
|
|
||||||
styleColor: "transparent"
|
|
||||||
horizontalAlignment: Text.AlignLeft
|
|
||||||
|
|
||||||
elide: Text.ElideRight
|
|
||||||
wrapMode: Text.Wrap
|
|
||||||
maximumLineCount: 2
|
|
||||||
|
|
||||||
font.weight: Font.Bold
|
|
||||||
font.pointSize: 18
|
|
||||||
layer.enabled: true
|
|
||||||
layer.effect: DropShadow {
|
|
||||||
verticalOffset: 1
|
|
||||||
radius: 4
|
|
||||||
samples: 6
|
|
||||||
color: Qt.rgba(0, 0, 0, 0.5)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue