123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265 |
- <template>
- <div class="baseTopo" id="baseTopo" ref="baseTopo">
- <topoTooltip
- v-show="showTooltip"
- class="topoTooltip-box"
- ref="topoTooltip"
- @closeTooltip="showTooltip = false"
- :havItem="havItem"
- ></topoTooltip>
- <canvas
- id="persagy_topo"
- :width="canvasWidth"
- :height="canvasHeight"
- tabindex="0"
- ></canvas>
- </div>
- </template>
- <script>
- import { PTopoScene, PTopoParser } from "@/components/editClass/persagy-edit";
- import { SGraphView } from "@persagy-web/graph";
- import { SFloorParser } from "@persagy-web/big/lib";
- import topoTooltip from "./topoTooltip.vue";
- import { mapState, mapMutations } from "vuex";
- import bus from "@/bus/bus";
- import {
- saveGroup,
- readGroup,
- uploadGroup,
- getImageGroup,
- readPubGroup,
- } from "@/api/editer";
- export default {
- components: { topoTooltip },
- data() {
- return {
- scene: null,
- view: null,
- canvasWidth: 700,
- canvasHeight: 700,
- havItem: false,
- showTooltip: false,
- topoContent: {},
- };
- },
- computed: {
- ...mapState([
- "editCmd",
- "legendObj",
- "graphId",
- "id",
- "isPub",
- "categoryId",
- "projectId",
- ]),
- },
- mounted() {
- this.canvasWidth = this.$refs.baseTopo.offsetWidth;
- this.canvasHeight = this.$refs.baseTopo.offsetHeight - 10;
- this.scene = new PTopoScene();
- this.view = new SGraphView("persagy_topo");
- this.view.scene = this.scene;
- this.scene.clearCmdStatus = this.clearCmdStatus;
-
- this.initBusEvent();
-
- this.scene.getItem = this.onContextMenu;
- this.scene.emitChoice = this.emitChoice;
-
- this.scene.vueOnMouseDown = this.vueOnMouseDown;
-
- document.getElementById("baseTopo").oncontextmenu = function (e) {
- return false;
- };
-
- this.readtopoMsg();
- },
- methods: {
- ...mapMutations([
- "SETCHOICELEHEND",
- "SETLEGENDOBJ",
- "SETPROJECT",
- "SETCATEGROY",
- "SETISPUB",
- ]),
-
- clearCmdStatus() {
- this.SETCHOICELEHEND("");
- this.SETLEGENDOBJ(null);
- },
-
- onContextMenu(item, [event]) {
- this.showTooltip = true;
- if (item) {
- this.havItem = true;
- } else {
- this.havItem = false;
- }
- const doms = document.getElementsByClassName("topoTooltip-box")[0];
- doms.style.left = event.offsetX + "px";
- doms.style.top = event.offsetY + "px";
- },
-
- vueOnMouseDown(e) {
-
- this.showTooltip = false;
- },
-
- emitChoice(itemList) {
- bus.$emit("emitChoice", itemList);
- },
-
- initBusEvent() {
-
- bus.$on("updateStyle", (type, val) => {
- this.scene.updateStyle(type, val);
- });
-
- bus.$on("topoUndo", (val) => {
- this.scene.undo();
- });
-
- bus.$on("topoRedo", (val) => {
- this.scene.redo();
- });
-
- bus.$on("deleteItem", (val) => {
- this.scene.deleteItem();
- });
-
- bus.$on("copy", (val) => {
- this.scene.copy();
- });
-
- bus.$on("paste", (val) => {
- this.scene.paste();
- });
-
- bus.$on("saveTopo", (val) => {
- const elements = this.scene.save();
- const obj = {
- elements,
- name: this.topoContent.name,
- categoryId: this.categoryId,
- projectId: this.projectId,
- label: this.topoContent.label,
- buildingId: "1",
- floorId: "1",
- note: "1",
- log: {
-
- mark: "1",
- commandList: [
- {
- command: "1",
- desc: "1",
- detail: "1",
- },
- ],
- },
- };
- Object.assign(obj, {
- graphId: this.graphId,
- id: this.id,
- });
- console.log(obj);
- saveGroup(obj).then((res) => {
-
- this.SETISPUB(0);
- const gid = res.entityList[0].graphId;
- const id = res.entityList[0].id;
-
- this.SETPROJECT({ graphId: gid, id: id });
-
- this.$router.push({
- name: "Editer",
- query: {
- graphId: gid,
- id: id,
- categoryName: encodeURI(this.categoryName),
- isPub: 0,
- },
- });
- });
- });
-
- bus.$on("setOrder", (val) => {
- this.scene.setOrder(val);
- });
-
- bus.$on("setItemStatus", (val) => {
- this.scene.setItemStatus();
- });
- },
-
- readtopoMsg() {
- const obj = {
- graphId: this.graphId,
- id: this.id,
- };
- if (this.isPub == 1) {
-
- readPubGroup(obj).then((res) => {
- this.getDataSuc(res);
- });
- } else {
- readGroup(obj).then((res) => {
- this.getDataSuc(res);
- });
- }
- },
-
- getDataSuc(res) {
- this.SETCATEGROY(res.content.categoryId);
- this.topoContent = res.content;
- const parse = new PTopoParser();
- parse.parseData(res.content.elements);
- parse.markers.forEach((item) => {
- item.selectable = true;
- item.moveable = true;
- item.connect("finishCreated", this.scene, this.scene.finishCreated);
- item.connect("onContextMenu", this, this.scene.getItem);
- this.scene.addItem(item);
- });
- parse.nodes.forEach((item) => {
- item.connect("finishCreated", this.scene, this.scene.finishCreated);
- item.connect("onContextMenu", this, this.scene.getItem);
- this.scene.addItem(item);
- });
- this.view.fitSceneToView()
- },
- },
- watch: {
- editCmd(val) {
- console.log("val", val);
- if (this.scene) {
-
- this.scene.editCmd = val;
- }
- },
- legendObj: {
- handler: function (val, oldVal) {
- this.scene.legendObj = val;
- },
- deep: true,
- },
- },
- created() {
- this.SETPROJECT(this.$route.query);
- this.SETISPUB(this.$route.query.isPub);
- this.categoryName = decodeURI(this.$route.query.categoryName);
- },
- };
- </script>
- <style lang="less" scoped>
- .baseTopo {
- width: 100%;
- height: 100%;
- position: relative;
- .topoTooltip-box {
- position: absolute;
- left: 0;
- top: 0;
- }
- }
- </style>
|