refactor: inputs/ --> {sys,home}/
This commit is contained in:
parent
8f22a24963
commit
f77c627980
225 changed files with 77 additions and 88 deletions
7
home/modules/desktop/media/default.nix
Normal file
7
home/modules/desktop/media/default.nix
Normal file
|
|
@ -0,0 +1,7 @@
|
|||
{
|
||||
imports = [
|
||||
./video
|
||||
./image
|
||||
./music
|
||||
];
|
||||
}
|
||||
13
home/modules/desktop/media/image/default.nix
Normal file
13
home/modules/desktop/media/image/default.nix
Normal file
|
|
@ -0,0 +1,13 @@
|
|||
{ lib, ... }:
|
||||
{
|
||||
imports = [
|
||||
./imv
|
||||
];
|
||||
|
||||
options.homeModules.desktop.media.image = {
|
||||
imv = {
|
||||
enable = lib.mkEnableOption "Enable imv image viewer";
|
||||
};
|
||||
};
|
||||
|
||||
}
|
||||
13
home/modules/desktop/media/image/imv/default.nix
Normal file
13
home/modules/desktop/media/image/imv/default.nix
Normal file
|
|
@ -0,0 +1,13 @@
|
|||
{ lib, config, ... }:
|
||||
let
|
||||
cfg = config.homeModules.desktop.media.image.imv;
|
||||
in
|
||||
{
|
||||
config = lib.mkIf cfg.enable {
|
||||
programs = {
|
||||
imv = {
|
||||
enable = true;
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
||||
17
home/modules/desktop/media/music/default.nix
Normal file
17
home/modules/desktop/media/music/default.nix
Normal file
|
|
@ -0,0 +1,17 @@
|
|||
{ lib, ... }:
|
||||
{
|
||||
imports = [
|
||||
#./spotify --- still needs to be implemented
|
||||
./easyeffects
|
||||
./tui
|
||||
];
|
||||
|
||||
options.homeModules.desktop.media.music = {
|
||||
tui = {
|
||||
enable = lib.mkEnableOption "Enable tui music";
|
||||
};
|
||||
spotify = {
|
||||
enable = lib.mkEnableOption "Enable spotify";
|
||||
};
|
||||
};
|
||||
}
|
||||
15
home/modules/desktop/media/music/easyeffects/default.nix
Normal file
15
home/modules/desktop/media/music/easyeffects/default.nix
Normal file
|
|
@ -0,0 +1,15 @@
|
|||
{lib, config, ... }:
|
||||
|
||||
let
|
||||
cfg = config.homeModules.desktop.media.music.easyeffects;
|
||||
inherit (lib) mkIf mkEnableOption;
|
||||
in
|
||||
|
||||
{
|
||||
options.homeModules.desktop.media.music.easyeffects.enable = mkEnableOption "Enable easy effects home module";
|
||||
config = mkIf cfg.enable {
|
||||
services.easyeffects = {
|
||||
enable = true;
|
||||
};
|
||||
};
|
||||
}
|
||||
122
home/modules/desktop/media/music/tui/default.nix
Normal file
122
home/modules/desktop/media/music/tui/default.nix
Normal file
|
|
@ -0,0 +1,122 @@
|
|||
{ pkgs, config, lib, ... }:
|
||||
|
||||
let
|
||||
inherit (config.colorscheme) palette;
|
||||
cfg = config.homeModules.desktop.media.music.tui;
|
||||
zellij = config.homeModules.console.multiplexer.zellij;
|
||||
spotify-cli = pkgs.spotify-player.override {
|
||||
withImage = false;
|
||||
withSixel = false;
|
||||
};
|
||||
in
|
||||
|
||||
{
|
||||
|
||||
|
||||
config = lib.mkIf cfg.enable {
|
||||
home.packages = with pkgs; [
|
||||
termusic
|
||||
spotify-cli
|
||||
alsa-utils
|
||||
mpv
|
||||
];
|
||||
programs.cava = {
|
||||
enable = true;
|
||||
settings = {
|
||||
general.framerate = 60;
|
||||
color = {
|
||||
gradient = 1;
|
||||
gradient_count = 5;
|
||||
gradient_color_1 = "'#${palette.base0A}'";
|
||||
gradient_color_2 = "'#${palette.base0B}'";
|
||||
gradient_color_3 = "'#${palette.base0C}'";
|
||||
gradient_color_4 = "'#${palette.base0D}'";
|
||||
gradient_color_5 = "'#${palette.base0E}'";
|
||||
};
|
||||
};
|
||||
};
|
||||
xdg.configFile."spotify-player/app.toml".text = /* toml */ ''
|
||||
theme = "default"
|
||||
client_id = "fc4c3656d7cc4a7ea70c6080965f8b1a"
|
||||
client_port = 8080
|
||||
tracks_playback_limit = 50
|
||||
playback_format = "{track} • {artists}\n{album}\n{metadata}"
|
||||
notify_format = { summary = "{track} • {artists}", body = "{album}" }
|
||||
app_refresh_duration_in_ms = 32
|
||||
playback_refresh_duration_in_ms = 0
|
||||
page_size_in_rows = 20
|
||||
enable_media_control = false
|
||||
enable_streaming = "Always"
|
||||
enable_notify = true
|
||||
enable_cover_image_cache = false
|
||||
notify_streaming_only = false
|
||||
default_device = "${config.home.sessionVariables.HN}"
|
||||
play_icon = "▶"
|
||||
pause_icon = "▌▌"
|
||||
liked_icon = "♥"
|
||||
playback_window_position = "Top"
|
||||
cover_img_length = 9
|
||||
cover_img_width = 5
|
||||
playback_window_width = 6
|
||||
|
||||
[device]
|
||||
name = "${config.home.sessionVariables.HN}"
|
||||
device_type = "speaker"
|
||||
volume = 100
|
||||
bitrate = 320
|
||||
audio_cache = false
|
||||
normalization = false
|
||||
'';
|
||||
|
||||
xdg.configFile."zellij/layouts/music.kdl".text = lib.mkIf zellij.enable /* kdl */ ''
|
||||
layout {
|
||||
default_tab_template {
|
||||
pane size=2 borderless=true {
|
||||
plugin location="file:${pkgs.zjstatus}/bin/zjstatus.wasm" {
|
||||
format_left "{mode}"
|
||||
format_right "{session} {datetime}"
|
||||
format_center "#[fg=#89B4FA,bold] {tabs}"
|
||||
format_space ""
|
||||
|
||||
border_enabled "true"
|
||||
border_char "─"
|
||||
border_format "#[fg=#${palette.base0D}]{char}"
|
||||
border_position "bottom"
|
||||
|
||||
hide_frame_for_single_pane "true"
|
||||
|
||||
mode_normal "#[fg=${palette.base0D}]"
|
||||
|
||||
tab_normal "#[bg=#${palette.base01}] {name} "
|
||||
tab_active "#[bg=#${palette.base02}] {name} "
|
||||
tab_separator " "
|
||||
|
||||
datetime "#[fg=#${palette.base05},bold] {format} "
|
||||
datetime_format "%I:%M %p"
|
||||
datetime_timezone "${config.home.sessionVariables.TZ}"
|
||||
}
|
||||
}
|
||||
children
|
||||
}
|
||||
|
||||
tab name="spotify" focus=true {
|
||||
pane name="spotify" {
|
||||
borderless true
|
||||
command "spotify_player"
|
||||
focus true
|
||||
}
|
||||
pane name="Visualizer" {
|
||||
borderless false
|
||||
split_direction "horizontal"
|
||||
size "20%"
|
||||
command "cava"
|
||||
}
|
||||
}
|
||||
}
|
||||
'';
|
||||
home.shellAliases = lib.mkIf zellij.enable {
|
||||
zjm = "zellij --layout music";
|
||||
};
|
||||
};
|
||||
|
||||
}
|
||||
20
home/modules/desktop/media/video/default.nix
Normal file
20
home/modules/desktop/media/video/default.nix
Normal file
|
|
@ -0,0 +1,20 @@
|
|||
{ lib, ... }:
|
||||
{
|
||||
imports = [
|
||||
./youtube
|
||||
./jellyfin
|
||||
./mpv
|
||||
];
|
||||
|
||||
options.homeModules.desktop.media.video = {
|
||||
mpv = {
|
||||
enable = lib.mkEnableOption "Enable mpv video player";
|
||||
};
|
||||
youtube = {
|
||||
enable = lib.mkEnableOption "Enable youtube tui player";
|
||||
};
|
||||
jellyfin = {
|
||||
enable = lib.mkEnableOption "Enable jellyifn media player";
|
||||
};
|
||||
};
|
||||
}
|
||||
9
home/modules/desktop/media/video/jellyfin/default.nix
Normal file
9
home/modules/desktop/media/video/jellyfin/default.nix
Normal file
|
|
@ -0,0 +1,9 @@
|
|||
{ pkgs, lib, config, ... }:
|
||||
let
|
||||
cfg = config.homeModules.desktop.media.video.jellyfin;
|
||||
in
|
||||
{
|
||||
config = lib.mkIf cfg.enable {
|
||||
home.packages = with pkgs; [ jellyfin-media-player ];
|
||||
};
|
||||
}
|
||||
13
home/modules/desktop/media/video/mpv/default.nix
Normal file
13
home/modules/desktop/media/video/mpv/default.nix
Normal file
|
|
@ -0,0 +1,13 @@
|
|||
{ lib, config, pkgs, ... }:
|
||||
|
||||
let
|
||||
cfg = config.homeModules.desktop.media.video.mpv;
|
||||
in
|
||||
{
|
||||
config = {
|
||||
programs.mpv = lib.mkIf cfg.enable {
|
||||
enable = true;
|
||||
};
|
||||
home.packages = [ pkgs.ffmpeg ];
|
||||
};
|
||||
}
|
||||
12
home/modules/desktop/media/video/youtube/default.nix
Normal file
12
home/modules/desktop/media/video/youtube/default.nix
Normal file
|
|
@ -0,0 +1,12 @@
|
|||
{ lib, config, pkgs, ...}:
|
||||
let
|
||||
cfg = config.homeModules.desktop.media.video.youtube;
|
||||
in
|
||||
{
|
||||
config = lib.mkIf cfg.enable {
|
||||
home.packages = with pkgs; [ youtube-tui ];
|
||||
programs.yt-dlp = {
|
||||
enable = true;
|
||||
};
|
||||
};
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue