Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@accordproject/markdown-editor

Package Overview
Dependencies
Maintainers
6
Versions
623
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@accordproject/markdown-editor

[![downloads](https://img.shields.io/npm/dm/@accordproject/markdown-editor)](https://www.npmjs.com/package/@accordproject/markdown-editor) [![npm version](https://badge.fury.io/js/%40accordproject%2Fmarkdown-editor.svg)](https://badge.fury.io/js/%40accord

  • 0.92.3-20200608223626
  • npm
  • Socket score

Version published
Weekly downloads
126
decreased by-83.74%
Maintainers
6
Weekly downloads
 
Created
Source

Accord Project Web Components Markdown Editor

downloads npm version join slack

This repository contains a WYSIWYG editor for markdown that conforms to the CommonMark specification.

The editor is based on React, Slate, and the Accord Project markdown-transform project.

Installation

npm install @accordproject/markdown-editor @accordproject/markdown-slate slate slate-history slate-react semantic-ui-react

Implementation

import React, { useState, useCallback } from 'react';
import ReactDOM from 'react-dom';
import { SlateTransformer } from '@accordproject/markdown-slate';
import { MarkdownEditor } from '@accordproject/markdown-editor';

const slateTransformer = new SlateTransformer();
const defaultMarkdown = `This is text. You can edit it.`;

const App = () => {
  const [slateValue, setSlateValue] = useState(() => {
    const slate = slateTransformer.fromMarkdown(defaultMarkdown);
    return slate.document.children;
  });

  const onSlateValueChange = useCallback((slateChildren) => {
    localStorage.setItem('slate-editor-value', JSON.stringify(slateChildren));
    const slateValue = { document: { children: slateChildren } };
    setSlateValue(slateValue.document.children);
  }, []);

  return (<MarkdownEditor readOnly={false} value={slateValue} onChange={onSlateValueChange} />);
}

ReactDOM.render(<App />, document.getElementById('root'));

Develop inside Storybook

While Storybook is running, if you make a change in a package that you want to see reflected in the demo, in a new terminal:

cd packages/markdown-editor
npm run build

Storybook will reload with the applied changes.

Props

Required Properties

Values
  • value: An array which is the initial contents of the editor (markdown text)
Functionality
  • onChange: A callback function called when contents of the editor change, receives the markdown text

Optional Properties

Values
  • readOnly: A boolean to lock all text and remove the formatting toolbar
  • placeholder: Placeholder string for text when the editor is blank
  • activeButton: Optional object to change formatting button active state color
    • { background: '#FFF', symbol: '#000' }
Functionality
  • onChange: A callback function called when contents of the editor change, receives the markdown text
  • augmentEditor: A higher order function to augment the methods on the Slate editor
  • customElements: A function for extending elements rendered by editor
  • isEditable: A function for determining if the current edit should be allowed
  • canBeFormatted: A function that determines if current formatting change should be allowed
  • canCopy: A function that determines if current selection copy should be allowed
  • canKeyDown: A function that determines if current key event should be allowed

Accord Project Logo

Accord Project is an open source, non-profit, initiative working to transform contract management and contract automation by digitizing contracts. Accord Project operates under the umbrella of the Linux Foundation. The technical charter for the Accord Project can be found here.

Learn More About Accord Project

Overview

Documentation

Contributing

The Accord Project technology is being developed as open source. All the software packages are being actively maintained on GitHub and we encourage organizations and individuals to contribute requirements, documentation, issues, new templates, and code.

Find out what’s coming on our blog.

Join the Accord Project Technology Working Group Slack channel to get involved!

For code contributions, read our CONTRIBUTING guide and information for DEVELOPERS.

README Badge

Using Accord Project? Add a README badge to let everyone know: accord project

[![accord project](https://img.shields.io/badge/powered%20by-accord%20project-19C6C8.svg)](https://www.accordproject.org/)

License

Accord Project source code files are made available under the Apache License, Version 2.0. Accord Project documentation files are made available under the Creative Commons Attribution 4.0 International License (CC-BY-4.0).

Copyright 2018-2019 Clause, Inc. All trademarks are the property of their respective owners. See LF Projects Trademark Policy.

FAQs

Package last updated on 08 Jun 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc