123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325 |
- <template>
- <div class="minder-editor-container">
- <div class="quickbar">
- <Tooltip placement="top" theme="light">
- <i class="ft icon" :title="$L('缩放')"></i>
- <div slot="content">
- <ul class="quickul">
- <li @click="execCommand('Zoom', 200)">200%</li>
- <li @click="execCommand('Zoom', 150)">150%</li>
- <li @click="execCommand('Zoom', 100)">100%</li>
- <li @click="execCommand('Zoom', 50)">50%</li>
- <li @click="execCommand('Zoom', 25)">25%</li>
- </ul>
- </div>
- </Tooltip>
- <Tooltip v-if="readOnly!==true" placement="top" theme="light">
- <i class="ft icon" :title="$L('图形')"></i>
- <div slot="content">
- <ul class="quickul mold">
- <li @click="execCommand('template', 'default')"><span class="default"></span></li>
- <li @click="execCommand('template', 'structure')"><span class="structure"></span></li>
- <li @click="execCommand('template', 'filetree')"><span class="filetree"></span></li>
- <li @click="execCommand('template', 'right')"><span class="right"></span></li>
- <li @click="execCommand('template', 'fish-bone')"><span class="fish-bone"></span></li>
- <li @click="execCommand('template', 'tianpan')"><span class="tianpan"></span></li>
- </ul>
- </div>
- </Tooltip>
- <Tooltip v-if="readOnly!==true" placement="top" theme="light">
- <i class="ft icon" :title="$L('样式')"></i>
- <div slot="content">
- <ul class="quickul">
- <li @click="execCommand('theme', 'fresh-blue')">{{$L('天空蓝')}}</li>
- <li @click="execCommand('theme', 'wire')">{{$L('线框')}}</li>
- <li @click="execCommand('theme', 'fish')">{{$L('鱼骨图')}}</li>
- <li @click="execCommand('theme', 'classic')">{{$L('脑图经典')}}</li>
- <li @click="execCommand('theme', 'classic-compact')">{{$L('紧凑经典')}}</li>
- <li @click="execCommand('theme', 'snow')">{{$L('温柔冷光')}}</li>
- <li @click="execCommand('theme', 'snow-compact')">{{$L('紧凑冷光')}}</li>
- <li @click="execCommand('theme', 'tianpan')">{{$L('经典天盘')}}</li>
- <li @click="execCommand('theme', 'tianpan-compact')">{{$L('紧凑天盘')}}</li>
- </ul>
- </div>
- </Tooltip>
- <Tooltip placement="top" theme="light">
- <i class="ft icon" :title="$L('折叠')"></i>
- <div slot="content">
- <ul class="quickul">
- <li @click="execCommand('ExpandToLevel', 1)">{{$L('展开到一级节点')}}</li>
- <li @click="execCommand('ExpandToLevel', 2)">{{$L('展开到二级节点')}}</li>
- <li @click="execCommand('ExpandToLevel', 3)">{{$L('展开到三级节点')}}</li>
- <li @click="execCommand('ExpandToLevel', 4)">{{$L('展开到四级节点')}}</li>
- <li @click="execCommand('ExpandToLevel', 5)">{{$L('展开到五级节点')}}</li>
- <li @click="execCommand('ExpandToLevel', 99)">{{$L('展开全部节点')}}</li>
- </ul>
- </div>
- </Tooltip>
- <Tooltip placement="top" :content="$L('居中')">
- <div @click="minder.execCommand('camera', minder.getRoot(), 600)"><i class="ft icon"></i></div>
- </Tooltip>
- <Tooltip placement="top" :content="$L('移动')">
- <div @click="[minder.execCommand('Hand'),isHand=!isHand]"><i class="ft icon" :class="{active:isHand}"></i></div>
- </Tooltip>
- </div>
- <div :id="id"></div>
- </div>
- </template>
- <style lang="less" scoped>
- .basebtn {
- color: #fff;
- background-color: #409eff;
- display: inline-block;
- line-height: 1;
- white-space: nowrap;
- cursor: pointer;
- border: 1px solid #dcdfe6;
- -webkit-appearance: none;
- text-align: center;
- box-sizing: border-box;
- outline: none;
- margin: 0;
- transition: 0.1s;
- font-weight: 500;
- -moz-user-select: none;
- -webkit-user-select: none;
- -ms-user-select: none;
- padding: 8px 12px;
- font-size: 14px;
- border-radius: 4px;
- }
- .baseSelect {
- height: 32px;
- option {
- min-height: 1.5em;
- }
- }
- .quickbar {
- position: fixed;
- left: 20px;
- bottom: 20px;
- height: 34px;
- border-radius: 3px;
- box-shadow: 3px 3px 10px rgba(0,0,0,.2);
- background-color: #fff;
- color: #666;
- z-index: 10;
- display: flex;
- padding: 0 6px;
- align-items: center;
- i {
- font-size: 22px;
- width: 34px;
- height: 34px;
- line-height: 34px;
- display: block;
- text-align: center;
- transform: scale(1);
- cursor: pointer;
- padding: 0;
- color: #666666;
- &:hover {
- color: #232323;
- }
- &.active {
- color: #0285d7;
- }
- }
- .quickul {
- li {
- cursor: pointer;
- padding: 8px 0;
- &:hover {
- color: #0285d7
- }
- }
- &.mold {
- span {
- display: block;
- width: 30px;
- background: url() no-repeat;background-size: 300px 24px;
- height: 30px;
- &.default {
- background-position: 0 3px
- }
- &.structure {
- background-position: -30px 3px
- }
- &.filetree {
- background-position: -60px 3px
- }
- &.right {
- background-position: -90px 3px
- }
- &.fish-bone {
- background-position: -120px 3px
- }
- &.tianpan {
- background-position: -150px 3px
- }
- }
- }
- }
- }
- </style>
- <script>
- import {generateMixed} from 'vue-kityminder-gg/src/utils/index.js';
- import 'vue-kityminder-gg/examples/styles/minder.css';
- import JSPDF from 'jspdf';
- export default {
- name: 'mind-editor',
- props: {
- value: {
- type: Object,
- default: function () {
- return {}
- }
- },
- AccessKey: {
- type: String,
- default: ''
- },
- SecretKey: {
- type: String,
- default: ''
- },
- Domain: {
- type: String,
- default: ''
- },
- scope: {
- type: String,
- default: ''
- },
- isImageUpload: {
- type: Boolean,
- default: true
- },
- saveShow: {
- type: Boolean,
- default: true
- },
- readOnly: {
- type: Boolean,
- default: false
- },
- id: {
- type: String,
- default: 'minder-component-' + generateMixed(12)
- },
- },
- data() {
- return {
- minder: null,
- isHand: false,
- bakValue: '',
- };
- },
- methods: {
- execCommand(var1, var2) {
- if (this.readOnly === true) {
- this.minder.enable();
- this.$nextTick(() => {
- this.minder.execCommand(var1, var2);
- this.$nextTick(() => {
- this.minder.disable();
- if (this.isHand) {
- this.minder.execCommand('Hand');
- }
- });
- });
- } else {
- this.minder.execCommand(var1, var2);
- }
- },
- exportHandle(n, filename) {
- filename = filename || (this.value.root.data.text || this.$L('无标题'));
- if (n === 0 || n === 'png') {
- this.minder.exportData('png').then((content) => {
- let element = document.createElement('a');
- element.setAttribute('href', content);
- element.setAttribute('download', filename);
- element.style.display = 'none';
- document.body.appendChild(element);
- element.click();
- document.body.removeChild(element);
- });
- } else if (n === 1 || n === 'pdf') {
- this.minder.exportData('png').then((content) => {
- let doc = new JSPDF();
- doc.addImage(content, 'PNG', 0, 0, 0, 0);
- doc.save(`${filename}.pdf`);
- });
- }
- },
- rendData() {
- this.$nextTick(() => {
- setTimeout(() => {
- if (this.minder !== null) {
- if (this.bakValue == JSON.stringify(this.value)) {
- return;
- }
- this.bakValue = JSON.stringify(this.value);
- this.minder.importJson(this.value);
- return;
- }
- window.__minderReadOnly = this.readOnly;
- const Editor = require('./editor');
- this.minder = window.editor = new Editor(document.getElementById(this.id)).minder;
- this.bakValue = JSON.stringify(this.value);
- this.minder.importJson(this.value);
- if (this.readOnly === true) {
- this.minder.disable();
- this.minder.execCommand('Hand');
- this.isHand = true;
- }
- this.$emit('minderHandle', this.minder);
- this.minder.on('contentchange', e => {
- const newJson = this.minder.exportJson();
- if (this.bakValue == JSON.stringify(newJson)) {
- return;
- }
- this.bakValue = JSON.stringify(newJson);
- this.$emit('input', newJson);
- });
- }, 300)
- });
- }
- },
- watch: {
- value: {
- handler: function (newObj) {
- if (typeof newObj !== "object" || newObj === null) {
- newObj = {
- root: newObj,
- theme: "fresh-blue",
- template: "default",
- };
- }
- if (typeof newObj.root !== "object" || newObj.root === null || newObj.root.length == 0) {
- newObj.root = {
- data: {
- id: generateMixed(12),
- text: this.$L('默认节点'),
- },
- children: []
- }
- }
- if (typeof newObj.theme !== "string") {
- newObj.theme = "fresh-blue";
- }
- if (typeof newObj.template !== "string") {
- newObj.template = "default";
- }
- this.rendData();
- },
- deep: true,
- immediate: true
- }
- }
- };
- </script>
|