{ config, pkgs, ... }:

{
    home.packages = with pkgs; [ papirus-icon-theme ];

    programs.rofi = {
        enable = true;
        package = pkgs.rofi-wayland;
        font = "SF Pro Rounded 13";
        extraConfig = {
            show-icons = true;
            icon-theme = "Papirus";
            kb-cancel = "Super_L+XF86Launch5,Escape";
            combi-hide-mode-prefix = true;
        };
        theme =
            let inherit (config.lib.formats.rasi) mkLiteral;
            in {
                "*" = {
                    background = mkLiteral "#0f111a";
                    foreground = mkLiteral "#f1f1f1";
                    selected = mkLiteral "#0033a1";
                    selected-text = mkLiteral "#ffffff";
                };

                "window" = {
                    transparency = "real";
                    background-color = mkLiteral "@background";
                    text-color = mkLiteral "@foreground";
                    width = mkLiteral "800px";
                    border-radius = mkLiteral "5px";
                };

                "textbox-prompt-colon" = {
                    expand = mkLiteral "false";
                    background-color = mkLiteral "@background";
                    padding = mkLiteral "4px 0px 0px 6px";
                };

                "inputbar" = {
                    children = mkLiteral "[ textbox-prompt-colon, entry ]";
                    background-color = mkLiteral "@background";
                    text-color = mkLiteral "@foreground";
                    expand = mkLiteral "false";
                    border = mkLiteral "0px 0px 0px 0px";
                    border-radius = mkLiteral "0px";
                    border-color = mkLiteral "@selected";
                    margin = mkLiteral "0px 0px 0px 0px";
                    padding = mkLiteral "0px 0px 4px 0px";
                    position = mkLiteral "center";
                };

                "entry" = {
                    background-color = mkLiteral "@background";
                    text-color = mkLiteral "@foreground";
                    placeholder-color = mkLiteral "@foreground";
                    expand = mkLiteral "true";
                    horizontal-align = mkLiteral "0";
                    blink = mkLiteral "true";
                    padding = mkLiteral "4px 0px 0px 4px";
                    font = "SF Pro Rounded 25";
                };

                "case-indicator" = {
                    background-color = mkLiteral "@background";
                    text-color = mkLiteral "@foreground";
                    spacing = mkLiteral "0";
                };

                "listview" = {
                    background-color = mkLiteral "@background";
                    columns = mkLiteral "1";
                    spacing = mkLiteral "5px";
                    cycle = mkLiteral "true";
                    dynamic = mkLiteral "true";
                    layout = mkLiteral "vertical";
                    fixed-height = "true";
                    lines = mkLiteral "5";
                };

                "mainbox" = {
                    background-color = mkLiteral "@background";
                    children = mkLiteral "[ inputbar, message, listview ]";
                    spacing = mkLiteral "20px";
                    padding = mkLiteral "20px 15px 15px 15px";
                };

                "message" = {
                    children = mkLiteral "[ textbox ]";
                    border-radius = mkLiteral "5px";
                };

                "textbox" = {
                    background-color = mkLiteral "@selected";
                    text-color = mkLiteral "@foreground";
                    padding = mkLiteral "20px 6px 20px 80px";
                };

                "element" = {
                    background-color = mkLiteral "@background";
                    text-color = mkLiteral "@foreground";
                    orientation = mkLiteral "horizontal";
                    border-radius = mkLiteral "4px";
                    padding = mkLiteral "2px 2px 2px 2px";
                };

                "element-text, element-icon" = {
                    background-color = mkLiteral "inherit";
                    text-color = mkLiteral "inherit";
                };

                "element-icon" = {
                    size = mkLiteral "40px";
                    padding = mkLiteral "10px 10px 10px 10px";
                };

                "element-text" = { padding = mkLiteral "20px 0px 0px 10px"; };

                "element selected" = {
                    background-color = mkLiteral "@selected";
                    text-color = mkLiteral "@selected-text";
                    border = mkLiteral "0px";
                    border-radius = mkLiteral "3px";
                    border-color = mkLiteral "@selected";
                };
            };
    };
}