(function webpackUniversalModuleDefinition(root, factory) { if(typeof exports === 'object' && typeof module === 'object') module.exports = factory(require("react"), require("quilljs")); else if(typeof define === 'function' && define.amd) define(["react", "quilljs"], factory); else if(typeof exports === 'object') exports["ReactQuill"] = factory(require("react"), require("quilljs")); else root["ReactQuill"] = factory(root["React"], root["Quill"]); })(this, function(__WEBPACK_EXTERNAL_MODULE_4__, __WEBPACK_EXTERNAL_MODULE_5__) { return /******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ /******/ // Check if module is in cache /******/ if(installedModules[moduleId]) /******/ return installedModules[moduleId].exports; /******/ /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules[moduleId] = { /******/ exports: {}, /******/ id: moduleId, /******/ loaded: false /******/ }; /******/ /******/ // Execute the module function /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); /******/ /******/ // Flag the module as loaded /******/ module.loaded = true; /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /******/ /******/ // expose the modules object (__webpack_modules__) /******/ __webpack_require__.m = modules; /******/ /******/ // expose the module cache /******/ __webpack_require__.c = installedModules; /******/ /******/ // __webpack_public_path__ /******/ __webpack_require__.p = ""; /******/ /******/ // Load entry module and return exports /******/ return __webpack_require__(0); /******/ }) /************************************************************************/ /******/ ([ /* 0 */ /*!**********************!*\ !*** ./src/index.js ***! \**********************/ /***/ function(module, exports, __webpack_require__) { /* React-Quill 0.0.2 https://github.com/zenoamaro/react-quill */ module.exports = __webpack_require__(/*! ./component */ 1); module.exports.Mixin = __webpack_require__(/*! ./mixin */ 2); module.exports.Toolbar = __webpack_require__(/*! ./toolbar */ 3); /***/ }, /* 1 */ /*!**************************!*\ !*** ./src/component.js ***! \**************************/ /***/ function(module, exports, __webpack_require__) { 'use strict'; var React = __webpack_require__(/*! react */ 4), QuillToolbar = __webpack_require__(/*! ./toolbar */ 3), QuillMixin = __webpack_require__(/*! ./mixin */ 2), T = React.PropTypes; // Support React 0.11 and 0.12 // FIXME: Remove with React 0.13 if (React.createFactory) { QuillToolbar = React.createFactory(QuillToolbar); } var QuillComponent = React.createClass({ displayName: 'Quill', mixins: [ QuillMixin ], propTypes: { id: T.string, className: T.string, value: T.string, defaultValue: T.string, readOnly: T.bool, toolbar: T.object, formats: T.array, styles: T.object, theme: T.string, pollInterval: T.number, onChange: T.func }, getDefaultProps: function() { return { className: '', modules: {} }; }, /* Retrieve the initial value from either `value` (preferred) or `defaultValue` if you want an un-controlled component. */ getInitialState: function() { return {}; }, /* Update only if we've been passed a new `value`. This leaves components using `defaultValue` alone. */ componentWillReceiveProps: function(nextProps) { if ('value' in nextProps) { if (nextProps.value !== this.props.value) { this.setEditorContents(this.state.editor, nextProps.value); } } }, componentDidMount: function() { var editor = this.createEditor( this.getEditorElement(), this.getEditorConfig()); this.setState({ editor:editor }); }, componentWillUnmount: function() { this.destroyEditor(this.state.editor); }, shouldComponentUpdate: function(nextProps, nextState) { // Never re-render or we lose the element. return false; }, /* If for whatever reason we are rendering again, we should tear down the editor and bring it up again. */ componentWillUpdate: function() { this.componentWillUnmount(); }, componentDidUpdate: function() { this.componentDidMount(); }, getEditorConfig: function() { var config = { readOnly: this.props.readOnly, theme: this.props.theme, formats: this.props.formats, styles: this.props.styles, modules: this.props.modules, pollInterval: this.props.pollInterval }; // Unless we're redefining the toolbar, // attach to the default one as a ref. if (!config.modules.toolbar) { // Don't mutate the original modules // because it's shared between components. config.modules = JSON.parse(JSON.stringify(config.modules)); config.modules.toolbar = { container: this.refs.toolbar.getDOMNode() }; } return config; }, getEditorElement: function() { return this.refs.editor.getDOMNode(); }, getEditorContents: function() { return this.props.value || this.props.defaultValue; }, getClassName: function() { return ['quill', this.props.className].join(' '); }, /* Renders either the specified contents, or a default configuration of toolbar and contents area. */ renderContents: function() { if (React.Children.count(this.props.children) > 0) { return React.Children.only(this.props.children); } else { return [ QuillToolbar({ key:'toolbar', ref:'toolbar', items: this.props.toolbar }), React.DOM.div({ key:'editor', ref:'editor', className: 'quill-contents', dangerouslySetInnerHTML: { __html:this.getEditorContents() } }) ]; } }, render: function() { return React.DOM.div({ className: this.getClassName(), onChange: this.preventDefault }, this.renderContents() ); }, /* Updates the local state with the new contents, executes the change handler passed as props. */ onEditorChange: function(value) { if (value !== this.state.value) { if (this.props.onChange) { this.props.onChange(value); } } }, /* Stop change events from the toolbar from bubbling up outside. */ preventDefault: function(event) { event.preventDefault(); event.stopPropagation(); } }); module.exports = QuillComponent; /***/ }, /* 2 */ /*!**********************!*\ !*** ./src/mixin.js ***! \**********************/ /***/ function(module, exports, __webpack_require__) { 'use strict'; var React = __webpack_require__(/*! react */ 4), Quill = __webpack_require__(/*! quilljs */ 5), T = React.PropTypes; var QuillMixin = { /** Creates an editor on the given element. The editor will be passed the configuration, have its events bound, */ createEditor: function($el, config) { var editor = new Quill($el, config); this.hookEditor(editor); return editor; }, hookEditor: function(editor) { var self = this; editor.on('text-change', function(delta, source) { if (self.onEditorChange) { self.onEditorChange(editor.getHTML(), delta, source); } }); }, 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'); }, destroyEditor: function(editor) { // TODO: How to destroy this? // editor.destroy(); editor.removeAllListeners(); }, /* Replace the contents of the editor, but keep the previous selection hanging around so that the cursor won't move. */ setEditorContents: function(editor, value) { var sel = editor.getSelection(); editor.setHTML(value); editor.setSelection(sel); } }; module.exports = QuillMixin; /***/ }, /* 3 */ /*!************************!*\ !*** ./src/toolbar.js ***! \************************/ /***/ function(module, exports, __webpack_require__) { 'use strict'; var React = __webpack_require__(/*! react */ 4), T = React.PropTypes; var defaultItems = [ { 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' } ]} ]; var QuillToolbar = React.createClass({ displayName: 'Quill Toolbar', propTypes: { id: T.string, className: T.string, items: T.array }, getDefaultProps: function(){ return { items: defaultItems }; }, renderGroup: function(item) { return React.DOM.span({ key: item.label, className:'ql-format-group' }, item.items.map(this.renderItem) ); }, renderChoiceItem: function(item) { return React.DOM.option({ key: item.label || item.value, value:item.value }, item.label ); }, renderChoices: function(item) { return React.DOM.select({ key: item.label, className: 'ql-'+item.type }, item.items.map(this.renderChoiceItem) ); }, renderAction: function(item) { return React.DOM.span({ key: item.label || item.value, className: 'ql-format-button ql-'+item.type, title: item.label } ); }, renderItem: function(item) { var mapping = { 'group': this.renderGroup, 'align': this.renderChoices, 'size': this.renderChoices, 'action': this.renderAction }; var renderer = mapping[item.type] || mapping.action; return renderer(item); }, getClassName: function() { return 'quill-toolbar ' + (this.props.className||''); }, render: function() { return React.DOM.div({ className: this.getClassName() }, this.props.items.map(this.renderItem) ); } }); module.exports = QuillToolbar; /***/ }, /* 4 */ /*!**************************************************************************************!*\ !*** external {"commonjs":"react","commonjs2":"react","amd":"react","root":"React"} ***! \**************************************************************************************/ /***/ function(module, exports, __webpack_require__) { module.exports = __WEBPACK_EXTERNAL_MODULE_4__; /***/ }, /* 5 */ /*!********************************************************************************************!*\ !*** external {"commonjs":"quilljs","commonjs2":"quilljs","amd":"quilljs","root":"Quill"} ***! \********************************************************************************************/ /***/ function(module, exports, __webpack_require__) { module.exports = __WEBPACK_EXTERNAL_MODULE_5__; /***/ } /******/ ]) }); //# 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"}