kdeconnect-kde/smsapp/qml/AttachmentViewer.qml

198 lines
6.6 KiB
QML

/**
* Copyright (C) 2020 Aniket Kumar <anikketkumar786@gmail.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) version 3 or any later version
* accepted by the membership of KDE e.V. (or its successor approved
* by the membership of KDE e.V.), which shall act as a proxy
* defined in Section 14 of version 3 of the license.
*
* 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.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
import QtQuick 2.12
import QtQuick.Layouts 1.12
import QtQuick.Controls 2.12
import org.kde.kirigami 2.13 as Kirigami
import QtMultimedia 5.12
Kirigami.Page {
id: root
property string filePath
property string mimeType
contextualActions: [
Kirigami.Action {
text: i18nd("kdeconnect-sms", "Open with default")
icon.name: "window-new"
onTriggered: {
Qt.openUrlExternally(filePath);
}
}
]
contentItem: Rectangle {
anchors.fill: parent
Rectangle {
id: imageViewer
visible: mimeType.match("image")
anchors.horizontalCenter: parent.horizontalCenter
width: image.width
height: parent.height - y
y: root.implicitHeaderHeight
color: parent.color
Image {
id: image
source: parent.visible ? filePath : ""
anchors.horizontalCenter: parent.horizontalCenter
anchors.verticalCenter: parent.verticalCenter
width: sourceSize.width
height: parent.height
fillMode: Image.PreserveAspectFit
}
}
MediaPlayer {
id: mediaPlayer
source: filePath
onPositionChanged: {
if (mediaPlayer.position > 1000 && mediaPlayer.duration - mediaPlayer.position < 1000) {
playAndPauseButton.icon.name = "media-playback-start"
mediaPlayer.pause()
mediaPlayer.seek(0)
}
}
}
Item {
width: parent.width
height: parent.height - mediaControls.height
anchors.topMargin: root.implicitHeaderHeight
VideoOutput {
anchors.fill: parent
source: mediaPlayer
fillMode: VideoOutput.PreserveAspectFit
// By default QML's videoOutput element rotates the vdeeo files by 90 degrees in clockwise direction
orientation: -90
}
}
Rectangle {
id: mediaControls
visible: mimeType.match("video")
width: parent.width
height: 50
anchors.horizontalCenter: parent.horizontalCenter
anchors.bottom: parent.bottom
color: Kirigami.Theme.backgroundColor
Rectangle {
anchors.top: parent.top
width: parent.width
height: 1
color: "lightGray"
}
ColumnLayout {
anchors.horizontalCenter: parent.horizontalCenter
width: parent.width
Rectangle {
id: progressBar
Layout.fillWidth: parent
Layout.leftMargin: Kirigami.Units.largeSpacing
Layout.rightMargin: Kirigami.Units.largeSpacing
Layout.topMargin: Kirigami.Units.smallSpacing
radius: 5
height: 5
color: "gray"
Rectangle {
anchors.left: parent.left
anchors.top: parent.top
anchors.bottom: parent.bottom
radius: 5
width: mediaPlayer.duration > 0 ? parent.width*mediaPlayer.position/mediaPlayer.duration : 0
color: {
Kirigami.Theme.colorSet = Kirigami.Theme.View
var accentColor = Kirigami.Theme.highlightColor
return Qt.tint(Kirigami.Theme.backgroundColor, Qt.rgba(accentColor.r, accentColor.g, accentColor.b, 1))
}
}
MouseArea {
anchors.fill: parent
onClicked: {
if (mediaPlayer.seekable) {
mediaPlayer.seek(mediaPlayer.duration * mouse.x/width);
}
}
}
}
RowLayout {
Layout.alignment: Qt.AlignHCenter
spacing: Kirigami.Units.largeSpacing
Button {
id: backwardButton
icon.name: "media-seek-backward"
onClicked: {
if (mediaPlayer.seekable) {
mediaPlayer.seek(mediaPlayer.position - 2000)
}
}
}
Button {
id: playAndPauseButton
icon.name: "media-playback-pause"
onClicked: {
if (icon.name == "media-playback-start") {
mediaPlayer.play()
icon.name = "media-playback-pause"
} else {
mediaPlayer.pause()
icon.name = "media-playback-start"
}
}
}
Button {
id: forwardButton
icon.name: "media-seek-forward"
onClicked: {
if (mediaPlayer.seekable) {
mediaPlayer.seek(mediaPlayer.position + 2000)
}
}
}
}
}
}
}
Component.onCompleted: {
mediaPlayer.play()
}
}