mirror of
https://gitee.com/log4j/pig-ui.git
synced 2025-01-03 23:42:23 +08:00
'admin-21.06.03:删除G6思维导图界面'
This commit is contained in:
parent
1596de0cde
commit
2950720b21
@ -1,527 +0,0 @@
|
|||||||
<template>
|
|
||||||
<div :style="{ height: `calc(100vh - ${initTagViewHeight}` }">
|
|
||||||
<div class="layout-view-bg-white">
|
|
||||||
<div id="antvG6" style="height: 100%" ref="antvG6Ref"></div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script lang="ts">
|
|
||||||
import { toRefs, reactive, computed, onMounted, getCurrentInstance } from 'vue';
|
|
||||||
import G6 from '@antv/g6';
|
|
||||||
import { useStore } from '/@/store/index.ts';
|
|
||||||
export default {
|
|
||||||
name: 'funMindMap',
|
|
||||||
setup() {
|
|
||||||
const { proxy } = getCurrentInstance() as any;
|
|
||||||
const store = useStore();
|
|
||||||
const state = reactive({});
|
|
||||||
// 设置主内容的高度
|
|
||||||
const initTagViewHeight = computed(() => {
|
|
||||||
let { isTagsview } = store.state.themeConfig.themeConfig;
|
|
||||||
if (isTagsview) return `114px`;
|
|
||||||
else return `80px`;
|
|
||||||
});
|
|
||||||
// 初始化 antv/G6
|
|
||||||
const initAntvG6 = () => {
|
|
||||||
const { Util } = G6;
|
|
||||||
const colorArr = [
|
|
||||||
'#5B8FF9',
|
|
||||||
'#5AD8A6',
|
|
||||||
'#5D7092',
|
|
||||||
'#F6BD16',
|
|
||||||
'#6F5EF9',
|
|
||||||
'#6DC8EC',
|
|
||||||
'#D3EEF9',
|
|
||||||
'#DECFEA',
|
|
||||||
'#FFE0C7',
|
|
||||||
'#1E9493',
|
|
||||||
'#BBDEDE',
|
|
||||||
'#FF99C3',
|
|
||||||
'#FFE0ED',
|
|
||||||
'#CDDDFD',
|
|
||||||
'#CDF3E4',
|
|
||||||
'#CED4DE',
|
|
||||||
'#FCEBB9',
|
|
||||||
'#D3CEFD',
|
|
||||||
'#945FB9',
|
|
||||||
'#FF9845',
|
|
||||||
];
|
|
||||||
|
|
||||||
const rawData = {
|
|
||||||
label: 'vue-next-admin',
|
|
||||||
id: '0',
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
label: 'Classification',
|
|
||||||
id: '0-1',
|
|
||||||
color: '#5AD8A6',
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
label: 'Logistic regression',
|
|
||||||
id: '0-1-1',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Linear discriminant analysis',
|
|
||||||
id: '0-1-2',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Rules',
|
|
||||||
id: '0-1-3',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Decision trees',
|
|
||||||
id: '0-1-4',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Naive Bayes',
|
|
||||||
id: '0-1-5',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'K nearest neighbor',
|
|
||||||
id: '0-1-6',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Probabilistic neural network',
|
|
||||||
id: '0-1-7',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Support vector machine',
|
|
||||||
id: '0-1-8',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Consensus',
|
|
||||||
id: '0-2',
|
|
||||||
color: '#F6BD16',
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
label: 'Models diversity',
|
|
||||||
id: '0-2-1',
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
label: 'Different initializations',
|
|
||||||
id: '0-2-1-1',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Different parameter choices',
|
|
||||||
id: '0-2-1-2',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Different architectures',
|
|
||||||
id: '0-2-1-3',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Different modeling methods',
|
|
||||||
id: '0-2-1-4',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Different training sets',
|
|
||||||
id: '0-2-1-5',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Different feature sets',
|
|
||||||
id: '0-2-1-6',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Methods',
|
|
||||||
id: '0-2-2',
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
label: 'Classifier selection',
|
|
||||||
id: '0-2-2-1',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Classifier fusion',
|
|
||||||
id: '0-2-2-2',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Common',
|
|
||||||
id: '0-2-3',
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
label: 'Bagging',
|
|
||||||
id: '0-2-3-1',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Boosting',
|
|
||||||
id: '0-2-3-2',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'AdaBoost',
|
|
||||||
id: '0-2-3-3',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Regression',
|
|
||||||
id: '0-3',
|
|
||||||
color: '#269A99',
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
label: 'Multiple linear regression',
|
|
||||||
id: '0-3-1',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Partial least squares',
|
|
||||||
id: '0-3-2',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Multi-layer feedforward neural network',
|
|
||||||
id: '0-3-3',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'General regression neural network',
|
|
||||||
id: '0-3-4',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Support vector regression',
|
|
||||||
id: '0-3-5',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
};
|
|
||||||
|
|
||||||
G6.registerNode(
|
|
||||||
'dice-mind-map-root',
|
|
||||||
{
|
|
||||||
jsx: (cfg: any) => {
|
|
||||||
const width = Util.getTextSize(cfg.label, 16)[0] + 24;
|
|
||||||
const stroke = cfg.style.stroke || '#096dd9';
|
|
||||||
return `
|
|
||||||
<group>
|
|
||||||
<rect draggable="true" style={{width: ${width}, height: 42, stroke: ${stroke}, radius: 4}} keyshape>
|
|
||||||
<text style={{ fontSize: 16, marginLeft: 12, marginTop: 12 }}>${cfg.label}</text>
|
|
||||||
<text style={{ marginLeft: ${width - 16}, marginTop: -20, stroke: '#66ccff', fill: '#000', cursor: 'pointer', opacity: ${
|
|
||||||
cfg.hover ? 0.75 : 0
|
|
||||||
} }} action="add">+</text>
|
|
||||||
</rect>
|
|
||||||
</group>
|
|
||||||
`;
|
|
||||||
},
|
|
||||||
getAnchorPoints() {
|
|
||||||
return [
|
|
||||||
[0, 0.5],
|
|
||||||
[1, 0.5],
|
|
||||||
];
|
|
||||||
},
|
|
||||||
},
|
|
||||||
'single-node'
|
|
||||||
);
|
|
||||||
|
|
||||||
G6.registerNode(
|
|
||||||
'dice-mind-map-sub',
|
|
||||||
{
|
|
||||||
jsx: (cfg: any) => {
|
|
||||||
const width = Util.getTextSize(cfg.label, 14)[0] + 24;
|
|
||||||
const color = cfg.color || cfg.style.stroke;
|
|
||||||
|
|
||||||
return `
|
|
||||||
<group>
|
|
||||||
<rect draggable="true" style={{width: ${width + 24}, height: 22}} keyshape>
|
|
||||||
<text draggable="true" style={{ fontSize: 14, marginLeft: 12, marginTop: 6 }}>${cfg.label}</text>
|
|
||||||
<text style={{ marginLeft: ${width - 8}, marginTop: -10, stroke: ${color}, fill: '#000', cursor: 'pointer', opacity: ${
|
|
||||||
cfg.hover ? 0.75 : 0
|
|
||||||
}, next: 'inline' }} action="add">+</text>
|
|
||||||
<text style={{ marginLeft: ${width - 4}, marginTop: -10, stroke: ${color}, fill: '#000', cursor: 'pointer', opacity: ${
|
|
||||||
cfg.hover ? 0.75 : 0
|
|
||||||
}, next: 'inline' }} action="delete">-</text>
|
|
||||||
</rect>
|
|
||||||
<rect style={{ fill: ${color}, width: ${width + 24}, height: 2, x: 0, y: 22 }} />
|
|
||||||
|
|
||||||
</group>
|
|
||||||
`;
|
|
||||||
},
|
|
||||||
getAnchorPoints() {
|
|
||||||
return [
|
|
||||||
[0, 0.965],
|
|
||||||
[1, 0.965],
|
|
||||||
];
|
|
||||||
},
|
|
||||||
},
|
|
||||||
'single-node'
|
|
||||||
);
|
|
||||||
|
|
||||||
G6.registerNode(
|
|
||||||
'dice-mind-map-leaf',
|
|
||||||
{
|
|
||||||
jsx: (cfg: any) => {
|
|
||||||
const width = Util.getTextSize(cfg.label, 12)[0] + 24;
|
|
||||||
const color = cfg.color || cfg.style.stroke;
|
|
||||||
|
|
||||||
return `
|
|
||||||
<group>
|
|
||||||
<rect draggable="true" style={{width: ${width + 20}, height: 26, fill: 'transparent' }}>
|
|
||||||
<text style={{ fontSize: 12, marginLeft: 12, marginTop: 6 }}>${cfg.label}</text>
|
|
||||||
<text style={{ marginLeft: ${width - 8}, marginTop: -10, stroke: ${color}, fill: '#000', cursor: 'pointer', opacity: ${
|
|
||||||
cfg.hover ? 0.75 : 0
|
|
||||||
}, next: 'inline' }} action="add">+</text>
|
|
||||||
<text style={{ marginLeft: ${width - 4}, marginTop: -10, stroke: ${color}, fill: '#000', cursor: 'pointer', opacity: ${
|
|
||||||
cfg.hover ? 0.75 : 0
|
|
||||||
}, next: 'inline' }} action="delete">-</text>
|
|
||||||
</rect>
|
|
||||||
<rect style={{ fill: ${color}, width: ${width + 24}, height: 2, x: 0, y: 32 }} />
|
|
||||||
|
|
||||||
</group>
|
|
||||||
`;
|
|
||||||
},
|
|
||||||
getAnchorPoints() {
|
|
||||||
return [
|
|
||||||
[0, 0.965],
|
|
||||||
[1, 0.965],
|
|
||||||
];
|
|
||||||
},
|
|
||||||
},
|
|
||||||
'single-node'
|
|
||||||
);
|
|
||||||
|
|
||||||
G6.registerBehavior('dice-mindmap', {
|
|
||||||
getEvents() {
|
|
||||||
return {
|
|
||||||
'node:click': 'clickNode',
|
|
||||||
'node:dblclick': 'editNode',
|
|
||||||
'node:mouseenter': 'hoverNode',
|
|
||||||
'node:mouseleave': 'hoverNodeOut',
|
|
||||||
};
|
|
||||||
},
|
|
||||||
clickNode(evt: any) {
|
|
||||||
const model = evt.item.get('model');
|
|
||||||
const name = evt.target.get('action');
|
|
||||||
switch (name) {
|
|
||||||
case 'add':
|
|
||||||
const newId =
|
|
||||||
model.id +
|
|
||||||
'-' +
|
|
||||||
(((model.children &&
|
|
||||||
model.children.reduce((a: any, b: any) => {
|
|
||||||
const num = Number(b.id.split('-').pop());
|
|
||||||
return a < num ? num : a;
|
|
||||||
}, 0)) ||
|
|
||||||
0) +
|
|
||||||
1);
|
|
||||||
evt.currentTarget.updateItem(evt.item, {
|
|
||||||
children: (model.children || []).concat([
|
|
||||||
{
|
|
||||||
id: newId,
|
|
||||||
direction: newId.charCodeAt(newId.length - 1) % 2 === 0 ? 'right' : 'left',
|
|
||||||
label: 'New',
|
|
||||||
type: 'dice-mind-map-leaf',
|
|
||||||
color: model.color || colorArr[Math.floor(Math.random() * colorArr.length)],
|
|
||||||
},
|
|
||||||
]),
|
|
||||||
});
|
|
||||||
evt.currentTarget.refreshLayout(false);
|
|
||||||
break;
|
|
||||||
case 'delete':
|
|
||||||
const parent = evt.item.get('parent');
|
|
||||||
evt.currentTarget.updateItem(parent, {
|
|
||||||
children: (parent.get('model').children || []).filter((e: any) => e.id !== model.id),
|
|
||||||
});
|
|
||||||
evt.currentTarget.refreshLayout(false);
|
|
||||||
break;
|
|
||||||
case 'edit':
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
editNode(evt: any) {
|
|
||||||
const item = evt.item;
|
|
||||||
const model = item.get('model');
|
|
||||||
const { x, y } = item.calculateBBox();
|
|
||||||
const graph = evt.currentTarget;
|
|
||||||
const realPosition = evt.currentTarget.getClientByPoint(x, y);
|
|
||||||
const el = document.createElement('div');
|
|
||||||
const fontSizeMap: any = {
|
|
||||||
'dice-mind-map-root': 24,
|
|
||||||
'dice-mind-map-sub': 18,
|
|
||||||
'dice-mind-map-leaf': 16,
|
|
||||||
};
|
|
||||||
el.style.fontSize = fontSizeMap[model.type] + 'px';
|
|
||||||
el.style.position = 'fixed';
|
|
||||||
el.style.top = realPosition.y + 'px';
|
|
||||||
el.style.left = realPosition.x + 'px';
|
|
||||||
el.style.paddingLeft = '12px';
|
|
||||||
el.style.transformOrigin = 'top left';
|
|
||||||
el.style.transform = `scale(${evt.currentTarget.getZoom()})`;
|
|
||||||
const input = document.createElement('input');
|
|
||||||
input.style.border = 'none';
|
|
||||||
input.value = model.label;
|
|
||||||
input.style.width = Util.getTextSize(model.label, fontSizeMap[model.type])[0] + 'px';
|
|
||||||
input.className = 'dice-input';
|
|
||||||
el.className = 'dice-input';
|
|
||||||
el.appendChild(input);
|
|
||||||
document.body.appendChild(el);
|
|
||||||
const destroyEl = () => {
|
|
||||||
document.body.removeChild(el);
|
|
||||||
};
|
|
||||||
const clickEvt = (event: any) => {
|
|
||||||
if (!event.target['className'].includes('dice-input')) {
|
|
||||||
window.removeEventListener('mousedown', clickEvt);
|
|
||||||
window.removeEventListener('scroll', clickEvt);
|
|
||||||
graph.updateItem(item, {
|
|
||||||
label: input.value,
|
|
||||||
});
|
|
||||||
graph.refreshLayout(false);
|
|
||||||
graph.off('wheelZoom', clickEvt);
|
|
||||||
destroyEl();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
graph.on('wheelZoom', clickEvt);
|
|
||||||
window.addEventListener('mousedown', clickEvt);
|
|
||||||
window.addEventListener('scroll', clickEvt);
|
|
||||||
input.addEventListener('keyup', (event) => {
|
|
||||||
if (event.key === 'Enter') {
|
|
||||||
clickEvt({
|
|
||||||
target: {},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
hoverNode(evt: any) {
|
|
||||||
evt.currentTarget.updateItem(evt.item, {
|
|
||||||
hover: true,
|
|
||||||
});
|
|
||||||
},
|
|
||||||
hoverNodeOut(evt: any) {
|
|
||||||
evt.currentTarget.updateItem(evt.item, {
|
|
||||||
hover: false,
|
|
||||||
});
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
G6.registerBehavior('scroll-canvas', {
|
|
||||||
getEvents: function getEvents() {
|
|
||||||
return {
|
|
||||||
wheel: 'onWheel',
|
|
||||||
};
|
|
||||||
},
|
|
||||||
|
|
||||||
onWheel: function onWheel(ev: any) {
|
|
||||||
const { graph } = this as any;
|
|
||||||
if (!graph) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (ev.ctrlKey) {
|
|
||||||
const canvas = graph.get('canvas');
|
|
||||||
const point = canvas.getPointByClient(ev.clientX, ev.clientY);
|
|
||||||
let ratio = graph.getZoom();
|
|
||||||
if (ev.wheelDelta > 0) {
|
|
||||||
ratio += ratio * 0.05;
|
|
||||||
} else {
|
|
||||||
ratio *= ratio * 0.05;
|
|
||||||
}
|
|
||||||
graph.zoomTo(ratio, {
|
|
||||||
x: point.x,
|
|
||||||
y: point.y,
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
const x = ev.deltaX || ev.movementX;
|
|
||||||
const y = ev.deltaY || ev.movementY || (-ev.wheelDelta * 125) / 3;
|
|
||||||
graph.translate(-x, -y);
|
|
||||||
}
|
|
||||||
ev.preventDefault();
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const dataTransform = (data: any) => {
|
|
||||||
let level: any = 0;
|
|
||||||
const changeData = (d: any, level?: any, color?: any) => {
|
|
||||||
const data = {
|
|
||||||
...d,
|
|
||||||
};
|
|
||||||
switch (level) {
|
|
||||||
case 0:
|
|
||||||
data.type = 'dice-mind-map-root';
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
data.type = 'dice-mind-map-sub';
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
data.type = 'dice-mind-map-leaf';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
data.hover = false;
|
|
||||||
|
|
||||||
if (color) {
|
|
||||||
data.color = color;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (level === 1 && !d.direction) {
|
|
||||||
if (!d.direction) {
|
|
||||||
data.direction = d.id.charCodeAt(d.id.length - 1) % 2 === 0 ? 'right' : 'left';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (d.children) {
|
|
||||||
data.children = d.children.map((child: any) => changeData(child, level + 1, data.color));
|
|
||||||
}
|
|
||||||
return data;
|
|
||||||
};
|
|
||||||
return changeData(data, level, data.color);
|
|
||||||
};
|
|
||||||
|
|
||||||
const container = proxy.$refs.antvG6Ref;
|
|
||||||
const width = container.scrollWidth;
|
|
||||||
const height = container.scrollHeight;
|
|
||||||
const tree = new G6.TreeGraph({
|
|
||||||
container: 'antvG6',
|
|
||||||
width,
|
|
||||||
height,
|
|
||||||
fitView: true,
|
|
||||||
fitViewPadding: [10, 20],
|
|
||||||
layout: {
|
|
||||||
type: 'mindmap',
|
|
||||||
direction: 'H',
|
|
||||||
getHeight: () => {
|
|
||||||
return 16;
|
|
||||||
},
|
|
||||||
getWidth: (node: any) => {
|
|
||||||
return node.level === 0 ? Util.getTextSize(node.label, 16)[0] + 12 : Util.getTextSize(node.label, 12)[0];
|
|
||||||
},
|
|
||||||
getVGap: () => {
|
|
||||||
return 10;
|
|
||||||
},
|
|
||||||
getHGap: () => {
|
|
||||||
return 60;
|
|
||||||
},
|
|
||||||
getSide: (node: any) => {
|
|
||||||
return node.data.direction;
|
|
||||||
},
|
|
||||||
},
|
|
||||||
defaultEdge: {
|
|
||||||
type: 'cubic-horizontal',
|
|
||||||
style: {
|
|
||||||
lineWidth: 2,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
minZoom: 0.5,
|
|
||||||
modes: {
|
|
||||||
default: ['drag-canvas', 'zoom-canvas', 'dice-mindmap'],
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
tree.data(dataTransform(rawData));
|
|
||||||
|
|
||||||
tree.render();
|
|
||||||
};
|
|
||||||
// 页面加载时
|
|
||||||
onMounted(() => {
|
|
||||||
initAntvG6();
|
|
||||||
});
|
|
||||||
return {
|
|
||||||
initTagViewHeight,
|
|
||||||
...toRefs(state),
|
|
||||||
};
|
|
||||||
},
|
|
||||||
};
|
|
||||||
</script>
|
|
Loading…
Reference in New Issue
Block a user