2020-09-29 10:37:08 +02:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Layouts 1.3
|
2021-09-28 18:04:06 +03:00
|
|
|
|
2022-07-20 17:54:30 +03:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
|
|
|
import shared.panels 1.0
|
2020-09-29 10:37:08 +02:00
|
|
|
|
|
|
|
Item {
|
2021-07-07 12:32:03 +03:00
|
|
|
id: emojiSection
|
2020-09-29 10:37:08 +02:00
|
|
|
property string searchString: ""
|
|
|
|
property string searchStringLowercase: searchString.toLowerCase()
|
|
|
|
property int imageWidth: 26
|
|
|
|
property int imageMargin: 4
|
|
|
|
property var emojis: []
|
|
|
|
property var allEmojis: modelData
|
|
|
|
property var addEmoji: function () {}
|
|
|
|
|
|
|
|
visible: emojis.length > 0 || !!(modelData && modelData.length && modelData[0].empty && searchString === "")
|
|
|
|
|
|
|
|
anchors.top: index === 0 ? parent.top : parent.children[index - 1].bottom
|
2022-04-12 15:47:23 +02:00
|
|
|
anchors.topMargin: 0
|
2020-09-29 10:37:08 +02:00
|
|
|
|
2022-09-01 12:09:59 +02:00
|
|
|
implicitHeight: visible ? childrenRect.height + Style.current.padding : 0
|
2020-09-29 10:37:08 +02:00
|
|
|
|
|
|
|
StyledText {
|
|
|
|
id: categoryText
|
|
|
|
text: modelData && modelData.length ? modelData[0].category.toUpperCase() : ""
|
2021-03-26 17:33:23 -04:00
|
|
|
color: Style.current.secondaryText
|
2020-09-29 10:37:08 +02:00
|
|
|
font.pixelSize: 13
|
|
|
|
}
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
id: noRecentText
|
|
|
|
visible: !!(allEmojis && allEmojis.length && allEmojis[0].empty)
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("No recent emojis")
|
2021-03-26 17:33:23 -04:00
|
|
|
color: Style.current.secondaryText
|
2020-09-29 10:37:08 +02:00
|
|
|
font.pixelSize: 10
|
|
|
|
anchors.top: categoryText.bottom
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
|
|
|
}
|
|
|
|
|
|
|
|
onSearchStringLowercaseChanged: {
|
|
|
|
if (emojiSection.searchStringLowercase === "") {
|
2020-11-19 15:45:18 -05:00
|
|
|
this.emojis = allEmojis
|
2020-09-29 10:37:08 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
this.emojis = modelData.filter(function (emoji) {
|
2020-11-19 15:45:18 -05:00
|
|
|
if (emoji.empty) {
|
|
|
|
return false
|
|
|
|
}
|
2020-09-29 10:37:08 +02:00
|
|
|
return emoji.name.includes(emojiSection.searchStringLowercase) ||
|
|
|
|
emoji.shortname.includes(emojiSection.searchStringLowercase) ||
|
|
|
|
emoji.aliases.some(a => a.includes(emojiSection.searchStringLowercase))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
onAllEmojisChanged: {
|
2021-07-07 12:32:03 +03:00
|
|
|
if (!!emojiSection.allEmojis[0] && this.allEmojis[0].empty) {
|
2020-09-29 10:37:08 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
this.emojis = this.allEmojis
|
|
|
|
}
|
|
|
|
|
2022-07-20 17:54:30 +03:00
|
|
|
StatusGridView {
|
2020-09-29 10:37:08 +02:00
|
|
|
id: emojiGrid
|
|
|
|
anchors.top: categoryText.bottom
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
|
|
|
width: parent.width
|
|
|
|
height: childrenRect.height
|
|
|
|
visible: count > 0
|
|
|
|
cellWidth: emojiSection.imageWidth + emojiSection.imageMargin * 2
|
|
|
|
cellHeight: emojiSection.imageWidth + emojiSection.imageMargin * 2
|
|
|
|
model: emojiSection.emojis
|
|
|
|
focus: true
|
|
|
|
interactive: false
|
|
|
|
|
|
|
|
delegate: Item {
|
|
|
|
id: emojiContainer
|
|
|
|
width: emojiGrid.cellWidth
|
|
|
|
height: emojiGrid.cellHeight
|
|
|
|
|
|
|
|
Column {
|
|
|
|
anchors.fill: parent
|
|
|
|
anchors.topMargin: emojiSection.imageMargin
|
|
|
|
anchors.leftMargin: emojiSection.imageMargin
|
|
|
|
|
2022-05-23 14:35:51 +03:00
|
|
|
StatusEmoji {
|
2022-08-15 13:43:38 +02:00
|
|
|
objectName: "statusEmoji_" + modelData.shortname.replace(/:/g, "")
|
|
|
|
|
2020-09-29 10:37:08 +02:00
|
|
|
width: emojiSection.imageWidth
|
|
|
|
height: emojiSection.imageWidth
|
2022-05-23 14:35:51 +03:00
|
|
|
emojiId: modelData.filename
|
2020-09-29 10:37:08 +02:00
|
|
|
|
|
|
|
MouseArea {
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
anchors.fill: parent
|
|
|
|
onClicked: {
|
|
|
|
emojiSection.addEmoji(modelData)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/*##^##
|
|
|
|
Designer {
|
|
|
|
D{i:0;formeditorColor:"#ffffff";height:440;width:360}
|
|
|
|
}
|
|
|
|
##^##*/
|