Skip to content

Latest commit

 

History

History
138 lines (98 loc) · 5.33 KB

README.md

File metadata and controls

138 lines (98 loc) · 5.33 KB

nixos-config

This repository contains my working environment config. It consists of:

  1. nixos config (placed in nixos/, home-manager/ & shared/)
  2. dotfiles (placed in dotfiles/)

It thoroughly defines every single tweak that I've made to any program that's running on my machine.

Features

Preview Image

The whole OS is centered around Catppuccin Mocha Mauve theme. Lots of applications are configured to match this color pallete, some examples include:

  • shell - zsh,
  • desktop environment - hyprland,
  • code editor - neovim,
  • app launcher - rofi,
  • bar / desktop widgets - eww,
  • and much more!

Other than that, this config is also integrated with catppuccin/nix; which regularly adds support for more apps.

Usage

  • SUPER + S / Print Screen - Screenshot,
  • SUPER + R - App Launcher,
  • SUPER + W - Change Wallpaper,
  • SUPER + A - Lock,
  • SUPER + E - Toggle Window Split (Horizontal / Vertical),
  • SUPER + F - Start Browser,
  • SUPER + T - Start Terminal,
  • SUPER + L - Change Workspace (Direction: Right),
  • SUPER + H - Change Workspace (Direction: Left),
  • SUPER + Q - Kill Active Window,
  • SUPER + V - Make Active Window Float,
  • SUPER + J - Fullscreen Active Window,
  • SUPER + RMB - Resize Active Window,
  • SUPER + LMB - Move Active Window,
  • CTRL + L - Change Workspace With Active Window (Direction: Right),
  • CTRL + H - Change Workspace With Active Window (Direction: Left),

Neovim

Checkout dotfiles/.config/nvim/README.md. It covers those topics:

  1. Keybindings
  2. Plugins
  3. Language Support
  4. Code Formatting

Shell

For every detail, see home-manager/modules/packages/shell.

TL;DR: you can accept autosuggestions using 'a, and exit insert mode with 'j.

If you have more questions, feel free to reach out to me!

Documentation

Every previously mentioned module (nixos/, home-manager/, shared/, dotfiles/) has it's own docs placed in <module_name>/README.md. If you're going to read them, the recommended order is:

  1. dotfiles/
  2. nixos/
  3. home-manager/
  4. shared/

If you're not familiar with Nix, checkout this page; in short, NixOS is a opinionated Linux distro which focuses on reproducibility. Nix is both a package manager, and a programming language at the same time.

Installation

You can setup this configuration in many different ways.

Using The Installer (install.sh)

I have written a minimal script for linking the dotfiles and switching to the NixOS configuration:

$ curl https://raw.githubusercontent.com/Khenziii/nixos-config/master/install.sh > install.sh && sudo chmod +x install.sh && sudo ./install.sh && rm -f install.sh

Tip

Running this script, requires having git and stow installed. If you're on NixOS, you can temporarily enter a shell session with them available using this command:

$ nix-shell -p git stow 

Tip

By default, the script shows a warning requesting the user to make sure that they want to proceed at startup. To override it, you can pass y as the first parameter when calling the script:

$ curl https://raw.githubusercontent.com/Khenziii/nixos-config/master/install.sh > install.sh && sudo chmod +x install.sh && sudo ./install.sh y && rm -f install.sh

Caution

curl'ing a file like this and executing it as root without necessary attention is extremely dangerous.

make sure to read the content of this script before running it!!! https://raw.githubusercontent.com/Khenziii/nixos-config/master/install.sh

Manually

If you don't want to run a random script originating from a random github repo (which is totally understandable, I'd be cautious too), you can execute the commands yourself:

$ git clone https://github.com/Khenziii/nixos-config
$ cd nixos-config
$ stow --no-folding --adopt -t ~ dotfiles
$ touch ~/.config/hypr/monitors.conf
$ touch ~/.config/hypr/workspaces.conf
$ sudo nixos-generate-config
$ sudo nixos-rebuild switch --flake ".#iusenixosbtw" --impure
$ home-manager switch --flake ".#khenzii"

monitors.conf and workspaces.conf are both files created by nwg-displays (output configuration utility). They're imported from hyprland.conf, so we create empty placeholders to avoid errors.

Remember, there's nothing stopping you from using the code however you like to! It's licensed under GPL-3.0. If you want to, you can use only the dotfiles like this:

$ git clone https://github.com/Khenziii/nixos-config
$ cd nixos-config
$ stow --no-folding --adopt -t ~ dotfiles
$ touch ~/.config/hypr/monitors.conf
$ touch ~/.config/hypr/workspaces.conf

The choice is up to you!