<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> 
 |