mirror of
https://gitlab.com/kelteseth/ScreenPlay.git
synced 2024-11-25 12:13:00 +01:00
441 lines
10 KiB
QML
441 lines
10 KiB
QML
import QtQuick
|
|
import Qt5Compat.GraphicalEffects
|
|
import QtQuick.Controls
|
|
import QtQuick.Controls.Material
|
|
import ScreenPlayWorkshop
|
|
|
|
Item {
|
|
id: root
|
|
|
|
property url imgUrl
|
|
property url additionalPreviewUrl
|
|
property string name
|
|
property var publishedFileID: 0
|
|
property int itemIndex
|
|
property int subscriptionCount
|
|
property bool isDownloading: false
|
|
property SteamWorkshop steamWorkshop
|
|
|
|
signal clicked(var publishedFileID, url imgUrl)
|
|
|
|
width: 320
|
|
height: 180
|
|
transform: [
|
|
Rotation {
|
|
id: rt
|
|
|
|
origin.x: width * 0.5
|
|
origin.y: height * 0.5
|
|
angle: 0
|
|
|
|
axis {
|
|
x: -0.5
|
|
y: 0
|
|
z: 0
|
|
}
|
|
},
|
|
Translate {
|
|
id: tr
|
|
},
|
|
Scale {
|
|
id: sc
|
|
|
|
origin.x: width * 0.5
|
|
origin.y: height * 0.5
|
|
}
|
|
]
|
|
|
|
RectangularGlow {
|
|
id: effect
|
|
|
|
height: parent.height
|
|
width: parent.width
|
|
cached: true
|
|
glowRadius: 3
|
|
spread: 0.2
|
|
color: "black"
|
|
opacity: 0.4
|
|
cornerRadius: 15
|
|
|
|
anchors {
|
|
top: parent.top
|
|
topMargin: 3
|
|
}
|
|
}
|
|
|
|
Timer {
|
|
id: timerAnim
|
|
|
|
interval: 40 * itemIndex * Math.random()
|
|
running: true
|
|
repeat: false
|
|
onTriggered: showAnim.start()
|
|
}
|
|
|
|
ParallelAnimation {
|
|
id: showAnim
|
|
|
|
running: false
|
|
|
|
RotationAnimation {
|
|
target: rt
|
|
from: 90
|
|
to: 0
|
|
duration: 500
|
|
easing.type: Easing.OutQuint
|
|
property: "angle"
|
|
}
|
|
|
|
PropertyAnimation {
|
|
target: root
|
|
from: 0
|
|
to: 1
|
|
duration: 500
|
|
easing.type: Easing.OutQuint
|
|
property: "opacity"
|
|
}
|
|
|
|
PropertyAnimation {
|
|
target: tr
|
|
from: 80
|
|
to: 0
|
|
duration: 500
|
|
easing.type: Easing.OutQuint
|
|
property: "y"
|
|
}
|
|
|
|
PropertyAnimation {
|
|
target: sc
|
|
from: 0.8
|
|
to: 1
|
|
duration: 500
|
|
easing.type: Easing.OutQuint
|
|
properties: "xScale,yScale"
|
|
}
|
|
}
|
|
|
|
Item {
|
|
id: screenPlay
|
|
|
|
anchors.centerIn: parent
|
|
height: 180
|
|
width: 320
|
|
|
|
Image {
|
|
id: mask
|
|
|
|
//source: "qrc:/qml/ScreenPlayWorkshop/assets/images/Window.svg"
|
|
sourceSize: Qt.size(screenPlay.width, screenPlay.height)
|
|
visible: false
|
|
smooth: true
|
|
fillMode: Image.PreserveAspectFit
|
|
}
|
|
|
|
Item {
|
|
id: itemWrapper
|
|
|
|
visible: false
|
|
|
|
anchors {
|
|
fill: parent
|
|
margins: 5
|
|
}
|
|
|
|
ScreenPlayItemImage {
|
|
id: screenPlayItemImage
|
|
|
|
anchors.fill: parent
|
|
sourceImage: root.imgUrl
|
|
sourceImageGIF: root.additionalPreviewUrl
|
|
}
|
|
|
|
Rectangle {
|
|
id: shadow
|
|
|
|
height: 80
|
|
opacity: 0
|
|
|
|
anchors {
|
|
bottom: parent.bottom
|
|
right: parent.right
|
|
left: parent.left
|
|
}
|
|
|
|
gradient: Gradient {
|
|
GradientStop {
|
|
position: 1
|
|
color: "#CC000000"
|
|
}
|
|
|
|
GradientStop {
|
|
position: 0
|
|
color: "#00000000"
|
|
}
|
|
}
|
|
}
|
|
|
|
Text {
|
|
id: txtTitle
|
|
|
|
text: root.name
|
|
opacity: 0
|
|
height: 30
|
|
width: 180
|
|
verticalAlignment: Text.AlignVCenter
|
|
color: "white"
|
|
font.pointSize: 14
|
|
wrapMode: Text.WrapAtWordBoundaryOrAnywhere
|
|
|
|
anchors {
|
|
bottom: parent.bottom
|
|
right: parent.right
|
|
rightMargin: 20
|
|
left: parent.left
|
|
leftMargin: 20
|
|
bottomMargin: -50
|
|
}
|
|
}
|
|
|
|
Item {
|
|
id: openInWorkshop
|
|
|
|
height: 20
|
|
width: 20
|
|
z: 99
|
|
opacity: 0
|
|
|
|
anchors {
|
|
margins: 10
|
|
top: parent.top
|
|
right: parent.right
|
|
}
|
|
|
|
Image {
|
|
source: "qrc:/qml/ScreenPlayWorkshop/assets/icons/icon_open_in_new.svg"
|
|
sourceSize: Qt.size(parent.width, parent.height)
|
|
fillMode: Image.PreserveAspectFit
|
|
}
|
|
}
|
|
}
|
|
|
|
OpacityMask {
|
|
anchors.fill: itemWrapper
|
|
source: itemWrapper
|
|
maskSource: mask
|
|
|
|
MouseArea {
|
|
anchors.fill: parent
|
|
hoverEnabled: true
|
|
cursorShape: Qt.PointingHandCursor
|
|
onContainsMouseChanged: {
|
|
if (!isDownloading) {
|
|
if (containsMouse)
|
|
root.state = "hover";
|
|
else
|
|
root.state = "";
|
|
}
|
|
}
|
|
onClicked: {
|
|
root.clicked(root.publishedFileID, root.imgUrl);
|
|
}
|
|
}
|
|
|
|
MouseArea {
|
|
height: 20
|
|
width: 20
|
|
cursorShape: Qt.PointingHandCursor
|
|
onClicked: {
|
|
Qt.openUrlExternally("steam://url/CommunityFilePage/" + root.publishedFileID);
|
|
}
|
|
|
|
anchors {
|
|
margins: 10
|
|
top: parent.top
|
|
right: parent.right
|
|
}
|
|
}
|
|
}
|
|
|
|
FastBlur {
|
|
id: effBlur
|
|
|
|
anchors.fill: itemWrapper
|
|
source: itemWrapper
|
|
radius: 0
|
|
}
|
|
|
|
Item {
|
|
id: itmDownloading
|
|
|
|
opacity: 0
|
|
|
|
anchors {
|
|
top: parent.top
|
|
topMargin: 50
|
|
right: parent.right
|
|
bottom: parent.bottom
|
|
left: parent.left
|
|
}
|
|
|
|
Text {
|
|
id: txtDownloading
|
|
|
|
text: qsTr("Successfully subscribed to Workshop Item!")
|
|
color: "white"
|
|
font.pointSize: 18
|
|
wrapMode: Text.WordWrap
|
|
horizontalAlignment: Qt.AlignHCenter
|
|
|
|
anchors {
|
|
verticalCenter: parent.verticalCenter
|
|
right: parent.right
|
|
rightMargin: 20
|
|
left: parent.left
|
|
leftMargin: 20
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
states: [
|
|
State {
|
|
name: "hover"
|
|
|
|
PropertyChanges {
|
|
target: openInWorkshop
|
|
opacity: 0.75
|
|
}
|
|
|
|
PropertyChanges {
|
|
target: txtTitle
|
|
opacity: 1
|
|
anchors.bottomMargin: 20
|
|
}
|
|
|
|
PropertyChanges {
|
|
target: shadow
|
|
opacity: 1
|
|
}
|
|
|
|
PropertyChanges {
|
|
target: effBlur
|
|
radius: 0
|
|
}
|
|
},
|
|
State {
|
|
name: "downloading"
|
|
|
|
PropertyChanges {
|
|
target: openInWorkshop
|
|
opacity: 0
|
|
}
|
|
|
|
PropertyChanges {
|
|
target: txtTitle
|
|
opacity: 0
|
|
}
|
|
|
|
PropertyChanges {
|
|
target: shadow
|
|
opacity: 0
|
|
}
|
|
|
|
PropertyChanges {
|
|
target: effBlur
|
|
radius: 64
|
|
}
|
|
|
|
PropertyChanges {
|
|
target: itmDownloading
|
|
opacity: 1
|
|
anchors.topMargin: 0
|
|
}
|
|
},
|
|
State {
|
|
name: "installed"
|
|
|
|
PropertyChanges {
|
|
target: txtTitle
|
|
opacity: 0
|
|
}
|
|
|
|
PropertyChanges {
|
|
target: shadow
|
|
opacity: 0
|
|
}
|
|
|
|
PropertyChanges {
|
|
target: effBlur
|
|
radius: 64
|
|
}
|
|
|
|
PropertyChanges {
|
|
target: itmDownloading
|
|
opacity: 1
|
|
anchors.topMargin: 0
|
|
}
|
|
|
|
PropertyChanges {
|
|
target: txtDownloading
|
|
text: qsTr("Download complete!")
|
|
}
|
|
}
|
|
]
|
|
transitions: [
|
|
Transition {
|
|
from: ""
|
|
to: "hover"
|
|
reversible: true
|
|
|
|
PropertyAnimation {
|
|
target: openInWorkshop
|
|
duration: 100
|
|
properties: "opacity"
|
|
}
|
|
|
|
PropertyAnimation {
|
|
target: txtTitle
|
|
duration: 100
|
|
properties: "opacity, anchors.bottomMargin"
|
|
}
|
|
|
|
PropertyAnimation {
|
|
target: shadow
|
|
duration: 100
|
|
properties: "opacity"
|
|
}
|
|
},
|
|
Transition {
|
|
from: "*"
|
|
to: "downloading"
|
|
reversible: true
|
|
|
|
PropertyAnimation {
|
|
target: txtTitle
|
|
duration: 100
|
|
properties: "opacity"
|
|
}
|
|
|
|
PropertyAnimation {
|
|
target: shadow
|
|
duration: 100
|
|
properties: "opacity"
|
|
}
|
|
|
|
SequentialAnimation {
|
|
PropertyAnimation {
|
|
target: effBlur
|
|
duration: 500
|
|
properties: "radius"
|
|
}
|
|
|
|
PropertyAnimation {
|
|
target: txtTitle
|
|
duration: 200
|
|
properties: "opacity, anchors.topMargin"
|
|
}
|
|
}
|
|
}
|
|
]
|
|
}
|