feat: iconify图标新增离线功能

This commit is contained in:
奔跑的面条 2023-12-17 00:12:50 +08:00
parent ce1a5476d6
commit 4c7c5cf4ba
10 changed files with 147 additions and 88 deletions

View File

@ -16,6 +16,7 @@
"dependencies": { "dependencies": {
"@amap/amap-jsapi-loader": "^1.0.1", "@amap/amap-jsapi-loader": "^1.0.1",
"@amap/amap-jsapi-types": "^0.0.8", "@amap/amap-jsapi-types": "^0.0.8",
"@iconify/json": "^2.2.158",
"@types/color": "^3.0.3", "@types/color": "^3.0.3",
"@types/crypto-js": "^4.1.1", "@types/crypto-js": "^4.1.1",
"@types/keymaster": "^1.6.30", "@types/keymaster": "^1.6.30",
@ -32,6 +33,7 @@
"gsap": "^3.11.3", "gsap": "^3.11.3",
"highlight.js": "^11.5.0", "highlight.js": "^11.5.0",
"html2canvas": "^1.4.1", "html2canvas": "^1.4.1",
"iconify-icon": "^1.0.8",
"keymaster": "^1.6.2", "keymaster": "^1.6.2",
"mitt": "^3.0.0", "mitt": "^3.0.0",
"monaco-editor": "^0.33.0", "monaco-editor": "^0.33.0",
@ -50,8 +52,6 @@
"devDependencies": { "devDependencies": {
"@commitlint/cli": "^17.0.2", "@commitlint/cli": "^17.0.2",
"@commitlint/config-conventional": "^17.0.2", "@commitlint/config-conventional": "^17.0.2",
"@iconify/types": "^2.0.0",
"@iconify/vue": "^4.1.1",
"@types/node": "^16.11.26", "@types/node": "^16.11.26",
"@types/three": "^0.144.0", "@types/three": "^0.144.0",
"@typescript-eslint/eslint-plugin": "^5.18.0", "@typescript-eslint/eslint-plugin": "^5.18.0",

View File

@ -11,6 +11,9 @@ dependencies:
'@amap/amap-jsapi-types': '@amap/amap-jsapi-types':
specifier: ^0.0.8 specifier: ^0.0.8
version: 0.0.8 version: 0.0.8
'@iconify/json':
specifier: ^2.2.158
version: 2.2.158
'@types/color': '@types/color':
specifier: ^3.0.3 specifier: ^3.0.3
version: 3.0.3 version: 3.0.3
@ -59,6 +62,9 @@ dependencies:
html2canvas: html2canvas:
specifier: ^1.4.1 specifier: ^1.4.1
version: 1.4.1 version: 1.4.1
iconify-icon:
specifier: ^1.0.8
version: 1.0.8
keymaster: keymaster:
specifier: ^1.6.2 specifier: ^1.6.2
version: 1.6.2 version: 1.6.2
@ -87,7 +93,7 @@ dependencies:
specifier: ^0.13.1 specifier: ^0.13.1
version: 0.13.1(vue@3.2.37) version: 0.13.1(vue@3.2.37)
vue-i18n: vue-i18n:
specifier: ^9.2.2 specifier: 9.2.2
version: 9.2.2(vue@3.2.37) version: 9.2.2(vue@3.2.37)
vue-router: vue-router:
specifier: 4.0.12 specifier: 4.0.12
@ -109,12 +115,6 @@ devDependencies:
'@commitlint/config-conventional': '@commitlint/config-conventional':
specifier: ^17.0.2 specifier: ^17.0.2
version: 17.0.2 version: 17.0.2
'@iconify/types':
specifier: ^2.0.0
version: 2.0.0
'@iconify/vue':
specifier: ^4.1.1
version: 4.1.1(vue@3.2.37)
'@types/node': '@types/node':
specifier: ^16.11.26 specifier: ^16.11.26
version: 16.11.40 version: 16.11.40
@ -1122,18 +1122,16 @@ packages:
resolution: {integrity: sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==} resolution: {integrity: sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==}
dev: true dev: true
/@iconify/types@2.0.0: /@iconify/json@2.2.158:
resolution: {integrity: sha512-+wluvCrRhXrhyOmRDJ3q8mux9JkKy5SJ/v8ol2tu4FVjyYvtEzkc/3pK15ET6RKg4b4w4BmTk1+gsCUhf21Ykg==} resolution: {integrity: sha512-6foGYcG97nmYpJ7N0MAbtfH7SKf7RvoOCYYSBi8gs+8qopXzplIP2F4lQiLrjpbPQihAoTercmGYWi4ABxLX1A==}
dev: true
/@iconify/vue@4.1.1(vue@3.2.37):
resolution: {integrity: sha512-RL85Bm/DAe8y6rT6pux7D2FJSiUEM/TPfyK7GrbAOfTSwrhvwJW+S5yijdGcmtXouA8MtuH9C7l4hiSE4mLMjg==}
peerDependencies:
vue: '>=3'
dependencies: dependencies:
'@iconify/types': 2.0.0 '@iconify/types': 2.0.0
vue: 3.2.37 pathe: 1.1.1
dev: true dev: false
/@iconify/types@2.0.0:
resolution: {integrity: sha512-+wluvCrRhXrhyOmRDJ3q8mux9JkKy5SJ/v8ol2tu4FVjyYvtEzkc/3pK15ET6RKg4b4w4BmTk1+gsCUhf21Ykg==}
dev: false
/@intlify/core-base@9.2.2: /@intlify/core-base@9.2.2:
resolution: {integrity: sha512-JjUpQtNfn+joMbrXvpR4hTF8iJQ2sEFzzK3KIESOx+f+uwIjgw20igOyaIdhfsVVBCds8ZM64MoeNSx+PHQMkA==} resolution: {integrity: sha512-JjUpQtNfn+joMbrXvpR4hTF8iJQ2sEFzzK3KIESOx+f+uwIjgw20igOyaIdhfsVVBCds8ZM64MoeNSx+PHQMkA==}
@ -3668,6 +3666,12 @@ packages:
hasBin: true hasBin: true
dev: true dev: true
/iconify-icon@1.0.8:
resolution: {integrity: sha512-jvbUKHXf8EnGGArmhlP2IG8VqQLFFyTvTqb9LVL2TKTh7/eCCD1o2HHE9thpbJJb6B8hzhcFb6rOKhvo7reNKA==}
dependencies:
'@iconify/types': 2.0.0
dev: false
/iconv-lite@0.4.24: /iconv-lite@0.4.24:
resolution: {integrity: sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==} resolution: {integrity: sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==}
engines: {node: '>=0.10.0'} engines: {node: '>=0.10.0'}
@ -4741,6 +4745,10 @@ packages:
engines: {node: '>=8'} engines: {node: '>=8'}
dev: true dev: true
/pathe@1.1.1:
resolution: {integrity: sha512-d+RQGp0MAYTIaDBIMmOfMwz3E+LOZnxx1HZd5R18mmCZY0QBlK0LDZfPc8FW8Ed2DlvsuE6PRjroDY+wg4+j/Q==}
dev: false
/picocolors@1.0.0: /picocolors@1.0.0:
resolution: {integrity: sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==} resolution: {integrity: sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==}

View File

@ -0,0 +1,3 @@
import GoIconify from './index.vue';
export { GoIconify };

View File

@ -0,0 +1,34 @@
<template>
<iconify-icon
:icon="icon"
:rotate="`${rotate}deg`"
:width="width"
:style="{
color: color
}"
></iconify-icon>
</template>
<script setup lang="ts">
defineProps({
icon: {
type: String,
required: true
},
color: {
type: String,
default: '#999999',
required: false
},
width: {
type: [String, Number],
default: '20',
required: false
},
rotate: {
type: [String, Number],
default: '0',
required: false
}
})
</script>

View File

@ -6,6 +6,10 @@ import { setupStore } from '@/store'
import { setupNaive, setupDirectives, setupCustomComponents, initFunction } from '@/plugins' import { setupNaive, setupDirectives, setupCustomComponents, initFunction } from '@/plugins'
import { GoAppProvider } from '@/components/GoAppProvider/index' import { GoAppProvider } from '@/components/GoAppProvider/index'
import { setHtmlTheme } from '@/utils' import { setHtmlTheme } from '@/utils'
import { addCollection } from 'iconify-icon'
import uimIcons from '@iconify/json/json/uim.json'
import lineMdIcons from '@iconify/json/json/line-md.json'
import wiIcons from '@iconify/json/json/wi.json'
// 引入全局样式 // 引入全局样式
import '@/styles/pages/index.scss' import '@/styles/pages/index.scss'
@ -13,6 +17,10 @@ import '@/styles/pages/index.scss'
import 'animate.css/animate.min.css' import 'animate.css/animate.min.css'
// 引入标尺 // 引入标尺
import 'vue3-sketch-ruler/lib/style.css' import 'vue3-sketch-ruler/lib/style.css'
// 注册图标
addCollection(uimIcons)
addCollection(lineMdIcons)
addCollection(wiIcons)
async function appInit() { async function appInit() {
const goAppProvider = createApp(GoAppProvider) const goAppProvider = createApp(GoAppProvider)

View File

@ -1,13 +1,13 @@
<template> <template>
<div class="go-icon-box"> <div class="go-icon-box">
<Icon :icon="((dataset || '') as string)" :color="color" :width="size" :rotate="rotate" /> <GoIconify :icon="((dataset || '') as string)" :color="color" :width="size" :rotate="rotate" />
</div> </div>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { PropType, toRefs } from 'vue' import { PropType, toRefs } from 'vue'
import { CreateComponentType } from '@/packages/index.d' import { CreateComponentType } from '@/packages/index.d'
import { Icon } from '@iconify/vue' import { GoIconify } from '@/components/GoIconify'
const props = defineProps({ const props = defineProps({
chartConfig: { chartConfig: {

View File

@ -23,7 +23,7 @@
</n-text> </n-text>
</div> </div>
<div class="list-center go-flex-center go-transition" draggable="true"> <div class="list-center go-flex-center go-transition" draggable="true">
<Icon v-if="item.icon" class="list-img" :icon="item.icon" color="#999" width="48" /> <GoIconify v-if="item.icon" class="list-img" :icon="item.icon" color="#999" width="48" style="height: auto" />
<chart-glob-image v-else class="list-img" :chartConfig="item" /> <chart-glob-image v-else class="list-img" :chartConfig="item" />
</div> </div>
<div class="list-bottom"> <div class="list-bottom">
@ -64,7 +64,7 @@ import { createComponent } from '@/packages'
import { ConfigType, CreateComponentType, PackagesCategoryEnum } from '@/packages/index.d' import { ConfigType, CreateComponentType, PackagesCategoryEnum } from '@/packages/index.d'
import { ChatCategoryEnum } from '@/packages/components/Photos/index.d' import { ChatCategoryEnum } from '@/packages/components/Photos/index.d'
import { fetchConfigComponent, fetchChartComponent } from '@/packages/index' import { fetchConfigComponent, fetchChartComponent } from '@/packages/index'
import { Icon } from '@iconify/vue' import { GoIconify } from '@/components/GoIconify'
import { icon } from '@/plugins' import { icon } from '@/plugins'
import omit from 'lodash/omit' import omit from 'lodash/omit'

View File

@ -37,7 +37,7 @@
:title="item.title" :title="item.title"
@click="selectChartHandle(item)" @click="selectChartHandle(item)"
> >
<Icon v-if="item.icon" class="list-img" :icon="item.icon" color="#999" width="20" /> <GoIconify v-if="item.icon" class="list-img" :icon="item.icon" color="#999" width="20" />
<chart-glob-image v-else class="list-item-img" :chartConfig="item" /> <chart-glob-image v-else class="list-item-img" :chartConfig="item" />
<n-text class="list-item-fs" depth="2">{{ item.title }}</n-text> <n-text class="list-item-fs" depth="2">{{ item.title }}</n-text>
</div> </div>
@ -79,7 +79,7 @@ import { isString, addEventListener, removeEventListener } from '@/utils'
import { fetchConfigComponent, fetchChartComponent } from '@/packages/index' import { fetchConfigComponent, fetchChartComponent } from '@/packages/index'
import { componentInstall, loadingStart, loadingFinish, loadingError } from '@/utils' import { componentInstall, loadingStart, loadingFinish, loadingError } from '@/utils'
import { ChartGlobImage } from '@/components/Pages/ChartGlobImage' import { ChartGlobImage } from '@/components/Pages/ChartGlobImage'
import { Icon } from '@iconify/vue' import { GoIconify } from '@/components/GoIconify'
const props = defineProps({ const props = defineProps({
menuOptions: { menuOptions: {

View File

@ -6,4 +6,3 @@ declare module '*.vue' {
declare module 'lodash/*' declare module 'lodash/*'
declare module 'dom-helpers' declare module 'dom-helpers'
declare module '@iconify/vue'

View File

@ -25,7 +25,7 @@ export default defineConfig({
}, },
{ {
find: 'vue-i18n', find: 'vue-i18n',
replacement: 'vue-i18n/dist/vue-i18n.cjs.js', //解决i8n警告 replacement: 'vue-i18n/dist/vue-i18n.cjs.js' //解决i8n警告
} }
], ],
dedupe: ['vue'] dedupe: ['vue']
@ -40,7 +40,14 @@ export default defineConfig({
} }
}, },
plugins: [ plugins: [
vue(), vue({
template: {
compilerOptions: {
// 排除 iconify 图标影子组件编译报错
isCustomElement: tag => tag.startsWith('iconify-icon')
}
}
}),
monacoEditorPlugin({ monacoEditorPlugin({
languageWorkers: ['editorWorkerService', 'typescript', 'json', 'html'] languageWorkers: ['editorWorkerService', 'typescript', 'json', 'html']
}), }),