English | 中文
一个构建图标库的启动模板。
- 📦 支持 svg 转换为 vue3、react 组件和 esm、cjs 模块
- 📦 支持 svg 转换为 web 字体
- 📦 支持图标组件自动导入
- 📦 支持图标预览站点
- 📦 支持从 figma 设计文件中获取所有 svg 文件
- 📦 提供发布相关工具,支持 npm、github 发布和变更日志生成
https://varletjs.github.io/varlet-icons-library-starter
import '<packageName>/svg-fonts/css/i-icons.css'
<i class="i i-account-circle-outline"></i>
<i class="i i-account-circle-outline" style="color: red; font-size: 30px"></i>
<script setup>
import { XIcon, AccountCircleOutline } from '<packageName>'
</script>
<template>
<x-icon>
<account-circle-outline />
</x-icon>
<x-icon color="red" :size="30">
<account-circle-outline />
</x-icon>
</template>
import { XIcon, AccountCircleOutline } from '<packageName>'
function Demo() {
return <>
<XIcon>
<AccountCircleOutline />
</XIcon>
<XIcon color="red" size={30}>
<AccountCircleOutline />
</XIcon>
</>
}
当我们生成图标组件时,我们也会为 unplugin-vue-components 生成一个 resolver
用于自动导入图标组件。
这里我们以 vite
搭配 vue component
为例。
// vite.config.ts
import components from 'unplugin-vue-components/vite'
import XIconResolver from '<packageName>/resolver'
import { defineConfig } from 'vite'
export default defineConfig({
plugins: [
components({
resolvers: [XIconResolver()]
})
]
})
<template>
<x-icon>
<x-account-circle-outline />
</x-icon>
<x-icon color="red" :size="30">
<x-account-circle-outline />
</x-icon>
</template>
我们支持 Vue3 和 React,默认将组件编译为 Vue3。如果要生成 React 组件,请参考以下配置。
// vi.config.ts
import { defineConfig } from '@varlet/icon-builder'
export default defineConfig({
name: 'i-icons',
namespace: 'i',
fontFamilyClassName: 'i',
output: './svg-fonts'
+ generate: {
+ framework: 'react'
+ }
})
// package.json
{
"peerDependencies": {
"unplugin-vue-components": "^0.27.0",
- "vue": "^3.4.29",
+ "react": "^18.3.1"
},
}
我们支持从 figma 文档中获取 svg 图标,具体实现步骤如下
创建一个 figma 文档,将 svg 图标库的页面名称设置为 Icons
,并获取到文件 id。
获取 figma 文档的访问 token。
设置 token 和 file id 到脚本中。(为了 token 的安全性,更推荐将 token 设置到 ci 环境变量中)。
// package.json
"scripts": {
- "icons:figma": "VI_FIGMA_TOKEN=123456 vi figma -f 123456",
+ "icons:figma": "VI_FIGMA_TOKEN=<token> vi figma -f <fileId>",
}
如果你希望设计师更新 figma 图标库的时候自动执行图标库的构建,可以接入 figma 的 webhook,这样可以完全打通设计师和前端开发工程师的自动化工作流。 详情见 figma webhook。
pnpm dev
pnpm build
pnpm preview
pnpm icons:build
pnpm icons:generate
pnpm icons:figma
pnpm release
我们推荐使用 issue 列表进行最直接有效的反馈,也可以下面的方式
- 微信
- 加入 Discord 社区交流
赞助本项目,支持我们更好的创作。