diff options
| author | akiyamn | 2021-10-05 18:16:11 +1100 | 
|---|---|---|
| committer | akiyamn | 2021-10-05 18:16:11 +1100 | 
| commit | b1d8102ac1a86e473c2f7826ef3c3c0a5b741410 (patch) | |
| tree | 0b023568af6c15d86e6a41e6e1910ef70c6baf31 | |
| download | dotfiles-b1d8102ac1a86e473c2f7826ef3c3c0a5b741410.tar.gz dotfiles-b1d8102ac1a86e473c2f7826ef3c3c0a5b741410.zip | |
First commit from Arch machine
| -rw-r--r-- | .Xresources | 1 | ||||
| -rw-r--r-- | .bashrc | 10 | ||||
| -rw-r--r-- | .config/alacritty/alacritty.yml | 596 | ||||
| -rw-r--r-- | .config/deadbeef/config | 72 | ||||
| -rw-r--r-- | .config/dunst/dunstrc | 466 | ||||
| -rw-r--r-- | .config/fish/config.fish | 25 | ||||
| -rw-r--r-- | .config/fish/fish_variables | 30 | ||||
| -rw-r--r-- | .config/gtk-3.0/bookmarks | 1 | ||||
| -rw-r--r-- | .config/gtk-3.0/settings.ini | 15 | ||||
| -rw-r--r-- | .config/picom.conf | 425 | ||||
| -rw-r--r-- | .config/qtile/__pycache__/config.cpython-39.pyc | bin | 0 -> 5598 bytes | |||
| -rwxr-xr-x | .config/qtile/autostart.sh | 17 | ||||
| -rw-r--r-- | .config/qtile/config.py | 240 | ||||
| -rw-r--r-- | .config/qtile/picom.log | 0 | ||||
| -rw-r--r-- | .gtkrc-2.0 | 18 | ||||
| -rw-r--r-- | .xprofile | 5 | 
16 files changed, 1921 insertions, 0 deletions
| diff --git a/.Xresources b/.Xresources new file mode 100644 index 0000000..86755c4 --- /dev/null +++ b/.Xresources @@ -0,0 +1 @@ +Xcursor.size: 32 @@ -0,0 +1,10 @@ +# +# ~/.bashrc +# + + +# If not running interactively, don't do anything +[[ $- != *i* ]] && return + +alias ls='ls --color=auto' +PS1='[\u@\h \W]\$ ' diff --git a/.config/alacritty/alacritty.yml b/.config/alacritty/alacritty.yml new file mode 100644 index 0000000..ac21adb --- /dev/null +++ b/.config/alacritty/alacritty.yml @@ -0,0 +1,596 @@ +# Configuration for Alacritty, the GPU enhanced terminal emulator. + +# Any items in the `env` entry below will be added as +# environment variables. Some entries may override variables +# set by alacritty itself. +env: +  # TERM variable +  # +  # This value is used to set the `$TERM` environment variable for +  # each instance of Alacritty. If it is not present, alacritty will +  # check the local terminfo database and use `alacritty` if it is +  # available, otherwise `xterm-256color` is used. +  TERM: xterm-256color + +window: +  # Window dimensions (changes require restart) +  # +  # Specified in number of columns/lines, not pixels. +  # If both are `0`, this setting is ignored. +  #dimensions: +  #  columns: 0 +  #  lines: 0 + +  # Window position (changes require restart) +  # +  # Specified in number of pixels. +  # If the position is not set, the window manager will handle the placement. +  #position: +  #  x: 0 +  #  y: 0 + +  # Window padding (changes require restart) +  # +  # Blank space added around the window in pixels. This padding is scaled +  # by DPI and the specified value is always added at both opposing sides. +  padding: +    x: 6 +    y: 6 + +  # Spread additional padding evenly around the terminal content. +  dynamic_padding: false + +  # Window decorations +  # +  # Values for `decorations`: +  #     - full: Borders and title bar +  #     - none: Neither borders nor title bar +  # +  # Values for `decorations` (macOS only): +  #     - transparent: Title bar, transparent background and title bar buttons +  #     - buttonless: Title bar, transparent background, but no title bar buttons +  #decorations: full + +  # Startup Mode (changes require restart) +  # +  # Values for `startup_mode`: +  #   - Windowed +  #   - Maximized +  #   - Fullscreen +  # +  # Values for `startup_mode` (macOS only): +  #   - SimpleFullscreen +  #startup_mode: Windowed + +  # Window title +  title: Alacritty + +  # Window class (Linux/BSD only): +  class: +    # Application instance name +    instance: Alacritty +    # General application class +    general: Alacritty + +  # GTK theme variant (Linux/BSD only) +  # +  # Override the variant of the GTK theme. Commonly supported values are `dark` and `light`. +  # Set this to `None` to use the default theme variant. +  #gtk_theme_variant: None + +scrolling: +  # Maximum number of lines in the scrollback buffer. +  # Specifying '0' will disable scrolling. +  history: 5000 + +  # Number of lines the viewport will move for every line scrolled when +  # scrollback is enabled (history > 0). +  #multiplier: 3 + +  # Scroll to the bottom when new text is written to the terminal. +  #auto_scroll: false + +# Spaces per Tab (changes require restart) +# +# This setting defines the width of a tab in cells. +# +# Some applications, like Emacs, rely on knowing about the width of a tab. +# To prevent unexpected behavior in these applications, it's also required to +# change the `it` value in terminfo when altering this setting. +#tabspaces: 8 + +# Font configuration +font: +  # Normal (roman) font face +  normal: +    # Font family +    # +    # Default: +    #   - (macOS) Menlo +    #   - (Linux/BSD) monospace +    #   - (Windows) Consolas +    family: Source Code Pro +    # family: CodeNewRoman Nerd Font +    # family: RobotoMono Nerd Font +    # family: Hack +    # family: JetBrains Mono +    # family: UbuntuMono Nerd Font +    # family: Monofur Nerd Font +    # family: TerminessTTF Nerd Font +    # family: Mononoki Nerd Font + +    # The `style` can be specified to pick a specific face. +    style: Regular + +  # Bold font face +  bold: +    # Font family +    # +    # If the bold family is not specified, it will fall back to the +    # value specified for the normal font. +    family: Source Code Pro +    # family: CodeNewRoman Nerd Font +    # family: RobotoMono Nerd Font +    # family: Hack +    # family: JetBrains Mono +    # family: UbuntuMono Nerd Font +    # family: Monofur Nerd Font +    # family: TerminessTTF Nerd Font +    # family: Mononoki Nerd Font + +    # The `style` can be specified to pick a specific face. +    style: Bold + +  # Italic font face +  italic: +    # Font family +    # +    # If the italic family is not specified, it will fall back to the +    # value specified for the normal font. +    family: Source Code Pro +    # family: CodeNewRoman Nerd Font +    # family: RobotoMono Nerd Font +    # family: Hack +    # family: JetBrains Mono +    # family: UbuntuMono Nerd Font +    # family: Monofuritalic Nerd Font Mono +    # family: TerminessTTF Nerd Font +    # family: Mononoki Nerd Font + +    # The `style` can be specified to pick a specific face. +    style: Italic + +  # Bold italic font face +  bold_italic: +    # Font family +    # +    # If the bold italic family is not specified, it will fall back to the +    # value specified for the normal font. +    family: Source Code Pro +    # family: CodeNewRoman Nerd Font +    # family: RobotoMono Nerd Font +    # family: Hack +    # family: JetBrains Mono +    # family: UbuntuMono Nerd Font +    # family: Monofuritalic Nerd Font Mono +    # family: TerminessTTF Nerd Font +    # family: Mononoki Nerd Font + +    # The `style` can be specified to pick a specific face. +    style: Bold Italic + +  # Point size +  size: 12.0 + +  # Offset is the extra space around each character. `offset.y` can be thought of +  # as modifying the line spacing, and `offset.x` as modifying the letter spacing. +  offset: +    x: 0 +    y: 1 + +  # Glyph offset determines the locations of the glyphs within their cells with +  # the default being at the bottom. Increasing `x` moves the glyph to the right, +  # increasing `y` moves the glyph upwards. +  #glyph_offset: +  #  x: 0 +  #  y: 0 + +  # Thin stroke font rendering (macOS only) +  # +  # Thin strokes are suitable for retina displays, but for non-retina screens +  # it is recommended to set `use_thin_strokes` to `false` +  # +  # macOS >= 10.14.x: +  # +  # If the font quality on non-retina display looks bad then set +  # `use_thin_strokes` to `true` and enable font smoothing by running the +  # following command: +  #   `defaults write -g CGFontRenderingFontSmoothingDisabled -bool NO` +  # +  # This is a global setting and will require a log out or restart to take +  # effect. +  #use_thin_strokes: true + +# If `true`, bold text is drawn using the bright color variants. +draw_bold_text_with_bright_colors: true + +# COLOR SCHEMES +schemes: +  # Doom One +  doom-one: &doom-one +    primary: +      background: '#282c34' +      foreground: '#bbc2cf' +    cursor: +      text: CellBackground +      cursor: '#528bff' +    selection: +      text: CellForeground +      background: '#3e4451' +    normal: +      black:   '#1c1f24' +      red:     '#ff6c6b' +      green:   '#98be65' +      yellow:  '#da8548' +      blue:    '#51afef' +      magenta: '#c678dd' +      cyan:    '#5699af' +      white:   '#202328' +    bright: +      black:   '#5b6268' +      red:     '#da8548' +      green:   '#4db5bd' +      yellow:  '#ecbe7b' +      blue:    '#3071db'   # This is 2257a0 in Doom Emacs but I lightened it. +      magenta: '#a9a1e1' +      cyan:    '#46d9ff' +      white:   '#dfdfdf' + +  # Dracula +  dracula: &dracula +    colors: +      primary: +        background: '#282a36' +        foreground: '#f8f8f2' +      cursor: +        text: CellBackground +        cursor: CellForeground +      vi_mode_cursor: +        text: CellBackground +        cursor: CellForeground +      search: +        matches: +          foreground: '#44475a' +          background: '#50fa7b' +        focused_match: +          foreground: '#44475a' +          background: '#ffb86c' +        bar: +          background: '#282a36' +          foreground: '#f8f8f2' +      line_indicator: +        foreground: None +        background: None +      selection: +        text: CellForeground +        background: '#44475a' +      normal: +        black:   '#000000' +        red:     '#ff5555' +        green:   '#50fa7b' +        yellow:  '#f1fa8c' +        blue:    '#bd93f9' +        magenta: '#ff79c6' +        cyan:    '#8be9fd' +        white:   '#bfbfbf' +      bright: +        black:   '#4d4d4d' +        red:     '#ff6e67' +        green:   '#5af78e' +        yellow:  '#f4f99d' +        blue:    '#caa9fa' +        magenta: '#ff92d0' +        cyan:    '#9aedfe' +        white:   '#e6e6e6' +      dim: +        black:   '#14151b' +        red:     '#ff2222' +        green:   '#1ef956' +        yellow:  '#ebf85b' +        blue:    '#4d5b86' +        magenta: '#ff46b0' +        cyan:    '#59dffc' +        white:   '#e6e6d1' + +# Choose ONE color scheme from those available in the above list. +colors: *doom-one + +# Visual Bell +# +# Any time the BEL code is received, Alacritty "rings" the visual bell. Once +# rung, the terminal background will be set to white and transition back to the +# default background color. You can control the rate of this transition by +# setting the `duration` property (represented in milliseconds). You can also +# configure the transition function by setting the `animation` property. +# +# Values for `animation`: +#   - Ease +#   - EaseOut +#   - EaseOutSine +#   - EaseOutQuad +#   - EaseOutCubic +#   - EaseOutQuart +#   - EaseOutQuint +#   - EaseOutExpo +#   - EaseOutCirc +#   - Linear +# +# Specifying a `duration` of `0` will disable the visual bell. +#visual_bell: +#  animation: EaseOutExpo +#  duration: 0 +#  color: '#ffffff' + +# Background opacity +# +# Window opacity as a floating point number from `0.0` to `1.0`. +# The value `0.0` is completely transparent and `1.0` is opaque. +background_opacity: 0.9 +# background_opacity: 0.80 + +#selection: +  #semantic_escape_chars: ",│`|:\"' ()[]{}<>\t" + +  # When set to `true`, selected text will be copied to the primary clipboard. +  #save_to_clipboard: false + +# Allow terminal applications to change Alacritty's window title. +#dynamic_title: true + +#cursor: +  # Cursor style +  # +  # Values for `style`: +  #   - ▇ Block +  #   - _ Underline +  #   - | Beam +  #style: Block + +  # If this is `true`, the cursor will be rendered as a hollow box when the +  # window is not focused. +  #unfocused_hollow: true + +# Live config reload (changes require restart) +#live_config_reload: true + +# Shell +# +# You can set `shell.program` to the path of your favorite shell, e.g. `/bin/fish`. +# Entries in `shell.args` are passed unmodified as arguments to the shell. +# +# Default: +#   - (macOS) /bin/bash --login +#   - (Linux/BSD) user login shell +#   - (Windows) powershell +#shell: +#  program: /bin/bash +#  args: +#    - --login + +# Startup directory +# +# Directory the shell is started in. If this is unset, or `None`, the working +# directory of the parent process will be used. +#working_directory: None + +# WinPTY backend (Windows only) +# +# Alacritty defaults to using the newer ConPTY backend if it is available, +# since it resolves a lot of bugs and is quite a bit faster. If it is not +# available, the the WinPTY backend will be used instead. +# +# Setting this option to `true` makes Alacritty use the legacy WinPTY backend, +# even if the ConPTY backend is available. +#winpty_backend: false + +# Send ESC (\x1b) before characters when alt is pressed. +#alt_send_esc: true + +#debug: +  # Display the time it takes to redraw each frame. +  #render_timer: false + +  # Keep the log file after quitting Alacritty. +  #persistent_logging: false + +  # Log level +  # +  # Values for `log_level`: +  #   - None +  #   - Error +  #   - Warn +  #   - Info +  #   - Debug +  #   - Trace +  #log_level: Warn + +  # Print all received window events. +  #print_events: false + +  # Record all characters and escape sequences as test data. +  #ref_test: false + +#mouse: +  # Click settings +  # +  # The `double_click` and `triple_click` settings control the time +  # alacritty should wait for accepting multiple clicks as one double +  # or triple click. +  #double_click: { threshold: 300 } +  #triple_click: { threshold: 300 } + +  # If this is `true`, the cursor is temporarily hidden when typing. +  #hide_when_typing: false + +  #url: +    # URL launcher +    # +    # This program is executed when clicking on a text which is recognized as a URL. +    # The URL is always added to the command as the last parameter. +    # +    # When set to `None`, URL launching will be disabled completely. +    # +    # Default: +    #   - (macOS) open +    #   - (Linux/BSD) xdg-open +    #   - (Windows) explorer +    #launcher: +    #  program: xdg-open +    #  args: [] + +    # URL modifiers +    # +    # These are the modifiers that need to be held down for opening URLs when clicking +    # on them. The available modifiers are documented in the key binding section. +    #modifiers: None + +# Mouse bindings +# +# Mouse bindings are specified as a list of objects, much like the key +# bindings further below. +# +# Each mouse binding will specify a: +# +# - `mouse`: +# +#   - Middle +#   - Left +#   - Right +#   - Numeric identifier such as `5` +# +# - `action` (see key bindings) +# +# And optionally: +# +# - `mods` (see key bindings) +#mouse_bindings: +#  - { mouse: Middle, action: PasteSelection } + +# Key bindings +# +# Key bindings are specified as a list of objects. For example, this is the +# default paste binding: +# +# `- { key: V, mods: Control|Shift, action: Paste }` +# +# Each key binding will specify a: +# +# - `key`: Identifier of the key pressed +# +#    - A-Z +#    - F1-F24 +#    - Key0-Key9 +# +#    A full list with available key codes can be found here: +#    https://docs.rs/glutin/*/glutin/event/enum.VirtualKeyCode.html#variants +# +#    Instead of using the name of the keys, the `key` field also supports using +#    the scancode of the desired key. Scancodes have to be specified as a +#    decimal number. This command will allow you to display the hex scancodes +#    for certain keys: +# +#       `showkey --scancodes`. +# +# Then exactly one of: +# +# - `chars`: Send a byte sequence to the running application +# +#    The `chars` field writes the specified string to the terminal. This makes +#    it possible to pass escape sequences. To find escape codes for bindings +#    like `PageUp` (`"\x1b[5~"`), you can run the command `showkey -a` outside +#    of tmux. Note that applications use terminfo to map escape sequences back +#    to keys. It is therefore required to update the terminfo when changing an +#    escape sequence. +# +# - `action`: Execute a predefined action +# +#   - Copy +#   - Paste +#   - PasteSelection +#   - IncreaseFontSize +#   - DecreaseFontSize +#   - ResetFontSize +#   - ScrollPageUp +#   - ScrollPageDown +#   - ScrollLineUp +#   - ScrollLineDown +#   - ScrollToTop +#   - ScrollToBottom +#   - ClearHistory +#   - Hide +#   - Minimize +#   - Quit +#   - ToggleFullscreen +#   - SpawnNewInstance +#   - ClearLogNotice +#   - ReceiveChar +#   - None +# +#   (macOS only): +#   - ToggleSimpleFullscreen: Enters fullscreen without occupying another space +# +# - `command`: Fork and execute a specified command plus arguments +# +#    The `command` field must be a map containing a `program` string and an +#    `args` array of command line parameter strings. For example: +#       `{ program: "alacritty", args: ["-e", "vttest"] }` +# +# And optionally: +# +# - `mods`: Key modifiers to filter binding actions +# +#    - Command +#    - Control +#    - Option +#    - Super +#    - Shift +#    - Alt +# +#    Multiple `mods` can be combined using `|` like this: +#       `mods: Control|Shift`. +#    Whitespace and capitalization are relevant and must match the example. +# +# - `mode`: Indicate a binding for only specific terminal reported modes +# +#    This is mainly used to send applications the correct escape sequences +#    when in different modes. +# +#    - AppCursor +#    - AppKeypad +#    - Alt +# +#    A `~` operator can be used before a mode to apply the binding whenever +#    the mode is *not* active, e.g. `~Alt`. +# +# Bindings are always filled by default, but will be replaced when a new +# binding with the same triggers is defined. To unset a default binding, it can +# be mapped to the `ReceiveChar` action. Alternatively, you can use `None` for +# a no-op if you do not wish to receive input characters for that binding. +key_bindings: +    # (Windows, Linux, and BSD only) +  - { key: V,         mods: Control|Shift, action: Paste                       } +  - { key: C,         mods: Control|Shift, action: Copy                        } +  - { key: Insert,    mods: Shift,         action: PasteSelection              } +  - { key: Key0,      mods: Control,       action: ResetFontSize               } +  - { key: Equals,    mods: Control,       action: IncreaseFontSize            } +  - { key: Plus,      mods: Control,       action: IncreaseFontSize            } +  - { key: Minus,     mods: Control,       action: DecreaseFontSize            } +  - { key: F11,       mods: None,          action: ToggleFullscreen            } +  - { key: Paste,     mods: None,          action: Paste                       } +  - { key: Copy,      mods: None,          action: Copy                        } +  - { key: L,         mods: Control,       action: ClearLogNotice              } +  - { key: L,         mods: Control,       chars: "\x0c"                       } +  - { key: PageUp,    mods: None,          action: ScrollPageUp,   mode: ~Alt  } +  - { key: PageDown,  mods: None,          action: ScrollPageDown, mode: ~Alt  } +  - { key: Home,      mods: Shift,         action: ScrollToTop,    mode: ~Alt  } +  - { key: End,       mods: Shift,         action: ScrollToBottom, mode: ~Alt  } diff --git a/.config/deadbeef/config b/.config/deadbeef/config new file mode 100644 index 0000000..4ea65fa --- /dev/null +++ b/.config/deadbeef/config @@ -0,0 +1,72 @@ +cli_add_playlist_name Default +deadbeef_version 1.8.8 +gtkui.columns.playlist [{"title":"♫","id":"1","format":"%playstatus%","sort_format":"","size":"50","align":"0","color_override":"0","color":"#ff000000"},{"title":"Artist / Album","id":"-1","format":"$if(%artist%,%artist%,Unknown Artist)[ - %album%]","sort_format":"","size":"449","align":"0","color_override":"0","color":"#ff000000"},{"title":"Track No","id":"-1","format":"%tracknumber%","sort_format":"","size":"57","align":"1","color_override":"0","color":"#ff000000"},{"title":"Title","id":"-1","format":"%title%","sort_format":"","size":"650","align":"0","color_override":"0","color":"#ff000000"},{"title":"Duration","id":"-1","format":"%length%","sort_format":"","size":"50","align":"0","color_override":"0","color":"#ff000000"}] +gtkui.eq.visible 0 +gtkui.layout.0.6.2 vbox expand="0 1" fill="1 1" homogeneous=0 {hbox expand="0 1 0" fill="1 1 1" homogeneous=0 {playtb {} seekbar {} volumebar {} } hsplitter locked=0 ratio=0.849606 pos=0 size2=0 {vsplitter locked=0 ratio=0.854421 pos=0 size2=0 {playlist hideheaders=0 width=3263 {} hsplitter locked=0 ratio=0.205283 pos=0 size2=0 {scope {} spectrum {} } } tabs active=1 num_tabs=2 tab000="Playlist browser" tab001="Properties" {pltbrowser {} vsplitter locked=0 ratio=0.857813 pos=0 size2=0 {selproperties {} coverart {} } } } }  +gtkui.statusbar.visible 1 +gtkui.tabscroll 0 +gtkui.titlebar_playing_tf %artist% - %title% - DeaDBeeF-%_deadbeef_version% +gtkui.titlebar_stopped_tf DeaDBeeF-%_deadbeef_version% +hotkey.key01 "Ctrl f" 0 0 find +hotkey.key02 "Ctrl o" 0 0 open_files +hotkey.key03 "Ctrl q" 0 0 quit +hotkey.key04 "Ctrl n" 0 0 new_playlist +hotkey.key05 "Ctrl a" 0 0 select_all +hotkey.key06 "Escape" 0 0 deselect_all +hotkey.key07 "Ctrl m" 0 0 toggle_stop_after_current +hotkey.key08 "Ctrl j" 0 0 jump_to_current_track +hotkey.key09 "F1" 0 0 help +hotkey.key10 "Delete" 1 0 remove_from_playlist +hotkey.key11 "Ctrl w" 0 0 remove_current_playlist +hotkey.key13 "Alt Return" 1 0 track_properties +hotkey.key14 "Return" 0 0 play +hotkey.key15 "Ctrl p" 0 0 toggle_pause +hotkey.key16 "Alt 1" 0 0 playlist1 +hotkey.key17 "Alt 2" 0 0 playlist2 +hotkey.key18 "Alt 3" 0 0 playlist3 +hotkey.key19 "Alt 4" 0 0 playlist4 +hotkey.key20 "Alt 5" 0 0 playlist5 +hotkey.key21 "Alt 6" 0 0 playlist6 +hotkey.key22 "Alt 7" 0 0 playlist7 +hotkey.key23 "Alt 8" 0 0 playlist8 +hotkey.key24 "Alt 9" 0 0 playlist9 +hotkey.key25 "Alt 0" 0 0 playlist10 +hotkey.key26 z 0 0 prev +hotkey.key27 x 0 0 play +hotkey.key28 c 0 0 toggle_pause +hotkey.key29 v 0 0 stop +hotkey.key30 b 0 0 next +hotkey.key31 n 0 0 playback_random +hotkey.key32 "Ctrl k" 0 0 toggle_stop_after_album +hotkeys_created 1 +logwindow.geometry.h 1440 +logwindow.geometry.w 2560 +logwindow.geometry.x 0 +logwindow.geometry.y 0 +mainwin.geometry.h 2110 +mainwin.geometry.w 3820 +mainwin.geometry.x 4488 +mainwin.geometry.y 38 +network.proxy.port 8080 +output_plugin pulseaudio +playback.loop 1 +playback.volume -30.71427 +playlist.current 1 +playlist.cursor.0 -1 +playlist.cursor.1 8 +playlist.scroll.0 0 +playlist.scroll.1 -12 +playlist.scroll.cursorfollowplayback 1 +playlist.tab.00000 Default +playlist.tab.00001 New Playlist +prefwin.geometry.h 563 +prefwin.geometry.w 684 +prefwin.geometry.x 1578 +prefwin.geometry.y 802 +resume.paused 0 +resume.playlist 1 +resume.position 333.42733 +resume.track 8 +streamer.samplerate 44100 +streamer.samplerate_mult_44 44100 +streamer.samplerate_mult_48 48000 diff --git a/.config/dunst/dunstrc b/.config/dunst/dunstrc new file mode 100644 index 0000000..19569db --- /dev/null +++ b/.config/dunst/dunstrc @@ -0,0 +1,466 @@ +[global] +    ### Display ### + +    # Which monitor should the notifications be displayed on. +    monitor = 0 + +    # Display notification on focused monitor.  Possible modes are: +    #   mouse: follow mouse pointer +    #   keyboard: follow window with keyboard focus +    #   none: don't follow anything +    # +    # "keyboard" needs a window manager that exports the +    # _NET_ACTIVE_WINDOW property. +    # This should be the case for almost all modern window managers. +    # +    # If this option is set to mouse or keyboard, the monitor option +    # will be ignored. +    follow = mouse + +    # The geometry of the window: +    #   [{width}]x{height}[+/-{x}+/-{y}] +    # The geometry of the message window. +    # The height is measured in number of notifications everything else +    # in pixels.  If the width is omitted but the height is given +    # ("-geometry x2"), the message window expands over the whole screen +    # (dmenu-like).  If width is 0, the window expands to the longest +    # message displayed.  A positive x is measured from the left, a +    # negative from the right side of the screen.  Y is measured from +    # the top and down respectively. +    # The width can be negative.  In this case the actual width is the +    # screen width minus the width defined in within the geometry option. +    geometry = "300x5-30+20" + +    # Turn on the progess bar +    progress_bar = true + +    # Set the progress bar height. This includes the frame, so make sure +    # it's at least twice as big as the frame width. +    progress_bar_height = 10 + +    # Set the frame width of the progress bar +    progress_bar_frame_width = 1 + +    # Set the minimum width for the progress bar +    progress_bar_min_width = 150 + +    # Set the maximum width for the progress bar +    progress_bar_max_width = 300 + + +    # Show how many messages are currently hidden (because of geometry). +    indicate_hidden = yes + +    # Shrink window if it's smaller than the width.  Will be ignored if +    # width is 0. +    shrink = no + +    # The transparency of the window.  Range: [0; 100]. +    # This option will only work if a compositing window manager is +    # present (e.g. xcompmgr, compiz, etc.). +    transparency = 0 + +    # The height of the entire notification.  If the height is smaller +    # than the font height and padding combined, it will be raised +    # to the font height and padding. +    notification_height = 0 + +    # Draw a line of "separator_height" pixel height between two +    # notifications. +    # Set to 0 to disable. +    separator_height = 2 + +    # Padding between text and separator. +    padding = 8 + +    # Horizontal padding. +    horizontal_padding = 8 + +    # Padding between text and icon. +    text_icon_padding = 0 + +    # Defines width in pixels of frame around the notification window. +    # Set to 0 to disable. +    frame_width = 3 + +    # Defines color of the frame around the notification window. +    frame_color = "#aaaaaa" + +    # Define a color for the separator. +    # possible values are: +    #  * auto: dunst tries to find a color fitting to the background; +    #  * foreground: use the same color as the foreground; +    #  * frame: use the same color as the frame; +    #  * anything else will be interpreted as a X color. +    separator_color = frame + +    # Sort messages by urgency. +    sort = yes + +    # Don't remove messages, if the user is idle (no mouse or keyboard input) +    # for longer than idle_threshold seconds. +    # Set to 0 to disable. +    # A client can set the 'transient' hint to bypass this. See the rules +    # section for how to disable this if necessary +    idle_threshold = 120 + +    ### Text ### + +    font = Monospace 12 + +    # The spacing between lines.  If the height is smaller than the +    # font height, it will get raised to the font height. +    line_height = 0 + +    # Possible values are: +    # full: Allow a small subset of html markup in notifications: +    #        <b>bold</b> +    #        <i>italic</i> +    #        <s>strikethrough</s> +    #        <u>underline</u> +    # +    #        For a complete reference see +    #        <https://developer.gnome.org/pango/stable/pango-Markup.html>. +    # +    # strip: This setting is provided for compatibility with some broken +    #        clients that send markup even though it's not enabled on the +    #        server. Dunst will try to strip the markup but the parsing is +    #        simplistic so using this option outside of matching rules for +    #        specific applications *IS GREATLY DISCOURAGED*. +    # +    # no:    Disable markup parsing, incoming notifications will be treated as +    #        plain text. Dunst will not advertise that it has the body-markup +    #        capability if this is set as a global setting. +    # +    # It's important to note that markup inside the format option will be parsed +    # regardless of what this is set to. +    markup = full + +    # The format of the message.  Possible variables are: +    #   %a  appname +    #   %s  summary +    #   %b  body +    #   %i  iconname (including its path) +    #   %I  iconname (without its path) +    #   %p  progress value if set ([  0%] to [100%]) or nothing +    #   %n  progress value if set without any extra characters +    #   %%  Literal % +    # Markup is allowed +    format = "<b>%s</b>\n%b" + +    # Alignment of message text. +    # Possible values are "left", "center" and "right". +    alignment = left + +    # Vertical alignment of message text and icon. +    # Possible values are "top", "center" and "bottom". +    vertical_alignment = center + +    # Show age of message if message is older than show_age_threshold +    # seconds. +    # Set to -1 to disable. +    show_age_threshold = 60 + +    # Split notifications into multiple lines if they don't fit into +    # geometry. +    word_wrap = yes + +    # When word_wrap is set to no, specify where to make an ellipsis in long lines. +    # Possible values are "start", "middle" and "end". +    ellipsize = middle + +    # Ignore newlines '\n' in notifications. +    ignore_newline = no + +    # Stack together notifications with the same content +    stack_duplicates = true + +    # Hide the count of stacked notifications with the same content +    hide_duplicate_count = false + +    # Display indicators for URLs (U) and actions (A). +    show_indicators = yes + +    ### Icons ### + +    # Align icons left/right/off +    icon_position = left + +    # Scale small icons up to this size, set to 0 to disable. Helpful +    # for e.g. small files or high-dpi screens. In case of conflict, +    # max_icon_size takes precedence over this. +    min_icon_size = 0 + +    # Scale larger icons down to this size, set to 0 to disable +    max_icon_size = 32 + +    # Paths to default icons. +    icon_path = /usr/share/icons/gnome/16x16/status/:/usr/share/icons/gnome/16x16/devices/ + +    ### History ### + +    # Should a notification popped up from history be sticky or timeout +    # as if it would normally do. +    sticky_history = yes + +    # Maximum amount of notifications kept in history +    history_length = 20 + +    ### Misc/Advanced ### + +    # dmenu path. +    dmenu = /usr/bin/dmenu -p dunst: + +    # Browser for opening urls in context menu. +    browser = /usr/bin/firefox -new-tab + +    # Always run rule-defined scripts, even if the notification is suppressed +    always_run_script = true + +    # Define the title of the windows spawned by dunst +    title = Dunst + +    # Define the class of the windows spawned by dunst +    class = Dunst + +    # Print a notification on startup. +    # This is mainly for error detection, since dbus (re-)starts dunst +    # automatically after a crash. +    startup_notification = false + +    # Manage dunst's desire for talking +    # Can be one of the following values: +    #  crit: Critical features. Dunst aborts +    #  warn: Only non-fatal warnings +    #  mesg: Important Messages +    #  info: all unimportant stuff +    # debug: all less than unimportant stuff +    verbosity = mesg + +    # Define the corner radius of the notification window +    # in pixel size. If the radius is 0, you have no rounded +    # corners. +    # The radius will be automatically lowered if it exceeds half of the +    # notification height to avoid clipping text and/or icons. +    corner_radius = 3 + +    # Ignore the dbus closeNotification message. +    # Useful to enforce the timeout set by dunst configuration. Without this +    # parameter, an application may close the notification sent before the +    # user defined timeout. +    ignore_dbusclose = false + +    ### Wayland ### +    # These settings are Wayland-specific. They have no effect when using X11 + +    # Uncomment this if you want to let notications appear under fullscreen +    # applications (default: overlay) +    # layer = top + +    # Set this to true to use X11 output on Wayland. +    force_xwayland = false + +    ### Legacy + +    # Use the Xinerama extension instead of RandR for multi-monitor support. +    # This setting is provided for compatibility with older nVidia drivers that +    # do not support RandR and using it on systems that support RandR is highly +    # discouraged. +    # +    # By enabling this setting dunst will not be able to detect when a monitor +    # is connected or disconnected which might break follow mode if the screen +    # layout changes. +    force_xinerama = false + +    ### mouse + +    # Defines list of actions for each mouse event +    # Possible values are: +    # * none: Don't do anything. +    # * do_action: If the notification has exactly one action, or one is marked as default, +    #              invoke it. If there are multiple and no default, open the context menu. +    # * close_current: Close current notification. +    # * close_all: Close all notifications. +    # These values can be strung together for each mouse event, and +    # will be executed in sequence. +    mouse_left_click = close_current +    mouse_middle_click = do_action, close_current +    mouse_right_click = close_all + +# Experimental features that may or may not work correctly. Do not expect them +# to have a consistent behaviour across releases. +[experimental] +    # Calculate the dpi to use on a per-monitor basis. +    # If this setting is enabled the Xft.dpi value will be ignored and instead +    # dunst will attempt to calculate an appropriate dpi value for each monitor +    # using the resolution and physical size. This might be useful in setups +    # where there are multiple screens with very different dpi values. +    per_monitor_dpi = true + +# The internal keyboard shortcut support in dunst is now considered deprecated +# and should be replaced by dunstctl calls. You can use the configuration of your +# WM or DE to bind these to shortcuts of your choice. +# Check the dunstctl manual page for more info. +[shortcuts] + +    # Shortcuts are specified as [modifier+][modifier+]...key +    # Available modifiers are "ctrl", "mod1" (the alt-key), "mod2", +    # "mod3" and "mod4" (windows-key). +    # Xev might be helpful to find names for keys. + +    # Close notification. Equivalent dunstctl command: +    # dunstctl close +    # close = ctrl+space + +    # Close all notifications. Equivalent dunstctl command: +    # dunstctl close-all +    # close_all = ctrl+shift+space + +    # Redisplay last message(s). Equivalent dunstctl command: +    # dunstctl history-pop +    # history = ctrl+grave + +    # Context menu. Equivalent dunstctl command: +    # dunstctl context +    # context = ctrl+shift+period + +[urgency_low] +    # IMPORTANT: colors have to be defined in quotation marks. +    # Otherwise the "#" and following would be interpreted as a comment. +    background = "#222222" +    foreground = "#888888" +    timeout = 10 +    # Icon for notifications with low urgency, uncomment to enable +    #icon = /path/to/icon + +[urgency_normal] +    background = "#285577" +    foreground = "#ffffff" +    timeout = 10 +    # Icon for notifications with normal urgency, uncomment to enable +    #icon = /path/to/icon + +[urgency_critical] +    background = "#900000" +    foreground = "#ffffff" +    frame_color = "#ff0000" +    timeout = 0 +    # Icon for notifications with critical urgency, uncomment to enable +    #icon = /path/to/icon + +# Every section that isn't one of the above is interpreted as a rules to +# override settings for certain messages. +# +# Messages can be matched by +#    appname (discouraged, see desktop_entry) +#    body +#    category +#    desktop_entry +#    icon +#    match_transient +#    msg_urgency +#    stack_tag +#    summary +# +# and you can override the +#    background +#    foreground +#    format +#    frame_color +#    fullscreen +#    new_icon +#    set_stack_tag +#    set_transient +#    timeout +#    urgency +# +# Shell-like globbing will get expanded. +# +# Instead of the appname filter, it's recommended to use the desktop_entry filter. +# GLib based applications export their desktop-entry name. In comparison to the appname, +# the desktop-entry won't get localized. +# +# SCRIPTING +# You can specify a script that gets run when the rule matches by +# setting the "script" option. +# The script will be called as follows: +#   script appname summary body icon urgency +# where urgency can be "LOW", "NORMAL" or "CRITICAL". +# +# NOTE: if you don't want a notification to be displayed, set the format +# to "". +# NOTE: It might be helpful to run dunst -print in a terminal in order +# to find fitting options for rules. + +# Disable the transient hint so that idle_threshold cannot be bypassed from the +# client +#[transient_disable] +#    match_transient = yes +#    set_transient = no +# +# Make the handling of transient notifications more strict by making them not +# be placed in history. +#[transient_history_ignore] +#    match_transient = yes +#    history_ignore = yes + +# fullscreen values +# show: show the notifications, regardless if there is a fullscreen window opened +# delay: displays the new notification, if there is no fullscreen window active +#        If the notification is already drawn, it won't get undrawn. +# pushback: same as delay, but when switching into fullscreen, the notification will get +#           withdrawn from screen again and will get delayed like a new notification +#[fullscreen_delay_everything] +#    fullscreen = delay +#[fullscreen_show_critical] +#    msg_urgency = critical +#    fullscreen = show + +#[espeak] +#    summary = "*" +#    script = dunst_espeak.sh + +#[script-test] +#    summary = "*script*" +#    script = dunst_test.sh + +#[ignore] +#    # This notification will not be displayed +#    summary = "foobar" +#    format = "" + +#[history-ignore] +#    # This notification will not be saved in history +#    summary = "foobar" +#    history_ignore = yes + +#[skip-display] +#    # This notification will not be displayed, but will be included in the history +#    summary = "foobar" +#    skip_display = yes + +#[signed_on] +#    appname = Pidgin +#    summary = "*signed on*" +#    urgency = low +# +#[signed_off] +#    appname = Pidgin +#    summary = *signed off* +#    urgency = low +# +#[says] +#    appname = Pidgin +#    summary = *says* +#    urgency = critical +# +#[twitter] +#    appname = Pidgin +#    summary = *twitter.com* +#    urgency = normal +# +#[stack-volumes] +#    appname = "some_volume_notifiers" +#    set_stack_tag = "volume" +# +# vim: ft=cfg diff --git a/.config/fish/config.fish b/.config/fish/config.fish new file mode 100644 index 0000000..4b9b740 --- /dev/null +++ b/.config/fish/config.fish @@ -0,0 +1,25 @@ +# if status is-interactive +    # Commands to run in interactive sessions can go here +# end + +# Disable fish greeting +set fish_greeting + + +# Aliases +alias ..='cd ..' +alias ...='cd ../..' + +alias yt="youtube-dl -f bestvideo+bestaudio " +alias yt-audio="youtube-dl --extract-audio --audio-format best " +alias ls="exa" +alias config='/usr/bin/git --git-dir=$HOME/dotfiles/ --work-tree=$HOME' + +function sudo --description "Replacement for Bash 'sudo !!' command to run last command using sudo." +    if test "$argv" = !! +    eval command sudo $history[1] +else +    command sudo $argv +    end +end + diff --git a/.config/fish/fish_variables b/.config/fish/fish_variables new file mode 100644 index 0000000..1b4481a --- /dev/null +++ b/.config/fish/fish_variables @@ -0,0 +1,30 @@ +# This file contains fish universal variable definitions. +# VERSION: 3.0 +SETUVAR __fish_initialized:3100 +SETUVAR fish_color_autosuggestion:555\x1ebrblack +SETUVAR fish_color_cancel:\x2dr +SETUVAR fish_color_command:005fd7 +SETUVAR fish_color_comment:990000 +SETUVAR fish_color_cwd:green +SETUVAR fish_color_cwd_root:red +SETUVAR fish_color_end:009900 +SETUVAR fish_color_error:ff0000 +SETUVAR fish_color_escape:00a6b2 +SETUVAR fish_color_history_current:\x2d\x2dbold +SETUVAR fish_color_host:normal +SETUVAR fish_color_host_remote:yellow +SETUVAR fish_color_normal:normal +SETUVAR fish_color_operator:00a6b2 +SETUVAR fish_color_param:00afff +SETUVAR fish_color_quote:999900 +SETUVAR fish_color_redirection:00afff +SETUVAR fish_color_search_match:bryellow\x1e\x2d\x2dbackground\x3dbrblack +SETUVAR fish_color_selection:white\x1e\x2d\x2dbold\x1e\x2d\x2dbackground\x3dbrblack +SETUVAR fish_color_status:red +SETUVAR fish_color_user:brgreen +SETUVAR fish_color_valid_path:\x2d\x2dunderline +SETUVAR fish_key_bindings:fish_default_key_bindings +SETUVAR fish_pager_color_completion:\x1d +SETUVAR fish_pager_color_description:B3A06D\x1eyellow +SETUVAR fish_pager_color_prefix:normal\x1e\x2d\x2dbold\x1e\x2d\x2dunderline +SETUVAR fish_pager_color_progress:brwhite\x1e\x2d\x2dbackground\x3dcyan diff --git a/.config/gtk-3.0/bookmarks b/.config/gtk-3.0/bookmarks new file mode 100644 index 0000000..5b0268c --- /dev/null +++ b/.config/gtk-3.0/bookmarks @@ -0,0 +1 @@ +sftp://yui@hirasawa.moe:69/ hirasawa diff --git a/.config/gtk-3.0/settings.ini b/.config/gtk-3.0/settings.ini new file mode 100644 index 0000000..b3000bc --- /dev/null +++ b/.config/gtk-3.0/settings.ini @@ -0,0 +1,15 @@ +[Settings] +gtk-theme-name=Arc-Dark +gtk-icon-theme-name=Arc +gtk-font-name=Cantarell 11 +gtk-cursor-theme-name=Breeze +gtk-cursor-theme-size=32 +gtk-toolbar-style=GTK_TOOLBAR_BOTH_HORIZ +gtk-toolbar-icon-size=GTK_ICON_SIZE_LARGE_TOOLBAR +gtk-button-images=0 +gtk-menu-images=0 +gtk-enable-event-sounds=1 +gtk-enable-input-feedback-sounds=1 +gtk-xft-antialias=1 +gtk-xft-hinting=1 +gtk-xft-hintstyle=hintmedium diff --git a/.config/picom.conf b/.config/picom.conf new file mode 100644 index 0000000..7a92a5d --- /dev/null +++ b/.config/picom.conf @@ -0,0 +1,425 @@ +################################# +#             Shadows           # +################################# + + +# Enabled client-side shadows on windows. Note desktop windows  +# (windows with '_NET_WM_WINDOW_TYPE_DESKTOP') never get shadow,  +# unless explicitly requested using the wintypes option. +# +# shadow = false +shadow = true; + +# The blur radius for shadows, in pixels. (defaults to 12) +# shadow-radius = 12 +shadow-radius = 7; + +# The opacity of shadows. (0.0 - 1.0, defaults to 0.75) +# shadow-opacity = .75 + +# The left offset for shadows, in pixels. (defaults to -15) +# shadow-offset-x = -15 +shadow-offset-x = -7; + +# The top offset for shadows, in pixels. (defaults to -15) +# shadow-offset-y = -15 +shadow-offset-y = -7; + +# Avoid drawing shadows on dock/panel windows. This option is deprecated, +# you should use the *wintypes* option in your config file instead. +# +# no-dock-shadow = false + +# Don't draw shadows on drag-and-drop windows. This option is deprecated,  +# you should use the *wintypes* option in your config file instead. +# +# no-dnd-shadow = false + +# Red color value of shadow (0.0 - 1.0, defaults to 0). +# shadow-red = 0 + +# Green color value of shadow (0.0 - 1.0, defaults to 0). +# shadow-green = 0 + +# Blue color value of shadow (0.0 - 1.0, defaults to 0). +# shadow-blue = 0 + +# Do not paint shadows on shaped windows. Note shaped windows  +# here means windows setting its shape through X Shape extension.  +# Those using ARGB background is beyond our control.  +# Deprecated, use  +#   shadow-exclude = 'bounding_shaped' +# or  +#   shadow-exclude = 'bounding_shaped && !rounded_corners' +# instead. +# +# shadow-ignore-shaped = '' + +# Specify a list of conditions of windows that should have no shadow. +# +# examples: +#   shadow-exclude = "n:e:Notification"; +# +# shadow-exclude = [] +shadow-exclude = [ +  "name = 'Notification'", +  "class_g = 'Conky'", +  "class_g = 'slop'", +  "class_g ?= 'Notify-osd'", +  "class_g = 'Cairo-clock'", +  "_GTK_FRAME_EXTENTS@:c" +]; + +# Specify a X geometry that describes the region in which shadow should not +# be painted in, such as a dock window region. Use  +#    shadow-exclude-reg = "x10+0+0" +# for example, if the 10 pixels on the bottom of the screen should not have shadows painted on. +# +# shadow-exclude-reg = ""  + +# Crop shadow of a window fully on a particular Xinerama screen to the screen. +# xinerama-shadow-crop = false + + +################################# +#           Fading              # +################################# + + +# Fade windows in/out when opening/closing and when opacity changes, +#  unless no-fading-openclose is used. +# fading = false +fading = true + +# Opacity change between steps while fading in. (0.01 - 1.0, defaults to 0.028) +# fade-in-step = 0.028 +fade-in-step = 0.06; + +# Opacity change between steps while fading out. (0.01 - 1.0, defaults to 0.03) +# fade-out-step = 0.03 +fade-out-step = 0.06; + +# The time between steps in fade step, in milliseconds. (> 0, defaults to 10) +# fade-delta = 10 + +# Specify a list of conditions of windows that should not be faded. +# fade-exclude = [] + +# Do not fade on window open/close. +# no-fading-openclose = false + +# Do not fade destroyed ARGB windows with WM frame. Workaround of bugs in Openbox, Fluxbox, etc. +# no-fading-destroyed-argb = false + + +################################# +#   Transparency / Opacity      # +################################# + + +# Opacity of inactive windows. (0.1 - 1.0, defaults to 1.0) +# inactive-opacity = 1 +inactive-opacity = 0.8; + +# Opacity of window titlebars and borders. (0.1 - 1.0, disabled by default) +# frame-opacity = 1.0 +frame-opacity = 0.7; + +# Default opacity for dropdown menus and popup menus. (0.0 - 1.0, defaults to 1.0) +# menu-opacity = 1.0 + +# Let inactive opacity set by -i override the '_NET_WM_OPACITY' values of windows. +# inactive-opacity-override = true +inactive-opacity-override = false; + +# Default opacity for active windows. (0.0 - 1.0, defaults to 1.0) +# active-opacity = 1.0 + +# Dim inactive windows. (0.0 - 1.0, defaults to 0.0) +# inactive-dim = 0.0 + +# Specify a list of conditions of windows that should always be considered focused. +# focus-exclude = [] +focus-exclude = [ "class_g = 'Cairo-clock'" ]; + +# Use fixed inactive dim value, instead of adjusting according to window opacity. +# inactive-dim-fixed = 1.0 + +# Specify a list of opacity rules, in the format `PERCENT:PATTERN`,  +# like `50:name *= "Firefox"`. picom-trans is recommended over this.  +# Note we don't make any guarantee about possible conflicts with other  +# programs that set '_NET_WM_WINDOW_OPACITY' on frame or client windows. +# example: +#    opacity-rule = [ "80:class_g = 'URxvt'" ]; +# +# opacity-rule = [] +opacity-rule = [ "92:class_g = 'Deadbeef'" ]; + + +################################# +#     Background-Blurring       # +################################# + + +# Parameters for background blurring, see the *BLUR* section for more information. +# blur-method =  +# blur-size = 12 +# +# blur-deviation = false + +# Blur background of semi-transparent / ARGB windows.  +# Bad in performance, with driver-dependent behavior.  +# The name of the switch may change without prior notifications. +# +# blur-background = false + +# Blur background of windows when the window frame is not opaque.  +# Implies: +#    blur-background  +# Bad in performance, with driver-dependent behavior. The name may change. +# +# blur-background-frame = false + + +# Use fixed blur strength rather than adjusting according to window opacity. +# blur-background-fixed = false + + +# Specify the blur convolution kernel, with the following format: +# example: +#   blur-kern = "5,5,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1"; +# +# blur-kern = '' +blur-kern = "3x3box"; + + +# Exclude conditions for background blur. +# blur-background-exclude = [] +blur-background-exclude = [ +  "window_type = 'dock'", +  "window_type = 'desktop'", +  "_GTK_FRAME_EXTENTS@:c" +]; + +################################# +#       General Settings        # +################################# + +# Daemonize process. Fork to background after initialization. Causes issues with certain (badly-written) drivers. +# daemon = false + +# Specify the backend to use: `xrender`, `glx`, or `xr_glx_hybrid`. +# `xrender` is the default one. +# +backend = "glx" +#backend = "xrender"; + +# Enable/disable VSync. +# vsync = false +vsync = true + +# Enable remote control via D-Bus. See the *D-BUS API* section below for more details. +# dbus = false + +# Try to detect WM windows (a non-override-redirect window with no  +# child that has 'WM_STATE') and mark them as active. +# +# mark-wmwin-focused = false +mark-wmwin-focused = true; + +# Mark override-redirect windows that doesn't have a child window with 'WM_STATE' focused. +# mark-ovredir-focused = false +mark-ovredir-focused = true; + +# Try to detect windows with rounded corners and don't consider them  +# shaped windows. The accuracy is not very high, unfortunately. +# +# detect-rounded-corners = false +detect-rounded-corners = true; + +# Detect '_NET_WM_OPACITY' on client windows, useful for window managers +# not passing '_NET_WM_OPACITY' of client windows to frame windows. +# +# detect-client-opacity = false +detect-client-opacity = true; + +# Specify refresh rate of the screen. If not specified or 0, picom will  +# try detecting this with X RandR extension. +# +# refresh-rate = 60 +refresh-rate = 0 + +# Limit picom to repaint at most once every 1 / 'refresh_rate' second to  +# boost performance. This should not be used with  +#   vsync drm/opengl/opengl-oml +# as they essentially does sw-opti's job already,  +# unless you wish to specify a lower refresh rate than the actual value. +# +# sw-opti =  + +# Use EWMH '_NET_ACTIVE_WINDOW' to determine currently focused window,  +# rather than listening to 'FocusIn'/'FocusOut' event. Might have more accuracy,  +# provided that the WM supports it. +# +# use-ewmh-active-win = false + +# Unredirect all windows if a full-screen opaque window is detected,  +# to maximize performance for full-screen windows. Known to cause flickering  +# when redirecting/unredirecting windows. +# +#unredir-if-possible = false + +# Delay before unredirecting the window, in milliseconds. Defaults to 0. +# unredir-if-possible-delay = 0 + +# Conditions of windows that shouldn't be considered full-screen for unredirecting screen. +# unredir-if-possible-exclude = [] + +# Use 'WM_TRANSIENT_FOR' to group windows, and consider windows  +# in the same group focused at the same time. +# +# detect-transient = false +detect-transient = true + +# Use 'WM_CLIENT_LEADER' to group windows, and consider windows in the same  +# group focused at the same time. 'WM_TRANSIENT_FOR' has higher priority if  +# detect-transient is enabled, too. +# +# detect-client-leader = false +detect-client-leader = true + +# Resize damaged region by a specific number of pixels.  +# A positive value enlarges it while a negative one shrinks it.  +# If the value is positive, those additional pixels will not be actually painted  +# to screen, only used in blur calculation, and such. (Due to technical limitations,  +# with use-damage, those pixels will still be incorrectly painted to screen.)  +# Primarily used to fix the line corruption issues of blur,  +# in which case you should use the blur radius value here  +# (e.g. with a 3x3 kernel, you should use `--resize-damage 1`,  +# with a 5x5 one you use `--resize-damage 2`, and so on).  +# May or may not work with *--glx-no-stencil*. Shrinking doesn't function correctly. +# +# resize-damage = 1 + +# Specify a list of conditions of windows that should be painted with inverted color.  +# Resource-hogging, and is not well tested. +# +# invert-color-include = [] + +# GLX backend: Avoid using stencil buffer, useful if you don't have a stencil buffer.  +# Might cause incorrect opacity when rendering transparent content (but never  +# practically happened) and may not work with blur-background.  +# My tests show a 15% performance boost. Recommended. +# +# glx-no-stencil = false + +# GLX backend: Avoid rebinding pixmap on window damage.  +# Probably could improve performance on rapid window content changes,  +# but is known to break things on some drivers (LLVMpipe, xf86-video-intel, etc.). +# Recommended if it works. +# +# glx-no-rebind-pixmap = false + +# Disable the use of damage information.  +# This cause the whole screen to be redrawn everytime, instead of the part of the screen +# has actually changed. Potentially degrades the performance, but might fix some artifacts. +# The opposing option is use-damage +# +# no-use-damage = false +use-damage = true + +# Use X Sync fence to sync clients' draw calls, to make sure all draw  +# calls are finished before picom starts drawing. Needed on nvidia-drivers  +# with GLX backend for some users. +# +# xrender-sync-fence = false + +# GLX backend: Use specified GLSL fragment shader for rendering window contents.  +# See `compton-default-fshader-win.glsl` and `compton-fake-transparency-fshader-win.glsl`  +# in the source tree for examples. +# +# glx-fshader-win = '' + +# Force all windows to be painted with blending. Useful if you  +# have a glx-fshader-win that could turn opaque pixels transparent. +# +# force-win-blend = false + +# Do not use EWMH to detect fullscreen windows.  +# Reverts to checking if a window is fullscreen based only on its size and coordinates. +# +# no-ewmh-fullscreen = false + +# Dimming bright windows so their brightness doesn't exceed this set value.  +# Brightness of a window is estimated by averaging all pixels in the window,  +# so this could comes with a performance hit.  +# Setting this to 1.0 disables this behaviour. Requires --use-damage to be disabled. (default: 1.0) +# +# max-brightness = 1.0 + +# Make transparent windows clip other windows like non-transparent windows do, +# instead of blending on top of them. +# +# transparent-clipping = false + +# Set the log level. Possible values are: +#  "trace", "debug", "info", "warn", "error" +# in increasing level of importance. Case doesn't matter.  +# If using the "TRACE" log level, it's better to log into a file  +# using *--log-file*, since it can generate a huge stream of logs. +# +# log-level = "debug" +log-level = "warn"; + +# Set the log file. +# If *--log-file* is never specified, logs will be written to stderr.  +# Otherwise, logs will to written to the given file, though some of the early  +# logs might still be written to the stderr.  +# When setting this option from the config file, it is recommended to use an absolute path. +# +# log-file = '/path/to/your/log/file' + +# Show all X errors (for debugging) +# show-all-xerrors = false + +# Write process ID to a file. +# write-pid-path = '/path/to/your/log/file' + +# Window type settings +#  +# 'WINDOW_TYPE' is one of the 15 window types defined in EWMH standard:  +#     "unknown", "desktop", "dock", "toolbar", "menu", "utility",  +#     "splash", "dialog", "normal", "dropdown_menu", "popup_menu",  +#     "tooltip", "notification", "combo", and "dnd". +#  +# Following per window-type options are available: :: +#  +#   fade, shadow::: +#     Controls window-type-specific shadow and fade settings. +#  +#   opacity::: +#     Controls default opacity of the window type. +#  +#   focus::: +#     Controls whether the window of this type is to be always considered focused.  +#     (By default, all window types except "normal" and "dialog" has this on.) +#  +#   full-shadow::: +#     Controls whether shadow is drawn under the parts of the window that you  +#     normally won't be able to see. Useful when the window has parts of it  +#     transparent, and you want shadows in those areas. +#  +#   redir-ignore::: +#     Controls whether this type of windows should cause screen to become  +#     redirected again after been unredirected. If you have unredir-if-possible +#     set, and doesn't want certain window to cause unnecessary screen redirection,  +#     you can set this to `true`. +# +wintypes: +{ +  tooltip = { fade = true; shadow = true; opacity = 0.90; focus = true; full-shadow = false; }; +  dock = { shadow = false; } +  dnd = { shadow = false; } +  popup_menu = { opacity = 0.9; } +  dropdown_menu = { opacity = 0.9; } +}; diff --git a/.config/qtile/__pycache__/config.cpython-39.pyc b/.config/qtile/__pycache__/config.cpython-39.pycBinary files differ new file mode 100644 index 0000000..73a3383 --- /dev/null +++ b/.config/qtile/__pycache__/config.cpython-39.pyc diff --git a/.config/qtile/autostart.sh b/.config/qtile/autostart.sh new file mode 100755 index 0000000..b91e584 --- /dev/null +++ b/.config/qtile/autostart.sh @@ -0,0 +1,17 @@ +#!/bin/sh + +# Window positions from ARandR +#xrandr --output DVI-D-1 --off --output DP-1 --mode 3840x2160 --pos 4480x0 --rotate normal --output DP-2 --primary --mode 2560x1440 --pos 1920x0 --rotate normal --output HDMI-1 --off --output DP-3 --mode 1920x1080 --pos 0x0 --rotate normal & +#/home/yui/layout.sh + +xrdb -merge ~/.Xresources +numlockx on & +lxsession & +picom & +nitrogen --restore & +volumeicon & +nm-applet & +#ibus-daemon -drxR & +fcitx & +xset s off -dpms +xscreensaver -no-splash & diff --git a/.config/qtile/config.py b/.config/qtile/config.py new file mode 100644 index 0000000..bc1a7f2 --- /dev/null +++ b/.config/qtile/config.py @@ -0,0 +1,240 @@ +# Copyright (c) 2010 Aldo Cortesi +# Copyright (c) 2010, 2014 dequis +# Copyright (c) 2012 Randall Ma +# Copyright (c) 2012-2014 Tycho Andersen +# Copyright (c) 2012 Craig Barnes +# Copyright (c) 2013 horsik +# Copyright (c) 2013 Tao Sauvage +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. +import os +import subprocess +from typing import List  # noqa: F401 + +from libqtile import bar, layout, widget, hook  +from libqtile.config import Click, Drag, Group, Key, Match, Screen +from libqtile.lazy import lazy +#from libqtile.utils import guess_terminal + +mod = "mod4" +#terminal = guess_terminal() +terminal = "alacritty" +selector =  "rofi -show drun -show-icons -theme 'Arc-Dark'" +weather_location = "Melbourne" +slimeshot = "/home/yui/Scripts/slimeshot.sh/slimeshot.sh" + +@hook.subscribe.startup_complete +def fix_screen_groups(): +    lazy.group['1'].toscreen(1) +    lazy.group['2'].toscreen(0) +    lazy.group['3'].toscreen(2) + +keys = [ +    # Switch between windows +    Key([mod], "Left", lazy.layout.left(), desc="Move focus to left"), +    Key([mod], "Right", lazy.layout.right(), desc="Move focus to right"), +    Key([mod], "Down", lazy.layout.down(), desc="Move focus down"), +    Key([mod], "Up", lazy.layout.up(), desc="Move focus up"), +    Key([mod], "z", lazy.layout.next(), +        desc="Move window focus to other window"), + +    # Move windows between left/right columns or move up/down in current stack. +    # Moving out of range in Columns layout will create new column. +    Key([mod, "shift"], "Left", lazy.layout.shuffle_left(), +        desc="Move window to the left"), +    Key([mod, "shift"], "Right", lazy.layout.shuffle_right(), +        desc="Move window to the right"), +    Key([mod, "shift"], "Down", lazy.layout.shuffle_down(), +        desc="Move window down"), +    Key([mod, "shift"], "Up", lazy.layout.shuffle_up(), desc="Move window up"), + +    # Grow windows. If current window is on the edge of screen and direction +    # will be to screen edge - window would shrink. +    Key([mod, "control"], "Left", lazy.layout.grow_left(), +        desc="Grow window to the left"), +    Key([mod, "control"], "Right", lazy.layout.grow_right(), +        desc="Grow window to the right"), +    Key([mod, "control"], "Down", lazy.layout.grow_down(), +        desc="Grow window down"), +    Key([mod, "control"], "Up", lazy.layout.grow_up(), desc="Grow window up"), +    Key([mod, "control"], "n", lazy.layout.normalize(), desc="Reset all window sizes"), + + +    Key([mod, "control"], "1", +        lazy.to_screen(1), +        desc='Keyboard focus to monitor 1' +        ), +    Key([mod, "control"], "2", +        lazy.to_screen(0), +        desc='Keyboard focus to monitor 2' +        ), +    Key([mod, "control"], "3", +        lazy.to_screen(2), +        desc='Keyboard focus to monitor 3' +        ), + + +    # Toggle between split and unsplit sides of stack. +    # Split = all windows displayed +    # Unsplit = 1 window displayed, like Max layout, but still with +    # multiple stack panes +    Key([mod, "shift"], "Return", lazy.layout.toggle_split(), +        desc="Toggle between split and unsplit sides of stack"), +    Key([mod], "Return", lazy.spawn(terminal), desc="Launch terminal"), + +    Key([mod], "space", lazy.window.toggle_floating(), desc='Toggle floating'), + +    # Toggle between different layouts as defined below +    Key([mod], "Tab", lazy.next_layout(), desc="Toggle between layouts"), +    Key([mod], "q", lazy.window.kill(), desc="Kill focused window"), + +    Key([mod, "control"], "r", lazy.restart(), desc="Restart Qtile"), +    Key([mod, "control"], "q", lazy.shutdown(), desc="Shutdown Qtile"), +    Key([mod], "r", lazy.spawncmd(), +        desc="Spawn a command using a prompt widget"), + +    Key([mod], "Return", lazy.spawn(terminal), desc="Launch terminal"), +    Key([mod], "d", lazy.spawn(selector), desc="Launch rofi"), +    Key([mod], "f", lazy.spawn("firefox"), desc="Launch firefox"), +    Key([mod], "e", lazy.spawn("/home/yui/Scripts/emoji.sh"), desc="Launch a emoji rofi"), + + +    Key([mod], "b", lazy.hide_show_bar("top")), + +    Key(["control"], "Print", lazy.spawn(f"{slimeshot}")), +    Key([mod, "control"], "Print", lazy.spawn(f"{slimeshot} l")), +    Key(["control", "shift"], "Print", lazy.spawn(f"{slimeshot} c")), +    Key([mod], "j",  lazy.group['1'].toscreen(1), lazy.group['2'].toscreen(0), lazy.group['3'].toscreen(2)), + +] + +group_labels = "零壱弐参四伍六七八九" +groups = [Group(i, label=group_labels[int(i)]) for i in "123456789"] + +for i in groups: +    keys.append(Key([mod], i.name, lazy.group[i.name].toscreen()))        # Switch to another group +    keys.append(Key([mod, "shift"], i.name, lazy.window.togroup(i.name))) # Send current window to another group + +layout_theme = {"border_width": 2, +                "margin": 8, +                "border_focus": "e1acff", +                "border_normal": "1D2330" +                } + +layouts = [ +    #layout.Columns(border_focus_stack='#d75f5f'), +    layout.Max(**layout_theme, name="全"), +    # Try more layouts by unleashing below layouts. +    # layout.Stack(num_stacks=2), +    # layout.Bsp(), +    # layout.Matrix(), +     layout.MonadTall(**layout_theme, name=">>="), +    # layout.MonadWide(), +    # layout.RatioTile(), +    # layout.Tile(), +    # layout.TreeTab(), +    # layout.VerticalTile(), +    # layout.Zoomy(), +] + +widget_defaults = dict( +    font='IBM Plex Sans', +    fontsize=16, +    padding=4, +) +extension_defaults = widget_defaults.copy() + + +def generate_widgets(side=False): +    main_widgets = [ +        widget.CurrentLayout(), +        widget.GroupBox(highlight_method="border", this_current_screen_border="8981e1", this_screen_border="888888"), +        widget.Prompt(), +        widget.WindowTabs(), +        widget.GenPollUrl(url=f"https://wttr.in/{weather_location}?format=1", json=False, update_interval=600, parse=lambda x: x.replace("+", "").strip()), +        widget.GenPollUrl(url="https://hirasawa.moe/vax.txt", json=False, update_interval=3600, parse=lambda x: x.decode("UTF-8").split("\t")[1]), +        #widget.GenPollUrl(url=f"https://hirasawa.moe/vax.txt", json=False, update_interval=3600, parse=lambda x: x.split("\t")[1]), +        widget.Systray(), +        widget.Clock(format='%m月%d日 %a %H:%M'), +    ] +    side_widgets = [ +        widget.CurrentLayout(), +        widget.GroupBox(highlight_method="border", this_current_screen_border="8981e1", this_screen_border="888888"), +        widget.WindowTabs(), +        widget.Clock(format='%m月%d日 %a %H:%M'), +    ] +    return side_widgets if side else main_widgets + + +screens = [ +    Screen(top=bar.Bar(generate_widgets(), 30)), +    Screen(top=bar.Bar(generate_widgets(side=True), 30)), +    Screen(top=bar.Bar(generate_widgets(side=True), 30)), +] + + +# Drag floating layouts. +mouse = [ +    Drag([mod], "Button1", lazy.window.set_position_floating(), +         start=lazy.window.get_position()), +    Drag([mod], "Button3", lazy.window.set_size_floating(), +         start=lazy.window.get_size()), +    Click([mod], "Button2", lazy.window.bring_to_front()) +] + +dgroups_key_binder = None +dgroups_app_rules = []  # type: List +follow_mouse_focus = True +bring_front_click = False +cursor_warp = False +floating_layout = layout.Floating(float_rules=[ +    # Run the utility of `xprop` to see the wm class and name of an X client. +    *layout.Floating.default_float_rules, +    Match(wm_class='confirmreset'),  # gitk +    Match(wm_class='makebranch'),  # gitk +    Match(wm_class='maketag'),  # gitk +    Match(wm_class='kdenlive'),  # kdenlive +    Match(wm_class='ssh-askpass'),  # ssh-askpass +    Match(title='branchdialog'),  # gitk +    Match(title='pinentry'),  # GPG key password entry +]) +auto_fullscreen = True +focus_on_window_activation = "smart" +reconfigure_screens = True + +# If things like steam games want to auto-minimize themselves when losing +# focus, should we respect this or not? +auto_minimize = False + + +@hook.subscribe.startup_once +def start_once(): +        home = os.path.expanduser('~') +        subprocess.call([home + '/.config/qtile/autostart.sh']) +  + +# XXX: Gasp! We're lying here. In fact, nobody really uses or cares about this +# string besides java UI toolkits; you can see several discussions on the +# mailing lists, GitHub issues, and other WM documentation that suggest setting +# this string if your java app doesn't work correctly. We may as well just lie +# and say that we're a working one by default. +# +# We choose LG3D to maximize irony: it is a 3D non-reparenting WM written in +# java that happens to be on java's whitelist. +wmname = "LG3D" diff --git a/.config/qtile/picom.log b/.config/qtile/picom.log new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/.config/qtile/picom.log diff --git a/.gtkrc-2.0 b/.gtkrc-2.0 new file mode 100644 index 0000000..ef24ff0 --- /dev/null +++ b/.gtkrc-2.0 @@ -0,0 +1,18 @@ +# DO NOT EDIT! This file will be overwritten by LXAppearance. +# Any customization should be done in ~/.gtkrc-2.0.mine instead. + +include "/home/yui/.gtkrc-2.0.mine" +gtk-theme-name="Arc-Dark" +gtk-icon-theme-name="Arc" +gtk-font-name="Cantarell 11" +gtk-cursor-theme-name="Breeze" +gtk-cursor-theme-size=32 +gtk-toolbar-style=GTK_TOOLBAR_BOTH_HORIZ +gtk-toolbar-icon-size=GTK_ICON_SIZE_LARGE_TOOLBAR +gtk-button-images=0 +gtk-menu-images=0 +gtk-enable-event-sounds=1 +gtk-enable-input-feedback-sounds=1 +gtk-xft-antialias=1 +gtk-xft-hinting=1 +gtk-xft-hintstyle="hintmedium" diff --git a/.xprofile b/.xprofile new file mode 100644 index 0000000..298befc --- /dev/null +++ b/.xprofile @@ -0,0 +1,5 @@ +export QT_QPA_PLATFORMTHEME=qt5ct +export GTK_IM_MODULE='fcitx' +export QT_IM_MODULE='fcitx' +export XMODIFIERS=@im='fcitx' +udiskie & | 
