diff --git a/.github/workflows/docs.yaml b/.github/workflows/docs.yaml
deleted file mode 100644
index 06dc541..0000000
--- a/.github/workflows/docs.yaml
+++ /dev/null
@@ -1,34 +0,0 @@
-# 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
deleted file mode 100644
index e92ddfd..0000000
--- a/.github/workflows/pr.yaml
+++ /dev/null
@@ -1,35 +0,0 @@
-# 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
deleted file mode 100644
index 1984fb1..0000000
--- a/.github/workflows/release.yaml
+++ /dev/null
@@ -1,29 +0,0 @@
-# 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 f610716..3853240 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,3 +1,11 @@
-result/*
-result
-flake.lock
+/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
diff --git a/.zshrc b/.zshrc
new file mode 100644
index 0000000..6bb491d
--- /dev/null
+++ b/.zshrc
@@ -0,0 +1,162 @@
+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
deleted file mode 100644
index 7b6bec5..0000000
--- a/LICENSE
+++ /dev/null
@@ -1,841 +0,0 @@
- 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 120000
index 95cf2af..0000000
--- a/README.md
+++ /dev/null
@@ -1 +0,0 @@
-docs/src/README.md
\ No newline at end of file
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..13a1458
--- /dev/null
+++ b/README.md
@@ -0,0 +1,6 @@
+# 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/anyrun/config.ron b/anyrun/config.ron
new file mode 100644
index 0000000..9954bd4
--- /dev/null
+++ b/anyrun/config.ron
@@ -0,0 +1,35 @@
+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
new file mode 100755
index 0000000..956091d
Binary files /dev/null and b/anyrun/plugins/libanyrun_websearch.so differ
diff --git a/anyrun/plugins/libapplications.so b/anyrun/plugins/libapplications.so
new file mode 100755
index 0000000..3a7ab5e
Binary files /dev/null and b/anyrun/plugins/libapplications.so differ
diff --git a/anyrun/plugins/libkidex.so b/anyrun/plugins/libkidex.so
new file mode 100755
index 0000000..75aba92
Binary files /dev/null and b/anyrun/plugins/libkidex.so differ
diff --git a/anyrun/plugins/librink.so b/anyrun/plugins/librink.so
new file mode 100755
index 0000000..58de8f5
Binary files /dev/null and b/anyrun/plugins/librink.so differ
diff --git a/anyrun/plugins/libshell.so b/anyrun/plugins/libshell.so
new file mode 100755
index 0000000..e7341cb
Binary files /dev/null and b/anyrun/plugins/libshell.so differ
diff --git a/anyrun/plugins/libsymbols.so b/anyrun/plugins/libsymbols.so
new file mode 100755
index 0000000..e1630ea
Binary files /dev/null and b/anyrun/plugins/libsymbols.so differ
diff --git a/anyrun/plugins/libtranslate.so b/anyrun/plugins/libtranslate.so
new file mode 100755
index 0000000..232a238
Binary files /dev/null and b/anyrun/plugins/libtranslate.so differ
diff --git a/anyrun/style.css b/anyrun/style.css
new file mode 100644
index 0000000..43f7385
--- /dev/null
+++ b/anyrun/style.css
@@ -0,0 +1,47 @@
+
+#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
new file mode 100644
index 0000000..67dc035
--- /dev/null
+++ b/anyrun/websearch.ron
@@ -0,0 +1,6 @@
+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
deleted file mode 100644
index 7ca00e2..0000000
--- a/assets/logo.svg
+++ /dev/null
@@ -1,228 +0,0 @@
-
-
-
-
diff --git a/assets/logo2.png b/assets/logo2.png
deleted file mode 100644
index beeac55..0000000
Binary files a/assets/logo2.png and /dev/null differ
diff --git a/assets/logo2.svg b/assets/logo2.svg
deleted file mode 100644
index 08baa43..0000000
--- a/assets/logo2.svg
+++ /dev/null
@@ -1,238 +0,0 @@
-
-
-
-
diff --git a/assets/logo3.svg b/assets/logo3.svg
deleted file mode 100644
index 6076a01..0000000
--- a/assets/logo3.svg
+++ /dev/null
@@ -1,238 +0,0 @@
-
-
-
-
diff --git a/assets/rainbow.svg b/assets/rainbow.svg
deleted file mode 100644
index 9f59c7c..0000000
--- a/assets/rainbow.svg
+++ /dev/null
@@ -1,141 +0,0 @@
-
-
diff --git a/base/black.jpg b/base/black.jpg
deleted file mode 100644
index 730b0b6..0000000
Binary files a/base/black.jpg and /dev/null differ
diff --git a/base/common_hardware.nix b/base/common_hardware.nix
deleted file mode 100644
index 9f7ccf1..0000000
--- a/base/common_hardware.nix
+++ /dev/null
@@ -1,174 +0,0 @@
-{
- 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
deleted file mode 100644
index eafd8a5..0000000
--- a/base/default.nix
+++ /dev/null
@@ -1,7 +0,0 @@
-{
- imports = [
- ./env.nix
- ./xkb_layout.nix
- ./common_hardware.nix
- ];
-}
diff --git a/base/env.nix b/base/env.nix
deleted file mode 100644
index 0eaf068..0000000
--- a/base/env.nix
+++ /dev/null
@@ -1,24 +0,0 @@
-{
- 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
deleted file mode 100644
index b399693..0000000
--- a/base/xkb_layout.nix
+++ /dev/null
@@ -1,23 +0,0 @@
-{
- 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
new file mode 100644
index 0000000..6ae5aec
--- /dev/null
+++ b/copyq/copyq-bak.conf
@@ -0,0 +1,216 @@
+[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
new file mode 100644
index 0000000..ae62c0a
--- /dev/null
+++ b/copyq/copyq-commands.ini
@@ -0,0 +1,44 @@
+[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
new file mode 100644
index 0000000..ae62c0a
--- /dev/null
+++ b/copyq/copyq-commands.ini.bak
@@ -0,0 +1,44 @@
+[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
new file mode 100644
index 0000000..50b0ec1
--- /dev/null
+++ b/copyq/copyq-filter.ini
@@ -0,0 +1,2 @@
+[General]
+filter_history=@Invalid()
diff --git a/copyq/copyq.conf b/copyq/copyq.conf
new file mode 100644
index 0000000..40d0c85
--- /dev/null
+++ b/copyq/copyq.conf
@@ -0,0 +1,216 @@
+[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=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.pub b/copyq/copyq.pub
new file mode 100644
index 0000000..a32e7f1
Binary files /dev/null and b/copyq/copyq.pub differ
diff --git a/dashie.json b/dashie.json
new file mode 100644
index 0000000..7e3e561
--- /dev/null
+++ b/dashie.json
@@ -0,0 +1,491 @@
+{
+ "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
deleted file mode 100644
index 1fd8a1e..0000000
--- a/docs/default.nix
+++ /dev/null
@@ -1,61 +0,0 @@
-# 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
deleted file mode 100644
index 3658e00..0000000
--- a/docs/src/README.md
+++ /dev/null
@@ -1,329 +0,0 @@
-
-
-
-
-
-
-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/docs/src/coding.md b/docs/src/coding.md
deleted file mode 100644
index e69de29..0000000
diff --git a/docs/src/conf.md b/docs/src/conf.md
deleted file mode 100755
index aa51f0b..0000000
--- a/docs/src/conf.md
+++ /dev/null
@@ -1 +0,0 @@
-# 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
deleted file mode 100644
index 08baa43..0000000
--- a/docs/src/logo.svg
+++ /dev/null
@@ -1,238 +0,0 @@
-
-
-
-
diff --git a/docs/src/mods.md b/docs/src/mods.md
deleted file mode 100755
index df7fe4f..0000000
--- a/docs/src/mods.md
+++ /dev/null
@@ -1 +0,0 @@
-# This file handles configuration of individual modules.
diff --git a/environment.d/envvars.conf b/environment.d/envvars.conf
new file mode 100644
index 0000000..1c04120
--- /dev/null
+++ b/environment.d/envvars.conf
@@ -0,0 +1,9 @@
+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
deleted file mode 100644
index 01ec944..0000000
--- a/example/flake.nix
+++ /dev/null
@@ -1,51 +0,0 @@
-{
- 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
deleted file mode 100644
index dbe8cd0..0000000
--- a/example/hosts/example/configuration.nix
+++ /dev/null
@@ -1,68 +0,0 @@
-{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
deleted file mode 100644
index 855cafb..0000000
--- a/example/hosts/example/hardware.nix
+++ /dev/null
@@ -1,3 +0,0 @@
-{
- # this file adds custom NixOS configuration
-}
diff --git a/example/hosts/example/home.nix b/example/hosts/example/home.nix
deleted file mode 100644
index e011ea7..0000000
--- a/example/hosts/example/home.nix
+++ /dev/null
@@ -1,3 +0,0 @@
-{
- # this file adds custom home-manager configuration
-}
diff --git a/example/secrets/secrets.md b/example/secrets/secrets.md
deleted file mode 100644
index 86d99c6..0000000
--- a/example/secrets/secrets.md
+++ /dev/null
@@ -1,3 +0,0 @@
-# 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
deleted file mode 100644
index e69de29..0000000
diff --git a/fish/completions/tide.fish b/fish/completions/tide.fish
new file mode 100644
index 0000000..2d3784d
--- /dev/null
+++ b/fish/completions/tide.fish
@@ -0,0 +1,12 @@
+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
new file mode 100644
index 0000000..939f17c
--- /dev/null
+++ b/fish/conf.d/_tide_init.fish
@@ -0,0 +1,41 @@
+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
new file mode 100644
index 0000000..20c0c5b
--- /dev/null
+++ b/fish/config.fish
@@ -0,0 +1,140 @@
+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
new file mode 100644
index 0000000..b2d5f77
--- /dev/null
+++ b/fish/fish_plugins
@@ -0,0 +1 @@
+ilancosman/tide@v5
diff --git a/fish/functions/_tide_1_line_prompt.fish b/fish/functions/_tide_1_line_prompt.fish
new file mode 100644
index 0000000..5772223
--- /dev/null
+++ b/fish/functions/_tide_1_line_prompt.fish
@@ -0,0 +1,19 @@
+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
new file mode 100644
index 0000000..e9017af
--- /dev/null
+++ b/fish/functions/_tide_2_line_prompt.fish
@@ -0,0 +1,31 @@
+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
new file mode 100644
index 0000000..31e3850
--- /dev/null
+++ b/fish/functions/_tide_cache_variables.fish
@@ -0,0 +1,17 @@
+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
new file mode 100644
index 0000000..5d96053
--- /dev/null
+++ b/fish/functions/_tide_detect_os.fish
@@ -0,0 +1,75 @@
+# 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
new file mode 100644
index 0000000..29f2180
--- /dev/null
+++ b/fish/functions/_tide_find_and_remove.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..7cb6338
--- /dev/null
+++ b/fish/functions/_tide_item_aws.fish
@@ -0,0 +1,11 @@
+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
new file mode 100644
index 0000000..10bb324
--- /dev/null
+++ b/fish/functions/_tide_item_character.fish
@@ -0,0 +1,17 @@
+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
new file mode 100644
index 0000000..02d5fbd
--- /dev/null
+++ b/fish/functions/_tide_item_chruby.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..bc48bac
--- /dev/null
+++ b/fish/functions/_tide_item_cmd_duration.fish
@@ -0,0 +1,12 @@
+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
new file mode 100644
index 0000000..575c438
--- /dev/null
+++ b/fish/functions/_tide_item_context.fish
@@ -0,0 +1,15 @@
+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
new file mode 100644
index 0000000..cec9752
--- /dev/null
+++ b/fish/functions/_tide_item_crystal.fish
@@ -0,0 +1,4 @@
+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
new file mode 100644
index 0000000..4eec0bf
--- /dev/null
+++ b/fish/functions/_tide_item_docker.fish
@@ -0,0 +1,5 @@
+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
new file mode 100644
index 0000000..43d46cb
--- /dev/null
+++ b/fish/functions/_tide_item_git.fish
@@ -0,0 +1,67 @@
+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
new file mode 100644
index 0000000..7c5919f
--- /dev/null
+++ b/fish/functions/_tide_item_go.fish
@@ -0,0 +1,4 @@
+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
new file mode 100644
index 0000000..6105acc
--- /dev/null
+++ b/fish/functions/_tide_item_java.fish
@@ -0,0 +1,4 @@
+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
new file mode 100644
index 0000000..96cf902
--- /dev/null
+++ b/fish/functions/_tide_item_jobs.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..ab044b3
--- /dev/null
+++ b/fish/functions/_tide_item_kubectl.fish
@@ -0,0 +1,4 @@
+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
new file mode 100644
index 0000000..647f606
--- /dev/null
+++ b/fish/functions/_tide_item_nix_shell.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..0588051
--- /dev/null
+++ b/fish/functions/_tide_item_node.fish
@@ -0,0 +1,4 @@
+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
new file mode 100644
index 0000000..8a6208c
--- /dev/null
+++ b/fish/functions/_tide_item_os.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..abc104e
--- /dev/null
+++ b/fish/functions/_tide_item_php.fish
@@ -0,0 +1,4 @@
+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
new file mode 100644
index 0000000..4eb4684
--- /dev/null
+++ b/fish/functions/_tide_item_private_mode.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..2e71645
--- /dev/null
+++ b/fish/functions/_tide_item_rustc.fish
@@ -0,0 +1,4 @@
+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
new file mode 100644
index 0000000..95dd5ff
--- /dev/null
+++ b/fish/functions/_tide_item_shlvl.fish
@@ -0,0 +1,4 @@
+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
new file mode 100644
index 0000000..3a040fd
--- /dev/null
+++ b/fish/functions/_tide_item_status.fish
@@ -0,0 +1,15 @@
+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
new file mode 100644
index 0000000..8d99fb7
--- /dev/null
+++ b/fish/functions/_tide_item_terraform.fish
@@ -0,0 +1,6 @@
+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
new file mode 100644
index 0000000..b8522bc
--- /dev/null
+++ b/fish/functions/_tide_item_time.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..28975d3
--- /dev/null
+++ b/fish/functions/_tide_item_toolbox.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..582855d
--- /dev/null
+++ b/fish/functions/_tide_item_vi_mode.fish
@@ -0,0 +1,16 @@
+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
new file mode 100644
index 0000000..0f20cee
--- /dev/null
+++ b/fish/functions/_tide_item_virtual_env.fish
@@ -0,0 +1,11 @@
+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
new file mode 100644
index 0000000..9f31b04
--- /dev/null
+++ b/fish/functions/_tide_parent_dirs.fish
@@ -0,0 +1,7 @@
+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
new file mode 100644
index 0000000..db5c98b
--- /dev/null
+++ b/fish/functions/_tide_print_item.fish
@@ -0,0 +1,22 @@
+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
new file mode 100644
index 0000000..3bd53b0
--- /dev/null
+++ b/fish/functions/_tide_pwd.fish
@@ -0,0 +1,37 @@
+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
new file mode 100644
index 0000000..f1111cb
--- /dev/null
+++ b/fish/functions/_tide_remove_unusable_items.fish
@@ -0,0 +1,21 @@
+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
new file mode 100644
index 0000000..5f087c8
--- /dev/null
+++ b/fish/functions/_tide_sub_bug-report.fish
@@ -0,0 +1,73 @@
+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
new file mode 100644
index 0000000..cb87290
--- /dev/null
+++ b/fish/functions/_tide_sub_configure.fish
@@ -0,0 +1,95 @@
+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
new file mode 100644
index 0000000..f37cf7d
--- /dev/null
+++ b/fish/functions/fish_mode_prompt.fish
@@ -0,0 +1 @@
+# Disable default vi prompt
diff --git a/fish/functions/fish_prompt.fish b/fish/functions/fish_prompt.fish
new file mode 100644
index 0000000..3e820c4
--- /dev/null
+++ b/fish/functions/fish_prompt.fish
@@ -0,0 +1,90 @@
+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
new file mode 100644
index 0000000..78672b0
--- /dev/null
+++ b/fish/functions/nheko.fish
@@ -0,0 +1,4 @@
+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
new file mode 100644
index 0000000..1a58f40
--- /dev/null
+++ b/fish/functions/tide.fish
@@ -0,0 +1,27 @@
+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
new file mode 100644
index 0000000..f60a128
--- /dev/null
+++ b/fish/functions/tide/configure/choices/all/finish.fish
@@ -0,0 +1,33 @@
+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
new file mode 100644
index 0000000..e53bffa
--- /dev/null
+++ b/fish/functions/tide/configure/choices/all/icons.fish
@@ -0,0 +1,33 @@
+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
new file mode 100644
index 0000000..90b1a9d
--- /dev/null
+++ b/fish/functions/tide/configure/choices/all/prompt_colors.fish
@@ -0,0 +1,26 @@
+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
new file mode 100644
index 0000000..ae31ef3
--- /dev/null
+++ b/fish/functions/tide/configure/choices/all/prompt_connection.fish
@@ -0,0 +1,28 @@
+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
new file mode 100644
index 0000000..b8803b4
--- /dev/null
+++ b/fish/functions/tide/configure/choices/all/prompt_connection_andor_frame_color.fish
@@ -0,0 +1,36 @@
+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
new file mode 100644
index 0000000..a5bb98b
--- /dev/null
+++ b/fish/functions/tide/configure/choices/all/prompt_spacing.fish
@@ -0,0 +1,21 @@
+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
new file mode 100644
index 0000000..8cf1843
--- /dev/null
+++ b/fish/functions/tide/configure/choices/all/show_time.fish
@@ -0,0 +1,31 @@
+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
new file mode 100644
index 0000000..ae52bc5
--- /dev/null
+++ b/fish/functions/tide/configure/choices/all/style.fish
@@ -0,0 +1,57 @@
+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
new file mode 100644
index 0000000..2189f36
--- /dev/null
+++ b/fish/functions/tide/configure/choices/classic/classic_prompt_color.fish
@@ -0,0 +1,38 @@
+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
new file mode 100644
index 0000000..17b88e4
--- /dev/null
+++ b/fish/functions/tide/configure/choices/classic/classic_prompt_separators.fish
@@ -0,0 +1,40 @@
+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
new file mode 100644
index 0000000..4db04a8
--- /dev/null
+++ b/fish/functions/tide/configure/choices/lean/lean_prompt_height.fish
@@ -0,0 +1,26 @@
+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
new file mode 100644
index 0000000..19b3588
--- /dev/null
+++ b/fish/functions/tide/configure/choices/powerline/powerline_prompt_frame.fish
@@ -0,0 +1,46 @@
+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
new file mode 100644
index 0000000..ac187c9
--- /dev/null
+++ b/fish/functions/tide/configure/choices/powerline/powerline_prompt_heads.fish
@@ -0,0 +1,40 @@
+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
new file mode 100644
index 0000000..83fef05
--- /dev/null
+++ b/fish/functions/tide/configure/choices/powerline/powerline_prompt_height.fish
@@ -0,0 +1,30 @@
+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
new file mode 100644
index 0000000..02f4609
--- /dev/null
+++ b/fish/functions/tide/configure/choices/powerline/powerline_prompt_tails.fish
@@ -0,0 +1,48 @@
+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
new file mode 100644
index 0000000..29f6ccc
--- /dev/null
+++ b/fish/functions/tide/configure/choices/rainbow/rainbow_prompt_separators.fish
@@ -0,0 +1,40 @@
+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
new file mode 100644
index 0000000..9b23f37
--- /dev/null
+++ b/fish/functions/tide/configure/configs/classic.fish
@@ -0,0 +1,133 @@
+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
new file mode 100644
index 0000000..acdc411
--- /dev/null
+++ b/fish/functions/tide/configure/configs/classic_16color.fish
@@ -0,0 +1,75 @@
+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
new file mode 100644
index 0000000..2565e0a
--- /dev/null
+++ b/fish/functions/tide/configure/configs/lean.fish
@@ -0,0 +1,133 @@
+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
new file mode 100644
index 0000000..49a8606
--- /dev/null
+++ b/fish/functions/tide/configure/configs/lean_16color.fish
@@ -0,0 +1,75 @@
+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
new file mode 100644
index 0000000..39ce7bb
--- /dev/null
+++ b/fish/functions/tide/configure/configs/rainbow.fish
@@ -0,0 +1,133 @@
+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
new file mode 100644
index 0000000..c102e2f
--- /dev/null
+++ b/fish/functions/tide/configure/configs/rainbow_16color.fish
@@ -0,0 +1,79 @@
+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
new file mode 100644
index 0000000..4661ab1
--- /dev/null
+++ b/fish/functions/tide/configure/functions/_fake_tide_cache_variables.fish
@@ -0,0 +1,41 @@
+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
new file mode 100644
index 0000000..73ae055
--- /dev/null
+++ b/fish/functions/tide/configure/functions/_fake_tide_item_character.fish
@@ -0,0 +1,5 @@
+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
new file mode 100644
index 0000000..5aa13b2
--- /dev/null
+++ b/fish/functions/tide/configure/functions/_fake_tide_item_cmd_duration.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..fb5b957
--- /dev/null
+++ b/fish/functions/tide/configure/functions/_fake_tide_item_git.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..c614bab
--- /dev/null
+++ b/fish/functions/tide/configure/functions/_fake_tide_item_newline.fish
@@ -0,0 +1,5 @@
+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
new file mode 100644
index 0000000..5255721
--- /dev/null
+++ b/fish/functions/tide/configure/functions/_fake_tide_item_os.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..bbce0b5
--- /dev/null
+++ b/fish/functions/tide/configure/functions/_fake_tide_item_time.fish
@@ -0,0 +1,3 @@
+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
new file mode 100644
index 0000000..30cd024
--- /dev/null
+++ b/fish/functions/tide/configure/functions/_fake_tide_print_item.fish
@@ -0,0 +1,22 @@
+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
new file mode 100644
index 0000000..11f20ca
--- /dev/null
+++ b/fish/functions/tide/configure/functions/_fake_tide_prompt.fish
@@ -0,0 +1,42 @@
+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
new file mode 100644
index 0000000..433eafa
--- /dev/null
+++ b/fish/functions/tide/configure/functions/_fake_tide_pwd.fish
@@ -0,0 +1,11 @@
+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
new file mode 100644
index 0000000..2c33869
--- /dev/null
+++ b/fish/themes/tokyonight_night.theme
@@ -0,0 +1,25 @@
+
+ # 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
new file mode 100644
index 0000000..f79979f
--- /dev/null
+++ b/fish/tokyonight_night.fish
@@ -0,0 +1,34 @@
+ # 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
deleted file mode 100644
index be1d5c2..0000000
--- a/flake.nix
+++ /dev/null
@@ -1,113 +0,0 @@
-{
- 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
new file mode 100644
index 0000000..b22732e
--- /dev/null
+++ b/fontconfig/fonts.conf
@@ -0,0 +1,27 @@
+
+
+
+
+
+ true
+
+
+ true
+
+
+ hintnone
+
+
+ none
+
+
+ true
+
+
+ lcdnone
+
+
+ 102
+
+
+
diff --git a/gtk-3.0/bookmarks b/gtk-3.0/bookmarks
new file mode 100644
index 0000000..0ea417d
--- /dev/null
+++ b/gtk-3.0/bookmarks
@@ -0,0 +1,14 @@
+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
new file mode 100644
index 0000000..1aa5d77
--- /dev/null
+++ b/gtk-3.0/gtk.css
@@ -0,0 +1,96 @@
+/*
+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
new file mode 100644
index 0000000..1f6ab50
--- /dev/null
+++ b/gtk-3.0/gtk.css.bak
@@ -0,0 +1,96 @@
+/*
+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
new file mode 100644
index 0000000..3d750d1
--- /dev/null
+++ b/gtk-4.0/gtk.css
@@ -0,0 +1,104 @@
+/*
+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
new file mode 100644
index 0000000..1f6ab50
--- /dev/null
+++ b/gtk-4.0/gtk.css.bak
@@ -0,0 +1,96 @@
+/*
+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
new file mode 100644
index 0000000..1205346
--- /dev/null
+++ b/gtk-4.0/servers
@@ -0,0 +1,25 @@
+
+
+
+ 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
new file mode 100644
index 0000000..d289a6a
--- /dev/null
+++ b/gtk-4.0/settings.ini
@@ -0,0 +1,3 @@
+[Settings]
+gtk-application-prefer-dark-theme=true
+gtk-hint-font-metrics=1
diff --git a/home/common.nix b/home/common.nix
deleted file mode 100644
index fe2fa53..0000000
--- a/home/common.nix
+++ /dev/null
@@ -1,42 +0,0 @@
-{
- 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
deleted file mode 100644
index afc0ab3..0000000
--- a/home/default.nix
+++ /dev/null
@@ -1,66 +0,0 @@
-{
- 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
deleted file mode 100644
index 38dceea..0000000
--- a/home/sync.nix
+++ /dev/null
@@ -1,55 +0,0 @@
-# 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
deleted file mode 100644
index 9976455..0000000
--- a/home/themes/default.nix
+++ /dev/null
@@ -1,8 +0,0 @@
-{
- imports = [
- ./qt.nix
- ./kdeglobals.nix
- ./oxiced.nix
- ./firefoxTheme.nix
- ];
-}
diff --git a/home/themes/firefoxTheme.nix b/home/themes/firefoxTheme.nix
deleted file mode 100644
index 0de46f6..0000000
--- a/home/themes/firefoxTheme.nix
+++ /dev/null
@@ -1,327 +0,0 @@
-# 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
deleted file mode 100644
index 8fa5003..0000000
--- a/home/themes/kdeglobals.nix
+++ /dev/null
@@ -1,252 +0,0 @@
-# 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
deleted file mode 100644
index 8a9e7dc..0000000
--- a/home/themes/oxiced.nix
+++ /dev/null
@@ -1,86 +0,0 @@
-{
- 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
deleted file mode 100644
index 21dc324..0000000
--- a/home/themes/qt.nix
+++ /dev/null
@@ -1,124 +0,0 @@
-{
- 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
new file mode 100644
index 0000000..8da8314
--- /dev/null
+++ b/hypr_desktop/conf/autostart.conf
@@ -0,0 +1,9 @@
+#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
new file mode 100644
index 0000000..092f811
--- /dev/null
+++ b/hypr_desktop/conf/env.conf
@@ -0,0 +1,21 @@
+#
+#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
new file mode 100644
index 0000000..19f6b32
--- /dev/null
+++ b/hypr_desktop/conf/general.conf
@@ -0,0 +1,56 @@
+
+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
new file mode 100644
index 0000000..5a1ce26
--- /dev/null
+++ b/hypr_desktop/conf/keybinds.conf
@@ -0,0 +1,99 @@
+# 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
+bind = SUPER,W,hycov:toggleoverview
+
+
+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
new file mode 100644
index 0000000..e46ea69
--- /dev/null
+++ b/hypr_desktop/conf/monitor.conf
@@ -0,0 +1,22 @@
+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
new file mode 100644
index 0000000..dd675c9
--- /dev/null
+++ b/hypr_desktop/conf/plugins.conf
@@ -0,0 +1,10 @@
+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
+ }
+}
diff --git a/hypr_desktop/conf/rules.conf b/hypr_desktop/conf/rules.conf
new file mode 100644
index 0000000..9e41b8f
--- /dev/null
+++ b/hypr_desktop/conf/rules.conf
@@ -0,0 +1,15 @@
+# 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
new file mode 100644
index 0000000..3dc2214
--- /dev/null
+++ b/hypr_desktop/hyprgreet.conf
@@ -0,0 +1,17 @@
+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
new file mode 100644
index 0000000..21697c3
--- /dev/null
+++ b/hypr_desktop/hyprland.conf
@@ -0,0 +1,7 @@
+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
new file mode 100644
index 0000000..be972a5
--- /dev/null
+++ b/hypr_desktop/hyprlandd.conf
@@ -0,0 +1,15 @@
+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
new file mode 100644
index 0000000..a3a340b
--- /dev/null
+++ b/hypr_desktop/hyprpaper.conf
@@ -0,0 +1,8 @@
+
+# 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
new file mode 100755
index 0000000..816c716
Binary files /dev/null and b/hypr_desktop/plugins/libhycov.so differ
diff --git a/hypr_desktop/regreet.toml b/hypr_desktop/regreet.toml
new file mode 100644
index 0000000..8874886
--- /dev/null
+++ b/hypr_desktop/regreet.toml
@@ -0,0 +1,17 @@
+[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
new file mode 100644
index 0000000..ba5bae2
--- /dev/null
+++ b/hypr_laptop/hyprdock.toml
@@ -0,0 +1 @@
+suspend_command = 'systemctl suspend'
diff --git a/hypr_laptop/hyprland.conf b/hypr_laptop/hyprland.conf
new file mode 100644
index 0000000..6e4c05f
--- /dev/null
+++ b/hypr_laptop/hyprland.conf
@@ -0,0 +1,195 @@
+#
+#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
new file mode 100644
index 0000000..1bbaaa7
--- /dev/null
+++ b/hypr_laptop/hyprlandd.conf
@@ -0,0 +1,128 @@
+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
new file mode 100644
index 0000000..a934db7
--- /dev/null
+++ b/hypr_laptop/hyprload.toml
@@ -0,0 +1,5 @@
+plugins = [
+ # ...
+ "outfoxxed/hy3",
+ # ...
+]
diff --git a/hypr_laptop/hyprpaper.conf b/hypr_laptop/hyprpaper.conf
new file mode 100644
index 0000000..199e59a
--- /dev/null
+++ b/hypr_laptop/hyprpaper.conf
@@ -0,0 +1,5 @@
+
+# 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/docs/src/SUMMARY.md b/hyprdock/hyprdock.toml
similarity index 100%
rename from docs/src/SUMMARY.md
rename to hyprdock/hyprdock.toml
diff --git a/hyprdock/monitor_configs/196440656454035672.json b/hyprdock/monitor_configs/196440656454035672.json
new file mode 100644
index 0000000..d608e38
--- /dev/null
+++ b/hyprdock/monitor_configs/196440656454035672.json
@@ -0,0 +1,79 @@
+[{
+ "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
new file mode 100644
index 0000000..b0423ae
--- /dev/null
+++ b/ironbar/config.toml
@@ -0,0 +1,32 @@
+[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
new file mode 100644
index 0000000..a7c244b
--- /dev/null
+++ b/ironbar/style.css
@@ -0,0 +1,132 @@
+@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
deleted file mode 100644
index 9272a65..0000000
--- a/iso/configuration.nix
+++ /dev/null
@@ -1,86 +0,0 @@
-{
- 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
new file mode 100644
index 0000000..51dcbe6
--- /dev/null
+++ b/kanata.kbd
@@ -0,0 +1,37 @@
+(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
new file mode 100644
index 0000000..d772778
--- /dev/null
+++ b/keymap.xkb
@@ -0,0 +1,1581 @@
+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;
+