2
0
mirror of https://github.com/iconify/iconify.git synced 2025-01-22 22:58:27 +00:00

chore: add options to tailwind plugin

This commit is contained in:
Vjacheslav Trushkin 2024-12-26 10:05:04 +02:00
parent fdb8263c46
commit 6c6eec1c71
4 changed files with 49 additions and 15 deletions

View File

@ -10,7 +10,7 @@
Monotone icons, arrow changes on hover: Monotone icons, arrow changes on hover:
<span class="text-2xl demo"> <span class="text-2xl demo">
<span <span
class="icon-[mdi-light--arrow-left] hover:icon-[mdi-light--arrow-right]" class="icon-[mdi-light--arrow-left] hover:icon-override-[mdi-light--arrow-right]"
></span> ></span>
<span class="icon-[mdi-light--forum]"></span> <span class="icon-[mdi-light--forum]"></span>
</span> </span>

View File

@ -2,6 +2,11 @@
@plugin "@iconify/tailwind4"; @plugin "@iconify/tailwind4";
@plugin "@iconify/tailwind4" {
prefix: 'icon-override';
override-only: true;
}
.demo { .demo {
color: var(--color-blue-600); color: var(--color-blue-600);
} }

View File

@ -3,7 +3,7 @@
"description": "Iconify plugin for Tailwind CSS", "description": "Iconify plugin for Tailwind CSS",
"type": "module", "type": "module",
"author": "Vjacheslav Trushkin <cyberalien@gmail.com> (https://iconify.design)", "author": "Vjacheslav Trushkin <cyberalien@gmail.com> (https://iconify.design)",
"version": "1.0.0", "version": "1.0.1",
"license": "MIT", "license": "MIT",
"main": "./dist/plugin.js", "main": "./dist/plugin.js",
"types": "./dist/plugin.d.ts", "types": "./dist/plugin.d.ts",

View File

@ -1,15 +1,43 @@
/* eslint-disable @typescript-eslint/unbound-method */ /* eslint-disable @typescript-eslint/unbound-method */
import plugin from 'tailwindcss/plugin'; import plugin from 'tailwindcss/plugin';
import { getDynamicCSSRules } from './dynamic.js'; import { getDynamicCSSRules } from './dynamic.js';
import type { DynamicIconifyPluginOptions } from './helpers/options.js';
/** /**
* Generate styles for dynamic selector * Generate styles for dynamic selector
* *
* Usage in HTML: <span class="icon-[mdi-light--home]" /> * Usage in HTML: <span class="icon-[mdi-light--home]" />
*/ */
function addDynamicIconSelectors(): ReturnType<typeof plugin> { function addDynamicIconSelectors(): ReturnType<typeof plugin.withOptions> {
const prefix = 'icon'; return plugin.withOptions((params: unknown) => {
return plugin(({ matchComponents }) => { // Clean up options
const options: DynamicIconifyPluginOptions = {};
Object.entries(params ?? {}).forEach(([key, value]) => {
switch (key) {
case 'prefix':
if (typeof value === 'string') {
options.prefix = value;
}
break;
case 'overrideOnly':
case 'override-only':
case 'overrideonly':
if (value === true) {
options.overrideOnly = true;
}
break;
case 'scale':
if (typeof value === 'number') {
options.scale = value;
}
break;
}
});
const prefix = options.prefix || 'icon';
return ({ matchComponents }) => {
matchComponents({ matchComponents({
[prefix]: (icon: string) => { [prefix]: (icon: string) => {
try { try {
@ -21,6 +49,7 @@ function addDynamicIconSelectors(): ReturnType<typeof plugin> {
} }
}, },
}); });
};
}); });
} }