2021-05-06 11:21:39 +03:00
|
|
|
import { defineComponent } from 'vue';
|
2021-09-27 16:58:47 +03:00
|
|
|
import type {
|
2021-05-06 11:21:39 +03:00
|
|
|
VNode,
|
|
|
|
DefineComponent,
|
|
|
|
ComponentOptionsMixin,
|
|
|
|
EmitsOptions,
|
|
|
|
VNodeProps,
|
|
|
|
AllowedComponentProps,
|
|
|
|
ComponentCustomProps,
|
|
|
|
} from 'vue';
|
2021-09-27 16:58:47 +03:00
|
|
|
import type { IconifyIcon, IconifyJSON } from '@iconify/types';
|
2022-04-30 23:12:34 +03:00
|
|
|
import type { IconifyIconSize } from '@iconify/utils/lib/customisations';
|
2021-05-24 13:25:02 +03:00
|
|
|
import { fullIcon } from '@iconify/utils/lib/icon';
|
2021-05-26 10:01:23 +03:00
|
|
|
import { parseIconSet } from '@iconify/utils/lib/icon-set/parse';
|
2022-03-31 11:07:02 +03:00
|
|
|
import { quicklyValidateIconSet } from '@iconify/utils/lib/icon-set/validate-basic';
|
2021-09-27 16:58:47 +03:00
|
|
|
import type {
|
2021-05-05 19:24:26 +03:00
|
|
|
IconifyIconCustomisations,
|
|
|
|
IconifyIconProps,
|
|
|
|
IconProps,
|
2022-04-30 22:04:40 +03:00
|
|
|
IconifyRenderMode,
|
2021-05-05 19:24:26 +03:00
|
|
|
} from './props';
|
|
|
|
import { render } from './render';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export stuff from props.ts
|
|
|
|
*/
|
|
|
|
export { IconifyIconCustomisations, IconifyIconProps, IconProps };
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export types that could be used in component
|
|
|
|
*/
|
2022-04-30 23:12:34 +03:00
|
|
|
export { IconifyIcon, IconifyJSON, IconifyIconSize, IconifyRenderMode };
|
2021-05-05 19:24:26 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Storage for icons referred by name
|
|
|
|
*/
|
|
|
|
const storage: Record<string, Required<IconifyIcon>> = Object.create(null);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add icon to storage, allowing to call it by name
|
|
|
|
*
|
|
|
|
* @param name
|
|
|
|
* @param data
|
|
|
|
*/
|
|
|
|
export function addIcon(name: string, data: IconifyIcon): void {
|
|
|
|
storage[name] = fullIcon(data);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add collection to storage, allowing to call icons by name
|
|
|
|
*
|
|
|
|
* @param data Icon set
|
|
|
|
* @param prefix Optional prefix to add to icon names, true (default) if prefix from icon set should be used.
|
|
|
|
*/
|
|
|
|
export function addCollection(
|
|
|
|
data: IconifyJSON,
|
|
|
|
prefix?: string | boolean
|
|
|
|
): void {
|
|
|
|
const iconPrefix: string =
|
|
|
|
typeof prefix === 'string'
|
|
|
|
? prefix
|
|
|
|
: prefix !== false && typeof data.prefix === 'string'
|
|
|
|
? data.prefix + ':'
|
|
|
|
: '';
|
2022-03-31 11:07:02 +03:00
|
|
|
quicklyValidateIconSet(data) &&
|
|
|
|
parseIconSet(data, (name, icon) => {
|
2021-10-12 17:17:51 +03:00
|
|
|
if (icon) {
|
|
|
|
storage[iconPrefix + name] = icon;
|
|
|
|
}
|
2022-03-31 11:07:02 +03:00
|
|
|
});
|
2021-05-05 19:24:26 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Component
|
|
|
|
*/
|
2021-05-06 11:21:39 +03:00
|
|
|
export const Icon = defineComponent({
|
|
|
|
// Do not inherit other attributes: it is handled by render()
|
|
|
|
inheritAttrs: false,
|
|
|
|
|
|
|
|
// Render icon
|
2021-05-05 19:24:26 +03:00
|
|
|
render() {
|
2021-05-06 11:21:39 +03:00
|
|
|
const props = this.$attrs;
|
2021-05-05 19:24:26 +03:00
|
|
|
|
|
|
|
// Check icon
|
|
|
|
const icon =
|
|
|
|
typeof props.icon === 'string'
|
|
|
|
? storage[props.icon]
|
|
|
|
: typeof props.icon === 'object'
|
|
|
|
? fullIcon(props.icon)
|
|
|
|
: null;
|
|
|
|
|
|
|
|
// Validate icon object
|
|
|
|
if (
|
|
|
|
icon === null ||
|
|
|
|
typeof icon !== 'object' ||
|
|
|
|
typeof icon.body !== 'string'
|
|
|
|
) {
|
|
|
|
return this.$slots.default ? this.$slots.default() : null;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Valid icon: render it
|
|
|
|
return render(icon, props);
|
|
|
|
},
|
2021-05-06 11:21:39 +03:00
|
|
|
});
|