Merge branch 'main' into hefty-hype

This commit is contained in:
end-4
2026-05-12 10:47:55 +02:00
8 changed files with 125 additions and 208 deletions
+1 -1
View File
@@ -1 +1 @@
hl.bind("CTRL+SUPER+ALT+Slash", hl.dsp.exec_cmd("xdg-open ~/.config/hypr/custom/keybinds.lua"), {description = "Edit user keybinds"} )
+2 -2
View File
@@ -6,8 +6,8 @@ input_path = '~/.config/matugen/templates/colors.json'
output_path = '~/.local/state/quickshell/user/generated/colors.json' output_path = '~/.local/state/quickshell/user/generated/colors.json'
[templates.hyprland] [templates.hyprland]
input_path = '~/.config/matugen/templates/hyprland/colors.conf' input_path = '~/.config/matugen/templates/hyprland/colors.lua'
output_path = '~/.config/hypr/hyprland/colors.conf' output_path = '~/.config/hypr/hyprland/colors.lua'
[templates.hyprlock] [templates.hyprlock]
input_path = '~/.config/matugen/templates/hyprland/hyprlock-colors.conf' input_path = '~/.config/matugen/templates/hyprland/hyprlock-colors.conf'
@@ -1,32 +0,0 @@
general {
col.active_border = rgba({{colors.outline_variant.default.hex_stripped}}77)
col.inactive_border = rgba({{colors.surface_container_low.default.hex_stripped}}33)
}
misc {
background_color = rgba({{colors.surface.dark.hex_stripped}}FF)
}
plugin {
hyprbars {
# Honestly idk if it works like css, but well, why not
bar_text_font = Google Sans Flex Medium, Rubik, Geist, AR One Sans, Reddit Sans, Inter, Roboto, Ubuntu, Noto Sans, sans-serif
bar_height = 30
bar_padding = 10
bar_button_padding = 5
bar_precedence_over_border = true
bar_part_of_window = true
bar_color = rgba({{colors.background.default.hex_stripped}}FF)
col.text = rgba({{colors.on_background.default.hex_stripped}}FF)
# example buttons (R -> L)
# hyprbars-button = color, size, on-click
hyprbars-button = rgb({{colors.on_background.default.hex_stripped}}), 13, 󰖭, hyprctl dispatch killactive
hyprbars-button = rgb({{colors.on_background.default.hex_stripped}}), 13, 󰖯, hyprctl dispatch fullscreen 1
hyprbars-button = rgb({{colors.on_background.default.hex_stripped}}), 13, 󰖰, hyprctl dispatch movetoworkspacesilent special
}
}
windowrule = border_color rgba({{colors.primary.default.hex_stripped}}AA) rgba({{colors.primary.default.hex_stripped}}77), match:pin 1
@@ -0,0 +1,16 @@
hl.config({
general = {
col = {
active_border = "rgba({{colors.outline_variant.default.hex_stripped}}77)",
inactive_border = "rgba({{colors.surface_container_low.default.hex_stripped}}33)",
},
},
misc = {
background_color = "rgba({{colors.surface.dark.hex_stripped}}FF)",
},
})
hl.window_rule({
match = { pin = 1 },
border_color = "rgba({{colors.primary.default.hex_stripped}}AA) rgba({{colors.primary.default.hex_stripped}}77)",
})
@@ -2,18 +2,22 @@ pragma ComponentBehavior: Bound
import qs.services import qs.services
import qs.modules.common import qs.modules.common
import qs.modules.common.functions
import qs.modules.common.widgets import qs.modules.common.widgets
import QtQuick import QtQuick
import QtQuick.Layouts import QtQuick.Layouts
import Quickshell
Item { Item {
id: root id: root
readonly property var keybinds: HyprlandKeybinds.keybinds readonly property var keybinds: HyprlandKeybinds.keybinds.filter(function(keybind) {
property real spacing: 20 return keybind.has_description;
})
property real columnSpacing: 40
property real titleSpacing: 7 property real titleSpacing: 7
property real padding: 4 property real padding: 4
implicitWidth: row.implicitWidth + padding * 2 implicitWidth: QsWindow.window.screen.width * 0.7
implicitHeight: row.implicitHeight + padding * 2 implicitHeight: QsWindow.window.screen.height * 0.7
// Excellent symbol explaination and source : // Excellent symbol explaination and source :
// http://xahlee.info/comp/unicode_computing_symbols.html // http://xahlee.info/comp/unicode_computing_symbols.html
// https://www.nerdfonts.com/cheat-sheet // https://www.nerdfonts.com/cheat-sheet
@@ -56,7 +60,7 @@ Item {
"Page_↑/↓": "⇞/⇟", "Page_↑/↓": "⇞/⇟",
}) })
property var keyBlacklist: ["Super_L"] property var keyBlacklist: ["SUPER_L", "SUPER_R"]
property var keySubstitutions: Object.assign({ property var keySubstitutions: Object.assign({
"Super": "", "Super": "",
"mouse_up": "Scroll ↓", // ikr, weird "mouse_up": "Scroll ↓", // ikr, weird
@@ -77,139 +81,91 @@ Item {
Config.options.cheatsheet.useMouseSymbol ? mouseSymbolMap : {}, Config.options.cheatsheet.useMouseSymbol ? mouseSymbolMap : {},
) )
Row { // Keybind columns StyledFlickable {
id: row id: flickable
spacing: root.spacing anchors.fill: parent
anchors.margins: Appearance.rounding.small
Repeater { contentHeight: height
model: keybinds.children contentWidth: flow.implicitWidth
Flow {
delegate: Column { // Keybind sections id: flow
spacing: root.spacing height: flickable.height
required property var modelData flow: Flow.TopToBottom
anchors.top: row.top spacing: 4
Repeater {
Repeater { model: root.keybinds
model: modelData.children delegate: BindLine {
required property var modelData
delegate: Item { // Section with real keybinds keyData: modelData
id: keybindSection }
required property var modelData }
implicitWidth: sectionColumn.implicitWidth }
implicitHeight: sectionColumn.implicitHeight }
Column { function modMaskToStringList(modMask: int): list<string> {
id: sectionColumn var list = [];
anchors.centerIn: parent if (modMask & (1 << 0)) { list.push("Shift"); }
spacing: root.titleSpacing if (modMask & (1 << 1)) { list.push("Caps"); }
if (modMask & (1 << 2)) { list.push("Ctrl"); }
StyledText { if (modMask & (1 << 3)) { list.push("Alt"); }
id: sectionTitle if (modMask & (1 << 4)) { list.push("Mod2"); }
font { if (modMask & (1 << 5)) { list.push("Mod3"); }
family: Appearance.font.family.title if (modMask & (1 << 6)) { list.push("Super"); }
pixelSize: Appearance.font.pixelSize.title if (modMask & (1 << 7)) { list.push("Mod5"); }
variableAxes: Appearance.font.variableAxes.title return list;
} }
color: Appearance.colors.colOnLayer0
text: keybindSection.modelData.name property int maxBindWidth: 0
}
component BindLine: Row {
GridLayout { required property var keyData
id: keybindGrid Row {
columns: 2 spacing: 16
columnSpacing: 4 Row {
rowSpacing: 4 id: modRow
Component.onCompleted: root.maxBindWidth = Math.max(root.maxBindWidth, implicitWidth)
Repeater { width: root.maxBindWidth
model: { spacing: 4
var result = []; Repeater {
for (var i = 0; i < keybindSection.modelData.keybinds.length; i++) { model: {
const keybind = keybindSection.modelData.keybinds[i]; const modList = root.modMaskToStringList(keyData.modmask)
if (modList.length == 0) return []
if (!Config.options.cheatsheet.splitButtons) { if (Config.options.cheatsheet.splitButtons) return modList;
for (var j = 0; j < keybind.mods.length; j++) { return [modList.join(" ")]
keybind.mods[j] = keySubstitutions[keybind.mods[j]] || keybind.mods[j]; }
} delegate: KeyboardKey {
keybind.mods = [keybind.mods.join(' ') ] required property var modelData
keybind.mods[0] += !keyBlacklist.includes(keybind.key) && keybind.mods[0].length ? ' ' : '' key: root.keySubstitutions[modelData] || modelData
keybind.mods[0] += !keyBlacklist.includes(keybind.key) ? (keySubstitutions[keybind.key] || keybind.key) : '' pixelSize: Config.options.cheatsheet.fontSize.key
} }
}
result.push({ StyledText {
"type": "keys", id: keybindPlus
"mods": keybind.mods, anchors.verticalCenter: parent.verticalCenter
"key": keybind.key, visible: !keyBlacklist.includes(keyData.key) && keyData.modmask > 0
}); text: "+"
result.push({ }
"type": "comment", KeyboardKey {
"comment": keybind.comment, id: keybindKey
}); anchors.verticalCenter: parent.verticalCenter
} visible: !keyBlacklist.includes(keyData.key)
return result; key: StringUtils.toTitleCase(root.keySubstitutions[keyData.key] || keyData.key)
} pixelSize: Config.options.cheatsheet.fontSize.key
delegate: Item { color: Appearance.colors.colOnLayer0
required property var modelData }
implicitWidth: keybindLoader.implicitWidth }
implicitHeight: keybindLoader.implicitHeight Item {
anchors.verticalCenter: parent.verticalCenter
Loader { implicitWidth: commentText.implicitWidth + root.columnSpacing
id: keybindLoader implicitHeight: commentText.implicitHeight
sourceComponent: (modelData.type === "keys") ? keysComponent : commentComponent StyledText {
} id: commentText
anchors.verticalCenter: parent.verticalCenter
Component { anchors.left: parent.left
id: keysComponent font.pixelSize: Config.options.cheatsheet.fontSize.comment || Appearance.font.pixelSize.smaller
Row { text: keyData.description
spacing: 4
Repeater {
model: modelData.mods
delegate: KeyboardKey {
required property var modelData
key: keySubstitutions[modelData] || modelData
pixelSize: Config.options.cheatsheet.fontSize.key
}
}
StyledText {
id: keybindPlus
visible: Config.options.cheatsheet.splitButtons && !keyBlacklist.includes(modelData.key) && modelData.mods.length > 0
text: "+"
}
KeyboardKey {
id: keybindKey
visible: Config.options.cheatsheet.splitButtons && !keyBlacklist.includes(modelData.key)
key: keySubstitutions[modelData.key] || modelData.key
pixelSize: Config.options.cheatsheet.fontSize.key
color: Appearance.colors.colOnLayer0
}
}
}
Component {
id: commentComponent
Item {
id: commentItem
implicitWidth: commentText.implicitWidth + 8 * 2
implicitHeight: commentText.implicitHeight
StyledText {
id: commentText
anchors.centerIn: parent
font.pixelSize: Config.options.cheatsheet.fontSize.comment || Appearance.font.pixelSize.smaller
text: modelData.comment
}
}
}
}
}
}
}
}
} }
} }
} }
} }
} }
@@ -14,54 +14,27 @@ import Quickshell.Hyprland
*/ */
Singleton { Singleton {
id: root id: root
property string keybindParserPath: FileUtils.trimFileProtocol(`${Directories.scriptPath}/hyprland/get_keybinds.py`) property var keybinds: []
property string defaultKeybindConfigPath: FileUtils.trimFileProtocol(`${Directories.config}/hypr/hyprland/keybinds.conf`)
property string userKeybindConfigPath: FileUtils.trimFileProtocol(`${Directories.config}/hypr/custom/keybinds.conf`)
property var defaultKeybinds: {"children": []}
property var userKeybinds: {"children": []}
property var keybinds: ({
children: [
...(defaultKeybinds.children ?? []),
...(userKeybinds.children ?? []),
]
})
Connections { Connections {
target: Hyprland target: Hyprland
function onRawEvent(event) { function onRawEvent(event) {
if (event.name == "configreloaded") { if (event.name == "configreloaded") {
getDefaultKeybinds.running = true getKeybinds.running = true
getUserKeybinds.running = true
} }
} }
} }
Process { Process {
id: getDefaultKeybinds id: getKeybinds
running: true running: true
command: [root.keybindParserPath, "--path", root.defaultKeybindConfigPath] command: ["hyprctl", "binds", "-j"]
stdout: SplitParser { stdout: StdioCollector {
onRead: data => { onStreamFinished: {
try { try {
root.defaultKeybinds = JSON.parse(data) root.keybinds = JSON.parse(text)
} catch (e) {
console.error("[CheatsheetKeybinds] Error parsing keybinds:", e)
}
}
}
}
Process {
id: getUserKeybinds
running: true
command: [root.keybindParserPath, "--path", root.userKeybindConfigPath]
stdout: SplitParser {
onRead: data => {
try {
root.userKeybinds = JSON.parse(data)
} catch (e) { } catch (e) {
console.error("[CheatsheetKeybinds] Error parsing keybinds:", e) console.error("[CheatsheetKeybinds] Error parsing keybinds:", e)
} }
+1 -1
View File
@@ -46,7 +46,7 @@ patterns:
- from: "dots/.config/hypr" - from: "dots/.config/hypr"
to: "$XDG_CONFIG_HOME/hypr" to: "$XDG_CONFIG_HOME/hypr"
mode: "sync" mode: "sync"
excludes: ["custom", "hyprlock.conf", "hypridle.conf", "monitors.conf", "workspaces.conf"] excludes: ["custom", "hyprlock.conf", "hypridle.conf"]
# Hyprland special files # Hyprland special files
- from: "dots/.config/hypr/hypridle.conf" - from: "dots/.config/hypr/hypridle.conf"
to: "$XDG_CONFIG_HOME/hypr/hypridle.conf" to: "$XDG_CONFIG_HOME/hypr/hypridle.conf"
+6 -2
View File
@@ -48,10 +48,14 @@ case "${SKIP_HYPRLAND}" in
true) sleep 0;; true) sleep 0;;
*) *)
install_dir__sync dots/.config/hypr/hyprland "$XDG_CONFIG_HOME"/hypr/hyprland install_dir__sync dots/.config/hypr/hyprland "$XDG_CONFIG_HOME"/hypr/hyprland
for i in hyprlock.conf {monitors,workspaces}.conf ; do if [ -f "${XDG_CONFIG_HOME}/hypr/hyprland.conf" ]; then
mv "${XDG_CONFIG_HOME}/hypr/hyprland.conf" "${XDG_CONFIG_HOME}/hypr/hyprland.conf.old" # disable old config
echo 'hyprland.conf has been renamed to hyprland.conf.old. This is to allow the new lua config to load.'
fi
for i in hyprlock.conf ; do
install_file__auto_backup "dots/.config/hypr/$i" "${XDG_CONFIG_HOME}/hypr/$i" install_file__auto_backup "dots/.config/hypr/$i" "${XDG_CONFIG_HOME}/hypr/$i"
done done
for i in hyprland.conf ; do for i in hyprland.lua ; do
case "${SKIP_HYPRLAND_ENTRY}" in case "${SKIP_HYPRLAND_ENTRY}" in
true) sleep 0;; true) sleep 0;;
*) install_file "dots/.config/hypr/$i" "${XDG_CONFIG_HOME}/hypr/$i" ;; *) install_file "dots/.config/hypr/$i" "${XDG_CONFIG_HOME}/hypr/$i" ;;