-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
refactor: split home to top/left/right components (#531)
Co-authored-by: tanzhiqiang <[email protected]> Co-authored-by: 秦少卫 <[email protected]>
- Loading branch information
1 parent
f39c9be
commit 06ee669
Showing
4 changed files
with
445 additions
and
399 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,173 @@ | ||
<script lang="ts" setup> | ||
// 左侧组件 | ||
import importTmpl from '@/components/importTmpl.vue'; | ||
import fontStyle from '@/components/fontStyle.vue'; | ||
import myMaterial from '@/components/myMaterial/index.vue'; | ||
import tools from '@/components/tools.vue'; | ||
import material from '@/components/material.vue'; | ||
import layer from '@/components/layer.vue'; | ||
import { useI18n } from 'vue-i18n'; | ||
// 路由 | ||
import { useRoute } from 'vue-router'; | ||
const { t } = useI18n(); | ||
const state = reactive({ | ||
menuActive: 1, | ||
toolsBarShow: true, | ||
}); | ||
// 左侧菜单渲染 | ||
const menuActive = ref('importTmpl'); | ||
const leftBarComponent = { | ||
importTmpl, | ||
tools, | ||
material, | ||
fontStyle, | ||
layer, | ||
myMaterial, | ||
}; | ||
// fix: 修复vue-i18n function "t" not reactive inside ref object | ||
// https://github.com/intlify/vue-i18n/issues/1396#issuecomment-1716123143 | ||
const leftBar = reactive([ | ||
{ | ||
//模板 | ||
key: 'importTmpl', | ||
name: computed(() => t('templates')), | ||
icon: 'md-book', | ||
}, | ||
{ | ||
//基础元素 | ||
key: 'tools', | ||
name: computed(() => t('elements')), | ||
icon: 'md-images', | ||
}, | ||
{ | ||
//字体样式 | ||
key: 'fontStyle', | ||
name: computed(() => t('font_style')), | ||
icon: 'ios-pulse', | ||
}, | ||
{ | ||
// 图片元素 | ||
key: 'material', | ||
name: computed(() => t('material.cartoon')), | ||
icon: 'ios-leaf-outline', | ||
}, | ||
{ | ||
// 图层 | ||
key: 'layer', | ||
name: computed(() => t('layers')), | ||
icon: 'md-reorder', | ||
}, | ||
{ | ||
// 用户素材 | ||
key: 'myMaterial', | ||
name: computed(() => t('mine')), | ||
icon: 'ios-contact-outline', | ||
}, | ||
]); | ||
// 隐藏工具条 | ||
const hideToolsBar = () => { | ||
state.toolsBarShow = !state.toolsBarShow; | ||
}; | ||
// 展示工具条 | ||
const showToolsBar = (val) => { | ||
menuActive.value = val; | ||
state.toolsBarShow = true; | ||
}; | ||
onMounted(() => { | ||
// 有ID时,打开作品面板 | ||
const route = useRoute(); | ||
if (route?.query?.id) { | ||
menuActive.value = 'myMaterial'; | ||
} | ||
}); | ||
</script> | ||
|
||
<template> | ||
<div :class="`left-bar ${state.toolsBarShow && 'show-tools-bar'}`"> | ||
<!-- 左侧菜单 --> | ||
<Menu :active-name="menuActive" accordion @on-select="showToolsBar" width="65px"> | ||
<MenuItem v-for="item in leftBar" :key="item.key" :name="item.key" class="menu-item"> | ||
<Icon :type="item.icon" size="24" /> | ||
<div>{{ item.name }}</div> | ||
</MenuItem> | ||
</Menu> | ||
<!-- 左侧组件 --> | ||
<div class="content" v-show="state.toolsBarShow"> | ||
<div class="left-panel"> | ||
<KeepAlive> | ||
<component :is="leftBarComponent[menuActive]"></component> | ||
</KeepAlive> | ||
</div> | ||
</div> | ||
<!-- 关闭按钮 --> | ||
<div | ||
:class="`close-btn left-btn ${state.toolsBarShow && 'left-btn-open'}`" | ||
@click="hideToolsBar" | ||
></div> | ||
</div> | ||
</template> | ||
|
||
<style lang="less" scoped> | ||
// 左侧容器 | ||
.left-bar { | ||
width: 65px; | ||
height: 100%; | ||
background: #fff; | ||
display: flex; | ||
position: relative; | ||
&.show-tools-bar { | ||
width: 380px; | ||
} | ||
} | ||
.ivu-menu-vertical .menu-item { | ||
text-align: center; | ||
padding: 10px 2px; | ||
box-sizing: border-box; | ||
font-size: 12px; | ||
& > i { | ||
margin: 0; | ||
} | ||
} | ||
.ivu-menu-light.ivu-menu-vertical .ivu-menu-item-active:not(.ivu-menu-submenu) { | ||
background: none; | ||
} | ||
.content { | ||
flex: 1; | ||
width: 220px; | ||
padding: 0 10px; | ||
height: 100%; | ||
overflow-y: auto; | ||
} | ||
// 关闭按钮 | ||
.close-btn { | ||
width: 20px; | ||
height: 64px; | ||
cursor: pointer; | ||
background-image: url(); | ||
background-repeat: no-repeat; | ||
background-size: cover; | ||
background-position: 50%; | ||
position: absolute; | ||
right: -20px; | ||
z-index: 1; | ||
top: 50%; | ||
margin-top: -10px; | ||
&.left-btn { | ||
background-image: url(); | ||
} | ||
&.left-btn-open { | ||
background-image: url(); | ||
transform: rotateY(360deg); | ||
} | ||
} | ||
</style> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,183 @@ | ||
<script lang="ts" setup> | ||
import align from '@/components/align.vue'; | ||
import centerAlign from '@/components/centerAlign.vue'; | ||
import flip from '@/components/flip.vue'; | ||
import clone from '@/components/clone.vue'; | ||
import hide from '@/components/hide.vue'; | ||
import group from '@/components/group.vue'; | ||
import lock from '@/components/lock.vue'; | ||
import dele from '@/components/del.vue'; | ||
import bgBar from '@/components/bgBar.vue'; | ||
import setSize from '@/components/setSize.vue'; | ||
import replaceImg from '@/components/replaceImg.vue'; | ||
import filters from '@/components/filters.vue'; | ||
import imgStroke from '@/components/imgStroke.vue'; | ||
// import elementData from '@/components/elementData.vue'; | ||
// 右侧组件 | ||
// import attribute from '@/components/attribute.vue'; | ||
import attributePostion from '@/components/attributePostion.vue'; | ||
import attributeId from '@/components/attributeId.vue'; | ||
import attributeShadow from '@/components/attributeShadow.vue'; | ||
import attributeBorder from '@/components/attributeBorder.vue'; | ||
import attributeRounded from '@/components/attributeRounded.vue'; | ||
import attributeFont from '@/components/attributeFont.vue'; | ||
import attributeTextFloat from '@/components/attributeTextFloat.vue'; | ||
import attributeColor from '@/components/attributeColor.vue'; | ||
import attributeBarcode from '@/components/attributeBarcode.vue'; | ||
import attributeQrCode from '@/components/attributeQrCode.vue'; | ||
// hooks | ||
import useSelectListen from '@/hooks/useSelectListen'; | ||
const canvasEditor: any = inject('canvasEditor'); | ||
const { mixinState } = useSelectListen(canvasEditor); | ||
const attrBarShow = ref(true); | ||
// 属性面板开关 | ||
const switchAttrBar = () => { | ||
attrBarShow.value = !attrBarShow.value; | ||
}; | ||
</script> | ||
|
||
<template> | ||
<!-- 属性区域 380--> | ||
<div class="right-bar" v-show="attrBarShow"> | ||
<div style="padding-top: 10px"> | ||
<!-- 未选择元素时 展示背景设置 --> | ||
<div v-show="!mixinState.mSelectMode"> | ||
<set-size></set-size> | ||
<bg-bar></bg-bar> | ||
</div> | ||
|
||
<!-- 多选时展示 --> | ||
<div v-show="mixinState.mSelectMode === 'multiple'"> | ||
<!-- 分组 --> | ||
<group></group> | ||
<!-- <Divider plain></Divider> --> | ||
<!-- 组对齐方式 --> | ||
<align></align> | ||
<!-- 居中对齐 --> | ||
<center-align></center-align> | ||
</div> | ||
|
||
<div v-show="mixinState.mSelectMode === 'one'" class="attr-item-box"> | ||
<!-- <h3>快捷操作</h3> --> | ||
<!-- 分组 --> | ||
<group></group> | ||
<!-- <Divider plain></Divider> --> | ||
<Divider plain orientation="left"> | ||
<h4>快捷操作</h4> | ||
</Divider> | ||
<div class="bg-item" v-show="mixinState.mSelectMode"> | ||
<lock></lock> | ||
<dele></dele> | ||
<clone></clone> | ||
<hide></hide> | ||
<edit></edit> | ||
</div> | ||
<!-- <Divider plain></Divider> --> | ||
<!-- 居中对齐 --> | ||
<center-align></center-align> | ||
<!-- 替换图片 --> | ||
<replaceImg></replaceImg> | ||
<!-- 图片裁切 --> | ||
<clip-image></clip-image> | ||
<!-- 翻转 --> | ||
<flip></flip> | ||
<!-- 条形码属性 --> | ||
<attributeBarcode></attributeBarcode> | ||
<!-- 二维码 --> | ||
<attributeQrCode></attributeQrCode> | ||
<!-- 图片滤镜 --> | ||
<filters></filters> | ||
<!-- 图片描边 --> | ||
<imgStroke /> | ||
<!-- 颜色 --> | ||
<attributeColor></attributeColor> | ||
<!-- 字体属性 --> | ||
<attributeFont></attributeFont> | ||
<!-- 字体小数点 --> | ||
<attributeTextFloat></attributeTextFloat> | ||
<!-- 文字内容 --> | ||
<attribute-text-content></attribute-text-content> | ||
<!-- 位置信息 --> | ||
<attributePostion></attributePostion> | ||
<!-- 阴影 --> | ||
<attributeShadow></attributeShadow> | ||
<!-- 边框 --> | ||
<attributeBorder></attributeBorder> | ||
<!-- 圆角 --> | ||
<attributeRounded></attributeRounded> | ||
<!-- 关联数据 --> | ||
<attributeId></attributeId> | ||
|
||
<!-- 新增字体样式使用 --> | ||
<Button @click="canvasEditor.getFontJson()" size="small">获取元素数据</Button> | ||
</div> | ||
</div> | ||
<!-- <attribute v-if="state.show"></attribute> --> | ||
</div> | ||
<!-- 右侧关闭按钮 --> | ||
<div | ||
:class="`close-btn right-btn ${attrBarShow && 'right-btn-open'}`" | ||
@click="switchAttrBar" | ||
></div> | ||
</template> | ||
|
||
<style lang="less" scoped> | ||
// 右侧容器 | ||
.right-bar { | ||
width: 304px; | ||
height: 100%; | ||
padding: 10px; | ||
overflow-y: auto; | ||
background: #fff; | ||
} | ||
// 属性面板样式 | ||
:deep(.attr-item) { | ||
position: relative; | ||
margin-bottom: 12px; | ||
height: 40px; | ||
padding: 0 10px; | ||
background: #f6f7f9; | ||
border: none; | ||
border-radius: 4px; | ||
display: flex; | ||
align-items: center; | ||
.ivu-tooltip { | ||
text-align: center; | ||
flex: 1; | ||
} | ||
} | ||
// 关闭按钮 | ||
.close-btn { | ||
width: 20px; | ||
height: 64px; | ||
cursor: pointer; | ||
background-image: url(); | ||
background-repeat: no-repeat; | ||
background-size: cover; | ||
background-position: 50%; | ||
position: absolute; | ||
right: -20px; | ||
z-index: 1; | ||
top: 50%; | ||
margin-top: -10px; | ||
&.right-btn { | ||
background-image: url(); | ||
transform: rotateY(180deg); | ||
right: 0px; | ||
} | ||
&.right-btn-open { | ||
background-image: url(); | ||
right: 304px; | ||
} | ||
} | ||
</style> |
Oops, something went wrong.