diff --git a/home/dot_config/rofi/config.rasi b/home/dot_config/rofi/config.rasi
index 6af1f39..a96dea9 100644
--- a/home/dot_config/rofi/config.rasi
+++ b/home/dot_config/rofi/config.rasi
@@ -30,9 +30,9 @@
}
element {
- padding: 1px ;
+ padding: 5px;
cursor: pointer;
- spacing: 5px ;
+ spacing: 15px ;
border: 0;
}
element normal.normal {
diff --git a/home/dot_config/sway/config b/home/dot_config/sway/config
new file mode 100644
index 0000000..a7863bc
--- /dev/null
+++ b/home/dot_config/sway/config
@@ -0,0 +1,217 @@
+# Default config for sway
+#
+# Copy this to ~/.config/sway/config and edit it to your liking.
+#
+# Read `man 5 sway` for a complete reference.
+
+### Variables
+#
+# Logo key. Use Mod1 for Alt.
+set $mod Mod4
+# Home row direction keys, like vim
+set $left h
+set $down j
+set $up k
+set $right l
+set $term kitty
+set $menu rofi -show drun -icon-theme Papirus -show-icons
+
+### Output configuration
+#
+# Default wallpaper (more resolutions are available in /run/current-system/sw/share/backgrounds/sway/)
+output * bg /run/current-system/sw/share/backgrounds/sway/Sway_Wallpaper_Blue_1920x1080.png fill
+#
+# Example configuration:
+#
+# output HDMI-A-1 resolution 1920x1080 position 1920,0
+#
+# You can get the names of your outputs by running: swaymsg -t get_outputs
+
+### Idle configuration
+#
+# Example configuration:
+#
+# exec swayidle -w \
+# timeout 300 'swaylock -f -c 000000' \
+# timeout 600 'swaymsg "output * power off"' resume 'swaymsg "output * power on"' \
+# before-sleep 'swaylock -f -c 000000'
+#
+# This will lock your screen after 300 seconds of inactivity, then turn off
+# your displays after another 300 seconds, and turn your screens back on when
+# resumed. It will also lock your screen before your computer goes to sleep.
+
+### Input configuration
+#
+# Example configuration:
+#
+ input type:touchpad {
+ dwt enabled
+ tap enabled
+ natural_scroll enabled
+ }
+
+### Key bindings
+#
+# Basics:
+#
+ # Start a terminal
+ bindsym $mod+Return exec $term
+
+ # Kill focused window
+ bindsym $mod+q kill
+
+ # Start your launcher
+ bindsym alt+space exec $menu
+
+ # Drag floating windows by holding down $mod and left mouse button.
+ # Resize them with right mouse button + $mod.
+ # Despite the name, also works for non-floating windows.
+ # Change normal to inverse to use left mouse button for resizing and right
+ # mouse button for dragging.
+ floating_modifier $mod normal
+
+ # Reload the configuration file
+ bindsym $mod+Shift+r reload
+
+ # Exit sway (logs you out of your Wayland session)
+#
+# Moving around:
+#
+ # Move your focus around
+ bindsym $mod+$left focus left
+ bindsym $mod+$down focus down
+ bindsym $mod+$up focus up
+ bindsym $mod+$right focus right
+ # Or use $mod+[up|down|left|right]
+ bindsym $mod+Left focus left
+ bindsym $mod+Down focus down
+ bindsym $mod+Up focus up
+ bindsym $mod+Right focus right
+
+ # Move the focused window with the same, but add Shift
+ bindsym $mod+Shift+$left move left
+ bindsym $mod+Shift+$down move down
+ bindsym $mod+Shift+$up move up
+ bindsym $mod+Shift+$right move right
+ # Ditto, with arrow keys
+ bindsym $mod+Shift+Left move left
+ bindsym $mod+Shift+Down move down
+ bindsym $mod+Shift+Up move up
+ bindsym $mod+Shift+Right move right
+#
+# Workspaces:
+#
+ # Switch to workspace
+ bindsym $mod+1 workspace number 1
+ bindsym $mod+2 workspace number 2
+ bindsym $mod+3 workspace number 3
+ bindsym $mod+4 workspace number 4
+ bindsym $mod+5 workspace number 5
+ bindsym $mod+6 workspace number 6
+ bindsym $mod+7 workspace number 7
+ bindsym $mod+8 workspace number 8
+ bindsym $mod+9 workspace number 9
+ bindsym $mod+0 workspace number 10
+ # Move focused container to workspace
+ bindsym $mod+Shift+1 move container to workspace number 1
+ bindsym $mod+Shift+2 move container to workspace number 2
+ bindsym $mod+Shift+3 move container to workspace number 3
+ bindsym $mod+Shift+4 move container to workspace number 4
+ bindsym $mod+Shift+5 move container to workspace number 5
+ bindsym $mod+Shift+6 move container to workspace number 6
+ bindsym $mod+Shift+7 move container to workspace number 7
+ bindsym $mod+Shift+8 move container to workspace number 8
+ bindsym $mod+Shift+9 move container to workspace number 9
+ bindsym $mod+Shift+0 move container to workspace number 10
+ # Note: workspaces can have any name you want, not just numbers.
+ # We just use 1-10 as the default.
+#
+# Layout stuff:
+#
+ # You can "split" the current object of your focus with
+ # $mod+b or $mod+v, for horizontal and vertical splits
+ # respectively.
+ bindsym $mod+b splith
+ bindsym $mod+shift+b splitv
+
+ # Switch the current container between different layout styles
+ # bindsym $mod+s layout stacking
+ bindsym $mod+w layout tabbed
+ bindsym $mod+x layout toggle split
+
+ # Make the current focus fullscreen
+ bindsym $mod+shift+m fullscreen
+
+ # Toggle the current focus between tiling and floating mode
+ bindsym $mod+Shift+space floating toggle
+
+ # Swap focus between the tiling area and the floating area
+ bindsym $mod+space focus mode_toggle
+
+ # Move focus to the parent container
+ bindsym $mod+a focus parent
+
+ bindsym $mod+e exec dolphin
+ bindsym $mod+shift+e exec kitty bash -c "yazi"
+ bindsym $mod+shift+w exec rofi -show window -icon-theme Papirus -show-icons
+ bindsym $mod+period exec rofi -show p -modi p:rofimoji | wl-copy
+ bindsym ctrl+alt+backspace exec rofi -show p -modi p:rofi-power-menu
+ # bindsym ctrl+alt+backspace exec swaynag -t warning -m 'You pressed the exit shortcut. Do you really want to exit sway? This will end your Wayland session.' -B 'Yes, exit sway' 'swaymsg exit'
+#
+# Scratchpad:
+#
+ # Sway has a "scratchpad", which is a bag of holding for windows.
+ # You can send windows there and get them back later.
+
+ # Move the currently focused window to the scratchpad
+ bindsym $mod+Shift+minus move scratchpad
+
+ # Show the next scratchpad window or hide the focused scratchpad window.
+ # If there are multiple scratchpad windows, this command cycles through them.
+ bindsym $mod+minus scratchpad show
+#
+# Resizing containers:
+#
+mode "resize" {
+ # left will shrink the containers width
+ # right will grow the containers width
+ # up will shrink the containers height
+ # down will grow the containers height
+ bindsym $left resize shrink width 10px
+ bindsym $down resize grow height 10px
+ bindsym $up resize shrink height 10px
+ bindsym $right resize grow width 10px
+
+ # Ditto, with arrow keys
+ bindsym Left resize shrink width 10px
+ bindsym Down resize grow height 10px
+ bindsym Up resize shrink height 10px
+ bindsym Right resize grow width 10px
+
+ # Return to default mode
+ bindsym Return mode "default"
+ bindsym Escape mode "default"
+}
+bindsym $mod+r mode "resize"
+#
+# Utilities:
+#
+ # Special keys to adjust volume via PulseAudio
+ bindsym --locked XF86AudioMute exec pactl set-sink-mute \@DEFAULT_SINK@ toggle
+ bindsym --locked XF86AudioLowerVolume exec pactl set-sink-volume \@DEFAULT_SINK@ -5%
+ bindsym --locked XF86AudioRaiseVolume exec pactl set-sink-volume \@DEFAULT_SINK@ +5%
+ bindsym --locked XF86AudioMicMute exec pactl set-source-mute \@DEFAULT_SOURCE@ toggle
+ # Special keys to adjust brightness via brightnessctl
+ bindsym --locked XF86MonBrightnessDown exec brightnessctl set 5%-
+ bindsym --locked XF86MonBrightnessUp exec brightnessctl set 5%+
+ # Special key to take a screenshot with grim
+ bindsym Print exec grimshot --notify savecopy area ~/Pictures/$(date "+%Y-%m-%d"T"%H:%M:%S").png
+ bindsym $mod+shift+s exec grimshot --notify savecopy area ~/Pictures/$(date "+%Y-%m-%d"T"%H:%M:%S").png
+
+#
+# Status Bar:
+exec waybar
+
+seat seat0 xcursor_theme Adwaita 30
+
+include /etc/sway/config.d/*
diff --git a/home/dot_config/waybar/config.jsonc b/home/dot_config/waybar/config.jsonc
index afc52ed..2c200ac 100644
--- a/home/dot_config/waybar/config.jsonc
+++ b/home/dot_config/waybar/config.jsonc
@@ -16,7 +16,7 @@
// "~/.config/waybar/modules/niri.jsonc"
],
// Choose the order of the modules
- "modules-left": ["custom/osicon", "wlr/taskbar"],
+ "modules-left": ["custom/osicon", "sway/workspaces", "wlr/taskbar"],
// "modules-center": ["clock"],
"modules-right": ["tray", "pulseaudio", "cpu", "memory", "network", "battery", "clock"],
// "modules-right": ["cpu", "memory", "battery", "network", "tray"],
diff --git a/home/dot_config/waybar/modules/misc.jsonc b/home/dot_config/waybar/modules/misc.jsonc
index 98c03d5..efc63e0 100644
--- a/home/dot_config/waybar/modules/misc.jsonc
+++ b/home/dot_config/waybar/modules/misc.jsonc
@@ -185,7 +185,7 @@
}
},
"custom/osicon": {
- "format": "",
- "on-click-right": "rofi -show drun"
+ "format": "",
+ "on-click-right": "rofi -show drun -icon-theme Papirus -show-icons"
}
}
diff --git a/home/dot_config/waybar/style.css b/home/dot_config/waybar/style.css
index 100f4f8..5e045f7 100644
--- a/home/dot_config/waybar/style.css
+++ b/home/dot_config/waybar/style.css
@@ -1,6 +1,6 @@
* {
/* `otf-font-awesome` is required to be installed for icons */
- font-family: Cantarell, 'Font Awesome 6 Free';
+ font-family: "Maple Mono NF";
font-size: 14px;
font-feature-settings: "tnum";
}
diff --git a/home/dot_config/yazi/init.lua b/home/dot_config/yazi/init.lua
index 4836798..c29e977 100644
--- a/home/dot_config/yazi/init.lua
+++ b/home/dot_config/yazi/init.lua
@@ -1,18 +1,18 @@
-- ~/.config/yazi/init.lua
-function Linemode:size_and_mtime()
- local time = math.floor(self._file.cha.mtime or 0)
- if time == 0 then
- time = ""
- elseif os.date("%Y", time) == os.date("%Y") then
- time = os.date("%b %d %H:%M", time)
- else
- time = os.date("%b %d %Y", time)
- end
-
- local size = self._file:size()
- return string.format("%s %s", size and ya.readable_size(size) or "-", time)
-end
-
--- require("dual-pane"):setup({ enabled = true })
-require("starship"):setup()
--- require("yaziline"):setup()
+-- function Linemode:size_and_mtime()
+-- local time = math.floor(self._file.cha.mtime or 0)
+-- if time == 0 then
+-- time = ""
+-- elseif os.date("%Y", time) == os.date("%Y") then
+-- time = os.date("%b %d %H:%M", time)
+-- else
+-- time = os.date("%b %d %Y", time)
+-- end
+--
+-- local size = self._file:size()
+-- return string.format("%s %s", size and ya.readable_size(size) or "-", time)
+-- end
+--
+-- -- require("dual-pane"):setup({ enabled = true })
+-- require("starship"):setup()
+-- -- require("yaziline"):setup()
diff --git a/nixcfgs/hosts/zephyrus/default.nix b/nixcfgs/hosts/zephyrus/default.nix
index 487c0de..f40e2db 100644
--- a/nixcfgs/hosts/zephyrus/default.nix
+++ b/nixcfgs/hosts/zephyrus/default.nix
@@ -20,9 +20,9 @@
../../modules/nixos/hardware/udev/basys3.nix
# desktop environment and display manager
- ../../modules/nixos/desktop/dm/gdm.nix
- ../../modules/nixos/desktop/de/gnome.nix
- ../../modules/nixos/desktop/de/niri.nix
+ ../../modules/nixos/desktop/dm/sddm.nix
+ ../../modules/nixos/desktop/de/kde.nix
+ ../../modules/nixos/desktop/de/sway.nix
# desktop programs
../../modules/nixos/programs/chromium.nix
diff --git a/nixcfgs/modules/nixos/desktop/de/niri.nix b/nixcfgs/modules/nixos/desktop/de/niri.nix
index 5916b1c..7ceff18 100644
--- a/nixcfgs/modules/nixos/desktop/de/niri.nix
+++ b/nixcfgs/modules/nixos/desktop/de/niri.nix
@@ -4,5 +4,8 @@
waybar
mako
rofi
+ rofimoji
+ rofi-power-menu
+ swaylock-effects
];
}
diff --git a/nixcfgs/modules/nixos/desktop/de/sway.nix b/nixcfgs/modules/nixos/desktop/de/sway.nix
new file mode 100644
index 0000000..42541d7
--- /dev/null
+++ b/nixcfgs/modules/nixos/desktop/de/sway.nix
@@ -0,0 +1,15 @@
+{pkgs, ...}: {
+ programs.sway.enable = true;
+ programs.sway.xwayland.enable = true;
+ environment.systemPackages = with pkgs; [
+ swaybg
+ swayidle
+ mako
+ rofi
+ rofimoji
+ rofi-power-menu
+ swaylock-effects
+ sway-contrib.grimshot
+ waybar
+ ];
+}
diff --git a/nixcfgs/modules/nixos/desktop/dm/sddm.nix b/nixcfgs/modules/nixos/desktop/dm/sddm.nix
index 7c5c6ff..b6b17c5 100644
--- a/nixcfgs/modules/nixos/desktop/dm/sddm.nix
+++ b/nixcfgs/modules/nixos/desktop/dm/sddm.nix
@@ -9,10 +9,10 @@ let
#};
};
in {
- # Enable the KDE Plasma Desktop Environment.
services.displayManager.sddm = {
enable = true;
- extraPackages = with pkgs; [
+ wayland.enable = true;
+ extraPackages = [
custom-sddm-astronaut
];