Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/itzalak/workspace

Dotfiles for development worspace
https://github.com/itzalak/workspace

awesomewm dotfiles linux macos nvim

Last synced: 3 months ago
JSON representation

Dotfiles for development worspace

Awesome Lists containing this project

README

        

# Workspace

Personal workspace mostly for development.

## Installation

- Install Arch Linux using [archinstall v2.5.2](https://github.com/archlinux/archinstall/tree/v2.5.2).
- MacOS installed via [brew](./installation/macos/brew/Brewfile)

Clone the workspace repository.

```shell
git clone https://github.com/itzalak/workspace.git
```

- Instructions for archlinux in [makefile](./installation/arch/makefile).
- Instructions for macOS in [makefile](./installation/macos/makefile) and [readme](./installation/macos/README.md).

## Awesomewm

Take look into [awesome readme](arch/.config/awesome/README.md)

## Configuration

### Color scheme

This setup is designed for integrating setting up the colorscheme for linux system and it is heavily dependent on
the `.Xresources` file, including `awesomewm`.

More information and details can be found in [decorator](terminal/.config/decorator), inside scripts can be
found for using a json color scheme file - I personally use [terminal.sexy](https://terminal.sexy/) - and
porting the result for `.Xresources` and other required formats.

It also works for macOS through `.Xresources` file, it configures mostly the terminals in that case, **WARN** the script
does not account for macOS usage.

### Zsh

Configuration for zsh can be found under [terminal folder](./terminal/) plus [arch folder](./arch) or [macos folder](./macos), specific os folders are required for correct functioning of the system like brew - and can it can be setup by allocating the files to the proper directory using [stow](https://www.gnu.org/software/stow/), symlink or just copying them.
There are two sets of stow folders to configure, they can be found under [terminal](./terminal/) and specific to OS.

Zsh framework configuration uses a self-installed, self-managed plugin manager called [zimfw](https://github.com/zimfw/zimfw) that will install itself and setup all needed plugins once zsh is started.
Plugin configuration can be found in the [.zimrc file](./terminal//.config/zsh/.zimrc).
A folder will automatically be created as `.zim` to store all required files for `zimfw`.

Global variable `ZDOTDIR` is defined under `./zshenv` as `$HOME/.config/zsh`. This tells zsh to look for further configurations files in that directory.
In `./zshrc` we load all configuration files within the `ZDOTDIR` directory ending in `*.zsh`. This is not required but it facilitates managing special configurations and settings.

Structure

```shell
.
├── .config
│ └── zsh
│ ├── 00-path.zsh
│ ├── 02-aliases.zsh
│ ├── 04-history.zsh
│ ├── 05-git.zsh
│ ├── ..
│ ├── 99-starship.zsh
│ ├── .zimrc
│ └── .zshrc
└── .zshenv
```

## Gnome

For using a full gnome desktop create a new user and assign to wheel group.

```shell
useradd -m -G wheel -s /bin/bash {{user}}
sudo passwd {{user}}
```

For installation follow instructions in [makefile](./installation/arch/makefile) setup-gnome instead of setup-awesome.

## IDEA

Intellij IDEA community useful plugins:

- .ignore
- Emmylua
- Gherkin
- GraphQL
- Hiberbee Theme
- IdeaVim
- Makefile Language
- Python
- Rainbow Brackets Lite
- Terraform and HCL

## Issues

Some issues might arise while configuring this application, initializing submodules and cloning uses ssh and for it to
work ssh must be configured with github.