mirror of
https://gitee.com/dromara/go-view.git
synced 2025-02-24 00:02:51 +08:00
feat: 创建通用图标组件
This commit is contained in:
parent
d472f53dfb
commit
338b4e0b55
20
src/packages/components/Icons/Icon/config.ts
Normal file
20
src/packages/components/Icons/Icon/config.ts
Normal file
@ -0,0 +1,20 @@
|
||||
import { PublicConfigClass } from '@/packages/public'
|
||||
import { CreateComponentType } from '@/packages/index.d'
|
||||
import { chartInitConfig } from '@/settings/designSetting'
|
||||
import { IconConfig } from './index'
|
||||
import cloneDeep from 'lodash/cloneDeep'
|
||||
|
||||
export const option = {
|
||||
// 图标名称
|
||||
dataset: 'uim:apple',
|
||||
color: '#03A9F4',
|
||||
size: 64,
|
||||
rotate: 0 // 旋转角度
|
||||
}
|
||||
|
||||
export default class Config extends PublicConfigClass implements CreateComponentType {
|
||||
public key = IconConfig.key
|
||||
public attr = { ...chartInitConfig, w: 64, h: 64, zIndex: 1 }
|
||||
public chartConfig = cloneDeep(IconConfig)
|
||||
public option = cloneDeep(option)
|
||||
}
|
50
src/packages/components/Icons/Icon/config.vue
Normal file
50
src/packages/components/Icons/Icon/config.vue
Normal file
@ -0,0 +1,50 @@
|
||||
<template>
|
||||
<collapse-item name="属性" :expanded="true">
|
||||
<setting-item-box name="样式">
|
||||
<setting-item name="颜色">
|
||||
<n-color-picker size="small" :modes="['hex']" v-model:value="optionData.color"></n-color-picker>
|
||||
</setting-item>
|
||||
<setting-item name="尺寸">
|
||||
<n-input-number v-model:value="optionData.size" size="small" :min="0" placeholder="尺寸"></n-input-number>
|
||||
</setting-item>
|
||||
</setting-item-box>
|
||||
<setting-item-box name="旋转">
|
||||
<setting-item name="旋转">
|
||||
<n-select v-model:value="optionData.rotate" size="small" :options="rotateMode"></n-select>
|
||||
</setting-item>
|
||||
</setting-item-box>
|
||||
</collapse-item>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
import { PropType } from 'vue'
|
||||
import { option } from './config'
|
||||
import { CollapseItem, SettingItemBox, SettingItem } from '@/components/Pages/ChartItemSetting'
|
||||
|
||||
const props = defineProps({
|
||||
optionData: {
|
||||
type: Object as PropType<typeof option>,
|
||||
required: true
|
||||
}
|
||||
})
|
||||
|
||||
// 旋转方式
|
||||
const rotateMode = [
|
||||
{
|
||||
value: 0,
|
||||
label: '0°'
|
||||
},
|
||||
{
|
||||
value: 1,
|
||||
label: '90°'
|
||||
},
|
||||
{
|
||||
value: 2,
|
||||
label: '180°'
|
||||
},
|
||||
{
|
||||
value: 3,
|
||||
label: '270°'
|
||||
}
|
||||
]
|
||||
</script>
|
14
src/packages/components/Icons/Icon/index.ts
Normal file
14
src/packages/components/Icons/Icon/index.ts
Normal file
@ -0,0 +1,14 @@
|
||||
import { ConfigType, PackagesCategoryEnum, ChartFrameEnum } from '@/packages/index.d'
|
||||
import { ChatCategoryEnum, ChatCategoryEnumName } from '../index.d'
|
||||
|
||||
export const IconConfig: ConfigType = {
|
||||
key: 'Icon',
|
||||
chartKey: 'VIcon',
|
||||
conKey: 'VCIcon',
|
||||
title: '图标',
|
||||
category: ChatCategoryEnum.UNICONS,
|
||||
categoryName: ChatCategoryEnumName.UNICONS,
|
||||
package: PackagesCategoryEnum.ICONS,
|
||||
chartFrame: ChartFrameEnum.COMMON,
|
||||
image: 'icon.png'
|
||||
}
|
31
src/packages/components/Icons/Icon/index.vue
Normal file
31
src/packages/components/Icons/Icon/index.vue
Normal file
@ -0,0 +1,31 @@
|
||||
<template>
|
||||
<div class="go-icon-box">
|
||||
<Icon :icon="((dataset || '') as string)" :color="color" :width="size" :rotate="rotate" />
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
import { PropType, toRefs } from 'vue'
|
||||
import { CreateComponentType } from '@/packages/index.d'
|
||||
import { Icon } from '@iconify/vue'
|
||||
|
||||
const props = defineProps({
|
||||
chartConfig: {
|
||||
type: Object as PropType<CreateComponentType>,
|
||||
required: true
|
||||
}
|
||||
})
|
||||
|
||||
const { w, h } = toRefs(props.chartConfig.attr)
|
||||
const { dataset, color, size, rotate } = toRefs(props.chartConfig.option)
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
@include go('icon-box') {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
width: v-bind('`${w}px`');
|
||||
height: v-bind('`${h}px`');
|
||||
}
|
||||
</style>
|
Loading…
Reference in New Issue
Block a user