Browse Source

Merge branch 'master' of http://39.106.8.246:3003/BDTP/adm-frontend

qule 3 years ago
parent
commit
13b2a18585

+ 2 - 1
public/systemConf.js

@@ -28,7 +28,8 @@ var __systemConf = {
         size: 16,
         color: '#646C73',
         weight: 600,
-        backGround: '#FFFFFF'
+        backGround: '#ffffff',
+        padding: 4
       },
       line:{
         width: 2,

+ 0 - 1
src/Main.vue

@@ -38,7 +38,6 @@ export default {
 }
 
 .leftRegion {
-  width: 235px;
   height: 100%;
 }
 .rightRegion {

+ 21 - 7
src/components/frame/leftMenu.vue

@@ -27,8 +27,21 @@
         :class="'leftMenuIconfont ' + menu.icon"
         v-if="!!menu.icon"
       ></i> -->
-      <img :src="menu.state == 'normal' ? menu.normalImg : menu.activeImg" />
+      <el-tooltip
+        v-if="!leftIsOpen"
+        effect="dark"
+        :content="menu.name"
+        placement="right"
+        popper-class="leftCloseTip"
+      >
+        <img :src="menu.state == 'normal' ? menu.normalImg : menu.activeImg" />
+      </el-tooltip>
+      <img
+        v-if="leftIsOpen"
+        :src="menu.state == 'normal' ? menu.normalImg : menu.activeImg"
+      />
       <span
+        v-if="leftIsOpen"
         slot="title"
         v-text="menu.name"
         style="margin-left: 6px"
@@ -42,29 +55,30 @@
 <script>
 export default {
   name: "leftMenu",
-  props: ["menu"],
+  props: ["menu", "leftIsOpen"],
   data() {
     return {
       routerPath: "",
     };
   },
   computed: {},
-  methods: {
-  },
-  created() {
-  },
+  methods: {},
+  created() {},
 
   mounted() {},
   components: {},
 };
 </script>
 
-<style scoped>
+<style>
 .menuIcon {
   margin-right: 6px;
   color: #fff;
   width: 20px;
   height: 20px;
 }
+.leftCloseTip {
+  left: 58px !important;
+}
 </style>
 

+ 75 - 26
src/components/frame/pageLeft.vue

@@ -1,32 +1,60 @@
 <template>
-  <div id="pageLeft">
-    <div class="topContainer">
-      <div class="logoDiv">
-        <img :src="logoUrl" class="logoImg" />
+  <div id="pageLeft" :class="{leftClose:!leftIsOpen}">
+    <div class="leftContainer" v-if="leftIsOpen">
+      <div class="topContainer">
+        <div class="logoDiv">
+          <img :src="logoUrl" class="logoImg" />
+        </div>
+        <div class="middDiv">
+          <i class="el-icon-fa-bars fa fa-bars" @click="toggleLeft"></i>
+        </div>
       </div>
-      <div class="middDiv">
-        <i class="el-icon-fa-bars fa fa-bars"></i>
+      <div class="menuDiv">
+        <el-menu
+          text-color="#fff"
+          active-text-color="#ffd04b"
+          background-color="#364150"
+          router
+        >
+          <el-menu-item-group v-for="menu in menus" :key="menu.id">
+            <template slot="title">
+              <span v-text="menu.name"></span>
+            </template>
+            <leftMenu
+              :menu="subMenu"
+              v-for="subMenu in menu.children"
+              :key="subMenu.id"
+              :index="subMenu.id"
+              :leftIsOpen="leftIsOpen"
+            ></leftMenu>
+          </el-menu-item-group>
+        </el-menu>
       </div>
     </div>
-    <div class="menuDiv">
-      <el-menu
-        text-color="#fff"
-        active-text-color="#ffd04b"
-        background-color="#364150"
-        router
-      >
-        <el-menu-item-group v-for="menu in menus" :key="menu.id">
-          <template slot="title">
-            <span v-text="menu.name"></span>
-          </template>
-          <leftMenu
-            :menu="subMenu"
-            v-for="subMenu in menu.children"
-            :key="subMenu.id"
-            :index="subMenu.id"
-          ></leftMenu>
-        </el-menu-item-group>
-      </el-menu>
+    <div class="leftContainer" v-if="!leftIsOpen">
+      <div class="topContainer">
+        <div class="middDiv middDivClose">
+          <i class="el-icon-fa-bars fa fa-bars el-icon-fa-barsClose" @click="toggleLeft"></i>
+        </div>
+      </div>
+      <div class="menuDiv">
+        <el-menu
+          text-color="#fff"
+          active-text-color="#ffd04b"
+          background-color="#364150"
+          router
+        >
+          <el-menu-item-group v-for="menu in menus" :key="menu.id">
+            <leftMenu
+              :menu="subMenu"
+              v-for="subMenu in menu.children"
+              :key="subMenu.id"
+              :index="subMenu.id"
+              :leftIsOpen="leftIsOpen"
+            ></leftMenu>
+          </el-menu-item-group>
+        </el-menu>
+      </div>
     </div>
   </div>
 </template>
@@ -37,13 +65,18 @@ export default {
   props: [],
   data() {
     return {
+      leftIsOpen: true,
       logoUrl: require("@/assets/images/logo.png"),
     };
   },
   computed: {
     ...mapState(["menus"]),
   },
-  methods: {},
+  methods: {
+    toggleLeft: function () {
+      this.leftIsOpen = !this.leftIsOpen;
+    },
+  },
   created() {},
 
   mounted() {},
@@ -57,8 +90,16 @@ export default {
 #pageLeft {
   width: 235px;
   height: 100%;
+}
+
+.leftClose{
+  width:64px !important;
+}
+
+.leftContainer {
   display: flex;
   flex-direction: column;
+  height: 100%;
 }
 
 .topContainer {
@@ -97,6 +138,10 @@ export default {
   cursor: pointer;
 }
 
+.el-icon-fa-barsClose{
+  margin-left: 0;
+}
+
 .logoDiv {
   flex: 1;
 }
@@ -105,6 +150,10 @@ export default {
   flex: 1;
 }
 
+.middDivClose{
+  text-align: center;
+}
+
 .el-menu-item-group__title span {
   font-size: 14px !important;
   color: #68707b;

+ 4 - 1
src/components/systemGraph/edit.vue

@@ -614,7 +614,7 @@ export default {
       //更新图形以及图形数据源
       this.$refs.graphc.updateDataAndGraph(3, 4, {
         id: this.selText.id,
-        fontColor: this.fontBackColor,
+        fontBackColor: this.fontBackColor,
       });
     },
     //文本X轴坐标变化后事件
@@ -1201,6 +1201,8 @@ export default {
 #divGraphEdit .graphInfoName {
   margin-left: 12px;
   margin-top: 21px;
+  font-size: 12px;
+  color:#6F777F;
 }
 
 #divGraphEdit .graphInfoFirstEdit {
@@ -1213,6 +1215,7 @@ export default {
 #divGraphEdit .graphInfoContent {
   margin-top: 12px;
   margin-left: 36px;
+  font-weight: normal;
 }
 
 #divGraphEdit .graphRegion {

+ 59 - 1
src/components/systemGraph/graph.vue

@@ -157,6 +157,7 @@ export default {
         });
 
         pixiContainer.appendChild(pixiApp.view);
+        pixiApp.stage.sortableChildren = true;
         _this.pixiApp = pixiApp;
       } else pixiApp = _this.pixiApp;
 
@@ -223,6 +224,7 @@ export default {
       });
 
       //文本
+      let textDefaultConfig = window.__systemConf.systemGraph.peiDian.text;
       _this.labelArr.forEach((_labelObj) => {
         var pixiTextStyle = new PIXI.TextStyle({
           fill: _labelObj.style.fontColor,
@@ -240,6 +242,8 @@ export default {
         });
 
         textInstance.position.set(newCordObj.x, newCordObj.y);
+        //zIndex没用?
+        // textInstance.zIndex = 2000000;
         // console.log(textInstance.width, "-", textInstance.height);
         //启用事件
         textInstance.interactive = true;
@@ -247,6 +251,39 @@ export default {
           _this.isClickGraphNode = true;
           _this.clickEventCall(event, 3);
         });
+
+        //----------------------------------------绘制文本的矩形背景框
+        var graphicsRect = new PIXI.Graphics();
+        graphicsRect.lineStyle({ width: 0 });
+        let newCordObjRect = _this.convertCoordToLeftOrigina({
+          x: _labelObj.absolutePosition.x - textDefaultConfig.padding,
+          y: _labelObj.absolutePosition.y - textDefaultConfig.padding,
+        });
+        var newWidth =
+          (textInstance.width + 2 * textDefaultConfig.padding) *
+          _this.canvasProObj.originalScale;
+        var newHeight =
+          (textInstance.height + 2 * textDefaultConfig.padding) *
+          _this.canvasProObj.originalScale;
+        graphicsRect.beginFill(
+          "0x" + _labelObj.style.backColor.substring(1)
+        );
+        graphicsRect.drawRect(
+          newCordObjRect.x,
+          newCordObjRect.y,
+          newWidth,
+          newHeight
+        );
+        graphicsRect.endFill();
+        graphicsRect.name = _this.constructorTextBackId(_labelObj.id);
+        graphicsRect._data = {
+          x: newCordObjRect.x,
+          y: newCordObjRect.y,
+          width: newWidth,
+          height: newHeight,
+        };
+        // textInstance.zIndex = 1;
+        pixiApp.stage.addChild(graphicsRect);
         pixiApp.stage.addChild(textInstance);
       });
 
@@ -668,11 +705,26 @@ export default {
               break;
             case 3:
               _dataObj.style.fontColor = exprObj.fontColor;
-              _dataObj.style.backColor = exprObj.fontBackColor;
               _stageStyle.fill = exprObj.fontColor;
               stageChild.style = _stageStyle;
               break;
             case 4:
+              let rectId = this.constructorTextBackId(exprObj.id);
+              let stageRectChild = this.pixiApp.stage.getChildByName(rectId);
+              // stageChild.fill.color = "0x000000";
+              let _cachData = stageRectChild._data;
+              stageRectChild.clear();
+              stageRectChild.beginFill(
+                "0x" + exprObj.fontBackColor.substring(1)
+              );
+              stageRectChild.drawRect(
+                _cachData.x,
+                _cachData.y,
+                _cachData.width,
+                _cachData.height
+              );
+              stageRectChild.endFill();
+
               _dataObj.style.backColor = exprObj.fontBackColor;
               break;
             case 6:
@@ -691,6 +743,12 @@ export default {
         }
       }
     },
+    /**
+     * 构造文本背景项的ID
+     */
+    constructorTextBackId: function (textId) {
+      return "textback_" + textId;
+    },
   },
   created() {},