diff --git a/README.md b/README.md index a95388aa..802cb546 100644 --- a/README.md +++ b/README.md @@ -140,4 +140,16 @@ const mindMap = new MindMap({ Chris + + + 水车 + + + + 仓鼠 + + + + 千帆 +

\ No newline at end of file diff --git a/index.html b/index.html index 1b985c2b..de5534fb 100644 --- a/index.html +++ b/index.html @@ -1 +1 @@ -思绪思维导图
\ No newline at end of file +思绪思维导图
\ No newline at end of file diff --git a/qrcode.jpg b/qrcode.jpg index 447274c9..6f53473e 100644 Binary files a/qrcode.jpg and b/qrcode.jpg differ diff --git a/simple-mind-map/full.js b/simple-mind-map/full.js index c119beb8..2c78b8be 100644 --- a/simple-mind-map/full.js +++ b/simple-mind-map/full.js @@ -10,6 +10,7 @@ import AssociativeLine from './src/plugins/AssociativeLine' import RichText from './src/plugins/RichText' import NodeImgAdjust from './src/plugins/NodeImgAdjust.js' import TouchEvent from './src/plugins/TouchEvent.js' +import Search from './src/plugins/Search.js' import xmind from './src/parse/xmind.js' import markdown from './src/parse/markdown.js' import icons from './src/svg/icons.js' @@ -36,5 +37,6 @@ MindMap .usePlugin(RichText) .usePlugin(TouchEvent) .usePlugin(NodeImgAdjust) + .usePlugin(Search) export default MindMap \ No newline at end of file diff --git a/simple-mind-map/index.js b/simple-mind-map/index.js index 731edd37..9f373ebe 100644 --- a/simple-mind-map/index.js +++ b/simple-mind-map/index.js @@ -7,9 +7,9 @@ import Style from './src/core/render/node/Style' import KeyCommand from './src/core/command/KeyCommand' import Command from './src/core/command/Command' import BatchExecution from './src/utils/BatchExecution' -import { layoutValueList, CONSTANTS } from './src/constants/constant' +import { layoutValueList, CONSTANTS, commonCaches } from './src/constants/constant' import { SVG } from '@svgdotjs/svg.js' -import { simpleDeepClone } from './src/utils' +import { simpleDeepClone, getType } from './src/utils' import defaultTheme, { checkIsNodeSizeIndependenceConfig } from './src/themes/default' import { defaultOpt } from './src/constants/defaultOptions' @@ -35,6 +35,9 @@ class MindMap { // 初始化主题 this.initTheme() + // 初始化缓存数据 + this.initCache() + // 事件类 this.event = new Event({ mindMap: this @@ -78,6 +81,8 @@ class MindMap { // 配置参数处理 handleOpt(opt) { + // 深拷贝一份节点数据 + opt.data = simpleDeepClone(opt.data || {}) // 检查布局配置 if (!layoutValueList.includes(opt.layout)) { opt.layout = CONSTANTS.LAYOUT.LOGICAL_STRUCTURE @@ -129,6 +134,23 @@ class MindMap { this.event.off(event, fn) } + // 初始化缓存数据 + initCache() { + Object.keys(commonCaches).forEach((key) => { + let type = getType(commonCaches[key]) + let value = '' + switch(type) { + case 'Boolean': + value = false + break + default: + value = null + break + } + commonCaches[key] = value + }) + } + // 设置主题 initTheme() { // 合并主题配置 diff --git a/simple-mind-map/package.json b/simple-mind-map/package.json index 18640db9..ccc51ff0 100644 --- a/simple-mind-map/package.json +++ b/simple-mind-map/package.json @@ -1,6 +1,6 @@ { "name": "simple-mind-map", - "version": "0.6.7", + "version": "0.6.11", "description": "一个简单的web在线思维导图", "authors": [ { diff --git a/simple-mind-map/src/constants/constant.js b/simple-mind-map/src/constants/constant.js index 64826939..9490ff9b 100644 --- a/simple-mind-map/src/constants/constant.js +++ b/simple-mind-map/src/constants/constant.js @@ -27,130 +27,162 @@ export const themeList = [ { name: '默认', value: 'default', + dark: false }, { name: '暗色2', value: 'dark2', + dark: true }, { name: '天清绿', value: 'skyGreen', + dark: false }, { name: '脑图经典2', value: 'classic2', + dark: false }, { name: '脑图经典3', value: 'classic3', + dark: false }, { name: '经典绿', value: 'classicGreen', + dark: false }, { name: '经典蓝', value: 'classicBlue', + dark: false }, { name: '天空蓝', value: 'blueSky', + dark: false }, { name: '脑残粉', value: 'brainImpairedPink', + dark: false }, { name: '暗色', value: 'dark', + dark: true }, { name: '泥土黄', value: 'earthYellow', + dark: false }, { name: '清新绿', value: 'freshGreen', + dark: false }, { name: '清新红', value: 'freshRed', + dark: false }, { name: '浪漫紫', value: 'romanticPurple', + dark: false }, { name: '粉红葡萄', value: 'pinkGrape', + dark: false }, { name: '薄荷', value: 'mint', + dark: false }, { name: '金色vip', value: 'gold', + dark: false }, { name: '活力橙', value: 'vitalityOrange', + dark: false }, { name: '绿叶', value: 'greenLeaf', + dark: false }, { name: '脑图经典', value: 'classic', + dark: true }, { name: '脑图经典4', value: 'classic4', + dark: false }, { name: '小黄人', value: 'minions', + dark: false }, { name: '简约黑', value: 'simpleBlack', + dark: false }, { name: '课程绿', value: 'courseGreen', + dark: false }, { name: '咖啡', value: 'coffee', + dark: false }, { name: '红色精神', value: 'redSpirit', + dark: false }, { name: '黑色幽默', value: 'blackHumour', + dark: true }, { name: '深夜办公室', value: 'lateNightOffice', + dark: true }, { name: '黑金', value: 'blackGold', + dark: true }, { name: '牛油果', value: 'avocado', + dark: false }, { name: '秋天', value: 'autumn', + dark: false }, { name: '橙汁', value: 'orangeJuice', + dark: true } ] @@ -213,6 +245,10 @@ export const CONSTANTS = { TOP: 'top', RIGHT: 'right', BOTTOM: 'bottom' + }, + PASTE_TYPE: { + CLIP_BOARD: 'clipBoard', + CANVAS: 'canvas' } } @@ -288,4 +324,9 @@ export const nodeDataNoStylePropList = [ 'resetRichText', 'uid', 'activeStyle' -] \ No newline at end of file +] + +// 数据缓存 +export const commonCaches = { + measureCustomNodeContentSizeEl: null +} \ No newline at end of file diff --git a/simple-mind-map/src/core/command/KeyCommand.js b/simple-mind-map/src/core/command/KeyCommand.js index cc7a772b..e894516c 100644 --- a/simple-mind-map/src/core/command/KeyCommand.js +++ b/simple-mind-map/src/core/command/KeyCommand.js @@ -57,8 +57,11 @@ export default class KeyCommand { } Object.keys(this.shortcutMap).forEach(key => { if (this.checkKey(e, key)) { - e.stopPropagation() - e.preventDefault() + // 粘贴事件不组织,因为要监听paste事件 + if (!this.checkKey(e, 'Control+v')) { + e.stopPropagation() + e.preventDefault() + } this.shortcutMap[key].forEach(fn => { fn() }) diff --git a/simple-mind-map/src/core/render/Render.js b/simple-mind-map/src/core/render/Render.js index 0a23119e..bc2c4439 100644 --- a/simple-mind-map/src/core/render/Render.js +++ b/simple-mind-map/src/core/render/Render.js @@ -7,7 +7,13 @@ import Timeline from '../../layouts/Timeline' import VerticalTimeline from '../../layouts/VerticalTimeline' import Fishbone from '../../layouts/Fishbone' import TextEdit from './TextEdit' -import { copyNodeTree, simpleDeepClone, walk, bfsWalk } from '../../utils' +import { + copyNodeTree, + simpleDeepClone, + walk, + bfsWalk, + loadImage +} from '../../utils' import { shapeList } from './node/Shape' import { lineStyleProps } from '../../themes/default' import { CONSTANTS } from '../../constants/constant' @@ -29,7 +35,7 @@ const layouts = { // 竖向时间轴 [CONSTANTS.LAYOUT.VERTICAL_TIMELINE]: VerticalTimeline, // 鱼骨图 - [CONSTANTS.LAYOUT.FISHBONE]: Fishbone, + [CONSTANTS.LAYOUT.FISHBONE]: Fishbone } // 渲染 @@ -42,7 +48,7 @@ class Render { this.themeConfig = this.mindMap.themeConfig this.draw = this.mindMap.draw // 渲染树,操作过程中修改的都是这里的数据 - this.renderTree = merge({}, this.mindMap.opt.data || {}) + this.renderTree = merge({},this.mindMap.opt.data || {}) // 是否重新渲染 this.reRender = false // 是否正在渲染中 @@ -60,6 +66,12 @@ class Render { this.root = null // 文本编辑框,需要再bindEvent之前实例化,否则单击事件只能触发隐藏文本编辑框,而无法保存文本修改 this.textEdit = new TextEdit(this) + // 当前复制的数据 + this.lastBeingCopyData = null + this.beingCopyData = null + this.beingPasteText = '' + this.beingPasteImgSize = 0 + this.currentBeingPasteType = '' // 布局 this.setLayout() // 绑定事件 @@ -82,18 +94,24 @@ class Render { // 绑定事件 bindEvent() { // 点击事件 - this.mindMap.on('draw_click', (e) => { + this.mindMap.on('draw_click', e => { // 清除激活状态 let isTrueClick = true let { useLeftKeySelectionRightKeyDrag } = this.mindMap.opt if (useLeftKeySelectionRightKeyDrag) { let mousedownPos = this.mindMap.event.mousedownPos - isTrueClick = Math.abs(e.clientX - mousedownPos.x) <= 5 && Math.abs(e.clientY - mousedownPos.y) <= 5 + isTrueClick = + Math.abs(e.clientX - mousedownPos.x) <= 5 && + Math.abs(e.clientY - mousedownPos.y) <= 5 } if (isTrueClick && this.activeNodeList.length > 0) { this.mindMap.execCommand('CLEAR_ACTIVE_NODE') } }) + // 粘贴事件 + this.mindMap.on('paste', data => { + this.onPaste(data) + }) } // 注册命令 @@ -215,7 +233,7 @@ class Render { } this.mindMap.keyCommand.addShortcut('Enter', this.insertNodeWrap) // 插入概要 - this.mindMap.keyCommand.addShortcut('Control+s', this.addGeneralization) + this.mindMap.keyCommand.addShortcut('Control+g', this.addGeneralization) // 展开/收起节点 this.toggleActiveExpand = this.toggleActiveExpand.bind(this) this.mindMap.keyCommand.addShortcut('/', this.toggleActiveExpand) @@ -242,6 +260,14 @@ class Render { // 下移节点 this.mindMap.keyCommand.addShortcut('Control+Down', this.downNode) // 复制节点、剪切节点、粘贴节点的快捷键需开发者自行注册实现,可参考demo + this.copy = this.copy.bind(this) + this.mindMap.keyCommand.addShortcut('Control+c', this.copy) + this.mindMap.keyCommand.addShortcut('Control+v', () => { + // 隐藏输入框可能会失去焦点,所以要重新聚焦 + this.textEdit.focusHiddenInput() + }) + this.cut = this.cut.bind(this) + this.mindMap.keyCommand.addShortcut('Control+x', this.cut) } // 开启文字编辑,会禁用回车键和删除键相关快捷键防止冲突 @@ -281,7 +307,7 @@ class Render { // 计算布局 this.layout.doLayout(root => { // 删除本次渲染时不再需要的节点 - Object.keys(this.lastNodeCache).forEach((uid) => { + Object.keys(this.lastNodeCache).forEach(uid => { if (!this.nodeCache[uid]) { this.lastNodeCache[uid].destroy() if (this.lastNodeCache[uid].parent) { @@ -301,7 +327,10 @@ class Render { this.render(callback, source) } else { // 触发一次保存,因为修改了渲染树的数据 - if (this.mindMap.richText && [CONSTANTS.CHANGE_THEME, CONSTANTS.SET_DATA].includes(source)) { + if ( + this.mindMap.richText && + [CONSTANTS.CHANGE_THEME, CONSTANTS.SET_DATA].includes(source) + ) { this.mindMap.command.addHistory() } } @@ -406,7 +435,7 @@ class Render { // 规范指定节点数据 formatAppointNodes(appointNodes) { if (!appointNodes) return [] - return Array.isArray(appointNodes) ? appointNodes: [appointNodes] + return Array.isArray(appointNodes) ? appointNodes : [appointNodes] } // 插入同级节点,多个节点只会操作第一个节点 @@ -415,7 +444,11 @@ class Render { if (this.activeNodeList.length <= 0 && appointNodes.length <= 0) { return } - let { defaultInsertSecondLevelNodeText, defaultInsertBelowSecondLevelNodeText } = this.mindMap.opt + this.textEdit.hideEditTextBox() + let { + defaultInsertSecondLevelNodeText, + defaultInsertBelowSecondLevelNodeText + } = this.mindMap.opt let list = appointNodes.length > 0 ? appointNodes : this.activeNodeList let first = list[0] if (first.isGeneralization) { @@ -424,7 +457,10 @@ class Render { if (first.isRoot) { this.insertChildNode(openEdit, appointNodes, appointData) } else { - let text = first.layerIndex === 1 ? defaultInsertSecondLevelNodeText : defaultInsertBelowSecondLevelNodeText + let text = + first.layerIndex === 1 + ? defaultInsertSecondLevelNodeText + : defaultInsertBelowSecondLevelNodeText if (first.layerIndex === 1) { first.parent.destroy() } @@ -451,7 +487,11 @@ class Render { if (this.activeNodeList.length <= 0 && appointNodes.length <= 0) { return } - let { defaultInsertSecondLevelNodeText, defaultInsertBelowSecondLevelNodeText } = this.mindMap.opt + this.textEdit.hideEditTextBox() + let { + defaultInsertSecondLevelNodeText, + defaultInsertBelowSecondLevelNodeText + } = this.mindMap.opt let list = appointNodes.length > 0 ? appointNodes : this.activeNodeList list.forEach(node => { if (node.isGeneralization) { @@ -460,7 +500,9 @@ class Render { if (!node.nodeData.children) { node.nodeData.children = [] } - let text = node.isRoot ? defaultInsertSecondLevelNodeText : defaultInsertBelowSecondLevelNodeText + let text = node.isRoot + ? defaultInsertSecondLevelNodeText + : defaultInsertBelowSecondLevelNodeText let isRichText = !!this.mindMap.richText node.nodeData.children.push({ inserting: openEdit, @@ -536,13 +578,81 @@ class Render { this.mindMap.render() } + // 复制节点 + copy() { + this.beingCopyData = this.copyNode() + } + + // 剪切节点 + cut() { + this.mindMap.execCommand('CUT_NODE', copyData => { + this.beingCopyData = copyData + }) + } + + // 粘贴节点 + paste() { + if (this.beingCopyData) { + this.mindMap.execCommand('PASTE_NODE', this.beingCopyData) + } + } + + // 粘贴事件 + async onPaste({ text, img }) { + // 检查剪切板数据是否有变化 + // 通过图片大小来判断图片是否发生变化,可能是不准确的,但是目前没有其他好方法 + const imgSize = img ? img.size : 0 + if (this.beingPasteText !== text || this.beingPasteImgSize !== imgSize) { + this.currentBeingPasteType = CONSTANTS.PASTE_TYPE.CLIP_BOARD + this.beingPasteText = text + this.beingPasteImgSize = imgSize + } + // 检查要粘贴的节点数据是否有变化,节点优先级高于剪切板 + if (this.lastBeingCopyData !== this.beingCopyData) { + this.lastBeingCopyData = this.beingCopyData + this.currentBeingPasteType = CONSTANTS.PASTE_TYPE.CANVAS + } + // 粘贴剪切板的数据 + if (this.currentBeingPasteType === CONSTANTS.PASTE_TYPE.CLIP_BOARD) { + // 存在文本,则创建子节点 + if (text) { + this.mindMap.execCommand('INSERT_CHILD_NODE', false, [], { + text + }) + } + // 存在图片,则添加到当前激活节点 + if (img) { + try { + let imgData = await loadImage(img) + if (this.activeNodeList.length > 0) { + this.activeNodeList.forEach(node => { + this.mindMap.execCommand('SET_NODE_IMAGE', node, { + url: imgData.url, + title: '', + width: imgData.size.width, + height: imgData.size.height + }) + }) + } + } catch (error) { + console.log(error) + } + } + } else { + // 粘贴节点数据 + this.paste() + } + } + // 将节点移动到另一个节点的前面 insertBefore(node, exist) { if (node.isRoot) { return } // 如果是二级节点变成了下级节点,或是下级节点变成了二级节点,节点样式需要更新 - let nodeLayerChanged = (node.layerIndex === 1 && exist.layerIndex !== 1) || (node.layerIndex !== 1 && exist.layerIndex === 1) + let nodeLayerChanged = + (node.layerIndex === 1 && exist.layerIndex !== 1) || + (node.layerIndex !== 1 && exist.layerIndex === 1) // 移动节点 let nodeParent = node.parent let nodeBorthers = nodeParent.children @@ -579,7 +689,9 @@ class Render { return } // 如果是二级节点变成了下级节点,或是下级节点变成了二级节点,节点样式需要更新 - let nodeLayerChanged = (node.layerIndex === 1 && exist.layerIndex !== 1) || (node.layerIndex !== 1 && exist.layerIndex === 1) + let nodeLayerChanged = + (node.layerIndex === 1 && exist.layerIndex !== 1) || + (node.layerIndex !== 1 && exist.layerIndex === 1) // 移动节点 let nodeParent = node.parent let nodeBorthers = nodeParent.children @@ -619,7 +731,7 @@ class Render { } let isAppointNodes = appointNodes.length > 0 let list = isAppointNodes ? appointNodes : this.activeNodeList - let root = list.find((node) => { + let root = list.find(node => { return node.isRoot }) if (root) { @@ -705,7 +817,7 @@ class Render { // 粘贴节点到节点 pasteNode(data) { - if (this.activeNodeList.length <= 0) { + if (this.activeNodeList.length <= 0 || !data) { return } this.activeNodeList.forEach(item => { @@ -860,10 +972,11 @@ class Render { } // 设置节点文本 - setNodeText(node, text, richText) { + setNodeText(node, text, richText, resetRichText) { this.setNodeDataRender(node, { text, - richText + richText, + resetRichText }) } @@ -989,7 +1102,7 @@ class Render { } // 定位到指定节点 - goTargetNode(node) { + goTargetNode(node, callback = () => {}) { let uid = typeof node === 'string' ? node : node.nodeData.data.uid if (!uid) return this.expandToNodeUid(uid, () => { @@ -997,7 +1110,8 @@ class Render { if (targetNode) { targetNode.active() this.moveNodeToCenter(targetNode) - } + callback() + } }) } @@ -1009,7 +1123,7 @@ class Render { } // 设置节点数据,并判断是否渲染 - setNodeDataRender(node, data) { + setNodeDataRender(node, data, notRender = false) { this.setNodeData(node, data) let changed = node.reRender() if (changed) { @@ -1017,7 +1131,7 @@ class Render { // 概要节点 node.generalizationBelongNode.updateGeneralization() } - this.mindMap.render() + if (!notRender) this.mindMap.render() } } @@ -1038,7 +1152,7 @@ class Render { this.mindMap.view.setScale(1) } - // 展开到指定uid的节点 + // 展开到指定uid的节点 expandToNodeUid(uid, callback = () => {}) { let parentsList = [] const cache = {} @@ -1047,11 +1161,11 @@ class Render { parentsList = parent ? [...cache[parent.data.uid], parent] : [] return 'stop' } else { - cache[node.data.uid] = parent ? [...cache[parent.data.uid], parent]: [] + cache[node.data.uid] = parent ? [...cache[parent.data.uid], parent] : [] } }) let needRender = false - parentsList.forEach((node) => { + parentsList.forEach(node => { if (!node.data.expand) { needRender = true node.data.expand = true @@ -1067,11 +1181,11 @@ class Render { // 根据uid找到对应的节点实例 findNodeByUid(uid) { let res = null - walk(this.root, null, (node) => { + walk(this.root, null, node => { if (node.nodeData.data.uid === uid) { res = node return true - } + } }) return res } diff --git a/simple-mind-map/src/core/render/TextEdit.js b/simple-mind-map/src/core/render/TextEdit.js index 6ae819a9..e426ecf6 100644 --- a/simple-mind-map/src/core/render/TextEdit.js +++ b/simple-mind-map/src/core/render/TextEdit.js @@ -10,11 +10,14 @@ export default class TextEdit { this.currentNode = null // 文本编辑框 this.textEditNode = null + // 隐藏的文本输入框 + this.hiddenInputEl = null // 文本编辑框是否显示 this.showTextEdit = false // 如果编辑过程中缩放画布了,那么缓存当前编辑的内容 this.cacheEditingText = '' this.bindEvent() + this.createHiddenInput() } // 事件 @@ -46,6 +49,10 @@ export default class TextEdit { this.mindMap.on('before_node_active', () => { this.hideEditTextBox() }) + // 节点激活事件 + this.mindMap.on('node_active', () => { + this.focusHiddenInput() + }) // 注册编辑快捷键 this.mindMap.keyCommand.addShortcut('F2', () => { if (this.renderer.activeNodeList.length <= 0) { @@ -56,12 +63,52 @@ export default class TextEdit { this.mindMap.on('scale', this.onScale) } + // 创建一个隐藏的文本输入框 + createHiddenInput() { + if (this.hiddenInputEl) return + this.hiddenInputEl = document.createElement('input') + this.hiddenInputEl.type = 'text' + this.hiddenInputEl.style.cssText = ` + position: fixed; + left: -99999px; + top: -99999px; + ` + // 监听粘贴事件 + this.hiddenInputEl.addEventListener('paste', async event => { + event.preventDefault() + const text = (event.clipboardData || window.clipboardData).getData('text') + const files = event.clipboardData.files + let img = null + if (files.length > 0) { + for (let i = 0; i < files.length; i++) { + if (/^image\//.test(files[i].type)) { + img = files[i] + break + } + } + } + this.mindMap.emit('paste', { + text, + img + }) + }) + document.body.appendChild(this.hiddenInputEl) + } + + // 让隐藏的文本输入框聚焦 + focusHiddenInput() { + if (this.hiddenInputEl) this.hiddenInputEl.focus() + } + // 注册临时快捷键 registerTmpShortcut() { // 注册回车快捷键 this.mindMap.keyCommand.addShortcut('Enter', () => { this.hideEditTextBox() }) + this.mindMap.keyCommand.addShortcut('Tab', () => { + this.hideEditTextBox() + }) } // 显示文本编辑框 @@ -96,7 +143,8 @@ export default class TextEdit { onScale() { if (!this.currentNode) return if (this.mindMap.richText) { - this.mindMap.richText.cacheEditingText = this.mindMap.richText.getEditText() + this.mindMap.richText.cacheEditingText = + this.mindMap.richText.getEditText() this.mindMap.richText.showTextEdit = false } else { this.cacheEditingText = this.getEditText() @@ -124,7 +172,9 @@ export default class TextEdit { let scale = this.mindMap.view.scale let lineHeight = node.style.merge('lineHeight') let fontSize = node.style.merge('fontSize') - let textLines = (this.cacheEditingText || node.nodeData.data.text).split(/\n/gim) + let textLines = (this.cacheEditingText || node.nodeData.data.text).split( + /\n/gim + ) let isMultiLine = node._textData.node.attr('data-ismultiLine') === 'true' node.style.domText(this.textEditNode, scale, isMultiLine) this.textEditNode.style.zIndex = this.mindMap.opt.nodeTextEditZIndex @@ -134,9 +184,12 @@ export default class TextEdit { this.textEditNode.style.left = rect.left + 'px' this.textEditNode.style.top = rect.top + 'px' this.textEditNode.style.display = 'block' - this.textEditNode.style.maxWidth = this.mindMap.opt.textAutoWrapWidth * scale + 'px' + this.textEditNode.style.maxWidth = + this.mindMap.opt.textAutoWrapWidth * scale + 'px' if (isMultiLine && lineHeight !== 1) { - this.textEditNode.style.transform = `translateY(${-((lineHeight * fontSize - fontSize) / 2) * scale}px)` + this.textEditNode.style.transform = `translateY(${ + -((lineHeight * fontSize - fontSize) / 2) * scale + }px)` } this.showTextEdit = true // 选中文本 diff --git a/simple-mind-map/src/core/render/node/Node.js b/simple-mind-map/src/core/render/node/Node.js index 4dd66d84..4a5a6ac2 100644 --- a/simple-mind-map/src/core/render/node/Node.js +++ b/simple-mind-map/src/core/render/node/Node.js @@ -266,6 +266,7 @@ class Node { paddingY += this.shapePadding.paddingY // 节点形状 this.shapeNode = this.shapeInstance.createShape() + this.shapeNode.addClass('smm-node-shape') this.group.add(this.shapeNode) this.updateNodeShape() // 渲染一个隐藏的矩形区域,用来触发展开收起按钮的显示 @@ -531,6 +532,7 @@ class Node { isLayout = true // 创建组 this.group = new G() + this.group.addClass('smm-node') this.group.css({ cursor: 'default' }) diff --git a/simple-mind-map/src/core/render/node/nodeCommandWraps.js b/simple-mind-map/src/core/render/node/nodeCommandWraps.js index ceb66ad2..3ef043e9 100644 --- a/simple-mind-map/src/core/render/node/nodeCommandWraps.js +++ b/simple-mind-map/src/core/render/node/nodeCommandWraps.js @@ -4,8 +4,8 @@ function setData(data = {}) { } // 设置文本 -function setText(text, richText) { - this.mindMap.execCommand('SET_NODE_TEXT', this, text, richText) +function setText(text, richText, resetRichText) { + this.mindMap.execCommand('SET_NODE_TEXT', this, text, richText, resetRichText) } // 设置图片 diff --git a/simple-mind-map/src/core/render/node/nodeCreateContents.js b/simple-mind-map/src/core/render/node/nodeCreateContents.js index 9822484a..505bab59 100644 --- a/simple-mind-map/src/core/render/node/nodeCreateContents.js +++ b/simple-mind-map/src/core/render/node/nodeCreateContents.js @@ -1,7 +1,7 @@ -import { measureText, resizeImgSize, getTextFromHtml } from '../../../utils' +import { measureText, resizeImgSize, removeHtmlStyle, addHtmlStyle, checkIsRichText } from '../../../utils' import { Image, SVG, A, G, Rect, Text, ForeignObject } from '@svgdotjs/svg.js' import iconsSvg from '../../../svg/icons' -import { CONSTANTS } from '../../../constants/constant' +import { CONSTANTS, commonCaches } from '../../../constants/constant' // 创建图片节点 function createImgNode() { @@ -64,6 +64,9 @@ function createIconNode() { node = new Image().load(src) } node.size(iconSize, iconSize) + node.on('click', e => { + this.mindMap.emit('node_icon_click', this, item, e) + }) return { node, width: iconSize, @@ -88,8 +91,21 @@ function createRichTextNode() { } } if (recoverText) { - let text = getTextFromHtml(this.nodeData.data.text) - this.nodeData.data.text = `

${text}

` + let text = this.nodeData.data.text + // 判断节点内容是否是富文本 + let isRichText = checkIsRichText(text) + // 样式字符串 + let style = this.style.createStyleText() + if (isRichText) { + // 如果是富文本那么线移除内联样式 + text = removeHtmlStyle(text) + // 再添加新的内联样式 + text = addHtmlStyle(text, 'span', style) + } else { + // 非富文本 + text = `

${text}

` + } + this.nodeData.data.text = text } let html = `
${this.nodeData.data.text}
` let div = document.createElement('div') @@ -293,20 +309,19 @@ function createNoteNode() { } // 测量自定义节点内容元素的宽高 -let warpEl = null function measureCustomNodeContentSize (content) { - if (!warpEl) { - warpEl = document.createElement('div') - warpEl.style.cssText = ` + if (!commonCaches.measureCustomNodeContentSizeEl) { + commonCaches.measureCustomNodeContentSizeEl = document.createElement('div') + commonCaches.measureCustomNodeContentSizeEl.style.cssText = ` position: fixed; left: -99999px; top: -99999px; ` - this.mindMap.el.appendChild(warpEl) + this.mindMap.el.appendChild(commonCaches.measureCustomNodeContentSizeEl) } - warpEl.innerHTML = '' - warpEl.appendChild(content) - let rect = warpEl.getBoundingClientRect() + commonCaches.measureCustomNodeContentSizeEl.innerHTML = '' + commonCaches.measureCustomNodeContentSizeEl.appendChild(content) + let rect = commonCaches.measureCustomNodeContentSizeEl.getBoundingClientRect() return { width: rect.width, height: rect.height diff --git a/simple-mind-map/src/core/render/node/nodeGeneralization.js b/simple-mind-map/src/core/render/node/nodeGeneralization.js index ba204186..ec7f95aa 100644 --- a/simple-mind-map/src/core/render/node/nodeGeneralization.js +++ b/simple-mind-map/src/core/render/node/nodeGeneralization.js @@ -36,15 +36,14 @@ function createGeneralizationNode () { // 更新概要节点 function updateGeneralization () { + if (this.isGeneralization) return this.removeGeneralization() this.createGeneralizationNode() } // 渲染概要节点 function renderGeneralization () { - if (this.isGeneralization) { - return - } + if (this.isGeneralization) return if (!this.checkHasGeneralization()) { this.removeGeneralization() this._generalizationNodeWidth = 0 @@ -67,6 +66,7 @@ function renderGeneralization () { // 删除概要节点 function removeGeneralization () { + if (this.isGeneralization) return if (this._generalizationLine) { this._generalizationLine.remove() this._generalizationLine = null @@ -87,6 +87,7 @@ function removeGeneralization () { // 隐藏概要节点 function hideGeneralization () { + if (this.isGeneralization) return if (this._generalizationLine) { this._generalizationLine.hide() } @@ -97,6 +98,7 @@ function hideGeneralization () { // 显示概要节点 function showGeneralization () { + if (this.isGeneralization) return if (this._generalizationLine) { this._generalizationLine.show() } diff --git a/simple-mind-map/src/plugins/AssociativeLine.js b/simple-mind-map/src/plugins/AssociativeLine.js index 28223265..2a7ebba1 100644 --- a/simple-mind-map/src/plugins/AssociativeLine.js +++ b/simple-mind-map/src/plugins/AssociativeLine.js @@ -11,7 +11,7 @@ import { import associativeLineControlsMethods from './associativeLine/associativeLineControls' import associativeLineTextMethods from './associativeLine/associativeLineText' -// 关联线类 +// 关联线插件 class AssociativeLine { constructor(opt = {}) { this.mindMap = opt.mindMap diff --git a/simple-mind-map/src/plugins/Drag.js b/simple-mind-map/src/plugins/Drag.js index d85ea667..78a4b8aa 100644 --- a/simple-mind-map/src/plugins/Drag.js +++ b/simple-mind-map/src/plugins/Drag.js @@ -1,8 +1,7 @@ import { bfsWalk, throttle } from '../utils' import Base from '../layouts/Base' -// 节点拖动类 - +// 节点拖动插件 class Drag extends Base { // 构造函数 constructor({ mindMap }) { diff --git a/simple-mind-map/src/plugins/Export.js b/simple-mind-map/src/plugins/Export.js index 1f719d8f..a5747595 100644 --- a/simple-mind-map/src/plugins/Export.js +++ b/simple-mind-map/src/plugins/Export.js @@ -1,9 +1,9 @@ -import { imgToDataUrl, downloadFile, readBlob } from '../utils' +import { imgToDataUrl, downloadFile, readBlob, removeHTMLEntities } from '../utils' import { SVG } from '@svgdotjs/svg.js' import drawBackgroundImageToCanvas from '../utils/simulateCSSBackgroundInCanvas' import { transformToMarkdown } from '../parse/toMarkdown' -// 导出类 +// 导出插件 class Export { // 构造函数 constructor(opt) { @@ -154,6 +154,7 @@ class Export { */ async png(name, transparent = false) { let { node, str } = await this.getSvgData() + str = removeHTMLEntities(str) // 如果开启了富文本,则使用htmltocanvas转换为图片 if (this.mindMap.richText) { let res = await this.mindMap.richText.handleExportPng(node.node) @@ -207,6 +208,7 @@ class Export { node.first().before(SVG(`${name}`)) await this.drawBackgroundToSvg(node) let str = node.svg() + str = removeHTMLEntities(str) // 转换成blob数据 let blob = new Blob([str], { type: 'image/svg+xml' diff --git a/simple-mind-map/src/plugins/ExportPDF.js b/simple-mind-map/src/plugins/ExportPDF.js index 2fcc254d..e46b3a3c 100644 --- a/simple-mind-map/src/plugins/ExportPDF.js +++ b/simple-mind-map/src/plugins/ExportPDF.js @@ -1,6 +1,6 @@ import JsPDF from 'jspdf' -// 导出PDF类,需要通过Export插件使用 +// 导出PDF插件,需要通过Export插件使用 class ExportPDF { // 构造函数 constructor(opt) { diff --git a/simple-mind-map/src/plugins/ExportXMind.js b/simple-mind-map/src/plugins/ExportXMind.js index 5f54e220..42ea665c 100644 --- a/simple-mind-map/src/plugins/ExportXMind.js +++ b/simple-mind-map/src/plugins/ExportXMind.js @@ -1,6 +1,6 @@ import xmind from '../parse/xmind' -// 导出XMind类,需要通过Export插件使用 +// 导出XMind插件,需要通过Export插件使用 class ExportXMind { // 构造函数 constructor(opt) { diff --git a/simple-mind-map/src/plugins/KeyboardNavigation.js b/simple-mind-map/src/plugins/KeyboardNavigation.js index 0a3f6098..5ed4b593 100644 --- a/simple-mind-map/src/plugins/KeyboardNavigation.js +++ b/simple-mind-map/src/plugins/KeyboardNavigation.js @@ -1,7 +1,7 @@ import { bfsWalk } from '../utils' import { CONSTANTS } from '../constants/constant' -// 键盘导航类 +// 键盘导航插件 class KeyboardNavigation { // 构造函数 constructor(opt) { diff --git a/simple-mind-map/src/plugins/MiniMap.js b/simple-mind-map/src/plugins/MiniMap.js index 9bc1d6ba..ed4a99d3 100644 --- a/simple-mind-map/src/plugins/MiniMap.js +++ b/simple-mind-map/src/plugins/MiniMap.js @@ -1,4 +1,6 @@ -// 小地图类 +import { isWhite, isTransparent } from '../utils/index' + +// 小地图插件 class MiniMap { // 构造函数 constructor(opt) { @@ -20,7 +22,7 @@ class MiniMap { * boxHeight:小地图容器的高度 */ calculationMiniMap(boxWidth, boxHeight) { - let { svgHTML, rect, origWidth, origHeight, scaleX, scaleY } = + let { svg, rect, origWidth, origHeight, scaleX, scaleY } = this.mindMap.getSvgData() // 计算数据 let boxRatio = boxWidth / boxHeight @@ -65,8 +67,10 @@ class MiniMap { Math.max(0, ((_rectY2 - origHeight) / _rectHeight) * actHeight) + miniMapBoxTop + 'px' + + this.removeNodeContent(svg) return { - svgHTML, // 小地图html + svgHTML: svg.svg(), // 小地图html viewBoxStyle, // 视图框的位置信息 miniMapBoxScale, // 视图框的缩放值 miniMapBoxLeft, // 视图框的left值 @@ -74,6 +78,38 @@ class MiniMap { } } + // 移除节点的内容 + removeNodeContent(svg) { + if (svg.hasClass('smm-node')) { + let shape = svg.findOne('.smm-node-shape') + let fill = shape.attr('fill') + if (isWhite(fill) || isTransparent(fill)) { + shape.attr('fill', this.getDefaultFill()) + } + svg.clear() + svg.add(shape) + return + } + let children = svg.children() + if (children && children.length > 0) { + children.forEach((node) => { + this.removeNodeContent(node) + }) + } + } + + // 计算默认的填充颜色 + getDefaultFill() { + let { lineColor, root, second, node } = this.mindMap.themeConfig + let list = [lineColor, root.fillColor, root.color, second.fillColor, second.color, node.fillColor, node.color, root.borderColor, second.borderColor, node.borderColor] + for(let i = 0; i < list.length; i++) { + let color = list[i] + if (!isTransparent(color) && !isWhite(color)) { + return color + } + } + } + // 小地图鼠标按下事件 onMousedown(e) { this.isMousedown = true diff --git a/simple-mind-map/src/plugins/NodeImgAdjust.js b/simple-mind-map/src/plugins/NodeImgAdjust.js index a9b9d947..37fce4b7 100644 --- a/simple-mind-map/src/plugins/NodeImgAdjust.js +++ b/simple-mind-map/src/plugins/NodeImgAdjust.js @@ -208,7 +208,10 @@ class NodeImgAdjust { // 渲染完成事件 onRenderEnd() { - if (!this.isAdjusted) return + if (!this.isAdjusted) { + this.hideHandleEl() + return + } this.isAdjusted = false } diff --git a/simple-mind-map/src/plugins/RichText.js b/simple-mind-map/src/plugins/RichText.js index d501c282..2652428f 100644 --- a/simple-mind-map/src/plugins/RichText.js +++ b/simple-mind-map/src/plugins/RichText.js @@ -28,7 +28,7 @@ let fontSizeList = new Array(100).fill(0).map((_, index) => { return index + 'px' }) -// 节点支持富文本编辑功能 +// 富文本编辑插件 class RichText { constructor({ mindMap, pluginOpt }) { this.mindMap = mindMap @@ -268,6 +268,12 @@ class RichText { handler: function () { // 覆盖默认的回车键换行 } + }, + tab: { + key: 9, + handler: function () { + // 覆盖默认的tab键 + } } } } diff --git a/simple-mind-map/src/plugins/Search.js b/simple-mind-map/src/plugins/Search.js new file mode 100644 index 00000000..5844ff00 --- /dev/null +++ b/simple-mind-map/src/plugins/Search.js @@ -0,0 +1,160 @@ +import { bfsWalk, getTextFromHtml, isUndef } from '../utils/index' + +// 搜索插件 +class Search { + // 构造函数 + constructor({ mindMap }) { + this.mindMap = mindMap + // 是否正在搜索 + this.isSearching = false + // 搜索文本 + this.searchText = '' + // 匹配的节点列表 + this.matchNodeList = [] + // 当前所在的节点列表索引 + this.currentIndex = -1 + // 不要复位搜索文本 + this.notResetSearchText = false + this.onDataChange = this.onDataChange.bind(this) + this.mindMap.on('data_change', this.onDataChange) + } + + // 节点数据改变了,需要重新搜索 + onDataChange() { + if (this.notResetSearchText) { + this.notResetSearchText = false + return + } + this.searchText = '' + } + + // 搜索 + search(text, callback) { + if (isUndef(text)) return this.endSearch() + text = String(text) + this.isSearching = true + if (this.searchText === text) { + // 和上一次搜索文本一样,那么搜索下一个 + this.searchNext(callback) + } else { + // 和上次搜索文本不一样,那么重新开始 + this.searchText = text + this.doSearch() + this.searchNext(callback) + } + this.emitEvent() + } + + // 结束搜索 + endSearch() { + if (!this.isSearching) return + this.searchText = '' + this.matchNodeList = [] + this.currentIndex = -1 + this.notResetSearchText = false + this.isSearching = false + this.emitEvent() + } + + // 搜索匹配的节点 + doSearch() { + this.matchNodeList = [] + this.currentIndex = -1 + bfsWalk(this.mindMap.renderer.root, node => { + let { richText, text } = node.nodeData.data + if (richText) { + text = getTextFromHtml(text) + } + if (text.includes(this.searchText)) { + this.matchNodeList.push(node) + } + }) + } + + // 搜索下一个,定位到下一个匹配节点 + searchNext(callback) { + if (!this.isSearching || this.matchNodeList.length <= 0) return + if (this.currentIndex < this.matchNodeList.length - 1) { + this.currentIndex++ + } else { + this.currentIndex = 0 + } + let currentNode = this.matchNodeList[this.currentIndex] + this.notResetSearchText = true + this.mindMap.execCommand('GO_TARGET_NODE', currentNode, () => { + this.notResetSearchText = false + callback() + }) + } + + // 替换当前节点 + replace(replaceText) { + if ( + isUndef(replaceText) || + !this.isSearching || + this.matchNodeList.length <= 0 + ) + return + replaceText = String(replaceText) + let currentNode = this.matchNodeList[this.currentIndex] + if (!currentNode) return + let text = this.getReplacedText(currentNode, this.searchText, replaceText) + this.notResetSearchText = true + currentNode.setText(text, currentNode.nodeData.data.richText, true) + this.matchNodeList = this.matchNodeList.filter(node => { + return currentNode !== node + }) + if (this.currentIndex > this.matchNodeList.length - 1) { + this.currentIndex = -1 + } else { + this.currentIndex-- + } + this.emitEvent() + } + + // 替换所有 + replaceAll(replaceText) { + if ( + isUndef(replaceText) || + !this.isSearching || + this.matchNodeList.length <= 0 + ) + return + replaceText = String(replaceText) + this.matchNodeList.forEach(node => { + let text = this.getReplacedText(node, this.searchText, replaceText) + this.mindMap.renderer.setNodeDataRender( + node, + { + text, + resetRichText: !!node.nodeData.data.richText + }, + true + ) + }) + this.mindMap.render() + this.mindMap.command.addHistory() + this.endSearch() + } + + // 获取某个节点替换后的文本 + getReplacedText(node, searchText, replaceText) { + let { richText, text } = node.nodeData.data + if (richText) { + text = getTextFromHtml(text) + } + return text.replaceAll(searchText, replaceText) + } + + // 发送事件 + emitEvent() { + this.mindMap.emit('search_info_change', { + currentIndex: this.currentIndex, + total: this.matchNodeList.length + }) + } +} + +Search.instanceName = 'search' + +export default Search diff --git a/simple-mind-map/src/plugins/Select.js b/simple-mind-map/src/plugins/Select.js index b2a58c14..bba83b0c 100644 --- a/simple-mind-map/src/plugins/Select.js +++ b/simple-mind-map/src/plugins/Select.js @@ -1,7 +1,6 @@ import { bfsWalk, throttle } from '../utils' -// 选择节点类 - +// 节点选择插件 class Select { // 构造函数 constructor({ mindMap }) { diff --git a/simple-mind-map/src/plugins/TouchEvent.js b/simple-mind-map/src/plugins/TouchEvent.js index 5afc1f04..2d4f78d1 100644 --- a/simple-mind-map/src/plugins/TouchEvent.js +++ b/simple-mind-map/src/plugins/TouchEvent.js @@ -1,5 +1,4 @@ -// 手势事件支持类 - +// 手势事件支持插件 class TouchEvent { // 构造函数 constructor({ mindMap }) { diff --git a/simple-mind-map/src/plugins/Watermark.js b/simple-mind-map/src/plugins/Watermark.js index 7d2ddaca..cd6a3c98 100644 --- a/simple-mind-map/src/plugins/Watermark.js +++ b/simple-mind-map/src/plugins/Watermark.js @@ -2,7 +2,7 @@ import { Text, G } from '@svgdotjs/svg.js' import { degToRad, camelCaseToHyphen } from '../utils' import merge from 'deepmerge' -// 水印类 +// 水印插件 class Watermark { constructor(opt = {}) { this.mindMap = opt.mindMap diff --git a/simple-mind-map/src/utils/index.js b/simple-mind-map/src/utils/index.js index 462b1913..68cc323a 100644 --- a/simple-mind-map/src/utils/index.js +++ b/simple-mind-map/src/utils/index.js @@ -433,4 +433,98 @@ export const getImageSize = src => { // 创建节点唯一的id export const createUid = () => { return uuidv4() +} + +// 加载图片文件 +export const loadImage = imgFile => { + return new Promise((resolve, reject) => { + let fr = new FileReader() + fr.readAsDataURL(imgFile) + fr.onload = async e => { + let url = e.target.result + let size = await getImageSize(url) + resolve({ + url, + size + }) + } + fr.onerror = error => { + reject(error) + } + }) +} + +// 移除字符串中的html实体 +export const removeHTMLEntities = (str) => { + [[' ', ' ']].forEach((item) => { + str = str.replaceAll(item[0], item[1]) + }) + return str +} + +// 获取一个数据的类型 +export const getType = (data) => { + return Object.prototype.toString.call(data).slice(7, -1) +} + +// 判断一个数据是否是null和undefined和空字符串 +export const isUndef = (data) => { + return data === null || data === undefined || data === '' +} + +// 移除html字符串中节点的内联样式 +export const removeHtmlStyle = (html) => { + return html.replaceAll(/(<[^\s]+)\s+style=["'][^'"]+["']\s*(>)/g, '$1$2') +} + +// 给html标签中指定的标签添加内联样式 +export const addHtmlStyle = (html, tag, style) => { + const reg = new RegExp(`(<${tag}[^>]*)(>[^<>]*)`, 'g') + return html.replaceAll(reg, `$1 style="${style}"$2`) +} + +// 检查一个字符串是否是富文本字符 +let checkIsRichTextEl = null +export const checkIsRichText = (str) => { + if (!checkIsRichTextEl) { + checkIsRichTextEl = document.createElement('div') + } + checkIsRichTextEl.innerHTML = str + for (let c = checkIsRichTextEl.childNodes, i = c.length; i--;) { + if (c[i].nodeType == 1) return true + } + return false +} + +// 搜索和替换html字符串中指定的文本 +let replaceHtmlTextEl = null +export const replaceHtmlText = (html, searchText, replaceText) => { + if (!replaceHtmlTextEl) { + replaceHtmlTextEl = document.createElement('div') + } + replaceHtmlTextEl.innerHTML = html + let walk = (root) => { + let childNodes = root.childNodes + childNodes.forEach((node) => { + if (node.nodeType === 1) {// 元素节点 + walk(node) + } else if (node.nodeType === 3) {// 文本节点 + root.replaceChild(document.createTextNode(node.nodeValue.replaceAll(searchText, replaceText)), node) + } + }) + } + walk(replaceHtmlTextEl) + return replaceHtmlTextEl.innerHTML +} + +// 判断一个颜色是否是白色 +export const isWhite = (color) => { + color = String(color).replaceAll(/\s+/g, '') + return ['#fff', '#ffffff', '#FFF', '#FFFFFF', 'rgb(255,255,255)'].includes(color) || /rgba\(255,255,255,[^)]+\)/.test(color) +} + +// 判断一个颜色是否是透明 +export const isTransparent = (color) => { + color = String(color).replaceAll(/\s+/g, '') + return ['', 'transparent'].includes(color) || /rgba\(\d+,\d+,\d+,0\)/.test(color) } \ No newline at end of file diff --git a/web/package.json b/web/package.json index 8cc3ff6a..7a73ec67 100644 --- a/web/package.json +++ b/web/package.json @@ -12,18 +12,19 @@ "serve": "vue-cli-service serve", "build": "vue-cli-service build && node ../copy.js", "lint": "vue-cli-service lint", - "autoBuildDoc": "node ./scripts/autoBuildDoc.js", - "buildDoc": "node ./scripts/buildDoc.js", "electron:build": "vue-cli-service electron:build -p never", "electron:build-all": "vue-cli-service electron:build -p never -mwl", "electron:build-mac": "vue-cli-service electron:build -p never -m", "electron:build-win": "vue-cli-service electron:build -p never -w", "electron:build-linux": "vue-cli-service electron:build -p never -l", "electron:serve": "vue-cli-service electron:serve", - "buildLibrary": "vue-cli-service build --target lib --name simpleMindMap ../simple-mind-map/full.js --dest ../simple-mind-map/dist && esbuild ../simple-mind-map/full.js --bundle --external:buffer --format=esm --outfile=../simple-mind-map/dist/simpleMindMap.esm.js", - "format": "prettier --write src/* src/*/* src/*/*/* src/*/*/*/*", "postinstall": "electron-builder install-app-deps", - "postuninstall": "electron-builder install-app-deps" + "postuninstall": "electron-builder install-app-deps", + "buildLibrary": "vue-cli-service build --target lib --name simpleMindMap ../simple-mind-map/full.js --dest ../simple-mind-map/dist && esbuild ../simple-mind-map/full.js --bundle --external:buffer --format=esm --outfile=../simple-mind-map/dist/simpleMindMap.esm.js && esbuild ../simple-mind-map/full.js --bundle --minify --external:buffer --format=esm --outfile=../simple-mind-map/dist/simpleMindMap.esm.min.js", + "format": "prettier --write src/* src/*/* src/*/*/* src/*/*/*/*", + "buildDoc": "node ./scripts/buildDoc.js", + "autoBuildDoc": "node ./scripts/autoBuildDoc.js", + "createNodeImageList": "node ./scripts/createNodeImageList.js" }, "main": "background.js", "dependencies": { diff --git a/web/scripts/createNodeImageList.js b/web/scripts/createNodeImageList.js new file mode 100644 index 00000000..f8b74c92 --- /dev/null +++ b/web/scripts/createNodeImageList.js @@ -0,0 +1,50 @@ +const path = require('path') +const fs = require('fs') + +const fileDest = path.join(__dirname, '../src/assets/svg') +const targetDest = path.join(__dirname, '../src/config/image.js') + +const run = (dir) => { + let dirs = fs.readdirSync(dir) + dirs.forEach(item => { + let cur = path.join(dir, item) + if (fs.statSync(cur).isDirectory()) { + walkDir(cur, item) + } + }) +} + +const list = [] +const importList = [] +const walkDir = (dir, item) => { + let files = fs.readdirSync(dir) + let name = files.find((file) => { + return !/\./.test(file) + }) + let fileList = files.filter((file) => { + return /\.svg$/.test(file) + }) + let itemList = [] + fileList.forEach((file) => { + let fileName = item + '_' + file.replace(/\.svg$/, '').replaceAll('-', '') + importList.push(`import ${fileName} from '../assets/svg/${item}/${file}'`) + itemList.push({ + url: fileName, + width: 100, + height: 100 + }) + }) + list.push({ + name, + list: itemList + }) + const content = ` +// 该文件请运行npm run createNodeImageList命令自动生成 +${importList.join('\n')} +export default ${JSON.stringify(list, null, 2).replace(/(url":\s*)"([^"]+)"(,)/g, '$1$2$3')} +` + fs.writeFileSync(targetDest, content) +} + +run(fileDest) +console.log('运行成功') \ No newline at end of file diff --git a/web/src/assets/avatar/仓鼠.jpg b/web/src/assets/avatar/仓鼠.jpg new file mode 100644 index 00000000..1eabba76 Binary files /dev/null and b/web/src/assets/avatar/仓鼠.jpg differ diff --git a/web/src/assets/avatar/千帆.jpg b/web/src/assets/avatar/千帆.jpg new file mode 100644 index 00000000..652e0d2e Binary files /dev/null and b/web/src/assets/avatar/千帆.jpg differ diff --git a/web/src/assets/avatar/水车.jpg b/web/src/assets/avatar/水车.jpg new file mode 100644 index 00000000..747178b7 Binary files /dev/null and b/web/src/assets/avatar/水车.jpg differ diff --git a/web/src/assets/icon-font/iconfont.css b/web/src/assets/icon-font/iconfont.css index d216721f..fe9033b0 100644 --- a/web/src/assets/icon-font/iconfont.css +++ b/web/src/assets/icon-font/iconfont.css @@ -1,8 +1,8 @@ @font-face { font-family: "iconfont"; /* Project id 2479351 */ - src: url('iconfont.woff2?t=1689407546912') format('woff2'), - url('iconfont.woff?t=1689407546912') format('woff'), - url('iconfont.ttf?t=1689407546912') format('truetype'); + src: url('iconfont.woff2?t=1690537337895') format('woff2'), + url('iconfont.woff?t=1690537337895') format('woff'), + url('iconfont.ttf?t=1690537337895') format('truetype'); } .iconfont { @@ -13,6 +13,18 @@ -moz-osx-font-smoothing: grayscale; } +.iconlieri:before { + content: "\e60b"; +} + +.iconmoon_line:before { + content: "\e745"; +} + +.iconsousuo:before { + content: "\e693"; +} + .iconjiantouyou:before { content: "\e62d"; } diff --git a/web/src/assets/icon-font/iconfont.ttf b/web/src/assets/icon-font/iconfont.ttf index 9c801c08..4b0d897e 100644 Binary files a/web/src/assets/icon-font/iconfont.ttf and b/web/src/assets/icon-font/iconfont.ttf differ diff --git a/web/src/assets/icon-font/iconfont.woff b/web/src/assets/icon-font/iconfont.woff index 4d446856..09e3ebb3 100644 Binary files a/web/src/assets/icon-font/iconfont.woff and b/web/src/assets/icon-font/iconfont.woff differ diff --git a/web/src/assets/icon-font/iconfont.woff2 b/web/src/assets/icon-font/iconfont.woff2 index 1d170d95..10ffcf6c 100644 Binary files a/web/src/assets/icon-font/iconfont.woff2 and b/web/src/assets/icon-font/iconfont.woff2 differ diff --git a/web/src/assets/img/darkNightLceBlade.jpg b/web/src/assets/img/darkNightLceBlade.jpg new file mode 100644 index 00000000..1ea928b5 Binary files /dev/null and b/web/src/assets/img/darkNightLceBlade.jpg differ diff --git a/web/src/assets/img/lemonBubbles.jpg b/web/src/assets/img/lemonBubbles.jpg new file mode 100644 index 00000000..ca6c5d67 Binary files /dev/null and b/web/src/assets/img/lemonBubbles.jpg differ diff --git a/web/src/assets/img/morandi.jpg b/web/src/assets/img/morandi.jpg new file mode 100644 index 00000000..b6fa2e2d Binary files /dev/null and b/web/src/assets/img/morandi.jpg differ diff --git a/web/src/assets/img/neonLamp.jpg b/web/src/assets/img/neonLamp.jpg new file mode 100644 index 00000000..2cc1d617 Binary files /dev/null and b/web/src/assets/img/neonLamp.jpg differ diff --git a/web/src/assets/img/oreo.jpg b/web/src/assets/img/oreo.jpg new file mode 100644 index 00000000..45071f4d Binary files /dev/null and b/web/src/assets/img/oreo.jpg differ diff --git a/web/src/assets/img/rose.jpg b/web/src/assets/img/rose.jpg new file mode 100644 index 00000000..d97d4dcb Binary files /dev/null and b/web/src/assets/img/rose.jpg differ diff --git a/web/src/assets/img/seaBlueLine.jpg b/web/src/assets/img/seaBlueLine.jpg new file mode 100644 index 00000000..7e7d6da4 Binary files /dev/null and b/web/src/assets/img/seaBlueLine.jpg differ diff --git a/web/src/assets/img/shallowSea.jpg b/web/src/assets/img/shallowSea.jpg new file mode 100644 index 00000000..0171ee35 Binary files /dev/null and b/web/src/assets/img/shallowSea.jpg differ diff --git a/web/src/assets/svg/business/-.svg b/web/src/assets/svg/business/-.svg new file mode 100644 index 00000000..2f239639 --- /dev/null +++ b/web/src/assets/svg/business/-.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_1.svg b/web/src/assets/svg/business/-_1.svg new file mode 100644 index 00000000..464b38fd --- /dev/null +++ b/web/src/assets/svg/business/-_1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_10.svg b/web/src/assets/svg/business/-_10.svg new file mode 100644 index 00000000..29b5d6c4 --- /dev/null +++ b/web/src/assets/svg/business/-_10.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_11.svg b/web/src/assets/svg/business/-_11.svg new file mode 100644 index 00000000..70edb4bc --- /dev/null +++ b/web/src/assets/svg/business/-_11.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_12.svg b/web/src/assets/svg/business/-_12.svg new file mode 100644 index 00000000..2dca3f23 --- /dev/null +++ b/web/src/assets/svg/business/-_12.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_13.svg b/web/src/assets/svg/business/-_13.svg new file mode 100644 index 00000000..0b9b863e --- /dev/null +++ b/web/src/assets/svg/business/-_13.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_14.svg b/web/src/assets/svg/business/-_14.svg new file mode 100644 index 00000000..764bc474 --- /dev/null +++ b/web/src/assets/svg/business/-_14.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_15.svg b/web/src/assets/svg/business/-_15.svg new file mode 100644 index 00000000..1f7dbc48 --- /dev/null +++ b/web/src/assets/svg/business/-_15.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_16.svg b/web/src/assets/svg/business/-_16.svg new file mode 100644 index 00000000..455fd265 --- /dev/null +++ b/web/src/assets/svg/business/-_16.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_17.svg b/web/src/assets/svg/business/-_17.svg new file mode 100644 index 00000000..36ff1123 --- /dev/null +++ b/web/src/assets/svg/business/-_17.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_18.svg b/web/src/assets/svg/business/-_18.svg new file mode 100644 index 00000000..df0bb8fb --- /dev/null +++ b/web/src/assets/svg/business/-_18.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_2.svg b/web/src/assets/svg/business/-_2.svg new file mode 100644 index 00000000..802a4467 --- /dev/null +++ b/web/src/assets/svg/business/-_2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_3.svg b/web/src/assets/svg/business/-_3.svg new file mode 100644 index 00000000..9f64cec0 --- /dev/null +++ b/web/src/assets/svg/business/-_3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_4.svg b/web/src/assets/svg/business/-_4.svg new file mode 100644 index 00000000..fbd7e467 --- /dev/null +++ b/web/src/assets/svg/business/-_4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_5.svg b/web/src/assets/svg/business/-_5.svg new file mode 100644 index 00000000..a9cbd0c7 --- /dev/null +++ b/web/src/assets/svg/business/-_5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_6.svg b/web/src/assets/svg/business/-_6.svg new file mode 100644 index 00000000..add3e62e --- /dev/null +++ b/web/src/assets/svg/business/-_6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_7.svg b/web/src/assets/svg/business/-_7.svg new file mode 100644 index 00000000..ae7bd9ce --- /dev/null +++ b/web/src/assets/svg/business/-_7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_8.svg b/web/src/assets/svg/business/-_8.svg new file mode 100644 index 00000000..437543c2 --- /dev/null +++ b/web/src/assets/svg/business/-_8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/-_9.svg b/web/src/assets/svg/business/-_9.svg new file mode 100644 index 00000000..bab1c671 --- /dev/null +++ b/web/src/assets/svg/business/-_9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/OAxitong.svg b/web/src/assets/svg/business/OAxitong.svg new file mode 100644 index 00000000..df92799c --- /dev/null +++ b/web/src/assets/svg/business/OAxitong.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/changyongziyuan.svg b/web/src/assets/svg/business/changyongziyuan.svg new file mode 100644 index 00000000..cae6e961 --- /dev/null +++ b/web/src/assets/svg/business/changyongziyuan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/chuchashenpi.svg b/web/src/assets/svg/business/chuchashenpi.svg new file mode 100644 index 00000000..eab11298 --- /dev/null +++ b/web/src/assets/svg/business/chuchashenpi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/fanwendengji.svg b/web/src/assets/svg/business/fanwendengji.svg new file mode 100644 index 00000000..de2c15bd --- /dev/null +++ b/web/src/assets/svg/business/fanwendengji.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/feizhengshiwendengji.svg b/web/src/assets/svg/business/feizhengshiwendengji.svg new file mode 100644 index 00000000..632f9277 --- /dev/null +++ b/web/src/assets/svg/business/feizhengshiwendengji.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/gongwenjiaohuan.svg b/web/src/assets/svg/business/gongwenjiaohuan.svg new file mode 100644 index 00000000..f7f14c57 --- /dev/null +++ b/web/src/assets/svg/business/gongwenjiaohuan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/gongzuohuibao.svg b/web/src/assets/svg/business/gongzuohuibao.svg new file mode 100644 index 00000000..3bab8229 --- /dev/null +++ b/web/src/assets/svg/business/gongzuohuibao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/gudingzichan.svg b/web/src/assets/svg/business/gudingzichan.svg new file mode 100644 index 00000000..57613ae5 --- /dev/null +++ b/web/src/assets/svg/business/gudingzichan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/huiyiguanli.svg b/web/src/assets/svg/business/huiyiguanli.svg new file mode 100644 index 00000000..2af78dfd --- /dev/null +++ b/web/src/assets/svg/business/huiyiguanli.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/huiyiyuding.svg b/web/src/assets/svg/business/huiyiyuding.svg new file mode 100644 index 00000000..cc09cc4c --- /dev/null +++ b/web/src/assets/svg/business/huiyiyuding.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/kaoqinguanli.svg b/web/src/assets/svg/business/kaoqinguanli.svg new file mode 100644 index 00000000..719d3a64 --- /dev/null +++ b/web/src/assets/svg/business/kaoqinguanli.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/qingxiujiashenqing.svg b/web/src/assets/svg/business/qingxiujiashenqing.svg new file mode 100644 index 00000000..d4abc1e1 --- /dev/null +++ b/web/src/assets/svg/business/qingxiujiashenqing.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/sannianjihua.svg b/web/src/assets/svg/business/sannianjihua.svg new file mode 100644 index 00000000..51155dc1 --- /dev/null +++ b/web/src/assets/svg/business/sannianjihua.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/tongzhifabu.svg b/web/src/assets/svg/business/tongzhifabu.svg new file mode 100644 index 00000000..33ab042a --- /dev/null +++ b/web/src/assets/svg/business/tongzhifabu.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/xiangmuguanli.svg b/web/src/assets/svg/business/xiangmuguanli.svg new file mode 100644 index 00000000..e6bb522b --- /dev/null +++ b/web/src/assets/svg/business/xiangmuguanli.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/xinxitougao.svg b/web/src/assets/svg/business/xinxitougao.svg new file mode 100644 index 00000000..b7d79eff --- /dev/null +++ b/web/src/assets/svg/business/xinxitougao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/zhishichanquan.svg b/web/src/assets/svg/business/zhishichanquan.svg new file mode 100644 index 00000000..8c00607c --- /dev/null +++ b/web/src/assets/svg/business/zhishichanquan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/zhongxindongtaifabu.svg b/web/src/assets/svg/business/zhongxindongtaifabu.svg new file mode 100644 index 00000000..c8d37c53 --- /dev/null +++ b/web/src/assets/svg/business/zhongxindongtaifabu.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/zongheshenpi.svg b/web/src/assets/svg/business/zongheshenpi.svg new file mode 100644 index 00000000..de280863 --- /dev/null +++ b/web/src/assets/svg/business/zongheshenpi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/business/商务 b/web/src/assets/svg/business/商务 new file mode 100644 index 00000000..e69de29b diff --git a/web/src/assets/svg/education/DNA.svg b/web/src/assets/svg/education/DNA.svg new file mode 100644 index 00000000..2037d53d --- /dev/null +++ b/web/src/assets/svg/education/DNA.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-1-shilibiao.svg b/web/src/assets/svg/education/a-1-shilibiao.svg new file mode 100644 index 00000000..682ab627 --- /dev/null +++ b/web/src/assets/svg/education/a-1-shilibiao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-10-yiliaoxiang.svg b/web/src/assets/svg/education/a-10-yiliaoxiang.svg new file mode 100644 index 00000000..51e11862 --- /dev/null +++ b/web/src/assets/svg/education/a-10-yiliaoxiang.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-11-yiyongweishengzhi.svg b/web/src/assets/svg/education/a-11-yiyongweishengzhi.svg new file mode 100644 index 00000000..34cb782e --- /dev/null +++ b/web/src/assets/svg/education/a-11-yiyongweishengzhi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-12-huxi.svg b/web/src/assets/svg/education/a-12-huxi.svg new file mode 100644 index 00000000..0ca0dc47 --- /dev/null +++ b/web/src/assets/svg/education/a-12-huxi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-13-xiguan.svg b/web/src/assets/svg/education/a-13-xiguan.svg new file mode 100644 index 00000000..4f41df0f --- /dev/null +++ b/web/src/assets/svg/education/a-13-xiguan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-14-zhutingqi.svg b/web/src/assets/svg/education/a-14-zhutingqi.svg new file mode 100644 index 00000000..fd117857 --- /dev/null +++ b/web/src/assets/svg/education/a-14-zhutingqi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-15-bingdu.svg b/web/src/assets/svg/education/a-15-bingdu.svg new file mode 100644 index 00000000..0bd3f3d1 --- /dev/null +++ b/web/src/assets/svg/education/a-15-bingdu.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-16-yiyuan.svg b/web/src/assets/svg/education/a-16-yiyuan.svg new file mode 100644 index 00000000..aa4f1d7a --- /dev/null +++ b/web/src/assets/svg/education/a-16-yiyuan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-17-zhusheqi.svg b/web/src/assets/svg/education/a-17-zhusheqi.svg new file mode 100644 index 00000000..4f1ffbc4 --- /dev/null +++ b/web/src/assets/svg/education/a-17-zhusheqi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-18-xiguan.svg b/web/src/assets/svg/education/a-18-xiguan.svg new file mode 100644 index 00000000..f1f98c7a --- /dev/null +++ b/web/src/assets/svg/education/a-18-xiguan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-19guaizhang.svg b/web/src/assets/svg/education/a-19guaizhang.svg new file mode 100644 index 00000000..f64bfbd7 --- /dev/null +++ b/web/src/assets/svg/education/a-19guaizhang.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-2-kouzhao.svg b/web/src/assets/svg/education/a-2-kouzhao.svg new file mode 100644 index 00000000..15c26a61 --- /dev/null +++ b/web/src/assets/svg/education/a-2-kouzhao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-20-shuye.svg b/web/src/assets/svg/education/a-20-shuye.svg new file mode 100644 index 00000000..7a3403b0 --- /dev/null +++ b/web/src/assets/svg/education/a-20-shuye.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-3-chuangkoutie.svg b/web/src/assets/svg/education/a-3-chuangkoutie.svg new file mode 100644 index 00000000..3cbdb6e7 --- /dev/null +++ b/web/src/assets/svg/education/a-3-chuangkoutie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-4-lunyi.svg b/web/src/assets/svg/education/a-4-lunyi.svg new file mode 100644 index 00000000..4c401e9f --- /dev/null +++ b/web/src/assets/svg/education/a-4-lunyi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-5-mianqian.svg b/web/src/assets/svg/education/a-5-mianqian.svg new file mode 100644 index 00000000..70028091 --- /dev/null +++ b/web/src/assets/svg/education/a-5-mianqian.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-6-jiancebi.svg b/web/src/assets/svg/education/a-6-jiancebi.svg new file mode 100644 index 00000000..599ae63e --- /dev/null +++ b/web/src/assets/svg/education/a-6-jiancebi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-7-xinzang.svg b/web/src/assets/svg/education/a-7-xinzang.svg new file mode 100644 index 00000000..962d8e3d --- /dev/null +++ b/web/src/assets/svg/education/a-7-xinzang.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-8-DNA.svg b/web/src/assets/svg/education/a-8-DNA.svg new file mode 100644 index 00000000..2cef90f2 --- /dev/null +++ b/web/src/assets/svg/education/a-8-DNA.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-9-tizhongcheng.svg b/web/src/assets/svg/education/a-9-tizhongcheng.svg new file mode 100644 index 00000000..fcb25b70 --- /dev/null +++ b/web/src/assets/svg/education/a-9-tizhongcheng.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-bitong1.svg b/web/src/assets/svg/education/a-bitong1.svg new file mode 100644 index 00000000..a611cf35 --- /dev/null +++ b/web/src/assets/svg/education/a-bitong1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-shu2.svg b/web/src/assets/svg/education/a-shu2.svg new file mode 100644 index 00000000..f8a272b5 --- /dev/null +++ b/web/src/assets/svg/education/a-shu2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-shu4.svg b/web/src/assets/svg/education/a-shu4.svg new file mode 100644 index 00000000..a8a8e67c --- /dev/null +++ b/web/src/assets/svg/education/a-shu4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-shu5.svg b/web/src/assets/svg/education/a-shu5.svg new file mode 100644 index 00000000..104124d2 --- /dev/null +++ b/web/src/assets/svg/education/a-shu5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-shuben2.svg b/web/src/assets/svg/education/a-shuben2.svg new file mode 100644 index 00000000..52bb1749 --- /dev/null +++ b/web/src/assets/svg/education/a-shuben2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-shuben3.svg b/web/src/assets/svg/education/a-shuben3.svg new file mode 100644 index 00000000..f7cef20d --- /dev/null +++ b/web/src/assets/svg/education/a-shuben3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-shuben4.svg b/web/src/assets/svg/education/a-shuben4.svg new file mode 100644 index 00000000..bd0bcec0 --- /dev/null +++ b/web/src/assets/svg/education/a-shuben4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/a-xueshimao1.svg b/web/src/assets/svg/education/a-xueshimao1.svg new file mode 100644 index 00000000..622b3511 --- /dev/null +++ b/web/src/assets/svg/education/a-xueshimao1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/baichui.svg b/web/src/assets/svg/education/baichui.svg new file mode 100644 index 00000000..036ae9fe --- /dev/null +++ b/web/src/assets/svg/education/baichui.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/bijiben.svg b/web/src/assets/svg/education/bijiben.svg new file mode 100644 index 00000000..0859802f --- /dev/null +++ b/web/src/assets/svg/education/bijiben.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/bitong.svg b/web/src/assets/svg/education/bitong.svg new file mode 100644 index 00000000..85d7bbb1 --- /dev/null +++ b/web/src/assets/svg/education/bitong.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/chizi.svg b/web/src/assets/svg/education/chizi.svg new file mode 100644 index 00000000..32b95a0d --- /dev/null +++ b/web/src/assets/svg/education/chizi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/chongdian.svg b/web/src/assets/svg/education/chongdian.svg new file mode 100644 index 00000000..2839d2d2 --- /dev/null +++ b/web/src/assets/svg/education/chongdian.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/citie.svg b/web/src/assets/svg/education/citie.svg new file mode 100644 index 00000000..bf322cf8 --- /dev/null +++ b/web/src/assets/svg/education/citie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/daima.svg b/web/src/assets/svg/education/daima.svg new file mode 100644 index 00000000..3adca80a --- /dev/null +++ b/web/src/assets/svg/education/daima.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/deng.svg b/web/src/assets/svg/education/deng.svg new file mode 100644 index 00000000..31f31223 --- /dev/null +++ b/web/src/assets/svg/education/deng.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/dianliushiyan.svg b/web/src/assets/svg/education/dianliushiyan.svg new file mode 100644 index 00000000..29c39475 --- /dev/null +++ b/web/src/assets/svg/education/dianliushiyan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/diqiu.svg b/web/src/assets/svg/education/diqiu.svg new file mode 100644 index 00000000..50c3d345 --- /dev/null +++ b/web/src/assets/svg/education/diqiu.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/diqiuyi.svg b/web/src/assets/svg/education/diqiuyi.svg new file mode 100644 index 00000000..e4f59750 --- /dev/null +++ b/web/src/assets/svg/education/diqiuyi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/fanyi.svg b/web/src/assets/svg/education/fanyi.svg new file mode 100644 index 00000000..fd1de51b --- /dev/null +++ b/web/src/assets/svg/education/fanyi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/gongwenbao.svg b/web/src/assets/svg/education/gongwenbao.svg new file mode 100644 index 00000000..1a0d104d --- /dev/null +++ b/web/src/assets/svg/education/gongwenbao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/heiban.svg b/web/src/assets/svg/education/heiban.svg new file mode 100644 index 00000000..b6526615 --- /dev/null +++ b/web/src/assets/svg/education/heiban.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/huiyi.svg b/web/src/assets/svg/education/huiyi.svg new file mode 100644 index 00000000..b83a3152 --- /dev/null +++ b/web/src/assets/svg/education/huiyi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/jiangbei.svg b/web/src/assets/svg/education/jiangbei.svg new file mode 100644 index 00000000..15b25754 --- /dev/null +++ b/web/src/assets/svg/education/jiangbei.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/jiaoxuelou.svg b/web/src/assets/svg/education/jiaoxuelou.svg new file mode 100644 index 00000000..e9433392 --- /dev/null +++ b/web/src/assets/svg/education/jiaoxuelou.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/jinpai.svg b/web/src/assets/svg/education/jinpai.svg new file mode 100644 index 00000000..dd07c1e0 --- /dev/null +++ b/web/src/assets/svg/education/jinpai.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/jisuan.svg b/web/src/assets/svg/education/jisuan.svg new file mode 100644 index 00000000..388e1316 --- /dev/null +++ b/web/src/assets/svg/education/jisuan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/jisuanqi.svg b/web/src/assets/svg/education/jisuanqi.svg new file mode 100644 index 00000000..455bc7c2 --- /dev/null +++ b/web/src/assets/svg/education/jisuanqi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/naozhong.svg b/web/src/assets/svg/education/naozhong.svg new file mode 100644 index 00000000..0901e9ed --- /dev/null +++ b/web/src/assets/svg/education/naozhong.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/qianbi.svg b/web/src/assets/svg/education/qianbi.svg new file mode 100644 index 00000000..11926c76 --- /dev/null +++ b/web/src/assets/svg/education/qianbi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/sepan.svg b/web/src/assets/svg/education/sepan.svg new file mode 100644 index 00000000..a99429fc --- /dev/null +++ b/web/src/assets/svg/education/sepan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/shiyan.svg b/web/src/assets/svg/education/shiyan.svg new file mode 100644 index 00000000..691625db --- /dev/null +++ b/web/src/assets/svg/education/shiyan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/shouji.svg b/web/src/assets/svg/education/shouji.svg new file mode 100644 index 00000000..99315966 --- /dev/null +++ b/web/src/assets/svg/education/shouji.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/shuben.svg b/web/src/assets/svg/education/shuben.svg new file mode 100644 index 00000000..2e00a4b5 --- /dev/null +++ b/web/src/assets/svg/education/shuben.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/shuxie.svg b/web/src/assets/svg/education/shuxie.svg new file mode 100644 index 00000000..99eb780e --- /dev/null +++ b/web/src/assets/svg/education/shuxie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/sousuo.svg b/web/src/assets/svg/education/sousuo.svg new file mode 100644 index 00000000..196d9674 --- /dev/null +++ b/web/src/assets/svg/education/sousuo.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/suanpan.svg b/web/src/assets/svg/education/suanpan.svg new file mode 100644 index 00000000..3bdacb5f --- /dev/null +++ b/web/src/assets/svg/education/suanpan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/tianping.svg b/web/src/assets/svg/education/tianping.svg new file mode 100644 index 00000000..42ed4fd8 --- /dev/null +++ b/web/src/assets/svg/education/tianping.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/tingzhenqi.svg b/web/src/assets/svg/education/tingzhenqi.svg new file mode 100644 index 00000000..ec166193 --- /dev/null +++ b/web/src/assets/svg/education/tingzhenqi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/tiyu.svg b/web/src/assets/svg/education/tiyu.svg new file mode 100644 index 00000000..d24aba2b --- /dev/null +++ b/web/src/assets/svg/education/tiyu.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/wenjian.svg b/web/src/assets/svg/education/wenjian.svg new file mode 100644 index 00000000..3cf32e0c --- /dev/null +++ b/web/src/assets/svg/education/wenjian.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/xianweijing.svg b/web/src/assets/svg/education/xianweijing.svg new file mode 100644 index 00000000..aa5ffd1d --- /dev/null +++ b/web/src/assets/svg/education/xianweijing.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/xiaoheiban.svg b/web/src/assets/svg/education/xiaoheiban.svg new file mode 100644 index 00000000..a4984acd --- /dev/null +++ b/web/src/assets/svg/education/xiaoheiban.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/xiezizhuo.svg b/web/src/assets/svg/education/xiezizhuo.svg new file mode 100644 index 00000000..f0b044d4 --- /dev/null +++ b/web/src/assets/svg/education/xiezizhuo.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/xueshimao.svg b/web/src/assets/svg/education/xueshimao.svg new file mode 100644 index 00000000..b8bd58bb --- /dev/null +++ b/web/src/assets/svg/education/xueshimao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/yuanpan.svg b/web/src/assets/svg/education/yuanpan.svg new file mode 100644 index 00000000..0674e526 --- /dev/null +++ b/web/src/assets/svg/education/yuanpan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/education/教育 b/web/src/assets/svg/education/教育 new file mode 100644 index 00000000..e69de29b diff --git a/web/src/assets/svg/festival/celianggongju.svg b/web/src/assets/svg/festival/celianggongju.svg new file mode 100644 index 00000000..3a077a11 --- /dev/null +++ b/web/src/assets/svg/festival/celianggongju.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/chunjie.svg b/web/src/assets/svg/festival/chunjie.svg new file mode 100644 index 00000000..6c031f3b --- /dev/null +++ b/web/src/assets/svg/festival/chunjie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/duanwujie.svg b/web/src/assets/svg/festival/duanwujie.svg new file mode 100644 index 00000000..b2cf2877 --- /dev/null +++ b/web/src/assets/svg/festival/duanwujie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/ertongjie.svg b/web/src/assets/svg/festival/ertongjie.svg new file mode 100644 index 00000000..604b2e0c --- /dev/null +++ b/web/src/assets/svg/festival/ertongjie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/fuqinjie.svg b/web/src/assets/svg/festival/fuqinjie.svg new file mode 100644 index 00000000..ec59a88b --- /dev/null +++ b/web/src/assets/svg/festival/fuqinjie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/ganenjie.svg b/web/src/assets/svg/festival/ganenjie.svg new file mode 100644 index 00000000..bbbc0e45 --- /dev/null +++ b/web/src/assets/svg/festival/ganenjie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/gongju.svg b/web/src/assets/svg/festival/gongju.svg new file mode 100644 index 00000000..2fba67a7 --- /dev/null +++ b/web/src/assets/svg/festival/gongju.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/hushijie.svg b/web/src/assets/svg/festival/hushijie.svg new file mode 100644 index 00000000..967206ee --- /dev/null +++ b/web/src/assets/svg/festival/hushijie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/jiaoshijie.svg b/web/src/assets/svg/festival/jiaoshijie.svg new file mode 100644 index 00000000..eb73ba0d --- /dev/null +++ b/web/src/assets/svg/festival/jiaoshijie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/laodongjie.svg b/web/src/assets/svg/festival/laodongjie.svg new file mode 100644 index 00000000..1494219f --- /dev/null +++ b/web/src/assets/svg/festival/laodongjie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/muqinjie.svg b/web/src/assets/svg/festival/muqinjie.svg new file mode 100644 index 00000000..031932e1 --- /dev/null +++ b/web/src/assets/svg/festival/muqinjie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/nvshengjie.svg b/web/src/assets/svg/festival/nvshengjie.svg new file mode 100644 index 00000000..e876962a --- /dev/null +++ b/web/src/assets/svg/festival/nvshengjie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/qingrenjie.svg b/web/src/assets/svg/festival/qingrenjie.svg new file mode 100644 index 00000000..b43b8e34 --- /dev/null +++ b/web/src/assets/svg/festival/qingrenjie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/qixi.svg b/web/src/assets/svg/festival/qixi.svg new file mode 100644 index 00000000..8c03aaaf --- /dev/null +++ b/web/src/assets/svg/festival/qixi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/shengdanjie.svg b/web/src/assets/svg/festival/shengdanjie.svg new file mode 100644 index 00000000..6c3f7354 --- /dev/null +++ b/web/src/assets/svg/festival/shengdanjie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/shuang.svg b/web/src/assets/svg/festival/shuang.svg new file mode 100644 index 00000000..d55927f4 --- /dev/null +++ b/web/src/assets/svg/festival/shuang.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/yuandan.svg b/web/src/assets/svg/festival/yuandan.svg new file mode 100644 index 00000000..dc16a3ec --- /dev/null +++ b/web/src/assets/svg/festival/yuandan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/yuanxiaojie.svg b/web/src/assets/svg/festival/yuanxiaojie.svg new file mode 100644 index 00000000..7dfacade --- /dev/null +++ b/web/src/assets/svg/festival/yuanxiaojie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/zhongqiujie.svg b/web/src/assets/svg/festival/zhongqiujie.svg new file mode 100644 index 00000000..23768942 --- /dev/null +++ b/web/src/assets/svg/festival/zhongqiujie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/zhongyangjie.svg b/web/src/assets/svg/festival/zhongyangjie.svg new file mode 100644 index 00000000..623717cc --- /dev/null +++ b/web/src/assets/svg/festival/zhongyangjie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/festival/节日 b/web/src/assets/svg/festival/节日 new file mode 100644 index 00000000..e69de29b diff --git a/web/src/assets/svg/food/binggan.svg b/web/src/assets/svg/food/binggan.svg new file mode 100644 index 00000000..32e0d9e9 --- /dev/null +++ b/web/src/assets/svg/food/binggan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/binggun.svg b/web/src/assets/svg/food/binggun.svg new file mode 100644 index 00000000..c260d5e1 --- /dev/null +++ b/web/src/assets/svg/food/binggun.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/bingqilin.svg b/web/src/assets/svg/food/bingqilin.svg new file mode 100644 index 00000000..705a2594 --- /dev/null +++ b/web/src/assets/svg/food/bingqilin.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/boluo.svg b/web/src/assets/svg/food/boluo.svg new file mode 100644 index 00000000..85e70441 --- /dev/null +++ b/web/src/assets/svg/food/boluo.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/caomei.svg b/web/src/assets/svg/food/caomei.svg new file mode 100644 index 00000000..9b601805 --- /dev/null +++ b/web/src/assets/svg/food/caomei.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/celianggongju.svg b/web/src/assets/svg/food/celianggongju.svg new file mode 100644 index 00000000..3a077a11 --- /dev/null +++ b/web/src/assets/svg/food/celianggongju.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/chengzi.svg b/web/src/assets/svg/food/chengzi.svg new file mode 100644 index 00000000..5f0d0a5a --- /dev/null +++ b/web/src/assets/svg/food/chengzi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/dangao.svg b/web/src/assets/svg/food/dangao.svg new file mode 100644 index 00000000..43b3258e --- /dev/null +++ b/web/src/assets/svg/food/dangao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/fanqiejiang.svg b/web/src/assets/svg/food/fanqiejiang.svg new file mode 100644 index 00000000..c756531b --- /dev/null +++ b/web/src/assets/svg/food/fanqiejiang.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/gongju.svg b/web/src/assets/svg/food/gongju.svg new file mode 100644 index 00000000..2fba67a7 --- /dev/null +++ b/web/src/assets/svg/food/gongju.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/hanbao.svg b/web/src/assets/svg/food/hanbao.svg new file mode 100644 index 00000000..6300b0ca --- /dev/null +++ b/web/src/assets/svg/food/hanbao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/jiandan.svg b/web/src/assets/svg/food/jiandan.svg new file mode 100644 index 00000000..073dd55b --- /dev/null +++ b/web/src/assets/svg/food/jiandan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/kafeibei.svg b/web/src/assets/svg/food/kafeibei.svg new file mode 100644 index 00000000..87fb290d --- /dev/null +++ b/web/src/assets/svg/food/kafeibei.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/lajiao.svg b/web/src/assets/svg/food/lajiao.svg new file mode 100644 index 00000000..e6cc34db --- /dev/null +++ b/web/src/assets/svg/food/lajiao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/naixi.svg b/web/src/assets/svg/food/naixi.svg new file mode 100644 index 00000000..5443f8a2 --- /dev/null +++ b/web/src/assets/svg/food/naixi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/niunai.svg b/web/src/assets/svg/food/niunai.svg new file mode 100644 index 00000000..dc3e6300 --- /dev/null +++ b/web/src/assets/svg/food/niunai.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/pingguo.svg b/web/src/assets/svg/food/pingguo.svg new file mode 100644 index 00000000..3584aab5 --- /dev/null +++ b/web/src/assets/svg/food/pingguo.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/pisa.svg b/web/src/assets/svg/food/pisa.svg new file mode 100644 index 00000000..f70c5218 --- /dev/null +++ b/web/src/assets/svg/food/pisa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/putao.svg b/web/src/assets/svg/food/putao.svg new file mode 100644 index 00000000..034c01ae --- /dev/null +++ b/web/src/assets/svg/food/putao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/quqi.svg b/web/src/assets/svg/food/quqi.svg new file mode 100644 index 00000000..8021ea3b --- /dev/null +++ b/web/src/assets/svg/food/quqi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/regou.svg b/web/src/assets/svg/food/regou.svg new file mode 100644 index 00000000..87bcce31 --- /dev/null +++ b/web/src/assets/svg/food/regou.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/shutiao.svg b/web/src/assets/svg/food/shutiao.svg new file mode 100644 index 00000000..d20a47e8 --- /dev/null +++ b/web/src/assets/svg/food/shutiao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/sudaqishui.svg b/web/src/assets/svg/food/sudaqishui.svg new file mode 100644 index 00000000..9d78ae3f --- /dev/null +++ b/web/src/assets/svg/food/sudaqishui.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/taozi.svg b/web/src/assets/svg/food/taozi.svg new file mode 100644 index 00000000..5c1f4353 --- /dev/null +++ b/web/src/assets/svg/food/taozi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/tiantianquan.svg b/web/src/assets/svg/food/tiantianquan.svg new file mode 100644 index 00000000..cd82d7b4 --- /dev/null +++ b/web/src/assets/svg/food/tiantianquan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/xiangjiao.svg b/web/src/assets/svg/food/xiangjiao.svg new file mode 100644 index 00000000..e667982a --- /dev/null +++ b/web/src/assets/svg/food/xiangjiao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/xigua.svg b/web/src/assets/svg/food/xigua.svg new file mode 100644 index 00000000..c98bee41 --- /dev/null +++ b/web/src/assets/svg/food/xigua.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/xilanhua.svg b/web/src/assets/svg/food/xilanhua.svg new file mode 100644 index 00000000..5d73b2be --- /dev/null +++ b/web/src/assets/svg/food/xilanhua.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/yingtao.svg b/web/src/assets/svg/food/yingtao.svg new file mode 100644 index 00000000..b3574f14 --- /dev/null +++ b/web/src/assets/svg/food/yingtao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/yumi.svg b/web/src/assets/svg/food/yumi.svg new file mode 100644 index 00000000..bc66ee26 --- /dev/null +++ b/web/src/assets/svg/food/yumi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/food/食物 b/web/src/assets/svg/food/食物 new file mode 100644 index 00000000..e69de29b diff --git a/web/src/assets/svg/medicine/a-1-shilibiao.svg b/web/src/assets/svg/medicine/a-1-shilibiao.svg new file mode 100644 index 00000000..682ab627 --- /dev/null +++ b/web/src/assets/svg/medicine/a-1-shilibiao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-10-yiliaoxiang.svg b/web/src/assets/svg/medicine/a-10-yiliaoxiang.svg new file mode 100644 index 00000000..51e11862 --- /dev/null +++ b/web/src/assets/svg/medicine/a-10-yiliaoxiang.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-11-yiyongweishengzhi.svg b/web/src/assets/svg/medicine/a-11-yiyongweishengzhi.svg new file mode 100644 index 00000000..34cb782e --- /dev/null +++ b/web/src/assets/svg/medicine/a-11-yiyongweishengzhi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-12-huxi.svg b/web/src/assets/svg/medicine/a-12-huxi.svg new file mode 100644 index 00000000..0ca0dc47 --- /dev/null +++ b/web/src/assets/svg/medicine/a-12-huxi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-13-xiguan.svg b/web/src/assets/svg/medicine/a-13-xiguan.svg new file mode 100644 index 00000000..4f41df0f --- /dev/null +++ b/web/src/assets/svg/medicine/a-13-xiguan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-14-zhutingqi.svg b/web/src/assets/svg/medicine/a-14-zhutingqi.svg new file mode 100644 index 00000000..fd117857 --- /dev/null +++ b/web/src/assets/svg/medicine/a-14-zhutingqi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-15-bingdu.svg b/web/src/assets/svg/medicine/a-15-bingdu.svg new file mode 100644 index 00000000..0bd3f3d1 --- /dev/null +++ b/web/src/assets/svg/medicine/a-15-bingdu.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-16-yiyuan.svg b/web/src/assets/svg/medicine/a-16-yiyuan.svg new file mode 100644 index 00000000..aa4f1d7a --- /dev/null +++ b/web/src/assets/svg/medicine/a-16-yiyuan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-17-zhusheqi.svg b/web/src/assets/svg/medicine/a-17-zhusheqi.svg new file mode 100644 index 00000000..4f1ffbc4 --- /dev/null +++ b/web/src/assets/svg/medicine/a-17-zhusheqi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-18-xiguan.svg b/web/src/assets/svg/medicine/a-18-xiguan.svg new file mode 100644 index 00000000..f1f98c7a --- /dev/null +++ b/web/src/assets/svg/medicine/a-18-xiguan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-19guaizhang.svg b/web/src/assets/svg/medicine/a-19guaizhang.svg new file mode 100644 index 00000000..f64bfbd7 --- /dev/null +++ b/web/src/assets/svg/medicine/a-19guaizhang.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-2-kouzhao.svg b/web/src/assets/svg/medicine/a-2-kouzhao.svg new file mode 100644 index 00000000..15c26a61 --- /dev/null +++ b/web/src/assets/svg/medicine/a-2-kouzhao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-20-shuye.svg b/web/src/assets/svg/medicine/a-20-shuye.svg new file mode 100644 index 00000000..7a3403b0 --- /dev/null +++ b/web/src/assets/svg/medicine/a-20-shuye.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-3-chuangkoutie.svg b/web/src/assets/svg/medicine/a-3-chuangkoutie.svg new file mode 100644 index 00000000..3cbdb6e7 --- /dev/null +++ b/web/src/assets/svg/medicine/a-3-chuangkoutie.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-4-lunyi.svg b/web/src/assets/svg/medicine/a-4-lunyi.svg new file mode 100644 index 00000000..4c401e9f --- /dev/null +++ b/web/src/assets/svg/medicine/a-4-lunyi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-5-mianqian.svg b/web/src/assets/svg/medicine/a-5-mianqian.svg new file mode 100644 index 00000000..70028091 --- /dev/null +++ b/web/src/assets/svg/medicine/a-5-mianqian.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-6-jiancebi.svg b/web/src/assets/svg/medicine/a-6-jiancebi.svg new file mode 100644 index 00000000..599ae63e --- /dev/null +++ b/web/src/assets/svg/medicine/a-6-jiancebi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-7-xinzang.svg b/web/src/assets/svg/medicine/a-7-xinzang.svg new file mode 100644 index 00000000..962d8e3d --- /dev/null +++ b/web/src/assets/svg/medicine/a-7-xinzang.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-8-DNA.svg b/web/src/assets/svg/medicine/a-8-DNA.svg new file mode 100644 index 00000000..2cef90f2 --- /dev/null +++ b/web/src/assets/svg/medicine/a-8-DNA.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/a-9-tizhongcheng.svg b/web/src/assets/svg/medicine/a-9-tizhongcheng.svg new file mode 100644 index 00000000..fcb25b70 --- /dev/null +++ b/web/src/assets/svg/medicine/a-9-tizhongcheng.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/medicine/医疗 b/web/src/assets/svg/medicine/医疗 new file mode 100644 index 00000000..e69de29b diff --git a/web/src/assets/svg/tools/gaizhui.svg b/web/src/assets/svg/tools/gaizhui.svg new file mode 100644 index 00000000..bae28c56 --- /dev/null +++ b/web/src/assets/svg/tools/gaizhui.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan.svg b/web/src/assets/svg/tools/ziyuan.svg new file mode 100644 index 00000000..86c6f891 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_1.svg b/web/src/assets/svg/tools/ziyuan_1.svg new file mode 100644 index 00000000..e8081cd2 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_10.svg b/web/src/assets/svg/tools/ziyuan_10.svg new file mode 100644 index 00000000..bb88c9b3 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_10.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_11.svg b/web/src/assets/svg/tools/ziyuan_11.svg new file mode 100644 index 00000000..9a7ff4e5 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_11.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_12.svg b/web/src/assets/svg/tools/ziyuan_12.svg new file mode 100644 index 00000000..2cb20b21 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_12.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_13.svg b/web/src/assets/svg/tools/ziyuan_13.svg new file mode 100644 index 00000000..6428c970 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_13.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_14.svg b/web/src/assets/svg/tools/ziyuan_14.svg new file mode 100644 index 00000000..dfe47e60 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_14.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_15.svg b/web/src/assets/svg/tools/ziyuan_15.svg new file mode 100644 index 00000000..4ed27737 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_15.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_16.svg b/web/src/assets/svg/tools/ziyuan_16.svg new file mode 100644 index 00000000..c1af7e5a --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_16.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_17.svg b/web/src/assets/svg/tools/ziyuan_17.svg new file mode 100644 index 00000000..0c3af499 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_17.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_18.svg b/web/src/assets/svg/tools/ziyuan_18.svg new file mode 100644 index 00000000..98983ab0 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_18.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_2.svg b/web/src/assets/svg/tools/ziyuan_2.svg new file mode 100644 index 00000000..4b79c303 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_3.svg b/web/src/assets/svg/tools/ziyuan_3.svg new file mode 100644 index 00000000..aa609adc --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_4.svg b/web/src/assets/svg/tools/ziyuan_4.svg new file mode 100644 index 00000000..bffbad4d --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_5.svg b/web/src/assets/svg/tools/ziyuan_5.svg new file mode 100644 index 00000000..72d8f4c3 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_6.svg b/web/src/assets/svg/tools/ziyuan_6.svg new file mode 100644 index 00000000..d5d13d5d --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_7.svg b/web/src/assets/svg/tools/ziyuan_7.svg new file mode 100644 index 00000000..4dcbef5a --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_8.svg b/web/src/assets/svg/tools/ziyuan_8.svg new file mode 100644 index 00000000..d00334f0 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/ziyuan_9.svg b/web/src/assets/svg/tools/ziyuan_9.svg new file mode 100644 index 00000000..e0e9e1e5 --- /dev/null +++ b/web/src/assets/svg/tools/ziyuan_9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/tools/工具 b/web/src/assets/svg/tools/工具 new file mode 100644 index 00000000..e69de29b diff --git a/web/src/assets/svg/travel/banshouli.svg b/web/src/assets/svg/travel/banshouli.svg new file mode 100644 index 00000000..11eb4419 --- /dev/null +++ b/web/src/assets/svg/travel/banshouli.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/chuhangshijian.svg b/web/src/assets/svg/travel/chuhangshijian.svg new file mode 100644 index 00000000..fd0ab6f5 --- /dev/null +++ b/web/src/assets/svg/travel/chuhangshijian.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/ditu.svg b/web/src/assets/svg/travel/ditu.svg new file mode 100644 index 00000000..7af7852c --- /dev/null +++ b/web/src/assets/svg/travel/ditu.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/fengjing.svg b/web/src/assets/svg/travel/fengjing.svg new file mode 100644 index 00000000..1e39d138 --- /dev/null +++ b/web/src/assets/svg/travel/fengjing.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/gonglve.svg b/web/src/assets/svg/travel/gonglve.svg new file mode 100644 index 00000000..b1b72d65 --- /dev/null +++ b/web/src/assets/svg/travel/gonglve.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/hangli.svg b/web/src/assets/svg/travel/hangli.svg new file mode 100644 index 00000000..c991f897 --- /dev/null +++ b/web/src/assets/svg/travel/hangli.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/huafei.svg b/web/src/assets/svg/travel/huafei.svg new file mode 100644 index 00000000..de9c9f33 --- /dev/null +++ b/web/src/assets/svg/travel/huafei.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/jipiao.svg b/web/src/assets/svg/travel/jipiao.svg new file mode 100644 index 00000000..2ac1c496 --- /dev/null +++ b/web/src/assets/svg/travel/jipiao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/jiudian.svg b/web/src/assets/svg/travel/jiudian.svg new file mode 100644 index 00000000..90fc62be --- /dev/null +++ b/web/src/assets/svg/travel/jiudian.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/lvban.svg b/web/src/assets/svg/travel/lvban.svg new file mode 100644 index 00000000..e70d2235 --- /dev/null +++ b/web/src/assets/svg/travel/lvban.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/meishi.svg b/web/src/assets/svg/travel/meishi.svg new file mode 100644 index 00000000..eea9914b --- /dev/null +++ b/web/src/assets/svg/travel/meishi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/menpiao.svg b/web/src/assets/svg/travel/menpiao.svg new file mode 100644 index 00000000..e9827748 --- /dev/null +++ b/web/src/assets/svg/travel/menpiao.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/paishe.svg b/web/src/assets/svg/travel/paishe.svg new file mode 100644 index 00000000..21cae9e9 --- /dev/null +++ b/web/src/assets/svg/travel/paishe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/qianzheng.svg b/web/src/assets/svg/travel/qianzheng.svg new file mode 100644 index 00000000..b25343fa --- /dev/null +++ b/web/src/assets/svg/travel/qianzheng.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/shangdian.svg b/web/src/assets/svg/travel/shangdian.svg new file mode 100644 index 00000000..9611b473 --- /dev/null +++ b/web/src/assets/svg/travel/shangdian.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/tianqi.svg b/web/src/assets/svg/travel/tianqi.svg new file mode 100644 index 00000000..a7eee081 --- /dev/null +++ b/web/src/assets/svg/travel/tianqi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/youlechangsuo.svg b/web/src/assets/svg/travel/youlechangsuo.svg new file mode 100644 index 00000000..faeb39d8 --- /dev/null +++ b/web/src/assets/svg/travel/youlechangsuo.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/yuyanfanyi.svg b/web/src/assets/svg/travel/yuyanfanyi.svg new file mode 100644 index 00000000..3206a9d3 --- /dev/null +++ b/web/src/assets/svg/travel/yuyanfanyi.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/zhuyishixiang.svg b/web/src/assets/svg/travel/zhuyishixiang.svg new file mode 100644 index 00000000..f71e648a --- /dev/null +++ b/web/src/assets/svg/travel/zhuyishixiang.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/zuche.svg b/web/src/assets/svg/travel/zuche.svg new file mode 100644 index 00000000..306ec6b7 --- /dev/null +++ b/web/src/assets/svg/travel/zuche.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/web/src/assets/svg/travel/旅行 b/web/src/assets/svg/travel/旅行 new file mode 100644 index 00000000..e69de29b diff --git a/web/src/config/constant.js b/web/src/config/constant.js index 87e82c94..a2e0e0e7 100644 --- a/web/src/config/constant.js +++ b/web/src/config/constant.js @@ -44,5 +44,13 @@ export const themeMap = { autumn: require('../assets/img/autumn.jpg'), avocado: require('../assets/img/avocado.jpg'), orangeJuice: require('../assets/img/orangeJuice.jpg'), + oreo: require('../assets/img/oreo.jpg'), + shallowSea: require('../assets/img/shallowSea.jpg'), + lemonBubbles: require('../assets/img/lemonBubbles.jpg'), + rose: require('../assets/img/rose.jpg'), + seaBlueLine: require('../assets/img/seaBlueLine.jpg'), + neonLamp: require('../assets/img/neonLamp.jpg'), + darkNightLceBlade: require('../assets/img/darkNightLceBlade.jpg'), + morandi: require('../assets/img/morandi.jpg'), } \ No newline at end of file diff --git a/web/src/config/en.js b/web/src/config/en.js index 327da91a..97aa75d4 100644 --- a/web/src/config/en.js +++ b/web/src/config/en.js @@ -210,7 +210,7 @@ export const shortcutKeyList = [ { icon: 'icongaikuozonglan', name: 'Insert summary', - value: 'Ctrl + S' + value: 'Ctrl + G' }, { icon: 'iconzhankai', @@ -271,6 +271,11 @@ export const shortcutKeyList = [ icon: 'iconzhengli', name: 'Arrange layout', value: 'Ctrl + L' + }, + { + icon: 'iconsousuo', + name: 'Search and Replace', + value: 'Ctrl + F' } ] }, diff --git a/web/src/config/icon.js b/web/src/config/icon.js index 9d83a9df..4704486d 100644 --- a/web/src/config/icon.js +++ b/web/src/config/icon.js @@ -50,6 +50,83 @@ const iconList = [ '' ] +const weekdayList = [ + '', + '', + '', + '', + '', + '', + '', +] + +const avatarList = [ + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '' +] + +const starList = [ + '', + '', + '', + '', + '', + '', + '', + '' +] + +const flagList = [ + '', + '', + '', + '', + '', + '', + '', + '' +] + +const weatherList = [ + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '', + '' +] + export default [ { name: '多彩标记图标', // 分组名称 @@ -60,5 +137,55 @@ export default [ icon: item } }) + }, + { + name: '星期', // 分组名称 + type: 'weekday', // 分组的值 + list: weekdayList.map((item, index) => { + return { + name: String(index + 1), + icon: item + } + }) + }, + { + name: '头像', // 分组名称 + type: 'avatar', // 分组的值 + list: avatarList.map((item, index) => { + return { + name: String(index + 1), + icon: item + } + }) + }, + { + name: '五角星', // 分组名称 + type: 'star', // 分组的值 + list: starList.map((item, index) => { + return { + name: String(index + 1), + icon: item + } + }) + }, + { + name: '旗帜', // 分组名称 + type: 'flag', // 分组的值 + list: flagList.map((item, index) => { + return { + name: String(index + 1), + icon: item + } + }) + }, + { + name: '天气', // 分组名称 + type: 'weather', // 分组的值 + list: weatherList.map((item, index) => { + return { + name: String(index + 1), + icon: item + } + }) } ] diff --git a/web/src/config/image.js b/web/src/config/image.js new file mode 100644 index 00000000..5cd56da7 --- /dev/null +++ b/web/src/config/image.js @@ -0,0 +1,1329 @@ + +// 该文件请运行npm run createNodeImageList命令自动生成 +import business_ from '../assets/svg/business/-.svg' +import business__1 from '../assets/svg/business/-_1.svg' +import business__10 from '../assets/svg/business/-_10.svg' +import business__11 from '../assets/svg/business/-_11.svg' +import business__12 from '../assets/svg/business/-_12.svg' +import business__13 from '../assets/svg/business/-_13.svg' +import business__14 from '../assets/svg/business/-_14.svg' +import business__15 from '../assets/svg/business/-_15.svg' +import business__16 from '../assets/svg/business/-_16.svg' +import business__17 from '../assets/svg/business/-_17.svg' +import business__18 from '../assets/svg/business/-_18.svg' +import business__2 from '../assets/svg/business/-_2.svg' +import business__3 from '../assets/svg/business/-_3.svg' +import business__4 from '../assets/svg/business/-_4.svg' +import business__5 from '../assets/svg/business/-_5.svg' +import business__6 from '../assets/svg/business/-_6.svg' +import business__7 from '../assets/svg/business/-_7.svg' +import business__8 from '../assets/svg/business/-_8.svg' +import business__9 from '../assets/svg/business/-_9.svg' +import business_OAxitong from '../assets/svg/business/OAxitong.svg' +import business_changyongziyuan from '../assets/svg/business/changyongziyuan.svg' +import business_chuchashenpi from '../assets/svg/business/chuchashenpi.svg' +import business_fanwendengji from '../assets/svg/business/fanwendengji.svg' +import business_feizhengshiwendengji from '../assets/svg/business/feizhengshiwendengji.svg' +import business_gongwenjiaohuan from '../assets/svg/business/gongwenjiaohuan.svg' +import business_gongzuohuibao from '../assets/svg/business/gongzuohuibao.svg' +import business_gudingzichan from '../assets/svg/business/gudingzichan.svg' +import business_huiyiguanli from '../assets/svg/business/huiyiguanli.svg' +import business_huiyiyuding from '../assets/svg/business/huiyiyuding.svg' +import business_kaoqinguanli from '../assets/svg/business/kaoqinguanli.svg' +import business_qingxiujiashenqing from '../assets/svg/business/qingxiujiashenqing.svg' +import business_sannianjihua from '../assets/svg/business/sannianjihua.svg' +import business_tongzhifabu from '../assets/svg/business/tongzhifabu.svg' +import business_xiangmuguanli from '../assets/svg/business/xiangmuguanli.svg' +import business_xinxitougao from '../assets/svg/business/xinxitougao.svg' +import business_zhishichanquan from '../assets/svg/business/zhishichanquan.svg' +import business_zhongxindongtaifabu from '../assets/svg/business/zhongxindongtaifabu.svg' +import business_zongheshenpi from '../assets/svg/business/zongheshenpi.svg' +import education_DNA from '../assets/svg/education/DNA.svg' +import education_a1shilibiao from '../assets/svg/education/a-1-shilibiao.svg' +import education_a10yiliaoxiang from '../assets/svg/education/a-10-yiliaoxiang.svg' +import education_a11yiyongweishengzhi from '../assets/svg/education/a-11-yiyongweishengzhi.svg' +import education_a12huxi from '../assets/svg/education/a-12-huxi.svg' +import education_a13xiguan from '../assets/svg/education/a-13-xiguan.svg' +import education_a14zhutingqi from '../assets/svg/education/a-14-zhutingqi.svg' +import education_a15bingdu from '../assets/svg/education/a-15-bingdu.svg' +import education_a16yiyuan from '../assets/svg/education/a-16-yiyuan.svg' +import education_a17zhusheqi from '../assets/svg/education/a-17-zhusheqi.svg' +import education_a18xiguan from '../assets/svg/education/a-18-xiguan.svg' +import education_a19guaizhang from '../assets/svg/education/a-19guaizhang.svg' +import education_a2kouzhao from '../assets/svg/education/a-2-kouzhao.svg' +import education_a20shuye from '../assets/svg/education/a-20-shuye.svg' +import education_a3chuangkoutie from '../assets/svg/education/a-3-chuangkoutie.svg' +import education_a4lunyi from '../assets/svg/education/a-4-lunyi.svg' +import education_a5mianqian from '../assets/svg/education/a-5-mianqian.svg' +import education_a6jiancebi from '../assets/svg/education/a-6-jiancebi.svg' +import education_a7xinzang from '../assets/svg/education/a-7-xinzang.svg' +import education_a8DNA from '../assets/svg/education/a-8-DNA.svg' +import education_a9tizhongcheng from '../assets/svg/education/a-9-tizhongcheng.svg' +import education_abitong1 from '../assets/svg/education/a-bitong1.svg' +import education_ashu2 from '../assets/svg/education/a-shu2.svg' +import education_ashu4 from '../assets/svg/education/a-shu4.svg' +import education_ashu5 from '../assets/svg/education/a-shu5.svg' +import education_ashuben2 from '../assets/svg/education/a-shuben2.svg' +import education_ashuben3 from '../assets/svg/education/a-shuben3.svg' +import education_ashuben4 from '../assets/svg/education/a-shuben4.svg' +import education_axueshimao1 from '../assets/svg/education/a-xueshimao1.svg' +import education_baichui from '../assets/svg/education/baichui.svg' +import education_bijiben from '../assets/svg/education/bijiben.svg' +import education_bitong from '../assets/svg/education/bitong.svg' +import education_chizi from '../assets/svg/education/chizi.svg' +import education_chongdian from '../assets/svg/education/chongdian.svg' +import education_citie from '../assets/svg/education/citie.svg' +import education_daima from '../assets/svg/education/daima.svg' +import education_deng from '../assets/svg/education/deng.svg' +import education_dianliushiyan from '../assets/svg/education/dianliushiyan.svg' +import education_diqiu from '../assets/svg/education/diqiu.svg' +import education_diqiuyi from '../assets/svg/education/diqiuyi.svg' +import education_fanyi from '../assets/svg/education/fanyi.svg' +import education_gongwenbao from '../assets/svg/education/gongwenbao.svg' +import education_heiban from '../assets/svg/education/heiban.svg' +import education_huiyi from '../assets/svg/education/huiyi.svg' +import education_jiangbei from '../assets/svg/education/jiangbei.svg' +import education_jiaoxuelou from '../assets/svg/education/jiaoxuelou.svg' +import education_jinpai from '../assets/svg/education/jinpai.svg' +import education_jisuan from '../assets/svg/education/jisuan.svg' +import education_jisuanqi from '../assets/svg/education/jisuanqi.svg' +import education_naozhong from '../assets/svg/education/naozhong.svg' +import education_qianbi from '../assets/svg/education/qianbi.svg' +import education_sepan from '../assets/svg/education/sepan.svg' +import education_shiyan from '../assets/svg/education/shiyan.svg' +import education_shouji from '../assets/svg/education/shouji.svg' +import education_shuben from '../assets/svg/education/shuben.svg' +import education_shuxie from '../assets/svg/education/shuxie.svg' +import education_sousuo from '../assets/svg/education/sousuo.svg' +import education_suanpan from '../assets/svg/education/suanpan.svg' +import education_tianping from '../assets/svg/education/tianping.svg' +import education_tingzhenqi from '../assets/svg/education/tingzhenqi.svg' +import education_tiyu from '../assets/svg/education/tiyu.svg' +import education_wenjian from '../assets/svg/education/wenjian.svg' +import education_xianweijing from '../assets/svg/education/xianweijing.svg' +import education_xiaoheiban from '../assets/svg/education/xiaoheiban.svg' +import education_xiezizhuo from '../assets/svg/education/xiezizhuo.svg' +import education_xueshimao from '../assets/svg/education/xueshimao.svg' +import education_yuanpan from '../assets/svg/education/yuanpan.svg' +import festival_celianggongju from '../assets/svg/festival/celianggongju.svg' +import festival_chunjie from '../assets/svg/festival/chunjie.svg' +import festival_duanwujie from '../assets/svg/festival/duanwujie.svg' +import festival_ertongjie from '../assets/svg/festival/ertongjie.svg' +import festival_fuqinjie from '../assets/svg/festival/fuqinjie.svg' +import festival_ganenjie from '../assets/svg/festival/ganenjie.svg' +import festival_gongju from '../assets/svg/festival/gongju.svg' +import festival_hushijie from '../assets/svg/festival/hushijie.svg' +import festival_jiaoshijie from '../assets/svg/festival/jiaoshijie.svg' +import festival_laodongjie from '../assets/svg/festival/laodongjie.svg' +import festival_muqinjie from '../assets/svg/festival/muqinjie.svg' +import festival_nvshengjie from '../assets/svg/festival/nvshengjie.svg' +import festival_qingrenjie from '../assets/svg/festival/qingrenjie.svg' +import festival_qixi from '../assets/svg/festival/qixi.svg' +import festival_shengdanjie from '../assets/svg/festival/shengdanjie.svg' +import festival_shuang from '../assets/svg/festival/shuang.svg' +import festival_yuandan from '../assets/svg/festival/yuandan.svg' +import festival_yuanxiaojie from '../assets/svg/festival/yuanxiaojie.svg' +import festival_zhongqiujie from '../assets/svg/festival/zhongqiujie.svg' +import festival_zhongyangjie from '../assets/svg/festival/zhongyangjie.svg' +import food_binggan from '../assets/svg/food/binggan.svg' +import food_binggun from '../assets/svg/food/binggun.svg' +import food_bingqilin from '../assets/svg/food/bingqilin.svg' +import food_boluo from '../assets/svg/food/boluo.svg' +import food_caomei from '../assets/svg/food/caomei.svg' +import food_celianggongju from '../assets/svg/food/celianggongju.svg' +import food_chengzi from '../assets/svg/food/chengzi.svg' +import food_dangao from '../assets/svg/food/dangao.svg' +import food_fanqiejiang from '../assets/svg/food/fanqiejiang.svg' +import food_gongju from '../assets/svg/food/gongju.svg' +import food_hanbao from '../assets/svg/food/hanbao.svg' +import food_jiandan from '../assets/svg/food/jiandan.svg' +import food_kafeibei from '../assets/svg/food/kafeibei.svg' +import food_lajiao from '../assets/svg/food/lajiao.svg' +import food_naixi from '../assets/svg/food/naixi.svg' +import food_niunai from '../assets/svg/food/niunai.svg' +import food_pingguo from '../assets/svg/food/pingguo.svg' +import food_pisa from '../assets/svg/food/pisa.svg' +import food_putao from '../assets/svg/food/putao.svg' +import food_quqi from '../assets/svg/food/quqi.svg' +import food_regou from '../assets/svg/food/regou.svg' +import food_shutiao from '../assets/svg/food/shutiao.svg' +import food_sudaqishui from '../assets/svg/food/sudaqishui.svg' +import food_taozi from '../assets/svg/food/taozi.svg' +import food_tiantianquan from '../assets/svg/food/tiantianquan.svg' +import food_xiangjiao from '../assets/svg/food/xiangjiao.svg' +import food_xigua from '../assets/svg/food/xigua.svg' +import food_xilanhua from '../assets/svg/food/xilanhua.svg' +import food_yingtao from '../assets/svg/food/yingtao.svg' +import food_yumi from '../assets/svg/food/yumi.svg' +import medicine_a1shilibiao from '../assets/svg/medicine/a-1-shilibiao.svg' +import medicine_a10yiliaoxiang from '../assets/svg/medicine/a-10-yiliaoxiang.svg' +import medicine_a11yiyongweishengzhi from '../assets/svg/medicine/a-11-yiyongweishengzhi.svg' +import medicine_a12huxi from '../assets/svg/medicine/a-12-huxi.svg' +import medicine_a13xiguan from '../assets/svg/medicine/a-13-xiguan.svg' +import medicine_a14zhutingqi from '../assets/svg/medicine/a-14-zhutingqi.svg' +import medicine_a15bingdu from '../assets/svg/medicine/a-15-bingdu.svg' +import medicine_a16yiyuan from '../assets/svg/medicine/a-16-yiyuan.svg' +import medicine_a17zhusheqi from '../assets/svg/medicine/a-17-zhusheqi.svg' +import medicine_a18xiguan from '../assets/svg/medicine/a-18-xiguan.svg' +import medicine_a19guaizhang from '../assets/svg/medicine/a-19guaizhang.svg' +import medicine_a2kouzhao from '../assets/svg/medicine/a-2-kouzhao.svg' +import medicine_a20shuye from '../assets/svg/medicine/a-20-shuye.svg' +import medicine_a3chuangkoutie from '../assets/svg/medicine/a-3-chuangkoutie.svg' +import medicine_a4lunyi from '../assets/svg/medicine/a-4-lunyi.svg' +import medicine_a5mianqian from '../assets/svg/medicine/a-5-mianqian.svg' +import medicine_a6jiancebi from '../assets/svg/medicine/a-6-jiancebi.svg' +import medicine_a7xinzang from '../assets/svg/medicine/a-7-xinzang.svg' +import medicine_a8DNA from '../assets/svg/medicine/a-8-DNA.svg' +import medicine_a9tizhongcheng from '../assets/svg/medicine/a-9-tizhongcheng.svg' +import tools_gaizhui from '../assets/svg/tools/gaizhui.svg' +import tools_ziyuan from '../assets/svg/tools/ziyuan.svg' +import tools_ziyuan_1 from '../assets/svg/tools/ziyuan_1.svg' +import tools_ziyuan_10 from '../assets/svg/tools/ziyuan_10.svg' +import tools_ziyuan_11 from '../assets/svg/tools/ziyuan_11.svg' +import tools_ziyuan_12 from '../assets/svg/tools/ziyuan_12.svg' +import tools_ziyuan_13 from '../assets/svg/tools/ziyuan_13.svg' +import tools_ziyuan_14 from '../assets/svg/tools/ziyuan_14.svg' +import tools_ziyuan_15 from '../assets/svg/tools/ziyuan_15.svg' +import tools_ziyuan_16 from '../assets/svg/tools/ziyuan_16.svg' +import tools_ziyuan_17 from '../assets/svg/tools/ziyuan_17.svg' +import tools_ziyuan_18 from '../assets/svg/tools/ziyuan_18.svg' +import tools_ziyuan_2 from '../assets/svg/tools/ziyuan_2.svg' +import tools_ziyuan_3 from '../assets/svg/tools/ziyuan_3.svg' +import tools_ziyuan_4 from '../assets/svg/tools/ziyuan_4.svg' +import tools_ziyuan_5 from '../assets/svg/tools/ziyuan_5.svg' +import tools_ziyuan_6 from '../assets/svg/tools/ziyuan_6.svg' +import tools_ziyuan_7 from '../assets/svg/tools/ziyuan_7.svg' +import tools_ziyuan_8 from '../assets/svg/tools/ziyuan_8.svg' +import tools_ziyuan_9 from '../assets/svg/tools/ziyuan_9.svg' +import travel_banshouli from '../assets/svg/travel/banshouli.svg' +import travel_chuhangshijian from '../assets/svg/travel/chuhangshijian.svg' +import travel_ditu from '../assets/svg/travel/ditu.svg' +import travel_fengjing from '../assets/svg/travel/fengjing.svg' +import travel_gonglve from '../assets/svg/travel/gonglve.svg' +import travel_hangli from '../assets/svg/travel/hangli.svg' +import travel_huafei from '../assets/svg/travel/huafei.svg' +import travel_jipiao from '../assets/svg/travel/jipiao.svg' +import travel_jiudian from '../assets/svg/travel/jiudian.svg' +import travel_lvban from '../assets/svg/travel/lvban.svg' +import travel_meishi from '../assets/svg/travel/meishi.svg' +import travel_menpiao from '../assets/svg/travel/menpiao.svg' +import travel_paishe from '../assets/svg/travel/paishe.svg' +import travel_qianzheng from '../assets/svg/travel/qianzheng.svg' +import travel_shangdian from '../assets/svg/travel/shangdian.svg' +import travel_tianqi from '../assets/svg/travel/tianqi.svg' +import travel_youlechangsuo from '../assets/svg/travel/youlechangsuo.svg' +import travel_yuyanfanyi from '../assets/svg/travel/yuyanfanyi.svg' +import travel_zhuyishixiang from '../assets/svg/travel/zhuyishixiang.svg' +import travel_zuche from '../assets/svg/travel/zuche.svg' +export default [ + { + "name": "商务", + "list": [ + { + "url": business_, + "width": 100, + "height": 100 + }, + { + "url": business__1, + "width": 100, + "height": 100 + }, + { + "url": business__10, + "width": 100, + "height": 100 + }, + { + "url": business__11, + "width": 100, + "height": 100 + }, + { + "url": business__12, + "width": 100, + "height": 100 + }, + { + "url": business__13, + "width": 100, + "height": 100 + }, + { + "url": business__14, + "width": 100, + "height": 100 + }, + { + "url": business__15, + "width": 100, + "height": 100 + }, + { + "url": business__16, + "width": 100, + "height": 100 + }, + { + "url": business__17, + "width": 100, + "height": 100 + }, + { + "url": business__18, + "width": 100, + "height": 100 + }, + { + "url": business__2, + "width": 100, + "height": 100 + }, + { + "url": business__3, + "width": 100, + "height": 100 + }, + { + "url": business__4, + "width": 100, + "height": 100 + }, + { + "url": business__5, + "width": 100, + "height": 100 + }, + { + "url": business__6, + "width": 100, + "height": 100 + }, + { + "url": business__7, + "width": 100, + "height": 100 + }, + { + "url": business__8, + "width": 100, + "height": 100 + }, + { + "url": business__9, + "width": 100, + "height": 100 + }, + { + "url": business_OAxitong, + "width": 100, + "height": 100 + }, + { + "url": business_changyongziyuan, + "width": 100, + "height": 100 + }, + { + "url": business_chuchashenpi, + "width": 100, + "height": 100 + }, + { + "url": business_fanwendengji, + "width": 100, + "height": 100 + }, + { + "url": business_feizhengshiwendengji, + "width": 100, + "height": 100 + }, + { + "url": business_gongwenjiaohuan, + "width": 100, + "height": 100 + }, + { + "url": business_gongzuohuibao, + "width": 100, + "height": 100 + }, + { + "url": business_gudingzichan, + "width": 100, + "height": 100 + }, + { + "url": business_huiyiguanli, + "width": 100, + "height": 100 + }, + { + "url": business_huiyiyuding, + "width": 100, + "height": 100 + }, + { + "url": business_kaoqinguanli, + "width": 100, + "height": 100 + }, + { + "url": business_qingxiujiashenqing, + "width": 100, + "height": 100 + }, + { + "url": business_sannianjihua, + "width": 100, + "height": 100 + }, + { + "url": business_tongzhifabu, + "width": 100, + "height": 100 + }, + { + "url": business_xiangmuguanli, + "width": 100, + "height": 100 + }, + { + "url": business_xinxitougao, + "width": 100, + "height": 100 + }, + { + "url": business_zhishichanquan, + "width": 100, + "height": 100 + }, + { + "url": business_zhongxindongtaifabu, + "width": 100, + "height": 100 + }, + { + "url": business_zongheshenpi, + "width": 100, + "height": 100 + } + ] + }, + { + "name": "教育", + "list": [ + { + "url": education_DNA, + "width": 100, + "height": 100 + }, + { + "url": education_a1shilibiao, + "width": 100, + "height": 100 + }, + { + "url": education_a10yiliaoxiang, + "width": 100, + "height": 100 + }, + { + "url": education_a11yiyongweishengzhi, + "width": 100, + "height": 100 + }, + { + "url": education_a12huxi, + "width": 100, + "height": 100 + }, + { + "url": education_a13xiguan, + "width": 100, + "height": 100 + }, + { + "url": education_a14zhutingqi, + "width": 100, + "height": 100 + }, + { + "url": education_a15bingdu, + "width": 100, + "height": 100 + }, + { + "url": education_a16yiyuan, + "width": 100, + "height": 100 + }, + { + "url": education_a17zhusheqi, + "width": 100, + "height": 100 + }, + { + "url": education_a18xiguan, + "width": 100, + "height": 100 + }, + { + "url": education_a19guaizhang, + "width": 100, + "height": 100 + }, + { + "url": education_a2kouzhao, + "width": 100, + "height": 100 + }, + { + "url": education_a20shuye, + "width": 100, + "height": 100 + }, + { + "url": education_a3chuangkoutie, + "width": 100, + "height": 100 + }, + { + "url": education_a4lunyi, + "width": 100, + "height": 100 + }, + { + "url": education_a5mianqian, + "width": 100, + "height": 100 + }, + { + "url": education_a6jiancebi, + "width": 100, + "height": 100 + }, + { + "url": education_a7xinzang, + "width": 100, + "height": 100 + }, + { + "url": education_a8DNA, + "width": 100, + "height": 100 + }, + { + "url": education_a9tizhongcheng, + "width": 100, + "height": 100 + }, + { + "url": education_abitong1, + "width": 100, + "height": 100 + }, + { + "url": education_ashu2, + "width": 100, + "height": 100 + }, + { + "url": education_ashu4, + "width": 100, + "height": 100 + }, + { + "url": education_ashu5, + "width": 100, + "height": 100 + }, + { + "url": education_ashuben2, + "width": 100, + "height": 100 + }, + { + "url": education_ashuben3, + "width": 100, + "height": 100 + }, + { + "url": education_ashuben4, + "width": 100, + "height": 100 + }, + { + "url": education_axueshimao1, + "width": 100, + "height": 100 + }, + { + "url": education_baichui, + "width": 100, + "height": 100 + }, + { + "url": education_bijiben, + "width": 100, + "height": 100 + }, + { + "url": education_bitong, + "width": 100, + "height": 100 + }, + { + "url": education_chizi, + "width": 100, + "height": 100 + }, + { + "url": education_chongdian, + "width": 100, + "height": 100 + }, + { + "url": education_citie, + "width": 100, + "height": 100 + }, + { + "url": education_daima, + "width": 100, + "height": 100 + }, + { + "url": education_deng, + "width": 100, + "height": 100 + }, + { + "url": education_dianliushiyan, + "width": 100, + "height": 100 + }, + { + "url": education_diqiu, + "width": 100, + "height": 100 + }, + { + "url": education_diqiuyi, + "width": 100, + "height": 100 + }, + { + "url": education_fanyi, + "width": 100, + "height": 100 + }, + { + "url": education_gongwenbao, + "width": 100, + "height": 100 + }, + { + "url": education_heiban, + "width": 100, + "height": 100 + }, + { + "url": education_huiyi, + "width": 100, + "height": 100 + }, + { + "url": education_jiangbei, + "width": 100, + "height": 100 + }, + { + "url": education_jiaoxuelou, + "width": 100, + "height": 100 + }, + { + "url": education_jinpai, + "width": 100, + "height": 100 + }, + { + "url": education_jisuan, + "width": 100, + "height": 100 + }, + { + "url": education_jisuanqi, + "width": 100, + "height": 100 + }, + { + "url": education_naozhong, + "width": 100, + "height": 100 + }, + { + "url": education_qianbi, + "width": 100, + "height": 100 + }, + { + "url": education_sepan, + "width": 100, + "height": 100 + }, + { + "url": education_shiyan, + "width": 100, + "height": 100 + }, + { + "url": education_shouji, + "width": 100, + "height": 100 + }, + { + "url": education_shuben, + "width": 100, + "height": 100 + }, + { + "url": education_shuxie, + "width": 100, + "height": 100 + }, + { + "url": education_sousuo, + "width": 100, + "height": 100 + }, + { + "url": education_suanpan, + "width": 100, + "height": 100 + }, + { + "url": education_tianping, + "width": 100, + "height": 100 + }, + { + "url": education_tingzhenqi, + "width": 100, + "height": 100 + }, + { + "url": education_tiyu, + "width": 100, + "height": 100 + }, + { + "url": education_wenjian, + "width": 100, + "height": 100 + }, + { + "url": education_xianweijing, + "width": 100, + "height": 100 + }, + { + "url": education_xiaoheiban, + "width": 100, + "height": 100 + }, + { + "url": education_xiezizhuo, + "width": 100, + "height": 100 + }, + { + "url": education_xueshimao, + "width": 100, + "height": 100 + }, + { + "url": education_yuanpan, + "width": 100, + "height": 100 + } + ] + }, + { + "name": "节日", + "list": [ + { + "url": festival_celianggongju, + "width": 100, + "height": 100 + }, + { + "url": festival_chunjie, + "width": 100, + "height": 100 + }, + { + "url": festival_duanwujie, + "width": 100, + "height": 100 + }, + { + "url": festival_ertongjie, + "width": 100, + "height": 100 + }, + { + "url": festival_fuqinjie, + "width": 100, + "height": 100 + }, + { + "url": festival_ganenjie, + "width": 100, + "height": 100 + }, + { + "url": festival_gongju, + "width": 100, + "height": 100 + }, + { + "url": festival_hushijie, + "width": 100, + "height": 100 + }, + { + "url": festival_jiaoshijie, + "width": 100, + "height": 100 + }, + { + "url": festival_laodongjie, + "width": 100, + "height": 100 + }, + { + "url": festival_muqinjie, + "width": 100, + "height": 100 + }, + { + "url": festival_nvshengjie, + "width": 100, + "height": 100 + }, + { + "url": festival_qingrenjie, + "width": 100, + "height": 100 + }, + { + "url": festival_qixi, + "width": 100, + "height": 100 + }, + { + "url": festival_shengdanjie, + "width": 100, + "height": 100 + }, + { + "url": festival_shuang, + "width": 100, + "height": 100 + }, + { + "url": festival_yuandan, + "width": 100, + "height": 100 + }, + { + "url": festival_yuanxiaojie, + "width": 100, + "height": 100 + }, + { + "url": festival_zhongqiujie, + "width": 100, + "height": 100 + }, + { + "url": festival_zhongyangjie, + "width": 100, + "height": 100 + } + ] + }, + { + "name": "食物", + "list": [ + { + "url": food_binggan, + "width": 100, + "height": 100 + }, + { + "url": food_binggun, + "width": 100, + "height": 100 + }, + { + "url": food_bingqilin, + "width": 100, + "height": 100 + }, + { + "url": food_boluo, + "width": 100, + "height": 100 + }, + { + "url": food_caomei, + "width": 100, + "height": 100 + }, + { + "url": food_celianggongju, + "width": 100, + "height": 100 + }, + { + "url": food_chengzi, + "width": 100, + "height": 100 + }, + { + "url": food_dangao, + "width": 100, + "height": 100 + }, + { + "url": food_fanqiejiang, + "width": 100, + "height": 100 + }, + { + "url": food_gongju, + "width": 100, + "height": 100 + }, + { + "url": food_hanbao, + "width": 100, + "height": 100 + }, + { + "url": food_jiandan, + "width": 100, + "height": 100 + }, + { + "url": food_kafeibei, + "width": 100, + "height": 100 + }, + { + "url": food_lajiao, + "width": 100, + "height": 100 + }, + { + "url": food_naixi, + "width": 100, + "height": 100 + }, + { + "url": food_niunai, + "width": 100, + "height": 100 + }, + { + "url": food_pingguo, + "width": 100, + "height": 100 + }, + { + "url": food_pisa, + "width": 100, + "height": 100 + }, + { + "url": food_putao, + "width": 100, + "height": 100 + }, + { + "url": food_quqi, + "width": 100, + "height": 100 + }, + { + "url": food_regou, + "width": 100, + "height": 100 + }, + { + "url": food_shutiao, + "width": 100, + "height": 100 + }, + { + "url": food_sudaqishui, + "width": 100, + "height": 100 + }, + { + "url": food_taozi, + "width": 100, + "height": 100 + }, + { + "url": food_tiantianquan, + "width": 100, + "height": 100 + }, + { + "url": food_xiangjiao, + "width": 100, + "height": 100 + }, + { + "url": food_xigua, + "width": 100, + "height": 100 + }, + { + "url": food_xilanhua, + "width": 100, + "height": 100 + }, + { + "url": food_yingtao, + "width": 100, + "height": 100 + }, + { + "url": food_yumi, + "width": 100, + "height": 100 + } + ] + }, + { + "name": "医疗", + "list": [ + { + "url": medicine_a1shilibiao, + "width": 100, + "height": 100 + }, + { + "url": medicine_a10yiliaoxiang, + "width": 100, + "height": 100 + }, + { + "url": medicine_a11yiyongweishengzhi, + "width": 100, + "height": 100 + }, + { + "url": medicine_a12huxi, + "width": 100, + "height": 100 + }, + { + "url": medicine_a13xiguan, + "width": 100, + "height": 100 + }, + { + "url": medicine_a14zhutingqi, + "width": 100, + "height": 100 + }, + { + "url": medicine_a15bingdu, + "width": 100, + "height": 100 + }, + { + "url": medicine_a16yiyuan, + "width": 100, + "height": 100 + }, + { + "url": medicine_a17zhusheqi, + "width": 100, + "height": 100 + }, + { + "url": medicine_a18xiguan, + "width": 100, + "height": 100 + }, + { + "url": medicine_a19guaizhang, + "width": 100, + "height": 100 + }, + { + "url": medicine_a2kouzhao, + "width": 100, + "height": 100 + }, + { + "url": medicine_a20shuye, + "width": 100, + "height": 100 + }, + { + "url": medicine_a3chuangkoutie, + "width": 100, + "height": 100 + }, + { + "url": medicine_a4lunyi, + "width": 100, + "height": 100 + }, + { + "url": medicine_a5mianqian, + "width": 100, + "height": 100 + }, + { + "url": medicine_a6jiancebi, + "width": 100, + "height": 100 + }, + { + "url": medicine_a7xinzang, + "width": 100, + "height": 100 + }, + { + "url": medicine_a8DNA, + "width": 100, + "height": 100 + }, + { + "url": medicine_a9tizhongcheng, + "width": 100, + "height": 100 + } + ] + }, + { + "name": "工具", + "list": [ + { + "url": tools_gaizhui, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_1, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_10, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_11, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_12, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_13, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_14, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_15, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_16, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_17, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_18, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_2, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_3, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_4, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_5, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_6, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_7, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_8, + "width": 100, + "height": 100 + }, + { + "url": tools_ziyuan_9, + "width": 100, + "height": 100 + } + ] + }, + { + "name": "旅行", + "list": [ + { + "url": travel_banshouli, + "width": 100, + "height": 100 + }, + { + "url": travel_chuhangshijian, + "width": 100, + "height": 100 + }, + { + "url": travel_ditu, + "width": 100, + "height": 100 + }, + { + "url": travel_fengjing, + "width": 100, + "height": 100 + }, + { + "url": travel_gonglve, + "width": 100, + "height": 100 + }, + { + "url": travel_hangli, + "width": 100, + "height": 100 + }, + { + "url": travel_huafei, + "width": 100, + "height": 100 + }, + { + "url": travel_jipiao, + "width": 100, + "height": 100 + }, + { + "url": travel_jiudian, + "width": 100, + "height": 100 + }, + { + "url": travel_lvban, + "width": 100, + "height": 100 + }, + { + "url": travel_meishi, + "width": 100, + "height": 100 + }, + { + "url": travel_menpiao, + "width": 100, + "height": 100 + }, + { + "url": travel_paishe, + "width": 100, + "height": 100 + }, + { + "url": travel_qianzheng, + "width": 100, + "height": 100 + }, + { + "url": travel_shangdian, + "width": 100, + "height": 100 + }, + { + "url": travel_tianqi, + "width": 100, + "height": 100 + }, + { + "url": travel_youlechangsuo, + "width": 100, + "height": 100 + }, + { + "url": travel_yuyanfanyi, + "width": 100, + "height": 100 + }, + { + "url": travel_zhuyishixiang, + "width": 100, + "height": 100 + }, + { + "url": travel_zuche, + "width": 100, + "height": 100 + } + ] + } +] diff --git a/web/src/config/zh.js b/web/src/config/zh.js index ba115b9c..6f8d0965 100644 --- a/web/src/config/zh.js +++ b/web/src/config/zh.js @@ -270,7 +270,7 @@ export const shortcutKeyList = [ { icon: 'icongaikuozonglan', name: '插入概要', - value: 'Ctrl + S' + value: 'Ctrl + G' }, { icon: 'iconzhankai', @@ -331,6 +331,11 @@ export const shortcutKeyList = [ icon: 'iconzhengli', name: '一键整理布局', value: 'Ctrl + L' + }, + { + icon: 'iconsousuo', + name: '搜索和替换', + value: 'Ctrl + F' } ] }, diff --git a/web/src/customThemes/darkNightLceBlade.js b/web/src/customThemes/darkNightLceBlade.js new file mode 100644 index 00000000..5345d914 --- /dev/null +++ b/web/src/customThemes/darkNightLceBlade.js @@ -0,0 +1,59 @@ +// 暗夜冰刃 +export default { + backgroundColor: 'rgb(0, 21, 21)', + // 连线的颜色 + lineColor: 'rgb(0, 139, 146)', + lineWidth: 3, + // 概要连线的粗细 + generalizationLineWidth: 3, + // 概要连线的颜色 + generalizationLineColor: 'rgba(2, 167, 240, 0.5)', + // 关联线默认状态的颜色 + associativeLineColor: 'rgb(255, 255, 255)', + // 关联线文字颜色 + associativeLineTextColor: 'rgb(255, 255, 255)', + // 根节点样式 + root: { + fillColor: 'rgb(0, 243, 255)', + color: 'rgb(0, 21, 21)', + borderColor: '#fff', + borderWidth: 3, + fontSize: 24, + shape: 'parallelogram', + active: { + borderColor: 'rgba(2, 167, 240, 0.5)', + } + }, + // 二级节点样式 + second: { + fillColor: 'rgb(0, 21, 21)', + color: '#fff', + borderColor: '#fff', + borderWidth: 3, + fontSize: 18, + shape: 'diamond', + active: { + borderColor: 'rgba(2, 167, 240, 0.5)', + } + }, + // 三级及以下节点样式 + node: { + fontSize: 14, + color: '#fff', + active: { + borderColor: 'rgba(2, 167, 240, 0.5)' + } + }, + // 概要节点样式 + generalization: { + fontSize: 14, + fillColor: '#fff', + borderColor: 'rgb(0, 117, 255)', + borderWidth: 2, + color: 'rgb(0, 21, 21)', + active: { + borderColor: 'rgb(0, 243, 255)' + } + } + } + \ No newline at end of file diff --git a/web/src/customThemes/index.js b/web/src/customThemes/index.js index 7d41263f..455a9ee2 100644 --- a/web/src/customThemes/index.js +++ b/web/src/customThemes/index.js @@ -1,9 +1,59 @@ -import simpleBlack from './simpleBlack' +import oreo from './oreo' +import shallowSea from './shallowSea' +import lemonBubbles from './lemonBubbles' +import rose from './rose' +import seaBlueLine from './seaBlueLine' +import neonLamp from './neonLamp' +import darkNightLceBlade from './darkNightLceBlade' +import morandi from './morandi' export default [ { - name: '简约黑', - value: 'simpleBlack', - theme: simpleBlack + name: '奥利奥', + value: 'oreo', + theme: oreo, + dark: false + }, + { + name: '浅海', + value: 'shallowSea', + theme: shallowSea, + dark: false + }, + { + name: '柠檬气泡', + value: 'lemonBubbles', + theme: lemonBubbles, + dark: false + }, + { + name: '玫瑰', + value: 'rose', + theme: rose, + dark: false + }, + { + name: '海蓝线', + value: 'seaBlueLine', + theme: seaBlueLine, + dark: false + }, + { + name: '霓虹灯', + value: 'neonLamp', + theme: neonLamp, + dark: true + }, + { + name: '暗夜冰刃', + value: 'darkNightLceBlade', + theme: darkNightLceBlade, + dark: true + }, + { + name: '莫兰迪', + value: 'morandi', + theme: morandi, + dark: false } ] \ No newline at end of file diff --git a/web/src/customThemes/lemonBubbles.js b/web/src/customThemes/lemonBubbles.js new file mode 100644 index 00000000..15470539 --- /dev/null +++ b/web/src/customThemes/lemonBubbles.js @@ -0,0 +1,55 @@ +// 柠檬气泡 +export default { + backgroundColor: 'rgb(236, 254, 255)', + // 连线的颜色 + lineColor: 'rgb(51, 51, 51)', + lineWidth: 3, + // 概要连线的粗细 + generalizationLineWidth: 3, + // 概要连线的颜色 + generalizationLineColor: 'rgb(51, 51, 51)', + // 根节点样式 + root: { + fillColor: 'rgb(39, 222, 232)', + color: 'rgb(26, 26, 26)', + borderColor: 'rgb(26, 26, 26)', + borderWidth: 3, + fontSize: 24, + shape: 'roundedRectangle', + active: { + borderColor: 'rgb(235, 255, 187)', + } + }, + // 二级节点样式 + second: { + fillColor: 'rgb(235, 255, 187)', + color: 'rgb(0, 0, 0)', + borderColor: 'rgb(51, 51, 51)', + borderWidth: 3, + fontSize: 18, + shape: 'roundedRectangle', + active: { + borderColor: 'rgb(39, 222, 232)', + } + }, + // 三级及以下节点样式 + node: { + fontSize: 14, + color: 'rgb(0, 0, 0)', + active: { + borderColor: 'rgb(39, 222, 232)' + } + }, + // 概要节点样式 + generalization: { + fontSize: 14, + fillColor: '#fff', + borderColor: 'rgb(26, 26, 26)', + borderWidth: 2, + color: 'rgb(26, 26, 26)', + active: { + borderColor: 'rgb(39, 222, 232)' + } + } + } + \ No newline at end of file diff --git a/web/src/customThemes/morandi.js b/web/src/customThemes/morandi.js new file mode 100644 index 00000000..dc106f68 --- /dev/null +++ b/web/src/customThemes/morandi.js @@ -0,0 +1,59 @@ +// 莫兰迪 +export default { + backgroundColor: 'rgb(252, 245, 241)', + // 连线的颜色 + lineColor: 'rgb(144, 114, 110)', + lineWidth: 3, + // 概要连线的粗细 + generalizationLineWidth: 3, + // 概要连线的颜色 + generalizationLineColor: 'rgb(128, 154, 151)', + // 关联线默认状态的颜色 + associativeLineColor: 'rgb(166, 124, 106)', + // 关联线文字颜色 + associativeLineTextColor: 'rgb(166, 124, 106)', + // 根节点样式 + root: { + fillColor: 'rgb(207, 121, 105)', + color: '#fff', + borderColor: 'rgb(207, 121, 105)', + borderWidth: 3, + fontSize: 24, + shape: 'roundedRectangle', + active: { + borderColor: 'rgb(172, 202, 199)', + } + }, + // 二级节点样式 + second: { + fillColor: 'rgb(239, 210, 207)', + color: 'rgb(144, 79, 68)', + borderColor: 'rgb(222, 186, 183)', + borderWidth: 3, + fontSize: 18, + shape: 'roundedRectangle', + active: { + borderColor: 'rgb(172, 202, 199)', + } + }, + // 三级及以下节点样式 + node: { + fontSize: 14, + color: 'rgb(131, 90, 64)', + active: { + borderColor: 'rgb(172, 202, 199)' + } + }, + // 概要节点样式 + generalization: { + fontSize: 14, + fillColor: 'rgb(172, 202, 199)', + borderColor: 'rgb(172, 202, 199)', + borderWidth: 2, + color: 'rgb(91, 102, 97)', + active: { + borderColor: 'rgb(207, 121, 105)' + } + } + } + \ No newline at end of file diff --git a/web/src/customThemes/neonLamp.js b/web/src/customThemes/neonLamp.js new file mode 100644 index 00000000..104e04f0 --- /dev/null +++ b/web/src/customThemes/neonLamp.js @@ -0,0 +1,58 @@ +// 霓虹灯 +export default { + backgroundColor: 'rgb(17, 17, 84)', + // 连线的颜色 + lineColor: 'rgb(255, 0, 214)', + lineWidth: 3, + // 概要连线的粗细 + generalizationLineWidth: 3, + // 概要连线的颜色 + generalizationLineColor: 'rgb(255, 181, 0)', + // 关联线默认状态的颜色 + associativeLineColor: 'rgb(255, 255, 255)', + // 关联线文字颜色 + associativeLineTextColor: 'rgb(255, 255, 255)', + // 根节点样式 + root: { + fillColor: 'rgb(251, 233, 248)', + color: 'rgb(208, 5, 176)', + borderColor: 'rgb(255, 0, 214)', + borderWidth: 3, + fontSize: 24, + shape: 'roundedRectangle', + active: { + borderColor: 'rgb(255, 181, 0)', + } + }, + // 二级节点样式 + second: { + fillColor: 'transparent', + color: 'rgb(248, 177, 237)', + borderColor: '', + borderWidth: 3, + fontSize: 18, + active: { + borderColor: 'rgb(255, 181, 0)', + } + }, + // 三级及以下节点样式 + node: { + fontSize: 14, + color: '#fff', + active: { + borderColor: 'rgb(255, 181, 0)' + } + }, + // 概要节点样式 + generalization: { + fontSize: 14, + fillColor: '#fff', + borderColor: 'rgb(255, 181, 0)', + borderWidth: 2, + color: 'rgb(17, 17, 84)', + active: { + borderColor: 'rgb(255, 0, 214)' + } + } + } + \ No newline at end of file diff --git a/web/src/customThemes/simpleBlack.js b/web/src/customThemes/oreo.js similarity index 58% rename from web/src/customThemes/simpleBlack.js rename to web/src/customThemes/oreo.js index 36457826..dfa58cff 100644 --- a/web/src/customThemes/simpleBlack.js +++ b/web/src/customThemes/oreo.js @@ -1,17 +1,17 @@ -// 简约黑 +// 奥利奥 export default { // 连线的颜色 - lineColor: 'rgb(34, 34, 34)', - lineWidth: 4, + lineColor: 'rgb(51, 51, 51)', + lineWidth: 3, // 概要连线的粗细 - generalizationLineWidth: 4, + generalizationLineWidth: 3, // 概要连线的颜色 - generalizationLineColor: 'rgb(34, 34, 34)', + generalizationLineColor: 'rgb(51, 51, 51)', // 根节点样式 root: { - fillColor: '#fff', - color: 'rgb(34, 34, 34)', - borderColor: 'rgb(34, 34, 34)', + fillColor: 'rgb(22, 22, 22)', + color: '#fff', + borderColor: 'rgb(22, 22, 22)', borderWidth: 3, fontSize: 24, active: { @@ -20,21 +20,22 @@ export default { }, // 二级节点样式 second: { - fillColor: 'rgb(241, 246, 248)', - color: 'rgb(34, 34, 34)', - borderColor: 'rgb(34, 34, 34)', + fillColor: 'rgb(244, 246, 253)', + color: 'rgb(0, 0, 0)', + borderColor: '', borderWidth: 3, fontSize: 18, + shape: 'roundedRectangle', active: { - borderColor: '#a13600', + borderColor: 'rgb(22, 22, 22)', } }, // 三级及以下节点样式 node: { fontSize: 14, - color: 'rgb(34, 34, 34)', + color: 'rgb(0, 0, 0)', active: { - borderColor: '#a13600' + borderColor: 'rgb(22, 22, 22)' } }, // 概要节点样式 diff --git a/web/src/customThemes/rose.js b/web/src/customThemes/rose.js new file mode 100644 index 00000000..c81368b8 --- /dev/null +++ b/web/src/customThemes/rose.js @@ -0,0 +1,55 @@ +// 玫瑰 +export default { + backgroundColor: 'rgb(255, 251, 231)', + // 连线的颜色 + lineColor: 'rgb(110, 165, 79)', + lineWidth: 3, + // 概要连线的粗细 + generalizationLineWidth: 3, + // 概要连线的颜色 + generalizationLineColor: 'rgb(136, 100, 0)', + // 根节点样式 + root: { + fillColor: 'rgb(254, 92, 92)', + color: '#fff', + borderColor: 'rgb(18, 187, 55)', + borderWidth: 3, + fontSize: 24, + shape: 'roundedRectangle', + active: { + borderColor: 'rgb(136, 100, 0)', + } + }, + // 二级节点样式 + second: { + fillColor: 'rgb(209, 237, 176)', + color: 'rgb(85, 136, 55)', + borderColor: '', + borderWidth: 3, + fontSize: 18, + shape: 'roundedRectangle', + active: { + borderColor: 'rgb(254, 92, 92)', + } + }, + // 三级及以下节点样式 + node: { + fontSize: 14, + color: 'rgb(26, 26, 26)', + active: { + borderColor: 'rgb(209, 237, 176)' + } + }, + // 概要节点样式 + generalization: { + fontSize: 14, + fillColor: '#fff', + borderColor: 'rgb(136, 100, 0)', + borderWidth: 2, + color: 'rgb(136, 100, 0)', + active: { + borderColor: 'rgb(254, 92, 92)' + } + } + } + \ No newline at end of file diff --git a/web/src/customThemes/seaBlueLine.js b/web/src/customThemes/seaBlueLine.js new file mode 100644 index 00000000..ffaba245 --- /dev/null +++ b/web/src/customThemes/seaBlueLine.js @@ -0,0 +1,55 @@ +// 海蓝线 +export default { + backgroundColor: 'rgb(231, 245, 255)', + // 连线的颜色 + lineColor: 'rgb(96, 189, 255)', + lineWidth: 3, + // 概要连线的粗细 + generalizationLineWidth: 3, + // 概要连线的颜色 + generalizationLineColor: 'rgb(0, 155, 255)', + // 根节点样式 + root: { + fillColor: 'rgb(96, 189, 255)', + color: '#fff', + borderColor: '#fff', + borderWidth: 3, + fontSize: 24, + shape: 'roundedRectangle', + active: { + borderColor: 'rgb(0, 155, 255)', + } + }, + // 二级节点样式 + second: { + fillColor: '#fff', + color: 'rgb(0, 149, 255)', + borderColor: '', + borderWidth: 3, + fontSize: 18, + shape: 'roundedRectangle', + active: { + borderColor: 'rgb(96, 189, 255)', + } + }, + // 三级及以下节点样式 + node: { + fontSize: 14, + color: 'rgb(0, 66, 157)', + active: { + borderColor: 'rgb(96, 189, 255)' + } + }, + // 概要节点样式 + generalization: { + fontSize: 14, + fillColor: '#fff', + borderColor: 'rgb(0, 155, 255)', + borderWidth: 2, + color: 'rgb(0, 155, 255)', + active: { + borderColor: 'rgba(2, 167, 240, 0.5)' + } + } + } + \ No newline at end of file diff --git a/web/src/customThemes/shallowSea.js b/web/src/customThemes/shallowSea.js new file mode 100644 index 00000000..92f6d160 --- /dev/null +++ b/web/src/customThemes/shallowSea.js @@ -0,0 +1,54 @@ +// 浅海 +export default { + backgroundColor: 'rgb(187, 241, 250)', + // 连线的颜色 + lineColor: 'rgb(74, 139, 170)', + lineWidth: 3, + // 概要连线的粗细 + generalizationLineWidth: 3, + // 概要连线的颜色 + generalizationLineColor: 'rgb(255, 168, 101)', + // 根节点样式 + root: { + fillColor: 'rgb(51, 149, 255)', + color: '#fff', + borderColor: 'rgb(51, 149, 255)', + borderWidth: 3, + fontSize: 24, + shape: 'roundedRectangle', + active: { + borderColor: 'rgb(255, 168, 101)', + } + }, + // 二级节点样式 + second: { + fillColor: 'rgb(74, 139, 170)', + color: '#fff', + borderColor: '', + borderWidth: 3, + fontSize: 18, + active: { + borderColor: 'rgb(255, 168, 101)', + } + }, + // 三级及以下节点样式 + node: { + fontSize: 14, + color: 'rgb(0, 0, 0)', + active: { + borderColor: 'rgb(255, 168, 101)' + } + }, + // 概要节点样式 + generalization: { + fontSize: 14, + fillColor: '#fff', + borderColor: 'rgb(255, 168, 101)', + borderWidth: 2, + color: '#000', + active: { + borderColor: 'rgb(51, 149, 255)' + } + } + } + \ No newline at end of file diff --git a/web/src/lang/en_us.js b/web/src/lang/en_us.js index 235ebd1d..a89f26ae 100644 --- a/web/src/lang/en_us.js +++ b/web/src/lang/en_us.js @@ -210,5 +210,12 @@ export default { mouseAction: { tip1: 'Current: Left click to drag the canvas, right click to box select nodes', tip2: 'Current: Left click to box select nodes, right click to drag the canvas', + }, + search: { + searchPlaceholder: 'Please enter the search content', + replacePlaceholder: 'Please enter replacement content', + replace: 'Replace', + replaceAll: 'Replace all', + cancel: 'Cancel' } } diff --git a/web/src/lang/zh_cn.js b/web/src/lang/zh_cn.js index c050b0f4..910dedfa 100644 --- a/web/src/lang/zh_cn.js +++ b/web/src/lang/zh_cn.js @@ -210,5 +210,12 @@ export default { mouseAction: { tip1: '当前:左键拖动画布,右键框选节点', tip2: '当前:左键框选节点,右键拖动画布', + }, + search: { + searchPlaceholder: '请输入查找内容', + replacePlaceholder: '请输入替换内容', + replace: '替换', + replaceAll: '全部替换', + cancel: '取消' } } diff --git a/web/src/pages/Doc/catalogList.js b/web/src/pages/Doc/catalogList.js index b709769d..7aca8d52 100644 --- a/web/src/pages/Doc/catalogList.js +++ b/web/src/pages/Doc/catalogList.js @@ -11,7 +11,7 @@ let langList = [ } ] let StartList = ['introduction', 'start', 'deploy', 'client', 'translate', 'changelog'] -let CourseList = new Array(20).fill(0).map((_, index) => { +let CourseList = new Array(21).fill(0).map((_, index) => { return 'course' + (index + 1) }) let APIList = [ @@ -32,10 +32,14 @@ let APIList = [ 'associativeLine', 'touchEvent', 'nodeImgAdjust', + 'search', 'xmind', 'markdown', 'utils' ] +let helpList = new Array(2).fill(0).map((_, index) => { + return 'help' + (index + 1) +}) const createList = (lang, list) => { let langRouter = routerList.find(item => { @@ -62,28 +66,39 @@ export default { zh: [ { groupName: '开始', + type: 'doc', list: createList('zh', StartList) }, { groupName: '教程', + type: 'doc', list: createList('zh', CourseList) }, { groupName: 'API', + type: 'doc', list: createList('zh', APIList) + }, + { + groupName: '使用帮助', + type: 'help', + list: createList('zh', helpList) } ], en: [ { groupName: 'Start', + type: 'doc', list: createList('en', StartList) }, { groupName: 'Course', + type: 'doc', list: createList('zh', CourseList) }, { groupName: 'API', + type: 'doc', list: createList('en', APIList) } ] diff --git a/web/src/pages/Doc/components/CatalogBar.vue b/web/src/pages/Doc/components/CatalogBar.vue index 9399ef6a..d6106ade 100644 --- a/web/src/pages/Doc/components/CatalogBar.vue +++ b/web/src/pages/Doc/components/CatalogBar.vue @@ -66,18 +66,18 @@ export default { methods: { // 获取当前语言 initLang() { - let lang = /^\/doc\/([^\/]+)\//.exec(this.$route.path) - if (lang && lang[1]) { - this.lang = lang[1] + let lang = /^\/(doc|help)\/([^\/]+)\//.exec(this.$route.path) + if (lang && lang[2]) { + this.lang = lang[2] } }, // 初始化二级标题目录 initCatalogList(newPath, oldPath) { - let newPathRes = /^\/doc\/[^\/]+\/([^\/]+)/.exec(newPath) - let oldPathRes = /^\/doc\/[^\/]+\/([^\/]+)/.exec(oldPath) + let newPathRes = /^\/(doc|help)\/[^\/]+\/([^\/]+)/.exec(newPath) + let oldPathRes = /^\/(doc|help)\/[^\/]+\/([^\/]+)/.exec(oldPath) // 语言变了、章节变了,需要重新获取二级标题目录 - if ((!newPath && !oldPath) || newPathRes[1] !== oldPathRes[1]) { + if ((!newPath && !oldPath) || newPathRes[2] !== oldPathRes[2]) { this.$emit('scroll', 0) this.resetActive() let container = document.getElementById('doc') @@ -93,9 +93,9 @@ export default { // 如果url中存在二级标题,那么滚动到该标题所在位置 scrollToCatalog() { - let url = /^\/doc\/[^\/]+\/[^\/]+\/([^\/]+)($|\/)/.exec(this.$route.path) - if (url && url[1]) { - let h = decodeURIComponent(url[1]) + let url = /^\/(doc|help)\/[^\/]+\/[^\/]+\/([^\/]+)($|\/)/.exec(this.$route.path) + if (url && url[2]) { + let h = decodeURIComponent(url[2]) let item = this.list.find(item => { return item.title === h }) @@ -126,15 +126,15 @@ export default { let path = this.$route.path let url = '' if (!title) { - url = path.replace(/^(\/doc\/[^\/]+\/[^\/]+)($|\/|.*)$/, '$1') - } else if (/^\/doc\/[^\/]+\/[^\/]+($|\/)$/.test(path)) { + url = path.replace(/^(\/(doc|help)\/[^\/]+\/[^\/]+)($|\/|.*)$/, '$1') + } else if (/^\/(doc|help)\/[^\/]+\/[^\/]+($|\/)$/.test(path)) { url = path.replace( - /^(\/doc\/[^\/]+\/[^\/]+)($|\/)$/, + /^(\/(doc|help)\/[^\/]+\/[^\/]+)($|\/)$/, '$1/' + encodeURIComponent(title) ) } else { url = path.replace( - /^(\/doc\/[^\/]+\/[^\/]+\/)([^\/]+)($|\/)/, + /^(\/(doc|help)\/[^\/]+\/[^\/]+\/)([^\/]+)($|\/)/, (...args) => { return args[1] + encodeURIComponent(title) } diff --git a/web/src/pages/Doc/components/Sidebar.vue b/web/src/pages/Doc/components/Sidebar.vue index 4482aa3c..c9a16725 100644 --- a/web/src/pages/Doc/components/Sidebar.vue +++ b/web/src/pages/Doc/components/Sidebar.vue @@ -31,7 +31,8 @@ export default { return { groupList: [], lang: '', - currentPath: '' + currentPath: '', + type: ''// doc、help } }, created() { @@ -47,20 +48,24 @@ export default { if (item.path === this.currentPath) { return } - this.$router.push(`/doc/${this.lang}/${item.path}`) + this.$router.push(`/${this.type}/${this.lang}/${item.path}`) }, initCatalog() { // 目录列表 - let lang = /^\/doc\/([^\/]+)\//.exec(this.$route.path) - if (lang && lang[1]) { - this.lang = lang[1] - this.groupList = catalogList[this.lang] + let lang = /^\/(doc|help)\/([^\/]+)\//.exec(this.$route.path) + if (lang && lang[2]) { + this.type = lang[1]// 判断是开发文档还是帮助文档 + this.lang = lang[2] + // 过滤出对应文档的章节 + this.groupList = catalogList[this.lang].filter((item) => { + return item.type === this.type + }) } // 当前所在路径 - let path = /^\/doc\/[^\/]+\/([^\/]+)(\/|$)/.exec(this.$route.path) - if (path && path[1]) { - this.currentPath = path[1] + let path = /^\/(doc|help)\/[^\/]+\/([^\/]+)(\/|$)/.exec(this.$route.path) + if (path && path[2]) { + this.currentPath = path[2] } } } diff --git a/web/src/pages/Doc/en/changelog/index.md b/web/src/pages/Doc/en/changelog/index.md index 509a39d9..849ba902 100644 --- a/web/src/pages/Doc/en/changelog/index.md +++ b/web/src/pages/Doc/en/changelog/index.md @@ -1,5 +1,41 @@ # Changelog +## 0.6.11 + +New: 1.Optimize the mini map, remove node content within the mini map, and optimize performance. + +Demo: 1.Add a new topic and add tab differentiation to the topic list. 2.Node image upload supports inputting network image addresses. 3.Node image upload supports inputting network images. + +## 0.6.10 + +Fix: 1.Fix the issue of deleting a node after searching for it and not updating the search results when searching again. 2.Fixed an issue where the button for adjusting image size did not update after node operation. 3.Fix the issue of incorrect internal data deep copy location. 4.Fix the issue of ineffective line wrapping in rich text nodes. 5. Fix the issue of node swapping and loss when switching themes and other scenarios. + +New: 1.Search supports searching for white space characters and replacing them with white space characters. + +Demo: 1.Support calling up search through icon buttons. 2.Support for switching to dark mode through icon buttons. 3.Optimize search: The mouse is not in the search area and not focused, solving the problem of not being able to delete input text when the mouse is not in the search area. 4.Adjust the interface UI for adding node icons and add a series of node icons. 5.Add a sticker list. 6.Fixed the issue of missing focus in the input box after entering the search box. 7.Support clicking on the icon within the node to display an icon for quick replacement and deletion of the floating panel. + +## 0.6.9-fix.1 + +Fix: 1.Fix the issue of incorrect replacement after a single search. + +New: 1.We will no longer directly modify the incoming data object, but will make a deep copy internally. + +## 0.6.9 + +Fix: 1.Fixed an issue where setting styles to summary nodes would cause summary nodes to disappear. 2.Fixed the issue of node content not rendering when creating a root instance again when customizing node content. 3.Fix the issue of losing focus when adding a new node while the node is in editing. 2.Fix the issue of continuously pressing the tab key not being able to continuously create child nodes. + +New: 1.Replace existing ` ` in SVG when exporting Characters to avoid exporting SVG errors. 2.Support for search and replace. + +Demo: 1.When switching themes, it is supported to choose whether to overwrite the set basic style. + +## 0.6.8 + +Fix: 1.Change the shortcut key for inserting a summary to Ctrl+G to avoid conflicts with the save shortcut key. 2.Fix the issue of abnormal switching between rich text editing configuration input boxes while nodes are being edited. + +New: 1.Modify the copy, cut, and paste logic, and support pasting data from the clipboard. + +Demo: 1.Fix the issue of not saving the outer margin of the basic style setting node. 2.Supports automatic switching to dark mode based on the theme. + ## 0.6.7 Fix: 1.Fixed the issue of missing placeholder elements for the expand and collapse button after node collapse and expansion. 2.Fixed the issue of being able to scale images in read-only mode. diff --git a/web/src/pages/Doc/en/changelog/index.vue b/web/src/pages/Doc/en/changelog/index.vue index 1ee49304..c61d8f73 100644 --- a/web/src/pages/Doc/en/changelog/index.vue +++ b/web/src/pages/Doc/en/changelog/index.vue @@ -1,6 +1,24 @@ diff --git a/web/src/pages/Doc/en/node/index.md b/web/src/pages/Doc/en/node/index.md index 809ae16b..0a0d9deb 100644 --- a/web/src/pages/Doc/en/node/index.md +++ b/web/src/pages/Doc/en/node/index.md @@ -131,6 +131,8 @@ nodeData, `SET_NODE_DATA` command's shortcut method - `richText`: v0.4.2+,`Boolean`, If you want to set rich text content, that is, `html` character, `richText` needs to be passed `true` +- `resetRichText`: v0.6.10+, `Boolean`, whether to reset rich text, The default is 'false'. If 'true' is passed, the style of the rich text node will be reset + Setting the node text, a shortcut for the `SET_NODE_TEXT` command ### setImage(imgData) diff --git a/web/src/pages/Doc/en/node/index.vue b/web/src/pages/Doc/en/node/index.vue index bac896da..e892c349 100644 --- a/web/src/pages/Doc/en/node/index.vue +++ b/web/src/pages/Doc/en/node/index.vue @@ -76,7 +76,12 @@ if key is not passed, return the data object

nodeData, SET_NODE_DATA command's shortcut method

setText(text, richText)

Setting the node text, a shortcut for the SET_NODE_TEXT command

setImage(imgData)

diff --git a/web/src/pages/Doc/en/render/index.md b/web/src/pages/Doc/en/render/index.md index 41ca1e2e..a76e1504 100644 --- a/web/src/pages/Doc/en/render/index.md +++ b/web/src/pages/Doc/en/render/index.md @@ -61,7 +61,9 @@ Delete a specific node Copy a node, the active node is the node to be operated on, if there are multiple active nodes, only the first node will be operated on -### setNodeDataRender(node, data) +### setNodeDataRender(node, data, notRender) + +- `notRender`: v0.6.9+, `Boolean`, Default is `false`, Do not trigger rendering. Set node `data`, i.e. the data in the data field, and will determine whether the node needs to be re-rendered based on whether the node size has changed, `data` @@ -109,4 +111,22 @@ Expand to the node of the specified uid. - `uid`: uid of node -Find the corresponding node instance based on the uid. \ No newline at end of file +Find the corresponding node instance based on the uid. + +### copy() + +> v0.6.8+ + +Copy nodes. After calling this method, the current activated node data will be stored. Multiple activated nodes will only operate on the first node, and subsequent calls to the 'paste()' method can be pasted. + +### cut() + +> v0.6.8+ + +Cut a node. After calling this method, the currently active node will be cut and the node data will be stored. Multiple nodes will only operate on the first node, and subsequent calls to the 'paste()' method can be pasted. + +### paste() + +> v0.6.8+ + +Pasting nodes can be done by calling the 'copy()' or 'cut()' method after calling it. This method does not support pasting data from the user's clipboard. Please use the built-in 'Ctrl+v' shortcut key. \ No newline at end of file diff --git a/web/src/pages/Doc/en/render/index.vue b/web/src/pages/Doc/en/render/index.vue index cc61846d..2819d97d 100644 --- a/web/src/pages/Doc/en/render/index.vue +++ b/web/src/pages/Doc/en/render/index.vue @@ -37,7 +37,10 @@ disable the enter key and delete key related shortcuts to prevent conflicts

copyNode()

Copy a node, the active node is the node to be operated on, if there are multiple active nodes, only the first node will be operated on

-

setNodeDataRender(node, data)

+

setNodeDataRender(node, data, notRender)

+

Set node data, i.e. the data in the data field, and will determine whether the node needs to be re-rendered based on whether the node size has changed, data is an object, e.g. {text: 'I am new text'}

@@ -83,6 +86,21 @@ is an object, e.g. {text: 'I am new text'}

  • uid: uid of node
  • Find the corresponding node instance based on the uid.

    +

    copy()

    +
    +

    v0.6.8+

    +
    +

    Copy nodes. After calling this method, the current activated node data will be stored. Multiple activated nodes will only operate on the first node, and subsequent calls to the 'paste()' method can be pasted.

    +

    cut()

    +
    +

    v0.6.8+

    +
    +

    Cut a node. After calling this method, the currently active node will be cut and the node data will be stored. Multiple nodes will only operate on the first node, and subsequent calls to the 'paste()' method can be pasted.

    +

    paste()

    +
    +

    v0.6.8+

    +
    +

    Pasting nodes can be done by calling the 'copy()' or 'cut()' method after calling it. This method does not support pasting data from the user's clipboard. Please use the built-in 'Ctrl+v' shortcut key.

    diff --git a/web/src/pages/Doc/en/search/index.md b/web/src/pages/Doc/en/search/index.md new file mode 100644 index 00000000..9bb87174 --- /dev/null +++ b/web/src/pages/Doc/en/search/index.md @@ -0,0 +1,68 @@ +# Search plugin + +> v0.6.9+ + +This plugin provides the ability to search and replace node content. + +## Register + +```js +import MindMap from 'simple-mind-map' +import Search from 'simple-mind-map/src/plugins/Search.js' +MindMap.usePlugin(Search) +``` + +After registration and instantiation of `MindMap`, the instance can be obtained through `mindMap.Search`. + +## Event + +### search_info_change + +You can listen to 'search_info_change' event to get the number of current search results and the index currently located. + +```js +mindMap.on('search_info_change', (data) => { + /* + data: { + currentIndex,// Index, from zero + total + } + */ +}) +``` + +## Method + +### search(searchText, callback) + +- `searchText`: Text to search for + +- `callback`: The callback function that completes this search will be triggered after jumping to the node + +Search for node content, which can be called repeatedly. Each call will search and locate to the next matching node. If the search text changes, it will be searched again. + +### endSearch() + +End search. + +### replace(replaceText) + +- `replaceText`: Text to be replaced + +To replace the content of the current node, call the 'search' method after calling it to replace the content of the currently located matching node. + +### replaceAll(replaceText) + +- `replaceText`: Text to be replaced + +Replace all matching node contents, and call it after calling the 'search' method. + +### getReplacedText(node, searchText, replaceText) + +- `node`: Node instance + +- `searchText`: Text to search for + +- `replaceText`: Text to be replaced + +Return the text content of the node after search and replacement. Note that the node content will not be actually changed, but is only used to calculate the content of a node after replacement. \ No newline at end of file diff --git a/web/src/pages/Doc/en/search/index.vue b/web/src/pages/Doc/en/search/index.vue new file mode 100644 index 00000000..600bcaf8 --- /dev/null +++ b/web/src/pages/Doc/en/search/index.vue @@ -0,0 +1,74 @@ + + + + + \ No newline at end of file diff --git a/web/src/pages/Doc/en/utils/index.md b/web/src/pages/Doc/en/utils/index.md index b6dd1037..71bb0f58 100644 --- a/web/src/pages/Doc/en/utils/index.md +++ b/web/src/pages/Doc/en/utils/index.md @@ -181,6 +181,55 @@ Get the size of image, return: } ``` +#### loadImage(imgFile) + +> v0.6.8+ + +- `imgFile`: File object of image type + +Load image, return: + +```js +{ + url,// DataUrl + size// { width, height } width and height of image +} +``` + +#### getType(data) + +> v0.6.9+ + +Get the type of a data, such as `Boolean`、`Array`. + +#### removeHtmlStyle(html) + +> v0.6.10+ + +Remove the inline style of nodes in the HTML string. + +#### addHtmlStyle(html, tag, style) + +> v0.6.10+ + +Add inline styles to the specified tags in the HTML tag. + +#### checkIsRichText(str) + +> v0.6.10+ + +Check if a string is a rich text character. + +#### isWhite(color) + +> v0.6.11+ + +Determine whether a color is white. + +#### isTransparent(color) + +Determine whether a color is transparent. + ## Simulate CSS background in Canvas Import: diff --git a/web/src/pages/Doc/en/utils/index.vue b/web/src/pages/Doc/en/utils/index.vue index e09a2070..1fa4504b 100644 --- a/web/src/pages/Doc/en/utils/index.vue +++ b/web/src/pages/Doc/en/utils/index.vue @@ -121,6 +121,46 @@ and copying the data of the data object, example:

    height } +

    loadImage(imgFile)

    +
    +

    v0.6.8+

    +
    + +

    Load image, return:

    +
    {
    +  url,// DataUrl
    +  size// { width, height } width and height of image
    +}
    +
    +

    getType(data)

    +
    +

    v0.6.9+

    +
    +

    Get the type of a data, such as BooleanArray.

    +

    removeHtmlStyle(html)

    +
    +

    v0.6.10+

    +
    +

    Remove the inline style of nodes in the HTML string.

    +

    addHtmlStyle(html, tag, style)

    +
    +

    v0.6.10+

    +
    +

    Add inline styles to the specified tags in the HTML tag.

    +

    checkIsRichText(str)

    +
    +

    v0.6.10+

    +
    +

    Check if a string is a rich text character.

    +

    isWhite(color)

    +
    +

    v0.6.11+

    +
    +

    Determine whether a color is white.

    +

    isTransparent(color)

    +

    Determine whether a color is transparent.

    Simulate CSS background in Canvas

    Import:

    import drawBackgroundImageToCanvas from 'simple-mind-map/src/utils/simulateCSSBackgroundInCanvas'
    diff --git a/web/src/pages/Doc/routerList.js b/web/src/pages/Doc/routerList.js
    index 1f08e498..dd4d9db7 100644
    --- a/web/src/pages/Doc/routerList.js
    +++ b/web/src/pages/Doc/routerList.js
    @@ -27,6 +27,7 @@ export default [
           { path: 'course18', title: '如何持久化数据' },
           { path: 'course19', title: '插入和扩展节点图标' },
           { path: 'course20', title: '如何自定义节点内容' },
    +      { path: 'course21', title: '如何复制、剪切、粘贴' },
           { path: 'doExport', title: 'Export 插件' },
           { path: 'drag', title: 'Drag插件' },
           { path: 'introduction', title: '简介' },
    @@ -47,7 +48,10 @@ export default [
           { path: 'deploy', title: '部署' },
           { path: 'client', title: '客户端' },
           { path: 'touchEvent', title: 'TouchEvent插件' },
    -      { path: 'nodeImgAdjust', title: 'NodeImgAdjust插件' }
    +      { path: 'nodeImgAdjust', title: 'NodeImgAdjust插件' },
    +      { path: 'search', title: 'Search插件' },
    +      { path: 'help1', title: '概要/关联线' },
    +      { path: 'help2', title: '客户端' }
         ]
       },
       {
    @@ -77,7 +81,8 @@ export default [
           { path: 'xmind', title: 'XMind parse' },
           { path: 'deploy', title: 'Deploy' },
           { path: 'touchEvent', title: 'TouchEvent plugin' },
    -      { path: 'nodeImgAdjust', title: 'NodeImgAdjust plugin' }
    +      { path: 'nodeImgAdjust', title: 'NodeImgAdjust plugin' },
    +      { path: 'search', title: 'Search plugin' }
         ]
       }
     ]
    diff --git a/web/src/pages/Doc/zh/changelog/index.md b/web/src/pages/Doc/zh/changelog/index.md
    index 72584967..00ec2448 100644
    --- a/web/src/pages/Doc/zh/changelog/index.md
    +++ b/web/src/pages/Doc/zh/changelog/index.md
    @@ -1,5 +1,41 @@
     # Changelog
     
    +## 0.6.11
    +
    +新增:1.优化小地图,去除小地图内的节点内容,优化性能。
    +
    +Demo:1.新增主题、主题列表新增tab区分。 2.节点图片上传支持输入网络图片地址。 3.节点图片上传支持输入网络图片。
    +
    +## 0.6.10
    +
    +修复:1.修复搜索定位到某个节点后删除该节点,再次搜索时搜索结果未更新的问题。 2.修复调整图片大小的按钮在节点操作后没有更新的问题。 3.修复内部数据深拷贝位置不正确的问题。 4.修复富文本节点换行不生效的问题。 5.修复切换主题等场景时节点换行会丢失的问题。
    +
    +新增:1.搜索支持搜索空白字符和替换为空白字符。
    +
    +Demo:1.支持通过图标按钮调出搜索。 2.支持通过图标按钮切换暗黑模式。 3.优化搜索:鼠标不在搜索区域内不聚焦,解决鼠标不在搜索区域内无法删除输入的文字的问题。 4.调整添加节点图标的界面UI,新增系列节点图标。 5.新增贴纸列表。 6.修复在搜索框回车后输入框焦点丢失的问题。 7.支持点击节点内的图标显示一个图标快捷替换和删除悬浮面板。 
    +
    +## 0.6.9-fix.1
    +
    +修复:1.修复搜索进行一次单个替换后再全部替换不正确的问题。
    +
    +新增:1.不会再直接修改传入的data对象,内部会深拷贝一份。
    +
    +## 0.6.9
    +
    +修复:1.修复给概要节点设置样式概要节点会消失的问题。2.修复自定义节点内容时,二次创建根实例时节点内容不渲染的问题。3.修复节点处于编辑中时添加新节点时新节点的焦点丢失问题。 2.修复连续按tab键无法连续创建子节点的问题。
    +
    +新增:1.导出svg时替换svg中存在的` `字符,避免导出的svg报错。 2.支持搜索和替换。
    +
    +Demo:1.切换主题时支持选择是否覆盖设置过的基础样式。
    +
    +## 0.6.8
    +
    +修复:1.修改插入概要的快捷键为Ctrl+G,避免和保存快捷键冲突。 2.修复节点正在编辑时切换富文本编辑配置输入框出现异常的问题。
    +
    +新增:1.修改复制、剪切、粘贴逻辑,支持粘贴剪切板中的数据。
    +
    +Demo:1.修复基础样式-设置节点外边距未保存的问题。 2.支持根据主题自动切换为暗黑模式。
    +
     ## 0.6.7
     
     修复:1.修复节点收起再展开后展开收起按钮占位元素丢失的问题。 2.修复只读模式下可以缩放图片的问题。
    diff --git a/web/src/pages/Doc/zh/changelog/index.vue b/web/src/pages/Doc/zh/changelog/index.vue
    index 071e4cab..0103219d 100644
    --- a/web/src/pages/Doc/zh/changelog/index.vue
    +++ b/web/src/pages/Doc/zh/changelog/index.vue
    @@ -1,6 +1,24 @@
     
    diff --git a/web/src/pages/Doc/zh/course21/index.md b/web/src/pages/Doc/zh/course21/index.md
    new file mode 100644
    index 00000000..0a049f9d
    --- /dev/null
    +++ b/web/src/pages/Doc/zh/course21/index.md
    @@ -0,0 +1,40 @@
    +# 如何复制、剪切、粘贴
    +
    +## 使用快捷键
    +
    +核心库内部默认支持`Ctrl+c`、`Ctrl+x`、`Ctrl+v`三个快捷键来执行复制、剪切、粘贴操作。
    +
    +当激活了某个节点,按`Ctrl+c`会复制当前激活节点的数据,按`Ctrl+x`会删除当前激活节点,同时保存该节点的数据,这两个操作当同时存在多个激活节点,只会对第一个生效。
    +
    +当按了`Ctrl+c`或`Ctrl+x`后,按`Ctrl+v`会在当前激活的节点粘贴复制或剪切的数据,也就是被复制或剪切的节点会作为该节点的子节点。
    +
    +除了支持粘贴在画布中复制或剪切的节点数据外,如果你再其他地方复制了文本或图片,也支持进行粘贴,也就是会粘贴你当前剪贴板中的数据,如果你的剪切板中存在文本数据,那么会粘贴作为当前激活节点的子节点,如果存在图片数据,那么会直接给当前激活节点添加或替换图片。
    +
    +如果复制或剪切了画布数据,同时剪切板中也存在数据,那么默认会以最新的`Ctrl+c`或`Ctrl+x`操作为准,比如你先复制了节点,然后又复制了其他地方的文本,那么会粘贴最后一次的操作,也就是其他地方复制的文本数据。
    +
    +## 使用按钮触发
    +
    +一般会在右键菜单上下文中显然复制、剪切、粘贴三个按钮,当点击了这三个按钮也需要能执行复制、剪切、粘贴操作,这需要调用内部的一些方法来完成:
    +
    +```js
    +// 点击了复制按钮
    +const onCopyBtnClick = () => {
    +    mindMap.renderer.copy()
    +}
    +
    +// 点击了剪切按钮
    +const onCutBtnClick = () => {
    +    mindMap.renderer.cut()
    +}
    +
    +// 点击了粘贴按钮
    +const onPasteBtnClick = () => {
    +    mindMap.renderer.paste()
    +}
    +```
    +
    +需要注意的是,这三个方法只能复制、剪切、粘贴画布中的节点数据,不支持操作用户的剪切板数据。
    +
    +### 完整示例
    +
    +