feat: make persistent-others similar to the new persistent-apps (#1431)

This commit is contained in:
Sam 2025-11-01 18:33:40 +00:00 committed by GitHub
commit fc4e3dbe40
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 154 additions and 10 deletions

View file

@ -197,16 +197,93 @@ in {
}; };
system.defaults.dock.persistent-others = mkOption { system.defaults.dock.persistent-others = mkOption {
type = types.nullOr (types.listOf (types.either types.path types.str)); type = let
folderType = types.submodule {
options.path = mkOption {
description = "Path to a folder to be added to the dock.";
type = types.str;
};
options.arrangement = mkOption {
description = "Sort order for files in folder when clicked.";
type = types.enum ["name" "date-added" "date-modified" "date-created" "kind"];
default = "name";
};
options.displayas = mkOption {
description = "How to display the folder before clicked. stack: Stack of file previews. folder: A folder icon";
type = types.enum ["stack" "folder"];
default = "stack";
};
options.showas = mkOption {
description = "Effect to show files when clicked. fan: fan-out effect, grid: box, list: list";
type = types.enum ["automatic" "fan" "grid" "list"];
default = "automatic";
};
};
taggedType = types.attrTag {
file = mkOption {
description = "A file to be added to the dock.";
type = types.str;
};
folder = mkOption {
description = "A folder to be added to the dock.";
type = types.coercedTo types.str (str: { path = str; }) folderType;
};
};
simpleType = types.either types.str types.path;
# Below to NOT break exisiting config
toTagged = _path: let path = builtins.toString _path; in if strings.hasInfix "." (last (splitString "/" path)) then { file = path; } else { folder = path; };
# toTagged = path: { folder = path; }; # or this to be consistent with persistent-apps
in
types.nullOr (types.listOf (types.coercedTo simpleType toTagged taggedType));
default = null; default = null;
example = [ "~/Documents" "~/Downloads" ]; example = lib.literalExpression ''
[
./flake.nix
"/Volumes"
{ folder = "/Users/@username@/Downloads"; }
{ folder = { path = "/Users/@username@/.emacs.d"; showas = "grid"; }; }
{ file = "/Users/@username@/Desktop/this_is_a_file"; }
]'';
description = '' description = ''
Persistent folders in the dock. Persistent files, and folders in the dock.
''; '';
apply = value: apply = let
if !(isList value) arrangementMap = {
then value name = 1;
else map (folder: { tile-data = { file-data = { _CFURLString = "file://" + folder; _CFURLStringType = 15; }; }; tile-type = if strings.hasInfix "." (last (splitString "/" folder)) then "file-tile" else "directory-tile"; }) value; date-added = 2;
date-modified = 3;
date-created = 4;
kind = 5;
};
displayasMap = {
stack = 0;
folder = 1;
};
showasMap = {
automatic = 0;
fan = 1;
grid = 2;
list = 3;
};
parseFolder = (folder:
builtins.mapAttrs (name: val:
if name == "arrangement" then arrangementMap.${val}
else if name == "displayas" then displayasMap.${val}
else if name == "showas" then showasMap.${val}
else val
) folder
);
toTile = item: {
tile-data = {
file-data = {
_CFURLString = "file://" + (if item ? folder then item.folder.path else item.file);
_CFURLStringType = 15;
};
} // (if item ? folder then {inherit (parseFolder item.folder) arrangement displayas showas;} else {});
tile-type = if item ? folder then "directory-tile" else "file-tile";
};
in
value: if value == null then null else map toTile value;
}; };
system.defaults.dock.scroll-to-open = mkOption { system.defaults.dock.scroll-to-open = mkOption {

View file

@ -331,13 +331,19 @@ launchctl asuser "$(id -u -- test-defaults-user)" sudo --user=test-defaults-user
<dict> <dict>
<key>tile-data</key> <key>tile-data</key>
<dict> <dict>
<key>arrangement</key>
<integer>1</integer>
<key>displayas</key>
<integer>0</integer>
<key>file-data</key> <key>file-data</key>
<dict> <dict>
<key>_CFURLString</key> <key>_CFURLString</key>
<string>file://~/Documents</string> <string>file:///file</string>
<key>_CFURLStringType</key> <key>_CFURLStringType</key>
<integer>15</integer> <integer>15</integer>
</dict> </dict>
<key>showas</key>
<integer>0</integer>
</dict> </dict>
<key>tile-type</key> <key>tile-type</key>
<string>directory-tile</string> <string>directory-tile</string>
@ -348,7 +354,7 @@ launchctl asuser "$(id -u -- test-defaults-user)" sudo --user=test-defaults-user
<key>file-data</key> <key>file-data</key>
<dict> <dict>
<key>_CFURLString</key> <key>_CFURLString</key>
<string>file://~/Downloads/file.txt</string> <string>file:///file</string>
<key>_CFURLStringType</key> <key>_CFURLStringType</key>
<integer>15</integer> <integer>15</integer>
</dict> </dict>
@ -356,6 +362,60 @@ launchctl asuser "$(id -u -- test-defaults-user)" sudo --user=test-defaults-user
<key>tile-type</key> <key>tile-type</key>
<string>file-tile</string> <string>file-tile</string>
</dict> </dict>
<dict>
<key>tile-data</key>
<dict>
<key>file-data</key>
<dict>
<key>_CFURLString</key>
<string>file:///folder.d</string>
<key>_CFURLStringType</key>
<integer>15</integer>
</dict>
</dict>
<key>tile-type</key>
<string>file-tile</string>
</dict>
<dict>
<key>tile-data</key>
<dict>
<key>arrangement</key>
<integer>5</integer>
<key>displayas</key>
<integer>1</integer>
<key>file-data</key>
<dict>
<key>_CFURLString</key>
<string>file:///folder.d</string>
<key>_CFURLStringType</key>
<integer>15</integer>
</dict>
<key>showas</key>
<integer>2</integer>
</dict>
<key>tile-type</key>
<string>directory-tile</string>
</dict>
<dict>
<key>tile-data</key>
<dict>
<key>arrangement</key>
<integer>1</integer>
<key>displayas</key>
<integer>0</integer>
<key>file-data</key>
<dict>
<key>_CFURLString</key>
<string>file:///folder</string>
<key>_CFURLStringType</key>
<integer>15</integer>
</dict>
<key>showas</key>
<integer>0</integer>
</dict>
<key>tile-type</key>
<string>directory-tile</string>
</dict>
</array> </array>
</plist>' </plist>'
launchctl asuser "$(id -u -- test-defaults-user)" sudo --user=test-defaults-user -- defaults write com.apple.dock scroll-to-open '<?xml version="1.0" encoding="UTF-8"?> launchctl asuser "$(id -u -- test-defaults-user)" sudo --user=test-defaults-user -- defaults write com.apple.dock scroll-to-open '<?xml version="1.0" encoding="UTF-8"?>

View file

@ -80,7 +80,14 @@
{ folder = "/Applications/Utilities"; } { folder = "/Applications/Utilities"; }
{ file = "/Users/example/Downloads/test.csv"; } { file = "/Users/example/Downloads/test.csv"; }
]; ];
system.defaults.dock.persistent-others = ["~/Documents" "~/Downloads/file.txt"]; system.defaults.dock.persistent-others = [
# ./. # TODO: how to test for paths while NOT being brittle?
"/file"
{ file = "/file"; }
"/folder.d"
{ folder = { path = "/folder.d"; arrangement="kind"; displayas="folder"; showas = "grid"; }; }
{ folder = "/folder"; }
];
system.defaults.dock.scroll-to-open = false; system.defaults.dock.scroll-to-open = false;
system.defaults.finder.AppleShowAllFiles = true; system.defaults.finder.AppleShowAllFiles = true;
system.defaults.finder.ShowStatusBar = true; system.defaults.finder.ShowStatusBar = true;