{"id":13440155,"url":"https://github.com/SSShooter/mind-elixir-core","last_synced_at":"2025-03-20T09:32:11.498Z","repository":{"id":37359286,"uuid":"199951138","full_name":"SSShooter/mind-elixir-core","owner":"SSShooter","description":"⚗ Mind Elixir is a framework agnostic mind map core.","archived":false,"fork":false,"pushed_at":"2024-03-12T13:59:26.000Z","size":3890,"stargazers_count":1850,"open_issues_count":16,"forks_count":273,"subscribers_count":28,"default_branch":"master","last_synced_at":"2024-04-14T00:48:43.133Z","etag":null,"topics":["graph","mind-map","mind-mapping","mindmap","tool","visualization"],"latest_commit_sha":null,"homepage":"https://docs.mind-elixir.com/","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/SSShooter.png","metadata":{"files":{"readme":"readme.cn.md","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null},"funding":{"github":null,"patreon":null,"open_collective":"ssshooter","ko_fi":null,"tidelift":null,"community_bridge":null,"liberapay":null,"issuehunt":null,"otechie":null,"custom":null}},"created_at":"2019-08-01T01:04:36.000Z","updated_at":"2024-04-11T15:35:09.000Z","dependencies_parsed_at":"2024-02-09T15:03:44.638Z","dependency_job_id":"4e48f654-f91d-4281-bb00-29fb10c6d1ee","html_url":"https://github.com/SSShooter/mind-elixir-core","commit_stats":{"total_commits":492,"total_committers":15,"mean_commits":32.8,"dds":0.2804878048780488,"last_synced_commit":"cd638e7c618bed6fe7c1d01991918b0240e943d1"},"previous_names":[],"tags_count":58,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SSShooter%2Fmind-elixir-core","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SSShooter%2Fmind-elixir-core/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SSShooter%2Fmind-elixir-core/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SSShooter%2Fmind-elixir-core/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/SSShooter","download_url":"https://codeload.github.com/SSShooter/mind-elixir-core/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":221745263,"owners_count":16873742,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["graph","mind-map","mind-mapping","mindmap","tool","visualization"],"created_at":"2024-07-31T03:01:20.268Z","updated_at":"2024-10-27T23:31:06.064Z","avatar_url":"https://github.com/SSShooter.png","language":"TypeScript","readme":"\u003cp align=\"center\"\u003e\u003ca href=\"mind-elixir.com\" target=\"_blank\" rel=\"noopener noreferrer\"\u003e\u003cimg width=\"150\" src=\"https://raw.githubusercontent.com/ssshooter/mind-elixir-core/master/images/logo2.png\" alt=\"mindelixir logo2\"\u003e\u003c/a\u003e\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://www.npmjs.com/package/mind-elixir\"\u003e\n    \u003cimg src=\"https://img.shields.io/npm/v/mind-elixir\" alt=\"version\"\u003e\n  \u003c/a\u003e\n  \u003cimg src=\"https://img.shields.io/npm/l/mind-elixir\" alt=\"license\"\u003e\n  \u003ca href=\"https://app.codacy.com/gh/ssshooter/mind-elixir-core?utm_source=github.com\u0026utm_medium=referral\u0026utm_content=ssshooter/mind-elixir-core\u0026utm_campaign=Badge_Grade_Settings\"\u003e\n    \u003cimg src=\"https://api.codacy.com/project/badge/Grade/09fadec5bf094886b30cea6aabf3a88b\" alt=\"code quality\"\u003e\n  \u003c/a\u003e\n  \u003ca href=\"https://bundlephobia.com/result?p=mind-elixir\"\u003e\n    \u003cimg src=\"https://badgen.net/bundlephobia/dependency-count/mind-elixir\" alt=\"dependency-count\"\u003e\n  \u003c/a\u003e\n  \u003ca href=\"https://packagephobia.com/result?p=mind-elixir\"\u003e\n    \u003cimg src=\"https://packagephobia.com/badge?p=mind-elixir\" alt=\"dependency-count\"\u003e\n  \u003c/a\u003e\n\u003c/p\u003e\n\nMind elixir 是一个无框架依赖的思维导图内核\n\n[English](https://github.com/ssshooter/mind-elixir-core/blob/master/readme.md)\n\n## 立即尝试\n\n![mindelixir](https://raw.githubusercontent.com/ssshooter/mind-elixir-core/master/images/screenshot2.png)\n\nhttps://mind-elixir.com/#/\n\n### Playground\n\nhttps://codepen.io/ssshooter/pen/GVQRYK\n\nwith React https://codesandbox.io/s/mind-elixir-react-9sisb\n\nwith Vue https://codesandbox.io/s/mind-elixir-vue-nqjjl\n\n## 如何使用\n\n### 安装\n\n#### NPM\n\n```bash\nnpm i mind-elixir -S\n```\n\n```javascript\nimport MindElixir, { E } from 'mind-elixir'\n```\n\n#### Script 标签\n\n```html\n\u003cscript type=\"module\" src=\"https://cdn.jsdelivr.net/npm/mind-elixir/dist/mind-elixir.js\"\u003e\u003c/script\u003e\n```\n\n### HTML 结构\n\n```html\n\u003cdiv id=\"map\"\u003e\u003c/div\u003e\n\u003cstyle\u003e\n  #map {\n    height: 500px;\n    width: 100%;\n  }\n\u003c/style\u003e\n```\n\n### 初始化\n\n```javascript\nimport MindElixir, { E } from 'mind-elixir'\nimport { exportSvg, exportPng } from '../dist/painter'\nimport example from '../dist/example1'\n\nlet options = {\n  el: '#map',\n  direction: MindElixir.LEFT,\n  // create new map data\n  data: MindElixir.new('new topic') or example,\n  // the data return from `.getData()`\n  draggable: true, // default true\n  contextMenu: true, // default true\n  toolBar: true, // default true\n  nodeMenu: true, // default true\n  keypress: true, // default true\n  locale: 'en', // [zh_CN,zh_TW,en,ja,pt] waiting for PRs\n  overflowHidden: false, // default false\n  mainLinkStyle: 2, // [1,2] default 1\n  contextMenuOption: {\n    focus: true,\n    link: true,\n    extend: [\n      {\n        name: 'Node edit',\n        onclick: () =\u003e {\n          alert('extend menu')\n        },\n      },\n    ],\n  },\n  allowUndo: false,\n  before: {\n    insertSibling(el, obj) {\n      return true\n    },\n    async addChild(el, obj) {\n      await sleep()\n      return true\n    },\n  },\n}\n\nlet mind = new MindElixir(options)\nmind.init()\n\n// get a node\nE('node-id')\n\n```\n\n### 数据结构\n\n```javascript\n// whole node data structure up to now\n{\n  topic: 'node topic',\n  id: 'bd1c24420cd2c2f5',\n  style: { fontSize: '32', color: '#3298db', background: '#ecf0f1' },\n  parent: null,\n  tags: ['Tag'],\n  icons: ['😀'],\n  hyperLink: 'https://github.com/ssshooter/mind-elixir-core',\n}\n```\n\n### 事件处理\n\n```javascript\nmind.bus.addListener('operation', operation =\u003e {\n  console.log(operation)\n  // return {\n  //   name: action name,\n  //   obj: target object\n  // }\n\n  // name: [insertSibling|addChild|removeNode|beginEdit|finishEdit]\n  // obj: target\n\n  // name: moveNode\n  // obj: {from:target1,to:target2}\n})\n\nmind.bus.addListener('selectNode', node =\u003e {\n  console.log(node)\n})\n\nmind.bus.addListener('expandNode', node =\u003e {\n  console.log('expandNode: ', node)\n})\n```\n\n### 数据导出\n\n```javascript\nmind.getData() // javascript object, see src/example.js\nmind.getDataString() // stringify object\nmind.getDataMd() // markdown\n```\n\n### 输出图片\n\n**WIP**\n\n```javascript\nimport painter from 'mind-elixir/dist/painter'\npainter.exportSvg()\npainter.exportPng()\n```\n\n### 操作拦截\n\n```javascript\nlet mind = new MindElixir({\n  ...\n  before: {\n    insertSibling(el, obj) {\n      console.log(el, obj)\n      if (this.currentNode.nodeObj.parent.root) {\n        return false\n      }\n      return true\n    },\n    async addChild(el, obj) {\n      await sleep()\n      if (this.currentNode.nodeObj.parent.root) {\n        return false\n      }\n      return true\n    },\n  },\n})\n```\n\n## 文档\n\nhttps://docs.mind-elixir.com/zh-Hans/\n","funding_links":["https://opencollective.com/ssshooter"],"categories":["HarmonyOS","TypeScript","工具列表"],"sub_categories":["Windows Manager","前端开发"],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FSSShooter%2Fmind-elixir-core","html_url":"https://awesome.ecosyste.ms/projects/github.com%2FSSShooter%2Fmind-elixir-core","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FSSShooter%2Fmind-elixir-core/lists"}