123456789101112131415161718192021222324252627282930313233343536373839404142 |
- #!/usr/bin/env node
- import { buildIcons } from '../../.build/build-icons.mjs'
- const componentTemplate = ({
- name,
- children,
- stringify
- }) => {
- return `\
- <script lang="ts">
- import Icon from '../Icon.svelte';
- import type { IconNode, IconProps } from '../types.js';
- type $$Props = IconProps;
- const iconNode: IconNode = ${JSON.stringify(children)};
- </script>
- <Icon name="${name}" {...$$props} iconNode={iconNode}>
- <slot/>
- </Icon>
- `;
- };
- const aliasTemplate = ({ fromPascal, to }) => `export { default as Icon${fromPascal} } from './icons/${to}.svelte';\n`
- const indexItemTemplate = ({
- name,
- namePascal
- }) => `export { default as ${namePascal} } from './${name}.svelte';`
- buildIcons({
- name: 'icons-svelte',
- componentTemplate,
- indexItemTemplate,
- aliasTemplate,
- extension: 'svelte',
- pretty: false,
- key: false,
- indexFile: 'icons/index.ts',
- pascalName: false,
- })
|