Compare commits
1 commit
main
...
refactor-c
Author | SHA1 | Date | |
---|---|---|---|
3260b42b8b |
168 changed files with 1718 additions and 8634 deletions
3
.gitmodules
vendored
Normal file
3
.gitmodules
vendored
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
[submodule "dot_tmux/plugins/tpm"]
|
||||||
|
path = dot_tmux/plugins/external_tpm
|
||||||
|
url = https://github.com/tmux-plugins/tpm
|
696
LICENSE
696
LICENSE
|
@ -1,675 +1,21 @@
|
||||||
GNU GENERAL PUBLIC LICENSE
|
MIT License
|
||||||
Version 3, 29 June 2007
|
|
||||||
|
Copyright (c) 2024 Anthony Rodriguez
|
||||||
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
|
|
||||||
Everyone is permitted to copy and distribute verbatim copies
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this license document, but changing it is not allowed.
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
Preamble
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
The GNU General Public License is a free, copyleft license for
|
furnished to do so, subject to the following conditions:
|
||||||
software and other kinds of works.
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
The licenses for most software and other practical works are designed
|
copies or substantial portions of the Software.
|
||||||
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
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
share and change all versions of a program--to make sure it remains free
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
software for all its users. We, the Free Software Foundation, use the
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
GNU General Public License for most of our software; it applies also to
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
any other work released this way by its authors. You can apply it to
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
your programs, too.
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
||||||
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.
|
|
||||||
|
|
||||||
<one line to give the program's name and a brief idea of what it does.>
|
|
||||||
Copyright (C) <year> <name of author>
|
|
||||||
|
|
||||||
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 <https://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
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:
|
|
||||||
|
|
||||||
<program> Copyright (C) <year> <name of author>
|
|
||||||
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
|
|
||||||
<https://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
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
|
|
||||||
<https://www.gnu.org/licenses/why-not-lgpl.html>.
|
|
||||||
|
|
||||||
|
|
75
README.md
75
README.md
|
@ -1,38 +1,59 @@
|
||||||
<h1 id="header" align="center">
|
# My NixOS Flake
|
||||||
<img src="assets/nix-snowflake-colors.svg" width="128px" height="128px" />
|
|
||||||
<br>
|
|
||||||
flocon
|
|
||||||
</h1>
|
|
||||||
|
|
||||||
My NixOS configurations, using flakes.
|
This repository contains my personal NixOS configurations for two machines: my laptop (`vamos`) and my desktop computer (`solaire`). These configurations are managed using the Nix Flake system to ensure reproducibility and ease of deployment.
|
||||||
|
|
||||||
# 🛠️ Structure
|
## Structure
|
||||||
|
|
||||||
| Name | Description |
|
- `flake.nix`: The main entry point for the Nix flake.
|
||||||
| ------------------- | ---------------------------------------------------------------- |
|
- `hosts/`: Directory containing the specific configurations for each host (`vamos` and `solaire`).
|
||||||
| [assets](assets/) | Resources used throughout the system (images etc.) |
|
- `modules/`: Reusable NixOS modules shared between different configurations.
|
||||||
| [hosts](hosts/) | Host-specific |
|
- `home/`: Userspace configuration, divided between laptop and desktop.
|
||||||
| [modules](modules/) | Local module system (where the bulk of the configurations lives) |
|
|
||||||
| [shared](shared/) | Exported components (so far only packages) |
|
|
||||||
|
|
||||||
My configuration is structured based on the following principles:
|
## Hosts
|
||||||
|
|
||||||
1. Hosts should be the main entry points and outputs.
|
### Vamos (Laptop)
|
||||||
2. Abstractions should be avoided as much as possible.
|
|
||||||
3. Setting up theming should be as simple as changing one or two options.
|
|
||||||
|
|
||||||
The main configuration can be found in [modules](modules/), which declares most of my programs and services.
|
This is the configuration for my laptop, `vamos`. It uses Gnome, and includes settings optimized for power management, and lightweight applications.
|
||||||
|
|
||||||
My hosts can then pick and choose the programs and configurations that they need from the local module system, which have its options declared in [modules/options](modules/options/) for easy reference.
|
### Solaire (Desktop)
|
||||||
|
|
||||||
# 👥 Credits
|
This is the configuration for my desktop computer, `solaire`. It also uses Gnome, and adds Nvidia drivers.
|
||||||
|
|
||||||
People / repositories I have copied / learned from:
|
## Usage
|
||||||
|
|
||||||
- [fufexan/dotfiles](https://github.com/fufexan/dotfiles) for the configuration structure
|
### Applying the Configuration
|
||||||
- [jacekpoz/nixos](https://git.jacekpoz.pl/poz/niksos) for learning how NixOS modules work
|
|
||||||
- [sodiboo](https://github.com/sodiboo) for helping me a whole lot with Niri-specific issues
|
|
||||||
- [llakala](https://github.com/llakala) for being very thorough and helpful when cleaning up my code and general structure.
|
|
||||||
- [Lunarnovaa](https://github.com/Lunarnovaa) for her [hjem](https://github.com/feel-co/hjem) configuration and functions, that I used when switching away from home-manager.
|
|
||||||
|
|
||||||
Some bits have also been borrowed from within the configuration, and credit has been given where its due.
|
To apply the configuration on a machine, use the following steps:
|
||||||
|
|
||||||
|
1. Clone this repository:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git clone https://github.com/nezia1/dotfiles.git .dotfiles
|
||||||
|
cd .dotfiles
|
||||||
|
```
|
||||||
|
|
||||||
|
2. Switch to the desired configuration:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo nixos-rebuild switch --flake .#<hostname>
|
||||||
|
```
|
||||||
|
|
||||||
|
Replace `<hostname>` with either `vamos` or `solaire` depending on the machine you are configuring.
|
||||||
|
|
||||||
|
### Example
|
||||||
|
|
||||||
|
For the laptop (`vamos`):
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo nixos-rebuild switch --flake .#vamos
|
||||||
|
```
|
||||||
|
|
||||||
|
For the desktop (`solaire`):
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo nixos-rebuild switch --flake .#solaire
|
||||||
|
```
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
This repository is licensed under the MIT License. See the [LICENSE](LICENSE) file for details.
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 7.4 KiB |
|
@ -1,187 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
width="535"
|
|
||||||
height="535"
|
|
||||||
viewBox="0 0 501.56251 501.56249"
|
|
||||||
id="svg2"
|
|
||||||
version="1.1"
|
|
||||||
inkscape:version="1.3.2 (091e20ef0f, 2023-11-25)"
|
|
||||||
sodipodi:docname="nix-snowflake-colours.svg"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/">
|
|
||||||
<defs
|
|
||||||
id="defs4">
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient5562">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#699ad7;stop-opacity:1"
|
|
||||||
offset="0"
|
|
||||||
id="stop5564" />
|
|
||||||
<stop
|
|
||||||
id="stop5566"
|
|
||||||
offset="0.24345198"
|
|
||||||
style="stop-color:#7eb1dd;stop-opacity:1" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#7ebae4;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop5568" />
|
|
||||||
</linearGradient>
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient5053">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#415e9a;stop-opacity:1"
|
|
||||||
offset="0"
|
|
||||||
id="stop5055" />
|
|
||||||
<stop
|
|
||||||
id="stop5057"
|
|
||||||
offset="0.23168644"
|
|
||||||
style="stop-color:#4a6baf;stop-opacity:1" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#5277c3;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop5059" />
|
|
||||||
</linearGradient>
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
xlink:href="#linearGradient5562"
|
|
||||||
id="linearGradient4328"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
gradientTransform="translate(70.650339,-1055.1511)"
|
|
||||||
x1="200.59668"
|
|
||||||
y1="351.41116"
|
|
||||||
x2="290.08701"
|
|
||||||
y2="506.18814" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
xlink:href="#linearGradient5053"
|
|
||||||
id="linearGradient4330"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
gradientTransform="translate(864.69589,-1491.3405)"
|
|
||||||
x1="-584.19934"
|
|
||||||
y1="782.33563"
|
|
||||||
x2="-496.29703"
|
|
||||||
y2="937.71399" />
|
|
||||||
</defs>
|
|
||||||
<sodipodi:namedview
|
|
||||||
id="base"
|
|
||||||
pagecolor="#ffffff"
|
|
||||||
bordercolor="#666666"
|
|
||||||
borderopacity="1.0"
|
|
||||||
inkscape:pageopacity="0.0"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:zoom="0.70904368"
|
|
||||||
inkscape:cx="99.429699"
|
|
||||||
inkscape:cy="195.33352"
|
|
||||||
inkscape:document-units="px"
|
|
||||||
inkscape:current-layer="layer3"
|
|
||||||
showgrid="false"
|
|
||||||
inkscape:window-width="1920"
|
|
||||||
inkscape:window-height="1050"
|
|
||||||
inkscape:window-x="1920"
|
|
||||||
inkscape:window-y="30"
|
|
||||||
inkscape:window-maximized="1"
|
|
||||||
inkscape:snap-global="true"
|
|
||||||
fit-margin-top="0"
|
|
||||||
fit-margin-left="0"
|
|
||||||
fit-margin-right="0"
|
|
||||||
fit-margin-bottom="0"
|
|
||||||
inkscape:showpageshadow="2"
|
|
||||||
inkscape:pagecheckerboard="0"
|
|
||||||
inkscape:deskcolor="#d1d1d1" />
|
|
||||||
<metadata
|
|
||||||
id="metadata7">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<g
|
|
||||||
inkscape:groupmode="layer"
|
|
||||||
id="layer3"
|
|
||||||
inkscape:label="gradient-logo"
|
|
||||||
style="display:inline;opacity:1"
|
|
||||||
transform="translate(-156.41121,933.30685)">
|
|
||||||
<g
|
|
||||||
id="g2"
|
|
||||||
transform="matrix(0.99994059,0,0,0.99994059,-0.06321798,33.188377)"
|
|
||||||
style="stroke-width:1.00006">
|
|
||||||
<path
|
|
||||||
sodipodi:nodetypes="cccccccccc"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
id="path3336-6"
|
|
||||||
d="m 309.54892,-710.38827 122.19683,211.67512 -56.15706,0.5268 -32.6236,-56.8692 -32.85645,56.5653 -27.90237,-0.011 -14.29086,-24.6896 46.81047,-80.4901 -33.22946,-57.8257 z"
|
|
||||||
style="opacity:1;fill:url(#linearGradient4328);fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:3.00018;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
|
|
||||||
<use
|
|
||||||
height="100%"
|
|
||||||
width="100%"
|
|
||||||
transform="rotate(60,407.11155,-715.78724)"
|
|
||||||
id="use3439-6"
|
|
||||||
inkscape:transform-center-y="151.59082"
|
|
||||||
inkscape:transform-center-x="124.43045"
|
|
||||||
xlink:href="#path3336-6"
|
|
||||||
y="0"
|
|
||||||
x="0"
|
|
||||||
style="stroke-width:1.00006" />
|
|
||||||
<use
|
|
||||||
height="100%"
|
|
||||||
width="100%"
|
|
||||||
transform="rotate(-60,407.31177,-715.70016)"
|
|
||||||
id="use3445-0"
|
|
||||||
inkscape:transform-center-y="75.573958"
|
|
||||||
inkscape:transform-center-x="-168.20651"
|
|
||||||
xlink:href="#path3336-6"
|
|
||||||
y="0"
|
|
||||||
x="0"
|
|
||||||
style="stroke-width:1.00006" />
|
|
||||||
<use
|
|
||||||
height="100%"
|
|
||||||
width="100%"
|
|
||||||
transform="rotate(180,407.41868,-715.7565)"
|
|
||||||
id="use3449-5"
|
|
||||||
inkscape:transform-center-y="-139.94592"
|
|
||||||
inkscape:transform-center-x="59.669705"
|
|
||||||
xlink:href="#path3336-6"
|
|
||||||
y="0"
|
|
||||||
x="0"
|
|
||||||
style="stroke-width:1.00006" />
|
|
||||||
<path
|
|
||||||
style="color:#000000;clip-rule:nonzero;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;fill:url(#linearGradient4330);fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:3.00018;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto;enable-background:accumulate"
|
|
||||||
d="m 309.54892,-710.38827 122.19683,211.67512 -56.15706,0.5268 -32.6236,-56.8692 -32.85645,56.5653 -27.90237,-0.011 -14.29086,-24.6896 46.81047,-80.4901 -33.22946,-57.8256 z"
|
|
||||||
id="path4260-0"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="cccccccccc" />
|
|
||||||
<use
|
|
||||||
height="100%"
|
|
||||||
width="100%"
|
|
||||||
transform="rotate(120,407.33916,-716.08356)"
|
|
||||||
id="use4354-5"
|
|
||||||
xlink:href="#path4260-0"
|
|
||||||
y="0"
|
|
||||||
x="0"
|
|
||||||
style="display:inline;stroke-width:1.00006" />
|
|
||||||
<use
|
|
||||||
height="100%"
|
|
||||||
width="100%"
|
|
||||||
transform="rotate(-120,407.28823,-715.86995)"
|
|
||||||
id="use4362-2"
|
|
||||||
xlink:href="#path4260-0"
|
|
||||||
y="0"
|
|
||||||
x="0"
|
|
||||||
style="display:inline;stroke-width:1.00006" />
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 6.4 KiB |
Binary file not shown.
Before Width: | Height: | Size: 4.7 MiB |
3142
flake.lock
3142
flake.lock
File diff suppressed because it is too large
Load diff
136
flake.nix
136
flake.nix
|
@ -1,118 +1,66 @@
|
||||||
{
|
{
|
||||||
description = "nezia's nixos configuration";
|
description = "nezia's nixos configuration";
|
||||||
|
|
||||||
outputs = {
|
outputs = inputs:
|
||||||
self,
|
inputs.flake-parts.lib.mkFlake {inherit inputs;} {
|
||||||
nixpkgs,
|
systems = ["x86-64_linux"];
|
||||||
agenix,
|
|
||||||
deploy-rs,
|
|
||||||
treefmt-nix,
|
|
||||||
...
|
|
||||||
} @ inputs: let
|
|
||||||
supportedSystems = nixpkgs.lib.singleton "x86_64-linux";
|
|
||||||
|
|
||||||
forAllSystems = function:
|
imports = [
|
||||||
nixpkgs.lib.genAttrs
|
./hosts
|
||||||
supportedSystems
|
./modules
|
||||||
(system: function nixpkgs.legacyPackages.${system});
|
];
|
||||||
treefmtEval = forAllSystems (pkgs: treefmt-nix.lib.evalModule pkgs ./treefmt.nix);
|
|
||||||
in {
|
perSystem = {pkgs, ...}: {
|
||||||
devShells = forAllSystems (pkgs: {
|
devShells.default = pkgs.mkShell {
|
||||||
default = pkgs.mkShell {
|
|
||||||
packages = [
|
packages = [
|
||||||
pkgs.alejandra
|
pkgs.alejandra
|
||||||
pkgs.git
|
pkgs.git
|
||||||
deploy-rs.packages.${pkgs.system}.default
|
|
||||||
agenix.packages.${pkgs.system}.default
|
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
});
|
formatter = pkgs.alejandra;
|
||||||
formatter = forAllSystems (pkgs: treefmtEval.${pkgs.system}.config.build.wrapper);
|
|
||||||
nixosConfigurations = import ./hosts {inherit self inputs;};
|
|
||||||
packages = forAllSystems (pkgs: import ./shared/pkgs {inherit inputs pkgs;});
|
|
||||||
deploy.nodes = import ./nodes.nix {inherit inputs;};
|
|
||||||
checks = builtins.mapAttrs (_: deployLib: deployLib.deployChecks self.deploy) deploy-rs.lib;
|
|
||||||
};
|
};
|
||||||
|
};
|
||||||
|
|
||||||
inputs = {
|
inputs = {
|
||||||
# nix related
|
# global, so they can be `.follow`ed
|
||||||
nixpkgs.url = "nixpkgs/nixos-unstable";
|
systems.url = "github:nix-systems/default-linux";
|
||||||
nixos-hardware.url = "github:NixOS/nixos-hardware";
|
|
||||||
nix-index-db = {
|
flake-utils = {
|
||||||
url = "github:nix-community/nix-index-database";
|
url = "github:numtide/flake-utils";
|
||||||
|
inputs.systems.follows = "systems";
|
||||||
|
};
|
||||||
|
|
||||||
|
flake-parts = {
|
||||||
|
url = "github:hercules-ci/flake-parts";
|
||||||
|
inputs.nixpkgs-lib.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
|
||||||
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
||||||
|
|
||||||
|
home-manager = {
|
||||||
|
url = "github:nix-community/home-manager";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
|
|
||||||
# other
|
wezterm = {
|
||||||
agenix = {
|
url = "github:wez/wezterm/main?dir=nix";
|
||||||
url = "github:ryantm/agenix";
|
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
anyrun = {
|
|
||||||
url = "github:anyrun-org/anyrun";
|
nvf = {
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
url = "github:notashelf/nvf";
|
||||||
};
|
};
|
||||||
|
|
||||||
basix.url = "github:notashelf/basix";
|
basix.url = "github:notashelf/basix";
|
||||||
deploy-rs.url = "github:serokell/deploy-rs";
|
|
||||||
|
|
||||||
hyprland.url = "github:hyprwm/Hyprland";
|
plasma-manager = {
|
||||||
hyprland-qtutils = {
|
url = "github:nix-community/plasma-manager";
|
||||||
url = "github:hyprwm/hyprland-qtutils";
|
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
inputs.home-manager.follows = "home-manager";
|
||||||
};
|
};
|
||||||
hypridle = {
|
|
||||||
url = "github:hyprwm/hypridle";
|
|
||||||
inputs = {
|
|
||||||
hyprlang.follows = "hyprland/hyprlang";
|
|
||||||
hyprutils.follows = "hyprland/hyprutils";
|
|
||||||
nixpkgs.follows = "hyprland/nixpkgs";
|
|
||||||
systems.follows = "hyprland/systems";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
hyprlock = {
|
|
||||||
url = "github:hyprwm/hyprlock";
|
|
||||||
inputs = {
|
|
||||||
hyprlang.follows = "hyprland/hyprlang";
|
|
||||||
hyprutils.follows = "hyprland/hyprutils";
|
|
||||||
nixpkgs.follows = "hyprland/nixpkgs";
|
|
||||||
systems.follows = "hyprland/systems";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
hyprpaper = {
|
|
||||||
url = "github:hyprwm/hyprpaper";
|
|
||||||
inputs = {
|
|
||||||
hyprlang.follows = "hyprland/hyprlang";
|
|
||||||
hyprutils.follows = "hyprland/hyprutils";
|
|
||||||
nixpkgs.follows = "hyprland/nixpkgs";
|
|
||||||
systems.follows = "hyprland/systems";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
hyprwm-contrib = {
|
|
||||||
url = "github:hyprwm/contrib";
|
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
|
||||||
};
|
|
||||||
hjem = {
|
|
||||||
url = "github:feel-co/hjem";
|
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
|
||||||
};
|
|
||||||
nix-flatpak.url = "github:gmodena/nix-flatpak/?ref=v0.5.0";
|
|
||||||
nix-gaming.url = "github:fufexan/nix-gaming";
|
|
||||||
nvf.url = "github:notashelf/nvf";
|
|
||||||
treefmt-nix.url = "github:numtide/treefmt-nix";
|
treefmt-nix.url = "github:numtide/treefmt-nix";
|
||||||
nezia_dev.url = "github:nezia1/nezia.dev";
|
|
||||||
};
|
nixos-hardware.url = "github:NixOS/nixos-hardware";
|
||||||
nixConfig = {
|
|
||||||
extra-substituters = [
|
|
||||||
# use nixos cache first
|
|
||||||
"https://cache.nixos.org?priority=10"
|
|
||||||
"https://hyprland.cachix.org"
|
|
||||||
"https://nix-gaming.cachix.org"
|
|
||||||
"https://anyrun.cachix.org"
|
|
||||||
];
|
|
||||||
extra-trusted-public-keys = [
|
|
||||||
"cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY="
|
|
||||||
"hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="
|
|
||||||
"nix-gaming.cachix.org-1:nbjlureqMbRAxR1gJ/f3hxemL9svXaZF/Ees8vCUUs4="
|
|
||||||
"anyrun.cachix.org-1:pqBobmOjI7nKlsUMV25u9QHa9btJK65/C8vnO3p346s="
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
20
home/default.nix
Normal file
20
home/default.nix
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
{
|
||||||
|
lib,
|
||||||
|
self,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
imports = [
|
||||||
|
./terminal
|
||||||
|
self.nixosModules.theme
|
||||||
|
];
|
||||||
|
home = {
|
||||||
|
username = "nezia";
|
||||||
|
homeDirectory = "/home/nezia";
|
||||||
|
stateVersion = "24.05";
|
||||||
|
};
|
||||||
|
|
||||||
|
programs.home-manager.enable = true;
|
||||||
|
|
||||||
|
theme.wallpaper = lib.mkDefault ../wallpapers/nix-wallpaper-nineish-catppuccin-frappe-alt.svg;
|
||||||
|
theme.scheme = lib.mkDefault "catppuccin-frappe";
|
||||||
|
}
|
10
home/profiles/default.nix
Normal file
10
home/profiles/default.nix
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
{
|
||||||
|
vamos = [
|
||||||
|
../.
|
||||||
|
./vamos
|
||||||
|
];
|
||||||
|
solaire = [
|
||||||
|
../.
|
||||||
|
./solaire
|
||||||
|
];
|
||||||
|
}
|
14
home/profiles/solaire/default.nix
Normal file
14
home/profiles/solaire/default.nix
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
{config, ...}: {
|
||||||
|
imports = [
|
||||||
|
../../programs/editors/neovim.nix
|
||||||
|
|
||||||
|
../../programs
|
||||||
|
../../programs/games
|
||||||
|
|
||||||
|
../../services/udiskie.nix
|
||||||
|
|
||||||
|
../../terminal/emulators/gnome-terminal.nix
|
||||||
|
../../terminal/emulators/wezterm.nix
|
||||||
|
];
|
||||||
|
config.theme.wallpaper = ../../../wallpapers/lucy-edgerunners-wallpaper.jpg;
|
||||||
|
}
|
15
home/profiles/vamos/default.nix
Normal file
15
home/profiles/vamos/default.nix
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
{inputs, ...}: {
|
||||||
|
imports = [
|
||||||
|
../../programs/editors/neovim.nix
|
||||||
|
|
||||||
|
../../programs
|
||||||
|
../../programs/plasma
|
||||||
|
|
||||||
|
../../services/udiskie.nix
|
||||||
|
|
||||||
|
../../terminal/emulators/konsole.nix
|
||||||
|
../../terminal/emulators/wezterm.nix
|
||||||
|
|
||||||
|
inputs.plasma-manager.homeManagerModules.plasma-manager
|
||||||
|
];
|
||||||
|
}
|
4
home/programs/browsers.nix
Normal file
4
home/programs/browsers.nix
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
{pkgs, ...}: {
|
||||||
|
programs.chromium.enable = true;
|
||||||
|
home.packages = [pkgs.floorp];
|
||||||
|
}
|
17
home/programs/default.nix
Normal file
17
home/programs/default.nix
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
{pkgs, ...}: {
|
||||||
|
imports = [
|
||||||
|
./browsers.nix
|
||||||
|
];
|
||||||
|
|
||||||
|
programs.fzf.enable = true;
|
||||||
|
programs.fastfetch.enable = true;
|
||||||
|
home.packages = with pkgs; [
|
||||||
|
imhex
|
||||||
|
obsidian
|
||||||
|
proton-pass
|
||||||
|
spotify
|
||||||
|
vesktop
|
||||||
|
wl-clipboard
|
||||||
|
stremio
|
||||||
|
];
|
||||||
|
}
|
120
home/programs/editors/neovim.nix
Normal file
120
home/programs/editors/neovim.nix
Normal file
|
@ -0,0 +1,120 @@
|
||||||
|
{
|
||||||
|
inputs,
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
imports = [inputs.nvf.homeManagerModules.default];
|
||||||
|
|
||||||
|
programs.nvf = {
|
||||||
|
enable = true;
|
||||||
|
settings.vim = {
|
||||||
|
viAlias = true;
|
||||||
|
vimAlias = true;
|
||||||
|
enableLuaLoader = true;
|
||||||
|
preventJunkFiles = true;
|
||||||
|
tabWidth = 4;
|
||||||
|
autoIndent = false;
|
||||||
|
useSystemClipboard = true;
|
||||||
|
|
||||||
|
luaConfigPost = lib.concatStrings [
|
||||||
|
''
|
||||||
|
vim.opt.formatoptions:remove('c')
|
||||||
|
vim.opt.formatoptions:remove('r')
|
||||||
|
vim.opt.formatoptions:remove('o')
|
||||||
|
''
|
||||||
|
];
|
||||||
|
|
||||||
|
maps = {
|
||||||
|
normal = {
|
||||||
|
"<leader>m" = {
|
||||||
|
silent = true;
|
||||||
|
action = "<cmd>make<CR>";
|
||||||
|
}; # Same as nnoremap <leader>m <silent> <cmd>make<CR>
|
||||||
|
"<leader>t" = {
|
||||||
|
silent = true;
|
||||||
|
action = "<cmd>Neotree toggle<CR>";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
theme = {
|
||||||
|
enable = true;
|
||||||
|
name = "catppuccin";
|
||||||
|
style = "frappe";
|
||||||
|
};
|
||||||
|
|
||||||
|
visuals = {
|
||||||
|
enable = true;
|
||||||
|
nvimWebDevicons.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
ui = {
|
||||||
|
noice.enable = true;
|
||||||
|
};
|
||||||
|
notify.nvim-notify.enable = true;
|
||||||
|
|
||||||
|
statusline.lualine = {
|
||||||
|
enable = true;
|
||||||
|
theme = "catppuccin";
|
||||||
|
};
|
||||||
|
|
||||||
|
git.enable = true;
|
||||||
|
|
||||||
|
lsp = {
|
||||||
|
enable = true;
|
||||||
|
lspSignature.enable = true;
|
||||||
|
lspconfig.enable = true;
|
||||||
|
formatOnSave = true;
|
||||||
|
mappings = {
|
||||||
|
addWorkspaceFolder = "<leader>wa";
|
||||||
|
codeAction = "<leader>a";
|
||||||
|
goToDeclaration = "gD";
|
||||||
|
goToDefinition = "gd";
|
||||||
|
hover = "K";
|
||||||
|
listImplementations = "gi";
|
||||||
|
listReferences = "gr";
|
||||||
|
listWorkspaceFolders = "<leader>wl";
|
||||||
|
nextDiagnostic = "<leader>k";
|
||||||
|
previousDiagnostic = "<leader>j";
|
||||||
|
openDiagnosticFloat = "<leader>e";
|
||||||
|
removeWorkspaceFolder = "<leader>wr";
|
||||||
|
renameSymbol = "<leader>r";
|
||||||
|
signatureHelp = "<C-k>";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
autocomplete = {
|
||||||
|
enable = true;
|
||||||
|
alwaysComplete = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
autopairs.enable = true;
|
||||||
|
languages = {
|
||||||
|
enableExtraDiagnostics = true;
|
||||||
|
enableFormat = true;
|
||||||
|
enableLSP = true;
|
||||||
|
enableTreesitter = true;
|
||||||
|
|
||||||
|
nix.enable = true;
|
||||||
|
clang.enable = true;
|
||||||
|
python.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
treesitter = {
|
||||||
|
enable = true;
|
||||||
|
fold = true;
|
||||||
|
context.enable = true;
|
||||||
|
grammars = [
|
||||||
|
pkgs.vimPlugins.nvim-treesitter.builtGrammars.nix
|
||||||
|
pkgs.vimPlugins.nvim-treesitter.builtGrammars.c
|
||||||
|
pkgs.vimPlugins.nvim-treesitter.builtGrammars.python
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
binds.whichKey.enable = true;
|
||||||
|
filetree.neo-tree.enable = true;
|
||||||
|
|
||||||
|
telescope.enable = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
15
home/programs/games/default.nix
Normal file
15
home/programs/games/default.nix
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
{pkgs, ...}: {
|
||||||
|
home.packages = with pkgs; [
|
||||||
|
protonup-qt
|
||||||
|
bottles
|
||||||
|
lutris
|
||||||
|
path-of-building
|
||||||
|
r2modman
|
||||||
|
|
||||||
|
# steamtinkerlaunch dependencies
|
||||||
|
xdotool
|
||||||
|
xorg.xwininfo
|
||||||
|
yad
|
||||||
|
];
|
||||||
|
programs.mangohud.enable = true;
|
||||||
|
}
|
66
home/programs/gnome/default.nix
Normal file
66
home/programs/gnome/default.nix
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
{
|
||||||
|
pkgs,
|
||||||
|
config,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
dconf = {
|
||||||
|
enable = true;
|
||||||
|
settings = {
|
||||||
|
"org/gnome/shell" = {
|
||||||
|
disable-user-extensions = false; # enables user extensions
|
||||||
|
enabled-extensions = [
|
||||||
|
pkgs.gnomeExtensions.appindicator.extensionUuid
|
||||||
|
pkgs.gnomeExtensions.blur-my-shell.extensionUuid
|
||||||
|
pkgs.gnomeExtensions.emoji-copy.extensionUuid
|
||||||
|
pkgs.gnomeExtensions.clipboard-history.extensionUuid
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
"org/gnome/desktop/input-sources" = {
|
||||||
|
xkb-options = ["compose:ralt"];
|
||||||
|
};
|
||||||
|
|
||||||
|
"org/gnome/desktop/interface" = {
|
||||||
|
enable-hot-corners = false;
|
||||||
|
color-scheme = "prefer-dark";
|
||||||
|
};
|
||||||
|
"org/gnome/desktop/background" = {
|
||||||
|
picture-uri-dark = "file://" + builtins.toString config.theme.wallpaper;
|
||||||
|
};
|
||||||
|
|
||||||
|
"org/gnome/desktop/search-providers" = {
|
||||||
|
disabled = [
|
||||||
|
"org.gnome.Terminal.desktop"
|
||||||
|
"org.gnome.Software.desktop"
|
||||||
|
"org.gnome.seahorse.Application.desktop"
|
||||||
|
"org.gnome.clocks.desktop"
|
||||||
|
"org.gnome.Characters.desktop"
|
||||||
|
"org.gnome.Calendar.desktop"
|
||||||
|
"org.gnome.Calculator.desktop"
|
||||||
|
];
|
||||||
|
enabled = [
|
||||||
|
"org.gnome.Nautilus.desktop"
|
||||||
|
"org.gnome.Settings.desktop"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
"org/freedesktop/tracker/mine/files" = {
|
||||||
|
index-recursive-directories = [
|
||||||
|
"&DESKTOP"
|
||||||
|
"&DOCUMENTS"
|
||||||
|
"&MUSIC"
|
||||||
|
"&PICTURES"
|
||||||
|
"&VIDEOS"
|
||||||
|
"${config.home.homeDirectory}/Notes"
|
||||||
|
"${config.home.homeDirectory}/Projects"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
home.packages = with pkgs.gnomeExtensions; [
|
||||||
|
appindicator
|
||||||
|
blur-my-shell
|
||||||
|
clipboard-history
|
||||||
|
emoji-copy
|
||||||
|
];
|
||||||
|
}
|
33
home/programs/plasma/default.nix
Normal file
33
home/programs/plasma/default.nix
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
programs.plasma = {
|
||||||
|
enable = true;
|
||||||
|
workspace = {
|
||||||
|
lookAndFeel = "org.kde.breezedark.desktop";
|
||||||
|
inherit (config.theme) wallpaper;
|
||||||
|
};
|
||||||
|
|
||||||
|
input = {
|
||||||
|
touchpads = [
|
||||||
|
{
|
||||||
|
enable = true;
|
||||||
|
naturalScroll = true;
|
||||||
|
vendorId = "093a";
|
||||||
|
productId = "0274";
|
||||||
|
name = "PIXA3854:00 093A:0274 Touchpad";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
keyboard = {
|
||||||
|
options = [
|
||||||
|
"compose:ralt"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
home.packages = with pkgs; [
|
||||||
|
qalculate-qt
|
||||||
|
];
|
||||||
|
}
|
3
home/services/udiskie.nix
Normal file
3
home/services/udiskie.nix
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
_: {
|
||||||
|
services.udiskie.enable = true;
|
||||||
|
}
|
|
@ -1,6 +1,5 @@
|
||||||
_: {
|
{
|
||||||
imports = [
|
imports = [
|
||||||
./emulators
|
|
||||||
./programs
|
./programs
|
||||||
./shell
|
./shell
|
||||||
];
|
];
|
28
home/terminal/emulators/gnome-terminal.nix
Normal file
28
home/terminal/emulators/gnome-terminal.nix
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
inputs,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
programs.gnome-terminal = {
|
||||||
|
enable = true;
|
||||||
|
showMenubar = true;
|
||||||
|
profile = {
|
||||||
|
"4621184a-b921-42cf-80a0-7784516606f2" = {
|
||||||
|
default = true;
|
||||||
|
audibleBell = false;
|
||||||
|
allowBold = true;
|
||||||
|
boldIsBright = true;
|
||||||
|
visibleName = "default";
|
||||||
|
font = "Intel One Mono 14";
|
||||||
|
colors = let
|
||||||
|
inherit (inputs.basix.schemeData.base16.${config.theme.scheme}) palette;
|
||||||
|
in {
|
||||||
|
backgroundColor = "#${palette.base00}";
|
||||||
|
foregroundColor = builtins.trace "#${palette.base05}" "#${palette.base05}";
|
||||||
|
|
||||||
|
palette = builtins.attrValues (builtins.mapAttrs (_: color: "#${color}") palette);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
29
home/terminal/emulators/konsole.nix
Normal file
29
home/terminal/emulators/konsole.nix
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
{
|
||||||
|
lib,
|
||||||
|
config,
|
||||||
|
inputs,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
programs.konsole = {
|
||||||
|
enable = true;
|
||||||
|
defaultProfile = "default";
|
||||||
|
profiles = {
|
||||||
|
default = {
|
||||||
|
font = {
|
||||||
|
name = "monospace";
|
||||||
|
size = 14;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
extraConfig = {
|
||||||
|
"MainWindow" = {
|
||||||
|
"MenuBar" = "Disabled";
|
||||||
|
"ToolBarsMovable" = "Disabled";
|
||||||
|
};
|
||||||
|
"KonsoleWindow" = {
|
||||||
|
"ShowMenuBarByDefault" = "false";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
71
home/terminal/emulators/wezterm.nix
Normal file
71
home/terminal/emulators/wezterm.nix
Normal file
|
@ -0,0 +1,71 @@
|
||||||
|
_: {
|
||||||
|
programs.wezterm = {
|
||||||
|
enable = true;
|
||||||
|
# package = inputs.wezterm.packages.${pkgs.system}.default;
|
||||||
|
extraConfig = ''
|
||||||
|
local w = require('wezterm')
|
||||||
|
|
||||||
|
local function is_vim(pane)
|
||||||
|
return pane:get_user_vars().IS_NVIM == 'true'
|
||||||
|
end
|
||||||
|
|
||||||
|
local direction_keys = {
|
||||||
|
h = 'Left',
|
||||||
|
j = 'Down',
|
||||||
|
k = 'Up',
|
||||||
|
l = 'Right',
|
||||||
|
}
|
||||||
|
|
||||||
|
local function split_nav(resize_or_move, key)
|
||||||
|
return {
|
||||||
|
key = key,
|
||||||
|
mods = resize_or_move == 'resize' and 'META' or 'CTRL',
|
||||||
|
action = w.action_callback(function(win, pane)
|
||||||
|
if is_vim(pane) then
|
||||||
|
win:perform_action({
|
||||||
|
SendKey = { key = key, mods = resize_or_move == 'resize' and 'META' or 'CTRL' },
|
||||||
|
}, pane)
|
||||||
|
else
|
||||||
|
if resize_or_move == 'resize' then
|
||||||
|
win:perform_action({ AdjustPaneSize = { direction_keys[key], 3 } }, pane)
|
||||||
|
else
|
||||||
|
win:perform_action({ ActivatePaneDirection = direction_keys[key] }, pane)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end),
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
return {
|
||||||
|
enable_wayland = false,
|
||||||
|
front_end = "WebGpu",
|
||||||
|
hide_tab_bar_if_only_one_tab = true,
|
||||||
|
show_new_tab_button_in_tab_bar = false,
|
||||||
|
harfbuzz_features = { "ss01", "ss03" },
|
||||||
|
|
||||||
|
leader = { key = " ", mods = "CTRL", timeout_milliseconds = 1000 },
|
||||||
|
|
||||||
|
keys = {
|
||||||
|
{
|
||||||
|
mods = "LEADER",
|
||||||
|
key = "-",
|
||||||
|
action = wezterm.action.SplitVertical { domain = "CurrentPaneDomain" }
|
||||||
|
},
|
||||||
|
{
|
||||||
|
mods = "LEADER",
|
||||||
|
key = "=",
|
||||||
|
action = wezterm.action.SplitHorizontal { domain = "CurrentPaneDomain" }
|
||||||
|
},
|
||||||
|
split_nav('move', 'h'),
|
||||||
|
split_nav('move', 'j'),
|
||||||
|
split_nav('move', 'k'),
|
||||||
|
split_nav('move', 'l'),
|
||||||
|
split_nav('resize', 'h'),
|
||||||
|
split_nav('resize', 'j'),
|
||||||
|
split_nav('resize', 'k'),
|
||||||
|
split_nav('resize', 'l'),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
21
home/terminal/programs/default.nix
Normal file
21
home/terminal/programs/default.nix
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
{pkgs, ...}: {
|
||||||
|
imports = [
|
||||||
|
./git.nix
|
||||||
|
./gnupg.nix
|
||||||
|
./tmux.nix
|
||||||
|
./direnv.nix
|
||||||
|
./zellij.nix
|
||||||
|
];
|
||||||
|
|
||||||
|
home.packages = with pkgs; [
|
||||||
|
# archives
|
||||||
|
zip
|
||||||
|
unzip
|
||||||
|
unrar
|
||||||
|
|
||||||
|
# utils
|
||||||
|
fd
|
||||||
|
file
|
||||||
|
ripgrep
|
||||||
|
];
|
||||||
|
}
|
8
home/terminal/programs/direnv.nix
Normal file
8
home/terminal/programs/direnv.nix
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
_: {
|
||||||
|
programs = {
|
||||||
|
direnv = {
|
||||||
|
enable = true;
|
||||||
|
nix-direnv.enable = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
15
home/terminal/programs/git.nix
Normal file
15
home/terminal/programs/git.nix
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
_: {
|
||||||
|
programs.git = {
|
||||||
|
enable = true;
|
||||||
|
userName = "Anthony Rodriguez";
|
||||||
|
userEmail = "anthony@nezia.dev";
|
||||||
|
signing = {
|
||||||
|
signByDefault = true;
|
||||||
|
key = "EE3BE97C040A86CE";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
programs.lazygit = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
}
|
8
home/terminal/programs/gnupg.nix
Normal file
8
home/terminal/programs/gnupg.nix
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
{
|
||||||
|
programs.gpg.enable = true;
|
||||||
|
services.gpg-agent = {
|
||||||
|
enable = true;
|
||||||
|
enableBashIntegration = true;
|
||||||
|
enableFishIntegration = true;
|
||||||
|
};
|
||||||
|
}
|
44
home/terminal/programs/tmux.nix
Normal file
44
home/terminal/programs/tmux.nix
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
{pkgs, ...}: {
|
||||||
|
programs.tmux = {
|
||||||
|
enable = true;
|
||||||
|
prefix = "C-space";
|
||||||
|
escapeTime = 10;
|
||||||
|
clock24 = true;
|
||||||
|
keyMode = "vi";
|
||||||
|
mouse = true;
|
||||||
|
baseIndex = 1;
|
||||||
|
extraConfig = ''
|
||||||
|
set-option -a terminal-features "''${TERM}:RGB"
|
||||||
|
'';
|
||||||
|
plugins = with pkgs; [
|
||||||
|
{
|
||||||
|
plugin = tmuxPlugins.catppuccin;
|
||||||
|
extraConfig = ''
|
||||||
|
set -g @catppuccin_window_left_separator ""
|
||||||
|
set -g @catppuccin_window_right_separator " "
|
||||||
|
set -g @catppuccin_window_middle_separator " █"
|
||||||
|
set -g @catppuccin_window_number_position "right"
|
||||||
|
|
||||||
|
set -g @catppuccin_window_default_fill "number"
|
||||||
|
set -g @catppuccin_window_default_text "#W"
|
||||||
|
|
||||||
|
set -g @catppuccin_window_current_fill "number"
|
||||||
|
set -g @catppuccin_window_current_text "#W"
|
||||||
|
|
||||||
|
set -g @catppuccin_status_modules_right "directory user host session"
|
||||||
|
set -g @catppuccin_status_left_separator " "
|
||||||
|
set -g @catppuccin_status_right_separator ""
|
||||||
|
set -g @catppuccin_status_fill "icon"
|
||||||
|
set -g @catppuccin_status_connect_separator "no"
|
||||||
|
|
||||||
|
set -g @catppuccin_directory_text "#{pane_current_path}"
|
||||||
|
|
||||||
|
set -g @catppuccin_flavor 'frappe'
|
||||||
|
'';
|
||||||
|
}
|
||||||
|
tmuxPlugins.vim-tmux-navigator
|
||||||
|
tmuxPlugins.yank
|
||||||
|
];
|
||||||
|
};
|
||||||
|
programs.fzf.tmux.enableShellIntegration = true;
|
||||||
|
}
|
8
home/terminal/programs/zellij.nix
Normal file
8
home/terminal/programs/zellij.nix
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
_: {
|
||||||
|
programs.zellij = {
|
||||||
|
enable = true;
|
||||||
|
settings = {
|
||||||
|
pane_frames = false;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
|
./fish.nix
|
||||||
./starship.nix
|
./starship.nix
|
||||||
./nushell.nix
|
|
||||||
./zoxide.nix
|
./zoxide.nix
|
||||||
];
|
];
|
||||||
}
|
}
|
32
home/terminal/shell/fish.nix
Normal file
32
home/terminal/shell/fish.nix
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
{pkgs, ...}: {
|
||||||
|
programs.fish = {
|
||||||
|
enable = true;
|
||||||
|
interactiveShellInit = ''
|
||||||
|
set fish_greeting # Disable greeting
|
||||||
|
fish_vi_key_bindings # Enable Vi mode
|
||||||
|
set -U fish_color_command green
|
||||||
|
set -U fish_color_param white
|
||||||
|
'';
|
||||||
|
shellAbbrs = {
|
||||||
|
cd = "z";
|
||||||
|
ngc = "sudo nix-collect-garbage -d";
|
||||||
|
};
|
||||||
|
plugins = [
|
||||||
|
{
|
||||||
|
name = "fzf";
|
||||||
|
inherit (pkgs.fishPlugins.fzf) src;
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
programs.bash = {
|
||||||
|
enable = true;
|
||||||
|
initExtra = ''
|
||||||
|
if [[ $(${pkgs.procps}/bin/ps --no-header --pid=$PPID --format=comm) != "fish" && -z ''${BASH_EXECUTION_STRING} ]]
|
||||||
|
then
|
||||||
|
shopt -q login_shell && LOGIN_OPTION='--login' || LOGIN_OPTION=""
|
||||||
|
exec ${pkgs.fish}/bin/fish $LOGIN_OPTION
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
6
home/terminal/shell/starship.nix
Normal file
6
home/terminal/shell/starship.nix
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
_: {
|
||||||
|
programs.starship = {
|
||||||
|
enable = true;
|
||||||
|
enableTransience = true;
|
||||||
|
};
|
||||||
|
}
|
6
home/terminal/shell/zoxide.nix
Normal file
6
home/terminal/shell/zoxide.nix
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
_: {
|
||||||
|
programs.zoxide = {
|
||||||
|
enable = true;
|
||||||
|
enableBashIntegration = false;
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,25 +0,0 @@
|
||||||
# 💻 Hosts
|
|
||||||
|
|
||||||
This directory contains the entry points for different NixOS system configurations. Each host represents a complete system configuration, combining NixOS system settings and Home Manager configurations.
|
|
||||||
|
|
||||||
## Components
|
|
||||||
|
|
||||||
### default.nix
|
|
||||||
|
|
||||||
The `default.nix` file in each host directory serves as the main entry point for the system configuration. It:
|
|
||||||
|
|
||||||
- Sets up NixOS configurations
|
|
||||||
- Sets up Home Manager configurations
|
|
||||||
- References host-specific module declarations
|
|
||||||
|
|
||||||
### modules/
|
|
||||||
|
|
||||||
The `modules/` directory contains host-specific declarations for custom modules that are defined in the flake's `nixosModules` output. This so far only includes global theme / style related declarations.
|
|
||||||
|
|
||||||
## Adding a New Host
|
|
||||||
|
|
||||||
1. Create a new directory for the host
|
|
||||||
2. Add a `hardware-configuration.nix` generated with `nixos-generate-config`
|
|
||||||
3. Add a `default.nix` that imports the desired configurations
|
|
||||||
4. Create host-specific module declarations in the `modules/` subdirectory to customize the global modules as needed
|
|
||||||
5. Reference the new host in `hosts/default.nix`
|
|
|
@ -1,28 +0,0 @@
|
||||||
{inputs, ...}: let
|
|
||||||
system = "${inputs.self}/system";
|
|
||||||
in {
|
|
||||||
imports = [
|
|
||||||
./hardware-configuration.nix
|
|
||||||
./networking.nix # generated at runtime by nixos-infect
|
|
||||||
|
|
||||||
inputs.agenix.nixosModules.default
|
|
||||||
];
|
|
||||||
|
|
||||||
local = {
|
|
||||||
systemVars = {
|
|
||||||
hostName = "anastacia";
|
|
||||||
};
|
|
||||||
|
|
||||||
profiles.server.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
boot.tmp.cleanOnBoot = true;
|
|
||||||
networking.domain = "";
|
|
||||||
services.openssh.enable = true;
|
|
||||||
users.users.root.openssh.authorizedKeys.keys = [
|
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIEzs7SQH0Vjt9JHoXXmWy9fPU1I3rrRWV5magZFrI5al"
|
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIHKEPlN/GU9nJZPleA77HH5NA+6vyhhM84fTSjEwnEgq"
|
|
||||||
];
|
|
||||||
|
|
||||||
system.stateVersion = "23.11";
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
modulesPath,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
imports = [(modulesPath + "/profiles/qemu-guest.nix")];
|
|
||||||
boot = {
|
|
||||||
loader.grub.device = "/dev/sda";
|
|
||||||
initrd.availableKernelModules = ["ata_piix" "uhci_hcd" "xen_blkfront" "vmw_pvscsi"];
|
|
||||||
initrd.kernelModules = ["nvme"];
|
|
||||||
};
|
|
||||||
fileSystems."/" = {
|
|
||||||
device = "/dev/sda1";
|
|
||||||
fsType = "ext4";
|
|
||||||
};
|
|
||||||
|
|
||||||
nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux";
|
|
||||||
}
|
|
|
@ -1,52 +0,0 @@
|
||||||
{lib, ...}: {
|
|
||||||
# This file was populated at runtime with the networking
|
|
||||||
# details gathered from the active system.
|
|
||||||
networking = {
|
|
||||||
nameservers = [
|
|
||||||
"8.8.8.8"
|
|
||||||
];
|
|
||||||
defaultGateway = "172.31.1.1";
|
|
||||||
defaultGateway6 = {
|
|
||||||
address = "fe80::1";
|
|
||||||
interface = "eth0";
|
|
||||||
};
|
|
||||||
dhcpcd.enable = false;
|
|
||||||
usePredictableInterfaceNames = lib.mkForce false;
|
|
||||||
interfaces = {
|
|
||||||
eth0 = {
|
|
||||||
ipv4.addresses = [
|
|
||||||
{
|
|
||||||
address = "78.47.146.254";
|
|
||||||
prefixLength = 32;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
ipv6.addresses = [
|
|
||||||
{
|
|
||||||
address = "2a01:4f8:1c1c:8495::1";
|
|
||||||
prefixLength = 64;
|
|
||||||
}
|
|
||||||
{
|
|
||||||
address = "fe80::9400:3ff:fecb:6deb";
|
|
||||||
prefixLength = 64;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
ipv4.routes = [
|
|
||||||
{
|
|
||||||
address = "172.31.1.1";
|
|
||||||
prefixLength = 32;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
ipv6.routes = [
|
|
||||||
{
|
|
||||||
address = "fe80::1";
|
|
||||||
prefixLength = 128;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
services.udev.extraRules = ''
|
|
||||||
ATTR{address}=="96:00:03:cb:6d:eb", NAME="eth0"
|
|
||||||
|
|
||||||
'';
|
|
||||||
}
|
|
|
@ -1,27 +1,54 @@
|
||||||
{inputs, ...}: let
|
{
|
||||||
lib' = import ../lib inputs.nixpkgs.lib;
|
self,
|
||||||
mkSystem = args:
|
inputs,
|
||||||
inputs.nixpkgs.lib.nixosSystem {
|
...
|
||||||
specialArgs = {inherit inputs lib';};
|
}: {
|
||||||
modules = (args.modules or []) ++ [../modules];
|
flake.nixosConfigurations = let
|
||||||
|
inherit (inputs.nixpkgs.lib) nixosSystem;
|
||||||
|
homeImports = import "${self}/home/profiles";
|
||||||
|
mod = "${self}/system";
|
||||||
|
inherit (import mod) laptop desktop;
|
||||||
|
specialArgs = {
|
||||||
|
inherit inputs self;
|
||||||
};
|
};
|
||||||
in {
|
in {
|
||||||
vamos = mkSystem {
|
vamos = nixosSystem {
|
||||||
modules = [
|
inherit specialArgs;
|
||||||
|
modules =
|
||||||
|
laptop
|
||||||
|
++ [
|
||||||
./vamos
|
./vamos
|
||||||
inputs.nixos-hardware.nixosModules.framework-13-7040-amd
|
|
||||||
inputs.hjem.nixosModules.default
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
solaire = mkSystem {
|
"${mod}/programs/kde.nix"
|
||||||
modules = [
|
|
||||||
./solaire
|
|
||||||
inputs.hjem.nixosModules.default
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
anastacia = mkSystem {
|
{
|
||||||
modules = [./anastacia];
|
home-manager = {
|
||||||
|
users.nezia.imports = homeImports.vamos;
|
||||||
|
extraSpecialArgs = specialArgs;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
inputs.nixos-hardware.nixosModules.framework-13-7040-amd
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
solaire = nixosSystem {
|
||||||
|
inherit specialArgs;
|
||||||
|
modules =
|
||||||
|
desktop
|
||||||
|
++ [
|
||||||
|
./solaire
|
||||||
|
|
||||||
|
"${mod}/programs/gnome.nix"
|
||||||
|
"${mod}/hardware/nvidia.nix"
|
||||||
|
|
||||||
|
{
|
||||||
|
home-manager = {
|
||||||
|
users.nezia.imports = homeImports.solaire;
|
||||||
|
extraSpecialArgs = specialArgs;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
_: {
|
|
||||||
local.style = {
|
|
||||||
enable = true;
|
|
||||||
wallpaper = ../../../assets/wallpapers/lucy-edgerunners-wallpaper.jpg;
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,25 +1,7 @@
|
||||||
_: {
|
{pkgs, ...}: {
|
||||||
imports = [./hardware-configuration.nix ./config/theme.nix];
|
imports = [
|
||||||
|
./hardware-configuration.nix
|
||||||
local = {
|
];
|
||||||
systemVars = {
|
networking.hostName = "solaire";
|
||||||
hostName = "solaire";
|
environment.variables.FLAKE = "/home/nezia/.dotfiles";
|
||||||
username = "nezia";
|
|
||||||
};
|
|
||||||
homeVars = {
|
|
||||||
fullName = "Anthony Rodriguez";
|
|
||||||
email = "anthony@nezia.dev";
|
|
||||||
signingKey = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIEzs7SQH0Vjt9JHoXXmWy9fPU1I3rrRWV5magZFrI5al nezia@solaire";
|
|
||||||
};
|
|
||||||
|
|
||||||
profiles = {
|
|
||||||
desktop.enable = true;
|
|
||||||
gaming.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
modules = {
|
|
||||||
hyprland.enable = true;
|
|
||||||
nvidia.enable = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +0,0 @@
|
||||||
{pkgs, ...}: {
|
|
||||||
local.style = {
|
|
||||||
enable = true;
|
|
||||||
wallpaper = pkgs.fetchurl {
|
|
||||||
url = "https://raw.githubusercontent.com/NixOS/nixos-artwork/refs/heads/master/wallpapers/nix-wallpaper-simple-dark-gray.png";
|
|
||||||
hash = "sha256-JaLHdBxwrphKVherDVe5fgh+3zqUtpcwuNbjwrBlAok=";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,28 +1,7 @@
|
||||||
_: {
|
{...}: {
|
||||||
imports = [
|
imports = [
|
||||||
./hardware-configuration.nix
|
./hardware-configuration.nix
|
||||||
./config/theme.nix
|
|
||||||
];
|
];
|
||||||
|
networking.hostName = "vamos";
|
||||||
local = {
|
environment.variables.FLAKE = "/home/nezia/.dotfiles";
|
||||||
systemVars = {
|
|
||||||
hostName = "vamos";
|
|
||||||
username = "nezia";
|
|
||||||
};
|
|
||||||
|
|
||||||
homeVars = {
|
|
||||||
fullName = "Anthony Rodriguez";
|
|
||||||
email = "anthony@nezia.dev";
|
|
||||||
signingKey = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIHKEPlN/GU9nJZPleA77HH5NA+6vyhhM84fTSjEwnEgq nezia@vamos";
|
|
||||||
};
|
|
||||||
|
|
||||||
profiles = {
|
|
||||||
desktop.enable = true;
|
|
||||||
laptop.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
modules = {
|
|
||||||
hyprland.enable = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,77 +0,0 @@
|
||||||
lib:
|
|
||||||
with lib; let
|
|
||||||
# thanks fufexan https://github.com/fufexan/dotfiles/blob/2947f27791e97ea33c48af4ee2d0188fe03f80dd/lib/colors/default.nix#L8-L66
|
|
||||||
# convert rrggbb hex to rgba(r, g, b, a) css
|
|
||||||
rgba = c: alpha: let
|
|
||||||
color = removePrefix "#" c;
|
|
||||||
r = toString (hexToDec (__substring 0 2 color));
|
|
||||||
g = toString (hexToDec (__substring 2 2 color));
|
|
||||||
b = toString (hexToDec (__substring 4 2 color));
|
|
||||||
a = toString alpha;
|
|
||||||
res = "rgba(${r}, ${g}, ${b}, ${a})";
|
|
||||||
in
|
|
||||||
res;
|
|
||||||
|
|
||||||
blurImage = pkgs: path:
|
|
||||||
pkgs.runCommand "${builtins.baseNameOf path}-blurred" {
|
|
||||||
buildInputs = [pkgs.imagemagick];
|
|
||||||
}
|
|
||||||
''
|
|
||||||
magick ${path} -gaussian-blur 0x12 "$out"
|
|
||||||
'';
|
|
||||||
# functions copied from https://gist.github.com/corpix/f761c82c9d6fdbc1b3846b37e1020e11
|
|
||||||
# convert a hex value to an integer
|
|
||||||
hexToDec = v: let
|
|
||||||
hexToInt = {
|
|
||||||
"0" = 0;
|
|
||||||
"1" = 1;
|
|
||||||
"2" = 2;
|
|
||||||
"3" = 3;
|
|
||||||
"4" = 4;
|
|
||||||
"5" = 5;
|
|
||||||
"6" = 6;
|
|
||||||
"7" = 7;
|
|
||||||
"8" = 8;
|
|
||||||
"9" = 9;
|
|
||||||
"a" = 10;
|
|
||||||
"b" = 11;
|
|
||||||
"c" = 12;
|
|
||||||
"d" = 13;
|
|
||||||
"e" = 14;
|
|
||||||
"f" = 15;
|
|
||||||
"A" = 10;
|
|
||||||
"B" = 11;
|
|
||||||
"C" = 12;
|
|
||||||
"D" = 13;
|
|
||||||
"E" = 14;
|
|
||||||
"F" = 15;
|
|
||||||
};
|
|
||||||
chars = stringToCharacters v;
|
|
||||||
charsLen = length chars;
|
|
||||||
in
|
|
||||||
foldl
|
|
||||||
(a: v: a + v)
|
|
||||||
0
|
|
||||||
(imap0
|
|
||||||
(k: v: hexToInt."${v}" * (pow 16 (charsLen - k - 1)))
|
|
||||||
chars);
|
|
||||||
|
|
||||||
pow = let
|
|
||||||
pow' = base: exponent: value:
|
|
||||||
# FIXME: It will silently overflow on values > 2**62 :(
|
|
||||||
# The value will become negative or zero in this case
|
|
||||||
if exponent == 0
|
|
||||||
then 1
|
|
||||||
else if exponent <= 1
|
|
||||||
then value
|
|
||||||
else (pow' base (exponent - 1) (value * base));
|
|
||||||
in
|
|
||||||
base: exponent: pow' base exponent base;
|
|
||||||
generateGtkColors = palette: (concatLines
|
|
||||||
(mapAttrsToList
|
|
||||||
(name: color: "@define-color ${name} ${color};")
|
|
||||||
palette));
|
|
||||||
in {
|
|
||||||
inherit blurImage generateGtkColors rgba;
|
|
||||||
generators = import ./generators lib;
|
|
||||||
}
|
|
|
@ -1,4 +0,0 @@
|
||||||
lib: {
|
|
||||||
toHyprConf = import ./tohyprconf.nix lib;
|
|
||||||
gtk = import ./gtk.nix lib;
|
|
||||||
}
|
|
|
@ -1,31 +0,0 @@
|
||||||
lib: let
|
|
||||||
# toGtk3Ini , formatGtk2Option , and finalGtk2Text are all taken from https://github.com/nix-community/home-manager, with some minor modifications to their function.
|
|
||||||
# All of the gtk generator functions are available under the MIT License.
|
|
||||||
inherit (lib) generators isBool boolToString mapAttrsToList concatMapStrings isString escape;
|
|
||||||
formatGtk2Option = n: v: let
|
|
||||||
v' =
|
|
||||||
if isBool v
|
|
||||||
then boolToString v
|
|
||||||
else if isString v
|
|
||||||
then ''"${v}"''
|
|
||||||
else toString v;
|
|
||||||
in "${escape ["="] n} = ${v'}";
|
|
||||||
in {
|
|
||||||
toGtk3Ini = generators.toINI {
|
|
||||||
mkKeyValue = key: value: let
|
|
||||||
value' =
|
|
||||||
if isBool value
|
|
||||||
then boolToString value
|
|
||||||
else toString value;
|
|
||||||
in "${escape ["="] key}=${value'}";
|
|
||||||
};
|
|
||||||
formatGtk2Option = n: v: let
|
|
||||||
v' =
|
|
||||||
if isBool v
|
|
||||||
then boolToString v
|
|
||||||
else if isString v
|
|
||||||
then ''"${v}"''
|
|
||||||
else toString v;
|
|
||||||
in "${escape ["="] n} = ${v'}";
|
|
||||||
finalGtk2Text = {attrs}: concatMapStrings (l: l + "\n") (mapAttrsToList formatGtk2Option attrs);
|
|
||||||
}
|
|
|
@ -1,63 +0,0 @@
|
||||||
lib: {
|
|
||||||
attrs,
|
|
||||||
indentLevel ? 0,
|
|
||||||
importantPrefixes ? ["$" "bezier" "name"],
|
|
||||||
}: let
|
|
||||||
inherit
|
|
||||||
(lib)
|
|
||||||
all
|
|
||||||
concatMapStringsSep
|
|
||||||
concatStrings
|
|
||||||
concatStringsSep
|
|
||||||
filterAttrs
|
|
||||||
foldl
|
|
||||||
generators
|
|
||||||
hasPrefix
|
|
||||||
isAttrs
|
|
||||||
isList
|
|
||||||
mapAttrsToList
|
|
||||||
replicate
|
|
||||||
;
|
|
||||||
|
|
||||||
initialIndent = concatStrings (replicate indentLevel " ");
|
|
||||||
|
|
||||||
toHyprconf' = indent: attrs: let
|
|
||||||
sections =
|
|
||||||
filterAttrs (_: v: isAttrs v || (isList v && all isAttrs v)) attrs;
|
|
||||||
|
|
||||||
mkSection = n: attrs:
|
|
||||||
if lib.isList attrs
|
|
||||||
then (concatMapStringsSep "\n" (a: mkSection n a) attrs)
|
|
||||||
else ''
|
|
||||||
${indent}${n} {
|
|
||||||
${toHyprconf' " ${indent}" attrs}${indent}}
|
|
||||||
'';
|
|
||||||
|
|
||||||
mkFields = generators.toKeyValue {
|
|
||||||
listsAsDuplicateKeys = true;
|
|
||||||
inherit indent;
|
|
||||||
};
|
|
||||||
|
|
||||||
allFields =
|
|
||||||
filterAttrs (_: v: !(isAttrs v || (isList v && all isAttrs v)))
|
|
||||||
attrs;
|
|
||||||
|
|
||||||
isImportantField = n: _:
|
|
||||||
foldl (acc: prev:
|
|
||||||
if hasPrefix prev n
|
|
||||||
then true
|
|
||||||
else acc)
|
|
||||||
false
|
|
||||||
importantPrefixes;
|
|
||||||
|
|
||||||
importantFields = filterAttrs isImportantField allFields;
|
|
||||||
|
|
||||||
fields =
|
|
||||||
builtins.removeAttrs allFields
|
|
||||||
(mapAttrsToList (n: _: n) importantFields);
|
|
||||||
in
|
|
||||||
mkFields importantFields
|
|
||||||
+ concatStringsSep "\n" (mapAttrsToList mkSection sections)
|
|
||||||
+ mkFields fields;
|
|
||||||
in
|
|
||||||
toHyprconf' initialIndent attrs
|
|
|
@ -1,15 +0,0 @@
|
||||||
{lib, ...}: {
|
|
||||||
imports = [
|
|
||||||
./hardware
|
|
||||||
|
|
||||||
./boot.nix
|
|
||||||
./fonts.nix
|
|
||||||
./locales.nix
|
|
||||||
./networking.nix
|
|
||||||
./nix.nix
|
|
||||||
./users.nix
|
|
||||||
./security.nix
|
|
||||||
];
|
|
||||||
system.stateVersion = lib.mkDefault "24.05";
|
|
||||||
zramSwap.enable = true;
|
|
||||||
}
|
|
|
@ -1,31 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
fonts = {
|
|
||||||
enableDefaultPackages = false;
|
|
||||||
packages = [
|
|
||||||
pkgs._0xproto
|
|
||||||
pkgs.noto-fonts-color-emoji
|
|
||||||
pkgs.nerd-fonts.symbols-only
|
|
||||||
|
|
||||||
pkgs.noto-fonts
|
|
||||||
pkgs.noto-fonts-cjk-sans
|
|
||||||
pkgs.noto-fonts-extra
|
|
||||||
];
|
|
||||||
|
|
||||||
fontconfig = {
|
|
||||||
enable = true;
|
|
||||||
defaultFonts = {
|
|
||||||
serif = ["Noto Serif"];
|
|
||||||
sansSerif = ["Inter Medium"];
|
|
||||||
monospace = ["0xProto"];
|
|
||||||
emoji = ["Noto Color Emoji"];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,10 +0,0 @@
|
||||||
{
|
|
||||||
imports = [
|
|
||||||
./fprintd.nix
|
|
||||||
./fwupd.nix
|
|
||||||
./nvidia.nix
|
|
||||||
./printing.nix
|
|
||||||
./uni-sync.nix
|
|
||||||
./via.nix
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
config = lib.mkIf config.local.profiles.laptop.enable {
|
|
||||||
services.fprintd.enable = true;
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
services.fwupd.enable = true;
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,22 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkIf;
|
|
||||||
in {
|
|
||||||
config = mkIf config.local.modules.nvidia.enable {
|
|
||||||
hardware.graphics.enable = true;
|
|
||||||
services.xserver.videoDrivers = ["nvidia"];
|
|
||||||
hardware.nvidia = {
|
|
||||||
open = false;
|
|
||||||
modesetting.enable = true;
|
|
||||||
powerManagement.enable = true;
|
|
||||||
nvidiaSettings = true;
|
|
||||||
package = config.boot.kernelPackages.nvidiaPackages.beta;
|
|
||||||
};
|
|
||||||
|
|
||||||
# https://wiki.hyprland.org/Nvidia/#suspendwakeup-issues
|
|
||||||
boot.kernelParams = ["nvidia.NVreg_PreserveVideoMemoryAllocations=1"];
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,36 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
services = {
|
|
||||||
# setup printing service
|
|
||||||
printing.enable = true;
|
|
||||||
|
|
||||||
avahi = {
|
|
||||||
enable = true;
|
|
||||||
nssmdns4 = true;
|
|
||||||
openFirewall = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
printing.drivers = [
|
|
||||||
pkgs.gutenprint
|
|
||||||
pkgs.hplip
|
|
||||||
];
|
|
||||||
|
|
||||||
udev.packages = [
|
|
||||||
pkgs.sane-airscan
|
|
||||||
pkgs.utsushi
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
hardware.sane.enable = true; # enables support for SANE scanners
|
|
||||||
hardware.sane.extraBackends = [
|
|
||||||
pkgs.sane-airscan # generic
|
|
||||||
pkgs.hplip # HP
|
|
||||||
pkgs.utsushi # other printers
|
|
||||||
];
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,44 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
config = lib.mkIf config.local.profiles.gaming.enable {
|
|
||||||
hardware.uni-sync = {
|
|
||||||
enable = true;
|
|
||||||
devices = [
|
|
||||||
{
|
|
||||||
device_id = "VID:3314/PID:41218/SN:6243168001";
|
|
||||||
sync_rgb = true;
|
|
||||||
channels = [
|
|
||||||
{
|
|
||||||
mode = "Manual";
|
|
||||||
speed = 60;
|
|
||||||
}
|
|
||||||
{
|
|
||||||
mode = "Manual";
|
|
||||||
speed = 60;
|
|
||||||
}
|
|
||||||
{
|
|
||||||
mode = "Manual";
|
|
||||||
speed = 60;
|
|
||||||
}
|
|
||||||
{
|
|
||||||
mode = "Manual";
|
|
||||||
speed = 60;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
systemd.services.uni-sync = {
|
|
||||||
enable = true;
|
|
||||||
serviceConfig = {
|
|
||||||
ExecStart = "${pkgs.uni-sync}/bin/uni-sync";
|
|
||||||
};
|
|
||||||
wantedBy = ["multi-user.target"];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,14 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
config = lib.mkIf config.local.profiles.gaming.enable {
|
|
||||||
hardware.keyboard.qmk.enable = true;
|
|
||||||
environment.systemPackages = with pkgs; [
|
|
||||||
via
|
|
||||||
];
|
|
||||||
services.udev.packages = [pkgs.via];
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,21 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
config = lib.mkIf (!config.local.profiles.server.enable) {
|
|
||||||
networking = {
|
|
||||||
inherit (config.local.systemVars) hostName;
|
|
||||||
nameservers = ["1.1.1.1" "1.0.0.1"];
|
|
||||||
networkmanager = {
|
|
||||||
enable = true;
|
|
||||||
dns = "systemd-resolved";
|
|
||||||
wifi.powersave = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
services.resolved = {
|
|
||||||
enable = true;
|
|
||||||
dnsovertls = "opportunistic";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,49 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkIf;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
in {
|
|
||||||
nix = {
|
|
||||||
package = pkgs.lix;
|
|
||||||
settings = {
|
|
||||||
accept-flake-config = true;
|
|
||||||
warn-dirty = false;
|
|
||||||
auto-optimise-store = true;
|
|
||||||
trusted-users = ["root" "@wheel"];
|
|
||||||
experimental-features = [
|
|
||||||
"nix-command"
|
|
||||||
"flakes"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
programs.nh = {
|
|
||||||
enable = true;
|
|
||||||
clean = {
|
|
||||||
enable = true;
|
|
||||||
extraArgs = "--keep-since 30d --keep 3";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
nixpkgs = {
|
|
||||||
config = {
|
|
||||||
allowUnfree = true;
|
|
||||||
permittedInsecurePackages = [
|
|
||||||
"cinny-4.2.3"
|
|
||||||
"cinny-unwrapped-4.2.3"
|
|
||||||
"segger-jlink-qt4-810"
|
|
||||||
];
|
|
||||||
segger-jlink.acceptLicense = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
hjem.users.${username} = {
|
|
||||||
files.".config/environment.d/${config.local.homeVars.userEnvFile}.conf".text = ''
|
|
||||||
FLAKE="${config.hjem.users.${username}.directory}/.dotfiles"
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,43 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
security = {
|
|
||||||
polkit.enable = true;
|
|
||||||
polkit = {
|
|
||||||
extraConfig = ''
|
|
||||||
polkit.addRule(function(action, subject) {
|
|
||||||
if (
|
|
||||||
subject.isInGroup("users")
|
|
||||||
&& (
|
|
||||||
action.id == "org.freedesktop.login1.reboot" ||
|
|
||||||
action.id == "org.freedesktop.login1.reboot-multiple-sessions" ||
|
|
||||||
action.id == "org.freedesktop.login1.power-off" ||
|
|
||||||
action.id == "org.freedesktop.login1.power-off-multiple-sessions"
|
|
||||||
)
|
|
||||||
)
|
|
||||||
{
|
|
||||||
return polkit.Result.YES;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
systemd.user.services.polkit-gnome-authentication-agent-1 = {
|
|
||||||
description = "polkit-gnome-authentication-agent-1";
|
|
||||||
wantedBy = ["graphical-session.target"];
|
|
||||||
wants = ["graphical-session.target"];
|
|
||||||
after = ["graphical-session.target"];
|
|
||||||
serviceConfig = {
|
|
||||||
Type = "simple";
|
|
||||||
ExecStart = "${pkgs.polkit_gnome}/libexec/polkit-gnome-authentication-agent-1";
|
|
||||||
Restart = "on-failure";
|
|
||||||
RestartSec = 1;
|
|
||||||
TimeoutStopSec = 10;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,30 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
in {
|
|
||||||
config = lib.mkIf (!config.local.profiles.server.enable) {
|
|
||||||
users.users.${config.local.systemVars.username} = {
|
|
||||||
isNormalUser = true;
|
|
||||||
description = config.local.homeVars.fullName or "User";
|
|
||||||
extraGroups = [
|
|
||||||
"networkmanager"
|
|
||||||
"audio"
|
|
||||||
"video"
|
|
||||||
"wheel"
|
|
||||||
"plugdev"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
hjem = {
|
|
||||||
clobberByDefault = true;
|
|
||||||
users.${username} = {
|
|
||||||
enable = true;
|
|
||||||
directory = "/home/${username}";
|
|
||||||
user = "${username}";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,8 +1,5 @@
|
||||||
{
|
{
|
||||||
imports = [
|
flake.nixosModules = {
|
||||||
./core
|
theme = import ./theme;
|
||||||
./options
|
};
|
||||||
./programs
|
|
||||||
./services
|
|
||||||
];
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,10 +0,0 @@
|
||||||
{
|
|
||||||
imports = [
|
|
||||||
./modules
|
|
||||||
./profiles
|
|
||||||
|
|
||||||
./homeVars.nix
|
|
||||||
./style.nix
|
|
||||||
./systemVars.nix
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,48 +0,0 @@
|
||||||
{
|
|
||||||
config,
|
|
||||||
lib,
|
|
||||||
options,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkIf mkOption;
|
|
||||||
inherit (lib.types) str;
|
|
||||||
in {
|
|
||||||
options.local.homeVars = {
|
|
||||||
fullName = mkOption {
|
|
||||||
type = str;
|
|
||||||
description = "your full name (used for git commits and user description)";
|
|
||||||
default = null;
|
|
||||||
};
|
|
||||||
email = mkOption {
|
|
||||||
type = str;
|
|
||||||
description = "your email (used for git commits)";
|
|
||||||
default = null;
|
|
||||||
};
|
|
||||||
signingKey = mkOption {
|
|
||||||
type = str;
|
|
||||||
description = "your ssh public key (used for signing git commits)";
|
|
||||||
};
|
|
||||||
|
|
||||||
userEnvFile = mkOption {
|
|
||||||
type = str;
|
|
||||||
description = "filename where the user environment variables such as EDITOR will be stored, under `$XDG_CONFIG_HOME/environment.d` (needs to be a file name without extension).";
|
|
||||||
default = "99-user-env";
|
|
||||||
example = "99-user-env";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config.assertions = mkIf (!config.local.profiles.server.enable) [
|
|
||||||
{
|
|
||||||
assertion = options.local.homeVars.fullName.isDefined;
|
|
||||||
}
|
|
||||||
{
|
|
||||||
assertion = options.local.homeVars.email.isDefined;
|
|
||||||
}
|
|
||||||
{
|
|
||||||
assertion = options.local.homeVars.signingKey.isDefined;
|
|
||||||
}
|
|
||||||
{
|
|
||||||
assertion = options.local.homeVars.userEnvFile.isDefined;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
imports = [
|
|
||||||
./hyprland.nix
|
|
||||||
./nvidia.nix
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,7 +0,0 @@
|
||||||
{lib, ...}: let
|
|
||||||
inherit (lib) mkEnableOption;
|
|
||||||
in {
|
|
||||||
options.local.modules.hyprland = {
|
|
||||||
enable = mkEnableOption "Hyprland modules";
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,7 +0,0 @@
|
||||||
{lib, ...}: let
|
|
||||||
inherit (lib) mkEnableOption;
|
|
||||||
in {
|
|
||||||
options.local.modules.nvidia = {
|
|
||||||
enable = mkEnableOption "nvidia";
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,8 +0,0 @@
|
||||||
{
|
|
||||||
imports = [
|
|
||||||
./desktop.nix
|
|
||||||
./gaming.nix
|
|
||||||
./laptop.nix
|
|
||||||
./server.nix
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkEnableOption;
|
|
||||||
in {
|
|
||||||
options = {
|
|
||||||
local.profiles.desktop.enable = mkEnableOption "the desktop profile";
|
|
||||||
};
|
|
||||||
|
|
||||||
config.assertions = lib.mkIf config.local.profiles.desktop.enable [
|
|
||||||
{
|
|
||||||
assertion = !config.local.profiles.server.enable;
|
|
||||||
message = "The desktop profile cannot be enabled if `local.profiles.server.enable` is set to true.";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkEnableOption;
|
|
||||||
in {
|
|
||||||
options = {
|
|
||||||
local.profiles.gaming.enable = mkEnableOption "the gaming profile";
|
|
||||||
};
|
|
||||||
|
|
||||||
config.assertions = lib.mkIf config.local.profiles.gaming.enable [
|
|
||||||
{
|
|
||||||
assertion = !config.local.profiles.server.enable;
|
|
||||||
message = "The gaming profile cannot be enabled if `local.profiles.server.enable` is set to true.";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkEnableOption;
|
|
||||||
in {
|
|
||||||
options = {
|
|
||||||
local.profiles.laptop.enable = mkEnableOption "the laptop profile";
|
|
||||||
};
|
|
||||||
|
|
||||||
config.assertions = lib.mkIf config.local.profiles.laptop.enable [
|
|
||||||
{
|
|
||||||
assertion = !config.local.profiles.server.enable;
|
|
||||||
message = "The laptop profile cannot be enabled if `local.profiles.server.enable` is set to true.";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,23 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkEnableOption;
|
|
||||||
in {
|
|
||||||
options = {
|
|
||||||
local.profiles.server.enable = mkEnableOption "the server profile";
|
|
||||||
};
|
|
||||||
|
|
||||||
config.assertions = lib.mkIf config.local.profiles.server.enable [
|
|
||||||
{
|
|
||||||
assertion = !config.local.profiles.desktop.enable;
|
|
||||||
message = "The server profile cannot be enabled if `local.profiles.desktop.enable` is set to true.";
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
|
||||||
assertion = !config.local.profiles.gaming.enable;
|
|
||||||
message = "The server profile cannot be enabled if `local.profiles.gaming.enable` is set to true.";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,138 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
options,
|
|
||||||
inputs,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) attrNames mkEnableOption mkOption pathExists;
|
|
||||||
inherit (lib.types) attrs bool enum package path str;
|
|
||||||
|
|
||||||
cfg = config.local.style;
|
|
||||||
in {
|
|
||||||
options.local.style = {
|
|
||||||
enable = mkEnableOption "style";
|
|
||||||
schemeName = mkOption {
|
|
||||||
description = ''
|
|
||||||
Name of the tinted-theming color scheme to use.
|
|
||||||
'';
|
|
||||||
type = enum (attrNames inputs.basix.schemeData.base16);
|
|
||||||
example = "catppuccin-mocha";
|
|
||||||
default = "catppuccin-mocha";
|
|
||||||
};
|
|
||||||
|
|
||||||
scheme = mkOption {
|
|
||||||
description = ''
|
|
||||||
Computed scheme from `config.local.style.schemeName`.
|
|
||||||
'';
|
|
||||||
type = attrs;
|
|
||||||
readOnly = true;
|
|
||||||
};
|
|
||||||
wallpaper = mkOption {
|
|
||||||
description = ''
|
|
||||||
Location of the wallpaper that will be used throughout the system.
|
|
||||||
'';
|
|
||||||
type = path;
|
|
||||||
example = lib.literalExpression "./wallpaper.png";
|
|
||||||
default = pkgs.fetchurl {
|
|
||||||
url = "https://raw.githubusercontent.com/NixOS/nixos-artwork/e0cf0eb237dc5baba86661a3572b20a6183c1876/wallpapers/nix-wallpaper-nineish-catppuccin-frappe.png?raw=true";
|
|
||||||
hash = "sha256-/HAtpGwLxjNfJvX5/4YZfM8jPNStaM3gisK8+ImRmQ4=";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
cursorTheme = {
|
|
||||||
name = mkOption {
|
|
||||||
description = ''
|
|
||||||
Name of the cursor theme.
|
|
||||||
'';
|
|
||||||
default = "phinger-cursors-dark";
|
|
||||||
};
|
|
||||||
package = mkOption {
|
|
||||||
type = package;
|
|
||||||
description = ''
|
|
||||||
Package providing the cursor theme.
|
|
||||||
'';
|
|
||||||
default = pkgs.phinger-cursors;
|
|
||||||
};
|
|
||||||
size = mkOption {
|
|
||||||
description = ''
|
|
||||||
Size of the cursor.
|
|
||||||
'';
|
|
||||||
default = 32;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
avatar = mkOption {
|
|
||||||
description = ''
|
|
||||||
Path to an avatar image (used for hyprlock).
|
|
||||||
'';
|
|
||||||
default = ../../assets/avatar.png; # TODO silly, change this
|
|
||||||
};
|
|
||||||
|
|
||||||
gtk = {
|
|
||||||
enable = mkOption {
|
|
||||||
type = bool;
|
|
||||||
description = "enable GTK theming options";
|
|
||||||
default = cfg.enable;
|
|
||||||
};
|
|
||||||
theme = {
|
|
||||||
name = mkOption {
|
|
||||||
type = str;
|
|
||||||
description = "Name for the GTK theme";
|
|
||||||
default = "Catppuccin-GTK-Purple-Dark";
|
|
||||||
};
|
|
||||||
package = mkOption {
|
|
||||||
type = package;
|
|
||||||
description = "Package providing the GTK theme";
|
|
||||||
|
|
||||||
default = pkgs.magnetic-catppuccin-gtk.override {
|
|
||||||
accent = ["purple"];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
iconTheme = {
|
|
||||||
name = mkOption {
|
|
||||||
type = str;
|
|
||||||
description = "The name for the icon theme that will be used for GTK programs";
|
|
||||||
default = "Papirus-Dark";
|
|
||||||
};
|
|
||||||
|
|
||||||
package = mkOption {
|
|
||||||
type = package;
|
|
||||||
description = "The GTK icon theme to be used";
|
|
||||||
default = pkgs.catppuccin-papirus-folders.override {
|
|
||||||
flavor = "mocha";
|
|
||||||
accent = "lavender";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config = lib.mkIf cfg.enable {
|
|
||||||
assertions = [
|
|
||||||
(let
|
|
||||||
themePath = cfg.gtk.theme.package + /share/themes + "/${cfg.gtk.theme.name}";
|
|
||||||
in {
|
|
||||||
assertion = cfg.gtk.enable -> pathExists themePath;
|
|
||||||
message = ''
|
|
||||||
${toString themePath} set by the GTK module does not exist!
|
|
||||||
|
|
||||||
To suppress this message, make sure that
|
|
||||||
`config.modules.theme.gtk.theme.package` contains
|
|
||||||
the path `${cfg.theme.name}`
|
|
||||||
'';
|
|
||||||
})
|
|
||||||
{
|
|
||||||
assertion = cfg.enable -> options.local.systemVars.username.isDefined;
|
|
||||||
message = ''
|
|
||||||
When enabling system-wide theming, a username needs to be set in `config.local.systemVars.username`.
|
|
||||||
'';
|
|
||||||
}
|
|
||||||
];
|
|
||||||
|
|
||||||
local.style.scheme = inputs.basix.schemeData.base16.${cfg.schemeName};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,30 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
options,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkOption;
|
|
||||||
inherit (lib.types) str;
|
|
||||||
in {
|
|
||||||
options.local.systemVars = {
|
|
||||||
hostName = mkOption {
|
|
||||||
type = str;
|
|
||||||
description = "hostname for the current host";
|
|
||||||
default = null;
|
|
||||||
};
|
|
||||||
username = mkOption {
|
|
||||||
type = str;
|
|
||||||
description = "username for the home directory";
|
|
||||||
default = null;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config.assertions = [
|
|
||||||
{
|
|
||||||
assertion = options.local.systemVars.hostName.isDefined;
|
|
||||||
}
|
|
||||||
{
|
|
||||||
assertion = options.local.systemVars.username.isDefined;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,38 +0,0 @@
|
||||||
Config(
|
|
||||||
// Position/size fields 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
|
|
||||||
|
|
||||||
// The horizontal position, adjusted so that Relative(0.5) always centers the runner
|
|
||||||
x: Fraction(0.5),
|
|
||||||
|
|
||||||
// The vertical position, works the same as `x`
|
|
||||||
y: Absolute(0),
|
|
||||||
|
|
||||||
// The width of the runner
|
|
||||||
width: Absolute(800),
|
|
||||||
|
|
||||||
// The minimum height of the runner, the runner will expand to fit all the entries
|
|
||||||
height: 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,
|
|
||||||
|
|
||||||
// Close window when a click outside the main box is received
|
|
||||||
close_on_click: false,
|
|
||||||
|
|
||||||
// Show search results immediately when Anyrun starts
|
|
||||||
show_results_immediately: true,
|
|
||||||
|
|
||||||
// Limit amount of entries shown in total
|
|
||||||
max_entries: None,
|
|
||||||
)
|
|
|
@ -1,36 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
inputs,
|
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkIf;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
in {
|
|
||||||
config = mkIf config.local.modules.hyprland.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [inputs.anyrun.packages.${pkgs.system}.anyrun-with-all-plugins];
|
|
||||||
files = {
|
|
||||||
".config/anyrun/config.ron".source = ./config.ron;
|
|
||||||
".config/anyrun/applications.ron".text = ''
|
|
||||||
Config(
|
|
||||||
// Also show the Desktop Actions defined in the desktop files, e.g. "New Window" from LibreWolf
|
|
||||||
desktop_actions: false,
|
|
||||||
max_entries: 5,
|
|
||||||
// The terminal used for running terminal based desktop entries, if left as `None` a static list of terminals is used
|
|
||||||
// to determine what terminal to use.
|
|
||||||
terminal: Some(Terminal(
|
|
||||||
// The main terminal command
|
|
||||||
command: "foot",
|
|
||||||
// What arguments should be passed to the terminal process to run the command correctly
|
|
||||||
// {} is replaced with the command in the desktop entry
|
|
||||||
args: "uwsm app -- {}",
|
|
||||||
)),
|
|
||||||
)
|
|
||||||
'';
|
|
||||||
".config/anyrun/style.css".source = ./style.css;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,25 +0,0 @@
|
||||||
#window {
|
|
||||||
background-color: rgba(0, 0, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
box#main {
|
|
||||||
border-radius: 10px;
|
|
||||||
background-color: @theme_bg_color;
|
|
||||||
}
|
|
||||||
|
|
||||||
list#main {
|
|
||||||
background-color: rgba(0, 0, 0, 0);
|
|
||||||
border-radius: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
list#plugin {
|
|
||||||
background-color: rgba(0, 0, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
label#match-desc {
|
|
||||||
font-size: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
label#plugin {
|
|
||||||
font-size: 14px;
|
|
||||||
}
|
|
|
@ -1,19 +0,0 @@
|
||||||
{
|
|
||||||
imports = [
|
|
||||||
./anyrun
|
|
||||||
./editors
|
|
||||||
./hypr
|
|
||||||
./media
|
|
||||||
./terminal
|
|
||||||
|
|
||||||
./discord.nix
|
|
||||||
./fastfetch.nix
|
|
||||||
./firefox.nix
|
|
||||||
./games.nix
|
|
||||||
./misc.nix
|
|
||||||
./thunar.nix
|
|
||||||
./waybar.nix
|
|
||||||
./wlogout.nix
|
|
||||||
./xdg.nix
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,118 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkIf;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
styleCfg = config.local.style;
|
|
||||||
in {
|
|
||||||
config = mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [pkgs.vesktop];
|
|
||||||
files.".config/vesktop/themes/midnight-base16.css".text = with styleCfg.scheme.palette;
|
|
||||||
mkIf styleCfg.enable ''
|
|
||||||
/**
|
|
||||||
* @name Midnight-base16
|
|
||||||
* @description A dark, rounded discord theme. Updated to use base16 colors.
|
|
||||||
* @author refact0r
|
|
||||||
* @version 1.6.2
|
|
||||||
* @invite nz87hXyvcy
|
|
||||||
* @website https://github.com/refact0r/midnight-discord
|
|
||||||
* @source https://github.com/refact0r/midnight-discord/blob/master/midnight.theme.css
|
|
||||||
* @authorId 508863359777505290
|
|
||||||
* @authorLink https://www.refact0r.dev
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* IMPORTANT: make sure to enable dark mode in discord settings for the theme to apply properly!!! */
|
|
||||||
|
|
||||||
@import url('https://refact0r.github.io/midnight-discord/midnight.css');
|
|
||||||
|
|
||||||
/* customize things here */
|
|
||||||
:root {
|
|
||||||
/* font, change to 'gg sans' for default discord font*/
|
|
||||||
--font: 'gg sans';
|
|
||||||
|
|
||||||
/* top left corner text */
|
|
||||||
--corner-text: '${styleCfg.scheme.name}';
|
|
||||||
|
|
||||||
/* color of status indicators and window controls */
|
|
||||||
--online-indicator: ${base0B}; /* change to #23a55a for default green */
|
|
||||||
--dnd-indicator: ${base08}; /* change to #f13f43 for default red */
|
|
||||||
--idle-indicator: ${base0A}; /* change to #f0b232 for default yellow */
|
|
||||||
--streaming-indicator: ${base0E}; /* change to #593695 for default purple */
|
|
||||||
|
|
||||||
/* accent colors */
|
|
||||||
--accent-1: ${base0D}; /* links */
|
|
||||||
--accent-2: ${base0E}; /* general unread/mention elements, some icons when active */
|
|
||||||
--accent-3: ${base0E}; /* accent buttons */
|
|
||||||
--accent-4: ${base03}; /* accent buttons when hovered */
|
|
||||||
--accent-5: ${base07}; /* accent buttons when clicked */
|
|
||||||
--mention: ${base00}1a; /* mentions & mention messages */
|
|
||||||
--mention-hover: ${base00}0d; /* mentions & mention messages when hovered */
|
|
||||||
|
|
||||||
/* text colors */
|
|
||||||
--text-0: var(--bg-4); /* text on colored elements */
|
|
||||||
--text-1: ${base06}; /* other normally white text */
|
|
||||||
--text-2: ${base06}; /* headings and important text */
|
|
||||||
--text-3: ${base05}; /* normal text */
|
|
||||||
--text-4: ${base05}; /* icon buttons and channels */
|
|
||||||
--text-5: ${base04}; /* muted channels/chats and timestamps */
|
|
||||||
|
|
||||||
/* background and dark colors */
|
|
||||||
--bg-1: ${base0E}; /* dark buttons when clicked */
|
|
||||||
--bg-2: ${base02}; /* dark buttons */
|
|
||||||
--bg-3: ${base01}; /* spacing, secondary elements */
|
|
||||||
--bg-4: ${base00}; /* main background color */
|
|
||||||
--hover: ${base03}1a; /* channels and buttons when hovered */
|
|
||||||
--active: ${base03}33; /* channels and buttons when clicked or selected */
|
|
||||||
--message-hover: #0000001a; /* messages when hovered */
|
|
||||||
|
|
||||||
/* amount of spacing and padding */
|
|
||||||
--spacing: 12px;
|
|
||||||
|
|
||||||
/* animations */
|
|
||||||
/* ALL ANIMATIONS CAN BE DISABLED WITH REDUCED MOTION IN DISCORD SETTINGS */
|
|
||||||
--list-item-transition: 0.2s ease; /* channels/members/settings hover transition */
|
|
||||||
--unread-bar-transition: 0.2s ease; /* unread bar moving into view transition */
|
|
||||||
--moon-spin-transition: 0.4s ease; /* moon icon spin */
|
|
||||||
--icon-spin-transition: 1s ease; /* round icon button spin (settings, emoji, etc.) */
|
|
||||||
|
|
||||||
/* corner roundness (border-radius) */
|
|
||||||
--roundness-xl: 22px; /* roundness of big panel outer corners */
|
|
||||||
--roundness-l: 20px; /* popout panels */
|
|
||||||
--roundness-m: 16px; /* smaller panels, images, embeds */
|
|
||||||
--roundness-s: 12px; /* members, settings inputs */
|
|
||||||
--roundness-xs: 10px; /* channels, buttons */
|
|
||||||
--roundness-xxs: 8px; /* searchbar, small elements */
|
|
||||||
|
|
||||||
/* direct messages moon icon */
|
|
||||||
/* change to block to show, none to hide */
|
|
||||||
--discord-icon: none; /* discord icon */
|
|
||||||
--moon-icon: block; /* moon icon */
|
|
||||||
--moon-icon-url: url('https://upload.wikimedia.org/wikipedia/commons/c/c4/Font_Awesome_5_solid_moon.svg'); /* custom icon url */
|
|
||||||
--moon-icon-size: auto;
|
|
||||||
|
|
||||||
/* filter uncolorable elements to fit theme */
|
|
||||||
/* (just set to none, they're too much work to configure) */
|
|
||||||
--login-bg-filter: saturate(0.3) hue-rotate(-15deg) brightness(0.4); /* login background artwork */
|
|
||||||
--green-to-accent-3-filter: hue-rotate(56deg) saturate(1.43); /* add friend page explore icon */
|
|
||||||
--blurple-to-accent-3-filter: hue-rotate(304deg) saturate(0.84) brightness(1.2); /* add friend page school icon */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Selected chat/friend text */
|
|
||||||
.selected_f5eb4b,
|
|
||||||
.selected_f6f816 .link_d8bfb3 {
|
|
||||||
color: var(--text-0) !important;
|
|
||||||
background: var(--accent-3) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.selected_f6f816 .link_d8bfb3 * {
|
|
||||||
color: var(--text-0) !important;
|
|
||||||
fill: var(--text-0) !important;
|
|
||||||
}
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,23 +0,0 @@
|
||||||
{
|
|
||||||
config,
|
|
||||||
lib,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkIf;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
inherit (config.local.homeVars) userEnvFile;
|
|
||||||
in {
|
|
||||||
imports = [
|
|
||||||
./neovim.nix
|
|
||||||
];
|
|
||||||
|
|
||||||
config = mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
files = {
|
|
||||||
".config/environment.d/${userEnvFile}.conf".text = ''
|
|
||||||
EDITOR="nvim"
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,247 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
inputs,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
styleCfg = config.local.style;
|
|
||||||
|
|
||||||
customNeovim = inputs.nvf.lib.neovimConfiguration {
|
|
||||||
inherit pkgs;
|
|
||||||
modules = lib.singleton {
|
|
||||||
config.vim = lib.mkMerge [
|
|
||||||
{
|
|
||||||
viAlias = true;
|
|
||||||
vimAlias = true;
|
|
||||||
enableLuaLoader = true;
|
|
||||||
preventJunkFiles = true;
|
|
||||||
useSystemClipboard = true;
|
|
||||||
options = {
|
|
||||||
tabstop = 4;
|
|
||||||
autoindent = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
luaConfigPost = ''
|
|
||||||
vim.opt.formatoptions:remove('c')
|
|
||||||
vim.opt.formatoptions:remove('r')
|
|
||||||
vim.opt.formatoptions:remove('o')
|
|
||||||
|
|
||||||
vim.api.nvim_create_autocmd("FileType", {
|
|
||||||
pattern = "nix",
|
|
||||||
callback = function(opts)
|
|
||||||
local bo = vim.bo[opts.buf]
|
|
||||||
bo.tabstop = 2
|
|
||||||
bo.shiftwidth = 2
|
|
||||||
end
|
|
||||||
})
|
|
||||||
'';
|
|
||||||
|
|
||||||
maps = {
|
|
||||||
normal = {
|
|
||||||
"<leader>m" = {
|
|
||||||
silent = true;
|
|
||||||
action = "<cmd>make<CR>";
|
|
||||||
}; # Same as nnoremap <leader>m <silent> <cmd>make<CR>
|
|
||||||
"<leader>t" = {
|
|
||||||
silent = true;
|
|
||||||
action = "<cmd>Neotree toggle<CR>";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
ui = {
|
|
||||||
noice.enable = true;
|
|
||||||
};
|
|
||||||
notify.nvim-notify.enable = true;
|
|
||||||
|
|
||||||
statusline = {
|
|
||||||
lualine = {
|
|
||||||
enable = true;
|
|
||||||
theme = "auto";
|
|
||||||
componentSeparator = {
|
|
||||||
left = "";
|
|
||||||
};
|
|
||||||
sectionSeparator = {
|
|
||||||
left = "";
|
|
||||||
right = "";
|
|
||||||
};
|
|
||||||
|
|
||||||
activeSection = {
|
|
||||||
a = [
|
|
||||||
''
|
|
||||||
{
|
|
||||||
"mode",
|
|
||||||
separator = { right = "" },
|
|
||||||
right_padding = 2
|
|
||||||
}
|
|
||||||
''
|
|
||||||
];
|
|
||||||
b = [
|
|
||||||
''
|
|
||||||
{
|
|
||||||
"branch",
|
|
||||||
icon = '',
|
|
||||||
separator = { right = "" }
|
|
||||||
}
|
|
||||||
''
|
|
||||||
];
|
|
||||||
c = [
|
|
||||||
''
|
|
||||||
"filename"
|
|
||||||
''
|
|
||||||
];
|
|
||||||
x = [
|
|
||||||
''
|
|
||||||
{
|
|
||||||
"diagnostics",
|
|
||||||
sources = {'nvim_lsp', 'nvim_diagnostic', 'nvim_diagnostic', 'vim_lsp', 'coc'},
|
|
||||||
symbols = {error = ' ', warn = ' ', info = ' ', hint = ' '},
|
|
||||||
colored = true,
|
|
||||||
update_in_insert = false,
|
|
||||||
always_visible = false,
|
|
||||||
diagnostics_color = {
|
|
||||||
color_error = { fg = 'red' },
|
|
||||||
color_warn = { fg = 'yellow' },
|
|
||||||
color_info = { fg = 'cyan' },
|
|
||||||
},
|
|
||||||
}
|
|
||||||
''
|
|
||||||
''
|
|
||||||
"filetype"
|
|
||||||
''
|
|
||||||
];
|
|
||||||
y = [
|
|
||||||
''
|
|
||||||
{
|
|
||||||
"progress",
|
|
||||||
separator = { left = "" },
|
|
||||||
}
|
|
||||||
''
|
|
||||||
''
|
|
||||||
''
|
|
||||||
];
|
|
||||||
z = [
|
|
||||||
''
|
|
||||||
{
|
|
||||||
"location",
|
|
||||||
separator = { left = "" },
|
|
||||||
left_padding = 2
|
|
||||||
}
|
|
||||||
''
|
|
||||||
''
|
|
||||||
{
|
|
||||||
"fileformat",
|
|
||||||
color = {fg='black'},
|
|
||||||
symbols = {
|
|
||||||
unix = '', -- e712
|
|
||||||
dos = '', -- e70f
|
|
||||||
mac = '', -- e711
|
|
||||||
},
|
|
||||||
}
|
|
||||||
''
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
inactiveSection = {
|
|
||||||
a = [
|
|
||||||
''
|
|
||||||
"filename"
|
|
||||||
''
|
|
||||||
];
|
|
||||||
z = [
|
|
||||||
''
|
|
||||||
"location"
|
|
||||||
''
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
git.enable = true;
|
|
||||||
|
|
||||||
utility = {
|
|
||||||
vim-wakatime.enable = true;
|
|
||||||
surround.enable = true;
|
|
||||||
motion.leap = {
|
|
||||||
enable = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
lsp = {
|
|
||||||
enable = true;
|
|
||||||
lspSignature.enable = true;
|
|
||||||
lspconfig.enable = true;
|
|
||||||
formatOnSave = true;
|
|
||||||
mappings = {
|
|
||||||
addWorkspaceFolder = "<leader>wa";
|
|
||||||
codeAction = "<leader>a";
|
|
||||||
goToDeclaration = "gD";
|
|
||||||
goToDefinition = "gd";
|
|
||||||
hover = "K";
|
|
||||||
listImplementations = "gi";
|
|
||||||
listReferences = "gr";
|
|
||||||
listWorkspaceFolders = "<leader>wl";
|
|
||||||
nextDiagnostic = "<leader>k";
|
|
||||||
previousDiagnostic = "<leader>j";
|
|
||||||
openDiagnosticFloat = "<leader>e";
|
|
||||||
removeWorkspaceFolder = "<leader>wr";
|
|
||||||
renameSymbol = "<leader>r";
|
|
||||||
signatureHelp = "<C-k>";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
autocomplete.nvim-cmp = {
|
|
||||||
enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
autopairs.nvim-autopairs.enable = true;
|
|
||||||
|
|
||||||
languages = {
|
|
||||||
enableExtraDiagnostics = true;
|
|
||||||
enableFormat = true;
|
|
||||||
enableLSP = true;
|
|
||||||
enableTreesitter = true;
|
|
||||||
|
|
||||||
nix.enable = true;
|
|
||||||
clang.enable = true;
|
|
||||||
python.enable = true;
|
|
||||||
ts.enable = true;
|
|
||||||
css.enable = true;
|
|
||||||
typst.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
treesitter = {
|
|
||||||
enable = true;
|
|
||||||
fold = true;
|
|
||||||
context.enable = true;
|
|
||||||
grammars = [
|
|
||||||
pkgs.vimPlugins.nvim-treesitter.builtGrammars.nix
|
|
||||||
pkgs.vimPlugins.nvim-treesitter.builtGrammars.c
|
|
||||||
pkgs.vimPlugins.nvim-treesitter.builtGrammars.python
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
binds.whichKey.enable = true;
|
|
||||||
filetree.neo-tree.enable = true;
|
|
||||||
|
|
||||||
telescope.enable = true;
|
|
||||||
}
|
|
||||||
(lib.mkIf styleCfg.enable {
|
|
||||||
theme = {
|
|
||||||
enable = true;
|
|
||||||
name = "base16";
|
|
||||||
base16-colors = styleCfg.scheme.palette;
|
|
||||||
};
|
|
||||||
})
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
in {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [customNeovim.neovim];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,123 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
logo = builtins.fetchurl {
|
|
||||||
url = "https://raw.githubusercontent.com/gytis-ivaskevicius/high-quality-nix-content/refs/heads/master/emoji/nix-owo-transparent.png";
|
|
||||||
sha256 = "137k3i7z4va68v4rvrazy26szc7p2w59h7bc2h8japzjyj6xjs71";
|
|
||||||
};
|
|
||||||
in {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [pkgs.fastfetch];
|
|
||||||
files = {
|
|
||||||
".config/fastfetch/config.jsonc".text = builtins.toJSON {
|
|
||||||
logo = {
|
|
||||||
source = logo;
|
|
||||||
type = "kitty";
|
|
||||||
width = 33;
|
|
||||||
};
|
|
||||||
|
|
||||||
modules = [
|
|
||||||
{
|
|
||||||
type = "title";
|
|
||||||
color = {
|
|
||||||
user = "35";
|
|
||||||
host = "36";
|
|
||||||
};
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "separator";
|
|
||||||
string = "▔";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "os";
|
|
||||||
key = "╭─ ";
|
|
||||||
format = "{3} ({12})";
|
|
||||||
keyColor = "32";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "host";
|
|
||||||
key = "├─ ";
|
|
||||||
keyColor = "32";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "kernel";
|
|
||||||
key = "├─ ";
|
|
||||||
format = "{1} {2}";
|
|
||||||
keyColor = "32";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "shell";
|
|
||||||
key = "├─$ ";
|
|
||||||
format = "{1} {4}";
|
|
||||||
keyColor = "32";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "packages";
|
|
||||||
key = "├─ ";
|
|
||||||
keyColor = "32";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "uptime";
|
|
||||||
key = "╰─ ";
|
|
||||||
keyColor = "32";
|
|
||||||
}
|
|
||||||
"break"
|
|
||||||
{
|
|
||||||
type = "display";
|
|
||||||
key = "╭─ ";
|
|
||||||
keyColor = "33";
|
|
||||||
compactType = "original";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "de";
|
|
||||||
key = "├─ ";
|
|
||||||
keyColor = "33";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "wm";
|
|
||||||
key = "├─ ";
|
|
||||||
keyColor = "33";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "theme";
|
|
||||||
key = "├─ ";
|
|
||||||
keyColor = "33";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "icons";
|
|
||||||
key = "├─ ";
|
|
||||||
keyColor = "33";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "cursor";
|
|
||||||
key = "├─ ";
|
|
||||||
keyColor = "33";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "font";
|
|
||||||
key = "├─ ";
|
|
||||||
format = "{2}";
|
|
||||||
keyColor = "33";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
type = "terminal";
|
|
||||||
key = "╰─ ";
|
|
||||||
format = "{3}";
|
|
||||||
keyColor = "33";
|
|
||||||
}
|
|
||||||
"break"
|
|
||||||
{
|
|
||||||
type = "colors";
|
|
||||||
symbol = "block";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,170 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
toINI = lib.generators.toINI {};
|
|
||||||
|
|
||||||
betterfox = pkgs.fetchFromGitHub {
|
|
||||||
owner = "yokoffing";
|
|
||||||
repo = "betterfox";
|
|
||||||
rev = "e026ed7d3a763c5d3f96c2680d7bc3340831af4f";
|
|
||||||
hash = "sha256-hpkEO5BhMVtINQG8HN4xqfas/R6q5pYPZiFK8bilIDs=";
|
|
||||||
};
|
|
||||||
|
|
||||||
firefox = pkgs.wrapFirefox pkgs.firefox-esr-128-unwrapped {
|
|
||||||
extraPolicies = {
|
|
||||||
SearchEngines.Default = "SearxNG";
|
|
||||||
SearchEngines.Add = [
|
|
||||||
{
|
|
||||||
Name = "SearxNG";
|
|
||||||
URLTemplate = "https://search.nezia.dev/search?q={searchTerms}";
|
|
||||||
Method = "GET";
|
|
||||||
SuggestURLTemplate = "https://search.nezia.dev/autocompleter?q={searchTerms}";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
Name = "Nix Packages";
|
|
||||||
Alias = "@np";
|
|
||||||
URLTemplate = "https://search.nixos.org/packages?channel=unstable&query={searchTerms}";
|
|
||||||
Method = "GET";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
Name = "Nix Options";
|
|
||||||
Alias = "@no";
|
|
||||||
URLTemplate = "https://search.nixos.org/options?channel=unstable&query={searchTerms}";
|
|
||||||
Method = "GET";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
Name = "NixOS Wiki";
|
|
||||||
Alias = "@nw";
|
|
||||||
URLTemplate = "https://wiki.nixos.org/w/index.php?search={searchTerms}";
|
|
||||||
Method = "GET";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
Name = "Home Manager Options";
|
|
||||||
Alias = "@hmo";
|
|
||||||
URLTemplate = "https://home-manager-options.extranix.com/?query={searchTerms}&release=master";
|
|
||||||
Method = "GET";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
Name = "ProtonDB";
|
|
||||||
Alias = "@pdb";
|
|
||||||
URLTemplate = "https://www.protondb.com/search?q={searchTerms}";
|
|
||||||
Method = "GET";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
Name = "Noogle";
|
|
||||||
Alias = "@ng";
|
|
||||||
URLTemplate = "https://noogle.dev/q?term={searchTerms}";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
Name = "GitHub Nix";
|
|
||||||
Alias = "@ghn";
|
|
||||||
URLTemplate = "https://github.com/search?q=language:nix NOT is:fork {searchTerms}&type=code";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
DisableTelemetry = true;
|
|
||||||
DisablePocket = true;
|
|
||||||
DisableFeedbackCommands = true;
|
|
||||||
DisableFirefoxStudies = true;
|
|
||||||
OfferToSaveLogins = false;
|
|
||||||
OffertosaveloginsDefault = false;
|
|
||||||
PasswordManagerEnabled = false;
|
|
||||||
SearchSuggestEnabled = true;
|
|
||||||
|
|
||||||
# https://github.com/Sly-Harvey/NixOS/blob/f9da2691ea46565256ad757959cfc26ec6cee10d/modules/programs/browser/firefox/default.nix#L58-L163
|
|
||||||
"3rdparty".Extensions = {
|
|
||||||
"addon@darkreader.org" = {
|
|
||||||
permissions = ["internal:privateBrowsingAllowed"];
|
|
||||||
enabled = true;
|
|
||||||
automation = {
|
|
||||||
enabled = true;
|
|
||||||
behavior = "OnOff";
|
|
||||||
mode = "system";
|
|
||||||
};
|
|
||||||
detectDarkTheme = true;
|
|
||||||
enabledByDefault = true;
|
|
||||||
changeBrowserTheme = false;
|
|
||||||
enableForProtectedPages = true;
|
|
||||||
fetchNews = false;
|
|
||||||
previewNewDesign = true;
|
|
||||||
};
|
|
||||||
"uBlock0@raymondhill.net" = {
|
|
||||||
permissions = ["internal:privateBrowsingAllowed"];
|
|
||||||
advancedSettings = [
|
|
||||||
[
|
|
||||||
"userResourcesLocation"
|
|
||||||
"https://raw.githubusercontent.com/pixeltris/TwitchAdSolutions/master/video-swap-new/video-swap-new-ublock-origin.js"
|
|
||||||
]
|
|
||||||
];
|
|
||||||
adminSettings = {
|
|
||||||
userSettings = {
|
|
||||||
uiTheme = "dark";
|
|
||||||
advancedUserEnabled = true;
|
|
||||||
userFiltersTrusted = true;
|
|
||||||
importedLists = [
|
|
||||||
"https://raw.githubusercontent.com/laylavish/uBlockOrigin-HUGE-AI-Blocklist/main/list.txt"
|
|
||||||
];
|
|
||||||
selectedFilterLists = [
|
|
||||||
"FRA-0"
|
|
||||||
"adguard-cookies"
|
|
||||||
"adguard-mobile-app-banners"
|
|
||||||
"adguard-other-annoyances"
|
|
||||||
"adguard-popup-overlays"
|
|
||||||
"adguard-social"
|
|
||||||
"adguard-spyware-url"
|
|
||||||
"adguard-widgets"
|
|
||||||
"easylist"
|
|
||||||
"easylist-annoyances"
|
|
||||||
"easylist-chat"
|
|
||||||
"easylist-newsletters"
|
|
||||||
"easylist-notifications"
|
|
||||||
"easyprivacy"
|
|
||||||
"fanboy-cookiemonster"
|
|
||||||
"https://filters.adtidy.org/extension/ublock/filters/3.txt"
|
|
||||||
"https://github.com/DandelionSprout/adfilt/raw/master/LegitimateURLShortener.txt"
|
|
||||||
"plowe-0"
|
|
||||||
"ublock-annoyances"
|
|
||||||
"ublock-badware"
|
|
||||||
"ublock-cookies-adguard"
|
|
||||||
"ublock-cookies-easylist"
|
|
||||||
"ublock-filters"
|
|
||||||
"ublock-privacy"
|
|
||||||
"ublock-quick-fixes"
|
|
||||||
"ublock-unbreak"
|
|
||||||
"urlhaus-1"
|
|
||||||
"https://raw.githubusercontent.com/laylavish/uBlockOrigin-HUGE-AI-Blocklist/main/list.txt"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
in {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [firefox];
|
|
||||||
files = {
|
|
||||||
".mozilla/firefox/profiles.ini".text = toINI {
|
|
||||||
Profile0 = {
|
|
||||||
# creates lunarnova profile and sets it as default
|
|
||||||
Name = "${username}";
|
|
||||||
IsRelative = 1;
|
|
||||||
Path = "${username}";
|
|
||||||
Default = 1;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
".mozilla/firefox/${username}/user.js".text = builtins.concatStringsSep "\n" [
|
|
||||||
(builtins.readFile "${betterfox}/user.js")
|
|
||||||
(builtins.readFile "${betterfox}/Securefox.js")
|
|
||||||
(builtins.readFile "${betterfox}/Fastfox.js")
|
|
||||||
(builtins.readFile "${betterfox}/Peskyfox.js")
|
|
||||||
(builtins.readFile "${betterfox}/Smoothfox.js")
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,36 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkIf;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
in {
|
|
||||||
config = mkIf config.local.profiles.gaming.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [
|
|
||||||
pkgs.mangohud
|
|
||||||
pkgs.bolt-launcher
|
|
||||||
pkgs.ankama-launcher
|
|
||||||
pkgs.lutris
|
|
||||||
pkgs.qbittorrent
|
|
||||||
pkgs.protonplus
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
programs = {
|
|
||||||
steam = {
|
|
||||||
enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
gamemode.enable = true;
|
|
||||||
gamescope.enable = true;
|
|
||||||
|
|
||||||
coolercontrol = {
|
|
||||||
enable = true;
|
|
||||||
nvidiaSupport = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
{
|
|
||||||
imports = [
|
|
||||||
./land
|
|
||||||
|
|
||||||
./idle.nix
|
|
||||||
./lock.nix
|
|
||||||
./paper.nix
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,62 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
lib',
|
|
||||||
inputs,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib'.generators) toHyprConf;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
inherit (inputs.hypridle.packages.${pkgs.system}) hypridle;
|
|
||||||
|
|
||||||
hyprlock = "${inputs.hyprlock.packages.${pkgs.system}.hyprlock}/bin/hyprlock";
|
|
||||||
in {
|
|
||||||
config = lib.mkIf config.local.modules.hyprland.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [hypridle];
|
|
||||||
files = {
|
|
||||||
".config/hypr/hypridle.conf".text = toHyprConf {
|
|
||||||
attrs = {
|
|
||||||
general = {
|
|
||||||
lock_cmd = "pidof ${hyprlock} || ${hyprlock}";
|
|
||||||
unlock_cmd = "pkill --signal SIGUSR1 ${hyprlock}";
|
|
||||||
before_sleep_cmd = "loginctl lock-session";
|
|
||||||
after_sleep_cmd = "hyprctl dispatch dpms on";
|
|
||||||
};
|
|
||||||
|
|
||||||
listener = [
|
|
||||||
{
|
|
||||||
timeout = 300; # 5m
|
|
||||||
on-timeout = "loginctl lock-session";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
timeout = 330; # 5.5m
|
|
||||||
on-timeout = "hyprctl dipsatch dpms off";
|
|
||||||
on-resume = "hyprctl dispatch dpms on";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
timeout = 600; # 10m
|
|
||||||
on-timeout = "systemctl suspend";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
# needed when using uwsm as the session manager
|
|
||||||
systemd.user.services.hypridle = {
|
|
||||||
name = "hypridle";
|
|
||||||
after = ["graphical-session.target"];
|
|
||||||
description = "Hyprland's Idle Daemon";
|
|
||||||
wantedBy = ["graphical-session.target"];
|
|
||||||
restartTriggers = ["${config.hjem.users.${username}.files.".config/hypr/hypridle.conf".text}"];
|
|
||||||
serviceConfig = {
|
|
||||||
Type = "exec";
|
|
||||||
ExecStart = "${hypridle}/bin/hypridle";
|
|
||||||
Restart = "on-failure";
|
|
||||||
Slice = "background-graphical.slice";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,79 +0,0 @@
|
||||||
lib: let
|
|
||||||
# thanks https://github.com/fufexan/dotfiles/blob/c0b3c77d95ce1f574a87e7f7ead672ca0d951245/home/programs/wayland/hyprland/binds.nix#L16-L20
|
|
||||||
toggle = program: uwsm: let
|
|
||||||
prog = builtins.substring 0 14 program;
|
|
||||||
in "pkill ${prog} || ${lib.optionalString uwsm "uwsm app -- "} ${program}";
|
|
||||||
runOnce = program: "pgrep ${program} || uwsm app -- ${program}";
|
|
||||||
run = program: "uwsm app -- ${program}";
|
|
||||||
in {
|
|
||||||
"$mod" = "SUPER";
|
|
||||||
bindr = [
|
|
||||||
"$mod, SUPER_L, exec, ${toggle "anyrun" false}"
|
|
||||||
];
|
|
||||||
bind = [
|
|
||||||
"$mod, Return, exec, ${run "ghostty"}"
|
|
||||||
"$mod, n, exec, ${run "neovide"}"
|
|
||||||
"$mod, w, exec, ${run "firefox"}"
|
|
||||||
", Print, exec, ${runOnce "grimblast"} --notify --cursor copysave output"
|
|
||||||
"$mod, q, killactive"
|
|
||||||
"$mod SHIFT, q, exec, loginctl terminate-user ''"
|
|
||||||
"$mod, period, exec, ${toggle "walker -m emojis" false}" # not using uwsm as it already runs as a service
|
|
||||||
"CTRL, Print, exec, ${runOnce "grimblast"} --notify --cursor --freeze copysave area"
|
|
||||||
|
|
||||||
"$mod, h, movefocus, l"
|
|
||||||
"$mod, j, movefocus, d"
|
|
||||||
"$mod, k, movefocus, u"
|
|
||||||
"$mod, l, movefocus, r"
|
|
||||||
|
|
||||||
"$mod SHIFT, h, movewindow, l"
|
|
||||||
"$mod SHIFT, j, movewindow, d"
|
|
||||||
"$mod SHIFT, k, movewindow, u"
|
|
||||||
"$mod SHIFT, l, movewindow, r"
|
|
||||||
|
|
||||||
"$mod, 1, workspace, 1"
|
|
||||||
"$mod, 2, workspace, 2"
|
|
||||||
"$mod, 3, workspace, 3"
|
|
||||||
"$mod, 4, workspace, 4"
|
|
||||||
"$mod, 5, workspace, 5"
|
|
||||||
"$mod, 6, workspace, 6"
|
|
||||||
"$mod, 7, workspace, 7"
|
|
||||||
"$mod, 8, workspace, 8"
|
|
||||||
"$mod, 9, workspace, 9"
|
|
||||||
"$mod, 0, workspace, 10"
|
|
||||||
|
|
||||||
"$mod SHIFT, 1, movetoworkspacesilent, 1"
|
|
||||||
"$mod SHIFT, 2, movetoworkspacesilent, 2"
|
|
||||||
"$mod SHIFT, 3, movetoworkspacesilent, 3"
|
|
||||||
"$mod SHIFT, 4, movetoworkspacesilent, 4"
|
|
||||||
"$mod SHIFT, 5, movetoworkspacesilent, 5"
|
|
||||||
"$mod SHIFT, 6, movetoworkspacesilent, 6"
|
|
||||||
"$mod SHIFT, 7, movetoworkspacesilent, 7"
|
|
||||||
"$mod SHIFT, 8, movetoworkspacesilent, 8"
|
|
||||||
"$mod SHIFT, 9, movetoworkspacesilent, 9"
|
|
||||||
"$mod SHIFT, 0, movetoworkspacesilent, 10"
|
|
||||||
|
|
||||||
"$mod, t, togglefloating"
|
|
||||||
", F11, fullscreen, 0"
|
|
||||||
"$mod, f, fullscreen, 1"
|
|
||||||
|
|
||||||
"$mod, e, togglespecialworkspace, file_manager_gui"
|
|
||||||
"$mod SHIFT, e, togglespecialworkspace, file_manager_tui"
|
|
||||||
"$mod , c, togglespecialworkspace, calculator_gui"
|
|
||||||
"$mod, m, togglespecialworkspace, mixer_gui"
|
|
||||||
|
|
||||||
", XF86PowerOff, exec, ${toggle "wlogout" true}"
|
|
||||||
];
|
|
||||||
|
|
||||||
bindel = [
|
|
||||||
", XF86AudioRaiseVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%+"
|
|
||||||
", XF86AudioLowerVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-"
|
|
||||||
", XF86AudioMute, exec, wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle"
|
|
||||||
|
|
||||||
", XF86MonBrightnessUp, exec, brillo -q -u 300000 -A 5"
|
|
||||||
", XF86MonBrightnessDown, exec, brillo -q -u 300000 -U 5"
|
|
||||||
", XF86AudioMedia, exec, XDG_CURRENT_DESKTOP=gnome gnome-control-center"
|
|
||||||
];
|
|
||||||
binde = [
|
|
||||||
"$mod Alt, l, exec, loginctl lock-session"
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,183 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
lib',
|
|
||||||
inputs,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (builtins) toString;
|
|
||||||
inherit (lib) mkIf optionalAttrs optionalString;
|
|
||||||
inherit (lib'.generators) toHyprConf;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
|
|
||||||
styleCfg = config.local.style;
|
|
||||||
gnomeControlCenter = pkgs.gnome-control-center.overrideAttrs (old: {
|
|
||||||
postInstall =
|
|
||||||
old.postInstall
|
|
||||||
+ ''
|
|
||||||
dir=$out/share/applications
|
|
||||||
for panel in $dir/*
|
|
||||||
do
|
|
||||||
[ "$panel" = "$dir/gnome-network-panel.desktop" ] && continue
|
|
||||||
[ "$panel" = "$dir/gnome-bluetooth-panel.desktop" ] && continue
|
|
||||||
[ "$panel" = "$dir/gnome-wifi-panel.desktop" ] && continue
|
|
||||||
[ "$panel" = "$dir/gnome-wwan-panel.desktop" ] && continue
|
|
||||||
[ "$panel" = "$dir/gnome-sharing-panel.desktop" ] && continue
|
|
||||||
[ "$panel" = "$dir/gnome-wacom-panel.desktop" ] && continue
|
|
||||||
rm "$panel"
|
|
||||||
done
|
|
||||||
'';
|
|
||||||
});
|
|
||||||
in {
|
|
||||||
config = mkIf config.local.modules.hyprland.enable {
|
|
||||||
environment.systemPackages = [
|
|
||||||
inputs.hyprland-qtutils.packages.${pkgs.system}.default
|
|
||||||
];
|
|
||||||
|
|
||||||
programs.hyprland = {
|
|
||||||
enable = true;
|
|
||||||
package = inputs.hyprland.packages.${pkgs.system}.hyprland;
|
|
||||||
portalPackage = inputs.hyprland.packages.${pkgs.system}.xdg-desktop-portal-hyprland;
|
|
||||||
withUWSM = true;
|
|
||||||
systemd.setPath.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
# copied from https://github.com/linyinfeng/dotfiles/blob/91b0363b093303f57885cbae9da7f8a99bbb4432/nixos/profiles/graphical/niri/default.nix#L17-L29
|
|
||||||
security.pam.services.hyprlock.text = mkIf config.services.fprintd.enable ''
|
|
||||||
account required pam_unix.so
|
|
||||||
|
|
||||||
# check passwork before fprintd
|
|
||||||
auth sufficient pam_unix.so try_first_pass likeauth
|
|
||||||
auth sufficient ${pkgs.fprintd}/lib/security/pam_fprintd.so
|
|
||||||
auth required pam_deny.so
|
|
||||||
|
|
||||||
password sufficient pam_unix.so nullok yescrypt
|
|
||||||
|
|
||||||
session required pam_env.so conffile=/etc/pam/environment readenv=0
|
|
||||||
session required pam_unix.so
|
|
||||||
'';
|
|
||||||
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [
|
|
||||||
inputs.hyprwm-contrib.packages.${pkgs.system}.grimblast
|
|
||||||
gnomeControlCenter
|
|
||||||
];
|
|
||||||
files = {
|
|
||||||
".config/hypr/hyprland.conf".text = toHyprConf {
|
|
||||||
attrs =
|
|
||||||
{
|
|
||||||
xwayland = {
|
|
||||||
force_zero_scaling = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
env = [
|
|
||||||
];
|
|
||||||
|
|
||||||
cursor = {
|
|
||||||
no_hardware_cursors = 1;
|
|
||||||
};
|
|
||||||
|
|
||||||
monitor = [
|
|
||||||
"eDP-1, preferred, auto, 1.33"
|
|
||||||
"Unknown-1,disabled"
|
|
||||||
];
|
|
||||||
workspace = [
|
|
||||||
"special:terminal, on-created-empty:ghostty"
|
|
||||||
"special:file_manager_gui, on-created-empty:thunar"
|
|
||||||
"special:file_manager_tui, on-created-empty:ghostty -e yazi"
|
|
||||||
|
|
||||||
"special:calculator_gui, on-created-empty:qalculate-gtk"
|
|
||||||
"special:mixer_gui, on-created-empty:pavucontrol"
|
|
||||||
];
|
|
||||||
|
|
||||||
windowrulev2 = [
|
|
||||||
# fixes fullscreen windows (mostly games)
|
|
||||||
"stayfocused, initialtitle:^()$, initialclass:^(steam)$"
|
|
||||||
"minsize 1 1, initialtitle:^()$, initialclass:^(steam)$"
|
|
||||||
"maximize, initialtitle:^(\S+)$, initialclass:^(steamwebhelper)$"
|
|
||||||
|
|
||||||
"immediate, initialclass:^(steam_app_)(.*)$"
|
|
||||||
"fullscreen, initialclass:^(steam_app_)(.*)$"
|
|
||||||
|
|
||||||
# inhibit idle on every fullscreen app except games
|
|
||||||
"idleinhibit always, fullscreen:1,!initialclass:^(steam_app_)(.*)$"
|
|
||||||
];
|
|
||||||
|
|
||||||
render = {
|
|
||||||
explicit_sync = 1;
|
|
||||||
explicit_sync_kms = 1;
|
|
||||||
expand_undersized_textures = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
bezier = "overshot, 0.05, 0.9, 0.1, 1.1";
|
|
||||||
|
|
||||||
animations = {
|
|
||||||
enabled = true;
|
|
||||||
animation = [
|
|
||||||
"windows, 1, 5, overshot"
|
|
||||||
"windowsOut, 1, 5, default, popin 80%"
|
|
||||||
"windowsMove, 1, 5, default, popin 80%"
|
|
||||||
"fade, 1, 5, default"
|
|
||||||
"border, 1, 5, default"
|
|
||||||
"borderangle, 0, 8, default"
|
|
||||||
"workspaces, 0"
|
|
||||||
"specialWorkspace, 0"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
input = {
|
|
||||||
kb_options = "compose:ralt";
|
|
||||||
touchpad = {
|
|
||||||
natural_scroll = true;
|
|
||||||
scroll_factor = 0.8;
|
|
||||||
tap-to-click = true;
|
|
||||||
clickfinger_behavior = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
gestures = {
|
|
||||||
workspace_swipe = true;
|
|
||||||
workspace_swipe_direction_lock = false;
|
|
||||||
workspace_swipe_cancel_ratio = 0.15;
|
|
||||||
};
|
|
||||||
|
|
||||||
misc = {
|
|
||||||
force_default_wallpaper = 0;
|
|
||||||
disable_hyprland_logo = true;
|
|
||||||
middle_click_paste = false;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
// optionalAttrs styleCfg.enable {
|
|
||||||
general = {
|
|
||||||
border_size = 4;
|
|
||||||
"col.active_border" = "rgb(${lib.removePrefix "#" styleCfg.scheme.palette.base0E})";
|
|
||||||
};
|
|
||||||
decoration = {
|
|
||||||
rounding = 10;
|
|
||||||
blur.enabled = true;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
// import ./binds.nix lib;
|
|
||||||
};
|
|
||||||
".config/environment.d/${config.local.homeVars.userEnvFile}.conf".text =
|
|
||||||
''
|
|
||||||
GDK_SCALE="1"
|
|
||||||
''
|
|
||||||
+ optionalString styleCfg.enable ''
|
|
||||||
|
|
||||||
HYPRCURSOR_THEME="${styleCfg.cursorTheme.name}"
|
|
||||||
HYPRCURSOR_SIZE="${toString styleCfg.cursorTheme.size}"
|
|
||||||
XCURSOR_SIZE="${toString styleCfg.cursorTheme.size}"
|
|
||||||
|
|
||||||
''
|
|
||||||
+ optionalString config.local.modules.nvidia.enable ''
|
|
||||||
LIBVA_DRIVER_NAME="nvidia"
|
|
||||||
__GLX_VENDOR_LIBRARY_NAME="nvidia"
|
|
||||||
XDG_SESSION_TYPE="wayland"
|
|
||||||
GBM_BACKEND="nvidia-drm"
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,119 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
lib',
|
|
||||||
inputs,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mkIf;
|
|
||||||
inherit (lib'.generators) toHyprConf;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
inherit (inputs.hyprlock.packages.${pkgs.system}) hyprlock;
|
|
||||||
|
|
||||||
styleCfg = config.local.style;
|
|
||||||
rgbaPalette = builtins.mapAttrs (_: c: (lib'.rgba c 1)) styleCfg.scheme.palette;
|
|
||||||
in {
|
|
||||||
config = mkIf config.local.modules.hyprland.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [hyprlock];
|
|
||||||
files = {
|
|
||||||
".config/hypr/hyprlock.conf".text = toHyprConf {
|
|
||||||
attrs =
|
|
||||||
{
|
|
||||||
general = {
|
|
||||||
disable_loading_bar = true;
|
|
||||||
hide_cursor = true;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
// (with rgbaPalette;
|
|
||||||
lib.optionalAttrs styleCfg.enable {
|
|
||||||
background = [
|
|
||||||
{
|
|
||||||
path = "screenshot";
|
|
||||||
blur_passes = 3;
|
|
||||||
blur_size = 8;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
|
|
||||||
label = [
|
|
||||||
{
|
|
||||||
monitor = "";
|
|
||||||
text = "Layout: $LAYOUT";
|
|
||||||
font_size = 25;
|
|
||||||
color = base05;
|
|
||||||
|
|
||||||
position = "30, -30";
|
|
||||||
halign = "left";
|
|
||||||
valign = "top";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
monitor = "";
|
|
||||||
text = "$TIME";
|
|
||||||
font_size = 90;
|
|
||||||
color = base05;
|
|
||||||
|
|
||||||
position = "-30, 0";
|
|
||||||
halign = "right";
|
|
||||||
valign = "top";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
monitor = "";
|
|
||||||
text = "cmd[update:43200000] date +\"%A, %d %B %Y\"";
|
|
||||||
font_size = 25;
|
|
||||||
color = base05;
|
|
||||||
|
|
||||||
position = "-30, -150";
|
|
||||||
halign = "right";
|
|
||||||
valign = "top";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
|
|
||||||
image = {
|
|
||||||
monitor = "";
|
|
||||||
path = "${styleCfg.avatar}"; # Replace with your avatar path
|
|
||||||
size = 100;
|
|
||||||
border_color = base0D;
|
|
||||||
|
|
||||||
position = "0, 75";
|
|
||||||
halign = "center";
|
|
||||||
valign = "center";
|
|
||||||
};
|
|
||||||
|
|
||||||
input-field = [
|
|
||||||
{
|
|
||||||
monitor = "";
|
|
||||||
|
|
||||||
size = "300, 60";
|
|
||||||
outline_thickness = 4;
|
|
||||||
dots_size = 0.2;
|
|
||||||
dots_spacing = 0.2;
|
|
||||||
dots_center = true;
|
|
||||||
|
|
||||||
outer_color = base0D;
|
|
||||||
inner_color = base02;
|
|
||||||
font_color = base05;
|
|
||||||
|
|
||||||
fade_on_empty = false;
|
|
||||||
|
|
||||||
# the span elements still use #RRGGBB, so we use scheme directly
|
|
||||||
placeholder_text = "<span foreground=\"#${styleCfg.scheme.palette.base05}\"><i> Logged in as </i><span foreground=\"#${styleCfg.scheme.palette.base0D}\">$USER</span></span>";
|
|
||||||
|
|
||||||
hide_input = false;
|
|
||||||
check_color = base0D;
|
|
||||||
fail_color = base08;
|
|
||||||
|
|
||||||
fail_text = "<i>$FAIL <b>($ATTEMPTS)</b></i>";
|
|
||||||
capslock_color = base0E;
|
|
||||||
|
|
||||||
position = "0, -47";
|
|
||||||
halign = "center";
|
|
||||||
valign = "center";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
});
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,42 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
lib',
|
|
||||||
inputs,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib'.generators) toHyprConf;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
inherit (config.local.style) wallpaper;
|
|
||||||
inherit (inputs.hyprpaper.packages.${pkgs.system}) hyprpaper;
|
|
||||||
in {
|
|
||||||
config = lib.mkIf config.local.modules.hyprland.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [hyprpaper];
|
|
||||||
files = {
|
|
||||||
".config/hypr/hyprpaper.conf".text = toHyprConf {
|
|
||||||
attrs = {
|
|
||||||
preload = ["${wallpaper}"];
|
|
||||||
wallpaper = [", ${wallpaper}"];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
systemd.user.services.hyprpaper = {
|
|
||||||
name = "hyprpaper";
|
|
||||||
after = ["graphical-session.target"];
|
|
||||||
description = "Fast, IPC-controlled wallpaper utility for Hyprland.";
|
|
||||||
documentation = ["https://wiki.hyprland.org/Hypr-Ecosystem/hyprpaper/"];
|
|
||||||
wantedBy = ["graphical-session.target"];
|
|
||||||
restartTriggers = ["${config.hjem.users.${username}.files.".config/hypr/hyprpaper.conf".text}"];
|
|
||||||
serviceConfig = {
|
|
||||||
Type = "simple";
|
|
||||||
ExecStart = "${hyprpaper}/bin/hyprpaper";
|
|
||||||
Restart = "on-failure";
|
|
||||||
Slice = "background-graphical.slice";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,23 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
in {
|
|
||||||
imports = [
|
|
||||||
./tidal-hifi.nix
|
|
||||||
./zathura.nix
|
|
||||||
];
|
|
||||||
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username}.packages = [
|
|
||||||
pkgs.gnome-calculator
|
|
||||||
pkgs.gthumb
|
|
||||||
pkgs.spotify
|
|
||||||
pkgs.stremio
|
|
||||||
pkgs.celluloid
|
|
||||||
];
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,201 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
styleCfg = config.local.style;
|
|
||||||
in {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [pkgs.tidal-hifi];
|
|
||||||
files = {
|
|
||||||
# based on https://github.com/rose-pine/tidal. adapted to work with base16 colors.
|
|
||||||
"tidal-hifi/themes/base16.css".text = with styleCfg.scheme.palette;
|
|
||||||
lib.mkIf styleCfg.enable ''
|
|
||||||
:root {
|
|
||||||
--glass-white-1: ${base05};
|
|
||||||
--glass-white-1-hover: ${base06};
|
|
||||||
--glass-white-2: ${base07};
|
|
||||||
--glass-white-2-hover: ${base08};
|
|
||||||
--glass-white-3: ${base07};
|
|
||||||
--glass-white-4: ${base04};
|
|
||||||
--glass-white-5: ${base04};
|
|
||||||
--glass-white-6: ${base05};
|
|
||||||
--snow-white: ${base07};
|
|
||||||
--snow-white-hover: ${base08};
|
|
||||||
--gray-4: ${base00};
|
|
||||||
--gray-5: ${base02};
|
|
||||||
--gray-6: ${base03};
|
|
||||||
--gray-7: ${base04};
|
|
||||||
--cyan-blue: ${base0D};
|
|
||||||
--cyan-blue-hover: ${base0C};
|
|
||||||
--glass-cyan-1: ${base04};
|
|
||||||
--glass-cyan-2: ${base05};
|
|
||||||
--glass-cyan-3: ${base06};
|
|
||||||
--master-gold: ${base0E};
|
|
||||||
--master-gold-hover: ${base08};
|
|
||||||
--glass-master-gold: ${base05};
|
|
||||||
--glass-master-gold-2: ${base06};
|
|
||||||
--raspberry-pink: ${base08};
|
|
||||||
--raspberry-pink-lighter: ${base09};
|
|
||||||
--black: ${base00};
|
|
||||||
--midnight-black: ${base00};
|
|
||||||
--controls-overlay: ${base03};
|
|
||||||
--duration-overlay: ${base02};
|
|
||||||
--background-dark: ${base00};
|
|
||||||
--hoverLighten: brightness(130%);
|
|
||||||
--hoverDarken: brightness(70%);
|
|
||||||
--hoverTransition: filter 0.15s ease;
|
|
||||||
--scrollbar-track: ${base03};
|
|
||||||
--scrollbar-thumb: ${base00};
|
|
||||||
--lighten-25: ${base01};
|
|
||||||
--red-alert: ${base08};
|
|
||||||
--user-profile-linear-gradient: linear-gradient(160deg,${base0D} 1.22%,${base0C} 40.51%,${base00} 79.07%);
|
|
||||||
--wave-border-radius--none: 0px;
|
|
||||||
--wave-border-radius--extra-small: 4px;
|
|
||||||
--wave-border-radius--small: 8px;
|
|
||||||
--wave-border-radius--regular: 12px;
|
|
||||||
--wave-border-radius--full: 1000px;
|
|
||||||
--wave-color-material-dark: ${base00}80;
|
|
||||||
--wave-color-material-light: ${base04}33;
|
|
||||||
--wave-color-opacity-accent-dark-ultra-thick: ${base0C}cc;
|
|
||||||
--wave-color-opacity-accent-darkest-ultra-thick: ${base01};
|
|
||||||
--wave-color-opacity-accent-fill-regular: ${base0C}66;
|
|
||||||
--wave-color-opacity-accent-fill-thin: ${base0C}33;
|
|
||||||
--wave-color-opacity-accent-fill-ultra-thick: ${base0C}cc;
|
|
||||||
--wave-color-opacity-accent-fill-ultra-thin: ${base0C}1a;
|
|
||||||
--wave-color-opacity-base-bright-thick: ${base00}99;
|
|
||||||
--wave-color-opacity-base-bright-thin: ${base00}33;
|
|
||||||
--wave-color-opacity-base-bright-transparent: ${base00};
|
|
||||||
--wave-color-opacity-base-bright-ultra-thick: ${base00}cc;
|
|
||||||
--wave-color-opacity-base-brighter-ultra-thick: ${base01}cc;
|
|
||||||
--wave-color-opacity-base-brightest-regular: ${base02}66;
|
|
||||||
--wave-color-opacity-base-brightest-thin: ${base02}33;
|
|
||||||
--wave-color-opacity-base-brightest-ultra-thin: ${base02}1a;
|
|
||||||
--wave-color-opacity-base-fill-regular: ${base00}66;
|
|
||||||
--wave-color-opacity-base-fill-thick: ${base00}99;
|
|
||||||
--wave-color-opacity-base-fill-thin: ${base00}33;
|
|
||||||
--wave-color-opacity-base-fill-transparent: #000;
|
|
||||||
--wave-color-opacity-base-fill-ultra-thick: ${base00}cc;
|
|
||||||
--wave-color-opacity-base-fill-ultra-thin: ${base00}1a;
|
|
||||||
--wave-color-opacity-contrast-fill-regular: ${base07}66;
|
|
||||||
--wave-color-opacity-contrast-fill-thick: ${base07}99;
|
|
||||||
--wave-color-opacity-contrast-fill-thin: ${base07}33;
|
|
||||||
--wave-color-opacity-contrast-fill-transparent: #fff;
|
|
||||||
--wave-color-opacity-contrast-fill-ultra-thick: ${base07}cc;
|
|
||||||
--wave-color-opacity-contrast-fill-ultra-thin: ${base07}1a;
|
|
||||||
--wave-color-opacity-rainbow-blue-thin: ${base0D}33;
|
|
||||||
--wave-color-opacity-rainbow-yellow-fill-regular: ${base0E}66;
|
|
||||||
--wave-color-opacity-rainbow-yellow-fill-thin: ${base0E}33;
|
|
||||||
--wave-color-opacity-rainbow-yellow-fill-ultra-thick: ${base0E}cc;
|
|
||||||
--wave-color-opacity-rainbow-yellow-fill-ultra-thin: ${base0E}1a;
|
|
||||||
--wave-color-opacity-special-fill-regular: ${base0E}66;
|
|
||||||
--wave-color-opacity-special-fill-thin: ${base0E}33;
|
|
||||||
--wave-color-opacity-special-fill-ultra-thick: ${base0E}cc;
|
|
||||||
--wave-color-opacity-special-fill-ultra-thin: ${base0E}1a;
|
|
||||||
--wave-color-services-facebook: ${base0D};
|
|
||||||
--wave-color-services-instagram-red: ${base08};
|
|
||||||
--wave-color-services-mtn: ${base0E};
|
|
||||||
--wave-color-services-musix-orange: ${base09};
|
|
||||||
--wave-color-services-musix-pink: ${base0E};
|
|
||||||
--wave-color-services-play: ${base0C};
|
|
||||||
--wave-color-services-plus: ${base0B};
|
|
||||||
--wave-color-services-snapchat: ${base0A};
|
|
||||||
--wave-color-services-sprint: ${base0A};
|
|
||||||
--wave-color-services-t-mobile: ${base08};
|
|
||||||
--wave-color-services-tik-tok-blue: ${base0D};
|
|
||||||
--wave-color-services-tik-tok-red: ${base08};
|
|
||||||
--wave-color-services-twitter: ${base0D};
|
|
||||||
--wave-color-services-viacom-1: ${base0D};
|
|
||||||
--wave-color-services-viacom-2: ${base0E};
|
|
||||||
--wave-color-services-viacom-3: ${base08};
|
|
||||||
--wave-color-services-viacom-4: ${base09};
|
|
||||||
--wave-color-services-viacom-5: ${base0E};
|
|
||||||
--wave-color-services-vivo: ${base0E};
|
|
||||||
--wave-color-services-vodafone: ${base08};
|
|
||||||
--wave-color-services-waze: ${base0D};
|
|
||||||
--wave-color-solid-accent-bright: ${base0D};
|
|
||||||
--wave-color-solid-accent-brighter: ${base0D};
|
|
||||||
--wave-color-solid-accent-dark: ${base0C};
|
|
||||||
--wave-color-solid-accent-darker: ${base01};
|
|
||||||
--wave-color-solid-accent-darkest: ${base00};
|
|
||||||
--wave-color-solid-accent-fill: ${base0D};
|
|
||||||
--wave-color-solid-base-bright: ${base00};
|
|
||||||
--wave-color-solid-base-brighter: ${base01};
|
|
||||||
--wave-color-solid-base-brightest: ${base02};
|
|
||||||
--wave-color-solid-base-fill: ${base00};
|
|
||||||
--wave-color-solid-contrast-dark: ${base07};
|
|
||||||
--wave-color-solid-contrast-darker: ${base06};
|
|
||||||
--wave-color-solid-contrast-darkest: ${base05};
|
|
||||||
--wave-color-solid-contrast-fill: ${base07};
|
|
||||||
--wave-color-solid-rainbow-blue-fill: ${base0D};
|
|
||||||
--wave-color-solid-rainbow-green-brighter: ${base0D};
|
|
||||||
--wave-color-solid-rainbow-green-dark: ${base0C};
|
|
||||||
--wave-color-solid-rainbow-green-darker: ${base0C};
|
|
||||||
--wave-color-solid-rainbow-green-darkest: ${base01};
|
|
||||||
--wave-color-solid-rainbow-green-fill: ${base0D};
|
|
||||||
--wave-color-solid-rainbow-orange-fill: ${base09};
|
|
||||||
--wave-color-solid-rainbow-purple-fill: ${base0E};
|
|
||||||
--wave-color-solid-rainbow-red-bright: ${base08};
|
|
||||||
--wave-color-solid-rainbow-red-brighter: ${base08};
|
|
||||||
--wave-color-solid-rainbow-red-dark: ${base09};
|
|
||||||
--wave-color-solid-rainbow-red-darker: ${base01};
|
|
||||||
--wave-color-solid-rainbow-red-darkest: ${base00};
|
|
||||||
--wave-color-solid-rainbow-red-fill: ${base08};
|
|
||||||
--wave-color-solid-rainbow-yellow-bright: ${base0A};
|
|
||||||
--wave-color-solid-rainbow-yellow-brighter: ${base06};
|
|
||||||
--wave-color-solid-rainbow-yellow-dark: ${base09};
|
|
||||||
--wave-color-solid-rainbow-yellow-darker: ${base01};
|
|
||||||
--wave-color-solid-rainbow-yellow-darkest: ${base00};
|
|
||||||
--wave-color-solid-rainbow-yellow-fill: ${base0A};
|
|
||||||
--wave-color-solid-special-bright: ${base09};
|
|
||||||
--wave-color-solid-special-brighter: ${base06};
|
|
||||||
--wave-color-solid-special-dark: ${base09};
|
|
||||||
--wave-color-solid-special-darker: ${base09};
|
|
||||||
--wave-color-solid-special-darkest: ${base00};
|
|
||||||
--wave-color-solid-special-fill: ${base0E};
|
|
||||||
--wave-color-solid-warning-bright: ${base08};
|
|
||||||
--wave-color-solid-warning-brighter: ${base09};
|
|
||||||
--wave-color-solid-warning-dark: ${base09};
|
|
||||||
--wave-color-solid-warning-darker: ${base01};
|
|
||||||
--wave-color-solid-warning-darkest: ${base00};
|
|
||||||
--wave-color-solid-warning-fill: ${base08};
|
|
||||||
--wave-color-text-disabled: ${base02};
|
|
||||||
--wave-color-text-link: ${base0D};
|
|
||||||
--wave-color-text-main: ${base07};
|
|
||||||
--wave-color-text-placeholder: ${base02};
|
|
||||||
--wave-color-text-secondary: ${base06};
|
|
||||||
--wave-color-text-tertiary: ${base05};
|
|
||||||
--wave-font-weight--bold: 700;
|
|
||||||
--wave-font-weight--demi: 600;
|
|
||||||
--wave-font-weight--medium: 500;
|
|
||||||
--wave-opacity--ultra-thin: .05;
|
|
||||||
--wave-opacity--thin: .1;
|
|
||||||
--wave-opacity--regular: .4;
|
|
||||||
--wave-opacity--thick: .6;
|
|
||||||
--wave-opacity--ultra-thick: .8;
|
|
||||||
--wave-spacing--extra-extra-large: 64px;
|
|
||||||
--wave-spacing--extra-large: 40px;
|
|
||||||
--wave-spacing--large: 24px;
|
|
||||||
--wave-spacing--medium: 20px;
|
|
||||||
--wave-spacing--regular: 16px;
|
|
||||||
--wave-spacing--small: 12px;
|
|
||||||
--wave-spacing--extra-small: 8px;
|
|
||||||
--wave-spacing--extra-extra-small: 4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.wave-text-caption-demi, .tidal-ui__v-stack {
|
|
||||||
color: var(--wave-color-solid-accent-bright) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.tidal-ui__icon {
|
|
||||||
fill: var(--wave-color-solid-rainbow-purple-fill) !important;
|
|
||||||
stroke: var(--wave-color-solid-rainbow-purple-fill) !important;
|
|
||||||
}
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,31 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
toZathura = attrs:
|
|
||||||
builtins.concatStringsSep "\n"
|
|
||||||
(lib.mapAttrsToList (option: value: "set ${option} \"${toString value}\"") attrs);
|
|
||||||
in {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [pkgs.zathura];
|
|
||||||
files = {
|
|
||||||
".config/zathura/zathurarc".text = toZathura {
|
|
||||||
font = "sans-serif 12";
|
|
||||||
selection-notification = true;
|
|
||||||
|
|
||||||
selection-clipboard = "clipboard";
|
|
||||||
adjust-open = "best-fit";
|
|
||||||
pages-per-row = "1";
|
|
||||||
scroll-page-aware = "true";
|
|
||||||
scroll-full-overlap = "0.01";
|
|
||||||
scroll-step = "100";
|
|
||||||
zoom-min = "10";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,40 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (builtins) toJSON;
|
|
||||||
inherit (lib) mkIf;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
in {
|
|
||||||
config = mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = with pkgs; [
|
|
||||||
entr
|
|
||||||
fractal
|
|
||||||
fzf
|
|
||||||
geary
|
|
||||||
hyfetch
|
|
||||||
imhex
|
|
||||||
logisim-evolution
|
|
||||||
mission-center
|
|
||||||
obsidian
|
|
||||||
playerctl
|
|
||||||
proton-pass
|
|
||||||
qalculate-gtk
|
|
||||||
simple-scan
|
|
||||||
wl-clipboard
|
|
||||||
];
|
|
||||||
|
|
||||||
files = {
|
|
||||||
".config/hyfetch.json".text = toJSON {
|
|
||||||
preset = "nonbinary";
|
|
||||||
mode = "rgb";
|
|
||||||
backend = "fastfetch";
|
|
||||||
color_align.mode = "horizontal";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
imports = [
|
|
||||||
./foot.nix
|
|
||||||
./ghostty.nix
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,56 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) optionalAttrs;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
|
|
||||||
styleCfg = config.local.style;
|
|
||||||
# because someone thought this was a great idea: https://github.com/tinted-theming/schemes/commit/61058a8d2e2bd4482b53d57a68feb56cdb991f0b
|
|
||||||
palette = builtins.mapAttrs (_: color: lib.removePrefix "#" color) styleCfg.scheme.palette;
|
|
||||||
toINI = lib.generators.toINI {};
|
|
||||||
mkColors = palette: {
|
|
||||||
background = palette.base00;
|
|
||||||
foreground = palette.base05;
|
|
||||||
regular0 = palette.base00;
|
|
||||||
regular1 = palette.base08;
|
|
||||||
regular2 = palette.base0B;
|
|
||||||
regular3 = palette.base0A;
|
|
||||||
regular4 = palette.base0D;
|
|
||||||
regular5 = palette.base0E;
|
|
||||||
regular6 = palette.base0C;
|
|
||||||
regular7 = palette.base05;
|
|
||||||
bright0 = palette.base02;
|
|
||||||
bright1 = palette.base08;
|
|
||||||
bright2 = palette.base0B;
|
|
||||||
bright3 = palette.base0A;
|
|
||||||
bright4 = palette.base0D;
|
|
||||||
bright5 = palette.base0E;
|
|
||||||
bright6 = palette.base0C;
|
|
||||||
bright7 = palette.base07;
|
|
||||||
"16" = palette.base09;
|
|
||||||
"17" = palette.base0F;
|
|
||||||
"18" = palette.base01;
|
|
||||||
"19" = palette.base02;
|
|
||||||
"20" = palette.base04;
|
|
||||||
"21" = palette.base06;
|
|
||||||
};
|
|
||||||
in {
|
|
||||||
config = lib.mkIf config.local.modules.hyprland.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [pkgs.foot];
|
|
||||||
files = {
|
|
||||||
".config/foot/foot.ini".text = toINI {
|
|
||||||
main = {
|
|
||||||
term = "xterm-256color";
|
|
||||||
font = "monospace:size=14";
|
|
||||||
shell = "${pkgs.nushell}/bin/nu";
|
|
||||||
};
|
|
||||||
colors = optionalAttrs styleCfg.enable (mkColors palette);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,100 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (lib) mapAttrs mkIf mkMerge optionalAttrs removePrefix;
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
toINI = lib.generators.toINIWithGlobalSection {listsAsDuplicateKeys = true;};
|
|
||||||
styleCfg = config.local.style;
|
|
||||||
|
|
||||||
prefix = "ctrl+a";
|
|
||||||
|
|
||||||
mkGhosttyTheme = palette: let
|
|
||||||
colors = mapAttrs (_: value: removePrefix "#" value) palette;
|
|
||||||
in {
|
|
||||||
palette = [
|
|
||||||
"0=#${colors.base00}"
|
|
||||||
"1=#${colors.base08}"
|
|
||||||
"2=#${colors.base0B}"
|
|
||||||
"3=#${colors.base0A}"
|
|
||||||
"4=#${colors.base0D}"
|
|
||||||
"5=#${colors.base0E}"
|
|
||||||
"6=#${colors.base0C}"
|
|
||||||
"7=#${colors.base05}"
|
|
||||||
"8=#${colors.base02}"
|
|
||||||
"9=#${colors.base08}"
|
|
||||||
"10=#${colors.base0B}"
|
|
||||||
"11=#${colors.base0A}"
|
|
||||||
"12=#${colors.base0D}"
|
|
||||||
"13=#${colors.base0E}"
|
|
||||||
"14=#${colors.base0C}"
|
|
||||||
"15=#${colors.base07}"
|
|
||||||
"16=#${colors.base09}"
|
|
||||||
"17=#${colors.base0F}"
|
|
||||||
"18=#${colors.base01}"
|
|
||||||
"19=#${colors.base02}"
|
|
||||||
"20=#${colors.base04}"
|
|
||||||
"21=#${colors.base06}"
|
|
||||||
];
|
|
||||||
background = colors.base00;
|
|
||||||
foreground = colors.base05;
|
|
||||||
cursor-color = colors.base06;
|
|
||||||
selection-background = colors.base02;
|
|
||||||
selection-foreground = colors.base05;
|
|
||||||
};
|
|
||||||
in {
|
|
||||||
config = mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
files = mkMerge [
|
|
||||||
{
|
|
||||||
".config/ghostty/config".text =
|
|
||||||
toINI
|
|
||||||
{
|
|
||||||
globalSection = {
|
|
||||||
font-family = ["monospace" "Symbols Nerd Font"];
|
|
||||||
font-size = 14;
|
|
||||||
gtk-single-instance = true;
|
|
||||||
gtk-adwaita = false;
|
|
||||||
confirm-close-surface = false;
|
|
||||||
|
|
||||||
keybind = [
|
|
||||||
"${prefix}>c=new_tab"
|
|
||||||
"${prefix}>p=move_tab:-1"
|
|
||||||
"${prefix}>n=move_tab:1"
|
|
||||||
|
|
||||||
"${prefix}>\\=new_split:right"
|
|
||||||
"${prefix}>-=new_split:down"
|
|
||||||
"${prefix}>h=goto_split:left"
|
|
||||||
"${prefix}>j=goto_split:bottom"
|
|
||||||
"${prefix}>k=goto_split:top"
|
|
||||||
"${prefix}>l=goto_split:right"
|
|
||||||
"${prefix}>shift+h=resize_split:left,10"
|
|
||||||
"${prefix}>shift+j=resize_split:down,10"
|
|
||||||
"${prefix}>shift+k=resize_split:up,10"
|
|
||||||
"${prefix}>shift+l=resize_split:right,11"
|
|
||||||
"${prefix}>z=toggle_split_zoom"
|
|
||||||
];
|
|
||||||
|
|
||||||
adw-toolbar-style = "flat";
|
|
||||||
gtk-tabs-location = "bottom";
|
|
||||||
gtk-wide-tabs = false;
|
|
||||||
window-decoration = false;
|
|
||||||
|
|
||||||
linux-cgroup = "always";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
(optionalAttrs styleCfg.enable
|
|
||||||
{
|
|
||||||
".config/ghostty/config".text = toINI {
|
|
||||||
globalSection.theme = "base16";
|
|
||||||
};
|
|
||||||
".config/ghostty/themes/base16".text = toINI {globalSection = mkGhosttyTheme styleCfg.scheme.palette;};
|
|
||||||
})
|
|
||||||
];
|
|
||||||
packages = [pkgs.ghostty];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,31 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
inherit (config.local.homeVars) userEnvFile;
|
|
||||||
toConf = attrs:
|
|
||||||
builtins.concatStringsSep "\n"
|
|
||||||
(lib.mapAttrsToList (option: value: "--${option}=\"${value}\"") attrs);
|
|
||||||
in {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = [
|
|
||||||
pkgs.bat
|
|
||||||
pkgs.bat-extras.batman
|
|
||||||
];
|
|
||||||
files = {
|
|
||||||
".config/bat/config".text = toConf {
|
|
||||||
theme = "base16";
|
|
||||||
};
|
|
||||||
|
|
||||||
".config/environment.d/${userEnvFile}.conf".text = ''
|
|
||||||
MANPAGER = "sh -c 'col -bx | bat --language man' "
|
|
||||||
MANROFFOPT = "-c"
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
{
|
|
||||||
imports = [
|
|
||||||
./bat.nix
|
|
||||||
./direnv.nix
|
|
||||||
./git.nix
|
|
||||||
./misc.nix
|
|
||||||
# ./tmux.nix
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
programs.direnv.enable = true;
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,29 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
inherit (config.local.homeVars) signingKey;
|
|
||||||
toINI = lib.generators.toINI {};
|
|
||||||
in {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = with pkgs; [git lazygit];
|
|
||||||
files = {
|
|
||||||
".config/git/config".text = toINI {
|
|
||||||
user = {
|
|
||||||
name = "Anthony Rodriguez";
|
|
||||||
email = "anthony@nezia.dev";
|
|
||||||
signingkey = signingKey;
|
|
||||||
};
|
|
||||||
commit.gpgsign = true;
|
|
||||||
tag.gpgsign = true;
|
|
||||||
gpg.format = "ssh";
|
|
||||||
push.autoSetupRemote = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,26 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
inherit (config.local.systemVars) username;
|
|
||||||
in {
|
|
||||||
config = lib.mkIf config.local.profiles.desktop.enable {
|
|
||||||
hjem.users.${username} = {
|
|
||||||
packages = with pkgs; [
|
|
||||||
# archives
|
|
||||||
zip
|
|
||||||
unzip
|
|
||||||
unrar
|
|
||||||
|
|
||||||
# utils
|
|
||||||
comma
|
|
||||||
fd
|
|
||||||
file
|
|
||||||
ripgrep
|
|
||||||
yazi
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue