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

react-quill

Package Overview
Dependencies
Maintainers
1
Versions
49
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-quill - npm Package Compare versions

Comparing version 0.0.2 to 0.0.3

.npmignore

5

CHANGELOG.md
Changelog
=========
v0.0.3
------
- Switched from `quilljs` package to `quill`.
- Using the new `destroy()` from Quill.
v0.0.2

@@ -5,0 +10,0 @@ ------

37

dist/react-quill.js
(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory(require("react"), require("quilljs"));
module.exports = factory(require("react"), require("quill"));
else if(typeof define === 'function' && define.amd)
define(["react", "quilljs"], factory);
define(["react", "quill"], factory);
else if(typeof exports === 'object')
exports["ReactQuill"] = factory(require("react"), require("quilljs"));
exports["ReactQuill"] = factory(require("react"), require("quill"));
else

@@ -61,3 +61,3 @@ root["ReactQuill"] = factory(root["React"], root["Quill"]);

/*
React-Quill 0.0.2
React-Quill v0.0.3
https://github.com/zenoamaro/react-quill

@@ -113,2 +113,3 @@ */

className: '',
theme: 'base',
modules: {}

@@ -147,2 +148,4 @@ };

this.destroyEditor(this.state.editor);
// NOTE: Don't set the state to null here
// as it would generate a loop.
},

@@ -269,3 +272,3 @@

var React = __webpack_require__(/*! react */ 4),
Quill = __webpack_require__(/*! quilljs */ 5),
Quill = __webpack_require__(/*! quill */ 5),
T = React.PropTypes;

@@ -295,14 +298,12 @@

updateEditor: function(editor, config) {
// TODO: Unfortunately, while we can add modules and
// stuff, we can't remove them. And there is
// little API to update other parts of the config.
// But if we could tear down the editor, at least
// we could do a re-init with the new config.
throw new Error('Not implemented');
// NOTE: This tears the editor down, and reinitializes
// it with the new config. Ugly but necessary
// as there is no api for updating it.
this.destroyEditor(editor);
this.createEditor(config);
return editor;
},
destroyEditor: function(editor) {
// TODO: How to destroy this?
// editor.destroy();
editor.removeAllListeners();
editor.destroy();
},

@@ -454,5 +455,5 @@

/* 5 */
/*!********************************************************************************************!*\
!*** external {"commonjs":"quilljs","commonjs2":"quilljs","amd":"quilljs","root":"Quill"} ***!
\********************************************************************************************/
/*!**************************************************************************************!*\
!*** external {"commonjs":"quill","commonjs2":"quill","amd":"quill","root":"Quill"} ***!
\**************************************************************************************/
/***/ function(module, exports, __webpack_require__) {

@@ -466,2 +467,2 @@

//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 419de4872921735037b9","webpack:///./src/index.js","webpack:///./src/component.js","webpack:///./src/mixin.js","webpack:///./src/toolbar.js","webpack:///external {\"commonjs\":\"react\",\"commonjs2\":\"react\",\"amd\":\"react\",\"root\":\"React\"}","webpack:///external {\"commonjs\":\"quilljs\",\"commonjs2\":\"quilljs\",\"amd\":\"quilljs\",\"root\":\"Quill\"}"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,uBAAe;AACf;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,wC;;;;;;;;;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;ACNA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA,kBAAiB,gBAAgB;AACjC,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA,gCAA+B;AAC/B,MAAK;AACL;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA,mCAAkC;AAClC;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,EAAC;;AAED,iC;;;;;;;;;AClLA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,6B;;;;;;;;;ACvDA;;AAEA;AACA;;AAEA;;AAEA,GAAE;AACF,IAAG;AACH,KAAI,2BAA2B;AAC/B,KAAI,iCAAiC;AACrC,KAAI,gCAAgC;AACpC,KAAI;AACJ,KAAI;AACJ,IAAG;AACH,KAAI,iCAAiC;AACrC,KAAI,6BAA6B;AACjC,KAAI,+BAA+B;AACnC,KAAI;AACJ;AACA,IAAG;;AAEH,GAAE;AACF,IAAG,4BAA4B;AAC/B,IAAG,gCAAgC;AACnC,IAAG,gCAAgC;AACnC,IAAG,sCAAsC;AACzC,IAAG;AACH,IAAG;;AAEH,GAAE;AACF,IAAG,gCAAgC;AACnC,IAAG;AACH;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA,iCAAgC;AAChC;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA,sBAAqB;AACrB;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA,gCAA+B;AAC/B;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA,oCAAmC;AACnC;AACA;AACA;;AAEA,EAAC;;AAED,+B;;;;;;;;;AC7GA,gD;;;;;;;;;ACAA,gD","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"react\"), require(\"quilljs\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"react\", \"quilljs\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"ReactQuill\"] = factory(require(\"react\"), require(\"quilljs\"));\n\telse\n\t\troot[\"ReactQuill\"] = factory(root[\"React\"], root[\"Quill\"]);\n})(this, function(__WEBPACK_EXTERNAL_MODULE_4__, __WEBPACK_EXTERNAL_MODULE_5__) {\nreturn \n\n\n/** WEBPACK FOOTER **\n ** webpack/universalModuleDefinition\n **/"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\texports: {},\n \t\t\tid: moduleId,\n \t\t\tloaded: false\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.loaded = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(0);\n\n\n/** WEBPACK FOOTER **\n ** webpack/bootstrap 419de4872921735037b9\n **/","/*\nReact-Quill 0.0.2\nhttps://github.com/zenoamaro/react-quill\n*/\nmodule.exports = require('./component');\nmodule.exports.Mixin = require('./mixin');\nmodule.exports.Toolbar = require('./toolbar');\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/index.js\n ** module id = 0\n ** module chunks = 0\n **/","'use strict';\n\nvar React = require('react'),\n\tQuillToolbar = require('./toolbar'),\n\tQuillMixin = require('./mixin'),\n\tT = React.PropTypes;\n\n// Support React 0.11 and 0.12\n// FIXME: Remove with React 0.13\nif (React.createFactory) {\n\tQuillToolbar = React.createFactory(QuillToolbar);\n}\n\nvar QuillComponent = React.createClass({\n\n\tdisplayName: 'Quill',\n\n\tmixins: [ QuillMixin ],\n\n\tpropTypes: {\n\t\tid:           T.string,\n\t\tclassName:    T.string,\n\t\tvalue:        T.string,\n\t\tdefaultValue: T.string,\n\t\treadOnly:     T.bool,\n\t\ttoolbar:      T.object,\n\t\tformats:      T.array,\n\t\tstyles:       T.object,\n\t\ttheme:        T.string,\n\t\tpollInterval: T.number,\n\t\tonChange:     T.func\n\t},\n\n\tgetDefaultProps: function() {\n\t\treturn {\n\t\t\tclassName: '',\n\t\t\tmodules: {}\n\t\t};\n\t},\n\n\t/*\n\tRetrieve the initial value from either `value` (preferred)\n\tor `defaultValue` if you want an un-controlled component.\n\t*/\n\tgetInitialState: function() {\n\t\treturn {};\n\t},\n\n\t/*\n\tUpdate only if we've been passed a new `value`.\n\tThis leaves components using `defaultValue` alone.\n\t*/\n\tcomponentWillReceiveProps: function(nextProps) {\n\t\tif ('value' in nextProps) {\n\t\t\tif (nextProps.value !== this.props.value) {\n\t\t\t\tthis.setEditorContents(this.state.editor, nextProps.value);\n\t\t\t}\n\t\t}\n\t},\n\n\tcomponentDidMount: function() {\n\t\tvar editor = this.createEditor(\n\t\t\tthis.getEditorElement(),\n\t\t\tthis.getEditorConfig());\n\t\tthis.setState({ editor:editor });\n\t},\n\n\tcomponentWillUnmount: function() {\n\t\tthis.destroyEditor(this.state.editor);\n\t},\n\n\tshouldComponentUpdate: function(nextProps, nextState) {\n\t\t// Never re-render or we lose the element.\n\t\treturn false;\n\t},\n\n\t/*\n\tIf for whatever reason we are rendering again,\n\twe should tear down the editor and bring it up\n\tagain.\n\t*/\n\tcomponentWillUpdate: function() {\n\t\tthis.componentWillUnmount();\n\t},\n\n\tcomponentDidUpdate: function() {\n\t\tthis.componentDidMount();\n\t},\n\n\tgetEditorConfig: function() {\n\t\tvar config = {\n\t\t\treadOnly:     this.props.readOnly,\n\t\t\ttheme:        this.props.theme,\n\t\t\tformats:      this.props.formats,\n\t\t\tstyles:       this.props.styles,\n\t\t\tmodules:      this.props.modules,\n\t\t\tpollInterval: this.props.pollInterval\n\t\t};\n\t\t// Unless we're redefining the toolbar,\n\t\t// attach to the default one as a ref.\n\t\tif (!config.modules.toolbar) {\n\t\t\t// Don't mutate the original modules\n\t\t\t// because it's shared between components.\n\t\t\tconfig.modules = JSON.parse(JSON.stringify(config.modules));\n\t\t\tconfig.modules.toolbar = {\n\t\t\t\tcontainer: this.refs.toolbar.getDOMNode()\n\t\t\t};\n\t\t}\n\t\treturn config;\n\t},\n\n\tgetEditorElement: function() {\n\t\treturn this.refs.editor.getDOMNode();\n\t},\n\n\tgetEditorContents: function() {\n\t\treturn this.props.value || this.props.defaultValue;\n\t},\n\n\tgetClassName: function() {\n\t\treturn ['quill', this.props.className].join(' ');\n\t},\n\n\t/*\n\tRenders either the specified contents, or a default\n\tconfiguration of toolbar and contents area.\n\t*/\n\trenderContents: function() {\n\t\tif (React.Children.count(this.props.children) > 0) {\n\t\t\treturn React.Children.only(this.props.children);\n\t\t} else {\n\t\t\treturn [\n\t\t\t\tQuillToolbar({\n\t\t\t\t\tkey:'toolbar',\n\t\t\t\t\tref:'toolbar',\n\t\t\t\t\titems: this.props.toolbar\n\t\t\t\t}),\n\t\t\t\tReact.DOM.div({\n\t\t\t\t\tkey:'editor',\n\t\t\t\t\tref:'editor',\n\t\t\t\t\tclassName: 'quill-contents',\n\t\t\t\t\tdangerouslySetInnerHTML: { __html:this.getEditorContents() }\n\t\t\t\t})\n\t\t\t];\n\t\t}\n\t},\n\n\trender: function() {\n\t\treturn React.DOM.div({\n\t\t\tclassName: this.getClassName(),\n\t\t\tonChange: this.preventDefault },\n\t\t\tthis.renderContents()\n\t\t);\n\t},\n\n\t/*\n\tUpdates the local state with the new contents,\n\texecutes the change handler passed as props.\n\t*/\n\tonEditorChange: function(value) {\n\t\tif (value !== this.state.value) {\n\t\t\tif (this.props.onChange) {\n\t\t\t\tthis.props.onChange(value);\n\t\t\t}\n\t\t}\n\t},\n\n\t/*\n\tStop change events from the toolbar from\n\tbubbling up outside.\n\t*/\n\tpreventDefault: function(event) {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t}\n\n});\n\nmodule.exports = QuillComponent;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/component.js\n ** module id = 1\n ** module chunks = 0\n **/","'use strict';\n\nvar React = require('react'),\n\tQuill = require('quilljs'),\n\tT = React.PropTypes;\n\nvar QuillMixin = {\n\n\t/**\n\tCreates an editor on the given element. The editor will\n\tbe passed the configuration, have its events bound,\n\t*/\n\tcreateEditor: function($el, config) {\n\t\tvar editor = new Quill($el, config);\n\t\tthis.hookEditor(editor);\n\t\treturn editor;\n\t},\n\n\thookEditor: function(editor) {\n\t\tvar self = this;\n\t\teditor.on('text-change', function(delta, source) {\n\t\t\tif (self.onEditorChange) {\n\t\t\t\tself.onEditorChange(editor.getHTML(), delta, source);\n\t\t\t}\n\t\t});\n\t},\n\n\tupdateEditor: function(editor, config) {\n\t\t// TODO: Unfortunately, while we can add modules and\n\t\t//       stuff, we can't remove them. And there is\n\t\t//       little API to update other parts of the config.\n\t\t//       But if we could tear down the editor, at least\n\t\t//       we could do a re-init with the new config.\n\t\tthrow new Error('Not implemented');\n\t},\n\n\tdestroyEditor: function(editor) {\n\t\t// TODO: How to destroy this?\n\t\t// editor.destroy();\n\t\teditor.removeAllListeners();\n\t},\n\n\t/*\n\tReplace the contents of the editor, but keep\n\tthe previous selection hanging around so that\n\tthe cursor won't move.\n\t*/\n\tsetEditorContents: function(editor, value) {\n\t\tvar sel = editor.getSelection();\n\t\teditor.setHTML(value);\n\t\teditor.setSelection(sel);\n\t}\n\n};\n\nmodule.exports = QuillMixin;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/mixin.js\n ** module id = 2\n ** module chunks = 0\n **/","'use strict';\n\nvar React = require('react'),\n\tT = React.PropTypes;\n\nvar defaultItems = [\n\n\t{ label:'Formats', type:'group', items: [\n\t\t{ label:'Size', type:'size', items: [\n\t\t\t{ label:'Normal', value:'' },\n\t\t\t{ label:'Smaller', value:'0.8em' },\n\t\t\t{ label:'Larger', value:'1.4em' },\n\t\t\t{ label:'Huge', value:'2em' }\n\t\t]},\n\t\t{ label:'Alignment', type:'align', items: [\n\t\t\t{ label:'Center', value:'center' },\n\t\t\t{ label:'Left', value:'left' },\n\t\t\t{ label:'Right', value:'right' },\n\t\t\t{ label:'Justify', value:'justify' }\n\t\t]}\n\t]},\n\n\t{ label:'Text', type:'group', items: [\n\t\t{ type:'bold', label:'Bold' },\n\t\t{ type:'italic', label:'Italic' },\n\t\t{ type:'strike', label:'Strike' },\n\t\t{ type:'underline', label:'Underline' },\n\t\t{ type:'link', label:'Link' }\n\t]},\n\n\t{ label:'Blocks', type:'group', items: [\n\t\t{ type:'bullet', label:'Bullet' },\n\t\t{ type:'list', label:'List' }\n\t]}\n\n];\n\nvar QuillToolbar = React.createClass({\n\n\tdisplayName: 'Quill Toolbar',\n\n\tpropTypes: {\n\t\tid:        T.string,\n\t\tclassName: T.string,\n\t\titems:     T.array\n\t},\n\n\tgetDefaultProps: function(){\n\t\treturn {\n\t\t\titems: defaultItems\n\t\t};\n\t},\n\n\trenderGroup: function(item) {\n\t\treturn React.DOM.span({\n\t\t\tkey: item.label,\n\t\t\tclassName:'ql-format-group' },\n\t\t\titem.items.map(this.renderItem)\n\t\t);\n\t},\n\n\trenderChoiceItem: function(item) {\n\t\treturn React.DOM.option({\n\t\t\tkey: item.label || item.value,\n\t\t\tvalue:item.value },\n\t\t\titem.label\n\t\t);\n\t},\n\n\trenderChoices: function(item) {\n\t\treturn React.DOM.select({\n\t\t\tkey: item.label,\n\t\t\tclassName: 'ql-'+item.type },\n\t\t\titem.items.map(this.renderChoiceItem)\n\t\t);\n\t},\n\n\trenderAction: function(item) {\n\t\treturn React.DOM.span({\n\t\t\tkey: item.label || item.value,\n\t\t\tclassName: 'ql-format-button ql-'+item.type,\n\t\t\ttitle: item.label }\n\t\t);\n\t},\n\n\trenderItem: function(item) {\n\t\tvar mapping = {\n\t\t\t'group': this.renderGroup,\n\t\t\t'align': this.renderChoices,\n\t\t\t'size': this.renderChoices,\n\t\t\t'action': this.renderAction\n\t\t};\n\t\tvar renderer = mapping[item.type] || mapping.action;\n\t\treturn renderer(item);\n\t},\n\n\tgetClassName: function() {\n\t\treturn 'quill-toolbar ' + (this.props.className||'');\n\t},\n\n\trender: function() {\n\t\treturn React.DOM.div({\n\t\t\tclassName: this.getClassName() },\n\t\t\tthis.props.items.map(this.renderItem)\n\t\t);\n\t}\n\n});\n\nmodule.exports = QuillToolbar;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/toolbar.js\n ** module id = 3\n ** module chunks = 0\n **/","module.exports = __WEBPACK_EXTERNAL_MODULE_4__;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** external {\"commonjs\":\"react\",\"commonjs2\":\"react\",\"amd\":\"react\",\"root\":\"React\"}\n ** module id = 4\n ** module chunks = 0\n **/","module.exports = __WEBPACK_EXTERNAL_MODULE_5__;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** external {\"commonjs\":\"quilljs\",\"commonjs2\":\"quilljs\",\"amd\":\"quilljs\",\"root\":\"Quill\"}\n ** module id = 5\n ** module chunks = 0\n **/"],"sourceRoot":"","file":"./dist/react-quill.js"}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 8eab63ec4685f7df5c32","webpack:///./src/index.js","webpack:///./src/component.js","webpack:///./src/mixin.js","webpack:///./src/toolbar.js","webpack:///external {\"commonjs\":\"react\",\"commonjs2\":\"react\",\"amd\":\"react\",\"root\":\"React\"}","webpack:///external {\"commonjs\":\"quill\",\"commonjs2\":\"quill\",\"amd\":\"quill\",\"root\":\"Quill\"}"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,uBAAe;AACf;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,wC;;;;;;;;;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;ACNA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA,kBAAiB,gBAAgB;AACjC,GAAE;;AAEF;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA,gCAA+B;AAC/B,MAAK;AACL;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA,mCAAkC;AAClC;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,EAAC;;AAED,iC;;;;;;;;;ACrLA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,6B;;;;;;;;;ACrDA;;AAEA;AACA;;AAEA;;AAEA,GAAE;AACF,IAAG;AACH,KAAI,2BAA2B;AAC/B,KAAI,iCAAiC;AACrC,KAAI,gCAAgC;AACpC,KAAI;AACJ,KAAI;AACJ,IAAG;AACH,KAAI,iCAAiC;AACrC,KAAI,6BAA6B;AACjC,KAAI,+BAA+B;AACnC,KAAI;AACJ;AACA,IAAG;;AAEH,GAAE;AACF,IAAG,4BAA4B;AAC/B,IAAG,gCAAgC;AACnC,IAAG,gCAAgC;AACnC,IAAG,sCAAsC;AACzC,IAAG;AACH,IAAG;;AAEH,GAAE;AACF,IAAG,gCAAgC;AACnC,IAAG;AACH;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA,iCAAgC;AAChC;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA,sBAAqB;AACrB;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA,gCAA+B;AAC/B;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;;AAEF;AACA;AACA,GAAE;;AAEF;AACA;AACA,oCAAmC;AACnC;AACA;AACA;;AAEA,EAAC;;AAED,+B;;;;;;;;;AC7GA,gD;;;;;;;;;ACAA,gD","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"react\"), require(\"quill\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"react\", \"quill\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"ReactQuill\"] = factory(require(\"react\"), require(\"quill\"));\n\telse\n\t\troot[\"ReactQuill\"] = factory(root[\"React\"], root[\"Quill\"]);\n})(this, function(__WEBPACK_EXTERNAL_MODULE_4__, __WEBPACK_EXTERNAL_MODULE_5__) {\nreturn \n\n\n/** WEBPACK FOOTER **\n ** webpack/universalModuleDefinition\n **/"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\texports: {},\n \t\t\tid: moduleId,\n \t\t\tloaded: false\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.loaded = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(0);\n\n\n/** WEBPACK FOOTER **\n ** webpack/bootstrap 8eab63ec4685f7df5c32\n **/","/*\nReact-Quill v0.0.3\nhttps://github.com/zenoamaro/react-quill\n*/\nmodule.exports = require('./component');\nmodule.exports.Mixin = require('./mixin');\nmodule.exports.Toolbar = require('./toolbar');\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/index.js\n ** module id = 0\n ** module chunks = 0\n **/","'use strict';\n\nvar React = require('react'),\n\tQuillToolbar = require('./toolbar'),\n\tQuillMixin = require('./mixin'),\n\tT = React.PropTypes;\n\n// Support React 0.11 and 0.12\n// FIXME: Remove with React 0.13\nif (React.createFactory) {\n\tQuillToolbar = React.createFactory(QuillToolbar);\n}\n\nvar QuillComponent = React.createClass({\n\n\tdisplayName: 'Quill',\n\n\tmixins: [ QuillMixin ],\n\n\tpropTypes: {\n\t\tid:           T.string,\n\t\tclassName:    T.string,\n\t\tvalue:        T.string,\n\t\tdefaultValue: T.string,\n\t\treadOnly:     T.bool,\n\t\ttoolbar:      T.object,\n\t\tformats:      T.array,\n\t\tstyles:       T.object,\n\t\ttheme:        T.string,\n\t\tpollInterval: T.number,\n\t\tonChange:     T.func\n\t},\n\n\tgetDefaultProps: function() {\n\t\treturn {\n\t\t\tclassName: '',\n\t\t\ttheme: 'base',\n\t\t\tmodules: {}\n\t\t};\n\t},\n\n\t/*\n\tRetrieve the initial value from either `value` (preferred)\n\tor `defaultValue` if you want an un-controlled component.\n\t*/\n\tgetInitialState: function() {\n\t\treturn {};\n\t},\n\n\t/*\n\tUpdate only if we've been passed a new `value`.\n\tThis leaves components using `defaultValue` alone.\n\t*/\n\tcomponentWillReceiveProps: function(nextProps) {\n\t\tif ('value' in nextProps) {\n\t\t\tif (nextProps.value !== this.props.value) {\n\t\t\t\tthis.setEditorContents(this.state.editor, nextProps.value);\n\t\t\t}\n\t\t}\n\t},\n\n\tcomponentDidMount: function() {\n\t\tvar editor = this.createEditor(\n\t\t\tthis.getEditorElement(),\n\t\t\tthis.getEditorConfig());\n\t\tthis.setState({ editor:editor });\n\t},\n\n\tcomponentWillUnmount: function() {\n\t\tthis.destroyEditor(this.state.editor);\n\t\t// NOTE: Don't set the state to null here\n\t\t//       as it would generate a loop.\n\t},\n\n\tshouldComponentUpdate: function(nextProps, nextState) {\n\t\t// Never re-render or we lose the element.\n\t\treturn false;\n\t},\n\n\t/*\n\tIf for whatever reason we are rendering again,\n\twe should tear down the editor and bring it up\n\tagain.\n\t*/\n\tcomponentWillUpdate: function() {\n\t\tthis.componentWillUnmount();\n\t},\n\n\tcomponentDidUpdate: function() {\n\t\tthis.componentDidMount();\n\t},\n\n\tgetEditorConfig: function() {\n\t\tvar config = {\n\t\t\treadOnly:     this.props.readOnly,\n\t\t\ttheme:        this.props.theme,\n\t\t\tformats:      this.props.formats,\n\t\t\tstyles:       this.props.styles,\n\t\t\tmodules:      this.props.modules,\n\t\t\tpollInterval: this.props.pollInterval\n\t\t};\n\t\t// Unless we're redefining the toolbar,\n\t\t// attach to the default one as a ref.\n\t\tif (!config.modules.toolbar) {\n\t\t\t// Don't mutate the original modules\n\t\t\t// because it's shared between components.\n\t\t\tconfig.modules = JSON.parse(JSON.stringify(config.modules));\n\t\t\tconfig.modules.toolbar = {\n\t\t\t\tcontainer: this.refs.toolbar.getDOMNode()\n\t\t\t};\n\t\t}\n\t\treturn config;\n\t},\n\n\tgetEditorElement: function() {\n\t\treturn this.refs.editor.getDOMNode();\n\t},\n\n\tgetEditorContents: function() {\n\t\treturn this.props.value || this.props.defaultValue;\n\t},\n\n\tgetClassName: function() {\n\t\treturn ['quill', this.props.className].join(' ');\n\t},\n\n\t/*\n\tRenders either the specified contents, or a default\n\tconfiguration of toolbar and contents area.\n\t*/\n\trenderContents: function() {\n\t\tif (React.Children.count(this.props.children) > 0) {\n\t\t\treturn React.Children.only(this.props.children);\n\t\t} else {\n\t\t\treturn [\n\t\t\t\tQuillToolbar({\n\t\t\t\t\tkey:'toolbar',\n\t\t\t\t\tref:'toolbar',\n\t\t\t\t\titems: this.props.toolbar\n\t\t\t\t}),\n\t\t\t\tReact.DOM.div({\n\t\t\t\t\tkey:'editor',\n\t\t\t\t\tref:'editor',\n\t\t\t\t\tclassName: 'quill-contents',\n\t\t\t\t\tdangerouslySetInnerHTML: { __html:this.getEditorContents() }\n\t\t\t\t})\n\t\t\t];\n\t\t}\n\t},\n\n\trender: function() {\n\t\treturn React.DOM.div({\n\t\t\tclassName: this.getClassName(),\n\t\t\tonChange: this.preventDefault },\n\t\t\tthis.renderContents()\n\t\t);\n\t},\n\n\t/*\n\tUpdates the local state with the new contents,\n\texecutes the change handler passed as props.\n\t*/\n\tonEditorChange: function(value) {\n\t\tif (value !== this.state.value) {\n\t\t\tif (this.props.onChange) {\n\t\t\t\tthis.props.onChange(value);\n\t\t\t}\n\t\t}\n\t},\n\n\t/*\n\tStop change events from the toolbar from\n\tbubbling up outside.\n\t*/\n\tpreventDefault: function(event) {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t}\n\n});\n\nmodule.exports = QuillComponent;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/component.js\n ** module id = 1\n ** module chunks = 0\n **/","'use strict';\n\nvar React = require('react'),\n\tQuill = require('quill'),\n\tT = React.PropTypes;\n\nvar QuillMixin = {\n\n\t/**\n\tCreates an editor on the given element. The editor will\n\tbe passed the configuration, have its events bound,\n\t*/\n\tcreateEditor: function($el, config) {\n\t\tvar editor = new Quill($el, config);\n\t\tthis.hookEditor(editor);\n\t\treturn editor;\n\t},\n\n\thookEditor: function(editor) {\n\t\tvar self = this;\n\t\teditor.on('text-change', function(delta, source) {\n\t\t\tif (self.onEditorChange) {\n\t\t\t\tself.onEditorChange(editor.getHTML(), delta, source);\n\t\t\t}\n\t\t});\n\t},\n\n\tupdateEditor: function(editor, config) {\n\t\t// NOTE: This tears the editor down, and reinitializes\n\t\t//       it with the new config. Ugly but necessary\n\t\t//       as there is no api for updating it.\n\t\tthis.destroyEditor(editor);\n\t\tthis.createEditor(config);\n\t\treturn editor;\n\t},\n\n\tdestroyEditor: function(editor) {\n\t\teditor.destroy();\n\t},\n\n\t/*\n\tReplace the contents of the editor, but keep\n\tthe previous selection hanging around so that\n\tthe cursor won't move.\n\t*/\n\tsetEditorContents: function(editor, value) {\n\t\tvar sel = editor.getSelection();\n\t\teditor.setHTML(value);\n\t\teditor.setSelection(sel);\n\t}\n\n};\n\nmodule.exports = QuillMixin;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/mixin.js\n ** module id = 2\n ** module chunks = 0\n **/","'use strict';\n\nvar React = require('react'),\n\tT = React.PropTypes;\n\nvar defaultItems = [\n\n\t{ label:'Formats', type:'group', items: [\n\t\t{ label:'Size', type:'size', items: [\n\t\t\t{ label:'Normal', value:'' },\n\t\t\t{ label:'Smaller', value:'0.8em' },\n\t\t\t{ label:'Larger', value:'1.4em' },\n\t\t\t{ label:'Huge', value:'2em' }\n\t\t]},\n\t\t{ label:'Alignment', type:'align', items: [\n\t\t\t{ label:'Center', value:'center' },\n\t\t\t{ label:'Left', value:'left' },\n\t\t\t{ label:'Right', value:'right' },\n\t\t\t{ label:'Justify', value:'justify' }\n\t\t]}\n\t]},\n\n\t{ label:'Text', type:'group', items: [\n\t\t{ type:'bold', label:'Bold' },\n\t\t{ type:'italic', label:'Italic' },\n\t\t{ type:'strike', label:'Strike' },\n\t\t{ type:'underline', label:'Underline' },\n\t\t{ type:'link', label:'Link' }\n\t]},\n\n\t{ label:'Blocks', type:'group', items: [\n\t\t{ type:'bullet', label:'Bullet' },\n\t\t{ type:'list', label:'List' }\n\t]}\n\n];\n\nvar QuillToolbar = React.createClass({\n\n\tdisplayName: 'Quill Toolbar',\n\n\tpropTypes: {\n\t\tid:        T.string,\n\t\tclassName: T.string,\n\t\titems:     T.array\n\t},\n\n\tgetDefaultProps: function(){\n\t\treturn {\n\t\t\titems: defaultItems\n\t\t};\n\t},\n\n\trenderGroup: function(item) {\n\t\treturn React.DOM.span({\n\t\t\tkey: item.label,\n\t\t\tclassName:'ql-format-group' },\n\t\t\titem.items.map(this.renderItem)\n\t\t);\n\t},\n\n\trenderChoiceItem: function(item) {\n\t\treturn React.DOM.option({\n\t\t\tkey: item.label || item.value,\n\t\t\tvalue:item.value },\n\t\t\titem.label\n\t\t);\n\t},\n\n\trenderChoices: function(item) {\n\t\treturn React.DOM.select({\n\t\t\tkey: item.label,\n\t\t\tclassName: 'ql-'+item.type },\n\t\t\titem.items.map(this.renderChoiceItem)\n\t\t);\n\t},\n\n\trenderAction: function(item) {\n\t\treturn React.DOM.span({\n\t\t\tkey: item.label || item.value,\n\t\t\tclassName: 'ql-format-button ql-'+item.type,\n\t\t\ttitle: item.label }\n\t\t);\n\t},\n\n\trenderItem: function(item) {\n\t\tvar mapping = {\n\t\t\t'group': this.renderGroup,\n\t\t\t'align': this.renderChoices,\n\t\t\t'size': this.renderChoices,\n\t\t\t'action': this.renderAction\n\t\t};\n\t\tvar renderer = mapping[item.type] || mapping.action;\n\t\treturn renderer(item);\n\t},\n\n\tgetClassName: function() {\n\t\treturn 'quill-toolbar ' + (this.props.className||'');\n\t},\n\n\trender: function() {\n\t\treturn React.DOM.div({\n\t\t\tclassName: this.getClassName() },\n\t\t\tthis.props.items.map(this.renderItem)\n\t\t);\n\t}\n\n});\n\nmodule.exports = QuillToolbar;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/toolbar.js\n ** module id = 3\n ** module chunks = 0\n **/","module.exports = __WEBPACK_EXTERNAL_MODULE_4__;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** external {\"commonjs\":\"react\",\"commonjs2\":\"react\",\"amd\":\"react\",\"root\":\"React\"}\n ** module id = 4\n ** module chunks = 0\n **/","module.exports = __WEBPACK_EXTERNAL_MODULE_5__;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** external {\"commonjs\":\"quill\",\"commonjs2\":\"quill\",\"amd\":\"quill\",\"root\":\"Quill\"}\n ** module id = 5\n ** module chunks = 0\n **/"],"sourceRoot":"","file":"./dist/react-quill.js"}

@@ -1,1 +0,1 @@

!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("react"),require("quilljs")):"function"==typeof define&&define.amd?define(["react","quilljs"],t):"object"==typeof exports?exports.ReactQuill=t(require("react"),require("quilljs")):e.ReactQuill=t(e.React,e.Quill)}(this,function(e,t){return function(e){function t(o){if(r[o])return r[o].exports;var n=r[o]={exports:{},id:o,loaded:!1};return e[o].call(n.exports,n,n.exports,t),n.loaded=!0,n.exports}var r={};return t.m=e,t.c=r,t.p="",t(0)}([function(e,t,r){e.exports=r(4),e.exports.Mixin=r(2),e.exports.Toolbar=r(3)},function(t){t.exports=e},function(e,t,r){"use strict";var o=r(1),n=r(5),i=(o.PropTypes,{createEditor:function(e,t){var r=new n(e,t);return this.hookEditor(r),r},hookEditor:function(e){var t=this;e.on("text-change",function(r,o){t.onEditorChange&&t.onEditorChange(e.getHTML(),r,o)})},updateEditor:function(){throw new Error("Not implemented")},destroyEditor:function(e){e.removeAllListeners()},setEditorContents:function(e,t){var r=e.getSelection();e.setHTML(t),e.setSelection(r)}});e.exports=i},function(e,t,r){"use strict";var o=r(1),n=o.PropTypes,i=[{label:"Formats",type:"group",items:[{label:"Size",type:"size",items:[{label:"Normal",value:""},{label:"Smaller",value:"0.8em"},{label:"Larger",value:"1.4em"},{label:"Huge",value:"2em"}]},{label:"Alignment",type:"align",items:[{label:"Center",value:"center"},{label:"Left",value:"left"},{label:"Right",value:"right"},{label:"Justify",value:"justify"}]}]},{label:"Text",type:"group",items:[{type:"bold",label:"Bold"},{type:"italic",label:"Italic"},{type:"strike",label:"Strike"},{type:"underline",label:"Underline"},{type:"link",label:"Link"}]},{label:"Blocks",type:"group",items:[{type:"bullet",label:"Bullet"},{type:"list",label:"List"}]}],l=o.createClass({displayName:"Quill Toolbar",propTypes:{id:n.string,className:n.string,items:n.array},getDefaultProps:function(){return{items:i}},renderGroup:function(e){return o.DOM.span({key:e.label,className:"ql-format-group"},e.items.map(this.renderItem))},renderChoiceItem:function(e){return o.DOM.option({key:e.label||e.value,value:e.value},e.label)},renderChoices:function(e){return o.DOM.select({key:e.label,className:"ql-"+e.type},e.items.map(this.renderChoiceItem))},renderAction:function(e){return o.DOM.span({key:e.label||e.value,className:"ql-format-button ql-"+e.type,title:e.label})},renderItem:function(e){var t={group:this.renderGroup,align:this.renderChoices,size:this.renderChoices,action:this.renderAction},r=t[e.type]||t.action;return r(e)},getClassName:function(){return"quill-toolbar "+(this.props.className||"")},render:function(){return o.DOM.div({className:this.getClassName()},this.props.items.map(this.renderItem))}});e.exports=l},function(e,t,r){"use strict";var o=r(1),n=r(3),i=r(2),l=o.PropTypes;o.createFactory&&(n=o.createFactory(n));var s=o.createClass({displayName:"Quill",mixins:[i],propTypes:{id:l.string,className:l.string,value:l.string,defaultValue:l.string,readOnly:l.bool,toolbar:l.object,formats:l.array,styles:l.object,theme:l.string,pollInterval:l.number,onChange:l.func},getDefaultProps:function(){return{className:"",modules:{}}},getInitialState:function(){return{}},componentWillReceiveProps:function(e){"value"in e&&e.value!==this.props.value&&this.setEditorContents(this.state.editor,e.value)},componentDidMount:function(){var e=this.createEditor(this.getEditorElement(),this.getEditorConfig());this.setState({editor:e})},componentWillUnmount:function(){this.destroyEditor(this.state.editor)},shouldComponentUpdate:function(){return!1},componentWillUpdate:function(){this.componentWillUnmount()},componentDidUpdate:function(){this.componentDidMount()},getEditorConfig:function(){var e={readOnly:this.props.readOnly,theme:this.props.theme,formats:this.props.formats,styles:this.props.styles,modules:this.props.modules,pollInterval:this.props.pollInterval};return e.modules.toolbar||(e.modules=JSON.parse(JSON.stringify(e.modules)),e.modules.toolbar={container:this.refs.toolbar.getDOMNode()}),e},getEditorElement:function(){return this.refs.editor.getDOMNode()},getEditorContents:function(){return this.props.value||this.props.defaultValue},getClassName:function(){return["quill",this.props.className].join(" ")},renderContents:function(){return o.Children.count(this.props.children)>0?o.Children.only(this.props.children):[n({key:"toolbar",ref:"toolbar",items:this.props.toolbar}),o.DOM.div({key:"editor",ref:"editor",className:"quill-contents",dangerouslySetInnerHTML:{__html:this.getEditorContents()}})]},render:function(){return o.DOM.div({className:this.getClassName(),onChange:this.preventDefault},this.renderContents())},onEditorChange:function(e){e!==this.state.value&&this.props.onChange&&this.props.onChange(e)},preventDefault:function(e){e.preventDefault(),e.stopPropagation()}});e.exports=s},function(e){e.exports=t}])});
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("react"),require("quill")):"function"==typeof define&&define.amd?define(["react","quill"],t):"object"==typeof exports?exports.ReactQuill=t(require("react"),require("quill")):e.ReactQuill=t(e.React,e.Quill)}(this,function(e,t){return function(e){function t(o){if(r[o])return r[o].exports;var n=r[o]={exports:{},id:o,loaded:!1};return e[o].call(n.exports,n,n.exports,t),n.loaded=!0,n.exports}var r={};return t.m=e,t.c=r,t.p="",t(0)}([function(e,t,r){e.exports=r(4),e.exports.Mixin=r(2),e.exports.Toolbar=r(3)},function(t){t.exports=e},function(e,t,r){"use strict";var o=r(1),n=r(5),i=(o.PropTypes,{createEditor:function(e,t){var r=new n(e,t);return this.hookEditor(r),r},hookEditor:function(e){var t=this;e.on("text-change",function(r,o){t.onEditorChange&&t.onEditorChange(e.getHTML(),r,o)})},updateEditor:function(e,t){return this.destroyEditor(e),this.createEditor(t),e},destroyEditor:function(e){e.destroy()},setEditorContents:function(e,t){var r=e.getSelection();e.setHTML(t),e.setSelection(r)}});e.exports=i},function(e,t,r){"use strict";var o=r(1),n=o.PropTypes,i=[{label:"Formats",type:"group",items:[{label:"Size",type:"size",items:[{label:"Normal",value:""},{label:"Smaller",value:"0.8em"},{label:"Larger",value:"1.4em"},{label:"Huge",value:"2em"}]},{label:"Alignment",type:"align",items:[{label:"Center",value:"center"},{label:"Left",value:"left"},{label:"Right",value:"right"},{label:"Justify",value:"justify"}]}]},{label:"Text",type:"group",items:[{type:"bold",label:"Bold"},{type:"italic",label:"Italic"},{type:"strike",label:"Strike"},{type:"underline",label:"Underline"},{type:"link",label:"Link"}]},{label:"Blocks",type:"group",items:[{type:"bullet",label:"Bullet"},{type:"list",label:"List"}]}],s=o.createClass({displayName:"Quill Toolbar",propTypes:{id:n.string,className:n.string,items:n.array},getDefaultProps:function(){return{items:i}},renderGroup:function(e){return o.DOM.span({key:e.label,className:"ql-format-group"},e.items.map(this.renderItem))},renderChoiceItem:function(e){return o.DOM.option({key:e.label||e.value,value:e.value},e.label)},renderChoices:function(e){return o.DOM.select({key:e.label,className:"ql-"+e.type},e.items.map(this.renderChoiceItem))},renderAction:function(e){return o.DOM.span({key:e.label||e.value,className:"ql-format-button ql-"+e.type,title:e.label})},renderItem:function(e){var t={group:this.renderGroup,align:this.renderChoices,size:this.renderChoices,action:this.renderAction},r=t[e.type]||t.action;return r(e)},getClassName:function(){return"quill-toolbar "+(this.props.className||"")},render:function(){return o.DOM.div({className:this.getClassName()},this.props.items.map(this.renderItem))}});e.exports=s},function(e,t,r){"use strict";var o=r(1),n=r(3),i=r(2),s=o.PropTypes;o.createFactory&&(n=o.createFactory(n));var l=o.createClass({displayName:"Quill",mixins:[i],propTypes:{id:s.string,className:s.string,value:s.string,defaultValue:s.string,readOnly:s.bool,toolbar:s.object,formats:s.array,styles:s.object,theme:s.string,pollInterval:s.number,onChange:s.func},getDefaultProps:function(){return{className:"",theme:"base",modules:{}}},getInitialState:function(){return{}},componentWillReceiveProps:function(e){"value"in e&&e.value!==this.props.value&&this.setEditorContents(this.state.editor,e.value)},componentDidMount:function(){var e=this.createEditor(this.getEditorElement(),this.getEditorConfig());this.setState({editor:e})},componentWillUnmount:function(){this.destroyEditor(this.state.editor)},shouldComponentUpdate:function(){return!1},componentWillUpdate:function(){this.componentWillUnmount()},componentDidUpdate:function(){this.componentDidMount()},getEditorConfig:function(){var e={readOnly:this.props.readOnly,theme:this.props.theme,formats:this.props.formats,styles:this.props.styles,modules:this.props.modules,pollInterval:this.props.pollInterval};return e.modules.toolbar||(e.modules=JSON.parse(JSON.stringify(e.modules)),e.modules.toolbar={container:this.refs.toolbar.getDOMNode()}),e},getEditorElement:function(){return this.refs.editor.getDOMNode()},getEditorContents:function(){return this.props.value||this.props.defaultValue},getClassName:function(){return["quill",this.props.className].join(" ")},renderContents:function(){return o.Children.count(this.props.children)>0?o.Children.only(this.props.children):[n({key:"toolbar",ref:"toolbar",items:this.props.toolbar}),o.DOM.div({key:"editor",ref:"editor",className:"quill-contents",dangerouslySetInnerHTML:{__html:this.getEditorContents()}})]},render:function(){return o.DOM.div({className:this.getClassName(),onChange:this.preventDefault},this.renderContents())},onEditorChange:function(e){e!==this.state.value&&this.props.onChange&&this.props.onChange(e)},preventDefault:function(e){e.preventDefault(),e.stopPropagation()}});e.exports=l},function(e){e.exports=t}])});
{
"name": "react-quill",
"version": "0.0.2",
"version": "0.0.3",
"description": "The Quill rich-text editor as a React component.",

@@ -8,3 +8,2 @@ "author": "zenoamaro <zenoamaro@gmail.com>",

"license": "MIT",
"bugs": {

@@ -14,3 +13,2 @@ "url": "https://github.com/zenoamaro/react-quill/issues",

},
"repository": {

@@ -20,5 +18,3 @@ "type": "git",

},
"main": "dist/react-quill.js",
"scripts": {

@@ -28,7 +24,5 @@ "test": "make test",

},
"engines": {
"node": ">= 0.8.x"
},
"keywords": [

@@ -40,3 +34,2 @@ "rich",

],
"files": [

@@ -49,11 +42,8 @@ "src/",

],
"dependencies": {
"quilljs": "^0.18.1"
"quill": "^0.19.4"
},
"peerDependencies": {
"react": ">=0.11.0"
},
"devDependencies": {

@@ -60,0 +50,0 @@ "blanket": "^1.1.6",

@@ -57,2 +57,6 @@ React-Quill ![](https://travis-ci.org/zenoamaro/react-quill.svg?branch=master)

---------
#### v0.0.3
- Switched from `quilljs` package to `quill`.
- Using the new `destroy()` from Quill.
#### v0.0.2

@@ -59,0 +63,0 @@ - Compatible with React 0.12.

@@ -37,2 +37,3 @@ 'use strict';

className: '',
theme: 'base',
modules: {}

@@ -71,2 +72,4 @@ };

this.destroyEditor(this.state.editor);
// NOTE: Don't set the state to null here
// as it would generate a loop.
},

@@ -73,0 +76,0 @@

/*
React-Quill 0.0.2
React-Quill v0.0.3
https://github.com/zenoamaro/react-quill

@@ -4,0 +4,0 @@ */

'use strict';
var React = require('react'),
Quill = require('quilljs'),
Quill = require('quill'),
T = React.PropTypes;

@@ -29,14 +29,12 @@

updateEditor: function(editor, config) {
// TODO: Unfortunately, while we can add modules and
// stuff, we can't remove them. And there is
// little API to update other parts of the config.
// But if we could tear down the editor, at least
// we could do a re-init with the new config.
throw new Error('Not implemented');
// NOTE: This tears the editor down, and reinitializes
// it with the new config. Ugly but necessary
// as there is no api for updating it.
this.destroyEditor(editor);
this.createEditor(config);
return editor;
},
destroyEditor: function(editor) {
// TODO: How to destroy this?
// editor.destroy();
editor.removeAllListeners();
editor.destroy();
},

@@ -43,0 +41,0 @@

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