code-scan starred remind
2022-3-5 13:30:51 Author: github.com(查看原文) 阅读量:15 收藏

Build packages Azure Static Web Apps CI/CD Quality Gate Status

A headless, framework-agnostic and extendable mindmap editor.

Try on https://remind.applet.ink

Play on https://stackblitz.com/edit/typescript-nwp9sk?file=index.ts

Feature

  • Highly extendable, take full control over styling and behavior
  • With default undo, redo, navigation, drag, CRUD, shortcut implementation (but can be replaced)
  • Framework-agnostic, remind can work with vanilla javascript, vue, react or any other framework
  • TypeScript, remind is written is typescript and has great typescript support

Installation

npm i remind-core remind-contributions

Quick Start

import { createMindmap, TopicData } from 'remind-core'
import 'remind-core/dist/style.css'
import { contributions } from 'remind-contributions'

const customData: TopicData = {
  id: '7bf8fd567273',
  title: 'Central Topic',
  children: [
    {
      title: 'main topic 1',
      id: 'f4cb61397246',
    },
    {
      title: 'main topic 2',
      id: 'fa4df6c9708c',
      children: [
        {
          title: 'sub topic 1',
          id: 'f4cb61397241',
        },
      ],
    },
  ],
}

createMindmap(document.querySelector('#app')!, {
  value: customData,
  contributions,
})

API

instance: ContributionAPI = createMindmap(containerNode, options)

Render mindmap into containerNode, and return a instance.

options

option type description default optional
value TopicData set mindmap value - true
onChange (value: TopicData) => void listen to value change - true
locale 'en' | 'cn' | 'ja' language localization en true
theme Theme custom theme - true
contributions Function extend editor's functionality [] true

Contribution let you extend editor's functionality, custom editor's behavior or add custom render content. For more information, see packages/contributions/src

types

interface ContributionAPI {
  model: IModelStructure & IModelTrait
  viewModel: IViewModelStructure & IViewModelTrait
  view: RefObject<HTMLDivElement>
  locale: IntlContent
}
interface TopicData {
  id: string
  title: string
  children?: TopicData[]
  depth?: number
}
interface Theme {
  link: {
    stroke: string
    strokeWidth: number
  }
  topic: Record<string, unknown>
  mainColor: string
}

License

MIT License


文章来源: https://github.com/luvsic3/remind
如有侵权请联系:admin#unsafe.sh