{lib, ...}: let
  inherit (lib.options) mkEnableOption mkOption;

  inherit (lib.types) enum listOf str nullOr int;
  inherit (lib.nvim.types) mkPluginSetupOption;
in {
  options.vim.utility.images.image-nvim = {
    enable = mkEnableOption "image support in Neovim [image.nvim]";

    setupOpts = mkPluginSetupOption "image.nvim" {
      backend = mkOption {
        type = enum ["kitty" "ueberzug"];
        default = "ueberzug";
        description = ''
          The backend to use for rendering images.

          - kitty - best in class, works great and is very snappy
          - ueberzug - backed by ueberzugpp, supports any terminal,
            but has lower performance
        '';
      };

      integrations = {
        markdown = {
          enable = mkEnableOption " image.nvim in markdown files" // {default = true;};
          clearInInsertMode = mkEnableOption "clearing of images when entering insert mode";
          downloadRemoteImages = mkEnableOption "downloading remote images";
          onlyRenderAtCursor = mkEnableOption "only rendering images at cursor";
          filetypes = mkOption {
            type = listOf str;
            default = ["markdown" "vimwiki"];
            description = ''
              Filetypes to enable image.nvim in. Markdown extensions
              (i.e. quarto) can go here
            '';
          };
        };

        neorg = {
          enable = mkEnableOption "image.nvim in Neorg files" // {default = true;};
          clearInInsertMode = mkEnableOption "clearing of images when entering insert mode";
          downloadRemoteImages = mkEnableOption "downloading remote images";
          onlyRenderAtCursor = mkEnableOption "only rendering images at cursor";
          filetypes = mkOption {
            type = listOf str;
            default = ["neorg"];
            description = ''
              Filetypes to enable image.nvim in.
            '';
          };
        };

        maxWidth = mkOption {
          type = nullOr int;
          default = null;
          description = ''
            The maximum width of images to render. Images larger than
            this will be scaled down to fit within this width.
          '';
        };
      };

      maxHeight = mkOption {
        type = nullOr int;
        default = null;
        description = ''
          The maximum height of images to render. Images larger than
          this will be scaled down to fit within this height.
        '';
      };

      maxWidthWindowPercentage = mkOption {
        type = nullOr int;
        default = null;
        description = ''
          The maximum width of images to render as a percentage of the
          window width. Images larger than this will be scaled down to
          fit within this width.
        '';
      };

      maxHeightWindowPercentage = mkOption {
        type = nullOr int;
        default = 50;
        description = ''
          The maximum height of images to render as a percentage of the
          window height. Images larger than this will be scaled down to
          fit within this height.
        '';
      };

      windowOverlapClear = {
        enable = mkEnableOption "clearing of images when they overlap with the window";
        ftIgnore = mkOption {
          type = listOf str;
          default = ["cmp_menu" "cmp_docs" ""];
          description = ''
            Filetypes to ignore window overlap clearing in.
          '';
        };
      };

      editorOnlyRenderWhenFocused = mkEnableOption "only rendering images when the editor is focused";
      hijackFilePatterns = mkOption {
        type = listOf str;
        default = ["*.png" "*.jpg" "*.jpeg" "*.gif" "*.webp"];
        description = ''
          File patterns to hijack for image.nvim. This is useful for
          filetypes that don't have a dedicated integration.
        '';
      };
    };
  };
}