2
0
mirror of https://github.com/iconify/iconify.git synced 2024-10-24 01:22:04 +00:00
iconify/packages/vue/src/props.ts

65 lines
1.5 KiB
TypeScript
Raw Normal View History

import type { IconifyIcon } from '@iconify/types';
import type { IconifyIconCustomisations as RawIconCustomisations } from '@iconify/utils/lib/customisations';
export { RawIconCustomisations };
2021-05-05 16:24:26 +00:00
2022-04-15 06:58:43 +00:00
/**
* Icon render mode
*
* 'style' = 'bg' or 'mask', depending on icon content
* 'bg' = <span> with style using `background`
* 'mask' = <span> with style using `mask`
* 'svg' = <svg>
2022-04-15 06:58:43 +00:00
*/
export type IconifyRenderMode = 'style' | 'bg' | 'mask' | 'svg';
2022-04-15 06:58:43 +00:00
2021-05-05 16:24:26 +00:00
// Allow rotation to be string
/**
* Icon customisations
*/
export type IconifyIconCustomisations = RawIconCustomisations & {
2021-05-05 16:24:26 +00:00
rotate?: string | number;
};
/**
* Callback for when icon has been loaded (only triggered for icons loaded from API)
*/
export type IconifyIconOnLoad = (name: string) => void;
2021-05-05 16:24:26 +00:00
/**
* Icon properties
*/
export interface IconifyIconProps extends IconifyIconCustomisations {
// Icon object
icon: IconifyIcon | string;
2022-04-15 06:58:43 +00:00
// Render mode
mode?: IconifyRenderMode;
2021-05-05 16:24:26 +00:00
// Style
color?: string;
// Shorthand properties
flip?: string;
align?: string;
}
/**
* Properties for element that are mentioned in render.ts
*/
interface IconifyElementProps {
// Unique id, used as base for ids for shapes. Use it to get consistent ids for server side rendering
id?: string;
// Style
style?: unknown;
// Callback to call when icon data has been loaded. Used only for icons loaded from API
onLoad?: IconifyIconOnLoad;
2021-05-05 16:24:26 +00:00
}
/**
* Mix of icon properties and HTMLElement properties
*/
export type IconProps = IconifyElementProps & IconifyIconProps;