mirror of
				https://github.com/community-scripts/ProxmoxVE.git
				synced 2025-11-04 10:22:50 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			181 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			181 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import type { Config } from "tailwindcss";
 | 
						|
 | 
						|
const svgToDataUri = require("mini-svg-data-uri");
 | 
						|
 | 
						|
const {
 | 
						|
  default: flattenColorPalette,
 | 
						|
} = require("tailwindcss/lib/util/flattenColorPalette");
 | 
						|
 | 
						|
const config = {
 | 
						|
  darkMode: ["class"],
 | 
						|
  content: [
 | 
						|
    "./pages/**/*.{ts,tsx}",
 | 
						|
    "./components/**/*.{ts,tsx}",
 | 
						|
    "./app/**/*.{ts,tsx}",
 | 
						|
    "./src/**/*.{ts,tsx}",
 | 
						|
  ],
 | 
						|
  prefix: "",
 | 
						|
  theme: {
 | 
						|
    container: {
 | 
						|
      center: true,
 | 
						|
      padding: "2rem",
 | 
						|
      screens: {
 | 
						|
        "2xl": "1400px",
 | 
						|
      },
 | 
						|
    },
 | 
						|
    extend: {
 | 
						|
      colors: {
 | 
						|
        border: "hsl(var(--border))",
 | 
						|
        input: "hsl(var(--input))",
 | 
						|
        ring: "hsl(var(--ring))",
 | 
						|
        background: "hsl(var(--background))",
 | 
						|
        foreground: "hsl(var(--foreground))",
 | 
						|
        primary: {
 | 
						|
          DEFAULT: "hsl(var(--primary))",
 | 
						|
          foreground: "hsl(var(--primary-foreground))",
 | 
						|
        },
 | 
						|
        secondary: {
 | 
						|
          DEFAULT: "hsl(var(--secondary))",
 | 
						|
          foreground: "hsl(var(--secondary-foreground))",
 | 
						|
        },
 | 
						|
        destructive: {
 | 
						|
          DEFAULT: "hsl(var(--destructive))",
 | 
						|
          foreground: "hsl(var(--destructive-foreground))",
 | 
						|
        },
 | 
						|
        muted: {
 | 
						|
          DEFAULT: "hsl(var(--muted))",
 | 
						|
          foreground: "hsl(var(--muted-foreground))",
 | 
						|
        },
 | 
						|
        accent: {
 | 
						|
          DEFAULT: "hsl(var(--accent))",
 | 
						|
          foreground: "hsl(var(--accent-foreground))",
 | 
						|
        },
 | 
						|
        popover: {
 | 
						|
          DEFAULT: "hsl(var(--popover))",
 | 
						|
          foreground: "hsl(var(--popover-foreground))",
 | 
						|
        },
 | 
						|
        card: {
 | 
						|
          DEFAULT: "hsl(var(--card))",
 | 
						|
          foreground: "hsl(var(--card-foreground))",
 | 
						|
        },
 | 
						|
      },
 | 
						|
      borderRadius: {
 | 
						|
        lg: "var(--radius)",
 | 
						|
        md: "calc(var(--radius) - 2px)",
 | 
						|
        sm: "calc(var(--radius) - 4px)",
 | 
						|
      },
 | 
						|
      keyframes: {
 | 
						|
        "accordion-down": {
 | 
						|
          from: { height: "0" },
 | 
						|
          to: { height: "var(--radix-accordion-content-height)" },
 | 
						|
        },
 | 
						|
        "accordion-up": {
 | 
						|
          from: { height: "var(--radix-accordion-content-height)" },
 | 
						|
          to: { height: "0" },
 | 
						|
        },
 | 
						|
        shine: {
 | 
						|
          from: { backgroundPosition: "200% 0" },
 | 
						|
          to: { backgroundPosition: "-200% 0" },
 | 
						|
        },
 | 
						|
        gradient: {
 | 
						|
          to: {
 | 
						|
            backgroundPosition: "var(--bg-size) 0",
 | 
						|
          },
 | 
						|
        },
 | 
						|
        "shine-pulse": {
 | 
						|
          "0%": {
 | 
						|
            "background-position": "0% 0%",
 | 
						|
          },
 | 
						|
          "50%": {
 | 
						|
            "background-position": "100% 100%",
 | 
						|
          },
 | 
						|
          to: {
 | 
						|
            "background-position": "0% 0%",
 | 
						|
          },
 | 
						|
        },
 | 
						|
        moveHorizontal: {
 | 
						|
          "0%": {
 | 
						|
            transform: "translateX(-50%) translateY(-10%)",
 | 
						|
          },
 | 
						|
          "50%": {
 | 
						|
            transform: "translateX(50%) translateY(10%)",
 | 
						|
          },
 | 
						|
          "100%": {
 | 
						|
            transform: "translateX(-50%) translateY(-10%)",
 | 
						|
          },
 | 
						|
        },
 | 
						|
        moveInCircle: {
 | 
						|
          "0%": {
 | 
						|
            transform: "rotate(0deg)",
 | 
						|
          },
 | 
						|
          "50%": {
 | 
						|
            transform: "rotate(180deg)",
 | 
						|
          },
 | 
						|
          "100%": {
 | 
						|
            transform: "rotate(360deg)",
 | 
						|
          },
 | 
						|
        },
 | 
						|
        moveVertical: {
 | 
						|
          "0%": {
 | 
						|
            transform: "translateY(-50%)",
 | 
						|
          },
 | 
						|
          "50%": {
 | 
						|
            transform: "translateY(50%)",
 | 
						|
          },
 | 
						|
          "100%": {
 | 
						|
            transform: "translateY(-50%)",
 | 
						|
          },
 | 
						|
        },
 | 
						|
      },
 | 
						|
      animation: {
 | 
						|
        "accordion-down": "accordion-down 0.2s ease-out",
 | 
						|
        "accordion-up": "accordion-up 0.2s ease-out",
 | 
						|
        shine: "shine 8s ease-in-out infinite",
 | 
						|
        gradient: "gradient 8s linear infinite",
 | 
						|
      },
 | 
						|
    },
 | 
						|
  },
 | 
						|
  plugins: [
 | 
						|
    require(`tailwindcss-animated`),
 | 
						|
    require("tailwindcss-animate"),
 | 
						|
    addVariablesForColors,
 | 
						|
    function ({ matchUtilities, theme }: any) {
 | 
						|
      matchUtilities(
 | 
						|
        {
 | 
						|
          "bg-grid": (value: any) => ({
 | 
						|
            backgroundImage: `url("${svgToDataUri(
 | 
						|
              `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 32 32" width="32" height="32" fill="none" stroke="${value}"><path d="M0 .5H31.5V32"/></svg>`,
 | 
						|
            )}")`,
 | 
						|
          }),
 | 
						|
          "bg-grid-small": (value: any) => ({
 | 
						|
            backgroundImage: `url("${svgToDataUri(
 | 
						|
              `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 32 32" width="8" height="8" fill="none" stroke="${value}"><path d="M0 .5H31.5V32"/></svg>`,
 | 
						|
            )}")`,
 | 
						|
          }),
 | 
						|
          "bg-dot": (value: any) => ({
 | 
						|
            backgroundImage: `url("${svgToDataUri(
 | 
						|
              `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 32 32" width="16" height="16" fill="none"><circle fill="${value}" id="pattern-circle" cx="10" cy="10" r="1.6257413380501518"></circle></svg>`,
 | 
						|
            )}")`,
 | 
						|
          }),
 | 
						|
        },
 | 
						|
        {
 | 
						|
          values: flattenColorPalette(theme("backgroundColor")),
 | 
						|
          type: "color",
 | 
						|
        },
 | 
						|
      );
 | 
						|
    },
 | 
						|
  ],
 | 
						|
} satisfies Config;
 | 
						|
 | 
						|
function addVariablesForColors({ addBase, theme }: any) {
 | 
						|
  let allColors = flattenColorPalette(theme("colors"));
 | 
						|
  let newVars = Object.fromEntries(
 | 
						|
    Object.entries(allColors).map(([key, val]) => [`--${key}`, val]),
 | 
						|
  );
 | 
						|
  addBase({
 | 
						|
    ":root": newVars,
 | 
						|
  });
 | 
						|
}
 | 
						|
 | 
						|
export default config;
 |