`
+ 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}[^>]*)(>[^<>]*${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 @@
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.
New: 1.Support locating to a node based on node instance or node uid. 2.Modify the creation method of node uids and export data to add node uids.
diff --git a/web/src/pages/Doc/en/constructor/index.md b/web/src/pages/Doc/en/constructor/index.md
index d4ca44d4..b5a3eaca 100644
--- a/web/src/pages/Doc/en/constructor/index.md
+++ b/web/src/pages/Doc/en/constructor/index.md
@@ -246,6 +246,7 @@ Listen to an event. Event list:
| associative_line_click(v0.4.5+) | Triggered when an associated line is clicked | path(Connector node)、clickPath(Invisible click line node)、node(Start node)、toNode(Target node) |
| svg_mouseenter(v0.5.1+) | Triggered when the mouse moves into the SVG canvas | e(event object) |
| svg_mouseleave(v0.5.1+) | Triggered when the mouse moves out of the SVG canvas | e(event object) |
+| node_icon_click(v0.6.10+) | Triggered when clicking on an icon within a node | this(node instance)、item(Click on the icon name)、e(event object) |
### emit(event, ...args)
@@ -333,7 +334,7 @@ redo. All commands are as follows:
| UNEXPAND_ALL | Collapse all nodes | |
| UNEXPAND_TO_LEVEL (v0.2.8+) | Expand to a specified level | level (the level to expand to, 1, 2, 3...) |
| SET_NODE_DATA | Update node data, that is, update the data in the data object of the node data object | node (the node to set), data (object, the data to update, e.g. `{expand: true}`) |
-| SET_NODE_TEXT | Set node text | node (the node to set), text (the new text for the node), richText(v0.4.0+, If you want to set a rich text character, you need to set it to `true`) |
+| SET_NODE_TEXT | Set node text | node (the node to set), text (the new text for the node), richText(v0.4.0+, If you want to set a rich text character, you need to set it to `true`)、resetRichText(v0.6.10+Do you want to reset rich text? The default is false. If true is passed, the style of the rich text node will be reset) |
| SET_NODE_IMAGE | Set Node Image | node (node to set), imgData (object, image information, structured as: `{url, title, width, height}`, the width and height of the image must be passed) |
| SET_NODE_ICON | Set Node Icon | node (node to set), icons (array, predefined image names array, available icons can be obtained in the nodeIconList list in the [icons.js](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/svg/icons.js) file, icon name is type_name, such as ['priority_1']) |
| SET_NODE_HYPERLINK | Set Node Hyperlink | node (node to set), link (hyperlink address), title (hyperlink name, optional) |
@@ -347,7 +348,7 @@ redo. All commands are as follows:
| SET_NODE_CUSTOM_POSITION (v0.2.0+) | Set a custom position for a node | node (the node to set), left (custom x coordinate, default is undefined), top (custom y coordinate, default is undefined) |
| RESET_LAYOUT (v0.2.0+) | Arrange layout with one click | |
| SET_NODE_SHAPE (v0.2.4+) | Set the shape of a node | node (the node to set), shape (the shape, all shapes: [Shape.js](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/core/render/node/Shape.js)) |
-| GO_TARGET_NODE(v0.6.7+) | Navigate to a node, and if the node is collapsed, it will automatically expand to that node | node(Node instance or node uid to locate) |
+| GO_TARGET_NODE(v0.6.7+) | Navigate to a node, and if the node is collapsed, it will automatically expand to that node | node(Node instance or node uid to locate)、callback(v0.6.9+, Callback function after positioning completion) |
### setData(data)
diff --git a/web/src/pages/Doc/en/constructor/index.vue b/web/src/pages/Doc/en/constructor/index.vue
index 194a7e7d..c8f70d61 100644
--- a/web/src/pages/Doc/en/constructor/index.vue
+++ b/web/src/pages/Doc/en/constructor/index.vue
@@ -714,6 +714,11 @@ poor performance and should be used sparingly.
Triggered when the mouse moves out of the SVG canvas
e(event object)
+
+
node_icon_click(v0.6.10+)
+
Triggered when clicking on an icon within a node
+
this(node instance)、item(Click on the icon name)、e(event object)
+
emit(event, ...args)
@@ -853,7 +858,7 @@ redo. All commands are as follows:
SET_NODE_TEXT
Set node text
-
node (the node to set), text (the new text for the node), richText(v0.4.0+, If you want to set a rich text character, you need to set it to true)
+
node (the node to set), text (the new text for the node), richText(v0.4.0+, If you want to set a rich text character, you need to set it to true)、resetRichText(v0.6.10+Do you want to reset rich text? The default is false. If true is passed, the style of the rich text node will be reset)
SET_NODE_IMAGE
@@ -923,7 +928,7 @@ redo. All commands are as follows:
GO_TARGET_NODE(v0.6.7+)
Navigate to a node, and if the node is collapsed, it will automatically expand to that node
-
node(Node instance or node uid to locate)
+
node(Node instance or node uid to locate)、callback(v0.6.9+, Callback function after positioning completion)
diff --git a/web/src/pages/Doc/en/deploy/index.md b/web/src/pages/Doc/en/deploy/index.md
index 4a8d593f..44f11bb9 100644
--- a/web/src/pages/Doc/en/deploy/index.md
+++ b/web/src/pages/Doc/en/deploy/index.md
@@ -1 +1,66 @@
-# Deploy
\ No newline at end of file
+# Deploy
+
+The 'web' directory of this project provides a complete project developed based on the 'simple mind map' library, 'Vue2. x', and 'ElementUI'. The data is stored locally on the computer by default, and can also be manipulated locally on the computer. Originally intended as an online 'demo', it can also be directly used as an online version of the mind map application, online address: [https://wanglin2.github.io/mind-map/](https://wanglin2.github.io/mind-map/).
+
+If your network environment is slow to access the 'GitHub' service, you can also deploy it to your server.
+
+## Deploying to a static file server
+
+The project itself does not rely on the backend, so it can be deployed to a static file server. The following commands can be executed in sequence:
+
+```bash
+git clone https://github.com/wanglin2/mind-map.git
+cd mind-map
+cd simple-mind-map
+npm i
+npm link
+cd ..
+cd web
+npm i
+npm link simple-mind-map
+```
+
+Then you can choose to start the local service:
+
+```bash
+npm run serve
+```
+
+You can also directly package and generate construction products:
+
+```bash
+npm run build
+```
+
+The packaged entry page 'index.html' can be found in the project root directory, and the corresponding static resources are located in the 'dist' directory under the root directory. The 'html' file will access the resources in the 'dist' directory through relative paths, such as 'dist/xxx'. You can directly upload these two files or directories to your static file server. In fact, this project is deployed to 'GitHub Pages' in this way.
+
+If you do not have any code modification requirements, it is also possible to directly copy these files from this repository.
+
+If you want to package 'index.html' into the 'dist' directory as well, you can modify the 'scripts.build' command in the 'web/package.json' file to delete '&& node ../copy.js' from 'vue-cli-service build && node ../copy.js'.
+
+If you want to modify the directory for packaging output, you can modify the 'outputDir' configuration of the 'web/vue.config.js' file to the path you want to output.
+
+If you want to modify the path of the 'index. html' file referencing static resources, you can modify the 'publicPath' configuration of the 'web/vue.config.js' file.
+
+In addition, the default route used is 'hash ', which means that there will be '#'in the path. If you want to use the 'history' route, you can modify the 'web/src/router.js' file to:
+
+```js
+const router = new VueRouter({
+ routes
+})
+```
+
+Change to:
+
+```js
+const router = new VueRouter({
+ mode: 'history',
+ routes
+})
+```
+
+However, this requires backend support, as our application is a single page client application. If the backend is not properly configured, users will return 404 when accessing sub routes directly in the browser. Therefore, you need to add a candidate resource on the server that covers all situations: if the 'URL' cannot match any static resources, the same 'index. html' page should be returned.
+
+## Docker
+
+In writing...
\ No newline at end of file
diff --git a/web/src/pages/Doc/en/deploy/index.vue b/web/src/pages/Doc/en/deploy/index.vue
new file mode 100644
index 00000000..b12696d2
--- /dev/null
+++ b/web/src/pages/Doc/en/deploy/index.vue
@@ -0,0 +1,55 @@
+
+
+
Deploy
+
The 'web' directory of this project provides a complete project developed based on the 'simple mind map' library, 'Vue2. x', and 'ElementUI'. The data is stored locally on the computer by default, and can also be manipulated locally on the computer. Originally intended as an online 'demo', it can also be directly used as an online version of the mind map application, online address: https://wanglin2.github.io/mind-map/.
+
If your network environment is slow to access the 'GitHub' service, you can also deploy it to your server.
+
Deploying to a static file server
+
The project itself does not rely on the backend, so it can be deployed to a static file server. The following commands can be executed in sequence:
+
git clone https://github.com/wanglin2/mind-map.git
+cd mind-map
+cd simple-mind-map
+npm i
+npm link
+cd ..
+cd web
+npm i
+npm link simple-mind-map
+
+
Then you can choose to start the local service:
+
npm run serve
+
+
You can also directly package and generate construction products:
+
npm run build
+
+
The packaged entry page 'index.html' can be found in the project root directory, and the corresponding static resources are located in the 'dist' directory under the root directory. The 'html' file will access the resources in the 'dist' directory through relative paths, such as 'dist/xxx'. You can directly upload these two files or directories to your static file server. In fact, this project is deployed to 'GitHub Pages' in this way.
+
If you do not have any code modification requirements, it is also possible to directly copy these files from this repository.
+
If you want to package 'index.html' into the 'dist' directory as well, you can modify the 'scripts.build' command in the 'web/package.json' file to delete '&& node ../copy.js' from 'vue-cli-service build && node ../copy.js'.
+
If you want to modify the directory for packaging output, you can modify the 'outputDir' configuration of the 'web/vue.config.js' file to the path you want to output.
+
If you want to modify the path of the 'index. html' file referencing static resources, you can modify the 'publicPath' configuration of the 'web/vue.config.js' file.
+
In addition, the default route used is 'hash ', which means that there will be '#'in the path. If you want to use the 'history' route, you can modify the 'web/src/router.js' file to:
However, this requires backend support, as our application is a single page client application. If the backend is not properly configured, users will return 404 when accessing sub routes directly in the browser. Therefore, you need to add a candidate resource on the server that covers all situations: if the 'URL' cannot match any static resources, the same 'index. html' page should be returned.
+
Docker
+
In writing...
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/web/src/pages/Doc/en/introduction/index.md b/web/src/pages/Doc/en/introduction/index.md
index c567ffd9..70a287e7 100644
--- a/web/src/pages/Doc/en/introduction/index.md
+++ b/web/src/pages/Doc/en/introduction/index.md
@@ -160,4 +160,16 @@ Open source is not easy. If this project is helpful to you, you can invite the a
Chris
+
+
+
水车
+
+
+
+
仓鼠
+
+
+
+
千帆
+
\ No newline at end of file
diff --git a/web/src/pages/Doc/en/introduction/index.vue b/web/src/pages/Doc/en/introduction/index.vue
index 7f99b20d..9c04d3d7 100644
--- a/web/src/pages/Doc/en/introduction/index.vue
+++ b/web/src/pages/Doc/en/introduction/index.vue
@@ -119,6 +119,18 @@ full screen, support mini map
Chris
+
+
+
水车
+
+
+
+
仓鼠
+
+
+
+
千帆
+
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)
-
richText: v0.4.2+,Boolean, If you want to set rich text content, that is, html character, richText needs to be passed true
+
+
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/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)
+
+
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
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 @@
+
+
+
Search plugin
+
+
v0.6.9+
+
+
This plugin provides the ability to search and replace node content.
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.
+
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/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+
+
+
+
imgFile: File object of image type
+
+
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 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.
+
+
+
+
+
\ No newline at end of file
diff --git a/web/src/pages/Doc/zh/introduction/index.md b/web/src/pages/Doc/zh/introduction/index.md
index f175c478..fd33a531 100644
--- a/web/src/pages/Doc/zh/introduction/index.md
+++ b/web/src/pages/Doc/zh/introduction/index.md
@@ -151,4 +151,16 @@
Chris
+
+
+
水车
+
+
+
+
仓鼠
+
+
+
+
千帆
+
\ No newline at end of file
diff --git a/web/src/pages/Doc/zh/introduction/index.vue b/web/src/pages/Doc/zh/introduction/index.vue
index d3cca190..7cd3ab6c 100644
--- a/web/src/pages/Doc/zh/introduction/index.vue
+++ b/web/src/pages/Doc/zh/introduction/index.vue
@@ -111,6 +111,18 @@