Gathering detailed insights and metrics for react-quill-with-table
Gathering detailed insights and metrics for react-quill-with-table
Gathering detailed insights and metrics for react-quill-with-table
Gathering detailed insights and metrics for react-quill-with-table
npm install react-quill-with-table
Typescript
Module System
Min. Node Version
Node Version
NPM Version
57.2
Supply Chain
100
Quality
74.2
Maintenance
100
Vulnerability
97.9
License
v1.1.0
Published on 04 Aug 2017
v1.0.0-rc.3
Published on 21 Jun 2017
Version 1.0.0-beta-5
Published on 10 Apr 2017
Version 1.0.0-beta-4
Published on 27 Mar 2017
Version 1.0.0-beta-3
Published on 03 Mar 2017
Version 1.0.0-beta-2
Published on 26 Feb 2017
JavaScript (64.52%)
TypeScript (35.48%)
Total Downloads
632,709
Last Day
189
Last Week
1,877
Last Month
8,972
Last Year
140,388
6,815 Stars
430 Commits
929 Forks
58 Watching
12 Branches
48 Contributors
Latest Version
1.3.3
Package Id
react-quill-with-table@1.3.3
Unpacked Size
3.16 MB
Size
622.61 kB
File Count
16
NPM Version
6.9.0
Node Version
10.16.3
Cumulative downloads
Total Downloads
Last day
-60.6%
189
Compared to previous day
Last week
-21.7%
1,877
Compared to previous week
Last month
-8.6%
8,972
Compared to previous month
Last year
-63%
140,388
Compared to previous year
1
💯 React Quill now supports Quill v1.0.0! Thanks to @clemmy and @alexkrolick for landing this much-awaited change. There are many breaking changes, so be sure to read the migration guide.
1npm install react-quill 2yarn add react-quill
Special thank you to everyone who contributed during the 1.0.0 release cycle!
1import ReactQuill from 'react-quill'; // ES6 2import * as ReactQuill from 'react-quill'; // Typescript 3const ReactQuill = require('react-quill'); // CommonJS
Two common examples are shown below. How stylesheets are included in your app depends on build system (Webpack, SCSS, LESS, etc). See the documentation on Themes for more information.
1<link rel="stylesheet" href="//cdn.quilljs.com/1.2.6/quill.snow.css">
css-loader
with Webpack or create-react-app
1require('react-quill/dist/quill.snow.css'); // CommonJS 2import 'react-quill/dist/quill.snow.css'; // ES6
1class MyComponent extends React.Component { 2 constructor(props) { 3 super(props) 4 this.state = { text: '' } // You can also pass a Quill Delta here 5 this.handleChange = this.handleChange.bind(this) 6 } 7 8 handleChange(value) { 9 this.setState({ text: value }) 10 } 11 12 render() { 13 return ( 14 <ReactQuill value={this.state.text} 15 onChange={this.handleChange} /> 16 ) 17 } 18}
You can pass a Quill Delta, instead of an HTML string, as the value
and defaultValue
properties. Deltas have a number of advantages over HTML strings, so you might want use them instead. Be aware, however, that comparing Deltas for changes is more expensive than comparing HTML strings, so it might be worth to profile your usage patterns.
Note that switching value
from an HTML string to a Delta, or vice-versa, will trigger a change, regardless of whether they represent the same document, so you might want to stick to a format and keep using it consistently throughout.
⚠️ Do not use the delta
object you receive from the onChange
event as value
. This object does not contain the full document, but only the last modifications, and doing so will most likely trigger an infinite loop where the same changes are applied over and over again. Use editor.getContents()
during the event to obtain a Delta of the full document instead. ReactQuill will prevent you from making such a mistake, however if you are absolutely sure that this is what you want, you can pass the object through new Delta()
again to un-taint it.
Pass defaultValue
instead of value
if you need to use DOM or Quill APIs to imperatively manipulate the editor state.
In this "uncontrolled" mode ReactQuill uses the prop as the initial value but allows the element to deviate after that. The onChange
callback still works normally.
The Quill editor supports themes. It includes a full-fledged theme, called snow, that is Quill's standard appearance, a bubble theme that is similar to the inline editor on Medium, and a core theme containing only the bare essentials to allow modules like toolbars or tooltips to work.
These stylesheets can be found in the Quill distribution, but for convenience they are also linked in React Quill's dist
folder. In a common case you would activate a theme by setting the theme prop. Pass a falsy value (null
) to disable the theme.
1<ReactQuill theme="snow" /> // or "bubble", null to use minimal core theme
And then link the appropriate stylesheet (only link the CSS for the themes you want to use):
1<link rel="stylesheet" href="node_modules/react-quill/dist/quill.snow.css"> 2<link rel="stylesheet" href="node_modules/react-quill/dist/quill.bubble.css"> 3<link rel="stylesheet" href="node_modules/react-quill/dist/quill.core.css">
This may vary depending how application is structured, directories or otherwise. For example, if you use a CSS pre-processor like SASS, you may want to import that stylesheet inside your own.
The Quill Toolbar Module API provides an easy way to configure the default toolbar icons using an array of format names.
1class MyComponent extends Component { 2 constructor(props) { 3 super(props); 4 this.state = { 5 text: "", 6 } 7 } 8 9 modules = { 10 toolbar: [ 11 [{ 'header': [1, 2, false] }], 12 ['bold', 'italic', 'underline','strike', 'blockquote'], 13 [{'list': 'ordered'}, {'list': 'bullet'}, {'indent': '-1'}, {'indent': '+1'}], 14 ['link', 'image'], 15 ['clean'] 16 ], 17 }, 18 19 formats = [ 20 'header', 21 'bold', 'italic', 'underline', 'strike', 'blockquote', 22 'list', 'bullet', 'indent', 23 'link', 'image' 24 ], 25 26 render() { 27 return ( 28 <div className="text-editor"> 29 <ReactQuill theme="snow" 30 modules={this.modules} 31 formats={this.formats}> 32 </ReactQuill> 33 </div> 34 ); 35 } 36} 37 38export default MyComponent;
You can also supply your own HTML/JSX toolbar with custom elements that are not part of the Quill theme.
See this example live on Codepen: Custom Toolbar Example
1/* 2 * Custom "star" icon for the toolbar using an Octicon 3 * https://octicons.github.io 4 */ 5const CustomButton = () => <span className="octicon octicon-star" /> 6 7/* 8 * Event handler to be attached using Quill toolbar module 9 * http://quilljs.com/docs/modules/toolbar/ 10 */ 11function insertStar () { 12 const cursorPosition = this.quill.getSelection().index 13 this.quill.insertText(cursorPosition, "★") 14 this.quill.setSelection(cursorPosition + 1) 15} 16 17/* 18 * Custom toolbar component including insertStar button and dropdowns 19 */ 20const CustomToolbar = () => ( 21 <div id="toolbar"> 22 <select className="ql-header" defaultValue={""} onChange={e => e.persist()}> 23 <option value="1"></option> 24 <option value="2"></option> 25 <option selected></option> 26 </select> 27 <button className="ql-bold"></button> 28 <button className="ql-italic"></button> 29 <select className="ql-color"> 30 <option value="red"></option> 31 <option value="green"></option> 32 <option value="blue"></option> 33 <option value="orange"></option> 34 <option value="violet"></option> 35 <option value="#d0d1d2"></option> 36 <option selected></option> 37 </select> 38 <button className="ql-insertStar"> 39 <CustomButton /> 40 </button> 41 </div> 42) 43 44/* 45 * Editor component with custom toolbar and content containers 46 */ 47class Editor extends React.Component { 48 constructor (props) { 49 super(props) 50 this.state = { editorHtml: '' } 51 this.handleChange = this.handleChange.bind(this) 52 } 53 54 handleChange (html) { 55 this.setState({ editorHtml: html }); 56 } 57 58 render() { 59 return ( 60 <div className="text-editor"> 61 <CustomToolbar /> 62 <ReactQuill 63 onChange={this.handleChange} 64 placeholder={this.props.placeholder} 65 modules={Editor.modules} 66 /> 67 </div> 68 ) 69 } 70} 71 72/* 73 * Quill modules to attach to editor 74 * See http://quilljs.com/docs/modules/ for complete options 75 */ 76Editor.modules = { 77 toolbar: { 78 container: "#toolbar", 79 handlers: { 80 "insertStar": insertStar, 81 } 82 } 83} 84 85/* 86 * Quill editor formats 87 * See http://quilljs.com/docs/formats/ 88 */ 89Editor.formats = [ 90 'header', 'font', 'size', 91 'bold', 'italic', 'underline', 'strike', 'blockquote', 92 'list', 'bullet', 'indent', 93 'link', 'image', 'color', 94] 95 96/* 97 * PropType validation 98 */ 99Editor.propTypes = { 100 placeholder: React.PropTypes.string, 101} 102 103/* 104 * Render component on page 105 */ 106ReactDOM.render( 107 <Editor placeholder={'Write something or insert a star ★'}/>, 108 document.querySelector('.app') 109)
The component has two types of formats:
formats
prop. All formats are enabled by default.1const ReactQuill = require('react-quill'); // CommonJS 2import ReactQuill, { Quill } from 'react-quill'; // ES6
1/* 2 * Example Parchment format from 3 * https://quilljs.com/guides/cloning-medium-with-parchment/ 4 * See the video example in the guide for a complex format 5 */ 6let Inline = Quill.import('blots/inline'); 7class BoldBlot extends Inline { } 8BoldBlot.blotName = 'bold'; 9BoldBlot.tagName = 'strong'; 10Quill.register('formats/bold', BoldBlot); 11 12const formats = ["bold"] // add custom format name + any built-in formats you need 13 14/* 15 * Editor component with default and custom formats 16 */ 17class MyComponent extends React.Component { 18 constructor(props) { 19 this.formats = formats 20 this.state = { text: '' } 21 } 22 23 handleChange(value) { 24 this.setState({text: value}) 25 } 26 27 render() { 28 return ( 29 <ReactQuill 30 value={this.state.text} 31 onChange={this.handleChange} 32 formats={this.formats} 33 /> 34 ) 35 } 36}
If you instantiate ReactQuill without children, it will create a <div>
for you, to be used as the editing area for Quill. If you prefer, you can specify your own element for ReactQuill to use. Note that <textarea>
s are not supported by Quill at this time.
Note: Custom editing areas lose focus when using React 16 as a peer dep at this time (bug).
1class MyComponent extends React.Component { 2 3 render() { 4 return ( 5 <ReactQuill> 6 <div className="my-editing-area"/> 7 </ReactQuill> 8 ); 9 } 10 11});
The module exports a mixin which can be used to create custom editor components. (Note that mixins will be deprecated in a future version of React).
The ReactQuill default component is built using the mixin. See component.js for source.
1import {Mixin} from 'react-quill'
2
3var MyComponent = React.createClass({
4 mixins: [ ReactQuill.Mixin ],
5
6 componentDidMount: function() {
7 var editor = this.createEditor(
8 this.getEditingArea(),
9 this.getEditorConfig()
10 );
11 this.setState({ editor:editor });
12 },
13
14 componentWillReceiveProps: function(nextProps) {
15 if ('value' in nextProps && nextProps.value !== this.props.value) {
16 this.setEditorContents(this.state.editor, nextProps.value);
17 }
18 },
19
20});
In most cases, ReactQuill will raise useful warnings to help you perform any necessary migration steps.
Please note that many migration steps to Quill v1.0 may also apply.
With v1.0.0, Quill adopted a new toolbar configuration format, to which React Quill will delegates all toolbar functionality, and which is now the preferred way to customize the toolbar.
Previously, toolbar properties could be set by passing a toolbar
prop to React Quill. Pass the same options as modules.toolbar
instead.
1+ modules: { 2 toolbar: [ 3 ... 4 ], 5+ }, 6 7 <ReactQuill 8- toolbar={this.toolbar} 9+ modules={this.modules} 10 />
If you used to provide your own HTML toolbar component, you can still do the same:
1+ modules: { 2+ toolbar: '#my-toolbar-component', 3+ }, 4 5 <ReactQuill 6- toolbar="#my-toolbar-component" 7+ modules={this.modules} 8 />
Note that it is not possible to pass a toolbar component as a child to ReactQuill anymore.
Previously, React Quill would create a custom HTML toolbar for you if you passed a configuration object as the toolbar
prop. This will not happen anymore. You can still create a ReactQuill.Toolbar
explicitly:
1+ modules: { 2+ toolbar: '#my-quill-toolbar', 3+ }, 4 5+ <ReactQuill.Toolbar 6+ id='my-quill-toolbar' 7+ items={this.oldStyleToolbarItems} 8+ /> 9 10 <ReactQuill 11- toolbar={this.oldStyleToolbarItems} 12+ modules={this.modules} 13 />
However, consider switching to the new Quill format instead, or provide your own toolbar component.
React Quill now follows the Quill toolbar format closely. See the Quill toolbar documentation for a complete reference on all supported options.
Previously, to provide a custom element for Quill to mount on, it was necessary to pass a child identified by a specific ref
: editor
.
This is now unnecessary, so you can omit the ref
entirely if you don't need it. In addition, any ref
you keep won't be stolen from the owner component anymore.
Note, however, that React Quill will now ensure that the element is compatible with Quill. This means that passing a <textarea>
now produces an error.
Previously, it was possible to pass arbitrary components as children of React Quill. Their ref
would identify them as either a custom toolbar or a custom editing area.
This is not possible anymore, and the only child you can pass now is an optional custom Editing Area element.
formats
property is deprecatedAs of 1.0.0, use Parchment to define new formats. Use the Quill export from the module to register and extend formats:
1Quill.register('formats/CustomFormat', MyCustomFormat);
styles
propertyPreviously, it was allowed to inject CSS styles by providing an object to the styles
property. This option has been removed from Quill 1.0, and support for it in React Quill has gone as well. If you need to inject styles, link an external stylesheet instead.
See the Quill Release Notes.
pollInterval
propertyThis property previously set the frequency with which Quill polled the DOM for changes. It does not have any effect anymore, and can safely be removed from the props.
1const ReactQuill = require('react-quill'); // CommonJS 2const {Quill, Mixin, Toolbar} = ReactQuill; 3 4import ReactQuill, { Quill, Mixin, Toolbar } from 'react-quill'; // ES6
Mixin
: Provides the bridge between React and Quill. ReactQuill
implements this mixin; in the same way you can use it to build your own component, or replace it to implement a new core for the default component. Note that mixins are deprecated in React and this export will be replaced by an HOC in the future.
Toolbar
: The component that renders the custom ReactQuill toolbar. The default collection of items and color swatches is available as ReactQuill.Toolbar.defaultItems
and ReactQuill.Toolbar.defaultColors
respectively. ⚠️ The Toolbar component is deprecated since v1.0.0. See upgrading to React Quill v1.0.0.
Quill
: The Quill
namespace on which you can call registerModule
and such.
id
: ID to be applied to the DOM element.
className
: Classes to be applied to the DOM element.
value
: Value for the editor as a controlled component. Can be a string containing HTML, a Quill Delta instance, or a plain object representing a Delta.
Note that due to limitations in Quill, this is actually a semi-controlled mode, meaning that the edit is not prevented, but changing value
will still replace the contents.
Also note that passing a Quill Delta here, and then an HTML string, or vice-versa, will always trigger a change, regardless of whether they represent the same document.
⚠️ Do not pass the delta
object from the onChange
event as value
, as it will cause a loop. See Using Deltas for details.
defaultValue
: Initial value for the editor as an uncontrolled component. Can be a string containing HTML, a Quill Delta, or a plain object representing a Delta.
readOnly
: If true, the editor won't allow changing its contents. Wraps the Quill disable
API.
placeholder
: The default value for the empty editor. Note: The Quill API does not support changing this value dynamically. Use refs and data-attributes instead (see #340).
modules
: An object specifying which modules are enabled, and their configuration. The editor toolbar is a commonly customized module. See the modules section over the Quill documentation for more information on what modules are available.
formats
: An array of formats to be enabled during editing. All implemented formats are enabled by default. See Formats for a list.
Custom formats should not be included in the array as of version 1.0.0. Instead they should be created through Parchment and registered with the module's Quill export.
style
: An object with custom CSS rules to apply on the editor's container. Rules should be in React's "camelCased" naming style.
theme
: The name of the theme to apply to the editor. Defaults to snow
, Quill's standard theme. Pass null
to use the minimal core theme. See the docs on themes for more information on including the required stylesheets.
tabIndex
: The order in which the editor becomes focused, among other controls in the page, during keyboard navigation.
bounds
: Selector or DOM element used by Quill to constrain position of popups. Defaults to document.body
.
children
: A single React element that will be used as the editing area for Quill in place of the default, which is a <div>
. Note that you cannot use a <textarea>
, as it is not a supported target. Also note that updating children is costly, as it will cause the Quill editor to be recreated. Set the value
prop if you want to control the html contents of the editor.
onChange(content, delta, source, editor)
: Called back with the new contents of the editor after change. It will be passed the HTML contents of the editor, a delta object expressing the change, the source of the change, and finally a read-only proxy to editor accessors such as getHTML()
.
⚠️ Do not use this delta
object as value
, as it will cause a loop. Use editor.getContents()
instead. See Using Deltas for details.
onChangeSelection(range, source, editor)
: Called back with the new selected range, or null when unfocused. It will be passed the selection range, the source of the change, and finally a read-only proxy to editor accessors such as getBounds()
.
onFocus(range, source, editor)
: Called when the editor becomes focused. It will receive the new selection range.
onBlur(previousRange, source, editor)
: Called when the editor loses focus. It will receive the selection range it had right before losing focus.
onKeyPress(event)
: Called after a key has been pressed and released.
: Note that, like its native counterpart, this won't be called for special keys such as shift or enter. If you need those, hook onto onKeyDown
or onKeyUp
.
onKeyDown(event)
: Called after a key has been pressed, but before it is released.
: Note that, due to how Quill works, it's possible that you won't receive events for keys such as enter, backspace or delete. If that's the case, try hooking onto onKeyUp
instead.
onKeyUp(event)
: Called after a key has been released.
preserveWhitespace
: If true, a pre
tag is used for the editor area instead of the default div
tag. This prevents Quill from
collapsing continuous whitespaces on paste. Related issue.
If you have a ref to a ReactQuill node, you will be able to invoke the following methods:
focus()
: Focuses the editor.
blur()
: Removes focus from the editor.
getEditor()
: Returns the Quill instance that backs the editor. While you can freely use this to access methods such as getText()
, please avoid from imperatively manipulating the instance, to avoid getting ReactQuill and Quill out-of-sync. A much-safer unprivileged editor is available as replacement.
1class Editor extends React.Component { 2 constructor(props) { 3 super(props) 4 this.quillRef = null; // Quill instance 5 this.reactQuillRef = null; // ReactQuill component 6 } 7 8 componentDidMount() { 9 this.attachQuillRefs() 10 } 11 12 componentDidUpdate() { 13 this.attachQuillRefs() 14 } 15 16 attachQuillRefs = () => { 17 if (typeof this.reactQuillRef.getEditor !== 'function') return; 18 this.quillRef = this.reactQuillRef.getEditor(); 19 } 20 21 insertText = () => { 22 var range = this.quillRef.getSelection(); 23 let position = range ? range.index : 0; 24 this.quillRef.insertText(position, 'Hello, World! ') 25 } 26 27 render() { 28 return ( 29 <div> 30 <ReactQuill 31 ref={(el) => { this.reactQuillRef = el }} 32 theme={'snow'} /> 33 <button onClick={this.insertText}>Insert Text</button> 34 </div> 35 ) 36 } 37}
makeUnprivilegedEditor
: Creates an unprivileged editor. Pass this method a reference to the Quill instance from getEditor
. Normally you do not need to use this method since the editor exposed to event handlers is already unprivileged.
1const editor = this.reactQuillRef.getEditor(); 2const unprivilegedEditor = this.reactQuillRef.makeUnprivilegedEditor(editor); 3// You may now use the unprivilegedEditor proxy methods 4unprivilegedEditor.getText();
During events, ReactQuill will make a restricted subset of the Quill API available as the editor
argument. This prevents access to destructive methods, which might cause ReactQuill to get out-of-sync with the component. It provides the following methods, which are mostly proxies of existing Quill methods:
getLength()
: Returns the length of the editor contents, in characters, not including any HTML tag.
getText()
: Returns the string contents of the editor, not including any HTML tag.
getHTML()
: Returns the full HTML contents of the editor.
getContents()
: Returns a Quill Delta of the complete document.
getSelection()
: Returns the current selection range, or null
if the editor is unfocused.
getBounds()
: Returns the pixel position, relative to the editor container, and dimensions, of a selection, at a given location.
You can run the automated test suite:
1npm test
And build a minificated version of the source:
1npm run build
More tasks are available on the Makefile:
lint: lints the source
spec: runs the test specs
coverage: runs the code coverage test
test: lint, spec and coverage threshold test
build: builds the minified version
Note that dist
is ignored in the git repository as of version 1.0.0. If you need to use the built files without downloading the package from NPM, you can run the build tasks yourself or use a CDN like unpkg.
Quill ships only a pre-built javascript file, so Webpack will complain after building a bundle:
Error: ./~/react-quill/~/quill/dist/quill.js
Critical dependencies:
6:478-485 This seems to be a pre-built javascript file. Though this is possible, it's not recommended. Try to require the original source to get better results.
@ ./~/react-quill/~/quill/dist/quill.js 6:478-485
The warning is harmless, but if you want to silence it you can avoid parsing Quill by adding this to your Webpack configuration:
1module: { 2 // Shut off warnings about using pre-built javascript files 3 // as Quill.js unfortunately ships one as its `main`. 4 noParse: /node_modules\/quill\/dist/ 5}
See #7 for more details.
Please check the browser support table for the upstream Quill dependency. The React part of the codebase is ES5-compatible.
React Quill would not be where it is today without the contributions of many people, which we are incredibly grateful for:
The MIT License (MIT)
Copyright (c) 2016, zenoamaro zenoamaro@gmail.com
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
No vulnerabilities found.
Reason
no binaries found in the repo
Reason
license file detected
Details
Reason
Found 6/21 approved changesets -- score normalized to 2
Reason
0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0
Reason
no effort to earn an OpenSSF best practices badge detected
Reason
security policy file not detected
Details
Reason
project is not fuzzed
Details
Reason
Project has not signed or included provenance with any releases.
Details
Reason
branch protection not enabled on development/release branches
Details
Reason
SAST tool is not run on all commits -- score normalized to 0
Details
Reason
55 existing vulnerabilities detected
Details
Score
Last Scanned on 2024-12-16
The Open Source Security Foundation is a cross-industry collaboration to improve the security of open source software (OSS). The Scorecard provides security health metrics for open source projects.
Learn More