summaryrefslogtreecommitdiff
path: root/modules/utilities/RecordingDeleteModal.qml
diff options
context:
space:
mode:
Diffstat (limited to 'modules/utilities/RecordingDeleteModal.qml')
-rw-r--r--modules/utilities/RecordingDeleteModal.qml114
1 files changed, 114 insertions, 0 deletions
diff --git a/modules/utilities/RecordingDeleteModal.qml b/modules/utilities/RecordingDeleteModal.qml
new file mode 100644
index 0000000..9b6f3d5
--- /dev/null
+++ b/modules/utilities/RecordingDeleteModal.qml
@@ -0,0 +1,114 @@
+pragma ComponentBehavior: Bound
+
+import qs.components
+import qs.components.controls
+import qs.components.effects
+import qs.services
+import qs.config
+import Caelestia
+import QtQuick
+import QtQuick.Layouts
+
+Loader {
+ id: root
+
+ required property var props
+
+ anchors.fill: parent
+
+ opacity: root.props.recordingConfirmDelete ? 1 : 0
+ active: opacity > 0
+ asynchronous: true
+
+ sourceComponent: MouseArea {
+ id: deleteConfirmation
+
+ property string path
+
+ Component.onCompleted: path = root.props.recordingConfirmDelete
+
+ hoverEnabled: true
+ onClicked: root.props.recordingConfirmDelete = ""
+
+ StyledRect {
+ anchors.centerIn: parent
+ radius: Appearance.rounding.large
+ color: Colours.palette.m3surfaceContainerHigh
+
+ scale: 0.5
+ Component.onCompleted: scale = Qt.binding(() => root.props.recordingConfirmDelete ? 1 : 0.5)
+
+ width: Math.min(parent.width - Appearance.padding.large * 2, implicitWidth)
+ implicitWidth: deleteConfirmationLayout.implicitWidth + Appearance.padding.large * 3
+ implicitHeight: deleteConfirmationLayout.implicitHeight + Appearance.padding.large * 3
+
+ Elevation {
+ anchors.fill: parent
+ radius: parent.radius
+ z: -1
+ level: 3
+ }
+
+ ColumnLayout {
+ id: deleteConfirmationLayout
+
+ anchors.fill: parent
+ anchors.margins: Appearance.padding.large * 1.5
+ spacing: Appearance.spacing.normal
+
+ StyledText {
+ text: qsTr("Delete recording?")
+ font.pointSize: Appearance.font.size.large
+ }
+
+ StyledText {
+ Layout.fillWidth: true
+ text: qsTr("Recording '%1' will be permanently deleted.").arg(deleteConfirmation.path)
+ color: Colours.palette.m3onSurfaceVariant
+ font.pointSize: Appearance.font.size.small
+ wrapMode: Text.WrapAtWordBoundaryOrAnywhere
+ }
+
+ RowLayout {
+ Layout.topMargin: Appearance.spacing.normal
+ Layout.alignment: Qt.AlignRight
+ spacing: Appearance.spacing.normal
+
+ TextButton {
+ text: qsTr("Cancel")
+ type: TextButton.Text
+ label.color: Colours.palette.m3primary
+ stateLayer.color: Colours.palette.m3primary
+
+ function onClicked(): void {
+ root.props.recordingConfirmDelete = "";
+ }
+ }
+
+ TextButton {
+ text: qsTr("Delete")
+ type: TextButton.Text
+ label.color: Colours.palette.m3primary
+ stateLayer.color: Colours.palette.m3primary
+
+ function onClicked(): void {
+ CUtils.deleteFile(Qt.resolvedUrl(root.props.recordingConfirmDelete));
+ root.props.recordingConfirmDelete = "";
+ }
+ }
+ }
+ }
+
+ Behavior on scale {
+ Anim {
+ duration: Appearance.anim.durations.expressiveDefaultSpatial
+ easing.bezierCurve: Appearance.anim.curves.expressiveDefaultSpatial
+ }
+ }
+ }
+ }
+
+ Behavior on opacity {
+ Anim {}
+ }
+}