2023-02-20 11:42:13 +01:00
|
|
|
{
|
|
|
|
lib,
|
2023-11-06 15:04:08 +01:00
|
|
|
helpers,
|
|
|
|
config,
|
|
|
|
pkgs,
|
2023-02-20 11:42:13 +01:00
|
|
|
...
|
|
|
|
}:
|
|
|
|
with lib;
|
|
|
|
let
|
2022-09-18 11:19:23 +01:00
|
|
|
cfg = config.plugins.notify;
|
2023-02-20 11:42:13 +01:00
|
|
|
in
|
|
|
|
{
|
2024-01-25 16:15:55 +01:00
|
|
|
options.plugins.notify = helpers.neovim-plugin.extraOptionsOptions // {
|
2023-09-19 11:37:33 +02:00
|
|
|
enable = mkEnableOption "nvim-notify";
|
2021-12-23 00:09:24 +01:00
|
|
|
|
2024-05-17 14:09:20 +02:00
|
|
|
package = helpers.mkPluginPackageOption "nvim-notify" pkgs.vimPlugins.nvim-notify;
|
2023-01-19 10:45:15 +00:00
|
|
|
|
2023-11-30 15:50:24 +01:00
|
|
|
level = helpers.defaultNullOpts.mkLogLevel "info" ''
|
|
|
|
Minimum log level to display. See `vim.log.levels`.
|
|
|
|
'';
|
2023-09-19 11:37:33 +02:00
|
|
|
|
|
|
|
timeout = helpers.defaultNullOpts.mkUnsignedInt 5000 "Default timeout for notification.";
|
|
|
|
|
2024-01-01 23:33:53 +01:00
|
|
|
maxWidth = helpers.mkNullOrOption (with types; either ints.unsigned helpers.nixvimTypes.rawLua) ''
|
2023-09-19 11:37:33 +02:00
|
|
|
Max number of columns for messages.
|
|
|
|
'';
|
|
|
|
|
2024-01-01 23:33:53 +01:00
|
|
|
maxHeight = helpers.mkNullOrOption (with types; either ints.unsigned helpers.nixvimTypes.rawLua) ''
|
2023-09-19 11:37:33 +02:00
|
|
|
Max number of lines for a message.
|
|
|
|
'';
|
|
|
|
|
|
|
|
stages =
|
|
|
|
helpers.defaultNullOpts.mkNullable
|
|
|
|
(
|
|
|
|
with types;
|
|
|
|
either (enum [
|
|
|
|
"fade"
|
|
|
|
"slide"
|
|
|
|
"fade_in_slide_out"
|
|
|
|
"static"
|
|
|
|
]) (listOf str)
|
|
|
|
)
|
|
|
|
"fade_in_slide_out"
|
|
|
|
''
|
|
|
|
Animation stages.
|
|
|
|
Can be either one of the builtin stages or an array of lua functions.
|
|
|
|
'';
|
|
|
|
|
|
|
|
backgroundColour = helpers.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.")
|
|
|
|
{
|
|
|
|
error = "";
|
|
|
|
warn = "";
|
|
|
|
info = "";
|
|
|
|
debug = "";
|
|
|
|
trace = "✎";
|
2021-12-23 00:09:24 +01:00
|
|
|
};
|
2023-09-19 11:37:33 +02:00
|
|
|
|
2023-12-29 15:24:42 +01:00
|
|
|
onOpen = helpers.defaultNullOpts.mkLuaFn "nil" ''
|
2023-09-19 11:37:33 +02:00
|
|
|
Function called when a new window is opened, use for changing win settings/config.
|
|
|
|
'';
|
|
|
|
|
2023-12-29 15:24:42 +01:00
|
|
|
onClose = helpers.defaultNullOpts.mkLuaFn "nil" ''
|
2023-09-19 11:37:33 +02:00
|
|
|
Function called when a new window is closed.
|
|
|
|
'';
|
|
|
|
|
2024-06-11 16:54:57 +01:00
|
|
|
render = helpers.defaultNullOpts.mkEnumFirstDefault [
|
|
|
|
"default"
|
|
|
|
"minimal"
|
|
|
|
] "Function to render a notification buffer or a built-in renderer name.";
|
2024-05-05 19:39:35 +02:00
|
|
|
|
2023-09-19 11:37:33 +02:00
|
|
|
minimumWidth = helpers.defaultNullOpts.mkUnsignedInt 50 ''
|
|
|
|
Minimum width for notification windows.
|
|
|
|
'';
|
2024-05-05 19:39:35 +02:00
|
|
|
|
2023-09-19 11:37:33 +02:00
|
|
|
fps = helpers.defaultNullOpts.mkPositiveInt 30 ''
|
|
|
|
Frames per second for animation stages, higher value means smoother animations but more CPU
|
|
|
|
usage.
|
|
|
|
'';
|
2024-05-05 19:39:35 +02:00
|
|
|
|
2023-09-19 11:37:33 +02:00
|
|
|
topDown = helpers.defaultNullOpts.mkBool true ''
|
|
|
|
Whether or not to position the notifications at the top or not.
|
|
|
|
'';
|
2021-12-23 00:09:24 +01:00
|
|
|
};
|
2024-05-05 19:39:35 +02:00
|
|
|
|
2023-02-20 11:42:13 +01:00
|
|
|
config =
|
|
|
|
let
|
2023-09-19 11:37:33 +02:00
|
|
|
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;
|
2023-12-29 15:24:42 +01:00
|
|
|
on_open = onOpen;
|
|
|
|
on_close = onClose;
|
2023-09-19 11:37:33 +02:00
|
|
|
inherit render;
|
|
|
|
minimum_width = minimumWidth;
|
|
|
|
inherit fps;
|
|
|
|
top_down = topDown;
|
|
|
|
}
|
|
|
|
// cfg.extraOptions;
|
2023-02-20 11:42:13 +01:00
|
|
|
in
|
2022-09-18 11:19:23 +01:00
|
|
|
mkIf cfg.enable {
|
2023-02-20 11:42:13 +01:00
|
|
|
extraPlugins = [ cfg.package ];
|
2023-09-19 11:37:33 +02:00
|
|
|
|
2021-12-23 00:09:24 +01:00
|
|
|
extraConfigLua = ''
|
|
|
|
vim.notify = require('notify');
|
|
|
|
require('notify').setup(${helpers.toLuaObject setupOptions})
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
}
|