plugins/notify: migrate to mkNeovimPlugin

This commit is contained in:
Austin Horstman 2025-02-01 17:57:24 -06:00
parent 10ea28fff4
commit 0827c5cb6c
No known key found for this signature in database
3 changed files with 121 additions and 95 deletions

View file

@ -1,41 +1,37 @@
{
lib,
helpers,
config,
pkgs,
...
}:
with lib;
let
cfg = config.plugins.notify;
inherit (lib.nixvim)
defaultNullOpts
mkNullOrOption
;
inherit (lib) types;
in
{
options.plugins.notify = lib.nixvim.plugins.neovim.extraOptionsOptions // {
enable = mkEnableOption "nvim-notify";
lib.nixvim.plugins.mkNeovimPlugin {
name = "notify";
packPathName = "nvim-notify";
package = "nvim-notify";
maintainers = [ lib.maintainers.khaneliman ];
package = lib.mkPackageOption pkgs "nvim-notify" {
default = [
"vimPlugins"
"nvim-notify"
];
};
description = ''
A fancy, configurable, notification manager for Neovim.
'';
level = helpers.defaultNullOpts.mkLogLevel "info" ''
settingsOptions = {
level = defaultNullOpts.mkLogLevel "info" ''
Minimum log level to display. See `vim.log.levels`.
'';
timeout = helpers.defaultNullOpts.mkUnsignedInt 5000 "Default timeout for notification.";
maxWidth = helpers.mkNullOrOption (with types; either ints.unsigned rawLua) ''
timeout = defaultNullOpts.mkUnsignedInt 5000 "Default timeout for notification.";
max_width = mkNullOrOption (with types; either ints.unsigned rawLua) ''
Max number of columns for messages.
'';
maxHeight = helpers.mkNullOrOption (with types; either ints.unsigned rawLua) ''
max_height = mkNullOrOption (with types; either ints.unsigned rawLua) ''
Max number of lines for a message.
'';
stages =
helpers.defaultNullOpts.mkNullable
defaultNullOpts.mkNullable
(
with types;
either (enum [
@ -50,82 +46,73 @@ in
Animation stages.
Can be either one of the builtin stages or an array of lua functions.
'';
backgroundColour = helpers.defaultNullOpts.mkStr "NotifyBackground" ''
background_colour = defaultNullOpts.mkStr "NotifyBackground" ''
For stages that change opacity this is treated as the highlight behind the window.
Set this to either a highlight group, an RGB hex value e.g. "#000000" or a function
returning an RGB code for dynamic values.
'';
icons =
mapAttrs (name: default: helpers.defaultNullOpts.mkStr default "Icon for the ${name} level.")
{
icons = lib.mapAttrs (name: default: defaultNullOpts.mkStr default "Icon for the ${name} level.") {
error = "";
warn = "";
info = "";
debug = "";
trace = "";
};
onOpen = helpers.defaultNullOpts.mkLuaFn "nil" ''
on_open = defaultNullOpts.mkLuaFn "nil" ''
Function called when a new window is opened, use for changing win settings/config.
'';
onClose = helpers.defaultNullOpts.mkLuaFn "nil" ''
on_close = defaultNullOpts.mkLuaFn "nil" ''
Function called when a new window is closed.
'';
render = helpers.defaultNullOpts.mkEnumFirstDefault [
render = defaultNullOpts.mkEnumFirstDefault [
"default"
"minimal"
"simple"
"compact"
"wrapped-compact"
] "Function to render a notification buffer or a built-in renderer name.";
minimumWidth = helpers.defaultNullOpts.mkUnsignedInt 50 ''
minimum_width = defaultNullOpts.mkUnsignedInt 50 ''
Minimum width for notification windows.
'';
fps = helpers.defaultNullOpts.mkPositiveInt 30 ''
fps = defaultNullOpts.mkPositiveInt 30 ''
Frames per second for animation stages, higher value means smoother animations but more CPU
usage.
'';
topDown = helpers.defaultNullOpts.mkBool true ''
top_down = defaultNullOpts.mkBool true ''
Whether or not to position the notifications at the top or not.
'';
};
config =
let
setupOptions =
with cfg;
{
inherit level timeout;
max_width = maxWidth;
max_height = maxHeight;
stages = helpers.ifNonNull' stages (if isString stages then stages else map helpers.mkRaw stages);
background_colour = backgroundColour;
icons = mapAttrs' (name: value: {
name = strings.toUpper name;
inherit value;
}) icons;
on_open = onOpen;
on_close = onClose;
inherit render;
minimum_width = minimumWidth;
inherit fps;
top_down = topDown;
}
// cfg.extraOptions;
in
mkIf cfg.enable {
extraPlugins = [ cfg.package ];
settingsExample = {
settings = {
level = "info";
timeout = 5000;
max_width = 80;
max_height = 10;
stages = "fade_in_slide_out";
background_colour = "#000000";
icons = {
error = "";
warn = "";
info = "";
debug = "";
trace = "";
};
on_open.__raw = "function() print('Window opened') end";
on_close.__raw = "function() print('Window closed') end";
render = "default";
minimum_width = 50;
fps = 30;
top_down = true;
};
};
extraConfigLua = ''
extraConfig = {
plugins.notify.luaConfig.pre = ''
vim.notify = require('notify');
require('notify').setup(${lib.nixvim.toLuaObject setupOptions})
'';
};
# TODO: Deprecated on 2025-02-01
inherit (import ./deprecations.nix) deprecateExtraOptions optionsRenamedToSettings;
}

View file

@ -0,0 +1,37 @@
{
deprecateExtraOptions = true;
optionsRenamedToSettings = [
"level"
"timeout"
"maxWidth"
"maxHeight"
"stages"
"backgroundColour"
[
"icons"
"error"
]
[
"icons"
"warn"
]
[
"icons"
"info"
]
[
"icons"
"debug"
]
[
"icons"
"trace"
]
"onOpen"
"onClose"
"render"
"minimumWidth"
"fps"
"topDown"
];
}

View file

@ -7,12 +7,13 @@
plugins.notify = {
enable = true;
settings = {
level = "info";
timeout = 5000;
maxWidth = null;
maxHeight = null;
max_width = null;
max_height = null;
stages = "fade_in_slide_out";
backgroundColour = "NotifyBackground";
background_colour = "NotifyBackground";
icons = {
error = "";
warn = "";
@ -20,12 +21,13 @@
debug = "";
trace = "";
};
onOpen = null;
onClose = null;
on_open = null;
on_close = null;
render = "default";
minimumWidth = 50;
minimum_width = 50;
fps = 30;
topDown = true;
top_down = true;
};
};
};
}