<script lang="ts" setup>
|
// import align from '@/fabric-editor/components/align.vue';
|
// import centerAlign from '@/fabric-editor/components/centerAlign.vue';
|
// import flip from '@/components/flip.vue';
|
|
// import clone from '@/components/clone.vue';
|
// import hide from '@/components/hide.vue';
|
import group from '@/fabric-editor/components/group.vue';
|
import lock from '@/fabric-editor/components/lock.vue';
|
import dele from '@/fabric-editor/components/del.vue';
|
import previewImageList from '@/fabric-editor/components/previewImageList.vue';
|
|
// import bgBar from '@/components/bgBar.vue';
|
// import setSize from '@/fabric-editor/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 '@/fabric-editor/components/attributePostion.vue';
|
import attributeTemplateParam from '@/fabric-editor/components/attributeTemplateParam.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 '@/fabric-editor/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';
|
// import cropperImg from '@/components/cropperImg.vue';
|
// hooks
|
import useSelectListen from '@/fabric-editor/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> -->
|
<preview-image-list />
|
</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> -->
|
<el-divider content-position="left">
|
<h4>快捷操作</h4>
|
</el-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> -->
|
<!-- 裁剪 -->
|
<!-- <cropperImg></cropperImg> -->
|
<!-- 图片裁切 -->
|
<!-- <clip-image></clip-image> -->
|
<!-- 翻转 -->
|
<!-- <flip></flip> -->
|
<!-- 条形码属性 -->
|
<!-- <attributeBarcode></attributeBarcode> -->
|
<!-- 二维码 -->
|
<!-- <attributeQrCode></attributeQrCode> -->
|
<!-- 图片滤镜 -->
|
<!-- <filters></filters> -->
|
<!-- 图片描边 -->
|
<!-- <imgStroke /> -->
|
<!-- 颜色 -->
|
<!-- <attributeColor></attributeColor> -->
|
<attributeTemplateParam></attributeTemplateParam>
|
<!-- 字体属性 -->
|
<attributeFont></attributeFont>
|
<!-- 字体小数点 -->
|
<!-- <attributeTextFloat></attributeTextFloat> -->
|
<!-- 文字内容 -->
|
<!-- <attribute-text-content></attribute-text-content> -->
|
<!-- 位置信息 -->
|
<attributePostion></attributePostion>
|
<!-- 阴影 -->
|
<!-- <attributeShadow></attributeShadow> -->
|
<!-- 边框 -->
|
<!-- <attributeBorder></attributeBorder> -->
|
<!-- 圆角 -->
|
<!-- <attributeRounded></attributeRounded> -->
|
<!-- 关联数据 -->
|
<!-- <attributeId></attributeId> -->
|
|
<!-- 新增字体样式使用 -->
|
<!-- <el-button @click="canvasEditor.getFontJson()" size="small">获取元素数据</el-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="scss" scoped>
|
// 右侧容器
|
|
.right-bar {
|
overflow-y: auto;
|
padding: 10px;
|
width: 330px;
|
height: 100%;
|
background: #ffffff;
|
}
|
|
// 属性面板样式
|
|
:deep(.attr-item) {
|
position: relative;
|
display: flex;
|
align-items: center;
|
margin-bottom: 12px;
|
padding: 0 10px;
|
height: 40px;
|
border: none;
|
border-radius: 4px;
|
background: #f6f7f9;
|
|
.ivu-tooltip {
|
text-align: center;
|
flex: 1;
|
}
|
}
|
|
// 关闭按钮
|
|
.close-btn {
|
position: absolute;
|
top: 50%;
|
right: -20px;
|
z-index: 1;
|
margin-top: -10px;
|
width: 20px;
|
height: 64px;
|
background-position: 50%;
|
background-repeat: no-repeat;
|
background-size: cover;
|
cursor: pointer;
|
background-image: url('');
|
|
&.right-btn {
|
background-image: url('');
|
transform: rotateY(180deg);
|
right: 0px;
|
}
|
|
&.right-btn-open {
|
background-image: url('');
|
right: 330px;
|
}
|
}
|
</style>
|