From 9800d3408e8654ae0f097d92faa12a8093ec7140 Mon Sep 17 00:00:00 2001 From: djib Date: Thu, 7 Nov 2024 12:18:01 +0100 Subject: [PATCH] Initial commit --- config | 236 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ status.sh | 45 +++++++++++ 2 files changed, 281 insertions(+) create mode 100644 config create mode 100755 status.sh diff --git a/config b/config new file mode 100644 index 0000000..7290582 --- /dev/null +++ b/config @@ -0,0 +1,236 @@ +# 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 +# Your preferred terminal emulator +set $term foot +# Your preferred application launcher +# Note: pass the final command to swaymsg so that the resulting window can be opened +# on the original workspace that the command was run on. +#set $menu dmenu_path | dmenu | xargs swaymsg exec -- +set $menu dmenu_path | dmenu | xargs swaymsg exec -- +set $altmenu wofi --show drun -i | xargs swaymsg exec -- + +include /etc/sway/config-vars.d/* + +### Output configuration +# +# Default wallpaper (more resolutions are available in /usr/share/backgrounds/sway/) +output * bg /usr/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 * dpms off"' resume 'swaymsg "output * dpms 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 "2:14:SynPS/2_Synaptics_TouchPad" { +# dwt enabled +# tap enabled +# natural_scroll enabled +# middle_emulation enabled +# } +# +# You can get the names of your inputs by running: swaymsg -t get_inputs +# Read `man 5 sway-input` for more information about this section. +input "type:keyboard" { + xkb_layout fr + xkb_variant bepo +} + +### Key bindings +# +# Basics: +# + # Start a terminal + bindsym $mod+Return exec $term + + # Kill focused window + bindsym $mod+Shift+q kill + + # Start your launcher + bindsym $mod+d exec $menu + bindsym $mod+Shift+D exec $altmenu + + # 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+c reload + + # Exit sway (logs you out of your Wayland session) + bindsym $mod+Shift+e 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' +# +# 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+Control+1 move container to workspace number 1 + bindsym $mod+Control+2 move container to workspace number 2 + bindsym $mod+Control+3 move container to workspace number 3 + bindsym $mod+Control+4 move container to workspace number 4 + bindsym $mod+Control+5 move container to workspace number 5 + bindsym $mod+Control+6 move container to workspace number 6 + bindsym $mod+Control+7 move container to workspace number 7 + bindsym $mod+Control+8 move container to workspace number 8 + bindsym $mod+Control+9 move container to workspace number 9 + bindsym $mod+Control+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+v splitv + + # Switch the current container between different layout styles + bindsym $mod+s layout stacking + bindsym $mod+w layout tabbed + bindsym $mod+e layout toggle split + + # Make the current focus fullscreen + bindsym $mod+f 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 +# +# 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" + +# Set volume using the media keys +bindsym XF86AudioRaiseVolume exec amixer set Master 5%+ +bindsym XF86AudioLowerVolume exec amixer set Master 5%- +# Mute and unmute loudspeakers +bindsym XF86AudioMute exec amixer set Master toggle + +# Hide mouse cursor after it isn't moved for the given amount of milliseconds +seat * hide_cursor 3000 + +# +# Status Bar: +# +# Read `man 5 sway-bar` for more information about this section. +bar { + position top + + # When the status_command prints a new line to stdout, swaybar updates. + # The default just shows the current date and time. + # status_command while date +'%Y-%m-%d %l:%M:%S %p'; do sleep 1; done + status_command while ~/.config/sway/status.sh; do sleep 1; done + + colors { + statusline #ffffff + background #323232 + inactive_workspace #32323200 #32323200 #5c5c5c + } +} + +include /etc/sway/config.d/* diff --git a/status.sh b/status.sh new file mode 100755 index 0000000..3b6691b --- /dev/null +++ b/status.sh @@ -0,0 +1,45 @@ +# The Sway configuration file in ~/.config/sway/config calls this script. +# You should see changes to the status bar after saving this script. +# If not, do "killall swaybar" and $mod+Shift+c to reload the configuration. + +# The abbreviated weekday (e.g., "Sat"), followed by the ISO-formatted date +# like 2018-10-06 and the time (e.g., 14:01). Check `man date` on how to format +# time and date. +date_formatted=$(date "+%a %F %H:%M") + +# "upower --enumerate | grep 'BAT'" gets the battery name (e.g., +# "/org/freedesktop/UPower/devices/battery_BAT0") from all power devices. +# "upower --show-info" prints battery information from which we get +# the state (such as "charging" or "fully-charged") and the battery's +# charge percentage. With awk, we cut away the column containing +# identifiers. i3 and sway convert the newline between battery state and +# the charge percentage automatically to a space, producing a result like +# "charging 59%" or "fully-charged 100%". +battery_info=$(upower --show-info $(upower --enumerate |\ +grep 'BAT') |\ +egrep "state|percentage" |\ +awk '{print $2}') + +# "amixer -M" gets the mapped volume for evaluating the percentage which +# is more natural to the human ear according to "man amixer". +# Column number 4 contains the current volume percentage in brackets, e.g., +# "[36%]". Column number 6 is "[off]" or "[on]" depending on whether sound +# is muted or not. +# "tr -d []" removes brackets around the volume. +# Adapted from https://bbs.archlinux.org/viewtopic.php?id=89648 +audio_volume=$(amixer -M get Master |\ +awk '/Mono.+/ {print $6=="[off]" ?\ +$4" muted!": \ +$4}' |\ +tr -d []) + +# Wifi +ip_address=$(nmcli -g GENERAL.STATE device show wlx0010603707fd | sed 's/.*(\(.*\))/\1/') + +# Temperature +temp=$(cat /sys/class/thermal/thermal_zone*/temp | sed 's/...$/°C/') + +# Mem info +mem=$(free -m | grep Mem | awk '{printf "%d%%", ($3/$2)*100}') + +echo "V: "$audio_volume" | M: "$mem" | B: "$battery_info" | T: "$temp" | N: "$ip_address" | "$date_formatted