Skip to content

Commit

Permalink
refactor: split home to top/left/right components (#531)
Browse files Browse the repository at this point in the history
Co-authored-by: tanzhiqiang <[email protected]>
Co-authored-by: 秦少卫 <[email protected]>
  • Loading branch information
3 people authored Nov 18, 2024
1 parent f39c9be commit 06ee669
Show file tree
Hide file tree
Showing 4 changed files with 445 additions and 399 deletions.
173 changes: 173 additions & 0 deletions src/views/home/components/left/index.vue
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>
183 changes: 183 additions & 0 deletions src/views/home/components/right/index.vue
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>
Loading

0 comments on commit 06ee669

Please sign in to comment.