added settings options
This commit is contained in:
@@ -1,37 +1,212 @@
|
||||
import Quickshell
|
||||
import Quickshell.Widgets
|
||||
import QtQuick
|
||||
import QtQuick.Layouts
|
||||
import qs.Components
|
||||
import qs.Modules as Modules
|
||||
import qs.Modules.Settings.Controls
|
||||
import qs.Config
|
||||
import qs.Helpers
|
||||
import qs.Components
|
||||
|
||||
CustomRect {
|
||||
SettingsPage {
|
||||
id: root
|
||||
|
||||
ColumnLayout {
|
||||
id: clayout
|
||||
function schemeTypeItem(items, value) {
|
||||
for (let i = 0; i < items.length; i++) {
|
||||
const item = items[i];
|
||||
if (item.value === value)
|
||||
return item;
|
||||
}
|
||||
|
||||
anchors.fill: parent
|
||||
return items[0] ?? null;
|
||||
}
|
||||
|
||||
component Settings: CustomRect {
|
||||
id: settingsItem
|
||||
SettingsSection {
|
||||
SettingsHeader {
|
||||
name: "General"
|
||||
}
|
||||
|
||||
required property string name
|
||||
SettingInput {
|
||||
name: "Logo"
|
||||
object: Config.general
|
||||
setting: "logo"
|
||||
}
|
||||
|
||||
Layout.preferredHeight: 60
|
||||
Layout.preferredWidth: 200
|
||||
Separator {
|
||||
}
|
||||
|
||||
CustomText {
|
||||
id: text
|
||||
SettingInput {
|
||||
name: "Wallpaper path"
|
||||
object: Config.general
|
||||
setting: "wallpaperPath"
|
||||
}
|
||||
|
||||
anchors.fill: parent
|
||||
font.bold: true
|
||||
font.pointSize: Appearance.font.size.large * 2
|
||||
text: settingsItem.name
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
Separator {
|
||||
}
|
||||
|
||||
SettingSwitch {
|
||||
name: "Desktop icons"
|
||||
object: Config.general
|
||||
setting: "desktopIcons"
|
||||
}
|
||||
}
|
||||
|
||||
SettingsSection {
|
||||
SettingsHeader {
|
||||
name: "Color"
|
||||
}
|
||||
|
||||
CustomSplitButtonRow {
|
||||
active: Config.general.color.mode === "light" ? menuItems[0] : menuItems[1]
|
||||
label: qsTr("Scheme mode")
|
||||
|
||||
menuItems: [
|
||||
MenuItem {
|
||||
icon: "light_mode"
|
||||
text: qsTr("Light")
|
||||
value: "light"
|
||||
},
|
||||
MenuItem {
|
||||
icon: "dark_mode"
|
||||
text: qsTr("Dark")
|
||||
value: "dark"
|
||||
}
|
||||
]
|
||||
|
||||
onSelected: item => {
|
||||
Config.general.color.mode = item.value;
|
||||
Config.save();
|
||||
}
|
||||
}
|
||||
|
||||
Separator {
|
||||
}
|
||||
|
||||
CustomSplitButtonRow {
|
||||
id: schemeType
|
||||
|
||||
active: root.schemeTypeItem(menuItems, Config.colors.schemeType)
|
||||
label: qsTr("Scheme type")
|
||||
z: 2
|
||||
|
||||
menuItems: [
|
||||
MenuItem {
|
||||
icon: "palette"
|
||||
text: qsTr("Vibrant")
|
||||
value: "vibrant"
|
||||
},
|
||||
MenuItem {
|
||||
icon: "gesture"
|
||||
text: qsTr("Expressive")
|
||||
value: "expressive"
|
||||
},
|
||||
MenuItem {
|
||||
icon: "contrast"
|
||||
text: qsTr("Monochrome")
|
||||
value: "monochrome"
|
||||
},
|
||||
MenuItem {
|
||||
icon: "tonality"
|
||||
text: qsTr("Neutral")
|
||||
value: "neutral"
|
||||
},
|
||||
MenuItem {
|
||||
icon: "gradient"
|
||||
text: qsTr("Tonal spot")
|
||||
value: "tonalSpot"
|
||||
},
|
||||
MenuItem {
|
||||
icon: "target"
|
||||
text: qsTr("Fidelity")
|
||||
value: "fidelity"
|
||||
},
|
||||
MenuItem {
|
||||
icon: "article"
|
||||
text: qsTr("Content")
|
||||
value: "content"
|
||||
},
|
||||
MenuItem {
|
||||
icon: "colors"
|
||||
text: qsTr("Rainbow")
|
||||
value: "rainbow"
|
||||
},
|
||||
MenuItem {
|
||||
icon: "nutrition"
|
||||
text: qsTr("Fruit salad")
|
||||
value: "fruitSalad"
|
||||
}
|
||||
]
|
||||
|
||||
onSelected: item => {
|
||||
Config.colors.schemeType = item.value;
|
||||
Config.save();
|
||||
}
|
||||
}
|
||||
|
||||
Separator {
|
||||
}
|
||||
|
||||
SettingSwitch {
|
||||
name: "Automatic color scheme"
|
||||
object: Config.general.color
|
||||
setting: "schemeGeneration"
|
||||
}
|
||||
|
||||
Separator {
|
||||
}
|
||||
|
||||
SettingSwitch {
|
||||
name: "Smart color scheme"
|
||||
object: Config.general.color
|
||||
setting: "smart"
|
||||
}
|
||||
|
||||
Separator {
|
||||
}
|
||||
|
||||
SettingSpinner {
|
||||
name: "Schedule dark mode"
|
||||
object: Config.general.color
|
||||
settings: ["scheduleDarkStart", "scheduleDarkEnd"]
|
||||
}
|
||||
}
|
||||
|
||||
SettingsSection {
|
||||
z: -1
|
||||
|
||||
SettingsHeader {
|
||||
name: "Default Apps"
|
||||
}
|
||||
|
||||
SettingStringList {
|
||||
addLabel: qsTr("Add terminal command")
|
||||
name: "Terminal"
|
||||
object: Config.general.apps
|
||||
setting: "terminal"
|
||||
}
|
||||
|
||||
Separator {
|
||||
}
|
||||
|
||||
SettingStringList {
|
||||
addLabel: qsTr("Add audio command")
|
||||
name: "Audio"
|
||||
object: Config.general.apps
|
||||
setting: "audio"
|
||||
}
|
||||
|
||||
Separator {
|
||||
}
|
||||
|
||||
SettingStringList {
|
||||
addLabel: qsTr("Add playback command")
|
||||
name: "Playback"
|
||||
object: Config.general.apps
|
||||
setting: "playback"
|
||||
}
|
||||
|
||||
Separator {
|
||||
}
|
||||
|
||||
SettingStringList {
|
||||
addLabel: qsTr("Add explorer command")
|
||||
name: "Explorer"
|
||||
object: Config.general.apps
|
||||
setting: "explorer"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user