diff --git a/.github/workflows/docs.yaml b/.github/workflows/docs.yaml
new file mode 100644
index 0000000..06dc541
--- /dev/null
+++ b/.github/workflows/docs.yaml
@@ -0,0 +1,34 @@
+# by https://github.com/danth/stylix/blob/master/.github/workflows/docs.yml
+name: Docs
+on:
+ push:
+ branches:
+ - main
+jobs:
+ build:
+ name: Build
+ permissions:
+ contents: read
+ runs-on: nixos-latest
+ steps:
+ - name: Nix Config
+ run: |
+ mkdir -p $HOME/.config
+ mkdir -p $HOME/.config/nix
+ echo experimental-features = nix-command flakes pipe-operators >> $HOME/.config/nix/nix.conf
+ echo access-tokens = github.com=${{ secrets.GITHUBTOKEN }} >> $HOME/.config/nix/nix.conf
+ nix profile install nixpkgs#nodejs
+ - name: Build docs
+ run: nix -L build git+https://git.dashie.org/${{ forgejo.repository }}.git?rev=${{ forgejo.sha }}#docs --no-write-lock-file
+ - name: Prepare docs for upload
+ run: cp -r --dereference --no-preserve=mode,ownership result/ public/
+ # - name: Upload artifact
+ # uses: https://data.forgejo.org/forgejo/upload-artifact@v4
+ # with:
+ # path: public/
+ - name: Publish Page
+ uses: https://data.forgejo.org/actions/git-pages@v2
+ with:
+ site: https://username.pages.dashie.org/reponame/
+ token: ${{ forge.token }}
+ source: public/
diff --git a/.github/workflows/pr.yaml b/.github/workflows/pr.yaml
new file mode 100644
index 0000000..e92ddfd
--- /dev/null
+++ b/.github/workflows/pr.yaml
@@ -0,0 +1,35 @@
+# inspired by https://github.com/danth/stylix/blob/master/.github/workflows/docs.yml
+name: PR check
+on:
+ pull_request:
+ branches: ["main"]
+jobs:
+ build:
+ name: check
+ permissions:
+ contents: read
+ runs-on: ubuntu-latest
+ steps:
+ - name: Install Nix
+ uses: DeterminateSystems/nix-installer-action@main
+ with:
+ github-token: ${{ secrets.GITHUB_TOKEN }}
+ extra-conf: |
+ extra-experimental-features = nix-command flakes pipe-operators
+ - name: Set up cache
+ uses: DeterminateSystems/magic-nix-cache-action@main
+ - name: action
+ uses: cachix/install-nix-action@v25
+ with:
+ nix_path: nixpkgs=channel:nixos-unstable
+ - name: cache
+ uses: cachix/cachix-action@v16
+ with:
+ name: dashnix
+ authToken: '${{ secrets.CACHIX_AUTH_TOKEN }}'
+ - name: Linter check
+ run: nix run --no-write-lock-file github:${{ github.repository }}/${{ github.sha }}#lint -- check
+ - name: Format check
+ run: nix run --no-write-lock-file github:${{ github.repository }}/${{ github.sha }}#format -- --check .
+ - name: Build docs
+ run: nix -L build github:${{ github.repository }}/${{ github.sha }}#docs --no-write-lock-file
diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml
new file mode 100644
index 0000000..1984fb1
--- /dev/null
+++ b/.github/workflows/release.yaml
@@ -0,0 +1,29 @@
+# by https://github.com/danth/stylix/blob/master/.github/workflows/docs.yml
+name: Release
+on:
+ release:
+ types: [created]
+jobs:
+ build:
+ name: Release
+ permissions: write-all
+ runs-on: ubuntu-latest
+ steps:
+ - name: Install Nix
+ uses: DeterminateSystems/nix-installer-action@main
+ with:
+ github-token: ${{ secrets.GITHUB_TOKEN }}
+ extra-conf: |
+ extra-experimental-features = nix-command flakes pipe-operators
+ - name: Set up cache
+ uses: DeterminateSystems/magic-nix-cache-action@main
+ - name: Build ISO
+ run: nix build github:${{ github.repository }}/${{ github.sha }}#iso --no-write-lock-file
+ - name: Prepare ISO for upload
+ run: |
+ cp -r --dereference --no-preserve=mode,ownership result/iso/DashNix.iso DashNix.iso
+ - name: upload ISO
+ uses: softprops/action-gh-release@v1
+ with:
+ files: |
+ DashNix.iso
diff --git a/.gitignore b/.gitignore
index 3853240..f610716 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,11 +1,3 @@
-/nvim/plugged/*
-gtk-3.0/bookmarks
-gtk-3.0/servers
-/fish/fish_variables
-fish/fish_variables
-fish/*.tmp.*
-copyq/copyq.lock
-copyq/copyq_geometry.*
-copyq/copyq_tab*
-nvim/lazy-lock.json
-ncspot/*.cbor
+result/*
+result
+flake.lock
diff --git a/.zshrc b/.zshrc
deleted file mode 100644
index 6bb491d..0000000
--- a/.zshrc
+++ /dev/null
@@ -1,162 +0,0 @@
-if [[ -r "${XDG_CACHE_HOME:-$HOME/.cache}/p10k-instant-prompt-${(%):-%n}.zsh" ]]; then
- source "${XDG_CACHE_HOME:-$HOME/.cache}/p10k-instant-prompt-${(%):-%n}.zsh"
-fi
-
-# The following lines were added by compinstall
-zstyle :compinstall filename '$HOME/.zshrc'
-
-autoload -Uz compinit
-compinit
-##########
-
-HISTFILE=~/.histfile
-HISTSIZE=1000
-SAVEHIST=1000
-# End of lines configured by zsh-newuser-install
-#
-source /usr/share/zsh/plugins/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh
-source /usr/share/zsh/plugins/zsh-autosuggestions/zsh-autosuggestions.zsh
-source /usr/share/zsh-theme-powerlevel10k/powerlevel10k.zsh-theme
-
-# To customize prompt, run `p10k configure` or edit ~/.p10k.zsh.
-[[ ! -f ~/.p10k.zsh ]] || source ~/.p10k.zsh
-typeset -g POWERLEVEL9K_INSTANT_PROMPT=quiet
-
-export PATH=$PATH:~/.local/bin
-export PATH=$PATH:~/.cargo/bin
-export GPG_TTY=$TTY
-export TEXMFHOME=$HOME/.texmf
-export MANGOHUD_CONFIG=position=top-right,font_scale=0.7,round_corners=10.0
-export MOZ_ENABLE_WAYLAND=1
-export QT_AUTO_SCREEN_SCALE_FACTOR=0
-export VISUAL=nvim;
-export EDITOR=nvim;
-
-alias sudo='sudo '
-alias ls='lsd'
-alias :q='exit'
-alias gh='git push origin'
-alias gl='git pull origin'
-alias gm='git commit -m'
-alias ga="git add -A"
-alias g+='bear -- g++ -Wextra -Werror -std=c++20'
-alias s="kitty +kitten ssh"
-
-# zoxide
-## =============================================================================
-#
-# Utility functions for zoxide.
-#
-
-# pwd based on the value of _ZO_RESOLVE_SYMLINKS.
-function __zoxide_pwd() {
- \builtin pwd -L
-}
-
-# cd + custom logic based on the value of _ZO_ECHO.
-function __zoxide_cd() {
- # shellcheck disable=SC2164
- \builtin cd -- "$@" >/dev/null
-}
-
-# =============================================================================
-#
-# Hook configuration for zoxide.
-#
-
-# Hook to add new entries to the database.
-function __zoxide_hook() {
- # shellcheck disable=SC2312
- \command zoxide add -- "$(__zoxide_pwd)"
-}
-
-# Initialize hook.
-# shellcheck disable=SC2154
-if [[ ${precmd_functions[(Ie)__zoxide_hook]:-} -eq 0 ]] && [[ ${chpwd_functions[(Ie)__zoxide_hook]:-} -eq 0 ]]; then
- chpwd_functions+=(__zoxide_hook)
-fi
-
-# =============================================================================
-#
-# When using zoxide with --no-cmd, alias these internal functions as desired.
-#
-
-__zoxide_z_prefix='z#'
-
-# Jump to a directory using only keywords.
-function __zoxide_z() {
- # shellcheck disable=SC2199
- if [[ "$#" -eq 0 ]]; then
- __zoxide_cd ~
- elif [[ "$#" -eq 1 ]] && { [[ -d "$1" ]] || [[ "$1" = '-' ]] || [[ "$1" =~ ^[-+][0-9]$ ]]; }; then
- __zoxide_cd "$1"
- elif [[ "$@[-1]" == "${__zoxide_z_prefix}"* ]]; then
- # shellcheck disable=SC2124
- \builtin local result="${@[-1]}"
- __zoxide_cd "${result:${#__zoxide_z_prefix}}"
- else
- \builtin local result
- # shellcheck disable=SC2312
- result="$(\command zoxide query --exclude "$(__zoxide_pwd)" -- "$@")" &&
- __zoxide_cd "${result}"
- fi
-}
-
-# Jump to a directory using interactive search.
-function __zoxide_zi() {
- \builtin local result
- result="$(\command zoxide query -i -- "$@")" && __zoxide_cd "${result}"
-}
-
-# =============================================================================
-#
-# Commands for zoxide. Disable these using --no-cmd.
-#
-
-\builtin unalias z &>/dev/null || \builtin true
-function z() {
- __zoxide_z "$@"
-}
-
-\builtin unalias zi &>/dev/null || \builtin true
-function zi() {
- __zoxide_zi "$@"
-}
-
-if [[ -o zle ]]; then
- function __zoxide_z_complete() {
- # Only show completions when the cursor is at the end of the line.
- # shellcheck disable=SC2154
- [[ "${#words[@]}" -eq "${CURRENT}" ]] || return
-
- if [[ "${#words[@]}" -eq 2 ]]; then
- _files -/
- elif [[ "${words[-1]}" == '' ]]; then
- \builtin local result
- # shellcheck disable=SC2086,SC2312
- if result="$(\command zoxide query --exclude "$(__zoxide_pwd)" -i -- ${words[2,-1]})"; then
- __zoxide_result="${result}"
- else
- __zoxide_result=''
- fi
- \builtin printf '\e[5n'
- fi
- }
-
- function __zoxide_z_complete_helper() {
- \builtin local result="${__zoxide_z_prefix}${__zoxide_result}"
- # shellcheck disable=SC2296
- [[ -n "${__zoxide_result}" ]] && LBUFFER="${LBUFFER}${(q-)result}"
- \builtin zle reset-prompt
- }
-
- \builtin zle -N __zoxide_z_complete_helper
- \builtin bindkey "\e[0n" __zoxide_z_complete_helper
- if [[ "${+functions[compdef]}" -ne 0 ]]; then
- \compdef -d z
- \compdef -d zi
- \compdef __zoxide_z_complete z
- fi
-fi
-
-# =============================================================================
diff --git a/LICENSE b/LICENSE
new file mode 100644
index 0000000..7b6bec5
--- /dev/null
+++ b/LICENSE
@@ -0,0 +1,841 @@
+ GNU LESSER GENERAL PUBLIC LICENSE
+ Version 3, 29 June 2007
+
+ Copyright (C) 2007 Free Software Foundation, Inc.
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+
+ This version of the GNU Lesser General Public License incorporates
+the terms and conditions of version 3 of the GNU General Public
+License, supplemented by the additional permissions listed below.
+
+ 0. Additional Definitions.
+
+ As used herein, "this License" refers to version 3 of the GNU Lesser
+General Public License, and the "GNU GPL" refers to version 3 of the GNU
+General Public License.
+
+ "The Library" refers to a covered work governed by this License,
+other than an Application or a Combined Work as defined below.
+
+ An "Application" is any work that makes use of an interface provided
+by the Library, but which is not otherwise based on the Library.
+Defining a subclass of a class defined by the Library is deemed a mode
+of using an interface provided by the Library.
+
+ A "Combined Work" is a work produced by combining or linking an
+Application with the Library. The particular version of the Library
+with which the Combined Work was made is also called the "Linked
+Version".
+
+ The "Minimal Corresponding Source" for a Combined Work means the
+Corresponding Source for the Combined Work, excluding any source code
+for portions of the Combined Work that, considered in isolation, are
+based on the Application, and not on the Linked Version.
+
+ The "Corresponding Application Code" for a Combined Work means the
+object code and/or source code for the Application, including any data
+and utility programs needed for reproducing the Combined Work from the
+Application, but excluding the System Libraries of the Combined Work.
+
+ 1. Exception to Section 3 of the GNU GPL.
+
+ You may convey a covered work under sections 3 and 4 of this License
+without being bound by section 3 of the GNU GPL.
+
+ 2. Conveying Modified Versions.
+
+ If you modify a copy of the Library, and, in your modifications, a
+facility refers to a function or data to be supplied by an Application
+that uses the facility (other than as an argument passed when the
+facility is invoked), then you may convey a copy of the modified
+version:
+
+ a) under this License, provided that you make a good faith effort to
+ ensure that, in the event an Application does not supply the
+ function or data, the facility still operates, and performs
+ whatever part of its purpose remains meaningful, or
+
+ b) under the GNU GPL, with none of the additional permissions of
+ this License applicable to that copy.
+
+ 3. Object Code Incorporating Material from Library Header Files.
+
+ The object code form of an Application may incorporate material from
+a header file that is part of the Library. You may convey such object
+code under terms of your choice, provided that, if the incorporated
+material is not limited to numerical parameters, data structure
+layouts and accessors, or small macros, inline functions and templates
+(ten or fewer lines in length), you do both of the following:
+
+ a) Give prominent notice with each copy of the object code that the
+ Library is used in it and that the Library and its use are
+ covered by this License.
+
+ b) Accompany the object code with a copy of the GNU GPL and this license
+ document.
+
+ 4. Combined Works.
+
+ You may convey a Combined Work under terms of your choice that,
+taken together, effectively do not restrict modification of the
+portions of the Library contained in the Combined Work and reverse
+engineering for debugging such modifications, if you also do each of
+the following:
+
+ a) Give prominent notice with each copy of the Combined Work that
+ the Library is used in it and that the Library and its use are
+ covered by this License.
+
+ b) Accompany the Combined Work with a copy of the GNU GPL and this license
+ document.
+
+ c) For a Combined Work that displays copyright notices during
+ execution, include the copyright notice for the Library among
+ these notices, as well as a reference directing the user to the
+ copies of the GNU GPL and this license document.
+
+ d) Do one of the following:
+
+ 0) Convey the Minimal Corresponding Source under the terms of this
+ License, and the Corresponding Application Code in a form
+ suitable for, and under terms that permit, the user to
+ recombine or relink the Application with a modified version of
+ the Linked Version to produce a modified Combined Work, in the
+ manner specified by section 6 of the GNU GPL for conveying
+ Corresponding Source.
+
+ 1) Use a suitable shared library mechanism for linking with the
+ Library. A suitable mechanism is one that (a) uses at run time
+ a copy of the Library already present on the user's computer
+ system, and (b) will operate properly with a modified version
+ of the Library that is interface-compatible with the Linked
+ Version.
+
+ e) Provide Installation Information, but only if you would otherwise
+ be required to provide such information under section 6 of the
+ GNU GPL, and only to the extent that such information is
+ necessary to install and execute a modified version of the
+ Combined Work produced by recombining or relinking the
+ Application with a modified version of the Linked Version. (If
+ you use option 4d0, the Installation Information must accompany
+ the Minimal Corresponding Source and Corresponding Application
+ Code. If you use option 4d1, you must provide the Installation
+ Information in the manner specified by section 6 of the GNU GPL
+ for conveying Corresponding Source.)
+
+ 5. Combined Libraries.
+
+ You may place library facilities that are a work based on the
+Library side by side in a single library together with other library
+facilities that are not Applications and are not covered by this
+License, and convey such a combined library under terms of your
+choice, if you do both of the following:
+
+ a) Accompany the combined library with a copy of the same work based
+ on the Library, uncombined with any other library facilities,
+ conveyed under the terms of this License.
+
+ b) Give prominent notice with the combined library that part of it
+ is a work based on the Library, and explaining where to find the
+ accompanying uncombined form of the same work.
+
+ 6. Revised Versions of the GNU Lesser General Public License.
+
+ The Free Software Foundation may publish revised and/or new versions
+of the GNU Lesser General Public License from time to time. Such new
+versions will be similar in spirit to the present version, but may
+differ in detail to address new problems or concerns.
+
+ Each version is given a distinguishing version number. If the
+Library as you received it specifies that a certain numbered version
+of the GNU Lesser General Public License "or any later version"
+applies to it, you have the option of following the terms and
+conditions either of that published version or of any later version
+published by the Free Software Foundation. If the Library as you
+received it does not specify a version number of the GNU Lesser
+General Public License, you may choose any version of the GNU Lesser
+General Public License ever published by the Free Software Foundation.
+
+ If the Library as you received it specifies that a proxy can decide
+whether future versions of the GNU Lesser General Public License shall
+apply, that proxy's public statement of acceptance of any version is
+permanent authorization for you to choose that version for the
+Library.
+
+ GNU GENERAL PUBLIC LICENSE
+ Version 3, 29 June 2007
+
+ Copyright (C) 2007 Free Software Foundation, Inc.
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The GNU General Public License is a free, copyleft license for
+software and other kinds of works.
+
+ The licenses for most software and other practical works are designed
+to take away your freedom to share and change the works. By contrast,
+the GNU General Public License is intended to guarantee your freedom to
+share and change all versions of a program--to make sure it remains free
+software for all its users. We, the Free Software Foundation, use the
+GNU General Public License for most of our software; it applies also to
+any other work released this way by its authors. You can apply it to
+your programs, too.
+
+ When we speak of free software, we are referring to freedom, not
+price. Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+them if you wish), that you receive source code or can get it if you
+want it, that you can change the software or use pieces of it in new
+free programs, and that you know you can do these things.
+
+ To protect your rights, we need to prevent others from denying you
+these rights or asking you to surrender the rights. Therefore, you have
+certain responsibilities if you distribute copies of the software, or if
+you modify it: responsibilities to respect the freedom of others.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must pass on to the recipients the same
+freedoms that you received. You must make sure that they, too, receive
+or can get the source code. And you must show them these terms so they
+know their rights.
+
+ Developers that use the GNU GPL protect your rights with two steps:
+(1) assert copyright on the software, and (2) offer you this License
+giving you legal permission to copy, distribute and/or modify it.
+
+ For the developers' and authors' protection, the GPL clearly explains
+that there is no warranty for this free software. For both users' and
+authors' sake, the GPL requires that modified versions be marked as
+changed, so that their problems will not be attributed erroneously to
+authors of previous versions.
+
+ Some devices are designed to deny users access to install or run
+modified versions of the software inside them, although the manufacturer
+can do so. This is fundamentally incompatible with the aim of
+protecting users' freedom to change the software. The systematic
+pattern of such abuse occurs in the area of products for individuals to
+use, which is precisely where it is most unacceptable. Therefore, we
+have designed this version of the GPL to prohibit the practice for those
+products. If such problems arise substantially in other domains, we
+stand ready to extend this provision to those domains in future versions
+of the GPL, as needed to protect the freedom of users.
+
+ Finally, every program is threatened constantly by software patents.
+States should not allow patents to restrict development and use of
+software on general-purpose computers, but in those that do, we wish to
+avoid the special danger that patents applied to a free program could
+make it effectively proprietary. To prevent this, the GPL assures that
+patents cannot be used to render the program non-free.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ TERMS AND CONDITIONS
+
+ 0. Definitions.
+
+ "This License" refers to version 3 of the GNU General Public License.
+
+ "Copyright" also means copyright-like laws that apply to other kinds of
+works, such as semiconductor masks.
+
+ "The Program" refers to any copyrightable work licensed under this
+License. Each licensee is addressed as "you". "Licensees" and
+"recipients" may be individuals or organizations.
+
+ To "modify" a work means to copy from or adapt all or part of the work
+in a fashion requiring copyright permission, other than the making of an
+exact copy. The resulting work is called a "modified version" of the
+earlier work or a work "based on" the earlier work.
+
+ A "covered work" means either the unmodified Program or a work based
+on the Program.
+
+ To "propagate" a work means to do anything with it that, without
+permission, would make you directly or secondarily liable for
+infringement under applicable copyright law, except executing it on a
+computer or modifying a private copy. Propagation includes copying,
+distribution (with or without modification), making available to the
+public, and in some countries other activities as well.
+
+ To "convey" a work means any kind of propagation that enables other
+parties to make or receive copies. Mere interaction with a user through
+a computer network, with no transfer of a copy, is not conveying.
+
+ An interactive user interface displays "Appropriate Legal Notices"
+to the extent that it includes a convenient and prominently visible
+feature that (1) displays an appropriate copyright notice, and (2)
+tells the user that there is no warranty for the work (except to the
+extent that warranties are provided), that licensees may convey the
+work under this License, and how to view a copy of this License. If
+the interface presents a list of user commands or options, such as a
+menu, a prominent item in the list meets this criterion.
+
+ 1. Source Code.
+
+ The "source code" for a work means the preferred form of the work
+for making modifications to it. "Object code" means any non-source
+form of a work.
+
+ A "Standard Interface" means an interface that either is an official
+standard defined by a recognized standards body, or, in the case of
+interfaces specified for a particular programming language, one that
+is widely used among developers working in that language.
+
+ The "System Libraries" of an executable work include anything, other
+than the work as a whole, that (a) is included in the normal form of
+packaging a Major Component, but which is not part of that Major
+Component, and (b) serves only to enable use of the work with that
+Major Component, or to implement a Standard Interface for which an
+implementation is available to the public in source code form. A
+"Major Component", in this context, means a major essential component
+(kernel, window system, and so on) of the specific operating system
+(if any) on which the executable work runs, or a compiler used to
+produce the work, or an object code interpreter used to run it.
+
+ The "Corresponding Source" for a work in object code form means all
+the source code needed to generate, install, and (for an executable
+work) run the object code and to modify the work, including scripts to
+control those activities. However, it does not include the work's
+System Libraries, or general-purpose tools or generally available free
+programs which are used unmodified in performing those activities but
+which are not part of the work. For example, Corresponding Source
+includes interface definition files associated with source files for
+the work, and the source code for shared libraries and dynamically
+linked subprograms that the work is specifically designed to require,
+such as by intimate data communication or control flow between those
+subprograms and other parts of the work.
+
+ The Corresponding Source need not include anything that users
+can regenerate automatically from other parts of the Corresponding
+Source.
+
+ The Corresponding Source for a work in source code form is that
+same work.
+
+ 2. Basic Permissions.
+
+ All rights granted under this License are granted for the term of
+copyright on the Program, and are irrevocable provided the stated
+conditions are met. This License explicitly affirms your unlimited
+permission to run the unmodified Program. The output from running a
+covered work is covered by this License only if the output, given its
+content, constitutes a covered work. This License acknowledges your
+rights of fair use or other equivalent, as provided by copyright law.
+
+ You may make, run and propagate covered works that you do not
+convey, without conditions so long as your license otherwise remains
+in force. You may convey covered works to others for the sole purpose
+of having them make modifications exclusively for you, or provide you
+with facilities for running those works, provided that you comply with
+the terms of this License in conveying all material for which you do
+not control copyright. Those thus making or running the covered works
+for you must do so exclusively on your behalf, under your direction
+and control, on terms that prohibit them from making any copies of
+your copyrighted material outside their relationship with you.
+
+ Conveying under any other circumstances is permitted solely under
+the conditions stated below. Sublicensing is not allowed; section 10
+makes it unnecessary.
+
+ 3. Protecting Users' Legal Rights From Anti-Circumvention Law.
+
+ No covered work shall be deemed part of an effective technological
+measure under any applicable law fulfilling obligations under article
+11 of the WIPO copyright treaty adopted on 20 December 1996, or
+similar laws prohibiting or restricting circumvention of such
+measures.
+
+ When you convey a covered work, you waive any legal power to forbid
+circumvention of technological measures to the extent such circumvention
+is effected by exercising rights under this License with respect to
+the covered work, and you disclaim any intention to limit operation or
+modification of the work as a means of enforcing, against the work's
+users, your or third parties' legal rights to forbid circumvention of
+technological measures.
+
+ 4. Conveying Verbatim Copies.
+
+ You may convey verbatim copies of the Program's source code as you
+receive it, in any medium, provided that you conspicuously and
+appropriately publish on each copy an appropriate copyright notice;
+keep intact all notices stating that this License and any
+non-permissive terms added in accord with section 7 apply to the code;
+keep intact all notices of the absence of any warranty; and give all
+recipients a copy of this License along with the Program.
+
+ You may charge any price or no price for each copy that you convey,
+and you may offer support or warranty protection for a fee.
+
+ 5. Conveying Modified Source Versions.
+
+ You may convey a work based on the Program, or the modifications to
+produce it from the Program, in the form of source code under the
+terms of section 4, provided that you also meet all of these conditions:
+
+ a) The work must carry prominent notices stating that you modified
+ it, and giving a relevant date.
+
+ b) The work must carry prominent notices stating that it is
+ released under this License and any conditions added under section
+ 7. This requirement modifies the requirement in section 4 to
+ "keep intact all notices".
+
+ c) You must license the entire work, as a whole, under this
+ License to anyone who comes into possession of a copy. This
+ License will therefore apply, along with any applicable section 7
+ additional terms, to the whole of the work, and all its parts,
+ regardless of how they are packaged. This License gives no
+ permission to license the work in any other way, but it does not
+ invalidate such permission if you have separately received it.
+
+ d) If the work has interactive user interfaces, each must display
+ Appropriate Legal Notices; however, if the Program has interactive
+ interfaces that do not display Appropriate Legal Notices, your
+ work need not make them do so.
+
+ A compilation of a covered work with other separate and independent
+works, which are not by their nature extensions of the covered work,
+and which are not combined with it such as to form a larger program,
+in or on a volume of a storage or distribution medium, is called an
+"aggregate" if the compilation and its resulting copyright are not
+used to limit the access or legal rights of the compilation's users
+beyond what the individual works permit. Inclusion of a covered work
+in an aggregate does not cause this License to apply to the other
+parts of the aggregate.
+
+ 6. Conveying Non-Source Forms.
+
+ You may convey a covered work in object code form under the terms
+of sections 4 and 5, provided that you also convey the
+machine-readable Corresponding Source under the terms of this License,
+in one of these ways:
+
+ a) Convey the object code in, or embodied in, a physical product
+ (including a physical distribution medium), accompanied by the
+ Corresponding Source fixed on a durable physical medium
+ customarily used for software interchange.
+
+ b) Convey the object code in, or embodied in, a physical product
+ (including a physical distribution medium), accompanied by a
+ written offer, valid for at least three years and valid for as
+ long as you offer spare parts or customer support for that product
+ model, to give anyone who possesses the object code either (1) a
+ copy of the Corresponding Source for all the software in the
+ product that is covered by this License, on a durable physical
+ medium customarily used for software interchange, for a price no
+ more than your reasonable cost of physically performing this
+ conveying of source, or (2) access to copy the
+ Corresponding Source from a network server at no charge.
+
+ c) Convey individual copies of the object code with a copy of the
+ written offer to provide the Corresponding Source. This
+ alternative is allowed only occasionally and noncommercially, and
+ only if you received the object code with such an offer, in accord
+ with subsection 6b.
+
+ d) Convey the object code by offering access from a designated
+ place (gratis or for a charge), and offer equivalent access to the
+ Corresponding Source in the same way through the same place at no
+ further charge. You need not require recipients to copy the
+ Corresponding Source along with the object code. If the place to
+ copy the object code is a network server, the Corresponding Source
+ may be on a different server (operated by you or a third party)
+ that supports equivalent copying facilities, provided you maintain
+ clear directions next to the object code saying where to find the
+ Corresponding Source. Regardless of what server hosts the
+ Corresponding Source, you remain obligated to ensure that it is
+ available for as long as needed to satisfy these requirements.
+
+ e) Convey the object code using peer-to-peer transmission, provided
+ you inform other peers where the object code and Corresponding
+ Source of the work are being offered to the general public at no
+ charge under subsection 6d.
+
+ A separable portion of the object code, whose source code is excluded
+from the Corresponding Source as a System Library, need not be
+included in conveying the object code work.
+
+ A "User Product" is either (1) a "consumer product", which means any
+tangible personal property which is normally used for personal, family,
+or household purposes, or (2) anything designed or sold for incorporation
+into a dwelling. In determining whether a product is a consumer product,
+doubtful cases shall be resolved in favor of coverage. For a particular
+product received by a particular user, "normally used" refers to a
+typical or common use of that class of product, regardless of the status
+of the particular user or of the way in which the particular user
+actually uses, or expects or is expected to use, the product. A product
+is a consumer product regardless of whether the product has substantial
+commercial, industrial or non-consumer uses, unless such uses represent
+the only significant mode of use of the product.
+
+ "Installation Information" for a User Product means any methods,
+procedures, authorization keys, or other information required to install
+and execute modified versions of a covered work in that User Product from
+a modified version of its Corresponding Source. The information must
+suffice to ensure that the continued functioning of the modified object
+code is in no case prevented or interfered with solely because
+modification has been made.
+
+ If you convey an object code work under this section in, or with, or
+specifically for use in, a User Product, and the conveying occurs as
+part of a transaction in which the right of possession and use of the
+User Product is transferred to the recipient in perpetuity or for a
+fixed term (regardless of how the transaction is characterized), the
+Corresponding Source conveyed under this section must be accompanied
+by the Installation Information. But this requirement does not apply
+if neither you nor any third party retains the ability to install
+modified object code on the User Product (for example, the work has
+been installed in ROM).
+
+ The requirement to provide Installation Information does not include a
+requirement to continue to provide support service, warranty, or updates
+for a work that has been modified or installed by the recipient, or for
+the User Product in which it has been modified or installed. Access to a
+network may be denied when the modification itself materially and
+adversely affects the operation of the network or violates the rules and
+protocols for communication across the network.
+
+ Corresponding Source conveyed, and Installation Information provided,
+in accord with this section must be in a format that is publicly
+documented (and with an implementation available to the public in
+source code form), and must require no special password or key for
+unpacking, reading or copying.
+
+ 7. Additional Terms.
+
+ "Additional permissions" are terms that supplement the terms of this
+License by making exceptions from one or more of its conditions.
+Additional permissions that are applicable to the entire Program shall
+be treated as though they were included in this License, to the extent
+that they are valid under applicable law. If additional permissions
+apply only to part of the Program, that part may be used separately
+under those permissions, but the entire Program remains governed by
+this License without regard to the additional permissions.
+
+ When you convey a copy of a covered work, you may at your option
+remove any additional permissions from that copy, or from any part of
+it. (Additional permissions may be written to require their own
+removal in certain cases when you modify the work.) You may place
+additional permissions on material, added by you to a covered work,
+for which you have or can give appropriate copyright permission.
+
+ Notwithstanding any other provision of this License, for material you
+add to a covered work, you may (if authorized by the copyright holders of
+that material) supplement the terms of this License with terms:
+
+ a) Disclaiming warranty or limiting liability differently from the
+ terms of sections 15 and 16 of this License; or
+
+ b) Requiring preservation of specified reasonable legal notices or
+ author attributions in that material or in the Appropriate Legal
+ Notices displayed by works containing it; or
+
+ c) Prohibiting misrepresentation of the origin of that material, or
+ requiring that modified versions of such material be marked in
+ reasonable ways as different from the original version; or
+
+ d) Limiting the use for publicity purposes of names of licensors or
+ authors of the material; or
+
+ e) Declining to grant rights under trademark law for use of some
+ trade names, trademarks, or service marks; or
+
+ f) Requiring indemnification of licensors and authors of that
+ material by anyone who conveys the material (or modified versions of
+ it) with contractual assumptions of liability to the recipient, for
+ any liability that these contractual assumptions directly impose on
+ those licensors and authors.
+
+ All other non-permissive additional terms are considered "further
+restrictions" within the meaning of section 10. If the Program as you
+received it, or any part of it, contains a notice stating that it is
+governed by this License along with a term that is a further
+restriction, you may remove that term. If a license document contains
+a further restriction but permits relicensing or conveying under this
+License, you may add to a covered work material governed by the terms
+of that license document, provided that the further restriction does
+not survive such relicensing or conveying.
+
+ If you add terms to a covered work in accord with this section, you
+must place, in the relevant source files, a statement of the
+additional terms that apply to those files, or a notice indicating
+where to find the applicable terms.
+
+ Additional terms, permissive or non-permissive, may be stated in the
+form of a separately written license, or stated as exceptions;
+the above requirements apply either way.
+
+ 8. Termination.
+
+ You may not propagate or modify a covered work except as expressly
+provided under this License. Any attempt otherwise to propagate or
+modify it is void, and will automatically terminate your rights under
+this License (including any patent licenses granted under the third
+paragraph of section 11).
+
+ However, if you cease all violation of this License, then your
+license from a particular copyright holder is reinstated (a)
+provisionally, unless and until the copyright holder explicitly and
+finally terminates your license, and (b) permanently, if the copyright
+holder fails to notify you of the violation by some reasonable means
+prior to 60 days after the cessation.
+
+ Moreover, your license from a particular copyright holder is
+reinstated permanently if the copyright holder notifies you of the
+violation by some reasonable means, this is the first time you have
+received notice of violation of this License (for any work) from that
+copyright holder, and you cure the violation prior to 30 days after
+your receipt of the notice.
+
+ Termination of your rights under this section does not terminate the
+licenses of parties who have received copies or rights from you under
+this License. If your rights have been terminated and not permanently
+reinstated, you do not qualify to receive new licenses for the same
+material under section 10.
+
+ 9. Acceptance Not Required for Having Copies.
+
+ You are not required to accept this License in order to receive or
+run a copy of the Program. Ancillary propagation of a covered work
+occurring solely as a consequence of using peer-to-peer transmission
+to receive a copy likewise does not require acceptance. However,
+nothing other than this License grants you permission to propagate or
+modify any covered work. These actions infringe copyright if you do
+not accept this License. Therefore, by modifying or propagating a
+covered work, you indicate your acceptance of this License to do so.
+
+ 10. Automatic Licensing of Downstream Recipients.
+
+ Each time you convey a covered work, the recipient automatically
+receives a license from the original licensors, to run, modify and
+propagate that work, subject to this License. You are not responsible
+for enforcing compliance by third parties with this License.
+
+ An "entity transaction" is a transaction transferring control of an
+organization, or substantially all assets of one, or subdividing an
+organization, or merging organizations. If propagation of a covered
+work results from an entity transaction, each party to that
+transaction who receives a copy of the work also receives whatever
+licenses to the work the party's predecessor in interest had or could
+give under the previous paragraph, plus a right to possession of the
+Corresponding Source of the work from the predecessor in interest, if
+the predecessor has it or can get it with reasonable efforts.
+
+ You may not impose any further restrictions on the exercise of the
+rights granted or affirmed under this License. For example, you may
+not impose a license fee, royalty, or other charge for exercise of
+rights granted under this License, and you may not initiate litigation
+(including a cross-claim or counterclaim in a lawsuit) alleging that
+any patent claim is infringed by making, using, selling, offering for
+sale, or importing the Program or any portion of it.
+
+ 11. Patents.
+
+ A "contributor" is a copyright holder who authorizes use under this
+License of the Program or a work on which the Program is based. The
+work thus licensed is called the contributor's "contributor version".
+
+ A contributor's "essential patent claims" are all patent claims
+owned or controlled by the contributor, whether already acquired or
+hereafter acquired, that would be infringed by some manner, permitted
+by this License, of making, using, or selling its contributor version,
+but do not include claims that would be infringed only as a
+consequence of further modification of the contributor version. For
+purposes of this definition, "control" includes the right to grant
+patent sublicenses in a manner consistent with the requirements of
+this License.
+
+ Each contributor grants you a non-exclusive, worldwide, royalty-free
+patent license under the contributor's essential patent claims, to
+make, use, sell, offer for sale, import and otherwise run, modify and
+propagate the contents of its contributor version.
+
+ In the following three paragraphs, a "patent license" is any express
+agreement or commitment, however denominated, not to enforce a patent
+(such as an express permission to practice a patent or covenant not to
+sue for patent infringement). To "grant" such a patent license to a
+party means to make such an agreement or commitment not to enforce a
+patent against the party.
+
+ If you convey a covered work, knowingly relying on a patent license,
+and the Corresponding Source of the work is not available for anyone
+to copy, free of charge and under the terms of this License, through a
+publicly available network server or other readily accessible means,
+then you must either (1) cause the Corresponding Source to be so
+available, or (2) arrange to deprive yourself of the benefit of the
+patent license for this particular work, or (3) arrange, in a manner
+consistent with the requirements of this License, to extend the patent
+license to downstream recipients. "Knowingly relying" means you have
+actual knowledge that, but for the patent license, your conveying the
+covered work in a country, or your recipient's use of the covered work
+in a country, would infringe one or more identifiable patents in that
+country that you have reason to believe are valid.
+
+ If, pursuant to or in connection with a single transaction or
+arrangement, you convey, or propagate by procuring conveyance of, a
+covered work, and grant a patent license to some of the parties
+receiving the covered work authorizing them to use, propagate, modify
+or convey a specific copy of the covered work, then the patent license
+you grant is automatically extended to all recipients of the covered
+work and works based on it.
+
+ A patent license is "discriminatory" if it does not include within
+the scope of its coverage, prohibits the exercise of, or is
+conditioned on the non-exercise of one or more of the rights that are
+specifically granted under this License. You may not convey a covered
+work if you are a party to an arrangement with a third party that is
+in the business of distributing software, under which you make payment
+to the third party based on the extent of your activity of conveying
+the work, and under which the third party grants, to any of the
+parties who would receive the covered work from you, a discriminatory
+patent license (a) in connection with copies of the covered work
+conveyed by you (or copies made from those copies), or (b) primarily
+for and in connection with specific products or compilations that
+contain the covered work, unless you entered into that arrangement,
+or that patent license was granted, prior to 28 March 2007.
+
+ Nothing in this License shall be construed as excluding or limiting
+any implied license or other defenses to infringement that may
+otherwise be available to you under applicable patent law.
+
+ 12. No Surrender of Others' Freedom.
+
+ If conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot convey a
+covered work so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you may
+not convey it at all. For example, if you agree to terms that obligate you
+to collect a royalty for further conveying from those to whom you convey
+the Program, the only way you could satisfy both those terms and this
+License would be to refrain entirely from conveying the Program.
+
+ 13. Use with the GNU Affero General Public License.
+
+ Notwithstanding any other provision of this License, you have
+permission to link or combine any covered work with a work licensed
+under version 3 of the GNU Affero General Public License into a single
+combined work, and to convey the resulting work. The terms of this
+License will continue to apply to the part which is the covered work,
+but the special requirements of the GNU Affero General Public License,
+section 13, concerning interaction through a network will apply to the
+combination as such.
+
+ 14. Revised Versions of this License.
+
+ The Free Software Foundation may publish revised and/or new versions of
+the GNU General Public License from time to time. Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+ Each version is given a distinguishing version number. If the
+Program specifies that a certain numbered version of the GNU General
+Public License "or any later version" applies to it, you have the
+option of following the terms and conditions either of that numbered
+version or of any later version published by the Free Software
+Foundation. If the Program does not specify a version number of the
+GNU General Public License, you may choose any version ever published
+by the Free Software Foundation.
+
+ If the Program specifies that a proxy can decide which future
+versions of the GNU General Public License can be used, that proxy's
+public statement of acceptance of a version permanently authorizes you
+to choose that version for the Program.
+
+ Later license versions may give you additional or different
+permissions. However, no additional obligations are imposed on any
+author or copyright holder as a result of your choosing to follow a
+later version.
+
+ 15. Disclaimer of Warranty.
+
+ THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
+APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
+HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
+OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
+THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
+IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
+ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+ 16. Limitation of Liability.
+
+ IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
+THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
+GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
+USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
+DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
+PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
+EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
+SUCH DAMAGES.
+
+ 17. Interpretation of Sections 15 and 16.
+
+ If the disclaimer of warranty and limitation of liability provided
+above cannot be given local legal effect according to their terms,
+reviewing courts shall apply local law that most closely approximates
+an absolute waiver of all civil liability in connection with the
+Program, unless a warranty or assumption of liability accompanies a
+copy of the Program in return for a fee.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. It is safest
+to attach them to the start of each source file to most effectively
+state the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+
+ Copyright (C)
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation, either version 3 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program. If not, see .
+
+Also add information on how to contact you by electronic and paper mail.
+
+ If the program does terminal interaction, make it output a short
+notice like this when it starts in an interactive mode:
+
+ Copyright (C)
+ This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, your program's commands
+might be different; for a GUI interface, you would use an "about box".
+
+ You should also get your employer (if you work as a programmer) or school,
+if any, to sign a "copyright disclaimer" for the program, if necessary.
+For more information on this, and how to apply and follow the GNU GPL, see
+.
+
+ The GNU General Public License does not permit incorporating your program
+into proprietary programs. If your program is a subroutine library, you
+may consider it more useful to permit linking proprietary applications with
+the library. If this is what you want to do, use the GNU Lesser General
+Public License instead of this License. But first, please read
+.
+
diff --git a/README.md b/README.md
deleted file mode 100644
index 13a1458..0000000
--- a/README.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# dotFiles
-
-## General
-Personal Dotfiles with many being combined together to get this, and other things coming from myself directly.
-
-## [Keymaps](nvim/README.md)
diff --git a/README.md b/README.md
new file mode 120000
index 0000000..95cf2af
--- /dev/null
+++ b/README.md
@@ -0,0 +1 @@
+docs/src/README.md
\ No newline at end of file
diff --git a/anyrun/config.ron b/anyrun/config.ron
deleted file mode 100644
index 9954bd4..0000000
--- a/anyrun/config.ron
+++ /dev/null
@@ -1,35 +0,0 @@
-Config(
- // `width` and `vertical_offset` use an enum for the value it can be either:
- // Absolute(n): The absolute value in pixels
- // Fraction(n): A fraction of the width or height of the full screen (depends on exclusive zones and the settings related to them) window respectively
-
- // How wide the input box and results are.
- width: Absolute(800),
-
- // Where Anyrun is located on the screen: Top, Center
- position: Center,
-
- // How much the runner is shifted vertically
- vertical_offset: Absolute(0),
-
- // Hide match and plugin info icons
- hide_icons: false,
-
- // ignore exclusive zones, f.e. Waybar
- ignore_exclusive_zones: false,
-
- // Layer shell layer: Background, Bottom, Top, Overlay
- layer: Overlay,
-
- // Hide the plugin info panel
- hide_plugin_info: false,
-
- // List of plugins to be loaded by default, can be specified with a relative path to be loaded from the
- // `/plugins` directory or with an absolute path to just load the file the path points to.
- plugins: [
- "libapplications.so",
- "libshell.so",
- "librink.so",
- "libanyrun_websearch.so"
- ],
-)
diff --git a/anyrun/plugins/libanyrun_websearch.so b/anyrun/plugins/libanyrun_websearch.so
deleted file mode 100755
index 956091d..0000000
Binary files a/anyrun/plugins/libanyrun_websearch.so and /dev/null differ
diff --git a/anyrun/plugins/libapplications.so b/anyrun/plugins/libapplications.so
deleted file mode 100755
index 3a7ab5e..0000000
Binary files a/anyrun/plugins/libapplications.so and /dev/null differ
diff --git a/anyrun/plugins/libkidex.so b/anyrun/plugins/libkidex.so
deleted file mode 100755
index 75aba92..0000000
Binary files a/anyrun/plugins/libkidex.so and /dev/null differ
diff --git a/anyrun/plugins/librink.so b/anyrun/plugins/librink.so
deleted file mode 100755
index 58de8f5..0000000
Binary files a/anyrun/plugins/librink.so and /dev/null differ
diff --git a/anyrun/plugins/libshell.so b/anyrun/plugins/libshell.so
deleted file mode 100755
index e7341cb..0000000
Binary files a/anyrun/plugins/libshell.so and /dev/null differ
diff --git a/anyrun/plugins/libsymbols.so b/anyrun/plugins/libsymbols.so
deleted file mode 100755
index e1630ea..0000000
Binary files a/anyrun/plugins/libsymbols.so and /dev/null differ
diff --git a/anyrun/plugins/libtranslate.so b/anyrun/plugins/libtranslate.so
deleted file mode 100755
index 232a238..0000000
Binary files a/anyrun/plugins/libtranslate.so and /dev/null differ
diff --git a/anyrun/style.css b/anyrun/style.css
deleted file mode 100644
index 43f7385..0000000
--- a/anyrun/style.css
+++ /dev/null
@@ -1,47 +0,0 @@
-
-#window {
- border-radius: 10px;
- background-color: none;
-}
-
-box#main {
- border-radius: 10px;
-}
-
-list#main {
- border-radius: 10px;
- margin: 0px 10px 10px 10px;
-}
-
-list#plugin {
- border-radius: 10px;
-}
-
-list#match {
- border-radius: 10px;
-}
-
-entry#entry {
- border: none;
- border-radius: 10px;
- margin: 10px 10px 0px 10px;
-}
-
-label#match-desc {
- font-size: 12px;
- border-radius: 10px;
-}
-
-label#match-title {
- font-size: 12px;
- border-radius: 10px;
-}
-
-label#plugin {
- font-size: 16px;
- border-radius: 10px;
-}
-
-* {
- border-radius: 10px;
-}
diff --git a/anyrun/websearch.ron b/anyrun/websearch.ron
deleted file mode 100644
index 67dc035..0000000
--- a/anyrun/websearch.ron
+++ /dev/null
@@ -1,6 +0,0 @@
-Config (
- prefix_url_map: {
- ":g": "https://google.com/search?q=",
- ":b": "https://search.brave.com/search?q=",
- }
-)
diff --git a/assets/logo.svg b/assets/logo.svg
new file mode 100644
index 0000000..7ca00e2
--- /dev/null
+++ b/assets/logo.svg
@@ -0,0 +1,228 @@
+
+
+
+
diff --git a/assets/logo2.png b/assets/logo2.png
new file mode 100644
index 0000000..beeac55
Binary files /dev/null and b/assets/logo2.png differ
diff --git a/assets/logo2.svg b/assets/logo2.svg
new file mode 100644
index 0000000..08baa43
--- /dev/null
+++ b/assets/logo2.svg
@@ -0,0 +1,238 @@
+
+
+
+
diff --git a/assets/logo3.svg b/assets/logo3.svg
new file mode 100644
index 0000000..6076a01
--- /dev/null
+++ b/assets/logo3.svg
@@ -0,0 +1,238 @@
+
+
+
+
diff --git a/assets/rainbow.svg b/assets/rainbow.svg
new file mode 100644
index 0000000..9f59c7c
--- /dev/null
+++ b/assets/rainbow.svg
@@ -0,0 +1,141 @@
+
+
diff --git a/base/black.jpg b/base/black.jpg
new file mode 100644
index 0000000..730b0b6
Binary files /dev/null and b/base/black.jpg differ
diff --git a/base/common_hardware.nix b/base/common_hardware.nix
new file mode 100644
index 0000000..9f7ccf1
--- /dev/null
+++ b/base/common_hardware.nix
@@ -0,0 +1,174 @@
+{
+ mkDashDefault,
+ pkgs,
+ config,
+ lib,
+ hostName,
+ modulesPath,
+ ...
+}: let
+ username = config.conf.username;
+in {
+ imports = [
+ (modulesPath + "/installer/scan/not-detected.nix")
+ ];
+
+ wsl.enable = mkDashDefault config.conf.wsl;
+
+ # Bootloader.
+ boot = lib.mkIf (!config.conf.wsl) {
+ consoleLogLevel = mkDashDefault 0;
+
+ lanzaboote = lib.mkIf config.conf.secureBoot {
+ enable = mkDashDefault true;
+ pkiBundle = mkDashDefault "/var/lib/sbctl";
+ settings.reboot-for-bitlocker = mkDashDefault true;
+ };
+
+ loader = {
+ systemd-boot = {
+ enable =
+ if config.conf.secureBoot
+ then lib.mkForce false
+ else if config.conf.useSystemdBootloader
+ then true
+ else mkDashDefault false;
+ configurationLimit = 5;
+ };
+ efi.canTouchEfiVariables = mkDashDefault true;
+ };
+
+ kernelPackages = mkDashDefault pkgs.linuxPackages_latest;
+ initrd = {
+ verbose = mkDashDefault false;
+ availableKernelModules = [
+ "nvme"
+ "xhci_pci"
+ "ahci"
+ "usbhid"
+ "usb_storage"
+ "sd_mod"
+ ];
+ };
+ kernelParams =
+ [
+ ''resume="PARTLABEL=SWAP"''
+ ''quiet''
+ ''udev.log_level=3''
+ ]
+ ++ config.conf.bootParams;
+ };
+
+ networking = {
+ useDHCP = mkDashDefault true;
+ networkmanager.enable = mkDashDefault true;
+ hostName = mkDashDefault hostName;
+ };
+
+ time = {
+ timeZone = mkDashDefault config.conf.timezone;
+ hardwareClockInLocalTime = mkDashDefault config.conf.systemLocalTime;
+ };
+
+ i18n.defaultLocale = mkDashDefault config.conf.locale;
+
+ services = {
+ lorri.enable = mkDashDefault true;
+ xserver.enable = mkDashDefault true;
+ fstrim.enable = mkDashDefault true;
+ pulseaudio.enable = mkDashDefault false;
+ pipewire = {
+ enable = mkDashDefault true;
+ alsa = {
+ enable = mkDashDefault true;
+ support32Bit = mkDashDefault true;
+ };
+ jack.enable = mkDashDefault true;
+ pulse.enable = mkDashDefault true;
+ };
+ };
+
+ nixpkgs.hostPlatform = mkDashDefault config.conf.system;
+ nix = {
+ gc = {
+ automatic = mkDashDefault true;
+ dates = mkDashDefault "weekly";
+ options = mkDashDefault "--delete-older-than 7d --delete-generations +5";
+ };
+ settings = {
+ trusted-users = [username];
+ auto-optimise-store = mkDashDefault true;
+
+ builders-use-substitutes = mkDashDefault true;
+
+ trusted-substituters = [
+ "https://hyprland.cachix.org"
+ "https://anyrun.cachix.org"
+ "https://oxipaste.cachix.org"
+ "https://oxinoti.cachix.org"
+ "https://oxishut.cachix.org"
+ "https://oxidash.cachix.org"
+ "https://oxicalc.cachix.org"
+ "https://hyprdock.cachix.org"
+ "https://reset.cachix.org"
+ "https://dashvim.cachix.org"
+ ];
+
+ trusted-public-keys = [
+ "hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="
+ "anyrun.cachix.org-1:pqBobmOjI7nKlsUMV25u9QHa9btJK65/C8vnO3p346s="
+ "oxipaste.cachix.org-1:n/oA3N3Z+LJP7eIWOwuoLd9QnPyZXqFjLgkahjsdDGc="
+ "oxinoti.cachix.org-1:dvSoJl2Pjo5HMaNngdBbSaixK9BSf2N8gzjP2MdGvfc="
+ "oxishut.cachix.org-1:axyAGF3XMh1IyMAW4UMbQCdMNovDH0KH6hqLLRJH8jU="
+ "oxidash.cachix.org-1:5K2FNHp7AS8VF7LmQkJAUG/dm6UHCz4ngshBVbjFX30="
+ "oxicalc.cachix.org-1:qF3krFc20tgSmtR/kt6Ku/T5QiG824z79qU5eRCSBTQ="
+ "hyprdock.cachix.org-1:HaROK3fBvFWIMHZau3Vq1TLwUoJE8yRbGLk0lEGzv3Y="
+ "reset.cachix.org-1:LfpnUUdG7QM/eOkN7NtA+3+4Ar/UBeYB+3WH+GjP9Xo="
+ "dashvim.cachix.org-1:uLRdxp1WOWHnsZZtu3SwUWZRsvC7SXo0Gyk3tIefuL0="
+ ];
+
+ experimental-features = mkDashDefault "nix-command flakes pipe-operators";
+ };
+ };
+
+ hardware = {
+ cpu.${config.conf.cpu}.updateMicrocode =
+ mkDashDefault
+ config.hardware.enableRedistributableFirmware;
+ };
+
+ security.rtkit.enable = mkDashDefault true;
+
+ environment.variables = {
+ XDG_CACHE_HOME = mkDashDefault "$HOME/.cache";
+ DIRENV_LOG_FORMAT = mkDashDefault "";
+ QT_QPA_PLATFORMTHEME = mkDashDefault "qt5ct";
+ };
+
+ # allows user change later on
+ users = {
+ mutableUsers = mkDashDefault true;
+ users.${username} = {
+ isNormalUser = mkDashDefault true;
+ description = mkDashDefault username;
+ extraGroups = [
+ "networkmanager"
+ "wheel"
+ "gamemode"
+ "docker"
+ "vboxusers"
+ "video"
+ "audio"
+ "scanner"
+ "lp"
+ ];
+ packages = with pkgs; [
+ home-manager
+ xdg-desktop-portal-gtk
+ ];
+ # this password will only last for the first login
+ # e.g. login, then change to whatever else, this also ensures no public hash is available
+ password = mkDashDefault "firstlogin";
+ };
+ };
+}
diff --git a/base/default.nix b/base/default.nix
new file mode 100644
index 0000000..eafd8a5
--- /dev/null
+++ b/base/default.nix
@@ -0,0 +1,7 @@
+{
+ imports = [
+ ./env.nix
+ ./xkb_layout.nix
+ ./common_hardware.nix
+ ];
+}
diff --git a/base/env.nix b/base/env.nix
new file mode 100644
index 0000000..0eaf068
--- /dev/null
+++ b/base/env.nix
@@ -0,0 +1,24 @@
+{
+ mkDashDefault,
+ pkgs,
+ config,
+ lib,
+ ...
+}: {
+ environment = {
+ variables = {
+ GSETTINGS_SCHEMA_DIR = mkDashDefault "${pkgs.glib.getSchemaPath pkgs.gsettings-desktop-schemas}";
+ NEOVIDE_MAXIMIZED = mkDashDefault "0";
+ GPG_TTY = mkDashDefault "$(tty)";
+ EDITOR = mkDashDefault "neovide --no-fork";
+ SUDO_EDITOR = mkDashDefault "neovide --no-fork";
+ SCRIPTS = mkDashDefault "$HOME/.config/scripts";
+ };
+ sessionVariables = {
+ NIXOS_OZONE_WL = mkDashDefault "1";
+ GOPATH = mkDashDefault "$HOME/.go";
+ FLAKE = mkDashDefault config.conf.nixosConfigPath;
+ NH_FLAKE = mkDashDefault config.conf.nixosConfigPath;
+ };
+ };
+}
diff --git a/base/xkb_layout.nix b/base/xkb_layout.nix
new file mode 100644
index 0000000..b399693
--- /dev/null
+++ b/base/xkb_layout.nix
@@ -0,0 +1,23 @@
+{
+ mkDashDefault,
+ pkgs,
+ ...
+}: let
+ layout = pkgs.writeText "enIntUmlaut" ''
+ xkb_symbols "enIntUmlaut"
+ {
+ include "us(basic)"
+ include "level3(ralt_switch)"
+ key { [ a, A, adiaeresis, Adiaeresis ] };
+ key { [ o, O, odiaeresis, Odiaeresis ] };
+ key { [ u, U, udiaeresis, Udiaeresis ] };
+ };
+ '';
+in {
+ environment.systemPackages = mkDashDefault [pkgs.xorg.xkbcomp];
+ services.xserver.xkb.extraLayouts.enIntUmlaut = {
+ description = "US layout with 'umlaut'";
+ languages = ["eng"];
+ symbolsFile = "${layout}";
+ };
+}
diff --git a/copyq/copyq-bak.conf b/copyq/copyq-bak.conf
deleted file mode 100644
index 6ae5aec..0000000
--- a/copyq/copyq-bak.conf
+++ /dev/null
@@ -1,216 +0,0 @@
-[General]
-plugin_priority=itemimage, itemencrypted, itemfakevim, itemnotes, itempinned, itemsync, itemtags, itemtext
-
-[Options]
-activate_closes=true
-activate_focuses=true
-activate_item_with_single_click=false
-activate_pastes=true
-always_on_top=false
-autocompletion=true
-autostart=false
-change_clipboard_owner_delay_ms=150
-check_clipboard=true
-check_selection=false
-clipboard_notification_lines=0
-clipboard_tab=&clipboard
-close_on_unfocus=false
-close_on_unfocus_delay_ms=500
-command_history_size=100
-confirm_exit=true
-copy_clipboard=false
-copy_selection=false
-disable_tray=false
-edit_ctrl_return=true
-editor=gedit --standalone -- %1
-expire_tab=0
-filter_case_insensitive=true
-filter_regular_expression=false
-hide_main_window=true
-hide_main_window_in_task_bar=false
-hide_tabs=false
-hide_toolbar=false
-hide_toolbar_labels=true
-item_popup_interval=0
-language=en
-max_process_manager_rows=1000
-maxitems=200
-move=true
-native_menu_bar=true
-native_notifications=true
-native_tray_menu=false
-notification_horizontal_offset=10
-notification_maximum_height=100
-notification_maximum_width=300
-notification_position=3
-notification_vertical_offset=10
-number_search=false
-open_windows_on_current_screen=true
-restore_geometry=true
-row_index_from_one=true
-run_selection=true
-save_delay_ms_on_item_added=300000
-save_delay_ms_on_item_edited=1000
-save_delay_ms_on_item_modified=300000
-save_delay_ms_on_item_moved=1800000
-save_delay_ms_on_item_removed=600000
-save_filter_history=false
-save_on_app_deactivated=true
-script_paste_delay_ms=250
-show_advanced_command_settings=false
-show_simple_items=false
-show_tab_item_count=false
-style=
-tab_tree=false
-tabs=&clipboard
-text_tab_width=8
-text_wrap=true
-transparency=0
-transparency_focused=0
-tray_commands=true
-tray_images=true
-tray_item_paste=true
-tray_items=5
-tray_menu_open_on_left_click=false
-tray_tab=
-tray_tab_is_current=true
-vi=false
-window_key_press_time_ms=50
-window_paste_with_ctrl_v_regex=
-window_wait_after_raised_ms=50
-window_wait_before_raise_ms=20
-window_wait_for_modifier_released_ms=2000
-window_wait_raised_ms=150
-
-[Plugins]
-itemencrypted\enabled=true
-itemfakevim\enabled=true
-itemimage\enabled=true
-itemimage\image_editor=
-itemimage\max_image_height=240
-itemimage\max_image_width=320
-itemimage\svg_editor=
-itemnotes\enabled=true
-itempinned\enabled=true
-itemsync\enabled=true
-itemtags\enabled=true
-itemtext\enabled=true
-
-[Shortcuts]
-about=shift+f1
-change_tab_icon=ctrl+shift+t
-commands=f6
-copy_selected_items=ctrl+c
-delete_item=del
-edit=f2
-edit_notes=shift+f2
-editor=ctrl+e
-editor_background=
-editor_bold=ctrl+b
-editor_cancel=esc
-editor_erase_style=
-editor_font=
-editor_foreground=
-editor_italic=ctrl+i
-editor_redo=ctrl+shift+z
-editor_save=f2
-editor_search=ctrl+f
-editor_strikethrough=
-editor_underline=ctrl+u
-editor_undo=ctrl+z
-exit=ctrl+q
-export=ctrl+s
-find_items=ctrl+g
-help=f1
-import=ctrl+i
-item-menu=shift+f10
-move_down=ctrl+down
-move_to_bottom=ctrl+end
-move_to_clipboard=
-move_to_top=ctrl+home
-move_up=ctrl+up
-new=ctrl+n
-new_tab=ctrl+t
-next_tab=right
-paste_selected_items=ctrl+v
-preferences=ctrl+p
-previous_tab=left
-process_manager=ctrl+shift+z
-remove_tab=ctrl+w
-rename_tab=ctrl+f2
-reverse_selected_items=ctrl+shift+r
-show-log=f12
-show_clipboard_content=ctrl+shift+c
-show_item_content=f4
-show_item_preview=f7
-sort_selected_items=ctrl+shift+s
-system-run=f5
-toggle_clipboard_storing=ctrl+shift+x
-
-[Tabs]
-1\icon=
-1\max_item_count=0
-1\name=&clipboard
-1\store_items=true
-size=1
-
-[Theme]
-alt_bg=default_alt_bg
-alt_item_css=
-bg=default_bg
-css=
-css_template_items=items
-css_template_main_window=main_window
-css_template_menu=menu
-css_template_notification=notification
-cur_item_css="\n ;border: 0.1em solid ${sel_bg}"
-edit_bg=default_bg
-edit_fg=default_text
-edit_font=
-fg=default_text
-find_bg=#ff0
-find_fg=#000
-find_font=
-font=
-font_antialiasing=true
-hover_item_css=
-icon_size=16
-item_css=
-item_spacing=
-menu_bar_css="\n ;background: ${bg}\n ;color: ${fg}"
-menu_bar_disabled_css="\n ;color: ${bg - #666}"
-menu_bar_selected_css="\n ;background: ${sel_bg}\n ;color: ${sel_fg}"
-menu_css="\n ;border: 1px solid ${sel_bg}\n ;background: ${bg}\n ;color: ${fg}"
-notes_bg=default_tooltip_bg
-notes_css=
-notes_fg=default_tooltip_text
-notes_font=
-notification_bg=#333
-notification_fg=#ddd
-notification_font=
-num_fg=default_placeholder_text
-num_font=
-num_margin=2
-search_bar="\n ;background: ${edit_bg}\n ;color: ${edit_fg}\n ;border: 1px solid ${alt_bg}\n ;margin: 2px"
-search_bar_focused="\n ;border: 1px solid ${sel_bg}"
-sel_bg=default_highlight_bg
-sel_fg=default_highlight_text
-sel_item_css=
-show_number=true
-show_scrollbars=true
-style_main_window=false
-tab_bar_css="\n ;background: ${bg - #222}"
-tab_bar_item_counter="\n ;color: ${fg - #044 + #400}\n ;font-size: 6pt"
-tab_bar_scroll_buttons_css="\n ;background: ${bg - #222}\n ;color: ${fg}\n ;border: 0"
-tab_bar_sel_item_counter="\n ;color: ${sel_bg - #044 + #400}"
-tab_bar_tab_selected_css="\n ;padding: 0.5em\n ;background: ${bg}\n ;border: 0.05em solid ${bg}\n ;color: ${fg}"
-tab_bar_tab_unselected_css="\n ;border: 0.05em solid ${bg}\n ;padding: 0.5em\n ;background: ${bg - #222}\n ;color: ${fg - #333}"
-tab_tree_css="\n ;color: ${fg}\n ;background-color: ${bg}"
-tab_tree_item_counter="\n ;color: ${fg - #044 + #400}\n ;font-size: 6pt"
-tab_tree_sel_item_counter="\n ;color: ${sel_fg - #044 + #400}"
-tab_tree_sel_item_css="\n ;color: ${sel_fg}\n ;background-color: ${sel_bg}\n ;border-radius: 2px"
-tool_bar_css="\n ;color: ${fg}\n ;background-color: ${bg}\n ;border: 0"
-tool_button_css="\n ;color: ${fg}\n ;background: ${bg}\n ;border: 0\n ;border-radius: 2px"
-tool_button_pressed_css="\n ;background: ${sel_bg}"
-tool_button_selected_css="\n ;background: ${sel_bg - #222}\n ;color: ${sel_fg}\n ;border: 1px solid ${sel_bg}"
-use_system_icons=false
diff --git a/copyq/copyq-commands.ini b/copyq/copyq-commands.ini
deleted file mode 100644
index ae62c0a..0000000
--- a/copyq/copyq-commands.ini
+++ /dev/null
@@ -1,44 +0,0 @@
-[Commands]
-1\Command=copyq: plugins.itempinned.pin()
-1\Icon=\xf08d
-1\InMenu=true
-1\Input=!OUTPUT
-1\InternalId=copyq_pinned_pin
-1\Name=Pin
-1\Output=application/x-copyq-item-pinned
-2\Command=copyq: plugins.itempinned.unpin()
-2\Icon=\xf08d
-2\InMenu=true
-2\Input=application/x-copyq-item-pinned
-2\InternalId=copyq_pinned_unpin
-2\Name=Unpin
-3\Command=copyq: plugins.itemtags.tag(decodeURIComponent('Important'))
-3\Icon=\xf02b
-3\InMenu=true
-3\InternalId=copyq_tags_tag:Important
-3\MatchCommand=copyq: plugins.itemtags.hasTag(decodeURIComponent('Important')) && fail()
-3\Name=Tag as \x201cImportant\x201d
-4\Command=copyq: plugins.itemtags.untag(decodeURIComponent('Important'))
-4\Icon=\xf02b
-4\InMenu=true
-4\InternalId=copyq_tags_untag:Important
-4\MatchCommand=copyq: plugins.itemtags.hasTag(decodeURIComponent('Important')) || fail()
-4\Name=Remove tag \x201cImportant\x201d
-5\Command=copyq: plugins.itemtags.tag()
-5\Icon=\xf02b
-5\InMenu=true
-5\InternalId=copyq_tags_tag
-5\Name=Add a Tag
-6\Command=copyq: plugins.itemtags.untag()
-6\Icon=\xf02b
-6\InMenu=true
-6\Input=application/x-copyq-tags
-6\InternalId=copyq_tags_untag
-6\Name=Remove a Tag
-7\Command=copyq: plugins.itemtags.clearTags()
-7\Icon=\xf02b
-7\InMenu=true
-7\Input=application/x-copyq-tags
-7\InternalId=copyq_tags_clear
-7\Name=Clear all tags
-size=7
diff --git a/copyq/copyq-commands.ini.bak b/copyq/copyq-commands.ini.bak
deleted file mode 100644
index ae62c0a..0000000
--- a/copyq/copyq-commands.ini.bak
+++ /dev/null
@@ -1,44 +0,0 @@
-[Commands]
-1\Command=copyq: plugins.itempinned.pin()
-1\Icon=\xf08d
-1\InMenu=true
-1\Input=!OUTPUT
-1\InternalId=copyq_pinned_pin
-1\Name=Pin
-1\Output=application/x-copyq-item-pinned
-2\Command=copyq: plugins.itempinned.unpin()
-2\Icon=\xf08d
-2\InMenu=true
-2\Input=application/x-copyq-item-pinned
-2\InternalId=copyq_pinned_unpin
-2\Name=Unpin
-3\Command=copyq: plugins.itemtags.tag(decodeURIComponent('Important'))
-3\Icon=\xf02b
-3\InMenu=true
-3\InternalId=copyq_tags_tag:Important
-3\MatchCommand=copyq: plugins.itemtags.hasTag(decodeURIComponent('Important')) && fail()
-3\Name=Tag as \x201cImportant\x201d
-4\Command=copyq: plugins.itemtags.untag(decodeURIComponent('Important'))
-4\Icon=\xf02b
-4\InMenu=true
-4\InternalId=copyq_tags_untag:Important
-4\MatchCommand=copyq: plugins.itemtags.hasTag(decodeURIComponent('Important')) || fail()
-4\Name=Remove tag \x201cImportant\x201d
-5\Command=copyq: plugins.itemtags.tag()
-5\Icon=\xf02b
-5\InMenu=true
-5\InternalId=copyq_tags_tag
-5\Name=Add a Tag
-6\Command=copyq: plugins.itemtags.untag()
-6\Icon=\xf02b
-6\InMenu=true
-6\Input=application/x-copyq-tags
-6\InternalId=copyq_tags_untag
-6\Name=Remove a Tag
-7\Command=copyq: plugins.itemtags.clearTags()
-7\Icon=\xf02b
-7\InMenu=true
-7\Input=application/x-copyq-tags
-7\InternalId=copyq_tags_clear
-7\Name=Clear all tags
-size=7
diff --git a/copyq/copyq-filter.ini b/copyq/copyq-filter.ini
deleted file mode 100644
index 50b0ec1..0000000
--- a/copyq/copyq-filter.ini
+++ /dev/null
@@ -1,2 +0,0 @@
-[General]
-filter_history=@Invalid()
diff --git a/copyq/copyq.conf b/copyq/copyq.conf
deleted file mode 100644
index 2430b72..0000000
--- a/copyq/copyq.conf
+++ /dev/null
@@ -1,216 +0,0 @@
-[General]
-plugin_priority=itemimage, itemencrypted, itemfakevim, itemnotes, itempinned, itemsync, itemtags, itemtext
-
-[Options]
-activate_closes=true
-activate_focuses=true
-activate_item_with_single_click=true
-activate_pastes=true
-always_on_top=true
-autocompletion=true
-autostart=false
-change_clipboard_owner_delay_ms=150
-check_clipboard=true
-check_selection=false
-clipboard_notification_lines=0
-clipboard_tab=&clipboard
-close_on_unfocus=false
-close_on_unfocus_delay_ms=500
-command_history_size=100
-confirm_exit=true
-copy_clipboard=false
-copy_selection=true
-disable_tray=false
-edit_ctrl_return=true
-editor=gedit --standalone -- %1
-expire_tab=0
-filter_case_insensitive=true
-filter_regular_expression=false
-hide_main_window=true
-hide_main_window_in_task_bar=false
-hide_tabs=false
-hide_toolbar=false
-hide_toolbar_labels=true
-item_popup_interval=0
-language=en
-max_process_manager_rows=1000
-maxitems=200
-move=true
-native_menu_bar=true
-native_notifications=true
-native_tray_menu=false
-notification_horizontal_offset=10
-notification_maximum_height=100
-notification_maximum_width=300
-notification_position=3
-notification_vertical_offset=10
-number_search=false
-open_windows_on_current_screen=true
-restore_geometry=true
-row_index_from_one=true
-run_selection=true
-save_delay_ms_on_item_added=300000
-save_delay_ms_on_item_edited=1000
-save_delay_ms_on_item_modified=300000
-save_delay_ms_on_item_moved=1800000
-save_delay_ms_on_item_removed=600000
-save_filter_history=false
-save_on_app_deactivated=true
-script_paste_delay_ms=250
-show_advanced_command_settings=false
-show_simple_items=false
-show_tab_item_count=false
-style=
-tab_tree=false
-tabs=&clipboard
-text_tab_width=8
-text_wrap=true
-transparency=0
-transparency_focused=0
-tray_commands=true
-tray_images=true
-tray_item_paste=true
-tray_items=5
-tray_menu_open_on_left_click=false
-tray_tab=
-tray_tab_is_current=true
-vi=false
-window_key_press_time_ms=50
-window_paste_with_ctrl_v_regex=
-window_wait_after_raised_ms=50
-window_wait_before_raise_ms=20
-window_wait_for_modifier_released_ms=2000
-window_wait_raised_ms=150
-
-[Plugins]
-itemencrypted\enabled=true
-itemfakevim\enabled=true
-itemimage\enabled=true
-itemimage\image_editor=
-itemimage\max_image_height=240
-itemimage\max_image_width=320
-itemimage\svg_editor=
-itemnotes\enabled=true
-itempinned\enabled=true
-itemsync\enabled=true
-itemtags\enabled=true
-itemtext\enabled=true
-
-[Shortcuts]
-about=shift+f1
-change_tab_icon=ctrl+shift+t
-commands=f6
-copy_selected_items=ctrl+c
-delete_item=del
-edit=f2
-edit_notes=shift+f2
-editor=ctrl+e
-editor_background=
-editor_bold=ctrl+b
-editor_cancel=esc
-editor_erase_style=
-editor_font=
-editor_foreground=
-editor_italic=ctrl+i
-editor_redo=ctrl+shift+z
-editor_save=f2
-editor_search=ctrl+f
-editor_strikethrough=
-editor_underline=ctrl+u
-editor_undo=ctrl+z
-exit=ctrl+q
-export=ctrl+s
-find_items=ctrl+g
-help=f1
-import=ctrl+i
-item-menu=shift+f10
-move_down=ctrl+down
-move_to_bottom=ctrl+end
-move_to_clipboard=
-move_to_top=ctrl+home
-move_up=ctrl+up
-new=ctrl+n
-new_tab=ctrl+t
-next_tab=right
-paste_selected_items=ctrl+v
-preferences=ctrl+p
-previous_tab=left
-process_manager=ctrl+shift+z
-remove_tab=ctrl+w
-rename_tab=ctrl+f2
-reverse_selected_items=ctrl+shift+r
-show-log=f12
-show_clipboard_content=ctrl+shift+c
-show_item_content=f4
-show_item_preview=f7
-sort_selected_items=ctrl+shift+s
-system-run=f5
-toggle_clipboard_storing=ctrl+shift+x
-
-[Tabs]
-1\icon=
-1\max_item_count=0
-1\name=&clipboard
-1\store_items=true
-size=1
-
-[Theme]
-alt_bg=default_alt_bg
-alt_item_css=
-bg=default_bg
-css=
-css_template_items=items
-css_template_main_window=main_window
-css_template_menu=menu
-css_template_notification=notification
-cur_item_css="\n ;border: 0.1em solid ${sel_bg}"
-edit_bg=default_bg
-edit_fg=default_text
-edit_font=
-fg=default_text
-find_bg=#ff0
-find_fg=#000
-find_font=
-font=
-font_antialiasing=true
-hover_item_css=
-icon_size=16
-item_css=
-item_spacing=
-menu_bar_css="\n ;background: ${bg}\n ;color: ${fg}"
-menu_bar_disabled_css="\n ;color: ${bg - #666}"
-menu_bar_selected_css="\n ;background: ${sel_bg}\n ;color: ${sel_fg}"
-menu_css="\n ;border: 1px solid ${sel_bg}\n ;background: ${bg}\n ;color: ${fg}"
-notes_bg=default_tooltip_bg
-notes_css=
-notes_fg=default_tooltip_text
-notes_font=
-notification_bg=#333
-notification_fg=#ddd
-notification_font=
-num_fg=default_placeholder_text
-num_font=
-num_margin=2
-search_bar="\n ;background: ${edit_bg}\n ;color: ${edit_fg}\n ;border: 1px solid ${alt_bg}\n ;margin: 2px"
-search_bar_focused="\n ;border: 1px solid ${sel_bg}"
-sel_bg=default_highlight_bg
-sel_fg=default_highlight_text
-sel_item_css=
-show_number=true
-show_scrollbars=true
-style_main_window=false
-tab_bar_css="\n ;background: ${bg - #222}"
-tab_bar_item_counter="\n ;color: ${fg - #044 + #400}\n ;font-size: 6pt"
-tab_bar_scroll_buttons_css="\n ;background: ${bg - #222}\n ;color: ${fg}\n ;border: 0"
-tab_bar_sel_item_counter="\n ;color: ${sel_bg - #044 + #400}"
-tab_bar_tab_selected_css="\n ;padding: 0.5em\n ;background: ${bg}\n ;border: 0.05em solid ${bg}\n ;color: ${fg}"
-tab_bar_tab_unselected_css="\n ;border: 0.05em solid ${bg}\n ;padding: 0.5em\n ;background: ${bg - #222}\n ;color: ${fg - #333}"
-tab_tree_css="\n ;color: ${fg}\n ;background-color: ${bg}"
-tab_tree_item_counter="\n ;color: ${fg - #044 + #400}\n ;font-size: 6pt"
-tab_tree_sel_item_counter="\n ;color: ${sel_fg - #044 + #400}"
-tab_tree_sel_item_css="\n ;color: ${sel_fg}\n ;background-color: ${sel_bg}\n ;border-radius: 2px"
-tool_bar_css="\n ;color: ${fg}\n ;background-color: ${bg}\n ;border: 0"
-tool_button_css="\n ;color: ${fg}\n ;background: ${bg}\n ;border: 0\n ;border-radius: 2px"
-tool_button_pressed_css="\n ;background: ${sel_bg}"
-tool_button_selected_css="\n ;background: ${sel_bg - #222}\n ;color: ${sel_fg}\n ;border: 1px solid ${sel_bg}"
-use_system_icons=false
diff --git a/copyq/copyq.pub b/copyq/copyq.pub
deleted file mode 100644
index a32e7f1..0000000
Binary files a/copyq/copyq.pub and /dev/null differ
diff --git a/dashie.json b/dashie.json
deleted file mode 100644
index 7e3e561..0000000
--- a/dashie.json
+++ /dev/null
@@ -1,491 +0,0 @@
-{
- "version": 1,
- "notes": "",
- "documentation": "\"This file is a QMK Configurator export. You can import this at . It can also be used directly with QMK's source code.\n\nTo setup your QMK environment check out the tutorial: \n\nYou can convert this file to a keymap.c using this command: `qmk json2c {keymap}`\n\nYou can compile this keymap using this command: `qmk compile {keymap}`\"\n",
- "keyboard": "rgbkb/sol3/rev1",
- "keymap": "dashie",
- "layout": "LAYOUT",
- "layers": [
- [
- "KC_ESC",
- "KC_1",
- "KC_2",
- "KC_3",
- "KC_4",
- "KC_5",
- "KC_MINS",
- "KC_EQL",
- "KC_6",
- "KC_7",
- "KC_8",
- "KC_9",
- "KC_0",
- "KC_BSPC",
- "KC_TAB",
- "KC_Q",
- "KC_W",
- "KC_E",
- "KC_R",
- "KC_T",
- "KC_LBRC",
- "KC_RBRC",
- "KC_Y",
- "KC_U",
- "KC_I",
- "KC_O",
- "KC_P",
- "KC_BSLS",
- "MO(1)",
- "KC_A",
- "KC_S",
- "KC_D",
- "KC_F",
- "KC_G",
- "KC_LPRN",
- "KC_RPRN",
- "KC_H",
- "KC_J",
- "KC_K",
- "KC_L",
- "KC_SCLN",
- "KC_QUOT",
- "KC_LSFT",
- "KC_Z",
- "KC_X",
- "KC_C",
- "KC_V",
- "KC_B",
- "KC_LCBR",
- "KC_RCBR",
- "KC_N",
- "KC_M",
- "KC_COMM",
- "KC_DOT",
- "KC_SLSH",
- "KC_GRV",
- "KC_LCTL",
- "MO(4)",
- "RGB_TOG",
- "KC_LALT",
- "KC_LGUI",
- "KC_SPC",
- "KC_PGDN",
- "KC_DEL",
- "KC_BSPC",
- "KC_PGUP",
- "KC_ENT",
- "KC_RCTL",
- "KC_RALT",
- "KC_CAPS",
- "KC_HOME",
- "KC_RCTL",
- "KC_VOLD",
- "KC_VOLU",
- "KC_VOLD",
- "KC_VOLU",
- "KC_VOLD",
- "KC_VOLU",
- "KC_VOLD",
- "KC_VOLU",
- "KC_VOLD",
- "KC_VOLU",
- "KC_VOLD",
- "KC_VOLU",
- "KC_VOLD",
- "KC_VOLU",
- "KC_MNXT",
- "KC_MPLY",
- "KC_MPRV",
- "KC_VOLD",
- "KC_VOLU",
- "KC_MNXT",
- "KC_MPLY",
- "KC_MPRV"
- ],
- [
- "KC_ESC",
- "KC_F1",
- "KC_F2",
- "KC_F3",
- "KC_F4",
- "KC_F5",
- "KC_F6",
- "KC_F7",
- "KC_F8",
- "KC_F9",
- "KC_F10",
- "KC_F11",
- "KC_F12",
- "KC_DEL",
- "KC_TRNS",
- "KC_MPRV",
- "KC_MNXT",
- "KC_MPLY",
- "KC_MUTE",
- "KC_G",
- "KC_TRNS",
- "KC_TRNS",
- "KC_BTN2",
- "KC_MS_L",
- "KC_MS_D",
- "KC_MS_U",
- "KC_MS_R",
- "KC_BTN1",
- "KC_TRNS",
- "KC_VOLD",
- "KC_VOLU",
- "KC_S",
- "KC_T",
- "KC_D",
- "KC_TRNS",
- "KC_TRNS",
- "KC_H",
- "KC_LEFT",
- "KC_DOWN",
- "KC_UP",
- "KC_RGHT",
- "KC_TRNS",
- "KC_TRNS",
- "KC_Z",
- "KC_X",
- "KC_C",
- "KC_V",
- "KC_B",
- "KC_TRNS",
- "KC_TRNS",
- "KC_K",
- "KC_M",
- "KC_COMM",
- "KC_DOT",
- "KC_SLSH",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_CAPS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS"
- ],
- [
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_F1",
- "KC_F5",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_Q",
- "KC_W",
- "KC_E",
- "KC_R",
- "KC_T",
- "KC_F2",
- "KC_F6",
- "KC_Y",
- "KC_U",
- "KC_I",
- "KC_O",
- "KC_P",
- "KC_TRNS",
- "KC_TRNS",
- "KC_A",
- "KC_S",
- "KC_D",
- "KC_F",
- "KC_G",
- "KC_F3",
- "KC_F7",
- "KC_H",
- "KC_J",
- "KC_K",
- "KC_L",
- "KC_SCLN",
- "KC_TRNS",
- "KC_TRNS",
- "KC_Z",
- "KC_X",
- "KC_C",
- "KC_V",
- "KC_B",
- "KC_F4",
- "KC_F8",
- "KC_N",
- "KC_M",
- "KC_COMM",
- "KC_DOT",
- "KC_SLSH",
- "KC_TRNS",
- "KC_TRNS",
- "KC_NO",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS"
- ],
- [
- "KC_TRNS",
- "KC_F1",
- "KC_F2",
- "KC_F3",
- "KC_F4",
- "KC_F5",
- "KC_F11",
- "KC_F12",
- "KC_F6",
- "KC_F7",
- "KC_F8",
- "KC_F9",
- "KC_F10",
- "KC_TRNS",
- "KC_TRNS",
- "KC_HOME",
- "KC_UP",
- "KC_END",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_HOME",
- "KC_UP",
- "KC_END",
- "KC_PSCR",
- "KC_PGUP",
- "KC_TRNS",
- "KC_LEFT",
- "KC_DOWN",
- "KC_RGHT",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_LEFT",
- "KC_DOWN",
- "KC_RGHT",
- "KC_INS",
- "KC_PGDN",
- "KC_TRNS",
- "ANY(AU_TOGG)",
- "ANY(MU_TOGG)",
- "ANY(MU_NEXT)",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "ANY(CK_TOGG)",
- "ANY(CK_UP)",
- "ANY(CK_DOWN)",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_MPLY",
- "KC_MNXT",
- "KC_MUTE",
- "KC_VOLD",
- "KC_VOLU",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS"
- ],
- [
- "KC_TRNS",
- "KC_F1",
- "KC_F2",
- "KC_F3",
- "KC_F4",
- "KC_F5",
- "KC_F11",
- "KC_F12",
- "KC_F6",
- "KC_F7",
- "KC_F8",
- "KC_F9",
- "KC_F10",
- "KC_TRNS",
- "KC_TRNS",
- "RGB_SAD",
- "RGB_VAI",
- "RGB_SAI",
- "QK_BOOT",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_P7",
- "KC_P8",
- "KC_P9",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "RGB_HUD",
- "RGB_VAD",
- "RGB_HUI",
- "KC_NO",
- "KC_TRNS",
- "ANY(DM_REC1)",
- "KC_TRNS",
- "KC_TRNS",
- "KC_P4",
- "KC_P5",
- "KC_P6",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "RGB_SPD",
- "KC_TRNS",
- "RGB_SPI",
- "KC_TRNS",
- "KC_TRNS",
- "ANY(DM_RSTP)",
- "KC_TRNS",
- "KC_TRNS",
- "KC_P1",
- "KC_P2",
- "KC_P3",
- "KC_TRNS",
- "DF(2)",
- "KC_TRNS",
- "RGB_RMOD",
- "RGB_TOG",
- "RGB_MOD",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_P0",
- "KC_PDOT",
- "KC_NUM",
- "DF(0)",
- "DF(1)",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS",
- "KC_TRNS"
- ]
- ],
- "author": ""
-}
\ No newline at end of file
diff --git a/docs/default.nix b/docs/default.nix
new file mode 100644
index 0000000..1fd8a1e
--- /dev/null
+++ b/docs/default.nix
@@ -0,0 +1,61 @@
+# with friendly help by stylix: https://github.com/danth/stylix/blob/master/docs/default.nix
+{
+ pkgs,
+ buildSystems,
+ lib,
+ ...
+}: let
+ makeOptionsDoc = configuration: pkgs.nixosOptionsDoc {options = configuration;};
+ generateDocs = obj: ''
+ touch src/${obj.fst}.md
+ sed '/*Declared by:*/,/^$/d' <${obj.snd.optionsCommonMark} >> src/${obj.fst}.md
+ '';
+ summaryAppend = name: ''
+ echo "- [${name}](${name}.md)" >> src/SUMMARY.md
+ '';
+ system = (buildSystems {root = ../example/.;})."example".options;
+ makeOptionsDocPrograms = names: pkgs.nixosOptionsDoc {options = lib.attrByPath (lib.splitString "." names) null system.mods;};
+ conf = makeOptionsDoc system.conf;
+ basePath = ../modules/programs;
+ pathToAttrs = path:
+ lib.attrsets.mapAttrsToList (
+ name: meta: {
+ inherit name;
+ inherit meta;
+ }
+ )
+ (builtins.readDir path);
+ pathToStrings = path: prefix: let
+ mapFn = attrs:
+ if attrs.meta == "directory"
+ then pathToStrings "${basePath}/${attrs.name}" attrs.name
+ else if prefix != ""
+ then "${prefix}.${attrs.name}"
+ else attrs.name;
+ in
+ map
+ mapFn
+ (pathToAttrs path);
+ filteredNames = builtins.filter (names: !(lib.strings.hasInfix "default" names)) (
+ map (name: lib.strings.removeSuffix ".nix" name) (lib.lists.flatten (pathToStrings basePath ""))
+ );
+ deduplicatedNames = map (name: lib.strings.splitString "." name |> lib.lists.unique |> lib.strings.concatStringsSep ".") filteredNames;
+ mods = map makeOptionsDocPrograms deduplicatedNames;
+ docs = lib.strings.concatLines (map generateDocs (lib.lists.zipLists deduplicatedNames mods));
+ summary = lib.strings.concatStringsSep " " (map summaryAppend deduplicatedNames);
+in
+ pkgs.stdenvNoCC.mkDerivation {
+ name = "dashNix-book";
+ src = ./.;
+
+ patchPhase = ''
+ sed '/*Declared by:*/,/^$/d' <${conf.optionsCommonMark} >> src/conf.md
+ ${docs}
+ echo "[README](README.md)\n # Options\n - [Base Config](conf.md)" >> src/SUMMARY.md
+ ${summary}
+ '';
+
+ buildPhase = ''
+ ${pkgs.mdbook}/bin/mdbook build --dest-dir $out
+ '';
+ }
diff --git a/docs/src/README.md b/docs/src/README.md
new file mode 100644
index 0000000..3658e00
--- /dev/null
+++ b/docs/src/README.md
@@ -0,0 +1,329 @@
+
+
+
+
+
+
+An opinionated flake to bootstrap NixOS systems with default configurations for various programs and services from both NixOS and HomeManager which can be enabled, disabled, configured or replaced at will.
+
+# Usage
+
+This flake is intended to be used as an input to your own NixOS configuration:
+
+```nix
+dashNix = {
+ url = "github:Xetibo/DashNix";
+ inputs = {
+ # ensure these are here to update the packages on your own
+ nixpkgs.follows = "nixpkgs";
+ stable.follows = "stable";
+ };
+};
+```
+
+You can then configure your systems in your flake outputs with a provided library command:
+
+Please note that overriding inputs will invalidate the cache configuration, this means you will have to add this manually:
+
+```nix
+ builders-use-substitutes = true;
+
+ extra-substituters = [
+ "https://hyprland.cachix.org"
+ "https://anyrun.cachix.org"
+ "https://cache.garnix.io"
+ "https://oxipaste.cachix.org"
+ "https://oxinoti.cachix.org"
+ "https://oxishut.cachix.org"
+ "https://oxidash.cachix.org"
+ "https://oxicalc.cachix.org"
+ "https://hyprdock.cachix.org"
+ "https://reset.cachix.org"
+ "https://dashvim.cachix.org"
+ ];
+
+ extra-trusted-public-keys = [
+ "hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="
+ "anyrun.cachix.org-1:pqBobmOjI7nKlsUMV25u9QHa9btJK65/C8vnO3p346s="
+ "cache.garnix.io:CTFPyKSLcx5RMJKfLo5EEPUObbA78b0YQ2DTCJXqr9g="
+ "oxipaste.cachix.org-1:n/oA3N3Z+LJP7eIWOwuoLd9QnPyZXqFjLgkahjsdDGc="
+ "oxinoti.cachix.org-1:dvSoJl2Pjo5HMaNngdBbSaixK9BSf2N8gzjP2MdGvfc="
+ "oxishut.cachix.org-1:axyAGF3XMh1IyMAW4UMbQCdMNovDH0KH6hqLLRJH8jU="
+ "oxidash.cachix.org-1:5K2FNHp7AS8VF7LmQkJAUG/dm6UHCz4ngshBVbjFX30="
+ "oxicalc.cachix.org-1:qF3krFc20tgSmtR/kt6Ku/T5QiG824z79qU5eRCSBTQ="
+ "hyprdock.cachix.org-1:HaROK3fBvFWIMHZau3Vq1TLwUoJE8yRbGLk0lEGzv3Y="
+ "reset.cachix.org-1:LfpnUUdG7QM/eOkN7NtA+3+4Ar/UBeYB+3WH+GjP9Xo="
+ "dashvim.cachix.org-1:uLRdxp1WOWHnsZZtu3SwUWZRsvC7SXo0Gyk3tIefuL0="
+ ];
+```
+
+```nix
+nixosConfigurations = inputs.dashNix.dashNixLib.buildSystems { root = ./.; };
+```
+
+This command will build each system that is placed within the hosts/ directory.
+In this directory create one directory for each system you want to configure with DashNix.
+This will automatically pick up the hostname for the system and look for 3 different files that are explained below.
+(Optionally, you can also change the parameter root (./.) to define a different starting directory than hosts/)
+
+In order for your configuration to work, you are required to at least provide a single config file with a further config file being optional for custom configuration.
+The hardware.nix specifies additional NixOS configuration, while home.nix specifies additional home-manager configuration. (both optional)
+
+|- flake.nix\
+|- flake.lock\
+|- hosts/\
+|--- system1/\
+|------ configuration.nix (required)\
+|------ hardware.nix (optional)\
+|------ home.nix (optional)\
+|--- system2/\
+|------ configuration.nix (required)\
+|------ hardware.nix (optional)\
+|------ home.nix (optional)\
+|--- system3/\
+|------ configuration.nix (required)\
+|------ hardware.nix (optional)\
+|------ home.nix (optional)
+
+Here is a minimal required configuration.nix (the TODOs mention a required change):
+
+```nix
+{config, ...}: {
+ # TODO denote important changes
+
+ # variables for system
+ conf = {
+ # TODO your username
+ username = "YOURNAME";
+ # TODO only needed when you use intel -> amd is default
+ # cpu = "intel";
+ # TODO your xkb layout
+ locale = "something.UTF-8";
+ # TODO your timezone
+ timezone = "CONTINENT/CITY";
+ };
+
+ # modules
+ mods = {
+ # default disk config has root home boot and swap partition, overwrite if you want something different
+ sops.enable = false;
+ nextcloud.enable = false;
+ wm.monitors = [
+ # Example
+ # {
+ # name = "DP-1";
+ # resolutionX = 3440;
+ # resolutionY = 1440;
+ # refreshrate = 180;
+ # positionX = 2560;
+ # positionY = 0;
+ # scale = 1;
+ # transform = "0";
+ # vrr = false;
+ # }
+ ];
+ gpu.nvidia.enable = true;
+ kdeConnect.enable = true;
+ # login manager:
+ # default is greetd
+ # greetd = { };
+ # sddm = { };
+ # gdm = { };
+ drives = {
+ # default assumes ROOT, BOOT, HOME and SWAP labaled drives exist
+ # for an example without HOME see below
+ # defaultDrives.enable = false;
+ # extraDrives = [
+ # {
+ # name = "boot";
+ # drive = {
+ # device = "/dev/disk/by-label/BOOT";
+ # fsType = "vfat";
+ # options = [ "rw" "fmask=0022" "dmask=0022" "noatime" ];
+ # };
+ # }
+ # {
+ # name = "";
+ # drive = {
+ # device = "/dev/disk/by-label/ROOT";
+ # fsType = "ext4";
+ # options = [ "noatime" "nodiratime" "discard" ];
+ # };
+ # }
+ # ];
+ # You can also use disko to format your disks on installation.
+ # Please refer to the Documentation about the drives module for an example.
+ };
+ };
+}
+```
+
+## First Login
+
+After logging in the first time, your password will be set to "firstlogin", please change this to whatever you like.
+
+## Configuring pkgs
+
+While DashNix offers a default pkgs config, you may want to permit an unsecure packages,
+add additional modules/inputs, or add an overlay to them.
+You can configure both stable and unstable pkgs the following way:
+
+Please note that modules and inputs are merged together to ensure functionality.
+
+```nix
+currentSystem = "x86_64-linux";
+permittedPackages = [
+ "some package"
+];
+config = {
+ system = currentSystem;
+ config = {
+ allowUnfree = true;
+ permittedInsecurePackages = permittedPackages;
+ };
+ inputs = {
+ # Some inputs
+ }
+ mods = {
+ home = [
+ # Some home manager module
+ ];
+ nixos = [
+ # Some nixos module
+ ];
+}
+};
+unstableBundle = {
+ pkgs = inputs.unstable;
+ inherit config mods;
+};
+inputs.dashNix.dashNixLib.buildSystems {
+ root = ./.;
+ inherit unstableBundle;
+}
+```
+
+With this you could also change your input to something different should you wish to do so.
+Note that overriding inputs via the flake still works,
+this way however ensures you can also configure the inputs.
+
+## Stable/Unstable
+
+Sometimes you want to differentiate between systems that are stable and unstable, e.g. for servers and desktops/laptops.
+This can be done with the overridePkgs flag for the lib function:
+
+(overridePkgs simply inverts the default bundle that is used for the nix standard library as well as NixOS itself)
+
+```nix
+nixosConfigurations =
+ inputs.dashNix.dashNixLib.buildSystems {
+ root = ./stable;
+ inherit stableBundle;
+ overridePkgs = true;
+ }
+ // inputs.dashNix.dashNixLib.buildSystems {
+ inherit unstableBundle;
+ root = ./unstable;
+ };
+```
+
+You can now place your systems in the respective directories.
+Keep in mind that the hosts directory will still need to exist in each variant.
+E.g. stable/hosts/yourserver and unstable/hosts/yourdesktop
+
+# Installation via ISO
+
+You can find a custom ISO in the releases: [Link](https://github.com/Xetibo/DashNix/releases).
+With this, you will receive the example config in /iso/example alongside the gnome desktop environment,
+as well as a few tools like gnome-disks, Neovim, Vscodium, a browser etc.
+
+Alternatively, you can use whatever NixOS installer and just install your config from there, just make sure to set the drive configuration before.
+
+## Commands
+
+First, copy the read-only config from /iso/example-config to a location of your choice.
+
+```sh
+cp /iso/example-config ~/config -r
+```
+
+Then configure as you please and choose a command below depending on your disk installation variant.
+
+Installation via manual configuration:
+
+```sh
+sudo nixos-install --flake # --root --option experimental-features "nix-command flakes pipe-operators"
+#example
+#nixos-install --flake ~/config#globi --root /mnt --option experimental-features "nix-command flakes pipe-operators"
+```
+
+Installation via disko:
+
+```sh
+sudo disko-install --flake # --disk --option experimental-features "nix-command flakes pipe-operators"
+#example
+#disko-install -- --flake ~/config#globi --disk main /dev/nvme0n1 --option experimental-features "nix-command flakes pipe-operators"
+```
+
+# Installation via flake
+
+If you already have nix installed, you can instead just copy the default config onto your system and install DashNix with it.
+To create the example config for a base to start with, you can just run this flake with the mkFlake command:
+
+```sh
+nix run github:Xetibo/DashNix#mkFlake
+```
+
+This command will put the default configuration into $HOME/gits/nixos
+
+# Modules
+
+This configuration features several modules that can be used as preconfigured "recipies".
+These modules attempt to combine the home-manager and nixos packages/options to one single configuration file for each new system.
+For package lists, please check the individual modules, as the lists can be long.
+
+- Hyprland: Installs and configures Hyprland with various additional packages
+- Niri: Installs and configures Niri with various additional packages
+- acpid : Enables the acpid daemon
+- base packages : A list of system packages to be installed by default
+- bluetooth : Configures/enables bluetooth and installs tools for bluetooth
+- coding packages : A list of coding packages to be installed by default
+- drives : A drive configuration module
+- firefox: Enables and configures firefox (extensions and settings)
+- fish: Enables and configures fish shell
+- gaming : Configures gaming related features (launchers, gamemode)
+- git : Git key and config module
+- gnome_services : Gnome services for minimal enviroments -> Window managers etc
+- gpu : GPU settings (AMD)
+- greetd : Enables and configures the greetd/regreet login manager with Hyprland
+- home packages : A list of home packages to be installed by default
+- kde_connect : Enables KDE connect and opens its ports
+- keepassxc : Configures keepassxc
+- kitty: Enables and configures kitty terminal
+- layout : Modules to configure keyboard layout system wide
+- media packages : A list of media packages to be installed by default
+- mime: Mime type configuration
+- nextcloud : Handles synchronization via nextcloud cmd. (requires config.sops.secrets.nextcloud)
+- oxi: My own programs, can be selectively disabled, or as a whole
+- piper : Installs and enables piper alongside its daemon
+- plymouth: enable or disable plymouth
+- printing : Enables and configures printing services
+- scripts: Various preconfigured scripts with the ability to add more
+- sops: Enables sops-nix
+- starship : Configures the starship prompt
+- stylix : Configures system themes, can also be applied to dashvim if used.
+- teams: For the poor souls that have to use this....
+- virtualbox : Enables and configures virtualbox
+- xkb: Keyboard layout configuration
+- xone : Installs the xone driver
+- yazi: Installs yazi and sets custom keybinds
+
+# Credits
+
+- [Fufexan](https://github.com/fufexan) for the xdg-mime config:
+- [Catppuccin](https://github.com/catppuccin) for base16 colors and zen-browser css
+- [Danth](https://github.com/danth) for providing a base for the nix docs
+- [chermnyx](https://github.com/chermnyx) for providing a base for zen configuration
+- [voronind-com](https://github.com/voronind-com) for providing the darkreader configuration
+- [Nix-Artwork](https://github.com/NixOS/nixos-artwork/tree/master/logo) for the Nix/NixOS logo (Tim Cuthbertson (@timbertson))
+- [xddxdd](https://github.com/xddxdd) for the CachyOS-Kernel flake
diff --git a/hyprdock/hyprdock.toml b/docs/src/SUMMARY.md
similarity index 100%
rename from hyprdock/hyprdock.toml
rename to docs/src/SUMMARY.md
diff --git a/docs/src/coding.md b/docs/src/coding.md
new file mode 100644
index 0000000..e69de29
diff --git a/docs/src/conf.md b/docs/src/conf.md
new file mode 100755
index 0000000..aa51f0b
--- /dev/null
+++ b/docs/src/conf.md
@@ -0,0 +1 @@
+# This file handles the basic configuration for settings like language, timezone, input, cpu etc.
diff --git a/docs/src/logo.svg b/docs/src/logo.svg
new file mode 100644
index 0000000..08baa43
--- /dev/null
+++ b/docs/src/logo.svg
@@ -0,0 +1,238 @@
+
+
+
+
diff --git a/docs/src/mods.md b/docs/src/mods.md
new file mode 100755
index 0000000..df7fe4f
--- /dev/null
+++ b/docs/src/mods.md
@@ -0,0 +1 @@
+# This file handles configuration of individual modules.
diff --git a/environment.d/envvars.conf b/environment.d/envvars.conf
deleted file mode 100644
index 1c04120..0000000
--- a/environment.d/envvars.conf
+++ /dev/null
@@ -1,9 +0,0 @@
-GPG_TTY=$(tty)
-PATH=$PATH:$HOME/.local/bin
-TEXMFHOME=$HOME/.texmf
-PATH=/usr/bin/site_perl:/usr/bin/vendor_perl:/usr/bin/core_perl:$HOME/.local/bin:$HOME/.cargo/bin:$PATH
-EDITOR="neovide --novsync --nofork"
-SUDO_EDITOR="neovide --novsync --nofork"
-PKG_CONFIG_PATH=/usr/local/lib/pkgconfig
-LD_LIBRARY_PATH=/usr/local/lib
-SCRIPTS=$HOME/.config/scripts
diff --git a/example/flake.nix b/example/flake.nix
new file mode 100644
index 0000000..01ec944
--- /dev/null
+++ b/example/flake.nix
@@ -0,0 +1,51 @@
+{
+ description = "some dots";
+
+ inputs = {
+ nixpkgs.url = "github:NixOs/nixpkgs/nixos-unstable";
+ stable.url = "github:NixOs/nixpkgs/nixos-24.05";
+ dashNix = {
+ url = "github:Xetibo/DashNix";
+ inputs = {
+ nixpkgs.follows = "nixpkgs";
+ stable.follows = "stable";
+ };
+ };
+ };
+
+ outputs = inputs: {
+ nixosConfigurations = inputs.dashNix.dashNixLib.buildSystems {root = ./.;};
+ };
+
+ nixConfig = {
+ builders-use-substitutes = true;
+
+ extra-substituters = [
+ "https://hyprland.cachix.org"
+ "https://anyrun.cachix.org"
+ "https://cache.garnix.io"
+ "https://oxipaste.cachix.org"
+ "https://oxinoti.cachix.org"
+ "https://oxishut.cachix.org"
+ "https://oxidash.cachix.org"
+ "https://oxicalc.cachix.org"
+ "https://hyprdock.cachix.org"
+ "https://reset.cachix.org"
+ "https://dashvim.cachix.org"
+ ];
+
+ extra-trusted-public-keys = [
+ "hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="
+ "anyrun.cachix.org-1:pqBobmOjI7nKlsUMV25u9QHa9btJK65/C8vnO3p346s="
+ "cache.garnix.io:CTFPyKSLcx5RMJKfLo5EEPUObbA78b0YQ2DTCJXqr9g="
+ "oxipaste.cachix.org-1:n/oA3N3Z+LJP7eIWOwuoLd9QnPyZXqFjLgkahjsdDGc="
+ "oxinoti.cachix.org-1:dvSoJl2Pjo5HMaNngdBbSaixK9BSf2N8gzjP2MdGvfc="
+ "oxishut.cachix.org-1:axyAGF3XMh1IyMAW4UMbQCdMNovDH0KH6hqLLRJH8jU="
+ "oxidash.cachix.org-1:5K2FNHp7AS8VF7LmQkJAUG/dm6UHCz4ngshBVbjFX30="
+ "oxicalc.cachix.org-1:qF3krFc20tgSmtR/kt6Ku/T5QiG824z79qU5eRCSBTQ="
+ "hyprdock.cachix.org-1:HaROK3fBvFWIMHZau3Vq1TLwUoJE8yRbGLk0lEGzv3Y="
+ "reset.cachix.org-1:LfpnUUdG7QM/eOkN7NtA+3+4Ar/UBeYB+3WH+GjP9Xo="
+ "dashvim.cachix.org-1:uLRdxp1WOWHnsZZtu3SwUWZRsvC7SXo0Gyk3tIefuL0="
+ ];
+ };
+}
diff --git a/example/hosts/example/configuration.nix b/example/hosts/example/configuration.nix
new file mode 100644
index 0000000..dbe8cd0
--- /dev/null
+++ b/example/hosts/example/configuration.nix
@@ -0,0 +1,68 @@
+{config, ...}: {
+ # TODO denote important changes
+
+ # variables for system
+ conf = {
+ # TODO your username
+ username = "exampleName";
+ # TODO only needed when you use intel -> amd is default
+ # cpu = "intel";
+ # TODO your xkb layout
+ locale = "en_US.UTF-8";
+ # TODO your timezone
+ timezone = "Europe/Zurich";
+ };
+
+ # modules
+ mods = {
+ # default disk config has root home boot and swap partition, overwrite if you want something different
+ sops.enable = false;
+ nextcloud.enable = false;
+ wm.monitors = [
+ # Example
+ # {
+ # name = "DP-1";
+ # resolutionX = 3440;
+ # resolutionY = 1440;
+ # refreshrate = 180;
+ # positionX = 2560;
+ # positionY = 0;
+ # scale = 1;
+ # transform = "0";
+ # vrr = false;
+ # }
+ ];
+ gpu.nvidia.enable = true;
+ kdeConnect.enable = true;
+ # login manager:
+ # default is greetd
+ # greetd = { };
+ # sddm = { };
+ # gdm = { };
+ drives = {
+ # default assumes ROOT, BOOT, HOME and SWAP labaled drives exist
+ # for an example without HOME see below
+ # defaultDrives.enable = false;
+ # extraDrives = [
+ # {
+ # name = "boot";
+ # drive = {
+ # device = "/dev/disk/by-label/BOOT";
+ # fsType = "vfat";
+ # options = [ "rw" "fmask=0022" "dmask=0022" "noatime" ];
+ # };
+ # }
+ # {
+ # name = "";
+ # drive = {
+ # device = "/dev/disk/by-label/ROOT";
+ # fsType = "ext4";
+ # options = [ "noatime" "nodiratime" "discard" ];
+ # };
+ # }
+ # ];
+ # You can also use disko to format your disks on installation.
+ # Please refer to the Documentation about the drives module for an example.
+ };
+ };
+}
diff --git a/example/hosts/example/hardware.nix b/example/hosts/example/hardware.nix
new file mode 100644
index 0000000..855cafb
--- /dev/null
+++ b/example/hosts/example/hardware.nix
@@ -0,0 +1,3 @@
+{
+ # this file adds custom NixOS configuration
+}
diff --git a/example/hosts/example/home.nix b/example/hosts/example/home.nix
new file mode 100644
index 0000000..e011ea7
--- /dev/null
+++ b/example/hosts/example/home.nix
@@ -0,0 +1,3 @@
+{
+ # this file adds custom home-manager configuration
+}
diff --git a/example/secrets/secrets.md b/example/secrets/secrets.md
new file mode 100644
index 0000000..86d99c6
--- /dev/null
+++ b/example/secrets/secrets.md
@@ -0,0 +1,3 @@
+# Secrets
+
+This file is for sops-nix and is also where your keys for various secrets will be stored.
diff --git a/example/secrets/secrets.yaml b/example/secrets/secrets.yaml
new file mode 100644
index 0000000..e69de29
diff --git a/fish/completions/tide.fish b/fish/completions/tide.fish
deleted file mode 100644
index 2d3784d..0000000
--- a/fish/completions/tide.fish
+++ /dev/null
@@ -1,12 +0,0 @@
-complete tide --no-files
-
-set -l subcommands bug-report configure
-
-complete tide -x -n __fish_use_subcommand -a bug-report -d "Print info for use in bug reports"
-complete tide -x -n __fish_use_subcommand -a configure -d "Run the configuration wizard"
-
-complete tide -x -n "not __fish_seen_subcommand_from $subcommands" -s h -l help -d "Print help message"
-complete tide -x -n "not __fish_seen_subcommand_from $subcommands" -s v -l version -d "Print tide version"
-
-complete tide -x -n '__fish_seen_subcommand_from bug-report' -l clean -d "Run clean Fish instance and install Tide"
-complete tide -x -n '__fish_seen_subcommand_from bug-report' -l verbose -d "Print full Tide configuration"
diff --git a/fish/conf.d/_tide_init.fish b/fish/conf.d/_tide_init.fish
deleted file mode 100644
index 939f17c..0000000
--- a/fish/conf.d/_tide_init.fish
+++ /dev/null
@@ -1,41 +0,0 @@
-function _tide_init_install --on-event _tide_init_install
- set -U VIRTUAL_ENV_DISABLE_PROMPT true
-
- source (functions --details _tide_sub_configure)
- _load_config lean
- _tide_finish
-
- if status is-interactive
- tide bug-report --check || sleep 4
-
- if contains ilancosman/tide (string lower $_fisher_plugins)
- set_color bryellow
- echo "ilancosman/tide is a development branch. Please install from a release tag:"
- echo -ns "fisher install ilancosman/tide@v5" | fish_indent --ansi
- sleep 3
- end
-
- switch (read --prompt-str="Configure tide prompt? [Y/n] " | string lower)
- case y ye yes ''
- tide configure
- case '*'
- echo -s \n 'Run ' (echo -ns "tide configure" | fish_indent --ansi) ' to customize your prompt.'
- end
- end
-end
-
-function _tide_init_update --on-event _tide_init_update
- # Warn users who install from main branch
- if contains ilancosman/tide (string lower $_fisher_plugins)
- set_color bryellow
- echo "ilancosman/tide is a development branch. Please install from a release tag:"
- echo -ns "fisher install ilancosman/tide@v5" | fish_indent --ansi
- sleep 3
- end
-end
-
-function _tide_init_uninstall --on-event _tide_init_uninstall
- set -e VIRTUAL_ENV_DISABLE_PROMPT
- set -e (set -U --names | string match --entire -r '^_?tide')
- functions --erase (functions --all | string match --entire -r '^_?tide')
-end
diff --git a/fish/config.fish b/fish/config.fish
deleted file mode 100644
index 20c0c5b..0000000
--- a/fish/config.fish
+++ /dev/null
@@ -1,140 +0,0 @@
-if status is-interactive
- # Commands to run in interactive sessions can go here
-end
-# =============================================================================
-#
-# Utility functions for zoxide.
-#
-set fish_greeting
-function sudo --description "Replacement for Bash 'sudo !!' command to run last command using sudo."
- if test "$argv" = !!
- echo sudo $history[1]
- eval command sudo $history[1]
- else
- command sudo $argv
- end
-end
-alias ls='lsd'
-alias :q='exit'
-alias gh='git push origin'
-alias gl='git pull origin'
-alias gm='git commit -m'
-alias ga="git add -A"
-alias g+='bear -- g++ -Wextra -Werror -std=c++20'
-alias s="kitty +kitten ssh"
-alias zl='z "" '
-alias jo='joshuto'
-alias nv='neovide --novsync --nofork'
-alias cr='cargo run'
-alias grep='rg'
-alias cat='bat'
-alias find='fd'
-alias rm='rip'
-
-# pwd based on the value of _ZO_RESOLVE_SYMLINKS.
-function __zoxide_pwd
- builtin pwd -L
-end
-
-# A copy of fish's internal cd function. This makes it possible to use
-# `alias cd=z` without causing an infinite loop.
-if ! builtin functions -q __zoxide_cd_internal
- if builtin functions -q cd
- builtin functions -c cd __zoxide_cd_internal
- else
- alias __zoxide_cd_internal='builtin cd'
- end
-end
-
-# cd + custom logic based on the value of _ZO_ECHO.
-function __zoxide_cd
- __zoxide_cd_internal $argv
-end
-
-# =============================================================================
-#
-# Hook configuration for zoxide.
-#
-
-# Initialize hook to add new entries to the database.
-function __zoxide_hook --on-variable PWD
- test -z "$fish_private_mode"
- and command zoxide add -- (__zoxide_pwd)
-end
-
-# =============================================================================
-#
-# When using zoxide with --no-cmd, alias these internal functions as desired.
-#
-
-set __zoxide_z_prefix 'z!'
-
-# Jump to a directory using only keywords.
-function __zoxide_z
- set -l argc (count $argv)
- set -l completion_regex '^'(string escape --style=regex $__zoxide_z_prefix)'(.*)$'
-
- if test $argc -eq 0
- __zoxide_cd $HOME
- else if test "$argv" = -
- __zoxide_cd -
- else if test $argc -eq 1 -a -d $argv[1]
- __zoxide_cd $argv[1]
- else if set -l result (string match --groups-only --regex $completion_regex $argv[-1])
- __zoxide_cd $result
- else
- set -l result (command zoxide query --exclude (__zoxide_pwd) -- $argv)
- and __zoxide_cd $result
- end
-end
-
-# Completions for `z`.
-function __zoxide_z_complete
- set -l tokens (commandline --current-process --tokenize)
- set -l curr_tokens (commandline --cut-at-cursor --current-process --tokenize)
-
- if test (count $tokens) -le 2 -a (count $curr_tokens) -eq 1
- # If there are < 2 arguments, use `cd` completions.
- __fish_complete_directories "$tokens[2]" ''
- else if test (count $tokens) -eq (count $curr_tokens)
- # If the last argument is empty, use interactive selection.
- set -l query $tokens[2..-1]
- set -l result (zoxide query --exclude (__zoxide_pwd) -i -- $query)
- and echo $__zoxide_z_prefix$result
- commandline --function repaint
- end
-end
-
-# Jump to a directory using interactive search.
-function __zoxide_zi
- set -l result (command zoxide query -i -- $argv)
- and __zoxide_cd $result
-end
-
-# =============================================================================
-#
-# Commands for zoxide. Disable these using --no-cmd.
-#
-
-abbr --erase z &>/dev/null
-complete --command z --erase
-function z
- __zoxide_z $argv
-end
-complete --command z --no-files --arguments '(__zoxide_z_complete)'
-
-abbr --erase zi &>/dev/null
-complete --command zi --erase
-function zi
- __zoxide_zi $argv
-end
-
-# =============================================================================
-#
-# To initialize zoxide, add this to your configuration (usually
-# ~/.config/fish/config.fish):
-#
-# zoxide init fish | source
-#
-# Note: zoxide only supports fish v3.4.0 and above.
-#
diff --git a/fish/fish_plugins b/fish/fish_plugins
deleted file mode 100644
index b2d5f77..0000000
--- a/fish/fish_plugins
+++ /dev/null
@@ -1 +0,0 @@
-ilancosman/tide@v5
diff --git a/fish/functions/_tide_1_line_prompt.fish b/fish/functions/_tide_1_line_prompt.fish
deleted file mode 100644
index 5772223..0000000
--- a/fish/functions/_tide_1_line_prompt.fish
+++ /dev/null
@@ -1,19 +0,0 @@
-function _tide_1_line_prompt
- set -g add_prefix
- _tide_side=left for item in $_tide_left_items
- _tide_item_$item
- end
- set_color $prev_bg_color -b normal
- echo $tide_left_prompt_suffix
-
- set -g add_prefix
- _tide_side=right for item in $_tide_right_items
- _tide_item_$item
- end
- set_color $prev_bg_color -b normal
- echo $tide_right_prompt_suffix
-end
-
-function _tide_item_pwd
- _tide_print_item pwd @PWD@
-end
diff --git a/fish/functions/_tide_2_line_prompt.fish b/fish/functions/_tide_2_line_prompt.fish
deleted file mode 100644
index e9017af..0000000
--- a/fish/functions/_tide_2_line_prompt.fish
+++ /dev/null
@@ -1,31 +0,0 @@
-function _tide_2_line_prompt
- set -g add_prefix
- _tide_side=left for item in $_tide_left_items
- _tide_item_$item
- end
- if not set -e add_prefix
- set_color $prev_bg_color -b normal
- echo $tide_left_prompt_suffix
- end
-
- echo
-
- set -g add_prefix
- _tide_side=right for item in $_tide_right_items
- _tide_item_$item
- end
- if not set -e add_prefix
- set_color $prev_bg_color -b normal
- echo $tide_right_prompt_suffix
- end
-end
-
-function _tide_item_pwd
- _tide_print_item pwd @PWD@
-end
-
-function _tide_item_newline
- set_color $prev_bg_color -b normal
- v=tide_"$_tide_side"_prompt_suffix echo $$v
- set -g add_prefix
-end
diff --git a/fish/functions/_tide_cache_variables.fish b/fish/functions/_tide_cache_variables.fish
deleted file mode 100644
index 31e3850..0000000
--- a/fish/functions/_tide_cache_variables.fish
+++ /dev/null
@@ -1,17 +0,0 @@
-function _tide_cache_variables
- # Same-color-separator color
- set_color $tide_prompt_color_separator_same_color | read -gx _tide_color_separator_same_color
-
- # git
- contains git $_tide_left_items $_tide_right_items && set_color $tide_git_color_branch | read -gx _tide_location_color
-
- # private_mode
- if contains private_mode $_tide_left_items $_tide_right_items && test -n "$fish_private_mode"
- set -gx _tide_private_mode
- else
- set -e _tide_private_mode
- end
-
- # item padding
- test "$tide_prompt_pad_items" = true && set -gx _tide_pad ' ' || set -e _tide_pad
-end
diff --git a/fish/functions/_tide_detect_os.fish b/fish/functions/_tide_detect_os.fish
deleted file mode 100644
index 5d96053..0000000
--- a/fish/functions/_tide_detect_os.fish
+++ /dev/null
@@ -1,75 +0,0 @@
-# Outputs icon, color, bg_color
-function _tide_detect_os
- set -lx defaultColor 080808 CED7CF
- switch (uname | string lower)
- case darwin
- printf %s\n D6D6D6 333333 # from apple.com header
- case freebsd openbsd dragonfly
- printf %s\n FFFFFF AB2B28 # https://freebsdfoundation.org/about-us/about-the-foundation/project/
- case 'cygwin*'
- printf %s\n FFFFFF 00CCFF # https://answers.microsoft.com/en-us/windows/forum/all/what-is-the-official-windows-8-blue-rgb-or-hex/fd57144b-f69b-42d8-8c21-6ca911646e44
- case linux
- if test (uname -o) = Android
- echo ﲎ # This character is evil and messes up code display, so it's put on its own line
- # https://developer.android.com/distribute/marketing-tools/brand-guidelines
- printf %s\n 3DDC84 3C3F41 # fg is from above link, bg is from Android Studio default dark theme
- else
- _tide_detect_os_linux_cases /etc/os-release ID ||
- _tide_detect_os_linux_cases /etc/os-release ID_LIKE ||
- _tide_detect_os_linux_cases /etc/lsb-release DISTRIB_ID ||
- printf %s\n $defaultColor
- end
- case '*'
- echo -ns '?'
- end
-end
-
-function _tide_detect_os_linux_cases -a file key
- test -e $file || return
- set -l split_file (string split '=' <$file)
- set -l key_index (contains --index $key $split_file) || return
- set -l value (string trim --chars='"' $split_file[(math $key_index + 1)])
-
- # Anything which would have pure white background has been changed to D4D4D4
- # It was just too bright otherwise
- switch (string lower $value)
- case alpine
- printf %s\n FFFFFF 0D597F # from alpine logo
- case arch
- printf %s\n 1793D1 4D4D4D # from arch wiki header
- case centos
- printf %s\n 000000 D4D4D4 # https://wiki.centos.org/ArtWork/Brand/Logo, monochromatic
- case debian
- printf %s\n C70036 D4D4D4 # from debian logo https://www.debian.org/logos/openlogo-nd-100.png
- case devuan
- printf %s\n $defaultColor # logo is monochromatic
- case elementary
- printf %s\n 000000 D4D4D4 # https://elementary.io/brand, encouraged to be monochromatic
- case fedora
- printf %s\n FFFFFF 294172 # from logo https://fedoraproject.org/w/uploads/2/2d/Logo_fedoralogo.png
- case gentoo
- printf %s\n FFFFFF 54487A # https://wiki.gentoo.org/wiki/Project:Artwork/Colors
- case mageia
- printf %s\n FFFFFF 262F45 # https://wiki.mageia.org/en/Artwork_guidelines
- case manjaro
- printf %s\n FFFFFF 35BF5C # from https://gitlab.manjaro.org/artwork/branding/logo/-/blob/master/logo.svg
- case mint
- printf %s\n FFFFFF 69B53F # extracted from https://linuxmint.com/web/img/favicon.ico
- case nixos
- printf %s\n FFFFFF 5277C3 # https://github.com/NixOS/nixos-artwork/tree/master/logo
- case opensuse-leap opensuse-tumbleweed
- printf %s\n 73BA25 173f4f # https://en.opensuse.org/openSUSE:Artwork_brand
- case raspbian
- printf %s\n FFFFFF A22846 # https://static.raspberrypi.org/files/Raspberry_Pi_Visual_Guidelines_2020.pdf
- case rhel
- printf %s\n EE0000 000000 # https://www.redhat.com/en/about/brand/standards/color
- case sabayon
- printf %s\n $defaultColor # Can't find colors, and they are rebranding anyway
- case slackware
- printf %s\n $defaultColor # Doesn't really have a logo, and the colors are too close to PWD blue anyway
- case ubuntu
- printf %s\n E95420 D4D4D4 # https://design.ubuntu.com/brand/
- case '*'
- return 1
- end
-end
diff --git a/fish/functions/_tide_find_and_remove.fish b/fish/functions/_tide_find_and_remove.fish
deleted file mode 100644
index 29f2180..0000000
--- a/fish/functions/_tide_find_and_remove.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _tide_find_and_remove -a name list --no-scope-shadowing
- contains --index $name $$list | read -l index && set -e "$list"[$index]
-end
diff --git a/fish/functions/_tide_item_aws.fish b/fish/functions/_tide_item_aws.fish
deleted file mode 100644
index 7cb6338..0000000
--- a/fish/functions/_tide_item_aws.fish
+++ /dev/null
@@ -1,11 +0,0 @@
-function _tide_item_aws
- # AWS_PROFILE overrides AWS_DEFAULT_PROFILE, AWS_REGION overrides AWS_DEFAULT_REGION
- set -q AWS_PROFILE && set -l AWS_DEFAULT_PROFILE $AWS_PROFILE
- set -q AWS_REGION && set -l AWS_DEFAULT_REGION $AWS_REGION
-
- if test -n "$AWS_DEFAULT_PROFILE" && test -n "$AWS_DEFAULT_REGION"
- _tide_print_item aws $tide_aws_icon' ' "$AWS_DEFAULT_PROFILE/$AWS_DEFAULT_REGION"
- else if test -n "$AWS_DEFAULT_PROFILE$AWS_DEFAULT_REGION"
- _tide_print_item aws $tide_aws_icon' ' "$AWS_DEFAULT_PROFILE$AWS_DEFAULT_REGION"
- end
-end
diff --git a/fish/functions/_tide_item_character.fish b/fish/functions/_tide_item_character.fish
deleted file mode 100644
index 10bb324..0000000
--- a/fish/functions/_tide_item_character.fish
+++ /dev/null
@@ -1,17 +0,0 @@
-function _tide_item_character
- test $_tide_status = 0 && set_color $tide_character_color || set_color $tide_character_color_failure
-
- set -q add_prefix || echo -ns ' '
-
- test "$fish_key_bindings" = fish_default_key_bindings && echo -ns $tide_character_icon ||
- switch $fish_bind_mode
- case insert
- echo -ns $tide_character_icon
- case default
- echo -ns $tide_character_vi_icon_default
- case replace replace_one
- echo -ns $tide_character_vi_icon_replace
- case visual
- echo -ns $tide_character_vi_icon_visual
- end
-end
diff --git a/fish/functions/_tide_item_chruby.fish b/fish/functions/_tide_item_chruby.fish
deleted file mode 100644
index 02d5fbd..0000000
--- a/fish/functions/_tide_item_chruby.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _tide_item_chruby
- test -n "$RUBY_VERSION" && _tide_print_item chruby $tide_chruby_icon' ' $RUBY_VERSION
-end
diff --git a/fish/functions/_tide_item_cmd_duration.fish b/fish/functions/_tide_item_cmd_duration.fish
deleted file mode 100644
index bc48bac..0000000
--- a/fish/functions/_tide_item_cmd_duration.fish
+++ /dev/null
@@ -1,12 +0,0 @@
-function _tide_item_cmd_duration
- test $CMD_DURATION -gt $tide_cmd_duration_threshold && t=(
- math -s0 "$CMD_DURATION/3600000" # Hours
- math -s0 "$CMD_DURATION/60000"%60 # Minutes
- math -s$tide_cmd_duration_decimals "$CMD_DURATION/1000"%60) if test $t[1] != 0
- _tide_print_item cmd_duration $tide_cmd_duration_icon' ' "$t[1]h $t[2]m $t[3]s"
- else if test $t[2] != 0
- _tide_print_item cmd_duration $tide_cmd_duration_icon' ' "$t[2]m $t[3]s"
- else
- _tide_print_item cmd_duration $tide_cmd_duration_icon' ' "$t[3]s"
- end
-end
diff --git a/fish/functions/_tide_item_context.fish b/fish/functions/_tide_item_context.fish
deleted file mode 100644
index 575c438..0000000
--- a/fish/functions/_tide_item_context.fish
+++ /dev/null
@@ -1,15 +0,0 @@
-function _tide_item_context
- if set -q SSH_TTY
- set -lx tide_context_color $tide_context_color_ssh
- test "$tide_context_hostname_parts" = 0 && _tide_print_item context $USER ||
- h=(string split . $hostname) _tide_print_item context $USER@(string join . $h[..$tide_context_hostname_parts])
- else if test "$EUID" = 0
- set -lx tide_context_color $tide_context_color_root
- test "$tide_context_hostname_parts" = 0 && _tide_print_item context $USER ||
- h=(string split . $hostname) _tide_print_item context $USER@(string join . $h[..$tide_context_hostname_parts])
- else if test "$tide_context_always_display" = true
- set -lx tide_context_color $tide_context_color_default
- test "$tide_context_hostname_parts" = 0 && _tide_print_item context $USER ||
- h=(string split . $hostname) _tide_print_item context $USER@(string join . $h[..$tide_context_hostname_parts])
- end
-end
diff --git a/fish/functions/_tide_item_crystal.fish b/fish/functions/_tide_item_crystal.fish
deleted file mode 100644
index cec9752..0000000
--- a/fish/functions/_tide_item_crystal.fish
+++ /dev/null
@@ -1,4 +0,0 @@
-function _tide_item_crystal
- path is $_tide_parent_dirs/shard.yml &&
- _tide_print_item crystal $tide_crystal_icon' ' (crystal --version | string match -r "[\d.]+")[1]
-end
diff --git a/fish/functions/_tide_item_docker.fish b/fish/functions/_tide_item_docker.fish
deleted file mode 100644
index 4eec0bf..0000000
--- a/fish/functions/_tide_item_docker.fish
+++ /dev/null
@@ -1,5 +0,0 @@
-function _tide_item_docker
- docker context inspect --format '{{.Name}}' | read -l context
- contains -- "$context" $tide_docker_default_contexts ||
- _tide_print_item docker $tide_docker_icon' ' $context
-end
diff --git a/fish/functions/_tide_item_git.fish b/fish/functions/_tide_item_git.fish
deleted file mode 100644
index 43d46cb..0000000
--- a/fish/functions/_tide_item_git.fish
+++ /dev/null
@@ -1,67 +0,0 @@
-function _tide_item_git
- if git branch --show-current 2>/dev/null | string replace -r ".+(.{$tide_git_truncation_length})" '…$1' | read -l location
- git rev-parse --git-dir --is-inside-git-dir | read -fL gdir in_gdir
- set location $_tide_location_color$location
- else if test $pipestatus[1] != 0
- return
- else if git tag --points-at HEAD | string replace -r ".+(.{$tide_git_truncation_length})" '…$1' | read location
- git rev-parse --git-dir --is-inside-git-dir | read -fL gdir in_gdir
- set location '#'$_tide_location_color$location
- else
- git rev-parse --git-dir --is-inside-git-dir --short HEAD | read -fL gdir in_gdir location
- set location @$_tide_location_color$location
- end
-
- # Operation
- if test -d $gdir/rebase-merge
- read -f step <$gdir/rebase-merge/msgnum
- read -f total_steps <$gdir/rebase-merge/end
- test -f $gdir/rebase-merge/interactive && set -f operation rebase-i || set -f operation rebase-m
- else if test -d $gdir/rebase-apply
- read -f step <$gdir/rebase-apply/next
- read -f total_steps <$gdir/rebase-apply/last
- if test -f $gdir/rebase-apply/rebasing
- set -f operation rebase
- else if test -f $gdir/rebase-apply/applying
- set -f operation am
- else
- set -f operation am/rebase
- end
- else if test -f $gdir/MERGE_HEAD
- set -f operation merge
- else if test -f $gdir/CHERRY_PICK_HEAD
- set -f operation cherry-pick
- else if test -f $gdir/REVERT_HEAD
- set -f operation revert
- else if test -f $gdir/BISECT_LOG
- set -f operation bisect
- end
-
- # Git status/stash + Upstream behind/ahead
- test $in_gdir = true && set -l _set_dir_opt -C $gdir/..
- # Suppress errors in case we are in a bare repo or there is no upstream
- stat=(git $_set_dir_opt --no-optional-locks status --porcelain 2>/dev/null) \
- string match -qr '(0|(?.*))\n(0|(?.*))\n(0|(?.*))
-(0|(?.*))\n(0|(?.*))(\n(0|(?.*))\t(0|(?.*)))?' \
- "$(git $_set_dir_opt stash list 2>/dev/null | count
- string match -r ^UU $stat | count
- string match -r ^[ADMR]. $stat | count
- string match -r ^.[ADMR] $stat | count
- string match -r '^\?\?' $stat | count
- git rev-list --count --left-right @{upstream}...HEAD 2>/dev/null)"
-
- if test -n "$operation$conflicted"
- set -g tide_git_bg_color $tide_git_bg_color_urgent
- else if test -n "$staged$dirty$untracked"
- set -g tide_git_bg_color $tide_git_bg_color_unstable
- end
-
- _tide_print_item git $_tide_location_color$tide_git_icon' ' (set_color white; echo -ns $location
- set_color $tide_git_color_operation; echo -ns ' '$operation ' '$step/$total_steps
- set_color $tide_git_color_upstream; echo -ns ' ⇣'$behind ' ⇡'$ahead
- set_color $tide_git_color_stash; echo -ns ' *'$stash
- set_color $tide_git_color_conflicted; echo -ns ' ~'$conflicted
- set_color $tide_git_color_staged; echo -ns ' +'$staged
- set_color $tide_git_color_dirty; echo -ns ' !'$dirty
- set_color $tide_git_color_untracked; echo -ns ' ?'$untracked)
-end
diff --git a/fish/functions/_tide_item_go.fish b/fish/functions/_tide_item_go.fish
deleted file mode 100644
index 7c5919f..0000000
--- a/fish/functions/_tide_item_go.fish
+++ /dev/null
@@ -1,4 +0,0 @@
-function _tide_item_go
- path is $_tide_parent_dirs/go.mod &&
- _tide_print_item go $tide_go_icon' ' (go version | string match -r "[\d.]+")
-end
diff --git a/fish/functions/_tide_item_java.fish b/fish/functions/_tide_item_java.fish
deleted file mode 100644
index 6105acc..0000000
--- a/fish/functions/_tide_item_java.fish
+++ /dev/null
@@ -1,4 +0,0 @@
-function _tide_item_java
- path is $_tide_parent_dirs/pom.xml &&
- _tide_print_item java $tide_java_icon' ' (java -version &| string match -r "[\d.]+")[1]
-end
diff --git a/fish/functions/_tide_item_jobs.fish b/fish/functions/_tide_item_jobs.fish
deleted file mode 100644
index 96cf902..0000000
--- a/fish/functions/_tide_item_jobs.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _tide_item_jobs
- set -q _tide_jobs && _tide_print_item jobs $tide_jobs_icon
-end
diff --git a/fish/functions/_tide_item_kubectl.fish b/fish/functions/_tide_item_kubectl.fish
deleted file mode 100644
index ab044b3..0000000
--- a/fish/functions/_tide_item_kubectl.fish
+++ /dev/null
@@ -1,4 +0,0 @@
-function _tide_item_kubectl
- kubectl config view --minify --output 'jsonpath={.current-context}/{..namespace}' 2>/dev/null | read -l context &&
- _tide_print_item kubectl $tide_kubectl_icon' ' (string replace -r '/(|default)$' '' $context)
-end
diff --git a/fish/functions/_tide_item_nix_shell.fish b/fish/functions/_tide_item_nix_shell.fish
deleted file mode 100644
index 647f606..0000000
--- a/fish/functions/_tide_item_nix_shell.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _tide_item_nix_shell
- set -q IN_NIX_SHELL && _tide_print_item nix_shell $tide_nix_shell_icon' ' $IN_NIX_SHELL
-end
diff --git a/fish/functions/_tide_item_node.fish b/fish/functions/_tide_item_node.fish
deleted file mode 100644
index 0588051..0000000
--- a/fish/functions/_tide_item_node.fish
+++ /dev/null
@@ -1,4 +0,0 @@
-function _tide_item_node
- path is $_tide_parent_dirs/package.json &&
- _tide_print_item node $tide_node_icon' ' (node --version | string trim --chars=v)
-end
diff --git a/fish/functions/_tide_item_os.fish b/fish/functions/_tide_item_os.fish
deleted file mode 100644
index 8a6208c..0000000
--- a/fish/functions/_tide_item_os.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _tide_item_os
- _tide_print_item os $tide_os_icon
-end
diff --git a/fish/functions/_tide_item_php.fish b/fish/functions/_tide_item_php.fish
deleted file mode 100644
index abc104e..0000000
--- a/fish/functions/_tide_item_php.fish
+++ /dev/null
@@ -1,4 +0,0 @@
-function _tide_item_php
- path is $_tide_parent_dirs/composer.json &&
- _tide_print_item php $tide_php_icon' ' (php --version | string match -r 'PHP ([\d.]+)')[2]
-end
diff --git a/fish/functions/_tide_item_private_mode.fish b/fish/functions/_tide_item_private_mode.fish
deleted file mode 100644
index 4eb4684..0000000
--- a/fish/functions/_tide_item_private_mode.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _tide_item_private_mode
- set -q _tide_private_mode && _tide_print_item private_mode $tide_private_mode_icon
-end
diff --git a/fish/functions/_tide_item_rustc.fish b/fish/functions/_tide_item_rustc.fish
deleted file mode 100644
index 2e71645..0000000
--- a/fish/functions/_tide_item_rustc.fish
+++ /dev/null
@@ -1,4 +0,0 @@
-function _tide_item_rustc
- path is $_tide_parent_dirs/Cargo.toml &&
- _tide_print_item rustc $tide_rustc_icon' ' (rustc --version | string split ' ')[2]
-end
diff --git a/fish/functions/_tide_item_shlvl.fish b/fish/functions/_tide_item_shlvl.fish
deleted file mode 100644
index 95dd5ff..0000000
--- a/fish/functions/_tide_item_shlvl.fish
+++ /dev/null
@@ -1,4 +0,0 @@
-function _tide_item_shlvl
- # Non-interactive shells do not increment SHLVL, so we don't need to subtract 1
- test $SHLVL -gt $tide_shlvl_threshold && _tide_print_item shlvl $tide_shlvl_icon' ' $SHLVL
-end
diff --git a/fish/functions/_tide_item_status.fish b/fish/functions/_tide_item_status.fish
deleted file mode 100644
index 3a040fd..0000000
--- a/fish/functions/_tide_item_status.fish
+++ /dev/null
@@ -1,15 +0,0 @@
-function _tide_item_status
- if string match -qv 0 $_tide_pipestatus # If there is a failure anywhere in the pipestatus
- if test "$_tide_pipestatus" = 1 # If simple failure
- contains character $_tide_left_items || tide_status_bg_color=$tide_status_bg_color_failure \
- tide_status_color=$tide_status_color_failure _tide_print_item status $tide_status_icon_failure' ' 1
- else
- fish_status_to_signal $_tide_pipestatus | string replace SIG '' | string join '|' | read -l out
- test $_tide_status = 0 && _tide_print_item status $tide_status_icon' ' $out ||
- tide_status_bg_color=$tide_status_bg_color_failure tide_status_color=$tide_status_color_failure \
- _tide_print_item status $tide_status_icon_failure' ' $out
- end
- else if not contains character $_tide_left_items
- _tide_print_item status $tide_status_icon
- end
-end
diff --git a/fish/functions/_tide_item_terraform.fish b/fish/functions/_tide_item_terraform.fish
deleted file mode 100644
index 8d99fb7..0000000
--- a/fish/functions/_tide_item_terraform.fish
+++ /dev/null
@@ -1,6 +0,0 @@
-function _tide_item_terraform
- if path is $_tide_parent_dirs/.terraform
- terraform workspace show | read -l workspace
- test $workspace != default && _tide_print_item terraform $tide_terraform_icon' ' $workspace
- end
-end
diff --git a/fish/functions/_tide_item_time.fish b/fish/functions/_tide_item_time.fish
deleted file mode 100644
index b8522bc..0000000
--- a/fish/functions/_tide_item_time.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _tide_item_time
- _tide_print_item time (date +$tide_time_format)
-end
diff --git a/fish/functions/_tide_item_toolbox.fish b/fish/functions/_tide_item_toolbox.fish
deleted file mode 100644
index 28975d3..0000000
--- a/fish/functions/_tide_item_toolbox.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _tide_item_toolbox
- test -e /run/.toolboxenv && _tide_print_item toolbox $tide_toolbox_icon' ' $hostname
-end
diff --git a/fish/functions/_tide_item_vi_mode.fish b/fish/functions/_tide_item_vi_mode.fish
deleted file mode 100644
index 582855d..0000000
--- a/fish/functions/_tide_item_vi_mode.fish
+++ /dev/null
@@ -1,16 +0,0 @@
-function _tide_item_vi_mode
- test "$fish_key_bindings" != fish_default_key_bindings && switch $fish_bind_mode
- case default
- tide_vi_mode_bg_color=$tide_vi_mode_bg_color_default tide_vi_mode_color=$tide_vi_mode_color_default \
- _tide_print_item vi_mode $tide_vi_mode_icon_default
- case insert
- tide_vi_mode_bg_color=$tide_vi_mode_bg_color_insert tide_vi_mode_color=$tide_vi_mode_color_insert \
- _tide_print_item vi_mode $tide_vi_mode_icon_insert
- case replace replace_one
- tide_vi_mode_bg_color=$tide_vi_mode_bg_color_replace tide_vi_mode_color=$tide_vi_mode_color_replace \
- _tide_print_item vi_mode $tide_vi_mode_icon_replace
- case visual
- tide_vi_mode_bg_color=$tide_vi_mode_bg_color_visual tide_vi_mode_color=$tide_vi_mode_color_visual \
- _tide_print_item vi_mode $tide_vi_mode_icon_visual
- end
-end
diff --git a/fish/functions/_tide_item_virtual_env.fish b/fish/functions/_tide_item_virtual_env.fish
deleted file mode 100644
index 0f20cee..0000000
--- a/fish/functions/_tide_item_virtual_env.fish
+++ /dev/null
@@ -1,11 +0,0 @@
-function _tide_item_virtual_env
- test -n "$VIRTUAL_ENV" && split_virtual_env=(string split / "$VIRTUAL_ENV") if test $split_virtual_env[-2] = virtualenvs
- # pipenv $VIRTUAL_ENV looks like /home/ilan/.local/share/virtualenvs/pipenv_project-EwRYuc3l
- # Detect whether we are using pipenv by looking for virtualenvs. If so, remove the hash at the end.
- _tide_print_item virtual_env $tide_virtual_env_icon' ' (string split -r -m1 - "$split_virtual_env[-1]")[1]
- else if contains -- $split_virtual_env[-1] virtualenv venv .venv env # avoid generic names
- _tide_print_item virtual_env $tide_virtual_env_icon' ' $split_virtual_env[-2]
- else
- _tide_print_item virtual_env $tide_virtual_env_icon' ' $split_virtual_env[-1]
- end
-end
diff --git a/fish/functions/_tide_parent_dirs.fish b/fish/functions/_tide_parent_dirs.fish
deleted file mode 100644
index 9f31b04..0000000
--- a/fish/functions/_tide_parent_dirs.fish
+++ /dev/null
@@ -1,7 +0,0 @@
-function _tide_parent_dirs --on-variable PWD
- set -g _tide_parent_dirs (string escape (
- for dir in (string split / -- $PWD)
- set -la parts $dir
- string join / -- $parts
- end))
-end
diff --git a/fish/functions/_tide_print_item.fish b/fish/functions/_tide_print_item.fish
deleted file mode 100644
index db5c98b..0000000
--- a/fish/functions/_tide_print_item.fish
+++ /dev/null
@@ -1,22 +0,0 @@
-function _tide_print_item -a item
- v=tide_"$item"_bg_color set -f item_bg_color $$v
-
- if set -e add_prefix
- set_color $item_bg_color -b normal
- v=tide_"$_tide_side"_prompt_prefix echo -ns $$v
- else if test "$item_bg_color" = "$prev_bg_color"
- v=tide_"$_tide_side"_prompt_separator_same_color echo -ns $_tide_color_separator_same_color$$v
- else if test $_tide_side = left
- set_color $prev_bg_color -b $item_bg_color
- echo -ns $tide_left_prompt_separator_diff_color
- else
- set_color $item_bg_color -b $prev_bg_color
- echo -ns $tide_right_prompt_separator_diff_color
- end
-
- v=tide_"$item"_color set_color $$v -b $item_bg_color
-
- echo -ns $_tide_pad $argv[2..] $_tide_pad
-
- set -g prev_bg_color $item_bg_color
-end
diff --git a/fish/functions/_tide_pwd.fish b/fish/functions/_tide_pwd.fish
deleted file mode 100644
index 3bd53b0..0000000
--- a/fish/functions/_tide_pwd.fish
+++ /dev/null
@@ -1,37 +0,0 @@
-set_color -o $tide_pwd_color_anchors | read -l color_anchors
-set_color $tide_pwd_color_truncated_dirs | read -l color_truncated
-set -l reset_to_color_dirs (set_color normal -b $tide_pwd_bg_color; set_color $tide_pwd_color_dirs)
-
-set -l unwritable_icon $tide_pwd_icon_unwritable' '
-set -l home_icon $tide_pwd_icon_home' '
-set -l pwd_icon $tide_pwd_icon' '
-
-eval "function _tide_pwd
- if set -l split_pwd (string replace -r '^$HOME' '~' -- \$PWD | string split /)
- test -w . && set -f split_output \"$pwd_icon\$split_pwd[1]\" \$split_pwd[2..] ||
- set -f split_output \"$unwritable_icon\$split_pwd[1]\" \$split_pwd[2..]
- set split_output[-1] \"$color_anchors\$split_output[-1]$reset_to_color_dirs\"
- else
- set -f split_output \"$home_icon$color_anchors~\"
- end
-
- string join / -- \$split_output | string length -V | read -g _tide_pwd_len
-
- i=1 for dir_section in \$split_pwd[2..-2]
- string join -- / \$split_pwd[..\$i] | string replace '~' $HOME | read -l parent_dir # Uses i before increment
-
- math \$i+1 | read i
-
- if path is \$parent_dir/\$dir_section/\$tide_pwd_markers
- set split_output[\$i] \"$color_anchors\$dir_section$reset_to_color_dirs\"
- else if test \$_tide_pwd_len -gt \$dist_btwn_sides
- set -l trunc
- while string match -qr \"(?\$trunc.)\" \$dir_section && v=\$parent_dir/\$trunc*/ set -q v[2]
- end
- test -n \"\$trunc\" && set split_output[\$i] \"$color_truncated\$trunc$reset_to_color_dirs\" &&
- string join / \$split_output | string length -V | read _tide_pwd_len
- end
- end
-
- string join -- / \"$reset_to_color_dirs\$split_output[1]\" \$split_output[2..]
-end"
diff --git a/fish/functions/_tide_remove_unusable_items.fish b/fish/functions/_tide_remove_unusable_items.fish
deleted file mode 100644
index f1111cb..0000000
--- a/fish/functions/_tide_remove_unusable_items.fish
+++ /dev/null
@@ -1,21 +0,0 @@
-function _tide_remove_unusable_items
- # Remove tool-specific items for tools the machine doesn't have installed
- set -l removed_items
- for item in aws chruby crystal docker git go java kubectl nix_shell node php rustc terraform toolbox virtual_env
- set -l cli_names $item
- switch $item
- case virtual_env
- set cli_names python python3
- case nix_shell
- set cli_names nix nix-shell
- end
- type --query $cli_names || set -a removed_items $item
- end
-
- set -U _tide_left_items (for item in $tide_left_prompt_items
- contains $item $removed_items || echo $item
- end)
- set -U _tide_right_items (for item in $tide_right_prompt_items
- contains $item $removed_items || echo $item
- end)
-end
diff --git a/fish/functions/_tide_sub_bug-report.fish b/fish/functions/_tide_sub_bug-report.fish
deleted file mode 100644
index 5f087c8..0000000
--- a/fish/functions/_tide_sub_bug-report.fish
+++ /dev/null
@@ -1,73 +0,0 @@
-function _tide_sub_bug-report
- argparse c/clean v/verbose check -- $argv
-
- set -l fish_path (status fish-path)
-
- if set -q _flag_clean
- HOME=(mktemp -d) $fish_path --init-command "curl --silent \
- https://raw.githubusercontent.com/jorgebucaran/fisher/main/functions/fisher.fish |
- source && fisher install ilancosman/tide@v5"
- else if set -q _flag_verbose
- set --long | string match -r "^_?tide.*" | # Get only tide variables
- string match -r --invert "^_tide_prompt_var.*" # Remove _tide_prompt_var
- else
- set -l fish_version ($fish_path --version | string match -r "fish, version (\d\.\d\.\d)")[2]
- _tide_check_version Fish fish-shell/fish-shell "(\d\.\d\.\d)" $fish_version || return
-
- set -l tide_version (tide --version | string match -r "tide, version (\d\.\d\.\d)")[2]
- _tide_check_version Tide IlanCosman/tide "v(\d\.\d\.\d)" $tide_version || return
-
- if command --query git
- test (git --version | string match -r "git version ([\d\.]*)" | string replace --all . '')[2] -gt 2220
- _tide_check_condition \
- "Your git version is too old." \
- "Tide requires at least version 2.22." \
- "Please update before submitting a bug report." || return
- end
-
- # Check that omf is not installed
- not functions --query omf
- _tide_check_condition \
- "Tide does not work with oh-my-fish installed." \
- "Please uninstall it before submitting a bug report." || return
-
- if not set -q _flag_check
- set -l fish_startup_time ($fish_path -ic "time $fish_path -c exit" 2>|
- string match -r "Executed in(.*)fish" | string trim)[2]
-
- read --local --prompt-str "What operating system are you using? (e.g Ubuntu 20.04): " os
- read --local --prompt-str "What terminal emulator are you using? (e.g Kitty): " terminal_emulator
-
- printf '%b\n' "\nPlease copy the following information into the issue:\n" \
- "fish version: $fish_version" \
- "tide version: $tide_version" \
- "term: $TERM" \
- "os: $os" \
- "terminal emulator: $terminal_emulator" \
- "fish startup: $fish_startup_time" \
- "fisher plugins: $_fisher_plugins"
- end
- end
-end
-
-function _tide_check_version -a program_name repo_name regex_to_get_version current_version
- curl --silent https://github.com/$repo_name/releases/latest |
- string match -r ".*$repo_name/releases/tag/$regex_to_get_version.*" |
- read --local --line __ latestVersion
-
- string match --quiet -r "^$latestVersion" "$current_version"
- _tide_check_condition \
- "Your $program_name version is out of date." \
- "The latest is $latestVersion. You have $current_version." \
- "Please update before submitting a bug report."
-end
-
-function _tide_check_condition
- if test "$status" != 0
- set_color red
- printf '%s\n' $argv
- set_color normal
- return 1
- end
- return 0
-end
diff --git a/fish/functions/_tide_sub_configure.fish b/fish/functions/_tide_sub_configure.fish
deleted file mode 100644
index cb87290..0000000
--- a/fish/functions/_tide_sub_configure.fish
+++ /dev/null
@@ -1,95 +0,0 @@
-set -g _tide_color_dark_blue 0087AF
-set -g _tide_color_dark_green 5FAF00
-set -g _tide_color_gold D7AF00
-set -g _tide_color_green 5FD700
-set -g _tide_color_light_blue 00AFFF
-
-# Create an empty fake function for each item
-for func in _fake(functions --all | string match --entire _tide_item)
- function $func
- end
-end
-
-for file in (status dirname)/tide/configure/{choices, functions}/**.fish
- source $file
-end
-
-function _tide_sub_configure
- if test $COLUMNS -lt 55 -o $LINES -lt 21
- echo 'Terminal size too small; must be at least 55 x 21'
- return 1
- end
-
- _tide_detect_os | read -g --line os_branding_icon os_branding_color os_branding_bg_color
-
- set -g fake_columns $COLUMNS
- test $fake_columns -gt 90 && set fake_columns 90
- set -g fake_lines $LINES
-
- set -g _tide_selected_option
- _next_choice all/style
-end
-
-function _next_choice -a nextChoice
- set -q _tide_selected_option || return 0
- set -l cmd (string split '/' $nextChoice)[2]
- $cmd
-end
-
-function _tide_title -a text
- command -q clear && clear
- set_color -o
- string pad --width (math --scale=0 "$fake_columns/2" + (string length $text)/2) $text
- set_color normal
-end
-
-function _tide_option -a symbol text
- set -ga _tide_option_list $symbol
-
- set_color -o
- echo "($symbol) $text"
- set_color normal
-end
-
-function _tide_menu
- set -l list_with_slashes (string join '/' $_tide_option_list)
-
- echo '(r) Restart from the beginning'
- echo '(q) Quit and do nothing'\n
-
- while true
- set_color -o
- read --nchars 1 --prompt-str "Choice [$list_with_slashes/r/q] " input
- set_color normal
-
- switch $input
- case r
- set -e _tide_option_list
- _next_choice all/style
- break
- case q
- set -e _tide_selected_option # Skip through all the _next_choices
- set -e _tide_option_list
- command -q clear && clear
- break
- case $_tide_option_list
- set -e _tide_option_list
- set -g _tide_selected_option $input
- break
- end
- end
-end
-
-function _tide_display_prompt -a var_name var_value
- test -n "$var_name" && set -g $var_name $var_value
- _fake_tide_cache_variables
- set -l prompt (_fake_tide_prompt)
-
- set -l bottom_left_prompt_string_length (string length --visible $prompt[-1])
- set -l right_prompt_string (string pad --width (math $fake_columns-$bottom_left_prompt_string_length) $prompt[1])
- set -l prompt[-1] "$prompt[-1]$right_prompt_string"
-
- string unescape $prompt[2..]
- set_color normal
- echo
-end
diff --git a/fish/functions/fish_mode_prompt.fish b/fish/functions/fish_mode_prompt.fish
deleted file mode 100644
index f37cf7d..0000000
--- a/fish/functions/fish_mode_prompt.fish
+++ /dev/null
@@ -1 +0,0 @@
-# Disable default vi prompt
diff --git a/fish/functions/fish_prompt.fish b/fish/functions/fish_prompt.fish
deleted file mode 100644
index 3e820c4..0000000
--- a/fish/functions/fish_prompt.fish
+++ /dev/null
@@ -1,90 +0,0 @@
-function fish_prompt
-end # In case this file gets loaded non-interactively, e.g by conda
-status is-interactive || exit
-
-_tide_remove_unusable_items
-_tide_cache_variables
-_tide_parent_dirs
-source (functions --details _tide_pwd)
-
-set -l prompt_var _tide_prompt_$fish_pid
-set -U $prompt_var # Set var here so if we erase $prompt_var, bg job won't set a uvar
-
-set_color normal | read -l color_normal
-status fish-path | read -l fish_path
-
-# _tide_repaint prevents us from creating a second background job
-function _tide_refresh_prompt --on-variable $prompt_var --on-variable COLUMNS
- set -g _tide_repaint
- commandline -f repaint
-end
-
-if contains newline $_tide_left_items # two line prompt initialization
- test "$tide_prompt_add_newline_before" = true && set -l add_newline '\n'
-
- set_color $tide_prompt_color_frame_and_connection -b normal | read -l prompt_and_frame_color
-
- set -l column_offset 5
- test "$tide_left_prompt_frame_enabled" = true &&
- set -l top_left_frame "$prompt_and_frame_color╭─" &&
- set -l bot_left_frame "$prompt_and_frame_color╰─" &&
- set column_offset (math $column_offset-2)
- test "$tide_right_prompt_frame_enabled" = true &&
- set -l top_right_frame "$prompt_and_frame_color─╮" &&
- set -l bot_right_frame "$prompt_and_frame_color─╯" &&
- set column_offset (math $column_offset-2)
-
- eval "
-function fish_prompt
- _tide_status=\$status _tide_pipestatus=\$pipestatus if not set -e _tide_repaint
- jobs -q && set -lx _tide_jobs
- $fish_path -c \"set _tide_pipestatus \$_tide_pipestatus
-set _tide_parent_dirs \$_tide_parent_dirs
-PATH=\$(string escape \"\$PATH\") CMD_DURATION=\$CMD_DURATION fish_bind_mode=\$fish_bind_mode set $prompt_var (_tide_2_line_prompt)\" &
- builtin disown
-
- command kill \$_tide_last_pid 2>/dev/null
- set -g _tide_last_pid \$last_pid
- end
-
- math \$COLUMNS-(string length -V \"\$$prompt_var[1][1]\$$prompt_var[1][3]\")+$column_offset | read -lx dist_btwn_sides
-
- echo -ns $add_newline'$top_left_frame'(string replace @PWD@ (_tide_pwd) \"\$$prompt_var[1][1]\")'$prompt_and_frame_color'
- string repeat -Nm(math max 0, \$dist_btwn_sides-\$_tide_pwd_len) '$tide_prompt_icon_connection'
- echo -ns \"\$$prompt_var[1][3]$top_right_frame\"\n\"$bot_left_frame\$$prompt_var[1][2]$color_normal \"
-end
-
-function fish_right_prompt
- string unescape \"\$$prompt_var[1][4]$bot_right_frame$color_normal\"
-end"
-else # one line prompt initialization
- test "$tide_prompt_add_newline_before" = true && set -l add_newline '\0'
-
- math 5 -$tide_prompt_min_cols | read -l column_offset
- test $column_offset -ge 0 && set column_offset "+$column_offset"
-
- eval "
-function fish_prompt
- _tide_status=\$status _tide_pipestatus=\$pipestatus if not set -e _tide_repaint
- jobs -q && set -lx _tide_jobs
- $fish_path -c \"set _tide_pipestatus \$_tide_pipestatus
-set _tide_parent_dirs \$_tide_parent_dirs
-PATH=\$(string escape \"\$PATH\") CMD_DURATION=\$CMD_DURATION fish_bind_mode=\$fish_bind_mode set $prompt_var (_tide_1_line_prompt)\" &
- builtin disown
-
- command kill \$_tide_last_pid 2>/dev/null
- set -g _tide_last_pid \$last_pid
- end
-
- math \$COLUMNS-(string length -V \"\$$prompt_var[1][1]\$$prompt_var[1][2]\")$column_offset | read -lx dist_btwn_sides
- string replace @PWD@ (_tide_pwd) $add_newline \$$prompt_var[1][1]'$color_normal '
-end
-
-function fish_right_prompt
- string unescape \"\$$prompt_var[1][2]$color_normal\"
-end"
-end
-
-eval "function _tide_on_fish_exit --on-event fish_exit
- set -e $prompt_var
-end"
diff --git a/fish/functions/nheko.fish b/fish/functions/nheko.fish
deleted file mode 100644
index 78672b0..0000000
--- a/fish/functions/nheko.fish
+++ /dev/null
@@ -1,4 +0,0 @@
-function nheko --description 'alias nheko nheko --style Breeze'
- command nheko --style Breeze $argv
-
-end
diff --git a/fish/functions/tide.fish b/fish/functions/tide.fish
deleted file mode 100644
index 1a58f40..0000000
--- a/fish/functions/tide.fish
+++ /dev/null
@@ -1,27 +0,0 @@
-function tide --description 'Manage your Tide prompt'
- argparse --stop-nonopt v/version h/help -- $argv
-
- if set -q _flag_version
- echo 'tide, version 5.5.1'
- else if set -q _flag_help
- _tide_help
- else if functions --query _tide_sub_$argv[1]
- _tide_sub_$argv[1] $argv[2..]
- else
- _tide_help
- return 1
- end
-end
-
-function _tide_help
- printf %s\n \
- 'Usage: tide [options] subcommand [options]' \
- '' \
- 'Options:' \
- ' -v or --version print tide version number' \
- ' -h or --help print this help message' \
- '' \
- 'Subcommands:' \
- ' configure run interactive configuration wizard' \
- ' bug-report print info for use in bug reports'
-end
diff --git a/fish/functions/tide/configure/choices/all/finish.fish b/fish/functions/tide/configure/choices/all/finish.fish
deleted file mode 100644
index f60a128..0000000
--- a/fish/functions/tide/configure/choices/all/finish.fish
+++ /dev/null
@@ -1,33 +0,0 @@
-function finish
- set_color red
- _tide_title 'Overwrite tide config?'
- set_color normal
-
- _tide_option y Yes
- echo
-
- _tide_menu
- switch $_tide_selected_option
- case y
- _tide_finish
- command -q clear && clear
- end
-end
-
-function _tide_finish
- set -e _tide_selected_option # Skip through all the _next_choices
-
- # Deal with prompt char/vi mode
- contains character $fake_tide_left_prompt_items || set -p fake_tide_left_prompt_items vi_mode
-
- # Set the real variables
- for fakeVar in (set --names | string match -r "^fake_tide.*")
- set -U (string replace 'fake_' '' $fakeVar) $$fakeVar
- end
-
- # Make sure old prompt won't display
- set -e $_tide_prompt_var 2>/dev/null
-
- # Re-initialize the prompt
- source (functions --details fish_prompt)
-end
diff --git a/fish/functions/tide/configure/choices/all/icons.fish b/fish/functions/tide/configure/choices/all/icons.fish
deleted file mode 100644
index e53bffa..0000000
--- a/fish/functions/tide/configure/choices/all/icons.fish
+++ /dev/null
@@ -1,33 +0,0 @@
-function icons
- _tide_title Icons
-
- _tide_option 1 'Few icons'
- _tide_display_prompt
-
- _tide_option 2 'Many icons'
- _enable_icons
- _tide_display_prompt
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- _disable_icons
- end
- _next_choice all/finish
-end
-
-function _enable_icons
- set -p fake_tide_left_prompt_items os
- set -g fake_tide_pwd_icon
- set -g fake_tide_pwd_icon_home
- set -g fake_tide_cmd_duration_icon
- set -g fake_tide_git_icon
-end
-
-function _disable_icons
- _tide_find_and_remove os fake_tide_left_prompt_items
- set fake_tide_pwd_icon
- set fake_tide_pwd_icon_home
- set fake_tide_cmd_duration_icon
- set fake_tide_git_icon
-end
diff --git a/fish/functions/tide/configure/choices/all/prompt_colors.fish b/fish/functions/tide/configure/choices/all/prompt_colors.fish
deleted file mode 100644
index 90b1a9d..0000000
--- a/fish/functions/tide/configure/choices/all/prompt_colors.fish
+++ /dev/null
@@ -1,26 +0,0 @@
-function prompt_colors
- _tide_title 'Prompt Colors'
-
- _tide_option 1 'True color'
- _tide_display_prompt
-
- _tide_option 2 '16 colors'
- _load_config "$_tide_configure_style"_16color
- set -g _tide_16color true
- _tide_display_prompt
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- _load_config "$_tide_configure_style"
- set -e _tide_16color
- switch $_tide_configure_style
- case lean rainbow
- _next_choice all/show_time
- case classic
- _next_choice classic/classic_prompt_color
- end
- case 2
- _next_choice all/show_time
- end
-end
diff --git a/fish/functions/tide/configure/choices/all/prompt_connection.fish b/fish/functions/tide/configure/choices/all/prompt_connection.fish
deleted file mode 100644
index ae31ef3..0000000
--- a/fish/functions/tide/configure/choices/all/prompt_connection.fish
+++ /dev/null
@@ -1,28 +0,0 @@
-function prompt_connection
- _tide_title 'Prompt Connection'
-
- _tide_option 1 Disconnected
- _tide_display_prompt fake_tide_prompt_icon_connection ' '
-
- _tide_option 2 Dotted
- _tide_display_prompt fake_tide_prompt_icon_connection '·'
-
- _tide_option 3 Solid
- _tide_display_prompt fake_tide_prompt_icon_connection '─'
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- set -g fake_tide_prompt_icon_connection ' '
- case 2
- set -g fake_tide_prompt_icon_connection '·'
- case 3
- set -g fake_tide_prompt_icon_connection '─'
- end
- switch $_tide_configure_style
- case lean
- _next_choice all/prompt_connection_andor_frame_color
- case classic rainbow
- _next_choice powerline/powerline_prompt_frame
- end
-end
diff --git a/fish/functions/tide/configure/choices/all/prompt_connection_andor_frame_color.fish b/fish/functions/tide/configure/choices/all/prompt_connection_andor_frame_color.fish
deleted file mode 100644
index b8803b4..0000000
--- a/fish/functions/tide/configure/choices/all/prompt_connection_andor_frame_color.fish
+++ /dev/null
@@ -1,36 +0,0 @@
-function prompt_connection_andor_frame_color
- if test "$_tide_16color" = true ||
- test "$fake_tide_left_prompt_frame_enabled" = false -a \
- "$fake_tide_right_prompt_frame_enabled" = false -a \
- "$fake_tide_prompt_icon_connection" = ' '
- _next_choice all/prompt_spacing
- return 0
- end
-
- _tide_title "Connection & Frame Color"
-
- _tide_option 1 Lightest
- _tide_display_prompt fake_tide_prompt_color_frame_and_connection 808080
-
- _tide_option 2 Light
- _tide_display_prompt fake_tide_prompt_color_frame_and_connection 6C6C6C
-
- _tide_option 3 Dark
- _tide_display_prompt fake_tide_prompt_color_frame_and_connection 585858
-
- _tide_option 4 Darkest
- _tide_display_prompt fake_tide_prompt_color_frame_and_connection 444444
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- set -g fake_tide_prompt_color_frame_and_connection 808080
- case 2
- set -g fake_tide_prompt_color_frame_and_connection 6C6C6C
- case 3
- set -g fake_tide_prompt_color_frame_and_connection 585858
- case 4
- set -g fake_tide_prompt_color_frame_and_connection 444444
- end
- _next_choice all/prompt_spacing
-end
diff --git a/fish/functions/tide/configure/choices/all/prompt_spacing.fish b/fish/functions/tide/configure/choices/all/prompt_spacing.fish
deleted file mode 100644
index a5bb98b..0000000
--- a/fish/functions/tide/configure/choices/all/prompt_spacing.fish
+++ /dev/null
@@ -1,21 +0,0 @@
-function prompt_spacing
- _tide_title 'Prompt Spacing'
-
- _tide_option 1 Compact
- _tide_display_prompt
- printf \e\[1A # Move cursor up 1 row
- _tide_display_prompt
-
- _tide_option 2 Sparse
- _tide_display_prompt
- _tide_display_prompt
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- set -g fake_tide_prompt_add_newline_before false
- case 2
- set -g fake_tide_prompt_add_newline_before true
- end
- _next_choice all/icons
-end
diff --git a/fish/functions/tide/configure/choices/all/show_time.fish b/fish/functions/tide/configure/choices/all/show_time.fish
deleted file mode 100644
index 8cf1843..0000000
--- a/fish/functions/tide/configure/choices/all/show_time.fish
+++ /dev/null
@@ -1,31 +0,0 @@
-function show_time
- _tide_title 'Show current time?'
-
- _tide_option 1 No
- _tide_display_prompt
-
- set -a fake_tide_right_prompt_items time
-
- _tide_option 2 '24-hour format'
- _tide_display_prompt fake_tide_time_format %T
-
- _tide_option 3 '12-hour format'
- _tide_display_prompt fake_tide_time_format '%r'
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- set -g fake_tide_time_format ''
- set -e fake_tide_right_prompt_items[-1]
- case 2
- set -g fake_tide_time_format %T
- case 3
- set -g fake_tide_time_format '%r'
- end
- switch $_tide_configure_style
- case lean
- _next_choice "$_tide_configure_style"/"$_tide_configure_style"_prompt_height
- case classic rainbow
- _next_choice "$_tide_configure_style"/"$_tide_configure_style"_prompt_separators
- end
-end
diff --git a/fish/functions/tide/configure/choices/all/style.fish b/fish/functions/tide/configure/choices/all/style.fish
deleted file mode 100644
index ae52bc5..0000000
--- a/fish/functions/tide/configure/choices/all/style.fish
+++ /dev/null
@@ -1,57 +0,0 @@
-function style
- _tide_title 'Prompt Style'
-
- _tide_option 1 Lean
- _load_config lean
- _tide_display_prompt
-
- _tide_option 2 Classic
- _load_config classic
- _tide_display_prompt
-
- _tide_option 3 Rainbow
- _load_config rainbow
- _tide_display_prompt
-
- _tide_style_menu
- switch $_tide_selected_option
- case 1
- _load_config lean
- set -g _tide_configure_style lean
- case 2
- _load_config classic
- set -g _tide_configure_style classic
- case 3
- _load_config rainbow
- set -g _tide_configure_style rainbow
- end
- _next_choice all/prompt_colors
-end
-
-function _load_config -a name
- string replace -r '^' 'set -g fake_' <(status dirname)/../../configs/$name.fish | source
-end
-
-function _tide_style_menu # Exactly like _tide_menu except that it doesn't have (r) option
- set -l list_with_slashes (string join '/' $_tide_option_list)
-
- echo '(q) Quit and do nothing'\n
-
- while true
- set_color -o
- read --nchars 1 --prompt-str "Choice [$list_with_slashes/q] " input
- set_color normal
-
- switch $input
- case q
- set -e _tide_selected_option # Skip through all the _next_choices
- set -e _tide_option_list
- command -q clear && clear
- break
- case $_tide_option_list
- set -e _tide_option_list
- set -g _tide_selected_option $input
- break
- end
- end
-end
diff --git a/fish/functions/tide/configure/choices/classic/classic_prompt_color.fish b/fish/functions/tide/configure/choices/classic/classic_prompt_color.fish
deleted file mode 100644
index 2189f36..0000000
--- a/fish/functions/tide/configure/choices/classic/classic_prompt_color.fish
+++ /dev/null
@@ -1,38 +0,0 @@
-function classic_prompt_color
- _tide_title 'Prompt Color'
-
- _tide_option 1 Lightest
- _set_all_items_bg_color 585858
- _tide_display_prompt
-
- _tide_option 2 Light
- _set_all_items_bg_color 444444
- _tide_display_prompt
-
- _tide_option 3 Dark
- _set_all_items_bg_color 303030
- _tide_display_prompt
-
- _tide_option 4 Darkest
- _set_all_items_bg_color 1C1C1C
- _tide_display_prompt
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- _set_all_items_bg_color 585858
- case 2
- _set_all_items_bg_color 444444
- case 3
- _set_all_items_bg_color 303030
- case 4
- _set_all_items_bg_color 1C1C1C
- end
- _next_choice all/show_time
-end
-
-function _set_all_items_bg_color -a color
- for var in (set --names | string match -r "fake_.*_bg_color.*")
- set $var $color
- end
-end
diff --git a/fish/functions/tide/configure/choices/classic/classic_prompt_separators.fish b/fish/functions/tide/configure/choices/classic/classic_prompt_separators.fish
deleted file mode 100644
index 17b88e4..0000000
--- a/fish/functions/tide/configure/choices/classic/classic_prompt_separators.fish
+++ /dev/null
@@ -1,40 +0,0 @@
-function classic_prompt_separators
- _tide_title 'Prompt Separators'
-
- _tide_option 1 Angled
- set -g fake_tide_left_prompt_separator_same_color
- set -g fake_tide_right_prompt_separator_same_color
- _tide_display_prompt
-
- _tide_option 2 Vertical
- set -g fake_tide_left_prompt_separator_same_color '│'
- set -g fake_tide_right_prompt_separator_same_color '│'
- _tide_display_prompt
-
- _tide_option 3 Slanted
- set -g fake_tide_left_prompt_separator_same_color '╱'
- set -g fake_tide_right_prompt_separator_same_color '╱'
- _tide_display_prompt
-
- _tide_option 4 Round
- set -g fake_tide_left_prompt_separator_same_color ''
- set -g fake_tide_right_prompt_separator_same_color ''
- _tide_display_prompt
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- set -g fake_tide_left_prompt_separator_same_color
- set -g fake_tide_right_prompt_separator_same_color
- case 2
- set -g fake_tide_left_prompt_separator_same_color '│'
- set -g fake_tide_right_prompt_separator_same_color '│'
- case 3
- set -g fake_tide_left_prompt_separator_same_color '╱'
- set -g fake_tide_right_prompt_separator_same_color '╱'
- case 4
- set -g fake_tide_left_prompt_separator_same_color ''
- set -g fake_tide_right_prompt_separator_same_color ''
- end
- _next_choice powerline/powerline_prompt_heads
-end
diff --git a/fish/functions/tide/configure/choices/lean/lean_prompt_height.fish b/fish/functions/tide/configure/choices/lean/lean_prompt_height.fish
deleted file mode 100644
index 4db04a8..0000000
--- a/fish/functions/tide/configure/choices/lean/lean_prompt_height.fish
+++ /dev/null
@@ -1,26 +0,0 @@
-function lean_prompt_height
- _tide_title 'Prompt Height'
-
- _tide_option 1 'One line'
- _tide_find_and_remove newline fake_tide_left_prompt_items
- set -g fake_tide_left_prompt_suffix ''
- _tide_display_prompt
-
- _tide_option 2 'Two lines'
- set -g fake_tide_left_prompt_items $fake_tide_left_prompt_items[1..-2] newline $fake_tide_left_prompt_items[-1]
- set -g fake_tide_left_prompt_suffix ' '
- _tide_display_prompt
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- _tide_find_and_remove newline fake_tide_left_prompt_items
- set fake_tide_left_prompt_suffix ''
- _next_choice all/prompt_connection_andor_frame_color
- case 2
- _tide_find_and_remove newline fake_tide_left_prompt_items
- set -g fake_tide_left_prompt_items $fake_tide_left_prompt_items[1..-2] newline $fake_tide_left_prompt_items[-1]
- set -g fake_tide_left_prompt_suffix ' '
- _next_choice all/prompt_connection
- end
-end
diff --git a/fish/functions/tide/configure/choices/powerline/powerline_prompt_frame.fish b/fish/functions/tide/configure/choices/powerline/powerline_prompt_frame.fish
deleted file mode 100644
index 19b3588..0000000
--- a/fish/functions/tide/configure/choices/powerline/powerline_prompt_frame.fish
+++ /dev/null
@@ -1,46 +0,0 @@
-function powerline_prompt_frame
- _tide_title 'Prompt Frame'
-
- _tide_option 1 'No frame'
- set fake_tide_left_prompt_frame_enabled false
- set fake_tide_right_prompt_frame_enabled false
- set -a fake_tide_left_prompt_items character
- _tide_display_prompt
- set -e fake_tide_left_prompt_items[-1]
-
- _tide_option 2 Left
- set fake_tide_left_prompt_frame_enabled true
- set fake_tide_right_prompt_frame_enabled false
- _tide_display_prompt
-
- _tide_option 3 Right
- set fake_tide_left_prompt_frame_enabled false
- set fake_tide_right_prompt_frame_enabled true
- set -a fake_tide_left_prompt_items character
- _tide_display_prompt
- set -e fake_tide_left_prompt_items[-1]
-
- _tide_option 4 Full
- set fake_tide_left_prompt_frame_enabled true
- set fake_tide_right_prompt_frame_enabled true
- _tide_display_prompt
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- set fake_tide_left_prompt_frame_enabled false
- set fake_tide_right_prompt_frame_enabled false
- set -a fake_tide_left_prompt_items character
- case 2
- set fake_tide_left_prompt_frame_enabled true
- set fake_tide_right_prompt_frame_enabled false
- case 3
- set fake_tide_left_prompt_frame_enabled false
- set fake_tide_right_prompt_frame_enabled true
- set -a fake_tide_left_prompt_items character
- case 4
- set fake_tide_left_prompt_frame_enabled true
- set fake_tide_right_prompt_frame_enabled true
- end
- _next_choice all/prompt_connection_andor_frame_color
-end
diff --git a/fish/functions/tide/configure/choices/powerline/powerline_prompt_heads.fish b/fish/functions/tide/configure/choices/powerline/powerline_prompt_heads.fish
deleted file mode 100644
index ac187c9..0000000
--- a/fish/functions/tide/configure/choices/powerline/powerline_prompt_heads.fish
+++ /dev/null
@@ -1,40 +0,0 @@
-function powerline_prompt_heads
- _tide_title 'Prompt Heads'
-
- _tide_option 1 Sharp
- set -g fake_tide_left_prompt_suffix
- set -g fake_tide_right_prompt_prefix
- _tide_display_prompt
-
- _tide_option 2 Blurred
- set -g fake_tide_left_prompt_suffix '▓▒░'
- set -g fake_tide_right_prompt_prefix '░▒▓'
- _tide_display_prompt
-
- _tide_option 3 Slanted
- set -g fake_tide_left_prompt_suffix ''
- set -g fake_tide_right_prompt_prefix ''
- _tide_display_prompt
-
- _tide_option 4 Round
- set -g fake_tide_left_prompt_suffix ''
- set -g fake_tide_right_prompt_prefix ''
- _tide_display_prompt
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- set -g fake_tide_left_prompt_suffix
- set -g fake_tide_right_prompt_prefix
- case 2
- set -g fake_tide_left_prompt_suffix '▓▒░'
- set -g fake_tide_right_prompt_prefix '░▒▓'
- case 3
- set -g fake_tide_left_prompt_suffix ''
- set -g fake_tide_right_prompt_prefix ''
- case 4
- set -g fake_tide_left_prompt_suffix ''
- set -g fake_tide_right_prompt_prefix ''
- end
- _next_choice powerline/powerline_prompt_tails
-end
diff --git a/fish/functions/tide/configure/choices/powerline/powerline_prompt_height.fish b/fish/functions/tide/configure/choices/powerline/powerline_prompt_height.fish
deleted file mode 100644
index 83fef05..0000000
--- a/fish/functions/tide/configure/choices/powerline/powerline_prompt_height.fish
+++ /dev/null
@@ -1,30 +0,0 @@
-function powerline_prompt_height
- _tide_title 'Prompt Height'
-
- _tide_option 1 'One line'
- _tide_find_and_remove newline fake_tide_left_prompt_items
- set fake_tide_left_prompt_frame_enabled false
- set fake_tide_right_prompt_frame_enabled false
- _tide_display_prompt
-
- _tide_option 2 'Two lines'
- set -g fake_tide_left_prompt_items $fake_tide_left_prompt_items newline
- set fake_tide_left_prompt_frame_enabled true
- set fake_tide_right_prompt_frame_enabled true
- _tide_display_prompt
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- _tide_find_and_remove newline fake_tide_left_prompt_items
- set fake_tide_left_prompt_frame_enabled false
- set fake_tide_right_prompt_frame_enabled false
- _next_choice all/prompt_connection_andor_frame_color
- case 2
- _tide_find_and_remove newline fake_tide_left_prompt_items
- set -g fake_tide_left_prompt_items $fake_tide_left_prompt_items newline
- set fake_tide_left_prompt_frame_enabled true
- set fake_tide_right_prompt_frame_enabled true
- _next_choice all/prompt_connection
- end
-end
diff --git a/fish/functions/tide/configure/choices/powerline/powerline_prompt_tails.fish b/fish/functions/tide/configure/choices/powerline/powerline_prompt_tails.fish
deleted file mode 100644
index 02f4609..0000000
--- a/fish/functions/tide/configure/choices/powerline/powerline_prompt_tails.fish
+++ /dev/null
@@ -1,48 +0,0 @@
-function powerline_prompt_tails
- _tide_title 'Prompt Tails'
-
- _tide_option 1 Flat
- set -g fake_tide_left_prompt_prefix ''
- set -g fake_tide_right_prompt_suffix ''
- _tide_display_prompt
-
- _tide_option 2 Blurred
- set -g fake_tide_left_prompt_prefix '░▒▓'
- set -g fake_tide_right_prompt_suffix '▓▒░'
- _tide_display_prompt
-
- _tide_option 3 Sharp
- set -g fake_tide_left_prompt_prefix
- set -g fake_tide_right_prompt_suffix
- _tide_display_prompt
-
- _tide_option 4 Slanted
- set -g fake_tide_left_prompt_prefix ''
- set -g fake_tide_right_prompt_suffix ''
- _tide_display_prompt
-
- _tide_option 5 Round
- set -g fake_tide_left_prompt_prefix ''
- set -g fake_tide_right_prompt_suffix ''
- _tide_display_prompt
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- set -g fake_tide_left_prompt_prefix ''
- set -g fake_tide_right_prompt_suffix ''
- case 2
- set -g fake_tide_left_prompt_prefix '░▒▓'
- set -g fake_tide_right_prompt_suffix '▓▒░'
- case 3
- set -g fake_tide_left_prompt_prefix
- set -g fake_tide_right_prompt_suffix
- case 4
- set -g fake_tide_left_prompt_prefix ''
- set -g fake_tide_right_prompt_suffix ''
- case 5
- set -g fake_tide_left_prompt_prefix ''
- set -g fake_tide_right_prompt_suffix ''
- end
- _next_choice powerline/powerline_prompt_height
-end
diff --git a/fish/functions/tide/configure/choices/rainbow/rainbow_prompt_separators.fish b/fish/functions/tide/configure/choices/rainbow/rainbow_prompt_separators.fish
deleted file mode 100644
index 29f6ccc..0000000
--- a/fish/functions/tide/configure/choices/rainbow/rainbow_prompt_separators.fish
+++ /dev/null
@@ -1,40 +0,0 @@
-function rainbow_prompt_separators
- _tide_title 'Prompt Separators'
-
- _tide_option 1 Angled
- set -g fake_tide_left_prompt_separator_diff_color
- set -g fake_tide_right_prompt_separator_diff_color
- _tide_display_prompt
-
- _tide_option 2 Vertical
- set -g fake_tide_left_prompt_separator_diff_color ''
- set -g fake_tide_right_prompt_separator_diff_color ''
- _tide_display_prompt
-
- _tide_option 3 Slanted
- set -g fake_tide_left_prompt_separator_diff_color ''
- set -g fake_tide_right_prompt_separator_diff_color ''
- _tide_display_prompt
-
- _tide_option 4 Round
- set -g fake_tide_left_prompt_separator_diff_color ''
- set -g fake_tide_right_prompt_separator_diff_color ''
- _tide_display_prompt
-
- _tide_menu
- switch $_tide_selected_option
- case 1
- set -g fake_tide_left_prompt_separator_diff_color
- set -g fake_tide_right_prompt_separator_diff_color
- case 2
- set -g fake_tide_left_prompt_separator_diff_color ''
- set -g fake_tide_right_prompt_separator_diff_color ''
- case 3
- set -g fake_tide_left_prompt_separator_diff_color ''
- set -g fake_tide_right_prompt_separator_diff_color ''
- case 4
- set -g fake_tide_left_prompt_separator_diff_color ''
- set -g fake_tide_right_prompt_separator_diff_color ''
- end
- _next_choice powerline/powerline_prompt_heads
-end
diff --git a/fish/functions/tide/configure/configs/classic.fish b/fish/functions/tide/configure/configs/classic.fish
deleted file mode 100644
index 9b23f37..0000000
--- a/fish/functions/tide/configure/configs/classic.fish
+++ /dev/null
@@ -1,133 +0,0 @@
-tide_aws_bg_color 444444
-tide_aws_color FF9900
-tide_aws_icon
-tide_character_color $_tide_color_green
-tide_character_color_failure FF0000
-tide_character_icon ❯
-tide_character_vi_icon_default ❮
-tide_character_vi_icon_replace ▶
-tide_character_vi_icon_visual V
-tide_chruby_bg_color 444444
-tide_chruby_color B31209
-tide_chruby_icon
-tide_cmd_duration_bg_color 444444
-tide_cmd_duration_color 87875F
-tide_cmd_duration_decimals 0
-tide_cmd_duration_icon
-tide_cmd_duration_threshold 3000
-tide_context_always_display false
-tide_context_bg_color 444444
-tide_context_color_default D7AF87
-tide_context_color_root $_tide_color_gold
-tide_context_color_ssh D7AF87
-tide_context_hostname_parts 1
-tide_crystal_bg_color 444444
-tide_crystal_color FFFFFF
-tide_crystal_icon ⬢
-tide_docker_bg_color 444444
-tide_docker_color 2496ED
-tide_docker_default_contexts default colima
-tide_docker_icon
-tide_git_bg_color 444444
-tide_git_bg_color_unstable 444444
-tide_git_bg_color_urgent 444444
-tide_git_color_branch $_tide_color_green
-tide_git_color_conflicted FF0000
-tide_git_color_dirty $_tide_color_gold
-tide_git_color_operation FF0000
-tide_git_color_staged $_tide_color_gold
-tide_git_color_stash $_tide_color_green
-tide_git_color_untracked $_tide_color_light_blue
-tide_git_color_upstream $_tide_color_green
-tide_git_icon
-tide_git_truncation_length 24
-tide_go_bg_color 444444
-tide_go_color 00ACD7
-tide_go_icon
-tide_java_bg_color 444444
-tide_java_color ED8B00
-tide_java_icon
-tide_jobs_bg_color 444444
-tide_jobs_color $_tide_color_dark_green
-tide_jobs_icon
-tide_kubectl_bg_color 444444
-tide_kubectl_color 326CE5
-tide_kubectl_icon ⎈
-tide_left_prompt_frame_enabled true
-tide_left_prompt_items pwd git newline
-tide_left_prompt_prefix ''
-tide_left_prompt_separator_diff_color
-tide_left_prompt_separator_same_color
-tide_left_prompt_suffix
-tide_nix_shell_bg_color 444444
-tide_nix_shell_color 7EBAE4
-tide_nix_shell_icon
-tide_node_bg_color 444444
-tide_node_color 44883E
-tide_node_icon ⬢
-tide_os_bg_color 444444
-tide_os_color EEEEEE
-tide_os_icon $os_branding_icon
-tide_php_bg_color 444444
-tide_php_color 617CBE
-tide_php_icon
-tide_private_mode_bg_color 444444
-tide_private_mode_color FFFFFF
-tide_private_mode_icon
-tide_prompt_add_newline_before true
-tide_prompt_color_frame_and_connection 6C6C6C
-tide_prompt_color_separator_same_color 949494
-tide_prompt_icon_connection ' '
-tide_prompt_min_cols 34
-tide_prompt_pad_items true
-tide_pwd_bg_color 444444
-tide_pwd_color_anchors $_tide_color_light_blue
-tide_pwd_color_dirs $_tide_color_dark_blue
-tide_pwd_color_truncated_dirs 8787AF
-tide_pwd_icon
-tide_pwd_icon_home
-tide_pwd_icon_unwritable
-tide_pwd_markers .bzr .citc .git .hg .node-version .python-version .ruby-version .shorten_folder_marker .svn .terraform Cargo.toml composer.json CVS go.mod package.json
-tide_right_prompt_frame_enabled true
-tide_right_prompt_items status cmd_duration context jobs node virtual_env rustc java php chruby go kubectl toolbox terraform aws nix_shell crystal
-tide_right_prompt_prefix
-tide_right_prompt_separator_diff_color
-tide_right_prompt_separator_same_color
-tide_right_prompt_suffix ''
-tide_rustc_bg_color 444444
-tide_rustc_color F74C00
-tide_rustc_icon
-tide_shlvl_bg_color 444444
-tide_shlvl_color d78700
-tide_shlvl_icon
-tide_shlvl_threshold 1
-tide_status_bg_color 444444
-tide_status_bg_color_failure 444444
-tide_status_color $_tide_color_dark_green
-tide_status_color_failure D70000
-tide_status_icon ✔
-tide_status_icon_failure ✘
-tide_terraform_bg_color 444444
-tide_terraform_color 844FBA
-tide_terraform_icon
-tide_time_bg_color 444444
-tide_time_color 5F8787
-tide_time_format %T
-tide_toolbox_bg_color 444444
-tide_toolbox_color 613583
-tide_toolbox_icon ⬢
-tide_vi_mode_bg_color_default 444444
-tide_vi_mode_bg_color_insert 444444
-tide_vi_mode_bg_color_replace 444444
-tide_vi_mode_bg_color_visual 444444
-tide_vi_mode_color_default 949494
-tide_vi_mode_color_insert 87AFAF
-tide_vi_mode_color_replace 87AF87
-tide_vi_mode_color_visual FF8700
-tide_vi_mode_icon_default D
-tide_vi_mode_icon_insert I
-tide_vi_mode_icon_replace R
-tide_vi_mode_icon_visual V
-tide_virtual_env_bg_color 444444
-tide_virtual_env_color 00AFAF
-tide_virtual_env_icon
diff --git a/fish/functions/tide/configure/configs/classic_16color.fish b/fish/functions/tide/configure/configs/classic_16color.fish
deleted file mode 100644
index acdc411..0000000
--- a/fish/functions/tide/configure/configs/classic_16color.fish
+++ /dev/null
@@ -1,75 +0,0 @@
-tide_aws_bg_color black
-tide_aws_color yellow
-tide_character_color brgreen
-tide_character_color_failure brred
-tide_chruby_bg_color black
-tide_chruby_color red
-tide_cmd_duration_bg_color black
-tide_cmd_duration_color brblack
-tide_context_bg_color black
-tide_context_color_default yellow
-tide_context_color_root bryellow
-tide_context_color_ssh yellow
-tide_crystal_bg_color black
-tide_crystal_color brwhite
-tide_docker_bg_color black
-tide_docker_color blue
-tide_git_bg_color black
-tide_git_bg_color_unstable black
-tide_git_bg_color_urgent black
-tide_git_color_branch brgreen
-tide_git_color_conflicted brred
-tide_git_color_dirty bryellow
-tide_git_color_operation brred
-tide_git_color_staged bryellow
-tide_git_color_stash brgreen
-tide_git_color_untracked brblue
-tide_git_color_upstream brgreen
-tide_go_bg_color black
-tide_go_color brcyan
-tide_java_bg_color black
-tide_java_color yellow
-tide_jobs_bg_color black
-tide_jobs_color green
-tide_kubectl_bg_color black
-tide_kubectl_color blue
-tide_nix_shell_bg_color black
-tide_nix_shell_color brblue
-tide_node_bg_color black
-tide_node_color green
-tide_os_bg_color black
-tide_os_color brwhite
-tide_php_bg_color black
-tide_php_color blue
-tide_private_mode_bg_color black
-tide_private_mode_color brwhite
-tide_prompt_color_frame_and_connection brblack
-tide_prompt_color_separator_same_color brblack
-tide_pwd_bg_color black
-tide_pwd_color_anchors brcyan
-tide_pwd_color_dirs cyan
-tide_pwd_color_truncated_dirs magenta
-tide_rustc_bg_color black
-tide_rustc_color red
-tide_shlvl_bg_color black
-tide_shlvl_color yellow
-tide_status_bg_color black
-tide_status_bg_color_failure black
-tide_status_color green
-tide_status_color_failure red
-tide_terraform_bg_color black
-tide_terraform_color magenta
-tide_time_bg_color black
-tide_time_color brblack
-tide_toolbox_bg_color black
-tide_toolbox_color magenta
-tide_vi_mode_bg_color_default black
-tide_vi_mode_bg_color_insert black
-tide_vi_mode_bg_color_replace black
-tide_vi_mode_bg_color_visual black
-tide_vi_mode_color_default white
-tide_vi_mode_color_insert cyan
-tide_vi_mode_color_replace green
-tide_vi_mode_color_visual yellow
-tide_virtual_env_bg_color black
-tide_virtual_env_color cyan
diff --git a/fish/functions/tide/configure/configs/lean.fish b/fish/functions/tide/configure/configs/lean.fish
deleted file mode 100644
index 2565e0a..0000000
--- a/fish/functions/tide/configure/configs/lean.fish
+++ /dev/null
@@ -1,133 +0,0 @@
-tide_aws_bg_color normal
-tide_aws_color FF9900
-tide_aws_icon
-tide_character_color $_tide_color_green
-tide_character_color_failure FF0000
-tide_character_icon ❯
-tide_character_vi_icon_default ❮
-tide_character_vi_icon_replace ▶
-tide_character_vi_icon_visual V
-tide_chruby_bg_color normal
-tide_chruby_color B31209
-tide_chruby_icon
-tide_cmd_duration_bg_color normal
-tide_cmd_duration_color 87875F
-tide_cmd_duration_decimals 0
-tide_cmd_duration_icon
-tide_cmd_duration_threshold 3000
-tide_context_always_display false
-tide_context_bg_color normal
-tide_context_color_default D7AF87
-tide_context_color_root $_tide_color_gold
-tide_context_color_ssh D7AF87
-tide_context_hostname_parts 1
-tide_crystal_bg_color normal
-tide_crystal_color FFFFFF
-tide_crystal_icon ⬢
-tide_docker_bg_color normal
-tide_docker_color 2496ED
-tide_docker_default_contexts default colima
-tide_docker_icon
-tide_git_bg_color normal
-tide_git_bg_color_unstable normal
-tide_git_bg_color_urgent normal
-tide_git_color_branch $_tide_color_green
-tide_git_color_conflicted FF0000
-tide_git_color_dirty $_tide_color_gold
-tide_git_color_operation FF0000
-tide_git_color_staged $_tide_color_gold
-tide_git_color_stash $_tide_color_green
-tide_git_color_untracked $_tide_color_light_blue
-tide_git_color_upstream $_tide_color_green
-tide_git_icon
-tide_git_truncation_length 24
-tide_go_bg_color normal
-tide_go_color 00ACD7
-tide_go_icon
-tide_java_bg_color normal
-tide_java_color ED8B00
-tide_java_icon
-tide_jobs_bg_color normal
-tide_jobs_color $_tide_color_dark_green
-tide_jobs_icon
-tide_kubectl_bg_color normal
-tide_kubectl_color 326CE5
-tide_kubectl_icon ⎈
-tide_left_prompt_frame_enabled false
-tide_left_prompt_items pwd git newline character
-tide_left_prompt_prefix ''
-tide_left_prompt_separator_diff_color ' '
-tide_left_prompt_separator_same_color ' '
-tide_left_prompt_suffix ' '
-tide_nix_shell_bg_color normal
-tide_nix_shell_color 7EBAE4
-tide_nix_shell_icon
-tide_node_bg_color normal
-tide_node_color 44883E
-tide_node_icon ⬢
-tide_os_bg_color normal
-tide_os_color normal
-tide_os_icon $os_branding_icon
-tide_php_bg_color normal
-tide_php_color 617CBE
-tide_php_icon
-tide_private_mode_bg_color normal
-tide_private_mode_color FFFFFF
-tide_private_mode_icon
-tide_prompt_add_newline_before true
-tide_prompt_color_frame_and_connection 6C6C6C
-tide_prompt_color_separator_same_color 949494
-tide_prompt_icon_connection ' '
-tide_prompt_min_cols 34
-tide_prompt_pad_items false
-tide_pwd_bg_color normal
-tide_pwd_color_anchors $_tide_color_light_blue
-tide_pwd_color_dirs $_tide_color_dark_blue
-tide_pwd_color_truncated_dirs 8787AF
-tide_pwd_icon
-tide_pwd_icon_home
-tide_pwd_icon_unwritable
-tide_pwd_markers .bzr .citc .git .hg .node-version .python-version .ruby-version .shorten_folder_marker .svn .terraform Cargo.toml composer.json CVS go.mod package.json
-tide_right_prompt_frame_enabled false
-tide_right_prompt_items status cmd_duration context jobs node virtual_env rustc java php chruby go kubectl toolbox terraform aws nix_shell crystal
-tide_right_prompt_prefix ' '
-tide_right_prompt_separator_diff_color ' '
-tide_right_prompt_separator_same_color ' '
-tide_right_prompt_suffix ''
-tide_rustc_bg_color normal
-tide_rustc_color F74C00
-tide_rustc_icon
-tide_shlvl_bg_color normal
-tide_shlvl_color d78700
-tide_shlvl_icon
-tide_shlvl_threshold 1
-tide_status_bg_color normal
-tide_status_bg_color_failure normal
-tide_status_color $_tide_color_dark_green
-tide_status_color_failure D70000
-tide_status_icon ✔
-tide_status_icon_failure ✘
-tide_terraform_bg_color normal
-tide_terraform_color 844FBA
-tide_terraform_icon
-tide_time_bg_color normal
-tide_time_color 5F8787
-tide_time_format %T
-tide_toolbox_bg_color normal
-tide_toolbox_color 613583
-tide_toolbox_icon ⬢
-tide_vi_mode_bg_color_default normal
-tide_vi_mode_bg_color_insert normal
-tide_vi_mode_bg_color_replace normal
-tide_vi_mode_bg_color_visual normal
-tide_vi_mode_color_default 949494
-tide_vi_mode_color_insert 87AFAF
-tide_vi_mode_color_replace 87AF87
-tide_vi_mode_color_visual FF8700
-tide_vi_mode_icon_default D
-tide_vi_mode_icon_insert I
-tide_vi_mode_icon_replace R
-tide_vi_mode_icon_visual V
-tide_virtual_env_bg_color normal
-tide_virtual_env_color 00AFAF
-tide_virtual_env_icon
diff --git a/fish/functions/tide/configure/configs/lean_16color.fish b/fish/functions/tide/configure/configs/lean_16color.fish
deleted file mode 100644
index 49a8606..0000000
--- a/fish/functions/tide/configure/configs/lean_16color.fish
+++ /dev/null
@@ -1,75 +0,0 @@
-tide_aws_bg_color normal
-tide_aws_color yellow
-tide_character_color brgreen
-tide_character_color_failure brred
-tide_chruby_bg_color normal
-tide_chruby_color red
-tide_cmd_duration_bg_color normal
-tide_cmd_duration_color brblack
-tide_context_bg_color normal
-tide_context_color_default yellow
-tide_context_color_root bryellow
-tide_context_color_ssh yellow
-tide_crystal_bg_color normal
-tide_crystal_color brwhite
-tide_docker_bg_color normal
-tide_docker_color blue
-tide_git_bg_color normal
-tide_git_bg_color_unstable normal
-tide_git_bg_color_urgent normal
-tide_git_color_branch brgreen
-tide_git_color_conflicted brred
-tide_git_color_dirty bryellow
-tide_git_color_operation brred
-tide_git_color_staged bryellow
-tide_git_color_stash brgreen
-tide_git_color_untracked brblue
-tide_git_color_upstream brgreen
-tide_go_bg_color normal
-tide_go_color brcyan
-tide_java_bg_color normal
-tide_java_color yellow
-tide_jobs_bg_color normal
-tide_jobs_color green
-tide_kubectl_bg_color normal
-tide_kubectl_color blue
-tide_nix_shell_bg_color normal
-tide_nix_shell_color brblue
-tide_node_bg_color normal
-tide_node_color green
-tide_os_bg_color normal
-tide_os_color brwhite
-tide_php_bg_color normal
-tide_php_color blue
-tide_private_mode_bg_color normal
-tide_private_mode_color brwhite
-tide_prompt_color_frame_and_connection brblack
-tide_prompt_color_separator_same_color brblack
-tide_pwd_bg_color normal
-tide_pwd_color_anchors brcyan
-tide_pwd_color_dirs cyan
-tide_pwd_color_truncated_dirs magenta
-tide_rustc_bg_color normal
-tide_rustc_color red
-tide_shlvl_bg_color normal
-tide_shlvl_color yellow
-tide_status_bg_color normal
-tide_status_bg_color_failure normal
-tide_status_color green
-tide_status_color_failure red
-tide_terraform_bg_color normal
-tide_terraform_color magenta
-tide_time_bg_color normal
-tide_time_color brblack
-tide_toolbox_bg_color normal
-tide_toolbox_color magenta
-tide_vi_mode_bg_color_default normal
-tide_vi_mode_bg_color_insert normal
-tide_vi_mode_bg_color_replace normal
-tide_vi_mode_bg_color_visual normal
-tide_vi_mode_color_default white
-tide_vi_mode_color_insert cyan
-tide_vi_mode_color_replace green
-tide_vi_mode_color_visual yellow
-tide_virtual_env_bg_color normal
-tide_virtual_env_color cyan
diff --git a/fish/functions/tide/configure/configs/rainbow.fish b/fish/functions/tide/configure/configs/rainbow.fish
deleted file mode 100644
index 39ce7bb..0000000
--- a/fish/functions/tide/configure/configs/rainbow.fish
+++ /dev/null
@@ -1,133 +0,0 @@
-tide_aws_bg_color FF9900
-tide_aws_color 232F3E
-tide_aws_icon
-tide_character_color $_tide_color_green
-tide_character_color_failure FF0000
-tide_character_icon ❯
-tide_character_vi_icon_default ❮
-tide_character_vi_icon_replace ▶
-tide_character_vi_icon_visual V
-tide_chruby_bg_color B31209
-tide_chruby_color 000000
-tide_chruby_icon
-tide_cmd_duration_bg_color C4A000
-tide_cmd_duration_color 000000
-tide_cmd_duration_decimals 0
-tide_cmd_duration_icon
-tide_cmd_duration_threshold 3000
-tide_context_always_display false
-tide_context_bg_color 444444
-tide_context_color_default D7AF87
-tide_context_color_root $_tide_color_gold
-tide_context_color_ssh D7AF87
-tide_context_hostname_parts 1
-tide_crystal_bg_color FFFFFF
-tide_crystal_color 000000
-tide_crystal_icon ⬢
-tide_docker_bg_color 2496ED
-tide_docker_color 000000
-tide_docker_default_contexts default colima
-tide_docker_icon
-tide_git_bg_color 4E9A06
-tide_git_bg_color_unstable C4A000
-tide_git_bg_color_urgent CC0000
-tide_git_color_branch 000000
-tide_git_color_conflicted 000000
-tide_git_color_dirty 000000
-tide_git_color_operation 000000
-tide_git_color_staged 000000
-tide_git_color_stash 000000
-tide_git_color_untracked 000000
-tide_git_color_upstream 000000
-tide_git_icon
-tide_git_truncation_length 24
-tide_go_bg_color 00ACD7
-tide_go_color 000000
-tide_go_icon
-tide_java_bg_color ED8B00
-tide_java_color 000000
-tide_java_icon
-tide_jobs_bg_color 444444
-tide_jobs_color 4E9A06
-tide_jobs_icon
-tide_kubectl_bg_color 326CE5
-tide_kubectl_color 000000
-tide_kubectl_icon ⎈
-tide_left_prompt_frame_enabled true
-tide_left_prompt_items pwd git newline
-tide_left_prompt_prefix ''
-tide_left_prompt_separator_diff_color
-tide_left_prompt_separator_same_color
-tide_left_prompt_suffix
-tide_nix_shell_bg_color 7EBAE4
-tide_nix_shell_color 000000
-tide_nix_shell_icon
-tide_node_bg_color 44883E
-tide_node_color 000000
-tide_node_icon ⬢
-tide_os_bg_color $os_branding_bg_color
-tide_os_color $os_branding_color
-tide_os_icon $os_branding_icon
-tide_php_bg_color 617CBE
-tide_php_color 000000
-tide_php_icon
-tide_private_mode_bg_color F1F3F4
-tide_private_mode_color 000000
-tide_private_mode_icon
-tide_prompt_add_newline_before true
-tide_prompt_color_frame_and_connection 6C6C6C
-tide_prompt_color_separator_same_color 949494
-tide_prompt_icon_connection ' '
-tide_prompt_min_cols 34
-tide_prompt_pad_items true
-tide_pwd_bg_color 3465A4
-tide_pwd_color_anchors E4E4E4
-tide_pwd_color_dirs E4E4E4
-tide_pwd_color_truncated_dirs BCBCBC
-tide_pwd_icon
-tide_pwd_icon_home
-tide_pwd_icon_unwritable
-tide_pwd_markers .bzr .citc .git .hg .node-version .python-version .ruby-version .shorten_folder_marker .svn .terraform Cargo.toml composer.json CVS go.mod package.json
-tide_right_prompt_frame_enabled true
-tide_right_prompt_items status cmd_duration context jobs node virtual_env rustc java php chruby go kubectl toolbox terraform aws nix_shell crystal
-tide_right_prompt_prefix
-tide_right_prompt_separator_diff_color
-tide_right_prompt_separator_same_color
-tide_right_prompt_suffix ''
-tide_rustc_bg_color F74C00
-tide_rustc_color 000000
-tide_rustc_icon
-tide_shlvl_bg_color 808000
-tide_shlvl_color 000000
-tide_shlvl_icon
-tide_shlvl_threshold 1
-tide_status_bg_color 2E3436
-tide_status_bg_color_failure CC0000
-tide_status_color 4E9A06
-tide_status_color_failure FFFF00
-tide_status_icon ✔
-tide_status_icon_failure ✘
-tide_terraform_bg_color 800080
-tide_terraform_color 000000
-tide_terraform_icon
-tide_time_bg_color D3D7CF
-tide_time_color 000000
-tide_time_format %T
-tide_toolbox_bg_color 613583
-tide_toolbox_color 000000
-tide_toolbox_icon ⬢
-tide_vi_mode_bg_color_default 949494
-tide_vi_mode_bg_color_insert 87AFAF
-tide_vi_mode_bg_color_replace 87AF87
-tide_vi_mode_bg_color_visual FF8700
-tide_vi_mode_color_default 000000
-tide_vi_mode_color_insert 000000
-tide_vi_mode_color_replace 000000
-tide_vi_mode_color_visual 000000
-tide_vi_mode_icon_default D
-tide_vi_mode_icon_insert I
-tide_vi_mode_icon_replace R
-tide_vi_mode_icon_visual V
-tide_virtual_env_bg_color 444444
-tide_virtual_env_color 00AFAF
-tide_virtual_env_icon
diff --git a/fish/functions/tide/configure/configs/rainbow_16color.fish b/fish/functions/tide/configure/configs/rainbow_16color.fish
deleted file mode 100644
index c102e2f..0000000
--- a/fish/functions/tide/configure/configs/rainbow_16color.fish
+++ /dev/null
@@ -1,79 +0,0 @@
-tide_aws_bg_color yellow
-tide_aws_color brblack
-tide_character_color brgreen
-tide_character_color_failure brred
-tide_chruby_bg_color red
-tide_chruby_color black
-tide_cmd_duration_bg_color yellow
-tide_cmd_duration_color black
-tide_context_bg_color brblack
-tide_context_color_default yellow
-tide_context_color_root yellow
-tide_context_color_ssh yellow
-tide_crystal_bg_color brwhite
-tide_crystal_color black
-tide_docker_bg_color blue
-tide_docker_color black
-tide_git_bg_color green
-tide_git_bg_color_unstable yellow
-tide_git_bg_color_urgent red
-tide_git_color_branch black
-tide_git_color_conflicted black
-tide_git_color_dirty black
-tide_git_color_operation black
-tide_git_color_staged black
-tide_git_color_stash black
-tide_git_color_untracked black
-tide_git_color_upstream black
-tide_go_bg_color brcyan
-tide_go_color black
-tide_java_bg_color yellow
-tide_java_color black
-tide_jobs_bg_color brblack
-tide_jobs_color green
-tide_kubectl_bg_color blue
-tide_kubectl_color black
-tide_nix_shell_bg_color brblue
-tide_nix_shell_color black
-tide_node_bg_color green
-tide_node_color black
-tide_os_bg_color white
-tide_os_color black
-tide_php_bg_color blue
-tide_php_color black
-tide_private_mode_bg_color brwhite
-tide_private_mode_color black
-tide_prompt_color_frame_and_connection brblack
-tide_prompt_color_separator_same_color brblack
-tide_pwd_bg_color blue
-tide_pwd_color_anchors brwhite
-tide_pwd_color_dirs brwhite
-tide_pwd_color_truncated_dirs white
-tide_rustc_bg_color red
-tide_rustc_color black
-tide_shlvl_bg_color yellow
-tide_shlvl_color black
-tide_status_bg_color black
-tide_status_bg_color_failure red
-tide_status_color green
-tide_status_color_failure bryellow
-tide_terraform_bg_color magenta
-tide_terraform_color black
-tide_time_bg_color white
-tide_time_color black
-tide_toolbox_bg_color magenta
-tide_toolbox_color black
-tide_vi_mode_bg_color_default white
-tide_vi_mode_bg_color_insert cyan
-tide_vi_mode_bg_color_replace green
-tide_vi_mode_bg_color_visual yellow
-tide_vi_mode_color_default black
-tide_vi_mode_color_insert black
-tide_vi_mode_color_replace black
-tide_vi_mode_color_visual black
-tide_vi_mode_icon_default D
-tide_vi_mode_icon_insert I
-tide_vi_mode_icon_replace R
-tide_vi_mode_icon_visual V
-tide_virtual_env_bg_color brblack
-tide_virtual_env_color cyan
diff --git a/fish/functions/tide/configure/functions/_fake_tide_cache_variables.fish b/fish/functions/tide/configure/functions/_fake_tide_cache_variables.fish
deleted file mode 100644
index 4661ab1..0000000
--- a/fish/functions/tide/configure/functions/_fake_tide_cache_variables.fish
+++ /dev/null
@@ -1,41 +0,0 @@
-function _fake_tide_cache_variables
- # pwd
- set_color -o $fake_tide_pwd_color_anchors | read -gx _fake_tide_color_anchors
- set -gx _fake_tide_color_truncated_dirs "$(set_color $fake_tide_pwd_color_truncated_dirs)"
- set -gx _fake_tide_reset_to_color_dirs (set_color normal -b $fake_tide_pwd_bg_color; set_color $fake_tide_pwd_color_dirs)
-
- # git
- contains git $fake_tide_left_prompt_items $fake_tide_right_prompt_items &&
- set -gx _fake_tide_location_color "$(set_color $fake_tide_git_color_branch)"
-
- # private_mode
- if contains private_mode $fake_tide_left_prompt_items $fake_tide_right_prompt_items && test -n "$fish_private_mode"
- set -gx _fake_tide_private_mode
- else
- set -e _fake_tide_private_mode
- end
-
- # Same-color-separator color
- set -gx _fake_tide_color_separator_same_color "$(set_color $fake_tide_prompt_color_separator_same_color)"
-
- # two line prompt
- if contains newline $fake_tide_left_prompt_items
- set_color $fake_tide_prompt_color_frame_and_connection -b normal | read -gx _fake_tide_prompt_and_frame_color
- else
- set -e _fake_tide_prompt_and_frame_color
- end
-
- # newline before
- if test "$fake_tide_prompt_add_newline_before" = true
- set -g _fake_tide_add_newline ''
- else
- set -e _fake_tide_add_newline
- end
-
- # item padding
- if test "$fake_tide_prompt_pad_items" = true
- set -gx _fake_tide_pad ' '
- else
- set -e _fake_tide_pad
- end
-end
diff --git a/fish/functions/tide/configure/functions/_fake_tide_item_character.fish b/fish/functions/tide/configure/functions/_fake_tide_item_character.fish
deleted file mode 100644
index 73ae055..0000000
--- a/fish/functions/tide/configure/functions/_fake_tide_item_character.fish
+++ /dev/null
@@ -1,5 +0,0 @@
-function _fake_tide_item_character
- set_color $fake_tide_character_color
- contains newline $fake_tide_left_prompt_items || echo -ns ' '
- echo -ns $fake_tide_character_icon
-end
diff --git a/fish/functions/tide/configure/functions/_fake_tide_item_cmd_duration.fish b/fish/functions/tide/configure/functions/_fake_tide_item_cmd_duration.fish
deleted file mode 100644
index 5aa13b2..0000000
--- a/fish/functions/tide/configure/functions/_fake_tide_item_cmd_duration.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _fake_tide_item_cmd_duration
- _fake_tide_print_item cmd_duration $fake_tide_cmd_duration_icon' ' 5s
-end
diff --git a/fish/functions/tide/configure/functions/_fake_tide_item_git.fish b/fish/functions/tide/configure/functions/_fake_tide_item_git.fish
deleted file mode 100644
index fb5b957..0000000
--- a/fish/functions/tide/configure/functions/_fake_tide_item_git.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _fake_tide_item_git
- _fake_tide_print_item git (set_color $fake_tide_git_color_branch) $fake_tide_git_icon' ' main
-end
diff --git a/fish/functions/tide/configure/functions/_fake_tide_item_newline.fish b/fish/functions/tide/configure/functions/_fake_tide_item_newline.fish
deleted file mode 100644
index c614bab..0000000
--- a/fish/functions/tide/configure/functions/_fake_tide_item_newline.fish
+++ /dev/null
@@ -1,5 +0,0 @@
-function _fake_tide_item_newline
- set_color $prev_bg_color -b normal
- var=fake_tide_"$_fake_tide_side"_prompt_suffix echo $$var
- set -g add_prefix
-end
diff --git a/fish/functions/tide/configure/functions/_fake_tide_item_os.fish b/fish/functions/tide/configure/functions/_fake_tide_item_os.fish
deleted file mode 100644
index 5255721..0000000
--- a/fish/functions/tide/configure/functions/_fake_tide_item_os.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _fake_tide_item_os
- _fake_tide_print_item os $fake_tide_os_icon
-end
diff --git a/fish/functions/tide/configure/functions/_fake_tide_item_time.fish b/fish/functions/tide/configure/functions/_fake_tide_item_time.fish
deleted file mode 100644
index bbce0b5..0000000
--- a/fish/functions/tide/configure/functions/_fake_tide_item_time.fish
+++ /dev/null
@@ -1,3 +0,0 @@
-function _fake_tide_item_time
- _fake_tide_print_item time (date +$fake_tide_time_format)
-end
diff --git a/fish/functions/tide/configure/functions/_fake_tide_print_item.fish b/fish/functions/tide/configure/functions/_fake_tide_print_item.fish
deleted file mode 100644
index 30cd024..0000000
--- a/fish/functions/tide/configure/functions/_fake_tide_print_item.fish
+++ /dev/null
@@ -1,22 +0,0 @@
-function _fake_tide_print_item -a item
- var=fake_tide_"$item"_bg_color set -f item_bg_color $$var
-
- if set -e add_prefix
- set_color $item_bg_color -b normal
- var=fake_tide_"$_fake_tide_side"_prompt_prefix echo -ns $$var
- else if test "$item_bg_color" = "$prev_bg_color"
- var=fake_tide_"$_fake_tide_side"_prompt_separator_same_color echo -ns $_fake_tide_color_separator_same_color$$var
- else if test "$_fake_tide_side" = left
- set_color $prev_bg_color -b $item_bg_color
- echo -ns $fake_tide_left_prompt_separator_diff_color
- else
- set_color $item_bg_color -b $prev_bg_color
- echo -ns $fake_tide_right_prompt_separator_diff_color
- end
-
- var=fake_tide_"$item"_color set_color $$var -b $item_bg_color
-
- echo -ns $_fake_tide_pad $argv[2..] $_fake_tide_pad
-
- set -g prev_bg_color $item_bg_color
-end
diff --git a/fish/functions/tide/configure/functions/_fake_tide_prompt.fish b/fish/functions/tide/configure/functions/_fake_tide_prompt.fish
deleted file mode 100644
index 11f20ca..0000000
--- a/fish/functions/tide/configure/functions/_fake_tide_prompt.fish
+++ /dev/null
@@ -1,42 +0,0 @@
-function _fake_tide_prompt
- set -g add_prefix
- _fake_tide_side=left set -f left (for item in $fake_tide_left_prompt_items
- _fake_tide_item_$item
- end
- if not set -e add_prefix
- set_color $prev_bg_color -b normal
- echo -ns $fake_tide_left_prompt_suffix
- end)
-
- set -g add_prefix
- _fake_tide_side=right set -f right (for item in $fake_tide_right_prompt_items
- _fake_tide_item_$item
- end
- if not set -e add_prefix
- set_color $prev_bg_color -b normal
- echo -ns $fake_tide_right_prompt_suffix
- end)
-
- if set -q _fake_tide_prompt_and_frame_color # If prompt is two lines
- test "$fake_tide_left_prompt_frame_enabled" = true &&
- set left[1] "$_fake_tide_prompt_and_frame_color╭─$left[1]" &&
- set left[2] "$_fake_tide_prompt_and_frame_color╰─$left[2]"
- test "$fake_tide_right_prompt_frame_enabled" = true &&
- set right[1] "$right[1]$_fake_tide_prompt_and_frame_color─╮" &&
- set right[2] "$right[2]$_fake_tide_prompt_and_frame_color─╯"
-
- # 5 = @PWD@ length which will be replaced
- math $fake_columns+5-(string length --visible "$left[1]$right[1]") | read -lx dist_btwn_sides
- echo -ns "$right[2]"\n(string replace @PWD@ (_fake_tide_pwd) "$left[1]")$_fake_tide_prompt_and_frame_color
-
- string repeat --no-newline --max (math max 0, $dist_btwn_sides-$_tide_pwd_len) $fake_tide_prompt_icon_connection
- echo -ns "$right[1]"\n"$left[2] "
- else
- math $fake_columns+5-(string length --visible "$left[1]$right[1]") -$fake_tide_prompt_min_cols | read -lx dist_btwn_sides
- string replace @PWD@ (_fake_tide_pwd) "$right[1]" "$left[1] "
- end
-end
-
-function _fake_tide_item_pwd
- _fake_tide_print_item pwd @PWD@
-end
diff --git a/fish/functions/tide/configure/functions/_fake_tide_pwd.fish b/fish/functions/tide/configure/functions/_fake_tide_pwd.fish
deleted file mode 100644
index 433eafa..0000000
--- a/fish/functions/tide/configure/functions/_fake_tide_pwd.fish
+++ /dev/null
@@ -1,11 +0,0 @@
-function _fake_tide_pwd
- set -l out (
- set_color $fake_tide_pwd_color_dirs
- echo -ns $fake_tide_pwd_icon' ' '~/'
- set_color -o $fake_tide_pwd_color_anchors
- echo -ns src
- set_color normal -b $fake_tide_pwd_bg_color
- )
- set -g _tide_pwd_len (string length --visible $out)
- echo -ns $out
-end
diff --git a/fish/themes/tokyonight_night.theme b/fish/themes/tokyonight_night.theme
deleted file mode 100644
index 2c33869..0000000
--- a/fish/themes/tokyonight_night.theme
+++ /dev/null
@@ -1,25 +0,0 @@
-
- # TokyoNight
-
- # Syntax Highlighting Colors
- fish_color_normal c0caf5
- fish_color_command 7dcfff
- fish_color_keyword bb9af7
- fish_color_quote e0af68
- fish_color_redirection c0caf5
- fish_color_end ff9e64
- fish_color_error f7768e
- fish_color_param 9d7cd8
- fish_color_comment 565f89
- fish_color_selection --background=33467c
- fish_color_search_match --background=33467c
- fish_color_operator 9ece6a
- fish_color_escape bb9af7
- fish_color_autosuggestion 565f89
-
- # Completion Pager Colors
- fish_pager_color_progress 565f89
- fish_pager_color_prefix 7dcfff
- fish_pager_color_completion c0caf5
- fish_pager_color_description 565f89
- fish_pager_color_selected_background --background=33467c
diff --git a/fish/tokyonight_night.fish b/fish/tokyonight_night.fish
deleted file mode 100644
index f79979f..0000000
--- a/fish/tokyonight_night.fish
+++ /dev/null
@@ -1,34 +0,0 @@
- # TokyoNight Color Palette
- set -l foreground c0caf5
- set -l selection 33467c
- set -l comment 565f89
- set -l red f7768e
- set -l orange ff9e64
- set -l yellow e0af68
- set -l green 9ece6a
- set -l purple 9d7cd8
- set -l cyan 7dcfff
- set -l pink bb9af7
-
- # Syntax Highlighting Colors
- set -g fish_color_normal $foreground
- set -g fish_color_command $cyan
- set -g fish_color_keyword $pink
- set -g fish_color_quote $yellow
- set -g fish_color_redirection $foreground
- set -g fish_color_end $orange
- set -g fish_color_error $red
- set -g fish_color_param $purple
- set -g fish_color_comment $comment
- set -g fish_color_selection --background=$selection
- set -g fish_color_search_match --background=$selection
- set -g fish_color_operator $green
- set -g fish_color_escape $pink
- set -g fish_color_autosuggestion $comment
-
- # Completion Pager Colors
- set -g fish_pager_color_progress $comment
- set -g fish_pager_color_prefix $cyan
- set -g fish_pager_color_completion $foreground
- set -g fish_pager_color_description $comment
- set -g fish_pager_color_selected_background --background=$selection
diff --git a/flake.nix b/flake.nix
new file mode 100644
index 0000000..be1d5c2
--- /dev/null
+++ b/flake.nix
@@ -0,0 +1,113 @@
+{
+ description = "DashNix";
+
+ inputs = {
+ unstable.url = "github:NixOs/nixpkgs/nixos-unstable";
+ stable.url = "github:NixOs/nixpkgs/nixos-25.05";
+ nixos-wsl.url = "github:nix-community/NixOS-WSL/main";
+ nur.url = "github:nix-community/NUR";
+ lanzaboote = {
+ url = "github:nix-community/lanzaboote/v0.4.2";
+ inputs.nixpkgs.follows = "unstable";
+ };
+ statix.url = "github:oppiliappan/statix?ref=master";
+ # Darkreader requires es20, hence a stable pin
+ pkgsDarkreader.url = "github:NixOs/nixpkgs/nixos-24.11";
+
+ home-manager = {
+ url = "github:nix-community/home-manager";
+ inputs.nixpkgs.follows = "unstable";
+ };
+ cachy.url = "github:xddxdd/nix-cachyos-kernel?rev=bb7b8aa687464f24dcd452354d9621331d6b0737";
+
+ sops-nix.url = "github:Mic92/sops-nix";
+
+ hyprland.url = "github:hyprwm/Hyprland";
+
+ ironbar = {
+ url = "github:JakeStanger/ironbar";
+ inputs.nixpkgs.follows = "unstable";
+ };
+
+ zen-browser.url = "github:youwen5/zen-browser-flake";
+
+ stylix.url = "github:danth/stylix";
+ base16.url = "github:SenchoPens/base16.nix";
+ disko.url = "github:nix-community/disko/latest";
+
+ anyrun.url = "github:Kirottu/anyrun";
+ oxicalc.url = "github:Xetibo/OxiCalc";
+ oxishut.url = "github:Xetibo/OxiShut";
+ oxinoti.url = "github:Xetibo/OxiNoti";
+ oxidash.url = "github:Xetibo/OxiDash";
+ oxipaste.url = "github:Xetibo/OxiPaste";
+ oxirun.url = "github:Xetibo/OxiRun";
+ dashvim.url = "github:Xetibo/DashVim";
+
+ hyprdock.url = "github:Xetibo/hyprdock";
+ reset.url = "github:Xetibo/ReSet";
+ reset-plugins.url = "github:Xetibo/ReSet-Plugins";
+
+ superfreq.url = "github:NotAShelf/superfreq";
+
+ compose.url = "github:garnix-io/nixos-compose";
+ };
+
+ outputs = {self, ...} @ inputs: let
+ currentSystem = "x86_64-linux";
+ permittedPackages = [
+ "olm-3.2.16"
+ ];
+ importPkgsFn = import ./lib/importPkgs.nix;
+ defaultConfigureFn = pkgs:
+ importPkgsFn {
+ inherit inputs currentSystem permittedPackages pkgs;
+ };
+ stable = defaultConfigureFn inputs.stable;
+ unstable = defaultConfigureFn inputs.unstable;
+ pkgsDarkreader = defaultConfigureFn inputs.pkgsDarkreader;
+ in rec {
+ dashNixLib = import ./lib {
+ inherit
+ self
+ inputs
+ unstable
+ permittedPackages
+ ;
+ dashNixAdditionalProps = {
+ inherit pkgsDarkreader;
+ };
+ system = currentSystem;
+ };
+ docs = import ./docs {
+ inherit inputs;
+ pkgs = unstable;
+ system = currentSystem;
+ inherit (inputs.unstable) lib;
+ inherit (dashNixLib) buildSystems;
+ };
+ lint = inputs.statix.packages.${currentSystem}.default;
+ format = unstable.alejandra;
+ dashNixInputs = inputs;
+ stablePkgs = stable;
+ unstablePkgs = unstable;
+ modules = ./modules;
+ iso = dashNixLib.buildIso.config.system.build.isoImage;
+ nixosConfigurations = dashNixLib.buildSystems {root = ./example/.;};
+
+ mkFlake = stablePkgs.writeShellApplication {
+ name = "Create example config";
+ text =
+ /*
+ bash
+ */
+ ''
+ mkdir -p ~/gits/nixos
+ mkdir -p ~/gits/backup_nixos
+
+ mv ~/gits/nixos/* ~/gits/backup_nixos/
+ cp -r ${./example}/* ~/gits/nixos/
+ '';
+ };
+ };
+}
diff --git a/fontconfig/fonts.conf b/fontconfig/fonts.conf
deleted file mode 100644
index b22732e..0000000
--- a/fontconfig/fonts.conf
+++ /dev/null
@@ -1,27 +0,0 @@
-
-
-
-
-
- true
-
-
- true
-
-
- hintnone
-
-
- none
-
-
- true
-
-
- lcdnone
-
-
- 102
-
-
-
diff --git a/gtk-3.0/bookmarks b/gtk-3.0/bookmarks
deleted file mode 100644
index 0ea417d..0000000
--- a/gtk-3.0/bookmarks
+++ /dev/null
@@ -1,14 +0,0 @@
-file:///home/dashie/gits/ReSet
-file:///home/dashie/Documents
-file:///home/dashie/Pictures
-file:///home/dashie/Downloads
-file:///home/dashie/gits
-file:///home/dashie/gits/ost-5semester ost-5semester
-file:///home/dashie/gits/ost-4semester
-file:///home/dashie/gits/ost-3semester
-file:///home/dashie/Documents/OST%205.semester OST 5.semester
-file:///home/dashie/Documents/OST%204.semester
-file:///drive2
-file:///drive2/animu
-file:///home/dashie/tako
-file:///home/dashie/ReSet
diff --git a/gtk-3.0/gtk.css b/gtk-3.0/gtk.css
deleted file mode 100644
index 1aa5d77..0000000
--- a/gtk-3.0/gtk.css
+++ /dev/null
@@ -1,96 +0,0 @@
-/*
-Generated with Gradience
-
-Issues caused by theming should be reported to Gradience repository, and not to upstream
-
-https://github.com/GradienceTeam/Gradience
-*/
-
-@define-color accent_color #a9b1d6;
-@define-color accent_bg_color #a9b1d6;
-@define-color accent_fg_color rgba(0, 0, 0, 0.87);
-@define-color destructive_color #F28B82;
-@define-color destructive_bg_color #F28B82;
-@define-color destructive_fg_color rgba(0, 0, 0, 0.87);
-@define-color success_color #81C995;
-@define-color success_bg_color #81C995;
-@define-color success_fg_color rgba(0, 0, 0, 0.87);
-@define-color warning_color #FDD633;
-@define-color warning_bg_color #FDD633;
-@define-color warning_fg_color rgba(0, 0, 0, 0.87);
-@define-color error_color #F28B82;
-@define-color error_bg_color #F28B82;
-@define-color error_fg_color rgba(0, 0, 0, 0.87);
-@define-color window_bg_color #1a1b26;
-@define-color window_fg_color #c0caf5;
-@define-color view_bg_color #1a1b26;
-@define-color view_fg_color #c0caf5;
-@define-color headerbar_bg_color #1a1b26;
-@define-color headerbar_fg_color #c0caf5;
-@define-color headerbar_border_color rgba(192, 202, 245, 0.12);
-@define-color headerbar_backdrop_color @window_bg_color;
-@define-color headerbar_shade_color rgba(0, 0, 0, 0.36);
-@define-color card_bg_color #1a1b26;
-@define-color card_fg_color #c0caf5;
-@define-color card_shade_color rgba(0, 0, 0, 0.36);
-@define-color dialog_bg_color #1a1b26;
-@define-color dialog_fg_color #c0caf5;
-@define-color popover_bg_color #1a1b26;
-@define-color popover_fg_color #c0caf5;
-@define-color shade_color rgba(0, 0, 0, 0.36);
-@define-color scrollbar_outline_color rgba(0, 0, 0, 0.5);
-@define-color secondary_sidebar_backdrop_color #1a1b26;
-@define-color secondary_sidebar_shade_color rgba(0,0,0,0.5);
-@define-color sidebar_backdrop_color #1a1b26;
-@define-color sidebar_shade_color rgba(0,0,0,0.5);
-@define-color sidebar_bg_color #1a1b26;
-@define-color sidebar_fg_color #c0caf5;
-@define-color secondary_sidebar_bg_color #1a1b26;
-@define-color secondary_sidebar_fg_color #c0caf5;
-@define-color thumbnail_bg_color #1a1b26;
-@define-color thumbnail_fg_color #c0caf5;
-@define-color blue_1 #99c1f1;
-@define-color blue_2 #62a0ea;
-@define-color blue_3 #3584e4;
-@define-color blue_4 #1c71d8;
-@define-color blue_5 #1a5fb4;
-@define-color green_1 #8ff0a4;
-@define-color green_2 #57e389;
-@define-color green_3 #33d17a;
-@define-color green_4 #2ec27e;
-@define-color green_5 #26a269;
-@define-color yellow_1 #f9f06b;
-@define-color yellow_2 #f8e45c;
-@define-color yellow_3 #f6d32d;
-@define-color yellow_4 #f5c211;
-@define-color yellow_5 #e5a50a;
-@define-color orange_1 #ffbe6f;
-@define-color orange_2 #ffa348;
-@define-color orange_3 #ff7800;
-@define-color orange_4 #e66100;
-@define-color orange_5 #c64600;
-@define-color red_1 #f66151;
-@define-color red_2 #ed333b;
-@define-color red_3 #e01b24;
-@define-color red_4 #c01c28;
-@define-color red_5 #a51d2d;
-@define-color purple_1 #dc8add;
-@define-color purple_2 #c061cb;
-@define-color purple_3 #9141ac;
-@define-color purple_4 #813d9c;
-@define-color purple_5 #613583;
-@define-color brown_1 #cdab8f;
-@define-color brown_2 #b5835a;
-@define-color brown_3 #986a44;
-@define-color brown_4 #865e3c;
-@define-color brown_5 #63452c;
-@define-color light_1 #ffffff;
-@define-color light_2 #f6f5f4;
-@define-color light_3 #deddda;
-@define-color light_4 #c0bfbc;
-@define-color light_5 #9a9996;
-@define-color dark_1 #77767b;
-@define-color dark_2 #5e5c64;
-@define-color dark_3 #3d3846;
-@define-color dark_4 #241f31;
-@define-color dark_5 #000000;
diff --git a/gtk-3.0/gtk.css.bak b/gtk-3.0/gtk.css.bak
deleted file mode 100644
index 1f6ab50..0000000
--- a/gtk-3.0/gtk.css.bak
+++ /dev/null
@@ -1,96 +0,0 @@
-/*
-Generated with Gradience
-
-Issues caused by theming should be reported to Gradience repository, and not to upstream
-
-https://github.com/GradienceTeam/Gradience
-*/
-
-@define-color accent_color #a9b1d6;
-@define-color accent_bg_color #a9b1d6;
-@define-color accent_fg_color rgba(0, 0, 0, 0.87);
-@define-color destructive_color #F28B82;
-@define-color destructive_bg_color #F28B82;
-@define-color destructive_fg_color rgba(0, 0, 0, 0.87);
-@define-color success_color #81C995;
-@define-color success_bg_color #81C995;
-@define-color success_fg_color rgba(0, 0, 0, 0.87);
-@define-color warning_color #FDD633;
-@define-color warning_bg_color #FDD633;
-@define-color warning_fg_color rgba(0, 0, 0, 0.87);
-@define-color error_color #F28B82;
-@define-color error_bg_color #F28B82;
-@define-color error_fg_color rgba(0, 0, 0, 0.87);
-@define-color window_bg_color #1a1b26;
-@define-color window_fg_color #c0caf5;
-@define-color view_bg_color #1a1b26;
-@define-color view_fg_color #c0caf5;
-@define-color headerbar_bg_color #1a1b26;
-@define-color headerbar_fg_color #c0caf5;
-@define-color headerbar_border_color rgba(192, 202, 245, 0.12);
-@define-color headerbar_backdrop_color @window_bg_color;
-@define-color headerbar_shade_color rgba(0, 0, 0, 0.36);
-@define-color card_bg_color #1a1b26;
-@define-color card_fg_color #c0caf5;
-@define-color card_shade_color rgba(0, 0, 0, 0.36);
-@define-color dialog_bg_color #1a1b26;
-@define-color dialog_fg_color #c0caf5;
-@define-color popover_bg_color #1a1b26;
-@define-color popover_fg_color #c0caf5;
-@define-color shade_color rgba(0, 0, 0, 0.36);
-@define-color scrollbar_outline_color rgba(0, 0, 0, 0.5);
-@define-color secondary_sidebar_backdrop_color #1a1b26;
-@define-color secondary_sidebar_shade_color #c0caf5;
-@define-color sidebar_backdrop_color #1a1b26;
-@define-color sidebar_shade_color #c0caf5;
-@define-color sidebar_bg_color #1a1b26;
-@define-color sidebar_fg_color #c0caf5;
-@define-color secondary_sidebar_bg_color #1a1b26;
-@define-color secondary_sidebar_fg_color #c0caf5;
-@define-color thumbnail_bg_color #1a1b26;
-@define-color thumbnail_fg_color #c0caf5;
-@define-color blue_1 #99c1f1;
-@define-color blue_2 #62a0ea;
-@define-color blue_3 #3584e4;
-@define-color blue_4 #1c71d8;
-@define-color blue_5 #1a5fb4;
-@define-color green_1 #8ff0a4;
-@define-color green_2 #57e389;
-@define-color green_3 #33d17a;
-@define-color green_4 #2ec27e;
-@define-color green_5 #26a269;
-@define-color yellow_1 #f9f06b;
-@define-color yellow_2 #f8e45c;
-@define-color yellow_3 #f6d32d;
-@define-color yellow_4 #f5c211;
-@define-color yellow_5 #e5a50a;
-@define-color orange_1 #ffbe6f;
-@define-color orange_2 #ffa348;
-@define-color orange_3 #ff7800;
-@define-color orange_4 #e66100;
-@define-color orange_5 #c64600;
-@define-color red_1 #f66151;
-@define-color red_2 #ed333b;
-@define-color red_3 #e01b24;
-@define-color red_4 #c01c28;
-@define-color red_5 #a51d2d;
-@define-color purple_1 #dc8add;
-@define-color purple_2 #c061cb;
-@define-color purple_3 #9141ac;
-@define-color purple_4 #813d9c;
-@define-color purple_5 #613583;
-@define-color brown_1 #cdab8f;
-@define-color brown_2 #b5835a;
-@define-color brown_3 #986a44;
-@define-color brown_4 #865e3c;
-@define-color brown_5 #63452c;
-@define-color light_1 #ffffff;
-@define-color light_2 #f6f5f4;
-@define-color light_3 #deddda;
-@define-color light_4 #c0bfbc;
-@define-color light_5 #9a9996;
-@define-color dark_1 #77767b;
-@define-color dark_2 #5e5c64;
-@define-color dark_3 #3d3846;
-@define-color dark_4 #241f31;
-@define-color dark_5 #000000;
diff --git a/gtk-4.0/gtk.css b/gtk-4.0/gtk.css
deleted file mode 100644
index 3d750d1..0000000
--- a/gtk-4.0/gtk.css
+++ /dev/null
@@ -1,104 +0,0 @@
-/*
-Generated with Gradience
-
-Issues caused by theming should be reported to Gradience repository, and not to upstream
-
-https://github.com/GradienceTeam/Gradience
-*/
-
-@define-color accent_color #a9b1d6;
-@define-color accent_bg_color #a9b1d6;
-@define-color accent_fg_color rgba(0, 0, 0, 0.87);
-@define-color destructive_color #F28B82;
-@define-color destructive_bg_color #F28B82;
-@define-color destructive_fg_color rgba(0, 0, 0, 0.87);
-@define-color success_color #81C995;
-@define-color success_bg_color #81C995;
-@define-color success_fg_color rgba(0, 0, 0, 0.87);
-@define-color warning_color #FDD633;
-@define-color warning_bg_color #FDD633;
-@define-color warning_fg_color rgba(0, 0, 0, 0.87);
-@define-color error_color #F28B82;
-@define-color error_bg_color #F28B82;
-@define-color error_fg_color rgba(0, 0, 0, 0.87);
-@define-color window_bg_color #1a1b26;
-@define-color window_fg_color #c0caf5;
-@define-color view_bg_color #1a1b26;
-@define-color view_fg_color #c0caf5;
-@define-color headerbar_bg_color #1a1b26;
-@define-color headerbar_fg_color #c0caf5;
-@define-color headerbar_border_color rgba(192, 202, 245, 0.12);
-@define-color headerbar_backdrop_color @window_bg_color;
-@define-color headerbar_shade_color rgba(0, 0, 0, 0.36);
-@define-color card_bg_color #1a1b26;
-@define-color card_fg_color #c0caf5;
-@define-color card_shade_color rgba(0, 0, 0, 0.36);
-@define-color dialog_bg_color #1a1b26;
-@define-color dialog_fg_color #c0caf5;
-@define-color popover_bg_color #1a1b26;
-@define-color popover_fg_color #c0caf5;
-@define-color shade_color rgba(0, 0, 0, 0.36);
-@define-color scrollbar_outline_color rgba(0, 0, 0, 0.5);
-@define-color secondary_sidebar_backdrop_color #1a1b26;
-@define-color secondary_sidebar_shade_color rgba(0,0,0,0.5);
-@define-color sidebar_backdrop_color #1a1b26;
-@define-color sidebar_shade_color rgba(0,0,0,0.5);
-@define-color sidebar_bg_color #1a1b26;
-@define-color sidebar_fg_color #c0caf5;
-@define-color secondary_sidebar_bg_color #1a1b26;
-@define-color secondary_sidebar_fg_color #c0caf5;
-@define-color thumbnail_bg_color #1a1b26;
-@define-color thumbnail_fg_color #c0caf5;
-@define-color blue_1 #99c1f1;
-@define-color blue_2 #62a0ea;
-@define-color blue_3 #3584e4;
-@define-color blue_4 #1c71d8;
-@define-color blue_5 #1a5fb4;
-@define-color green_1 #8ff0a4;
-@define-color green_2 #57e389;
-@define-color green_3 #33d17a;
-@define-color green_4 #2ec27e;
-@define-color green_5 #26a269;
-@define-color yellow_1 #f9f06b;
-@define-color yellow_2 #f8e45c;
-@define-color yellow_3 #f6d32d;
-@define-color yellow_4 #f5c211;
-@define-color yellow_5 #e5a50a;
-@define-color orange_1 #ffbe6f;
-@define-color orange_2 #ffa348;
-@define-color orange_3 #ff7800;
-@define-color orange_4 #e66100;
-@define-color orange_5 #c64600;
-@define-color red_1 #f66151;
-@define-color red_2 #ed333b;
-@define-color red_3 #e01b24;
-@define-color red_4 #c01c28;
-@define-color red_5 #a51d2d;
-@define-color purple_1 #dc8add;
-@define-color purple_2 #c061cb;
-@define-color purple_3 #9141ac;
-@define-color purple_4 #813d9c;
-@define-color purple_5 #613583;
-@define-color brown_1 #cdab8f;
-@define-color brown_2 #b5835a;
-@define-color brown_3 #986a44;
-@define-color brown_4 #865e3c;
-@define-color brown_5 #63452c;
-@define-color light_1 #ffffff;
-@define-color light_2 #f6f5f4;
-@define-color light_3 #deddda;
-@define-color light_4 #c0bfbc;
-@define-color light_5 #9a9996;
-@define-color dark_1 #77767b;
-@define-color dark_2 #5e5c64;
-@define-color dark_3 #3d3846;
-@define-color dark_4 #241f31;
-@define-color dark_5 #000000;
-/*
-Generated with Gradience
-
-Issues caused by theming should be reported to Gradience repository, and not to upstream
-
-https://github.com/GradienceTeam/Gradience
-*/
-
diff --git a/gtk-4.0/gtk.css.bak b/gtk-4.0/gtk.css.bak
deleted file mode 100644
index 1f6ab50..0000000
--- a/gtk-4.0/gtk.css.bak
+++ /dev/null
@@ -1,96 +0,0 @@
-/*
-Generated with Gradience
-
-Issues caused by theming should be reported to Gradience repository, and not to upstream
-
-https://github.com/GradienceTeam/Gradience
-*/
-
-@define-color accent_color #a9b1d6;
-@define-color accent_bg_color #a9b1d6;
-@define-color accent_fg_color rgba(0, 0, 0, 0.87);
-@define-color destructive_color #F28B82;
-@define-color destructive_bg_color #F28B82;
-@define-color destructive_fg_color rgba(0, 0, 0, 0.87);
-@define-color success_color #81C995;
-@define-color success_bg_color #81C995;
-@define-color success_fg_color rgba(0, 0, 0, 0.87);
-@define-color warning_color #FDD633;
-@define-color warning_bg_color #FDD633;
-@define-color warning_fg_color rgba(0, 0, 0, 0.87);
-@define-color error_color #F28B82;
-@define-color error_bg_color #F28B82;
-@define-color error_fg_color rgba(0, 0, 0, 0.87);
-@define-color window_bg_color #1a1b26;
-@define-color window_fg_color #c0caf5;
-@define-color view_bg_color #1a1b26;
-@define-color view_fg_color #c0caf5;
-@define-color headerbar_bg_color #1a1b26;
-@define-color headerbar_fg_color #c0caf5;
-@define-color headerbar_border_color rgba(192, 202, 245, 0.12);
-@define-color headerbar_backdrop_color @window_bg_color;
-@define-color headerbar_shade_color rgba(0, 0, 0, 0.36);
-@define-color card_bg_color #1a1b26;
-@define-color card_fg_color #c0caf5;
-@define-color card_shade_color rgba(0, 0, 0, 0.36);
-@define-color dialog_bg_color #1a1b26;
-@define-color dialog_fg_color #c0caf5;
-@define-color popover_bg_color #1a1b26;
-@define-color popover_fg_color #c0caf5;
-@define-color shade_color rgba(0, 0, 0, 0.36);
-@define-color scrollbar_outline_color rgba(0, 0, 0, 0.5);
-@define-color secondary_sidebar_backdrop_color #1a1b26;
-@define-color secondary_sidebar_shade_color #c0caf5;
-@define-color sidebar_backdrop_color #1a1b26;
-@define-color sidebar_shade_color #c0caf5;
-@define-color sidebar_bg_color #1a1b26;
-@define-color sidebar_fg_color #c0caf5;
-@define-color secondary_sidebar_bg_color #1a1b26;
-@define-color secondary_sidebar_fg_color #c0caf5;
-@define-color thumbnail_bg_color #1a1b26;
-@define-color thumbnail_fg_color #c0caf5;
-@define-color blue_1 #99c1f1;
-@define-color blue_2 #62a0ea;
-@define-color blue_3 #3584e4;
-@define-color blue_4 #1c71d8;
-@define-color blue_5 #1a5fb4;
-@define-color green_1 #8ff0a4;
-@define-color green_2 #57e389;
-@define-color green_3 #33d17a;
-@define-color green_4 #2ec27e;
-@define-color green_5 #26a269;
-@define-color yellow_1 #f9f06b;
-@define-color yellow_2 #f8e45c;
-@define-color yellow_3 #f6d32d;
-@define-color yellow_4 #f5c211;
-@define-color yellow_5 #e5a50a;
-@define-color orange_1 #ffbe6f;
-@define-color orange_2 #ffa348;
-@define-color orange_3 #ff7800;
-@define-color orange_4 #e66100;
-@define-color orange_5 #c64600;
-@define-color red_1 #f66151;
-@define-color red_2 #ed333b;
-@define-color red_3 #e01b24;
-@define-color red_4 #c01c28;
-@define-color red_5 #a51d2d;
-@define-color purple_1 #dc8add;
-@define-color purple_2 #c061cb;
-@define-color purple_3 #9141ac;
-@define-color purple_4 #813d9c;
-@define-color purple_5 #613583;
-@define-color brown_1 #cdab8f;
-@define-color brown_2 #b5835a;
-@define-color brown_3 #986a44;
-@define-color brown_4 #865e3c;
-@define-color brown_5 #63452c;
-@define-color light_1 #ffffff;
-@define-color light_2 #f6f5f4;
-@define-color light_3 #deddda;
-@define-color light_4 #c0bfbc;
-@define-color light_5 #9a9996;
-@define-color dark_1 #77767b;
-@define-color dark_2 #5e5c64;
-@define-color dark_3 #3d3846;
-@define-color dark_4 #241f31;
-@define-color dark_5 #000000;
diff --git a/gtk-4.0/servers b/gtk-4.0/servers
deleted file mode 100644
index 1205346..0000000
--- a/gtk-4.0/servers
+++ /dev/null
@@ -1,25 +0,0 @@
-
-
-
- Windows shares on 192.168.1.4
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/gtk-4.0/settings.ini b/gtk-4.0/settings.ini
deleted file mode 100644
index d289a6a..0000000
--- a/gtk-4.0/settings.ini
+++ /dev/null
@@ -1,3 +0,0 @@
-[Settings]
-gtk-application-prefer-dark-theme=true
-gtk-hint-font-metrics=1
diff --git a/home/common.nix b/home/common.nix
new file mode 100644
index 0000000..fe2fa53
--- /dev/null
+++ b/home/common.nix
@@ -0,0 +1,42 @@
+{
+ mkDashDefault,
+ config,
+ lib,
+ pkgs,
+ ...
+}: let
+ username = config.conf.username;
+in {
+ manual = {
+ html.enable = mkDashDefault false;
+ json.enable = mkDashDefault false;
+ manpages.enable = mkDashDefault false;
+ };
+
+ fonts.fontconfig.enable = mkDashDefault true;
+
+ home = {
+ username = mkDashDefault username;
+ homeDirectory = mkDashDefault "/home/${username}";
+ sessionPath = ["$HOME/.cargo/bin"];
+
+ enableNixpkgsReleaseCheck = mkDashDefault false;
+ sessionVariables = {
+ GOROOT = mkDashDefault "$HOME/.go";
+ QT_QPA_PLATFORMTHEME = mkDashDefault "qt5ct";
+ };
+
+ keyboard = mkDashDefault null;
+ };
+
+ programs.nix-index = {
+ enable = mkDashDefault true;
+ enableFishIntegration = mkDashDefault true;
+ };
+
+ nix = {
+ extraOptions = lib.mkIf (config ? sops.secrets && config.sops.secrets ? access.path) ''
+ !include ${config.sops.secrets.access.path}
+ '';
+ };
+}
diff --git a/home/default.nix b/home/default.nix
new file mode 100644
index 0000000..afc0ab3
--- /dev/null
+++ b/home/default.nix
@@ -0,0 +1,66 @@
+{
+ mkDashDefault,
+ dashNixAdditionalProps,
+ config,
+ homeMods,
+ inputs,
+ lib,
+ additionalHomeConfig,
+ mod,
+ pkgs,
+ root,
+ alternativePkgs,
+ system,
+ stable,
+ unstable,
+ ...
+}: {
+ xdg = {
+ portal.config.common = {
+ default = mkDashDefault "hyprland;gtk";
+ "org.freedesktop.impl.portal.FileChooser" = lib.mkIf (config.mods.media.filePickerPortal != "Default") "shana";
+ };
+ portal = {
+ enable = mkDashDefault true;
+ extraPortals = with pkgs; [
+ xdg-desktop-portal-gtk # prob needed either way
+ (lib.mkIf (config.mods.media.filePickerPortal != "Default") xdg-desktop-portal-shana)
+ (lib.mkIf (config.mods.media.filePickerPortal == "Kde") kdePackages.xdg-desktop-portal-kde)
+ # Gnome uses their file manager, kinda cool tbh
+ (lib.mkIf (config.mods.media.filePickerPortal == "Gnome" && !config.mods.nautilus.enable) nautilus)
+ (lib.mkIf (config.mods.media.filePickerPortal == "Lxqt") xdg-desktop-portal-lxqt)
+ (lib.mkIf (config.mods.media.filePickerPortal == "Term") xdg-desktop-portal-termfilechooser)
+ ];
+ };
+ };
+ home-manager = {
+ useGlobalPkgs = mkDashDefault true;
+ useUserPackages = mkDashDefault true;
+ extraSpecialArgs = {
+ inherit
+ inputs
+ root
+ alternativePkgs
+ system
+ stable
+ unstable
+ dashNixAdditionalProps
+ ;
+ mkDashDefault = import ../lib/override.nix {inherit lib;};
+ };
+
+ users.${config.conf.username} = {
+ disabledModules = ["programs/anyrun.nix"];
+ imports =
+ [
+ ./common.nix
+ ./themes
+ ./sync.nix
+ ../lib/foxwrappers.nix
+ ]
+ ++ homeMods
+ ++ lib.optional (builtins.pathExists additionalHomeConfig) additionalHomeConfig
+ ++ lib.optional (builtins.pathExists mod) mod;
+ };
+ };
+}
diff --git a/home/sync.nix b/home/sync.nix
new file mode 100644
index 0000000..38dceea
--- /dev/null
+++ b/home/sync.nix
@@ -0,0 +1,55 @@
+# derived from NixOS wiki
+{
+ config,
+ pkgs,
+ lib,
+ ...
+}: let
+ username = config.mods.nextcloud.username;
+ password =
+ if (config.sops.secrets ? nextcloud.path)
+ then config.sops.secrets.nextcloud.path
+ else "";
+ url = config.mods.nextcloud.url;
+ synclist = config.mods.nextcloud.synclist;
+in
+ lib.mkIf config.mods.nextcloud.enable {
+ systemd.user = {
+ services = builtins.listToAttrs (
+ map (opts: {
+ name = "${opts.name}";
+ value = {
+ Unit = {
+ Description = "Auto sync Nextcloud";
+ After = "network-online.target";
+ };
+ Service = {
+ Type = "simple";
+ ExecStart = "${pkgs.bash}/bin/bash -c '${pkgs.nextcloud-client}/bin/nextcloudcmd -h --path ${opts.remote} ${opts.local} https://${username}:$(bat ${password})@${url}'";
+ TimeoutStopSec = "180";
+ KillMode = "process";
+ KillSignal = "SIGINT";
+ };
+ Install.WantedBy = ["multi-user.target"];
+ };
+ })
+ synclist
+ );
+ timers = builtins.listToAttrs (
+ map (opts: {
+ name = "${opts.name}";
+ value = {
+ Unit.Description = "Automatic sync files with Nextcloud when booted up after 1 minute then rerun every 60 minutes";
+ Timer.OnBootSec = "1min";
+ Timer.OnUnitActiveSec = "60min";
+ Install.WantedBy = [
+ "multi-user.target"
+ "timers.target"
+ ];
+ };
+ })
+ synclist
+ );
+ startServices = true;
+ };
+ }
diff --git a/home/themes/default.nix b/home/themes/default.nix
new file mode 100644
index 0000000..9976455
--- /dev/null
+++ b/home/themes/default.nix
@@ -0,0 +1,8 @@
+{
+ imports = [
+ ./qt.nix
+ ./kdeglobals.nix
+ ./oxiced.nix
+ ./firefoxTheme.nix
+ ];
+}
diff --git a/home/themes/firefoxTheme.nix b/home/themes/firefoxTheme.nix
new file mode 100644
index 0000000..0de46f6
--- /dev/null
+++ b/home/themes/firefoxTheme.nix
@@ -0,0 +1,327 @@
+# css from https://github.com/catppuccin/zen-browser/tree/main/themes
+{
+ config,
+ inputs,
+ pkgs,
+ lib,
+ ...
+}: let
+ # at time of using this here, stylix might not be evaluated yet
+ # hence ensure it is by using base16 mkSchemeAttrs
+ base16 = pkgs.callPackage inputs.base16.lib {};
+ scheme = base16.mkSchemeAttrs config.stylix.base16Scheme;
+ userChrome =
+ /*
+ css
+ */
+ ''
+ /* Catppuccin Mocha Blue userContent.css*/
+
+ @media (prefers-color-scheme: dark) {
+
+ /* Common variables affecting all pages */
+ @-moz-document url-prefix("about:") {
+ :root {
+ --in-content-page-color: #${scheme.base05} !important;
+ --color-accent-primary: #${scheme.base0D} !important;
+ --color-accent-primary-hover: rgb(163, 197, 251) !important; // TODO
+ --color-accent-primary-active: rgb(138, 153, 250) !important; // TODO
+ background-color: #${scheme.base00} !important;
+ --in-content-page-background: #${scheme.base00} !important;
+ }
+
+ }
+
+ /* Variables and styles specific to about:newtab and about:home */
+ @-moz-document url("about:newtab"), url("about:home") {
+
+ :root {
+ --newtab-background-color: #${scheme.base00} !important;
+ --newtab-background-color-secondary: #${scheme.base02} !important;
+ --newtab-element-hover-color: #${scheme.base02} !important;
+ --newtab-text-primary-color: #${scheme.base05} !important;
+ --newtab-wordmark-color: #${scheme.base05} !important;
+ --newtab-primary-action-background: #${scheme.base0D} !important;
+ }
+
+ .icon {
+ color: #${scheme.base0D} !important;
+ }
+
+ .search-wrapper .logo-and-wordmark .logo {
+ //background: url("zen-logo-mocha.svg"), url("https://raw.githubusercontent.com/IAmJafeth/zen-browser/main/themes/Mocha/Blue/zen-logo-mocha.svg") no-repeat center !important; // TODO
+ display: inline-block !important;
+ height: 82px !important;
+ width: 82px !important;
+ background-size: 82px !important;
+ }
+
+ @media (max-width: 609px) {
+ .search-wrapper .logo-and-wordmark .logo {
+ background-size: 64px !important;
+ height: 64px !important;
+ width: 64px !important;
+ }
+ }
+
+ .card-outer:is(:hover, :focus, .active):not(.placeholder) .card-title {
+ color: #${scheme.base0D} !important;
+ }
+
+ .top-site-outer .search-topsite {
+ background-color: #${scheme.base0D} !important;
+ }
+
+ .compact-cards .card-outer .card-context .card-context-icon.icon-download {
+ fill: #${scheme.base0B} !important;
+ }
+ }
+
+ /* Variables and styles specific to about:preferences */
+ @-moz-document url-prefix("about:preferences") {
+ :root {
+ --zen-colors-tertiary: #${scheme.base01} !important;
+ --in-content-text-color: #${scheme.base05} !important;
+ --link-color: #${scheme.base0D} !important;
+ --link-color-hover: rgb(163, 197, 251) !important; // TODO
+ --zen-colors-primary: #${scheme.base02} !important;
+ --in-content-box-background: #${scheme.base02} !important;
+ --zen-primary-color: #${scheme.base0D} !important;
+ }
+
+ groupbox , moz-card{
+ background: #${scheme.base00} !important;
+ }
+
+ button,
+ groupbox menulist {
+ background: #${scheme.base02} !important;
+ color: #${scheme.base05} !important;
+ }
+
+ .main-content {
+ background-color: #${scheme.base01} !important;
+ }
+
+ .identity-color-blue {
+ --identity-tab-color: #8aadf4 !important; // TODO
+ --identity-icon-color: #8aadf4 !important; // TODO
+ }
+
+ .identity-color-turquoise {
+ --identity-tab-color: #8bd5ca !important; // TODO
+ --identity-icon-color: #8bd5ca !important; // TODO
+ }
+
+ .identity-color-green {
+ --identity-tab-color: #${scheme.base0B} !important;
+ --identity-icon-color: #${scheme.base0B} !important;
+ }
+
+ .identity-color-yellow {
+ --identity-tab-color: #eed49f !important; // TODO
+ --identity-icon-color: #eed49f !important; // TODO
+ }
+
+ .identity-color-orange {
+ --identity-tab-color: #f5a97f !important; // TODO
+ --identity-icon-color: #f5a97f !important; // TODO
+ }
+
+ .identity-color-red {
+ --identity-tab-color: #ed8796 !important; // TODO
+ --identity-icon-color: #ed8796 !important; // TODO
+ }
+
+ .identity-color-pink {
+ --identity-tab-color: #f5bde6 !important; // TODO
+ --identity-icon-color: #f5bde6 !important; // TODO
+ }
+
+ .identity-color-purple {
+ --identity-tab-color: #c6a0f6 !important; // TODO
+ --identity-icon-color: #c6a0f6 !important; // TODO
+ }
+ }
+
+ /* Variables and styles specific to about:addons */
+ @-moz-document url-prefix("about:addons") {
+ :root {
+ --zen-dark-color-mix-base: #${scheme.base01} !important;
+ --background-color-box: #${scheme.base00} !important;
+ }
+ }
+
+ /* Variables and styles specific to about:protections */
+ @-moz-document url-prefix("about:protections") {
+ :root {
+ --zen-primary-color: #${scheme.base00} !important;
+ --social-color: #${scheme.base0E} !important;
+ --coockie-color: #${scheme.base08} !important;
+ --fingerprinter-color: #${scheme.base0A} !important;
+ --cryptominer-color: #${scheme.base07} !important;
+ --tracker-color: #${scheme.base0B} !important;
+ --in-content-primary-button-background-hover: rgb(81, 83, 05) !important;
+ --in-content-primary-button-text-color-hover: #${scheme.base05} !important;
+ --in-content-primary-button-background: #${scheme.base03} !important;
+ --in-content-primary-button-text-color: #${scheme.base05} !important;
+ }
+
+
+ .card {
+ background-color: #${scheme.base02} !important;
+ }
+ }
+ }
+ '';
+ userContent =
+ /*
+ css
+ */
+ ''
+ /* Catppuccin Mocha Blue userChrome.css*/
+ @media (prefers-color-scheme: dark) {
+
+ :root {
+ --zen-colors-primary: #${scheme.base02} !important;
+ --zen-primary-color: #${scheme.base0D} !important;
+ --zen-colors-secondary: #${scheme.base02} !important;
+ --zen-colors-tertiary: #${scheme.base01} !important;
+ --zen-colors-border: #${scheme.base0D} !important;
+ --toolbarbutton-icon-fill: #${scheme.base0D} !important;
+ --lwt-text-color: #${scheme.base05} !important;
+ --toolbar-field-color: #${scheme.base05} !important;
+ --tab-selected-textcolor: rgb(171, 197, 247) !important; // TODO
+ --toolbar-field-focus-color: #${scheme.base05} !important;
+ --toolbar-color: #${scheme.base05} !important;
+ --newtab-text-primary-color: #${scheme.base05} !important;
+ --arrowpanel-color: #${scheme.base05} !important;
+ --arrowpanel-background: #${scheme.base00} !important;
+ --sidebar-text-color: #${scheme.base05} !important;
+ --lwt-sidebar-text-color: #${scheme.base05} !important;
+ --lwt-sidebar-background-color: #${scheme.base01} !important; //TODO 11111b !important;
+ --toolbar-bgcolor: #${scheme.base02} !important;
+ --newtab-background-color: #${scheme.base00} !important;
+ --zen-themed-toolbar-bg: #${scheme.base01} !important;
+ --zen-main-browser-background: #${scheme.base01} !important;
+ }
+
+ #permissions-granted-icon{
+ color: #${scheme.base01} !important;
+ }
+
+ .sidebar-placesTree {
+ background-color: #${scheme.base00} !important;
+ }
+
+ #zen-workspaces-button {
+ background-color: #${scheme.base00} !important;
+ }
+
+ #TabsToolbar {
+ background-color: #${scheme.base01} !important;
+ }
+
+ #urlbar-background {
+ background-color: #${scheme.base00} !important;
+ }
+
+ .content-shortcuts {
+ background-color: #${scheme.base00} !important;
+ border-color: #${scheme.base0D} !important;
+ }
+
+ .urlbarView-url {
+ color: #${scheme.base0D} !important;
+ }
+
+ #zenEditBookmarkPanelFaviconContainer {
+ background: #${scheme.base01} !important;
+ }
+
+ toolbar .toolbarbutton-1 {
+ &:not([disabled]) {
+ &:is([open], [checked]) > :is(.toolbarbutton-icon, .toolbarbutton-text, .toolbarbutton-badge-stack){
+ fill: #${scheme.base01};
+ }
+ }
+ }
+
+ .identity-color-blue {
+ --identity-tab-color: #${scheme.base0D} !important;
+ --identity-icon-color: #${scheme.base0D} !important;
+ }
+
+ .identity-color-turquoise {
+ --identity-tab-color: #${scheme.base0C} !important;
+ --identity-icon-color: #${scheme.base0C} !important;
+ }
+
+ .identity-color-green {
+ --identity-tab-color: #${scheme.base0B} !important;
+ --identity-icon-color: #${scheme.base0B} !important;
+ }
+
+ .identity-color-yellow {
+ --identity-tab-color: #${scheme.base0A} !important;
+ --identity-icon-color: #${scheme.base0A} !important;
+ }
+
+ .identity-color-orange {
+ --identity-tab-color: #${scheme.base09} !important;
+ --identity-icon-color: #${scheme.base09} !important;
+ }
+
+ .identity-color-red {
+ --identity-tab-color: #${scheme.base08} !important;
+ --identity-icon-color: #${scheme.base08} !important;
+ }
+
+ .identity-color-pink {
+ --identity-tab-color: #${scheme.base0F} !important;
+ --identity-icon-color: #${scheme.base0F} !important; // TODO f5c2e7
+ }
+
+ .identity-color-purple {
+ --identity-tab-color: #${scheme.base0E} !important;
+ --identity-icon-color: #${scheme.base0E} !important;
+ }
+ }
+ '';
+ browsername = config.mods.homePackages.browser;
+ profiles =
+ if config.mods.homePackages.browser == "firefox"
+ then config.mods.browser.firefox.profiles
+ else if config.mods.homePackages.browser == "zen"
+ then config.mods.browser.zen.profiles
+ else if config.mods.homePackages.browser == "librewolf"
+ then [
+ {
+ name = "default";
+ value = {};
+ }
+ ]
+ else [];
+ profileNamesFn =
+ builtins.catAttrs "name";
+ chromesFn = builtins.map (
+ name:
+ if (builtins.isString browsername)
+ then {
+ ".${browsername}/${name}/chrome/userContent.css" = {
+ text = userChrome;
+ };
+
+ ".${browsername}/${name}/chrome/userChrome.css" = {
+ text = userContent;
+ };
+ }
+ else {}
+ );
+ moduleFn = lib.lists.foldr (attr1: attr2: attr1 // attr2) {};
+ mkFirefoxTheme = profiles:
+ profiles
+ |> profileNamesFn
+ |> chromesFn
+ |> moduleFn;
+in {home.file = mkFirefoxTheme profiles;}
diff --git a/home/themes/kdeglobals.nix b/home/themes/kdeglobals.nix
new file mode 100644
index 0000000..8fa5003
--- /dev/null
+++ b/home/themes/kdeglobals.nix
@@ -0,0 +1,252 @@
+# This is ABSOLUTE GARGABE, KDE srsly, remove this!
+# props to catppuccin mocha for sparing me from doing this manually: https://github.com/catppuccin/kde/blob/main/Resources/Base.colors
+{
+ pkgs,
+ config,
+ lib,
+ inputs,
+ ...
+}: let
+ base16 = pkgs.callPackage inputs.base16.lib {};
+
+ baseScheme = base16.mkSchemeAttrs config.stylix.base16Scheme;
+ power = number: powerIndex:
+ if powerIndex == 1
+ then number
+ else if powerIndex == 0
+ then 1
+ else number * power number (powerIndex - 1);
+
+ lookupTable = powerIndex: {
+ "0" = 0 * (power 16 powerIndex);
+ "1" = 1 * (power 16 powerIndex);
+ "2" = 2 * (power 16 powerIndex);
+ "3" = 3 * (power 16 powerIndex);
+ "4" = 4 * (power 16 powerIndex);
+ "5" = 5 * (power 16 powerIndex);
+ "6" = 6 * (power 16 powerIndex);
+ "7" = 7 * (power 16 powerIndex);
+ "8" = 8 * (power 16 powerIndex);
+ "9" = 9 * (power 16 powerIndex);
+ "a" = 10 * (power 16 powerIndex);
+ "b" = 11 * (power 16 powerIndex);
+ "c" = 12 * (power 16 powerIndex);
+ "d" = 13 * (power 16 powerIndex);
+ "e" = 14 * (power 16 powerIndex);
+ "f" = 15 * (power 16 powerIndex);
+ };
+
+ convertHex = hexChars:
+ recombineColors [
+ (convertColor (lib.lists.take 2 hexChars))
+ (convertColor (lib.lists.take 2 (lib.lists.drop 2 hexChars)))
+ (convertColor (lib.lists.take 2 (lib.lists.drop 4 hexChars)))
+ ];
+
+ convertColor = color: (lookupTable 1).${(lib.lists.head color)} + (lookupTable 0).${(lib.lists.last color)};
+ recombineColors = colors: lib.lists.foldr (a: b: (toString a) + "," + (toString b)) "end" colors;
+
+ scheme = {
+ base00 = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base00)
+ );
+ base01 = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base01)
+ );
+ base02 = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base02)
+ );
+ base03 = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base03)
+ );
+ base04 = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base04)
+ );
+ base05 = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base05)
+ );
+ base06 = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base06)
+ );
+ base07 = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base07)
+ );
+ base08 = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base08)
+ );
+ base09 = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base09)
+ );
+ base0A = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base0A)
+ );
+ base0B = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base0B)
+ );
+ base0C = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base0C)
+ );
+ base0D = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base0D)
+ );
+ base0E = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base0E)
+ );
+ base0F = lib.strings.removeSuffix ",end" (
+ convertHex (lib.strings.stringToCharacters baseScheme.base0F)
+ );
+ };
+in {
+ # temp
+ # crust -> surface1
+ # subtext0 -> surface2
+ # accentColor -> lavender
+ xdg.configFile."kdeglobals" = {
+ text = ''
+ [ColorEffects:Disabled]
+ Color=${scheme.base01}
+ ColorAmount=0.30000000000000004
+ ColorEffect=2
+ ContrastAmount=0.1
+ ContrastEffect=0
+ IntensityAmount=-1
+ IntensityEffect=0
+
+ [ColorEffects:Inactive]
+ ChangeSelectionColor=true
+ Color=${scheme.base01}
+ ColorAmount=0.5
+ ColorEffect=3
+ ContrastAmount=0
+ ContrastEffect=0
+ Enable=true
+ IntensityAmount=0
+ IntensityEffect=0
+
+ [Colors:Button]
+ BackgroundAlternate=${scheme.base07}
+ BackgroundNormal=${scheme.base02}
+ DecorationFocus=${scheme.base07}
+ DecorationHover=${scheme.base02}
+ ForegroundActive=${scheme.base09}
+ ForegroundInactive=${scheme.base04}
+ ForegroundLink=${scheme.base07}
+ ForegroundNegative=${scheme.base08}
+ ForegroundNeutral=${scheme.base0A}
+ ForegroundNormal=${scheme.base05}
+ ForegroundPositive=${scheme.base0B}
+ ForegroundVisited=${scheme.base0E}
+
+
+ [Colors:Complementary]
+ BackgroundAlternate=${scheme.base03}
+ BackgroundNormal=${scheme.base00}
+ DecorationFocus=${scheme.base07}
+ DecorationHover=${scheme.base02}
+ ForegroundActive=${scheme.base09}
+ ForegroundInactive=${scheme.base04}
+ ForegroundLink=${scheme.base07}
+ ForegroundNegative=${scheme.base08}
+ ForegroundNeutral=${scheme.base0A}
+ ForegroundNormal=${scheme.base05}
+ ForegroundPositive=${scheme.base0B}
+ ForegroundVisited=${scheme.base0E}
+
+
+ [Colors:Header]
+ BackgroundAlternate=${scheme.base03}
+ BackgroundNormal=${scheme.base00}
+ DecorationFocus=${scheme.base07}
+ DecorationHover=${scheme.base02}
+ ForegroundActive=${scheme.base09}
+ ForegroundInactive=${scheme.base04}
+ ForegroundLink=${scheme.base07}
+ ForegroundNegative=${scheme.base08}
+ ForegroundNeutral=${scheme.base0A}
+ ForegroundNormal=${scheme.base05}
+ ForegroundPositive=${scheme.base0B}
+ ForegroundVisited=${scheme.base0E}
+
+
+ [Colors:Selection]
+ BackgroundAlternate=${scheme.base07}
+ BackgroundNormal=${scheme.base07}
+ DecorationFocus=${scheme.base07}
+ DecorationHover=${scheme.base02}
+ ForegroundLink=${scheme.base07}
+ ForegroundInactive=${scheme.base00}
+ ForegroundActive=${scheme.base09}
+ ForegroundLink=${scheme.base07}
+ ForegroundNegative=${scheme.base08}
+ ForegroundNeutral=${scheme.base0A}
+ ForegroundNormal=${scheme.base03}
+ ForegroundPositive=${scheme.base0B}
+ ForegroundVisited=${scheme.base0E}
+
+
+ [Colors:Tooltip]
+ BackgroundAlternate=27,25,35
+ BackgroundNormal=${scheme.base01}
+ DecorationFocus=${scheme.base07}
+ DecorationHover=${scheme.base02}
+ ForegroundActive=${scheme.base09}
+ ForegroundInactive=${scheme.base04}
+ ForegroundLink=${scheme.base07}
+ ForegroundNegative=${scheme.base08}
+ ForegroundNeutral=${scheme.base0A}
+ ForegroundNormal=${scheme.base05}
+ ForegroundPositive=${scheme.base0B}
+ ForegroundVisited=${scheme.base0E}
+
+
+ [Colors:View]
+ BackgroundAlternate=${scheme.base00}
+ BackgroundNormal=${scheme.base01}
+ DecorationFocus=${scheme.base07}
+ DecorationHover=${scheme.base02}
+ ForegroundActive=${scheme.base09}
+ ForegroundInactive=${scheme.base04}
+ ForegroundLink=${scheme.base07}
+ ForegroundNegative=${scheme.base08}
+ ForegroundNeutral=${scheme.base0A}
+ ForegroundNormal=${scheme.base05}
+ ForegroundPositive=${scheme.base0B}
+ ForegroundVisited=${scheme.base0E}
+
+
+ [Colors:Window]
+ BackgroundAlternate=${scheme.base03}
+ BackgroundNormal=${scheme.base00}
+ DecorationFocus=${scheme.base07}
+ DecorationHover=${scheme.base02}
+ ForegroundActive=${scheme.base09}
+ ForegroundInactive=${scheme.base04}
+ ForegroundLink=${scheme.base07}
+ ForegroundNegative=${scheme.base08}
+ ForegroundNeutral=${scheme.base0A}
+ ForegroundNormal=${scheme.base05}
+ ForegroundPositive=${scheme.base0B}
+ ForegroundVisited=${scheme.base0E}
+
+
+ [General]
+ ColorScheme=CustomBase16Nix
+ Name=CustomBase16Nix
+ accentActiveTitlebar=false
+ shadeSortColumn=true
+
+
+ [KDE]
+ contrast=4
+
+
+ [WM]
+ activeBackground=${scheme.base01}
+ activeBlend=${scheme.base05}
+ activeForeground=${scheme.base05}
+ inactiveBackground=${scheme.base03}
+ inactiveBlend=${scheme.base04}
+ inactiveForeground=${scheme.base04}
+ '';
+ };
+}
diff --git a/home/themes/oxiced.nix b/home/themes/oxiced.nix
new file mode 100644
index 0000000..8a9e7dc
--- /dev/null
+++ b/home/themes/oxiced.nix
@@ -0,0 +1,86 @@
+{
+ config,
+ inputs,
+ pkgs,
+ ...
+}: let
+ # at time of using this here, stylix might not be evaluated yet
+ # hence ensure it is by using base16 mkSchemeAttrs
+ base16 = pkgs.callPackage inputs.base16.lib {};
+ scheme = base16.mkSchemeAttrs config.stylix.base16Scheme;
+ valueOrDefault = value: fallback:
+ if (scheme ? oxiced && scheme.oxiced ? ${value})
+ then scheme.oxiced.value
+ else fallback;
+in {
+ xdg.configFile."oxiced/theme.toml" = {
+ source = (pkgs.formats.toml {}).generate "oxiced" {
+ base = valueOrDefault "base" scheme.base00;
+ mantle = valueOrDefault "mantle" scheme.base01;
+ primary_bg = valueOrDefault "primary_bg" scheme.base02;
+ secondary_bg = valueOrDefault "secondary_bg" scheme.base03;
+ tertiary_bg = valueOrDefault "tertiary_bg" scheme.base04;
+ text = valueOrDefault "text" scheme.base05;
+
+ primary = valueOrDefault "primary" scheme.base0D;
+ primary_contrast = valueOrDefault "primary_contrast" "FFFFFF";
+ secondary = valueOrDefault "primary" scheme.base07;
+ secondary_contrast = valueOrDefault "secondary_contrast" "FFFFFF";
+
+ good = valueOrDefault "good" scheme.base0B;
+ good_contrast = valueOrDefault "good_contrast" "000000";
+ bad = valueOrDefault "bad" scheme.base08;
+ bad_contrast = valueOrDefault "bad_contrast" "FFFFFF";
+ warning = valueOrDefault "warning" scheme.base0A;
+ warning_contrast = valueOrDefault "warning_contrast" "000000";
+ info = valueOrDefault "info" scheme.base0C;
+ info_contrast = valueOrDefault "info_contrast" "FFFFFF";
+
+ rose = valueOrDefault "rose" scheme.base06;
+ lavender = valueOrDefault "lavender" scheme.base07;
+ blue = valueOrDefault "blue" scheme.base0D;
+ mauve = valueOrDefault "mauve" scheme.base0E;
+ flamingo = valueOrDefault "flamingo" scheme.base0F;
+
+ border_color_weak = valueOrDefault "border_color_weak" scheme.base05;
+ border_color_strong = valueOrDefault "border_color_strong" scheme.base0D;
+
+ tint_amount = valueOrDefault "tint_amound" 0.10;
+ shade_amount = valueOrDefault "shade_amount" 0.05;
+
+ border_radius = valueOrDefault "border_radius" 10;
+
+ padding_xs = valueOrDefault "padding_xs" 4.0;
+ padding_sm = valueOrDefault "padding_sm" 8.0;
+ padding_md = valueOrDefault "padding_md" 12.0;
+ padding_lg = valueOrDefault "padding_lg" 16.0;
+ padding_xl = valueOrDefault "padding_xl" 24.0;
+ padding_xxl = valueOrDefault "padding_xxl" 32.0;
+
+ font_sm = valueOrDefault "font_sm" 10.0;
+ font_md = valueOrDefault "font_md" 14.0;
+ font_lg = valueOrDefault "font_lg" 18.0;
+ font_xl = valueOrDefault "font_xl" 24.0;
+ font_xxl = valueOrDefault "font_xxl" 32.0;
+
+ # legacy compatibility
+ name = scheme.scheme;
+ inherit (scheme) base00;
+ inherit (scheme) base01;
+ inherit (scheme) base02;
+ inherit (scheme) base03;
+ inherit (scheme) base04;
+ inherit (scheme) base05;
+ inherit (scheme) base06;
+ inherit (scheme) base07;
+ inherit (scheme) base08;
+ inherit (scheme) base09;
+ base0a = scheme.base0A;
+ base0b = scheme.base0B;
+ base0c = scheme.base0C;
+ base0d = scheme.base0D;
+ base0e = scheme.base0E;
+ base0f = scheme.base0F;
+ };
+ };
+}
diff --git a/home/themes/qt.nix b/home/themes/qt.nix
new file mode 100644
index 0000000..21dc324
--- /dev/null
+++ b/home/themes/qt.nix
@@ -0,0 +1,124 @@
+{
+ config,
+ inputs,
+ pkgs,
+ lib,
+ ...
+}: let
+ username = config.conf.username;
+ # at time of using this here, stylix might not be evaluated yet
+ # hence ensure it is by using base16 mkSchemeAttrs
+ base16 = pkgs.callPackage inputs.base16.lib {};
+ scheme = base16.mkSchemeAttrs config.stylix.base16Scheme;
+ # active_colors=#ffc0caf5, #${scheme.base00}, #ff373949, #ff2b2c3b, #ff1a1b26, #ff2b2c3b, #ffc0caf5, #ffc0caf5, #ffc0caf5, #ff1a1b26, #ff1a1b26, #19000000, #ff2b2c3b, #ffc0caf5, #ff3584e4, #ff1b6acb, #ff1a1b26, #ff242530, #ff1a1b26, #ffc0caf5, #ffc0caf5
+ # disabled_colors=#ff6d728d, #${scheme.base00}, #ff373949, #ff2b2c3b, #ff1a1b26, #ff2b2c3b, #ff6d728d, #ff6d728d, #ff6d728d, #ff1a1b26, #ff1a1b26, #19000000, #ff2b2c3b, #ff6d728d, #ff3584e4, #ff1b6acb, #ff1a1b26, #ff242530, #ff1a1b26, #ff6d728d, #ff6d728d
+ # inactive_colors=#ff6d728d, #${scheme.base00}, #ff373949, #ff2b2c3b, #ff1a1b26, #ff2b2c3b, #ff6d728d, #ff6d728d, #ff6d728d, #ff1a1b26, #ff1a1b26, #19000000, #ff2b2c3b, #ff6d728d, #ff3584e4, #ff1b6acb, #ff1a1b26, #ff242530, #ff1a1b26, #ff6d728d, #ff6d728d
+ color = ''
+
+
+ [ColorScheme]
+ active_colors=#ff${scheme.base05}, #ff${scheme.base01}, #ff${scheme.base01}, #ff${scheme.base01}, #ff${scheme.base00}, #ff${scheme.base00}, #ff${scheme.base05}, #ff${scheme.base04}, #ff${scheme.base05}, #ff${scheme.base00}, #ff${scheme.base00}, #00${scheme.base01}, #ff${scheme.base02}, #ff${scheme.base04}, #ff${scheme.base08}, #ff${scheme.base04}, #ff${scheme.base01}, #ff${scheme.base00}, #ff${scheme.base01}, #ff${scheme.base05}, #ff${scheme.base04}
+ disabled_colors=#ff${scheme.base05}, #ff${scheme.base01}, #ff${scheme.base01}, #ff${scheme.base01}, #ff${scheme.base00}, #ff${scheme.base00}, #ff${scheme.base05}, #ff${scheme.base04}, #ff${scheme.base05}, #ff${scheme.base00}, #ff${scheme.base00}, #00${scheme.base01}, #ff${scheme.base02}, #ff${scheme.base04}, #ff${scheme.base08}, #ff${scheme.base04}, #ff${scheme.base01}, #ff${scheme.base00}, #ff${scheme.base01}, #ff${scheme.base05}, #ff${scheme.base04}
+ inactive_colors=#ff${scheme.base05}, #ff${scheme.base01}, #ff${scheme.base01}, #ff${scheme.base01}, #ff${scheme.base00}, #ff${scheme.base00}, #ff${scheme.base05}, #ff${scheme.base04}, #ff${scheme.base05}, #ff${scheme.base00}, #ff${scheme.base00}, #00${scheme.base01}, #ff${scheme.base02}, #ff${scheme.base04}, #ff${scheme.base08}, #ff${scheme.base04}, #ff${scheme.base01}, #ff${scheme.base00}, #ff${scheme.base01}, #ff${scheme.base05}, #ff${scheme.base04}
+ '';
+ qss = ''
+
+ QTabBar::tab:selected {
+ color: palette(highlight);
+ }
+ QMenuBar, QMenu, QToolBar, QStatusBar, QFrame, QScrollBar {
+ border: none;
+ }
+ '';
+in {
+ stylix.targets.qt = {
+ enable = false;
+ };
+ qt = {
+ enable = true;
+ style.package = pkgs.kdePackages.breeze;
+ style.name = lib.mkForce "breeze-dark";
+ };
+
+ xdg.configFile = {
+ "qt5ct/colors/tokyonight.conf" = {
+ text = "${color}";
+ };
+ "qt6ct/colors/tokyonight.conf" = {
+ text = "${color}";
+ };
+ "qt5ct/qss/tab.qss" = {
+ text = "${qss}";
+ };
+ "qt5ct/qt5ct.conf" = {
+ text = ''
+
+ [Appearance]
+ color_scheme_path=/home/${username}/.config/qt5ct/colors/tokyonight.conf
+ custom_palette=true
+ icon_theme=MoreWaita
+ standard_dialogs=xdgdesktopportal
+ style=Breeze
+
+ [Fonts]
+ fixed="Noto Sans,12,-1,5,50,0,0,0,0,0"
+ general="Noto Sans,12,-1,5,50,0,0,0,0,0"
+
+ [Interface]
+ activate_item_on_single_click=2
+ buttonbox_layout=3
+ cursor_flash_time=1000
+ dialog_buttons_have_icons=0
+ double_click_interval=400
+ gui_effects=General, AnimateMenu, AnimateCombo, AnimateTooltip, AnimateToolBox
+ keyboard_scheme=4
+ menus_have_icons=true
+ show_shortcuts_in_context_menus=true
+ stylesheets=/home/${username}/.config/qt5ct/qss/tab.qss, /nix/store/5713p1pv913a6fsn8j7z6ndikcwikbcd-qt5ct-1.8/share/qt5ct/qss/fusion-fixes.qss, /nix/store/5713p1pv913a6fsn8j7z6ndikcwikbcd-qt5ct-1.8/share/qt5ct/qss/scrollbar-simple.qss, /nix/store/5713p1pv913a6fsn8j7z6ndikcwikbcd-qt5ct-1.8/share/qt5ct/qss/sliders-simple.qss, /nix/store/5713p1pv913a6fsn8j7z6ndikcwikbcd-qt5ct-1.8/share/qt5ct/qss/tooltip-simple.qss, /nix/store/5713p1pv913a6fsn8j7z6ndikcwikbcd-qt5ct-1.8/share/qt5ct/qss/traynotification-simple.qss
+ toolbutton_style=4
+ underline_shortcut=0
+ wheel_scroll_lines=3
+
+ [SettingsWindow]
+ geometry=@ByteArray(\x1\xd9\xd0\xcb\0\x3\0\0\0\0\n\0\0\0\0\0\0\0\rK\0\0\x5q\0\0\n\0\0\0\0\0\0\0\r[\0\0\x5\x7f\0\0\0\0\x2\0\0\0\rp\0\0\n\0\0\0\0\0\0\0\rK\0\0\x5q)
+
+ [Troubleshooting]
+ force_raster_widgets=1
+ ignored_applications=@Invalid()
+ '';
+ };
+ "qt6ct/qt6ct.conf" = {
+ text = ''
+
+ [Appearance]
+ color_scheme_path=/home/${username}/.config/qt6ct/colors/tokyonight.conf
+ custom_palette=true
+ standard_dialogs=xdgdesktopportal
+ style=Breeze
+
+ [Fonts]
+ fixed="DejaVu LGC Sans,12,-1,5,400,0,0,0,0,0,0,0,0,0,0,1"
+ general="DejaVu LGC Sans,12,-1,5,400,0,0,0,0,0,0,0,0,0,0,1"
+
+ [Interface]
+ activate_item_on_single_click=2
+ buttonbox_layout=3
+ cursor_flash_time=1000
+ dialog_buttons_have_icons=0
+ double_click_interval=400
+ gui_effects=General, AnimateMenu, AnimateCombo, AnimateTooltip, AnimateToolBox
+ keyboard_scheme=4
+ menus_have_icons=true
+ show_shortcuts_in_context_menus=true
+ stylesheets=@Invalid()
+ toolbutton_style=4
+ underline_shortcut=1
+ wheel_scroll_lines=3
+
+ [Troubleshooting]
+ force_raster_widgets=1
+ ignored_applications=@Invalid()
+ '';
+ };
+ };
+}
diff --git a/hypr_desktop/conf/autostart.conf b/hypr_desktop/conf/autostart.conf
deleted file mode 100644
index 8da8314..0000000
--- a/hypr_desktop/conf/autostart.conf
+++ /dev/null
@@ -1,9 +0,0 @@
-#autostart programs
-exec-once=hyprpaper
-exec-once=ironbar
-exec-once=firefox
-exec-once=streamdeck -n
-exec-once=copyq --start-server
-exec-once=/usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1
-exec-once=nextcloud --background
-exec-once=oxinoti
diff --git a/hypr_desktop/conf/env.conf b/hypr_desktop/conf/env.conf
deleted file mode 100644
index 092f811..0000000
--- a/hypr_desktop/conf/env.conf
+++ /dev/null
@@ -1,21 +0,0 @@
-#
-#fix the fucking portal
-exec-once=systemctl --user import-environment
-exec-once=dbus-update-activation-environment --systemd --all
-#
-
-env=GTK_CSD,0
-env=TERM,"kitty /bin/fish"
-env=XDG_CURRENT_DESKTOP=Hyprland
-env=XDG_SESSION_TYPE=wayland
-env=XDG_SESSION_DESKTOP=Hyprland
-env=QT_QPA_PLATFORM,wayland
-env=QT_WAYLAND_FORCE_DPI,96
-env=QT_AUTO_SCREEN_SCALE_FACTOR,0
-env=QT_WAYLAND_DISABLE_WINDOWDECORATION,1
-env=QT_SCALE_FACTOR,1
-# env=XCURSOR_SIZE,24
-env=PKG_CONFIG_PATH,/usr/local/lib/pkgconfig
-env=LD_LIBRARY_PATH,/usr/local/lib
-env=EDITOR,"neovide --novsync --nofork"
-
diff --git a/hypr_desktop/conf/general.conf b/hypr_desktop/conf/general.conf
deleted file mode 100644
index 19f6b32..0000000
--- a/hypr_desktop/conf/general.conf
+++ /dev/null
@@ -1,56 +0,0 @@
-
-input {
- kb_layout=diaeresis
- repeat_delay=200
- natural_scroll=false
- follow_mouse=1
- force_no_accel=true
- touchpad {
- natural_scroll=yes
- tap-to-click=yes
- }
-}
-
-general {
- sensitivity=1.0 # for mouse cursor
- gaps_in=3 3 3 3
- gaps_out=2 5 5 5
- border_size=3
- col.active_border=0xFFFF0000 0xFF00FF00 0xFF0000FF 45deg
- col.inactive_border=0x66333333
- apply_sens_to_raw=0 # whether to apply the sensitivity to raw input (e.g. used by games where you aim using your mouse)
-}
-
-decoration {
- rounding=4
-}
-
-animations {
- enabled=1
- animation=windowsMove,1,4,default
- animation=windows,1,7,default,popin 70%
- animation=border,1,10,default
- animation=fade,1,10,default
- animation=workspaces,1,6,default
-}
-
-dwindle {
- preserve_split=true
- pseudotile=0
- permanent_direction_override=false
-}
-
-gestures {
- workspace_swipe=yes
-}
-
-misc {
- vfr=true
- vrr = 1
- animate_manual_resizes=1
- enable_swallow=true
- disable_splash_rendering = true
- disable_hyprland_logo = true
- swallow_regex=^(.*)(kitty)(.*)$
- layers_hog_keyboard_focus=false
- }
diff --git a/hypr_desktop/conf/keybinds.conf b/hypr_desktop/conf/keybinds.conf
deleted file mode 100644
index 88168e2..0000000
--- a/hypr_desktop/conf/keybinds.conf
+++ /dev/null
@@ -1,98 +0,0 @@
-# binds
-bind=SUPER,S,exec,grim -g "$(slurp)" - | wl-copy
-bind=SUPERSHIFTALT,S,exec, grim -g "$(slurp)" $HOME/gits/ost-5semester/Screenshots/$(date +'%Y_%m_%d_%I_%M_%S.png') && (date +'%Y_%m_%d_%I_%M_%S.png') | wl-copy
-bind=SUPERSHIFT,S,exec,grim -g "$(slurp)" - | satty -f -
-bind=SUPERCONTROLSHIFT,S,exec,grim -c -g "0,0 3440x1440" - | wl-copy
-bind=SUPER,F,exec,firefox
-bind=SUPER,T,exec,kitty -1
-bind=SUPER,Q,killactive,
-bind=SUPERSHIFTALT,M,exit,
-bind=SUPER,E,exec,nautilus -w
-bind=SUPER,N,exec,neovide --novsync
-bind=SUPER,M,exec,oxidash
-bind=SUPER,V,togglefloating,
-bind=SUPER,B,fullscreen,
-bind=SUPER,R,exec,anyrun
-bind=SUPER,C,togglesplit
-bind=SUPER,G,exec,oxicalc
-bind=SUPERSHIFT,G,exec,gamelock
-bind=SUPERSHIFT,L,exec, playerctl -a pause & swaylock -c 000000 & systemctl suspend
-bind=,XF86AudioMute,exec,pactl $HOME/.config/scripts/audio_control.sh mute
-bind=,XF86AudioLowerVolume,exec, $HOME/.config/scripts/audio_control.sh sink -5%
-bind=,XF86AudioRaiseVolume,exec, $HOME/.config/scripts/audio_control.sh sink +5%
-bind=,XF86AudioPlay,exec, playerctl play-pause
-bind=,XF86AudioNext,exec, playerctl next
-bind=,XF86AudioPrev,exec, playerctl previous
-bind=,XF86MonBrightnessDown,exec, $HOME/.config/scripts/change-brightness brightness 10%-
-bind=,XF86MonBrightnessUp,exec, $HOME/.config/scripts/change-brightness brightness +10%
-bind=SUPER,D,exec,oxishut
-bind=SUPER,A,exec,copyq toggle
-bind=SUPERSHIFT,W,togglespecialworkspace
-# bind=SUPER,W,movetoworkspace,special
-
-
-binde=SUPER,J,movefocus,l
-binde=SUPER,semicolon,movefocus,r
-binde=SUPER,L,movefocus,u
-binde=SUPER,K,movefocus,d
-
-binde=SUPER,U,resizeactive,-20 0
-binde=SUPER,P,resizeactive,20 0
-binde=SUPER,O,resizeactive,0 -20
-binde=SUPER,I,resizeactive,0 20
-
-bind=SUPER,left,movewindow,l
-bind=SUPER,right,movewindow,r
-bind=SUPER,up,movewindow,u
-bind=SUPER,down,movewindow,d
-
-bind=SUPER,1,workspace,1
-bind=SUPER,2,workspace,2
-bind=SUPER,3,workspace,3
-bind=SUPER,4,workspace,4
-bind=SUPER,5,workspace,5
-bind=SUPER,6,workspace,6
-bind=SUPER,7,workspace,7
-bind=SUPER,8,workspace,8
-bind=SUPER,9,workspace,9
-bind=SUPER,0,workspace,10
-
-bind=SUPERSHIFT,1,movetoworkspace,1
-bind=SUPERSHIFT,2,movetoworkspace,2
-bind=SUPERSHIFT,3,movetoworkspace,3
-bind=SUPERSHIFT,4,movetoworkspace,4
-bind=SUPERSHIFT,5,movetoworkspace,5
-bind=SUPERSHIFT,6,movetoworkspace,6
-bind=SUPERSHIFT,7,movetoworkspace,7
-bind=SUPERSHIFT,8,movetoworkspace,8
-bind=SUPERSHIFT,9,movetoworkspace,9
-bind=SUPERSHIFT,0,movetoworkspace,10
-
-bind=SUPERSHIFTALT,1,movetoworkspacesilent,1
-bind=SUPERSHIFTALT,2,movetoworkspacesilent,2
-bind=SUPERSHIFTALT,3,movetoworkspacesilent,3
-bind=SUPERSHIFTALT,4,movetoworkspacesilent,4
-bind=SUPERSHIFTALT,5,movetoworkspacesilent,5
-bind=SUPERSHIFTALT,6,movetoworkspacesilent,6
-bind=SUPERSHIFTALT,7,movetoworkspacesilent,7
-bind=SUPERSHIFTALT,8,movetoworkspacesilent,8
-bind=SUPERSHIFTALT,9,movetoworkspacesilent,9
-bind=SUPERSHIFTALT,0,movetoworkspacesilent,10
-
-bind=SUPERALT,j,layoutmsg,preselect l
-bind=SUPERALT,k,layoutmsg,preselect d
-bind=SUPERALT,l,layoutmsg,preselect u
-bind=SUPERALT,semicolon,layoutmsg,preselect r
-bind=SUPERALT,h,layoutmsg,preselect n
-
-bindm=SUPER,mouse:272,movewindow
-bindm=SUPER,mouse:273,resizewindow
-
-#binds for debug testing
-# bind=SUPERALT,J,pass,^(wlroots)$
-# bind=SUPERALT,left,pass,^(wlroots)$
-# bind=SUPERALT,right,pass,^(wlroots)$
-# bind=SUPERALT,up,pass,^(wlroots)$
-# bind=SUPERALT,down,pass,^(wlroots)$
-# bind=CTRLALT,P,pass,^(parcellite)$
-
diff --git a/hypr_desktop/conf/monitor.conf b/hypr_desktop/conf/monitor.conf
deleted file mode 100644
index e46ea69..0000000
--- a/hypr_desktop/conf/monitor.conf
+++ /dev/null
@@ -1,22 +0,0 @@
-monitor=DP-3,2560x1440@165,-2560x0,1
-monitor=DP-1,3440x1440@180,0x0,1
-monitor=DP-2,1920x1200@60,3440x0,1
-monitor=DP-2,transform,1
-monitor=,highrr,auto,1
-
-workspace=DP-3,1
-workspace=DP-1,2
-workspace=DP-2,3
-
-workspace = 2,monitor:DP-1
-workspace = 4,monitor:DP-1
-workspace = 6,monitor:DP-1
-workspace = 8,monitor:DP-1
-workspace = 9,monitor:DP-1
-workspace = 10,monitor:DP-1
-
-workspace = 1,monitor:DP-3
-workspace = 5,monitor:DP-3
-workspace = 3,monitor:DP-2
-workspace = 7,monitor:DP-2
-
diff --git a/hypr_desktop/conf/plugins.conf b/hypr_desktop/conf/plugins.conf
deleted file mode 100644
index f863b04..0000000
--- a/hypr_desktop/conf/plugins.conf
+++ /dev/null
@@ -1,12 +0,0 @@
-plugin = $HOME/.config/hypr/plugins/libhycov.so
-
-plugin {
- hycov {
- overview_gappo = 30 #gas width from screem
- overview_gappi = 10 #gas width from clients
- hotarea_size = 0 #hotarea size in bottom left,10x10
- enable_hotarea = 0 # enable mouse cursor hotarea
- }
-}
-
-bind = SUPER,W,hycov:toggleoverview
diff --git a/hypr_desktop/conf/rules.conf b/hypr_desktop/conf/rules.conf
deleted file mode 100644
index 9e41b8f..0000000
--- a/hypr_desktop/conf/rules.conf
+++ /dev/null
@@ -1,15 +0,0 @@
-# window rules
-windowrule=tile,^(.*)(Spotify)(.*)$
-windowrule=float,^(.*)(OxiCalc)(.*)$
-windowrule=float,^(.*)(winecfg.exe)(.*)$
-windowrule=float,^(.*)(speed.exe)(.*)$
-windowrule=float,^(.*)(copyq)(.*)$
-# windowrule=center,^(.*)(gnome)(.*)$
-# windowrule=size 1200 800,^(org.gnome.NautilusPreviewer)$
-windowrule=center,^(.*)(swappy)(.*)$
-windowrule=float,title:^(.*)(Spirit)(.*)$
-windowrule=float,title:^(.*)(reset)(.*)$
-windowrule=workspace 10 silent,^(.*)(steam)(.*)$
-windowrule=workspace 9 silent,^(.*)(dota)(.*)$
-windowrule=workspace 9 silent,^(.*)(battlebits)(.*)$
-windowrule=workspace 9 silent,^(.*)(aoe)(.*)$
diff --git a/hypr_desktop/hyprgreet.conf b/hypr_desktop/hyprgreet.conf
deleted file mode 100644
index 3dc2214..0000000
--- a/hypr_desktop/hyprgreet.conf
+++ /dev/null
@@ -1,17 +0,0 @@
-exec-once=gsettings set org.gnome.desktop.interface gtk-theme 'adw-gtk3-dark'
-exec-once=gsettings set org.gnome.desktop.interface color-scheme 'prefer-dark'
-
-monitor=DP-1,3440x1440@180,0x0,1
-monitor=DP-2,disable
-monitor=DP-3,disable
-
-input {
- force_no_accel = true
-}
-
-misc {
- disable_splash_rendering = true
- disable_hyprland_logo = true
-}
-
-exec-once=regreet --config /home/dashie/.config/hypr/regreet.toml --style /home/dashie/.config/gtk-3.0/gtk.css; hyprctl dispatch exit
diff --git a/hypr_desktop/hyprland.conf b/hypr_desktop/hyprland.conf
deleted file mode 100644
index 7ee1b2c..0000000
--- a/hypr_desktop/hyprland.conf
+++ /dev/null
@@ -1,7 +0,0 @@
-source=/home/dashie/.config/hypr/conf/env.conf
-#source=/home/dashie/.config/hypr/conf/plugins.conf
-source=/home/dashie/.config/hypr/conf/monitor.conf
-source=/home/dashie/.config/hypr/conf/general.conf
-source=/home/dashie/.config/hypr/conf/rules.conf
-source=/home/dashie/.config/hypr/conf/keybinds.conf
-source=/home/dashie/.config/hypr/conf/autostart.conf
diff --git a/hypr_desktop/hyprlandd.conf b/hypr_desktop/hyprlandd.conf
deleted file mode 100644
index be972a5..0000000
--- a/hypr_desktop/hyprlandd.conf
+++ /dev/null
@@ -1,15 +0,0 @@
-bind=SUPERALT,T,exec,kitty
-
-bind=SUPERALT,left,movewindow,l
-bind=SUPERALT,right,movewindow,r
-bind=SUPERALT,up,movewindow,u
-bind=SUPERALT,down,movewindow,d
-bind=SUPERALT,J,fullscreen
-
-bindm=SUPER,mouse:272,movewindow
-bindm=SUPER,mouse:273,resizewindow
-binde=SUPER,O,resizeactive,-20 0
-binde=SUPER,P,resizeactive,20 0
-binde=SUPER,K,resizeactive,0 -20
-binde=SUPER,L,resizeactive,0 20
-
diff --git a/hypr_desktop/hyprpaper.conf b/hypr_desktop/hyprpaper.conf
deleted file mode 100644
index a3a340b..0000000
--- a/hypr_desktop/hyprpaper.conf
+++ /dev/null
@@ -1,8 +0,0 @@
-
-# wallpaper
-preload = /home/dashie/Pictures/backgrounds/tree_1200.jpg
-preload = /home/dashie/Pictures/backgrounds/pxfuel.jpg
-preload = /home/dashie/Pictures/backgrounds/pxfuel(3).jpg
-wallpaper = DP-2,/home/dashie/Pictures/backgrounds/tree_1200.jpg
-wallpaper = DP-1,/home/dashie/Pictures/backgrounds/pxfuel.jpg
-wallpaper = DP-3,/home/dashie/Pictures/backgrounds/pxfuel(3).jpg
diff --git a/hypr_desktop/plugins/libhycov.so b/hypr_desktop/plugins/libhycov.so
deleted file mode 100755
index a02ff32..0000000
Binary files a/hypr_desktop/plugins/libhycov.so and /dev/null differ
diff --git a/hypr_desktop/regreet.toml b/hypr_desktop/regreet.toml
deleted file mode 100644
index 8874886..0000000
--- a/hypr_desktop/regreet.toml
+++ /dev/null
@@ -1,17 +0,0 @@
-[background]
-# path = "/usr/share/backgrounds/greeter.jpg"
-fit = "Contain"
-
-[env]
-PATH = "/home/dashie/.config/:$HOME/.local/bin:/home/dashie/.cargo/bin:$PATH"
-QT_QPA_PLATFORMTHEME = "qt5ct"
-
-[GTK]
-application_prefer_dark_theme = true
-cursor_theme_name = "Adwaita"
-icon_theme_name = "Adwaita"
-theme_name = "adw-gtk3"
-
-[commands]
-reboot = ["systemctl", "reboot"]
-poweroff = ["systemctl", "poweroff"]
diff --git a/hypr_laptop/hyprdock.toml b/hypr_laptop/hyprdock.toml
deleted file mode 100644
index ba5bae2..0000000
--- a/hypr_laptop/hyprdock.toml
+++ /dev/null
@@ -1 +0,0 @@
-suspend_command = 'systemctl suspend'
diff --git a/hypr_laptop/hyprland.conf b/hypr_laptop/hyprland.conf
deleted file mode 100644
index 6e4c05f..0000000
--- a/hypr_laptop/hyprland.conf
+++ /dev/null
@@ -1,195 +0,0 @@
-#
-#fix the fucking portal
-exec-once=systemctl --user import-environment
-exec-once=dbus-update-activation-environment --all
-#
-
-env = PATH,/usr/bin/site_perl:/usr/bin/vendor_perl:/usr/bin/core_perl:$HOME/.local/bin:$HOME/.cargo/bin:$PATH
-
-monitor=eDP-1,1920x1080@144,0x0,1
-monitor=,highres,1920x0,1
-input {
- kb_file=/home/dashie/.config/keymap.xkb #us with dead_diaeresis on shift + ' to get ä ö ü
- repeat_delay=200
- repeat_rate=35
- natural_scroll=false
- follow_mouse=1
- force_no_accel=true
-
- touchpad {
- natural_scroll=yes
- tap-to-click=yes
- }
-}
-
-general {
- sensitivity=1.0 # for mouse cursor
-
- gaps_in=5
- gaps_out=10
- border_size=3
- col.active_border=0xFFFF0000 0xFF00FF00 0xFF0000FF 60deg
- col.inactive_border=0x66333333
-
- apply_sens_to_raw=0 # whether to apply the sensitivity to raw input (e.g. used by games where you aim using your mouse)
-
-}
-
-decoration {
- rounding=10
-}
-
-animations {
- enabled=1
- animation=windowsMove,1,5,default
- animation=windows,1,5,default
- animation=border,1,10,default
- animation=fade,1,10,default
- animation=workspaces,1,3,default
-}
-
-dwindle {
- preserve_split=true
- pseudotile=0 # enable pseudotiling on dwindle
-}
-
-gestures {
- workspace_swipe=yes
-}
-
-misc {
- vfr=true
- vrr=1
- animate_manual_resizes=true
- animate_mouse_windowdragging=false
- enable_swallow=true
- swallow_regex=^(.*)(kitty)(.*)$
- }
-
-# debug {
-# overlay=true
-# }
-
-#reserve place for bar
-#monitor=eDP-1,addreserved,45,0,0,0
-
-# example window rules
-# for windows named/classed as abc and xyz
-windowrule=opacity 80,^(.*)(dunst)(.*)$
-windowrule=float,^(.*)(OxiCalc)(.*)$
-windowrule=float,^(.*)(copyq)(.*)$
-windowrule=dimaround,^(.*)(onagre)(.*)$
-windowrule=noborder,^(.*)(onagre)(.*)$
-#windowrule=tile,xyz
-#windowrule=float,abc
-#windowrule=pseudo,abc
-#windowrule=monitor 0,xyz
-
-# example binds
-bind=SUPER,S,exec,grim -g "$(slurp)" - | wl-copy
-bind=SUPER,F,exec,firefox
-bind=SUPER,T,exec,kitty
-bind=SUPER,Q,killactive,
-bind=SUPERALTSHIFT,M,exit,
-bind=SUPERSHIFT,M,exec,oxidash --css /home/dashie/gits/OxiDash/style.css
-bind=SUPER,E,exec,nautilus --new-window
-bind=SUPER,V,togglefloating,
-# bind=SUPER,R,exec,rofi -show drun -theme tokyonight
-# bind=SUPERSHIFT,R,exec,rofi -show run -theme tokyonight
-bind=SUPER,R,exec,anyrun
-bind=SUPER,C,togglesplit
-bind=SUPER,B,fullscreen
-bind=SUPER,G,exec, oxicalc
-bind=SUPERSHIFT,equal,exec, hyprdock --gui
-bind=SUPERSHIFT,L,exec, playerctl --all-players -a pause & swaylock -c 000000 & systemctl suspend
-bind=,XF86AudioMute,exec, $HOME/.config/eww/scripts/toggle-mute
-bind=,XF86AudioLowerVolume,exec, $HOME/.config/eww/scripts/change-volume sink -5%
-bind=,XF86AudioRaiseVolume,exec, $HOME/.config/eww/scripts/change-volume sink +5%
-bind=,XF86AudioPlay,exec, playerctl --player=ncspot,firefox play-pause
-bind=,XF86AudioNext,exec, playerctl --player=ncspot,firefox next
-bind=,XF86AudioPrev,exec, playerctl --player=ncspot,firefox previous
-bind=,XF86MonBrightnessDown,exec, $HOME/.config/eww/scripts/change-brightness brightness 10%-
-bind=,XF86MonBrightnessUp,exec, $HOME/.config/eww/scripts/change-brightness brightness +10%
-bind=SUPERSHIFT,S,exec, grim -g "$(slurp)" - | swappy -f -
-bind=SUPERSHIFTALT,S,exec, grim -g "$(slurp)" $HOME/gits/ost-4semester/Screenshots/$(date +'%Y_%m_%d_%I_%M_%S.png') && (date +'%Y_%m_%d_%I_%M_%S.png') | wl-copy
-bind=SUPER,D,exec, oxishut --css /home/dashie/gits/OxiShut/style.css
-bind=,Print,exec, grim - | wl-copy
-bind=SUPER,A,exec,copyq toggle
-bind=SUPERSHIFT,Y,exec, $HOME/.config/eww/scripts/monitor.sh extend
-bind=SUPERSHIFT,H,exec, $HOME/.config/eww/scripts/monitor.sh mirror
-bind=SUPERSHIFT,P,exec,hyprpicker | wl-copy
-
-
-# bind=SUPERALT,H,pass,^(wlroots)$
-# bind=SUPERALT,left,pass,^(wlroots)$
-# bind=SUPERALT,right,pass,^(wlroots)$
-# bind=SUPERALT,up,pass,^(wlroots)$
-# bind=SUPERALT,down,pass,^(wlroots)$
-
-bind=SUPER,J,movefocus,l
-bind=SUPER,semicolon,movefocus,r
-bind=SUPER,L,movefocus,u
-bind=SUPER,K,movefocus,d
-
-binde=SUPER,U,resizeactive,-20 0
-binde=SUPER,P,resizeactive,20 0
-binde=SUPER,O,resizeactive,0 -20
-binde=SUPER,I,resizeactive,0 20
-
-bind=SUPER,left,movewindow,l
-bind=SUPER,right,movewindow,r
-bind=SUPER,up,movewindow,u
-bind=SUPER,down,movewindow,d
-
-# bind=SUPERALT,left,movecursortocorner,2
-# bind=SUPERALT,left,exec, hyprctl dispatch movewindow && hyprctl dispatch moveactive -1000 300 && sleep 0.5 && hyprctl dispatch togglefloating
-
-bind=SUPER,1,workspace,1
-bind=SUPER,2,workspace,2
-bind=SUPER,3,workspace,3
-bind=SUPER,4,workspace,4
-bind=SUPER,5,workspace,5
-bind=SUPER,6,workspace,6
-bind=SUPER,7,workspace,7
-bind=SUPER,8,workspace,8
-bind=SUPER,9,workspace,9
-bind=SUPER,0,workspace,10
-
-bind=SUPERSHIFT,1,movetoworkspace,1
-bind=SUPERSHIFT,2,movetoworkspace,2
-bind=SUPERSHIFT,3,movetoworkspace,3
-bind=SUPERSHIFT,4,movetoworkspace,4
-bind=SUPERSHIFT,5,movetoworkspace,5
-bind=SUPERSHIFT,6,movetoworkspace,6
-bind=SUPERSHIFT,7,movetoworkspace,7
-bind=SUPERSHIFT,8,movetoworkspace,8
-bind=SUPERSHIFT,9,movetoworkspace,9
-bind=SUPERSHIFT,0,movetoworkspace,10
-
-bind=SUPERSHIFTALT,1,movetoworkspacesilent,1
-bind=SUPERSHIFTALT,2,movetoworkspacesilent,2
-bind=SUPERSHIFTALT,3,movetoworkspacesilent,3
-bind=SUPERSHIFTALT,4,movetoworkspacesilent,4
-bind=SUPERSHIFTALT,5,movetoworkspacesilent,5
-bind=SUPERSHIFTALT,6,movetoworkspacesilent,6
-bind=SUPERSHIFTALT,7,movetoworkspacesilent,7
-bind=SUPERSHIFTALT,8,movetoworkspacesilent,8
-bind=SUPERSHIFTALT,9,movetoworkspacesilent,9
-bind=SUPERSHIFTALT,0,movetoworkspacesilent,10
-
-bind=SUPER,mouse_down,workspace,e+1
-bind=SUPER,mouse_up,workspace,e-1
-bindm=SUPER,mouse:272,movewindow
-bindm=SUPER,mouse:273,resizewindow
-
-#autostart programs
-exec-once=hyprpaper
-exec-once=nheko
-exec-once=firefox
-exec-once=nextcloud
-exec-once=kitty ncspot
-exec-once=oxinoti --css /home/dashie/gits/oxinoti/style.css
-exec-once = copyq --start-server
-exec-once = hyprdock server
-exec-once=/usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1
-exec-once=ironbar
diff --git a/hypr_laptop/hyprlandd.conf b/hypr_laptop/hyprlandd.conf
deleted file mode 100644
index 1bbaaa7..0000000
--- a/hypr_laptop/hyprlandd.conf
+++ /dev/null
@@ -1,128 +0,0 @@
-monitor=,1920x1080@144,0x0,1
-input {
- repeat_delay=200
- natural_scroll=false
- follow_mouse=1
- force_no_accel=true
-
- touchpad {
- natural_scroll=yes
- tap-to-click=yes
- }
-}
-
-general {
- sensitivity=1.0 # for mouse cursor
-
- gaps_in=5
- gaps_out=10
- border_size=3
- col.active_border=0x66ee1111
- col.inactive_border=0x66333333
-
- apply_sens_to_raw=0 # whether to apply the sensitivity to raw input (e.g. used by games where you aim using your mouse)
-
-}
-
-decoration {
- rounding=10
- blur=yes
- blur=1
- blur_size=3 # minimum 1
- blur_passes=1 # minimum 1
- blur_new_optimizations=true
-
- drop_shadow=false
-}
-
-animations {
- bezier=test,0.5,0.5,0.5,0.5
- enabled=1
- animation=windowsMove,1,1,default
- animation=windows,1,5,default
- animation=border,1,10,default
- animation=fade,1,10,default
- animation=workspaces,1,3,default
-}
-
-dwindle {
- preserve_split=true
- pseudotile=0 # enable pseudotiling on dwindle
-}
-
-gestures {
- workspace_swipe=yes
-}
-
-misc {
- animate_manual_resizes=true
- animate_mouse_windowdragging=true
- enable_swallow=true
- swallow_regex=^(.*)(Alacritty)(.*)$
- }
-
-# debug {
-# overlay=true
-# }
-
-#reserve place for bar
-#monitor=eDP-1,addreserved,45,0,0,0
-
-# example window rules
-# for windows named/classed as abc and xyz
-#windowrule=tile,xyz
-#windowrule=float,abc
-#windowrule=pseudo,abc
-#windowrule=monitor 0,xyz
-
-# example binds
-bind=SUPER,T,exec,alacritty
-bind=SUPER,Q,killactive,
-bind=SUPER,M,exit,
-bind=SUPER,V,togglefloating,
-bind=SUPER,C,togglesplit
-bind=SUPER,B,fullscreen
-bind=SUPER,H,exec,alacritty
-
-bind=SUPER,bracketleft,movefocus,l
-bind=SUPER,bracketright,movefocus,r
-bind=SUPER,semicolon,movefocus,u
-bind=SUPER,apostrophe,movefocus,d
-
-bind=SUPERALT,left,movewindow,l
-bind=SUPERALT,right,movewindow,r
-bind=SUPERALT,up,movewindow,u
-bind=SUPERALT,down,movewindow,d
-
-bind=SUPER,1,workspace,1
-bind=SUPER,2,workspace,2
-bind=SUPER,3,workspace,3
-bind=SUPER,4,workspace,4
-bind=SUPER,5,workspace,5
-bind=SUPER,6,workspace,6
-bind=SUPER,7,workspace,7
-bind=SUPER,8,workspace,8
-bind=SUPER,9,workspace,9
-bind=SUPER,0,workspace,10
-
-bind=SUPERSHIFT,1,movetoworkspace,1
-bind=SUPERSHIFT,2,movetoworkspace,2
-bind=SUPERSHIFT,3,movetoworkspace,3
-bind=SUPERSHIFT,4,movetoworkspace,4
-bind=SUPERSHIFT,5,movetoworkspace,5
-bind=SUPERSHIFT,6,movetoworkspace,6
-bind=SUPERSHIFT,7,movetoworkspace,7
-bind=SUPERSHIFT,8,movetoworkspace,8
-bind=SUPERSHIFT,9,movetoworkspace,9
-bind=SUPERSHIFT,0,movetoworkspace,10
-
-bind=SUPER,mouse_down,workspace,e+1
-bind=SUPER,mouse_up,workspace,e-1
-bindm=SUPER,mouse:272,movewindow
-bindm=SUPER,mouse:273,resizewindow
-
-binde=SUPER,O,resizeactive,-20 0
-binde=SUPER,P,resizeactive,20 0
-binde=SUPER,K,resizeactive,0 -20
-binde=SUPER,L,resizeactive,0 20
-
diff --git a/hypr_laptop/hyprload.toml b/hypr_laptop/hyprload.toml
deleted file mode 100644
index a934db7..0000000
--- a/hypr_laptop/hyprload.toml
+++ /dev/null
@@ -1,5 +0,0 @@
-plugins = [
- # ...
- "outfoxxed/hy3",
- # ...
-]
diff --git a/hypr_laptop/hyprpaper.conf b/hypr_laptop/hyprpaper.conf
deleted file mode 100644
index 199e59a..0000000
--- a/hypr_laptop/hyprpaper.conf
+++ /dev/null
@@ -1,5 +0,0 @@
-
-# wallpaper
-preload = /home/dashie/Pictures/backgrounds/arch-chan3-1920.png
-wallpaper = eDP-1,/home/dashie/Pictures/backgrounds/arch-chan3-1920.png
-ipc = off
diff --git a/hyprdock/monitor_configs/196440656454035672.json b/hyprdock/monitor_configs/196440656454035672.json
deleted file mode 100644
index d608e38..0000000
--- a/hyprdock/monitor_configs/196440656454035672.json
+++ /dev/null
@@ -1,79 +0,0 @@
-[{
- "id": 0,
- "name": "DP-1",
- "description": "ASUSTek COMPUTER INC XG349C (DP-1)",
- "make": "ASUSTek COMPUTER INC",
- "model": "XG349C",
- "serial": "",
- "width": 3440,
- "height": 1440,
- "refreshRate": 179.998993,
- "x": 2560,
- "y": 0,
- "activeWorkspace": {
- "id": 2,
- "name": "2"
- },
- "specialWorkspace": {
- "id": 0,
- "name": ""
- },
- "reserved": [0, 30, 0, 0],
- "scale": 1.00,
- "transform": 0,
- "focused": true,
- "dpmsStatus": true,
- "vrr": true
-},{
- "id": 1,
- "name": "DP-2",
- "description": "Lenovo Group Limited LEN LT2452pwC 0x33344B41 (DP-2)",
- "make": "Lenovo Group Limited",
- "model": "LEN LT2452pwC",
- "serial": "0x33344B41",
- "width": 1920,
- "height": 1200,
- "refreshRate": 59.950001,
- "x": 6000,
- "y": 0,
- "activeWorkspace": {
- "id": 3,
- "name": "3"
- },
- "specialWorkspace": {
- "id": 0,
- "name": ""
- },
- "reserved": [0, 0, 0, 0],
- "scale": 1.00,
- "transform": 1,
- "focused": false,
- "dpmsStatus": true,
- "vrr": false
-},{
- "id": 2,
- "name": "DP-3",
- "description": "ASUSTek COMPUTER INC ROG PG278QR #ASOWXFZDWU/d (DP-3)",
- "make": "ASUSTek COMPUTER INC",
- "model": "ROG PG278QR",
- "serial": "#ASOWXFZDWU/d",
- "width": 2560,
- "height": 1440,
- "refreshRate": 165.000000,
- "x": 0,
- "y": 0,
- "activeWorkspace": {
- "id": 1,
- "name": "1"
- },
- "specialWorkspace": {
- "id": 0,
- "name": ""
- },
- "reserved": [0, 0, 0, 0],
- "scale": 1.00,
- "transform": 0,
- "focused": false,
- "dpmsStatus": true,
- "vrr": false
-}]
diff --git a/ironbar/config.toml b/ironbar/config.toml
deleted file mode 100644
index b0423ae..0000000
--- a/ironbar/config.toml
+++ /dev/null
@@ -1,32 +0,0 @@
-[monitors.DP-1]
-end = [
- { type = "sys_info", format = [
- " {memory_percent}",
- ], interval.memory = 30, class = "memory-usage" },
- { type = "custom", bar = [
- { type = "button", class = "popup-button", label = "", on_click = "popup:toggle" },
- ], class = "popup-button-box", popup = [
- { type = "box", orientation = "vertical", class = "audio-box", widgets = [
- { type = "box", orientation = "horizontal", widgets = [
- { type = "button", class = "audio-button", label = "", on_click = "!/home/dashie/.config/eww/scripts/audio_control.sh bluetooth" },
- { type = "button", class = "audio-button", label = "", on_click = "!/home/dashie/.config/eww/scripts/audio_control.sh internal" },
- ], class = "audio-button-box" },
- { type = "label", label = "Output" },
- { type = "slider", class = "audio-slider", step = 1.0, length = 200, value = "pactl get-sink-volume @DEFAULT_SINK@ | awk -F'/' '{ print $2 }' | tr -d ' %'", on_change = "!pactl set-sink-volume @DEFAULT_SINK@ $0%" },
- { type = "label", label = "Input" },
- { type = "slider", class = "audio-slider", step = 1.0, length = 200, value = "pactl get-source-volume @DEFAULT_SOURCE@ | awk -F'/' '{ print $2 }' | tr -d ' %'", on_change = "!pactl set-source-volume @DEFAULT_SOURCE@ $0%" },
- ] },
- ] },
- { type = "custom", bar = [
- { type = "button", class = "popup-button", label = "", on_click = "!oxidash --css /home/dashie/gits/oxidash/style.css" },
- ], class = "popup-button-box" },
- { type = "clock", format = "%I:%M", format_popup = "%I:%M:%S", locale = "en_US" },
- { type = "tray" },
-]
-position = "top"
-height = 10
-anchor_to_edges = true
-start = [{ type = "workspaces", all_monitors = true }]
-center = [
- { type = "focused", show_icon = true, show_title = true, icon_size = 20, truncate = "end" },
-]
diff --git a/ironbar/style.css b/ironbar/style.css
deleted file mode 100644
index a7c244b..0000000
--- a/ironbar/style.css
+++ /dev/null
@@ -1,132 +0,0 @@
-@import url("/home/dashie/.config/gtk-3.0/gtk.css");
-
-* {
- color: #71bbe6;
- padding: 0px;
- margin: 0px;
-}
-
-.background {
- background-color: rgba(0, 0, 0, 0);
-}
-
-.workspaces {
- margin: 2px 0px 0px 5px;
- border-radius: 10px;
- /* background-color: #2b2c3b; */
- background-color: #1E1E2E;
- padding: 2px 5px 2px 5px;
-}
-
-.workspaces .item {
- margin: 0px 3px 0px 3px;
- font-size: 13px;
- border-radius: 100%;
- padding: 0px 2px 0px 3px;
- background-color: rgba(0, 0, 0, 0);
-}
-
-.workspaces .item:hover {
- background-color: #3e4152;
-}
-
-.workspaces .item.focused {
- background-color: #3e4152;
-}
-
-.audio-box {
- padding: 2em;
- background-color: #1E1E2E;
- border-radius: 5px;
-}
-
-.audio-slider {
- padding: 5px;
- margin: 5px;
-}
-
-.audio-button {
- padding: 5px 10px 5px 10px;
- margin: 0px 1em 20px 1em;
- border-radius: 100%;
- font-size: 17px;
-}
-
-.audio-button-box {
- padding: 0px 2.5em 0px 2.5em;
-}
-
-.focused {
- /* margin: 2px 0px 0px 0px; */
- padding: 0px 5px 0px 5px;
- /* background-color: 1a1b26; */
- background-color: #1E1E2E;
- font-size: 17px;
- border-radius: 10px;
-}
-
-#bar #end {
- margin: 0px 5px 0px 0px;
- padding: 0px 5px 0px 5px;
- background-color: #1E1E2E;
- border-radius: 10px;
-}
-
-.popup-button {
- padding: 0px 5px 0px 3px;
- margin: 0em 3px;
- border-radius: 100%;
- font-size: 13px;
- background-color: #1E1E2E;
-}
-
-.popup-button-box {
- padding: 2px 0px 2px 0px;
-}
-
-.clock {
- padding: 0px 5px 0px 5px;
- font-size: 17px;
- background-color: #1E1E2E;
-}
-
-.clock:hover {
- background-color: #3e4152;
-}
-
-.custom button {
- background-color: #1E1E2E;
-}
-
-.custom button:hover {
- background-color: #3e4152;
-}
-
-.memory-usage {
- font-size: 15px;
- margin: 0px 5px 0px 0px;
-}
-
-.memory-usage:hover {
- background-color: #3e4152;
-}
-
-.popup-clock {
- background-color: #1E1E2E;
- border-radius: 5px;
- padding: 2px 8px 10px 8px;
-}
-
-.popup-clock .calendar-clock {
- font-size: 2.5em;
- padding-bottom: 0.1em;
-}
-
-.popup-clock .calendar {
- border-radius: 5px;
- font-size: 1.05em;
-}
-
-.popup-clock .calendar:selected {
- background-color: #3e4152;
-}
diff --git a/iso/configuration.nix b/iso/configuration.nix
new file mode 100644
index 0000000..9272a65
--- /dev/null
+++ b/iso/configuration.nix
@@ -0,0 +1,86 @@
+{
+ pkgs,
+ modulesPath,
+ lib,
+ self,
+ inputs,
+ ...
+}: let
+ system = "x86_64-linux";
+in {
+ imports = ["${modulesPath}/installer/cd-dvd/iso-image.nix"];
+ nixpkgs.hostPlatform = {
+ inherit system;
+ };
+
+ environment.systemPackages = with pkgs; [
+ inputs.dashvim.packages.${system}.minimal
+ disko
+ git
+ firefox
+ kitty
+ gnome-disk-utility
+ inputs.disko.packages.${system}.disko-install
+ ];
+
+ networking = {
+ wireless.enable = false;
+ networkmanager.enable = true;
+ };
+
+ nix.settings.experimental-features = [
+ "nix-command"
+ "flakes"
+ "pipe-operators"
+ ];
+
+ users.users.nixos = {
+ isNormalUser = true;
+ password = "nixos";
+ extraGroups = ["wheel"];
+ };
+
+ image.baseName = lib.mkForce "DashNix";
+
+ programs = {
+ hyprland = {
+ enable = true;
+ withUWSM = true;
+ xwayland.enable = false;
+ };
+ uwsm.enable = true;
+ };
+
+ fonts.packages = [pkgs.adwaita-fonts];
+ i18n.defaultLocale = "en_US.UTF-8";
+
+ services = {
+ displayManager.autoLogin = {
+ enable = true;
+ user = "nixos";
+ };
+ greetd = {
+ enable = true;
+ settings = {
+ terminal.vt = 1;
+ default_session = {
+ command = "${lib.getExe pkgs.hyprland}";
+ user = "nixos";
+ };
+ };
+ };
+ };
+
+ isoImage = {
+ makeEfiBootable = true;
+ makeUsbBootable = true;
+ contents = [
+ {
+ source = "${self}/example";
+ target = "example-config";
+ }
+ ];
+ };
+
+ system.stateVersion = "25.11";
+}
diff --git a/kanata.kbd b/kanata.kbd
deleted file mode 100644
index 51dcbe6..0000000
--- a/kanata.kbd
+++ /dev/null
@@ -1,37 +0,0 @@
-(deflocalkeys-linux
- ü 186
- ö 192
- ´ 221
- ä 226
-)
-
-(defalias
- umalt (layer-while-held umlaut)
-)
-
-(defsrc
- esc f1 f2 f3 f4 f5 f6 f7 f8 f9 f10 f11 f12 ins del
- grv 1 2 3 4 5 6 7 8 9 0 - = bspc
- tab q w e r t y u i o p [ ] \
- caps a s d f g h j k l ; ' ret
- lsft z x c v b n m , . / rsft up
- lctl lmet lalt spc ralt rmet rctl left down rght
-)
-
-(deflayer default
- esc f1 f2 f3 f4 f5 f6 f7 f8 f9 f10 f11 f12 ins del
- grv 1 2 3 4 5 6 7 8 9 0 - = bspc
- tab q w e r t y u i o p [ ] \
- caps a s d f g h j k l ; ' ret
- lsft z x c v b n m , . / rsft up
- lctl lmet lalt spc @umalt rmet rctl left down rght
-)
-
-(deflayer umlaut
- esc f1 f2 f3 f4 f5 f6 f7 f8 f9 f10 f11 f12 ins del
- grv 1 2 3 4 5 6 7 8 9 0 - = bspc
- tab ä ö ü ` t y u i o p [ ] \
- caps a s d f g h j k l ; ' ret
- lsft z x c v b n m , . / rsft up
- lctl lmet lalt spc ralt rmet rctl left down rght
-)
diff --git a/keymap.xkb b/keymap.xkb
deleted file mode 100644
index d772778..0000000
--- a/keymap.xkb
+++ /dev/null
@@ -1,1581 +0,0 @@
-xkb_keymap {
-xkb_keycodes "(unnamed)" {
- minimum = 8;
- maximum = 255;
- = 9;
- = 10;
- = 11;
- = 12;
- = 13;
- = 14;
- = 15;
- = 16;
- = 17;
- = 18;
- = 19;
- = 20;
- = 21;
- = 22;
- = 23;
- = 24;
- = 25;
- = 26;
- = 27;
- = 28;
- = 29;
- = 30;
- = 31;
- = 32;
- = 33;
- = 34;
- = 35;
- = 36;
- = 37;
- = 38;
- = 39;
- = 40;
- = 41;
- = 42;
- = 43;
- = 44;
- = 45;
- = 46;
- = 47;
- = 48;
- = 49;
- = 50;
- = 51;
- = 52;
- = 53;
- = 54;
- = 55;
- = 56;
- = 57;
- = 58;
- = 59;
- = 60;
- = 61;
- = 62;
- = 63;
- = 64;
- = 65;
- = 66;
- = 67;
- = 68;
- = 69;
- = 70;
- = 71;
- = 72;
- = 73;
- = 74;
- = 75;
- = 76;
- = 77;
- = 78;
- = 79;
- = 80;
- = 81;
- = 82;
- = 83;
- = 84;
- = 85;
- = 86;
- = 87;
- = 88;
- = 89;
- = 90;
- = 91;
- = 92;
- = 94;
- = 95;
- = 96;
- = 97;
- = 98;
- = 99;
- = 100;
- = 101;
- = 102;
- = 103;
- = 104;
- = 105;
- = 106;
- = 107;
- = 108;
- = 109;
- = 110;
- = 111;
- = 112;
- = 113;
- = 114;
- = 115;
- = 116;
- = 117;
- = 118;
- = 119;
- = 120;
- = 121;
- = 122;
- = 123;
- = 124;
- = 125;
- = 126;
- = 127;
- = 128;
- = 129;
- = 130;
- = 131;
- = 132;
- = 133;
- = 134;
- = 135;
- = 136;
- = 137;
- = 138;
- = 139;
- = 140;
- = 141;
- = 142;
- = 143;
- = 144;
- = 145;
- = 146;
- = 147;
- = 148;
- = 149;
- = 150;
- = 151;
- = 152;
- = 153;
- = 154;
- = 155;
- = 156;
- = 157;
- = 158;
- = 159;
- = 160;
- = 161;
- = 162;
- = 163;
- = 164;
- = 165;
- = 166;
- = 167;
- = 168;
- = 169;
- = 170;
- = 171;
- = 172;
- = 173;
- = 174;
- = 175;
- = 176;
- = 177;
- = 178;
- = 179;
- = 180;
- = 181;
- = 182;
- = 183;
- = 184;
- = 185;
- = 186;
- = 187;
- = 188;
- = 189;
- = 190;
- = 191;
- = 192;
- = 193;
- = 194;
- = 195;
- = 196;
- = 197;
- = 198;
- = 199;
- = 200;
- = 201;
- = 202;
- = 203;
- = 204;
- = 205;
- = 206;
- = 207;
- = 208;
- = 209;
- = 210;
- = 211;
- = 212;
- = 213;
- = 214;
- = 215;
- = 216;
- = 217;
- = 218;
- = 219;
- = 220;
- = 221;
- = 222;
- = 223;
- = 224;
- = 225;
- = 226;
- = 227;
- = 228;
- = 229;
- = 230;
- = 231;
- = 232;
- = 233;
- = 234;
- = 235;
- = 236;
-