summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--modules/utilities/Content.qml10
-rw-r--r--modules/utilities/Wrapper.qml4
-rw-r--r--modules/utilities/cards/Record.qml277
-rw-r--r--utils/Icons.qml3
-rw-r--r--utils/Paths.qml1
5 files changed, 0 insertions, 295 deletions
diff --git a/modules/utilities/Content.qml b/modules/utilities/Content.qml
index 902656d..f6d8d63 100644
--- a/modules/utilities/Content.qml
+++ b/modules/utilities/Content.qml
@@ -21,19 +21,9 @@ Item {
IdleInhibit {}
- Record {
- props: root.props
- visibilities: root.visibilities
- z: 1
- }
-
Toggles {
visibilities: root.visibilities
popouts: root.popouts
}
}
-
- RecordingDeleteModal {
- props: root.props
- }
}
diff --git a/modules/utilities/Wrapper.qml b/modules/utilities/Wrapper.qml
index 77178e3..455b5fa 100644
--- a/modules/utilities/Wrapper.qml
+++ b/modules/utilities/Wrapper.qml
@@ -13,10 +13,6 @@ Item {
required property Item popouts
readonly property PersistentProperties props: PersistentProperties {
- property bool recordingListExpanded: false
- property string recordingConfirmDelete
- property string recordingMode
-
reloadableId: "utilities"
}
readonly property bool shouldBeActive: visibilities.sidebar || (visibilities.utilities && Config.utilities.enabled && !(visibilities.session && Config.session.enabled))
diff --git a/modules/utilities/cards/Record.qml b/modules/utilities/cards/Record.qml
deleted file mode 100644
index 273c640..0000000
--- a/modules/utilities/cards/Record.qml
+++ /dev/null
@@ -1,277 +0,0 @@
-pragma ComponentBehavior: Bound
-
-import qs.components
-import qs.components.controls
-import qs.services
-import qs.config
-import QtQuick
-import QtQuick.Layouts
-
-StyledRect {
- id: root
-
- required property var props
- required property var visibilities
-
- Layout.fillWidth: true
- implicitHeight: layout.implicitHeight + layout.anchors.margins * 2
-
- radius: Appearance.rounding.normal
- color: Colours.tPalette.m3surfaceContainer
-
- ColumnLayout {
- id: layout
-
- anchors.fill: parent
- anchors.margins: Appearance.padding.large
- spacing: Appearance.spacing.normal
-
- RowLayout {
- spacing: Appearance.spacing.normal
- z: 1
-
- StyledRect {
- implicitWidth: implicitHeight
- implicitHeight: {
- const h = icon.implicitHeight + Appearance.padding.smaller * 2;
- return h - (h % 2);
- }
-
- radius: Appearance.rounding.full
- color: Recorder.running ? Colours.palette.m3secondary : Colours.palette.m3secondaryContainer
-
- MaterialIcon {
- id: icon
-
- anchors.centerIn: parent
- anchors.horizontalCenterOffset: -0.5
- anchors.verticalCenterOffset: 1.5
- text: "screen_record"
- color: Recorder.running ? Colours.palette.m3onSecondary : Colours.palette.m3onSecondaryContainer
- font.pointSize: Appearance.font.size.large
- }
- }
-
- ColumnLayout {
- Layout.fillWidth: true
- spacing: 0
-
- StyledText {
- Layout.fillWidth: true
- text: qsTr("Screen Recorder")
- font.pointSize: Appearance.font.size.normal
- elide: Text.ElideRight
- }
-
- StyledText {
- Layout.fillWidth: true
- text: Recorder.paused ? qsTr("Recording paused") : Recorder.running ? qsTr("Recording running") : qsTr("Recording off")
- color: Colours.palette.m3onSurfaceVariant
- font.pointSize: Appearance.font.size.small
- elide: Text.ElideRight
- }
- }
-
- SplitButton {
- disabled: Recorder.running
- active: menuItems.find(m => root.props.recordingMode === m.icon + m.text) ?? menuItems[0]
- menu.onItemSelected: item => root.props.recordingMode = item.icon + item.text
-
- menuItems: [
- MenuItem {
- icon: "fullscreen"
- text: qsTr("Record fullscreen")
- activeText: qsTr("Fullscreen")
- onClicked: Recorder.start()
- },
- MenuItem {
- icon: "screenshot_region"
- text: qsTr("Record region")
- activeText: qsTr("Region")
- onClicked: Recorder.start(["-r"])
- },
- MenuItem {
- icon: "select_to_speak"
- text: qsTr("Record fullscreen with sound")
- activeText: qsTr("Fullscreen")
- onClicked: Recorder.start(["-s"])
- },
- MenuItem {
- icon: "volume_up"
- text: qsTr("Record region with sound")
- activeText: qsTr("Region")
- onClicked: Recorder.start(["-sr"])
- }
- ]
- }
- }
-
- Loader {
- id: listOrControls
-
- property bool running: Recorder.running
-
- Layout.fillWidth: true
- Layout.preferredHeight: implicitHeight
- sourceComponent: running ? recordingControls : recordingList
-
- Behavior on Layout.preferredHeight {
- id: locHeightAnim
-
- enabled: false
-
- Anim {}
- }
-
- Behavior on running {
- SequentialAnimation {
- ParallelAnimation {
- Anim {
- target: listOrControls
- property: "scale"
- to: 0.7
- duration: Appearance.anim.durations.small
- easing.bezierCurve: Appearance.anim.curves.standardAccel
- }
- Anim {
- target: listOrControls
- property: "opacity"
- to: 0
- duration: Appearance.anim.durations.small
- easing.bezierCurve: Appearance.anim.curves.standardAccel
- }
- }
- PropertyAction {
- target: locHeightAnim
- property: "enabled"
- value: true
- }
- PropertyAction {}
- PropertyAction {
- target: locHeightAnim
- property: "enabled"
- value: false
- }
- ParallelAnimation {
- Anim {
- target: listOrControls
- property: "scale"
- to: 1
- duration: Appearance.anim.durations.small
- easing.bezierCurve: Appearance.anim.curves.standardDecel
- }
- Anim {
- target: listOrControls
- property: "opacity"
- to: 1
- duration: Appearance.anim.durations.small
- easing.bezierCurve: Appearance.anim.curves.standardDecel
- }
- }
- }
- }
- }
- }
-
- Component {
- id: recordingList
-
- RecordingList {
- props: root.props
- visibilities: root.visibilities
- }
- }
-
- Component {
- id: recordingControls
-
- RowLayout {
- spacing: Appearance.spacing.normal
-
- StyledRect {
- radius: Appearance.rounding.full
- color: Recorder.paused ? Colours.palette.m3tertiary : Colours.palette.m3error
-
- implicitWidth: recText.implicitWidth + Appearance.padding.normal * 2
- implicitHeight: recText.implicitHeight + Appearance.padding.smaller * 2
-
- StyledText {
- id: recText
-
- anchors.centerIn: parent
- animate: true
- text: Recorder.paused ? "PAUSED" : "REC"
- color: Recorder.paused ? Colours.palette.m3onTertiary : Colours.palette.m3onError
- font.family: Appearance.font.family.mono
- }
-
- Behavior on implicitWidth {
- Anim {}
- }
-
- SequentialAnimation on opacity {
- running: !Recorder.paused
- alwaysRunToEnd: true
- loops: Animation.Infinite
-
- Anim {
- from: 1
- to: 0
- duration: Appearance.anim.durations.large
- easing.bezierCurve: Appearance.anim.curves.emphasizedAccel
- }
- Anim {
- from: 0
- to: 1
- duration: Appearance.anim.durations.extraLarge
- easing.bezierCurve: Appearance.anim.curves.emphasizedDecel
- }
- }
- }
-
- StyledText {
- text: {
- const elapsed = Recorder.elapsed;
-
- const hours = Math.floor(elapsed / 3600);
- const mins = Math.floor((elapsed % 3600) / 60);
- const secs = Math.floor(elapsed % 60).toString().padStart(2, "0");
-
- let time;
- if (hours > 0)
- time = `${hours}:${mins.toString().padStart(2, "0")}:${secs}`;
- else
- time = `${mins}:${secs}`;
-
- return qsTr("Recording for %1").arg(time);
- }
- font.pointSize: Appearance.font.size.normal
- }
-
- Item {
- Layout.fillWidth: true
- }
-
- IconButton {
- label.animate: true
- icon: Recorder.paused ? "play_arrow" : "pause"
- toggle: true
- checked: Recorder.paused
- type: IconButton.Tonal
- font.pointSize: Appearance.font.size.large
- onClicked: {
- Recorder.togglePause();
- internalChecked = Recorder.paused;
- }
- }
-
- IconButton {
- icon: "stop"
- inactiveColour: Colours.palette.m3error
- inactiveOnColour: Colours.palette.m3onError
- font.pointSize: Appearance.font.size.large
- onClicked: Recorder.stop()
- }
- }
- }
-}
diff --git a/utils/Icons.qml b/utils/Icons.qml
index c06cbf8..50b0592 100644
--- a/utils/Icons.qml
+++ b/utils/Icons.qml
@@ -52,7 +52,6 @@ Singleton {
Audio: "music_note",
Music: "music_note",
Player: "music_note",
- Recorder: "mic",
Game: "sports_esports",
FileTools: "files",
FileManager: "files",
@@ -144,8 +143,6 @@ Singleton {
summary = summary.toLowerCase();
if (summary.includes("reboot"))
return "restart_alt";
- if (summary.includes("recording"))
- return "screen_record";
if (summary.includes("battery"))
return "power";
if (summary.includes("screenshot"))
diff --git a/utils/Paths.qml b/utils/Paths.qml
index bc89770..6d52399 100644
--- a/utils/Paths.qml
+++ b/utils/Paths.qml
@@ -19,7 +19,6 @@ Singleton {
readonly property string imagecache: `${cache}/imagecache`
readonly property string notifimagecache: `${imagecache}/notifs`
readonly property string wallsdir: Quickshell.env("CAELESTIA_WALLPAPERS_DIR") || absolutePath(Config.paths.wallpaperDir)
- readonly property string recsdir: Quickshell.env("CAELESTIA_RECORDINGS_DIR") || `${videos}/Recordings`
readonly property string libdir: Quickshell.env("CAELESTIA_LIB_DIR") || "/usr/lib/caelestia"
function toLocalFile(path: url): string {