diff --git a/modules/system/defaults/dock.nix b/modules/system/defaults/dock.nix
index bba0afb75..b169a76f9 100644
--- a/modules/system/defaults/dock.nix
+++ b/modules/system/defaults/dock.nix
@@ -5,6 +5,54 @@ with lib;
let
# Should only be used with options that previously used floats defined as strings.
inherit (config.lib.defaults.types) floatWithDeprecationError;
+
+persistentOther = types.submodule {
+ options = {
+ path = lib.mkOption {
+ type = types.either types.path types.str;
+ description = "Path as either a path type or string";
+ };
+ arrangement = let
+ values = [
+ "automatic" # 0
+ "name" # 1
+ "date-added" # 2
+ "date-modified" # 3
+ "date-created" # 4
+ "kind" # 5
+ ];
+ in lib.mkOption {
+ type = types.nullOr (types.enum values);
+ default = null;
+ description = "Sort items by specified criteria";
+ apply = value: lib.lists.findFirstIndex (x: x == value) 0 values;
+ };
+ showas = let
+ values = [
+ "automatic" # 0
+ "fan" # 1
+ "grid" # 2
+ "list" # 3
+ ];
+ in lib.mkOption {
+ type = types.nullOr (types.enum values);
+ default = null;
+ description = "View content as specified style";
+ apply = value: lib.lists.findFirstIndex (x: x == value) 0 values;
+ };
+ displayas = let
+ values = [
+ "stack" # 0
+ "folder" # 1
+ ];
+ in lib.mkOption {
+ type = types.nullOr (types.enum values);
+ default = null;
+ description = "Display item as stack or folder";
+ apply = value: lib.lists.findFirstIndex (x: x == value) 0 values;
+ };
+ };
+ };
in {
imports = [
(mkRenamedOptionModule [ "system" "defaults" "dock" "expose-group-by-app" ] [ "system" "defaults" "dock" "expose-group-apps" ])
@@ -141,16 +189,34 @@ in {
};
system.defaults.dock.persistent-others = mkOption {
- type = types.nullOr (types.listOf (types.either types.path types.str));
+ type = types.nullOr (types.listOf (types.oneOf [ types.path types.str persistentOther ]));
default = null;
example = [ "~/Documents" "~/Downloads" ];
description = ''
Persistent folders in the dock.
'';
apply = value:
- if !(isList value)
+ if !(lib.isList value)
then value
- 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;
+ else map (folder:
+ let
+ folderPath = if builtins.isAttrs folder then toString folder.path else toString folder;
+ isSimplePath = !(builtins.isAttrs folder);
+ in {
+ tile-data = {
+ file-data = {
+ _CFURLString = "file://" + folderPath;
+ _CFURLStringType = 15;
+ };
+ } // (if isSimplePath then {} else lib.filterAttrs (n: v: v != null) {
+ arrangement = folder.arrangement;
+ showas = folder.showas;
+ displayas = folder.displayas;
+ });
+ tile-type = if lib.strings.hasInfix "." (lib.last (lib.splitString "/" folderPath))
+ then "file-tile"
+ else "directory-tile";
+ }) value;
};
system.defaults.dock.scroll-to-open = mkOption {
diff --git a/tests/fixtures/system-defaults-write/activate-user.txt b/tests/fixtures/system-defaults-write/activate-user.txt
index e09f689b3..ba9a61ae7 100644
--- a/tests/fixtures/system-defaults-write/activate-user.txt
+++ b/tests/fixtures/system-defaults-write/activate-user.txt
@@ -307,6 +307,26 @@ defaults write com.apple.dock 'persistent-others' $'tile-type
file-tile
+
+ tile-data
+
+ file-data
+
+ _CFURLString
+ file://~/Applications
+ _CFURLStringType
+ 15
+
+ displayas
+ 1
+ showas
+ 2
+ arrangement
+ 3
+
+ tile-type
+ directory-tile
+
'
defaults write com.apple.dock 'scroll-to-open' $'
diff --git a/tests/system-defaults-write.nix b/tests/system-defaults-write.nix
index fae08de38..ba9a94720 100644
--- a/tests/system-defaults-write.nix
+++ b/tests/system-defaults-write.nix
@@ -51,7 +51,16 @@
system.defaults.dock.autohide-delay = 0.24;
system.defaults.dock.orientation = "left";
system.defaults.dock.persistent-apps = ["MyApp.app" "Cool.app"];
- system.defaults.dock.persistent-others = ["~/Documents" "~/Downloads/file.txt"];
+ system.defaults.dock.persistent-others = [
+ "~/Documents"
+ "~/Downloads/file.txt"
+ {
+ path = "~/Appications";
+ displayas = "folder";
+ showas = "fan";
+ arrangement = "date-modified";
+ }
+ ];
system.defaults.dock.scroll-to-open = false;
system.defaults.finder.AppleShowAllFiles = true;
system.defaults.finder.ShowStatusBar = true;
@@ -122,6 +131,10 @@
out = '${config.out}/${x}'
if Path(fixture).read_text() not in Path(out).read_text():
print("Did not find content from %s in %s" % (fixture, out), file=sys.stderr)
+ print("Expected:", file=sys.stderr)
+ print(Path(fixture).read_text(), file=sys.stderr)
+ print("Got:", file=sys.stderr)
+ print(Path(out).read_text(), file=sys.stderr)
sys.exit(1)
EOL
'') [