status-desktop/ui/imports/shared/status/StatusChatInputImageArea.qml
Lukáš Tinkl d9d6d90dc9 [Style] remove legacy Style and its themes
- legacy Style and ThemePalette removed
- moved and deduplicated font definitions into `Theme` (unrelated to a
color palette)
- `Style.current.foo` -> `Theme.foo`
- `Style.current.fooColor` -> `Theme.palette.fooColor`
- upgrade the imports to 5.15
- removed some mode dead components

Fixes #16514
2024-10-22 15:54:31 +02:00

91 lines
2.6 KiB
QML

import QtQuick 2.15
import QtGraphicalEffects 1.15
import QtQuick.Controls 2.15
import StatusQ.Core.Theme 0.1
import utils 1.0
import shared 1.0
import shared.controls.chat 1.0
import shared.panels 1.0
Row {
id: imageArea
spacing: Theme.halfPadding
signal imageRemoved(int index)
signal imageClicked(var chatImage)
property bool leftTail: true
property alias imageSource: rptImages.model
Repeater {
id: rptImages
Item {
height: chatImage.height
width: chatImage.width
Image {
id: chatImage
anchors.left: parent.left
anchors.bottom: parent.bottom
width: 64
height: 64
fillMode: Image.PreserveAspectCrop
mipmap: true
smooth: false
antialiasing: true
cache: false
source: modelData
layer.enabled: true
layer.effect: CalloutOpacityMask {
width: parent.width
height: parent.height
leftTail: imageArea.leftTail
}
}
MouseArea {
id: mouseArea
anchors.fill: parent
cursorShape: Qt.PointingHandCursor
hoverEnabled: true
onClicked: imageClicked(chatImage)
}
RoundButton {
id: closeBtn
width: 24
height: 24
padding: 0
anchors.right: chatImage.right
anchors.rightMargin: -width / 3
anchors.top: chatImage.top
anchors.topMargin: -height / 3
hoverEnabled: false
opacity: mouseArea.containsMouse || buttonMouseArea.containsMouse ? 1 : 0
contentItem: SVGImage {
source: Theme.svg( !buttonMouseArea.containsMouse ? "close-filled" : "close-filled-hovered")
width: closeBtn.width
height: closeBtn.height
}
background: Rectangle {
color: "transparent"
}
onClicked: {
imageArea.imageRemoved(index)
}
MouseArea {
id: buttonMouseArea
anchors.fill: parent
cursorShape: Qt.PointingHandCursor
hoverEnabled: true
onClicked: closeBtn.clicked()
}
}
}
}
}