mapSystem.vue 4.42 KB
<template>
  <div>
    <map-component></map-component>

    <!-- <el-dialog
      title="模板"
      :visible.sync="dialogVisible"
      width="30%"
      :before-close="handleClose"
    >
      <el-select
        v-model="seleceTemplate"
        @change="templateChange"
        placeholder="请选择模板"
      >
        <div v-for="item in templateList">
          <el-option :label="item.name" :value="item.template"></el-option>
        </div>
      </el-select>
      <span slot="footer" class="dialog-footer">
        <el-button @click="dialogVisible = false">取 消</el-button>
        <el-button type="primary" @click="templateqd">确 定</el-button>
      </span>
    </el-dialog>

    <el-dialog
      title="保存模板"
      :visible.sync="dialogVisible2"
      width="30%"
      :before-close="handleClose"
    >
      <div>
        <span>模板名称:</span><el-input v-model="templatesName"></el-input>
      </div>
      <span slot="footer" class="dialog-footer">
        <el-button @click="dialogVisible2 = false">取 消</el-button>
        <el-button type="primary" @click="uptemplate">确 定</el-button>
      </span>
    </el-dialog> -->

    <!-- <div style="margin-top: 10px; margin-left: 10px">
      <el-button type="primary" size="mini" @click="reset()">复位</el-button>
      <el-button type="primary" size="mini" @click="save()">导出</el-button>
      <el-button type="primary" size="mini" @click="clickSave()"
        >导入</el-button
      >
      <el-button type="primary" size="mini" @click="template()">模版</el-button>
      <el-button type="primary" size="mini" @click="bctemplate()"
        >保存模板</el-button
      >
      <div style="display: none">
        <input
          type="file"
          id="files"
          style="color: #fff"
          @change="savetemplate"
        />
      </div> -->
    <!-- <el-upload
            class="upload-demo"
            action=""
            :on-preview="handlePreview"
            :on-remove="handleRemove"
            :before-remove="beforeRemove"
            multiple
            :limit="3"
            :on-exceed="handleExceed"
            :file-list="fileList">
            <el-button size="small" type="primary">点击上传</el-button>
            <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div>
          </el-upload> -->
    <!-- </div> -->
  </div>
</template>
<script>
import {
  SaveUpdateCanvasTemplate,
  GetCanvasTemplates,
} from "@/api/taskManagement/stacker";
import mapComponent from "./components/mapComponent.vue";

export default {
  components: {
    mapComponent,
  },
  data() {
    return {
      imgs: "",

      templateList: [],
      dialogVisible2: false,
      dialogVisible: false,
      templatesName: "",
      seleceTemplate: "",
    };
  },

  mounted() {},
  methods: {
    handleClose() {
      dialogVisible2 = false;
      dialogVisible = false;
    },

    handleRemove(file, fileList) {
      console.log(file, fileList);
    },

    handlePreview(file) {
      console.log(file);
    },

    handleExceed(files, fileList) {
      this.$message.warning(
        `当前限制选择 3 个文件,本次选择了 ${files.length} 个文件,共选择了 ${
          files.length + fileList.length
        } 个文件`
      );
    },

    beforeRemove(file, fileList) {
      return this.$confirm(`确定移除 ${file.name}?`);
    },
    uptemplate() {
      let data = {
        name: this.templatesName,
        template: JSON.stringify(this.graph.toJSON()),
      };
      SaveUpdateCanvasTemplate(data).then((res) => {
        if (res.code == "Success") {
          dialogVisible2 = false;
        }
      });
    },
    templateqd() {
      this.graph.fromJSON(JSON.parse(this.seleceTemplate));
      this.dialogVisible = false;
    },
    template() {
      this.dialogVisible = true;
      GetCanvasTemplates({ id: "0" }).then((res) => {
        this.templateList = res.data;
        console.log(this.templateList);
      });
    },
    templateChange() {
      console.log(this.seleceTemplate);
    },
    bctemplate() {
      this.dialogVisible2 = true;
    },
  },
};
</script>
<style scoped>
::v-deep .el-collapse-item__content {
  display: flex !important;
  flex-wrap: wrap;
  margin: 0 20px;
  justify-content: space-between;
}

.no-select {
  -webkit-user-select: none; /* Safari */
  -moz-user-select: none; /* Firefox */
  -ms-user-select: none; /* IE10+/Edge */
  user-select: none; /* 标准语法 */
}
</style>