 0067075ed1
			
		
	
	
		0067075ed1
		
			
		
	
	
	
	
		
			
			* Update ScriptAccordion and ScriptItem components for improved styling * Add README.md for Proxmox VE Helper-Scripts Frontend * Remove testing dependencies and related test files from the frontend project * Update analytics URL in siteConfig to point to community-scripts.org * Refactor ESLint configuration to have one source of truth and run "npm lint" to apply new changes * Update lint script in package.json to remove npm * Add 'next' option to ESLint configuration for improved compatibility * Update package dependencies and versions in package.json and package-lock.json * Refactor theme provider import and enhance calendar component for dynamic icon rendering * rename sidebar, alerts and buttons * rename description and interfaces files * rename more files * change folder name * Refactor tooltip logic to improve updateable condition handling * Enhance CommandMenu to prevent duplicate scripts across categories * Remove test step from frontend CI/CD workflow
		
			
				
	
	
		
			182 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			182 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /* eslint-disable ts/no-require-imports */
 | |
| //
 | |
| import type { Config } from "tailwindcss";
 | |
| 
 | |
| const {
 | |
|   default: flattenColorPalette,
 | |
| } = require("tailwindcss/lib/util/flattenColorPalette");
 | |
| const svgToDataUri = require("mini-svg-data-uri");
 | |
| 
 | |
| 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) {
 | |
|   const allColors = flattenColorPalette(theme("colors"));
 | |
|   const newVars = Object.fromEntries(
 | |
|     Object.entries(allColors).map(([key, val]) => [`--${key}`, val]),
 | |
|   );
 | |
|   addBase({
 | |
|     ":root": newVars,
 | |
|   });
 | |
| }
 | |
| 
 | |
| export default config;
 |