From d02cd04a42ac61059538ac6688233ca72061688a Mon Sep 17 00:00:00 2001 From: Emeric Date: Sat, 27 Apr 2024 19:40:42 +0200 Subject: [PATCH] Various UI cleanups --- qml/components/FileInputArea.qml | 98 +++++++++++++++--------------- qml/components/FolderInputArea.qml | 58 ++++++++---------- qml/components/SliderPlayer.qml | 4 +- 3 files changed, 78 insertions(+), 82 deletions(-) diff --git a/qml/components/FileInputArea.qml b/qml/components/FileInputArea.qml index ae6797d..2435de0 100644 --- a/qml/components/FileInputArea.qml +++ b/qml/components/FileInputArea.qml @@ -1,27 +1,24 @@ +import QtCore import QtQuick +import QtQuick.Dialogs import QtQuick.Controls.impl import QtQuick.Templates as T -//import QtQuick.Dialogs 1.3 // Qt5 -//import QtGraphicalEffects 1.15 // Qt5 - -import QtQuick.Dialogs // Qt6 -import Qt5Compat.GraphicalEffects // Qt6 - import ThemeEngine import "qrc:/utils/UtilsPath.js" as UtilsPath T.TextField { id: control - implicitWidth: implicitBackgroundWidth + leftInset + rightInset || - Math.max(contentWidth, placeholder.implicitWidth) + leftPadding + rightPadding + implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset, + contentWidth + leftPadding + rightPadding, + placeholder.implicitWidth + leftPadding + rightPadding) implicitHeight: Math.max(implicitBackgroundHeight + topInset + bottomInset, contentHeight + topPadding + bottomPadding, placeholder.implicitHeight + topPadding + bottomPadding) - leftPadding: 12 - rightPadding: 12 + leftPadding: 8 + rightPadding: buttonWidth + 6 clip: true color: colorText @@ -39,7 +36,9 @@ T.TextField { selectedTextColor: colorSelectedText onEditingFinished: focus = false + Keys.onBackPressed: focus = false + // settings property alias folder: control.text property alias file: fileArea.text property alias extension: extensionArea.text @@ -47,18 +46,24 @@ T.TextField { property bool isValid: (control.text.length > 0 && fileArea.text.length > 0 && extensionArea.text.length > 0) // settings + property string dialogTitle: qsTr("Please choose a file!") + property var dialogFilter: ["All files (*)"] + property int dialogFileMode: FileDialog.SaveFile // OpenFile / OpenFiles / SaveFile + property var currentFolder: StandardPaths.writableLocation(StandardPaths.HomeLocation) + + // button property string buttonText: qsTr("change") - property int buttonWidth: (buttonChange.visible ? buttonChange.width : 0) + property int buttonWidth: (buttonChange.visible ? buttonChange.width + 2 : 2) // colors - property string colorText: Theme.colorComponentText - property string colorPlaceholderText: Theme.colorSubText - property string colorBorder: Theme.colorComponentBorder - property string colorBackground: Theme.colorComponentBackground - property string colorSelection: Theme.colorPrimary - property string colorSelectedText: "white" + property color colorText: Theme.colorComponentText + property color colorPlaceholderText: Theme.colorSubText + property color colorBorder: Theme.colorComponentBorder + property color colorBackground: Theme.colorComponentBackground + property color colorSelection: Theme.colorPrimary + property color colorSelectedText: "white" - //////////////////////////////////////////////////////////////////////////// + //////////////// Loader { id: fileDialogLoader @@ -66,15 +71,17 @@ T.TextField { active: false asynchronous: false sourceComponent: FileDialog { - title: qsTr("Please choose a file!") - currentFolder: UtilsPath.makeUrl(control.text) - fileMode: FileDialog.SaveFile + title: control.dialogTitle + nameFilters: control.dialogFilter - //fileMode: FileDialog.OpenFile / FileDialog.OpenFiles / FileDialog.SaveFile - //flags: FileDialog.HideNameFilterDetails + fileMode: control.dialogFileMode + currentFolder: UtilsPath.makeUrl(control.text) + currentFile: UtilsPath.makeUrl(control.text) onAccepted: { - //console.log("fileDialog URL: " + selectedFile) + //console.log("fileDialog currentFolder: " + currentFolder) + //console.log("fileDialog currentFile: " + currentFile) + //console.log("fileDialog selectedFile: " + selectedFile) var f = UtilsPath.cleanUrl(selectedFile) if (f.slice(0, -1) !== "/") f += "/" @@ -84,15 +91,24 @@ T.TextField { } } - //////////////////////////////////////////////////////////////////////////// + //////////////// + + background: Rectangle { + implicitWidth: 256 + implicitHeight: Theme.componentHeight + + radius: Theme.componentRadius + color: control.colorBackground + } + + //////////////// PlaceholderText { id: placeholder - anchors.top: control.top - anchors.bottom: control.bottom - x: control.leftPadding + y: control.topPadding width: control.width - (control.leftPadding + control.rightPadding) + height: control.height - (control.topPadding + control.bottomPadding) text: control.placeholderText font: control.font @@ -109,8 +125,12 @@ T.TextField { id: contentRow anchors.left: parent.left anchors.leftMargin: control.leftPadding + control.contentWidth + anchors.right: parent.right + anchors.rightMargin: control.rightPadding anchors.verticalCenter: parent.verticalCenter + clip: true + TextInput { // fileArea id: fileArea anchors.verticalCenter: parent.verticalCenter @@ -127,6 +147,7 @@ T.TextField { onEditingFinished: focus = false } Text { // dot + id: extensionDot anchors.verticalCenter: parent.verticalCenter text: "." color: Theme.colorSubText @@ -140,27 +161,6 @@ T.TextField { } } - //////////////////////////////////////////////////////////////////////////// - - background: Rectangle { - implicitWidth: 256 - implicitHeight: Theme.componentHeight - - radius: Theme.componentRadius - color: control.colorBackground - - layer.enabled: false - layer.effect: OpacityMask { - maskSource: Rectangle { - x: background.x - y: background.y - width: background.width - height: background.height - radius: background.radius - } - } - } - //////////////// ButtonThemed { diff --git a/qml/components/FolderInputArea.qml b/qml/components/FolderInputArea.qml index f0060ef..c3341f7 100644 --- a/qml/components/FolderInputArea.qml +++ b/qml/components/FolderInputArea.qml @@ -1,27 +1,23 @@ import QtQuick +import QtQuick.Dialogs import QtQuick.Controls.impl import QtQuick.Templates as T -//import QtQuick.Dialogs 1.3 // Qt5 -//import QtGraphicalEffects 1.15 // Qt5 - -import QtQuick.Dialogs // Qt6 -import Qt5Compat.GraphicalEffects // Qt6 - import ThemeEngine import "qrc:/utils/UtilsPath.js" as UtilsPath T.TextField { id: control - implicitWidth: implicitBackgroundWidth + leftInset + rightInset || - Math.max(contentWidth, placeholder.implicitWidth) + leftPadding + rightPadding + implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset, + contentWidth + leftPadding + rightPadding, + placeholder.implicitWidth + leftPadding + rightPadding) implicitHeight: Math.max(implicitBackgroundHeight + topInset + bottomInset, contentHeight + topPadding + bottomPadding, placeholder.implicitHeight + topPadding + bottomPadding) - leftPadding: 12 - rightPadding: 12 + leftPadding: 8 + rightPadding: buttonWidth + 6 clip: true color: colorText @@ -39,24 +35,30 @@ T.TextField { selectedTextColor: colorSelectedText onEditingFinished: focus = false + Keys.onBackPressed: focus = false + // settings property alias folder: control.text property string path: control.text property bool isValid: (control.text.length > 0) // settings + property string dialogTitle: qsTr("Please choose a directory!") + property var currentFolder: StandardPaths.writableLocation(StandardPaths.HomeLocation) + + // button property string buttonText: qsTr("change") - property int buttonWidth: (buttonChange.visible ? buttonChange.width : 0) + property int buttonWidth: (buttonChange.visible ? buttonChange.width + 2 : 2) // colors - property string colorText: Theme.colorComponentText - property string colorPlaceholderText: Theme.colorSubText - property string colorBorder: Theme.colorComponentBorder - property string colorBackground: Theme.colorComponentBackground - property string colorSelection: Theme.colorPrimary - property string colorSelectedText: "white" + property color colorText: Theme.colorComponentText + property color colorPlaceholderText: Theme.colorSubText + property color colorBorder: Theme.colorComponentBorder + property color colorBackground: Theme.colorComponentBackground + property color colorSelection: Theme.colorPrimary + property color colorSelectedText: "white" - //////////////////////////////////////////////////////////////////////////// + //////////////// Loader { id: folderDialogLoader @@ -64,11 +66,14 @@ T.TextField { active: false asynchronous: false sourceComponent: FolderDialog { - title: qsTr("Please choose a directory!") + title: control.dialogTitle + currentFolder: UtilsPath.makeUrl(control.text) + //currentFolder: UtilsPath.makeUrl(control.currentFolder) onAccepted: { - //console.log("fileDialog URL: " + selectedFolder) + //console.log("folderDialog currentFolder: " + currentFolder) + //console.log("folderDialog selectedFolder: " + selectedFolder) var f = UtilsPath.cleanUrl(selectedFolder) if (f.slice(0, -1) !== "/") f += "/" @@ -78,7 +83,7 @@ T.TextField { } } - //////////////////////////////////////////////////////////////////////////// + //////////////// background: Rectangle { implicitWidth: 256 @@ -86,17 +91,6 @@ T.TextField { radius: Theme.componentRadius color: control.colorBackground - - layer.enabled: false - layer.effect: OpacityMask { - maskSource: Rectangle { - x: background.x - y: background.y - width: background.width - height: background.height - radius: background.radius - } - } } //////////////// diff --git a/qml/components/SliderPlayer.qml b/qml/components/SliderPlayer.qml index d0ef20b..9391c4f 100644 --- a/qml/components/SliderPlayer.qml +++ b/qml/components/SliderPlayer.qml @@ -6,11 +6,13 @@ import ThemeEngine T.Slider { id: control + implicitWidth: 200 implicitHeight: 4 + padding: 0 - value: 0.5 + value: 0 background: Rectangle { x: control.leftPadding