460 lines
30 KiB
JavaScript
460 lines
30 KiB
JavaScript
(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"}
|