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

ngx-quill

Package Overview
Dependencies
Maintainers
1
Versions
290
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ngx-quill - npm Package Compare versions

Comparing version 13.1.0 to 13.2.0

8

bundles/ngx-quill.umd.js

@@ -980,2 +980,3 @@ (function (global, factory) {

this.preserveWhitespace = false;
this.onEditorCreated = new i0.EventEmitter();
this.valueSetter = function (quillEditor, value) {

@@ -1064,2 +1065,6 @@ var format = getFormat(_this.format, _this.service.config.format);

}
// trigger created in a timeout to avoid changed models after checked
setTimeout(function () {
_this.onEditorCreated.emit(_this.quillEditor);
});
return [2 /*return*/];

@@ -1099,3 +1104,4 @@ }

customOptions: [{ type: i0.Input }],
preserveWhitespace: [{ type: i0.Input }]
preserveWhitespace: [{ type: i0.Input }],
onEditorCreated: [{ type: i0.Output }]
};

@@ -1102,0 +1108,0 @@

2

bundles/ngx-quill.umd.min.js

@@ -15,3 +15,3 @@ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/common"),require("@angular/core"),require("@angular/platform-browser"),require("@angular/forms")):"function"==typeof define&&define.amd?define("ngx-quill",["exports","@angular/common","@angular/core","@angular/platform-browser","@angular/forms"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self)["ngx-quill"]={},e.ng.common,e.ng.core,e.ng.platformBrowser,e.ng.forms)}(this,(function(e,t,i,n,r){"use strict";

PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */var o=function(e,t){return(o=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var i in t)Object.prototype.hasOwnProperty.call(t,i)&&(e[i]=t[i])})(e,t)};function s(e,t,i,n){return new(i||(i=Promise))((function(r,o){function s(e){try{a(n.next(e))}catch(e){o(e)}}function l(e){try{a(n.throw(e))}catch(e){o(e)}}function a(e){var t;e.done?r(e.value):(t=e.value,t instanceof i?t:new i((function(e){e(t)}))).then(s,l)}a((n=n.apply(e,t||[])).next())}))}function l(e,t){var i,n,r,o,s={label:0,sent:function(){if(1&r[0])throw r[1];return r[1]},trys:[],ops:[]};return o={next:l(0),throw:l(1),return:l(2)},"function"==typeof Symbol&&(o[Symbol.iterator]=function(){return this}),o;function l(o){return function(l){return function(o){if(i)throw new TypeError("Generator is already executing.");for(;s;)try{if(i=1,n&&(r=2&o[0]?n.return:o[0]?n.throw||((r=n.return)&&r.call(n),0):n.next)&&!(r=r.call(n,o[1])).done)return r;switch(n=0,r&&(o=[2&o[0],r.value]),o[0]){case 0:case 1:r=o;break;case 4:return s.label++,{value:o[1],done:!1};case 5:s.label++,n=o[1],o=[0];continue;case 7:o=s.ops.pop(),s.trys.pop();continue;default:if(!(r=s.trys,(r=r.length>0&&r[r.length-1])||6!==o[0]&&2!==o[0])){s=0;continue}if(3===o[0]&&(!r||o[1]>r[0]&&o[1]<r[3])){s.label=o[1];break}if(6===o[0]&&s.label<r[1]){s.label=r[1],r=o;break}if(r&&s.label<r[2]){s.label=r[2],s.ops.push(o);break}r[2]&&s.ops.pop(),s.trys.pop();continue}o=t.call(e,s)}catch(e){o=[6,e],n=0}finally{i=r=0}if(5&o[0])throw o[1];return{value:o[0]?o[1]:void 0,done:!0}}([o,l])}}}Object.create;function a(e,t){var i="function"==typeof Symbol&&e[Symbol.iterator];if(!i)return e;var n,r,o=i.call(e),s=[];try{for(;(void 0===t||t-- >0)&&!(n=o.next()).done;)s.push(n.value)}catch(e){r={error:e}}finally{try{n&&!n.done&&(i=o.return)&&i.call(o)}finally{if(r)throw r.error}}return s}Object.create;var u={toolbar:[["bold","italic","underline","strike"],["blockquote","code-block"],[{header:1},{header:2}],[{list:"ordered"},{list:"bullet"}],[{script:"sub"},{script:"super"}],[{indent:"-1"},{indent:"+1"}],[{direction:"rtl"}],[{size:["small",!1,"large","huge"]}],[{header:[1,2,3,4,5,6,!1]}],[{color:[]},{background:[]}],[{font:[]}],[{align:[]}],["clean"],["link","image","video"]]},c=function(e,t){return e||t||"html"},h=new i.InjectionToken("config"),d=function(){function e(e){this.config=e,this.count=0,this.config||(this.config={modules:u})}return e.prototype.getQuill=function(){var e=this;return this.count++,this.Quill||1!==this.count||(this.$importPromise=new Promise((function(t){return s(e,void 0,void 0,(function(){var e,i,n,r=this;return l(this,(function(o){switch(o.label){case 0:return[4,import("quill")];case 1:return n=o.sent(),this.Quill=n.default?n.default:n,null===(e=this.config.customOptions)||void 0===e||e.forEach((function(e){var t=r.Quill.import(e.import);t.whitelist=e.whitelist,r.Quill.register(t,!0,r.config.suppressGlobalRegisterWarning)})),null===(i=this.config.customModules)||void 0===i||i.forEach((function(e){var t=e.implementation,i=e.path;r.Quill.register(i,t,r.config.suppressGlobalRegisterWarning)})),t(this.Quill),[2]}}))}))}))),this.$importPromise},e}();d.ɵprov=i.ɵɵdefineInjectable({factory:function(){return new d(i.ɵɵinject(h))},token:d,providedIn:"root"}),d.decorators=[{type:i.Injectable,args:[{providedIn:"root"}]}],d.ctorParameters=function(){return[{type:void 0,decorators:[{type:i.Inject,args:[h]}]}]};var p=function(){function e(e,t,n,r,o,s,l){var a=this;this.elementRef=e,this.domSanitizer=t,this.doc=n,this.platformId=r,this.renderer=o,this.zone=s,this.service=l,this.required=!1,this.customToolbarPosition="top",this.sanitize=!1,this.styles=null,this.strict=!0,this.customOptions=[],this.customModules=[],this.preserveWhitespace=!1,this.trimOnValidation=!1,this.compareValues=!1,this.filterNull=!1,this.onEditorCreated=new i.EventEmitter,this.onEditorChanged=new i.EventEmitter,this.onContentChanged=new i.EventEmitter,this.onSelectionChanged=new i.EventEmitter,this.onFocus=new i.EventEmitter,this.onBlur=new i.EventEmitter,this.disabled=!1,this.valueGetter=function(e,t){var i=t.querySelector(".ql-editor").innerHTML;"<p><br></p>"!==i&&"<div><br></div>"!==i||(i=null);var n=i,r=c(a.format,a.service.config.format);if("text"===r)n=e.getText();else if("object"===r)n=e.getContents();else if("json"===r)try{n=JSON.stringify(e.getContents())}catch(t){n=e.getText()}return n},this.valueSetter=function(e,t){var n=c(a.format,a.service.config.format);if("html"===n)return a.sanitize&&(t=a.domSanitizer.sanitize(i.SecurityContext.HTML,t)),e.clipboard.convert(t);if("json"===n)try{return JSON.parse(t)}catch(e){return[{insert:t}]}return t},this.selectionChangeHandler=function(e,t,i){var n=!e&&!!a.onModelTouched;(a.onBlur.observers.length||a.onFocus.observers.length||a.onSelectionChanged.observers.length||n)&&a.zone.run((function(){null===e?a.onBlur.emit({editor:a.quillEditor,source:i}):null===t&&a.onFocus.emit({editor:a.quillEditor,source:i}),a.onSelectionChanged.emit({editor:a.quillEditor,oldRange:t,range:e,source:i}),n&&a.onModelTouched()}))},this.textChangeHandler=function(e,t,i){var n=a.quillEditor.getText(),r=a.quillEditor.getContents(),o=a.editorElem.querySelector(".ql-editor").innerHTML;"<p><br></p>"!==o&&"<div><br></div>"!==o||(o=null);var s=a.trackChanges||a.service.config.trackChanges,l=("user"===i||s&&"all"===s)&&!!a.onModelChange;(a.onContentChanged.observers.length||l)&&a.zone.run((function(){l&&a.onModelChange(a.valueGetter(a.quillEditor,a.editorElem)),a.onContentChanged.emit({content:r,delta:e,editor:a.quillEditor,html:o,oldDelta:t,source:i,text:n})}))},this.editorChangeHandler=function(e,t,i,n){if(a.onEditorChanged.observers.length)if("text-change"===e){var r=a.quillEditor.getText(),o=a.quillEditor.getContents(),s=a.editorElem.querySelector(".ql-editor").innerHTML;"<p><br></p>"!==s&&"<div><br></div>"!==s||(s=null),a.zone.run((function(){a.onEditorChanged.emit({content:o,delta:t,editor:a.quillEditor,event:e,html:s,oldDelta:i,source:n,text:r})}))}else a.onEditorChanged.emit({editor:a.quillEditor,event:e,oldRange:i,range:t,source:n})}}return e.normalizeClassNames=function(e){return e.trim().split(" ").reduce((function(e,t){var i=t.trim();return i&&e.push(i),e}),[])},e.prototype.ngAfterViewInit=function(){return s(this,void 0,void 0,(function(){var e,i,n,r,o,s,h,d,p,f,m=this;return l(this,(function(l){switch(l.label){case 0:return t.isPlatformServer(this.platformId)?[2]:[4,this.service.getQuill()];case 1:return e=l.sent(),this.elementRef.nativeElement.insertAdjacentHTML("top"===this.customToolbarPosition?"beforeend":"afterbegin",this.preserveWhitespace?"<pre quill-editor-element></pre>":"<div quill-editor-element></div>"),this.editorElem=this.elementRef.nativeElement.querySelector("[quill-editor-element]"),i=this.elementRef.nativeElement.querySelector("[quill-editor-toolbar]"),n=Object.assign({},this.modules||this.service.config.modules),i?n.toolbar=i:void 0===n.toolbar&&(n.toolbar=u.toolbar),void 0===(r=void 0!==this.placeholder?this.placeholder:this.service.config.placeholder)&&(r="Insert text here ..."),this.styles&&Object.keys(this.styles).forEach((function(e){m.renderer.setStyle(m.editorElem,e,m.styles[e])})),this.classes&&this.addClasses(this.classes),this.customOptions.forEach((function(t){var i=e.import(t.import);i.whitelist=t.whitelist,e.register(i,!0)})),this.customModules.forEach((function(t){var i=t.implementation,n=t.path;e.register(n,i)})),(o=this.bounds&&"self"===this.bounds?this.editorElem:this.bounds)||(o=this.service.config.bounds?this.service.config.bounds:this.doc.body),!(s=this.debug)&&!1!==s&&this.service.config.debug&&(s=this.service.config.debug),(h=this.readOnly)||!1===this.readOnly||(h=void 0!==this.service.config.readOnly&&this.service.config.readOnly),(d=this.scrollingContainer)||null===this.scrollingContainer||(d=null===this.service.config.scrollingContainer||this.service.config.scrollingContainer?this.service.config.scrollingContainer:null),(p=this.formats)||void 0!==p||(p=this.service.config.formats?function(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(a(arguments[t]));return e}(this.service.config.formats):null===this.service.config.formats?null:void 0),this.zone.runOutsideAngular((function(){var t,i,l;if(m.quillEditor=new e(m.editorElem,{bounds:o,debug:s,formats:p,modules:n,placeholder:r,readOnly:h,scrollingContainer:d,strict:m.strict,theme:m.theme||(m.service.config.theme?m.service.config.theme:"snow")}),m.linkPlaceholder){var a=null===(i=null===(t=m.quillEditor)||void 0===t?void 0:t.theme)||void 0===i?void 0:i.tooltip,u=null===(l=null==a?void 0:a.root)||void 0===l?void 0:l.querySelector("input[data-link]");(null==u?void 0:u.dataset)&&(u.dataset.link=m.linkPlaceholder)}})),this.content&&("text"===c(this.format,this.service.config.format)?this.quillEditor.setText(this.content,"silent"):(f=this.valueSetter(this.quillEditor,this.content),this.quillEditor.setContents(f,"silent")),this.quillEditor.getModule("history").clear()),this.setDisabledState(),this.quillEditor.on("editor-change",this.editorChangeHandler),this.quillEditor.on("selection-change",this.selectionChangeHandler),this.quillEditor.on("text-change",this.textChangeHandler),setTimeout((function(){m.onValidatorChanged&&m.onValidatorChanged(),m.onEditorCreated.emit(m.quillEditor)})),[2]}}))}))},e.prototype.ngOnDestroy=function(){this.quillEditor&&(this.quillEditor.off("selection-change",this.selectionChangeHandler),this.quillEditor.off("text-change",this.textChangeHandler),this.quillEditor.off("editor-change",this.editorChangeHandler))},e.prototype.ngOnChanges=function(e){var t=this;if(this.quillEditor){if(e.readOnly&&this.quillEditor.enable(!e.readOnly.currentValue),e.placeholder&&(this.quillEditor.root.dataset.placeholder=e.placeholder.currentValue),e.styles){var i=e.styles.currentValue,n=e.styles.previousValue;n&&Object.keys(n).forEach((function(e){t.renderer.removeStyle(t.editorElem,e)})),i&&Object.keys(i).forEach((function(e){t.renderer.setStyle(t.editorElem,e,t.styles[e])}))}if(e.classes){var r=e.classes.currentValue,o=e.classes.previousValue;o&&this.removeClasses(o),r&&this.addClasses(r)}}},e.prototype.addClasses=function(t){var i=this;e.normalizeClassNames(t).forEach((function(e){i.renderer.addClass(i.editorElem,e)}))},e.prototype.removeClasses=function(t){var i=this;e.normalizeClassNames(t).forEach((function(e){i.renderer.removeClass(i.editorElem,e)}))},e.prototype.writeValue=function(e){if((!this.filterNull||null!==e)&&(this.content=e,this.quillEditor)){var t=c(this.format,this.service.config.format),i=this.valueSetter(this.quillEditor,e);if(this.compareValues){var n=this.quillEditor.getContents();if(JSON.stringify(n)===JSON.stringify(i))return}e?"text"===t?this.quillEditor.setText(e):this.quillEditor.setContents(i):this.quillEditor.setText("")}},e.prototype.setDisabledState=function(e){void 0===e&&(e=this.disabled),this.disabled=e,this.quillEditor&&(e?(this.quillEditor.disable(),this.renderer.setAttribute(this.elementRef.nativeElement,"disabled","disabled")):(this.readOnly||this.quillEditor.enable(),this.renderer.removeAttribute(this.elementRef.nativeElement,"disabled")))},e.prototype.registerOnChange=function(e){this.onModelChange=e},e.prototype.registerOnTouched=function(e){this.onModelTouched=e},e.prototype.registerOnValidatorChange=function(e){this.onValidatorChanged=e},e.prototype.validate=function(){if(!this.quillEditor)return null;var e={},t=!0,i=this.quillEditor.getText(),n=this.trimOnValidation?i.trim().length:1===i.length&&0===i.trim().length?0:i.length-1;return this.minLength&&n&&n<this.minLength&&(e.minLengthError={given:n,minLength:this.minLength},t=!1),this.maxLength&&n>this.maxLength&&(e.maxLengthError={given:n,maxLength:this.maxLength},t=!1),this.required&&!n&&(e.requiredError={empty:!0},t=!1),t?null:e},e}();p.decorators=[{type:i.Directive}],p.ctorParameters=function(){return[{type:i.ElementRef},{type:n.DomSanitizer},{type:void 0,decorators:[{type:i.Inject,args:[t.DOCUMENT]}]},{type:void 0,decorators:[{type:i.Inject,args:[i.PLATFORM_ID]}]},{type:i.Renderer2},{type:i.NgZone},{type:d}]},p.propDecorators={format:[{type:i.Input}],theme:[{type:i.Input}],modules:[{type:i.Input}],debug:[{type:i.Input}],readOnly:[{type:i.Input}],placeholder:[{type:i.Input}],maxLength:[{type:i.Input}],minLength:[{type:i.Input}],required:[{type:i.Input}],formats:[{type:i.Input}],customToolbarPosition:[{type:i.Input}],sanitize:[{type:i.Input}],styles:[{type:i.Input}],strict:[{type:i.Input}],scrollingContainer:[{type:i.Input}],bounds:[{type:i.Input}],customOptions:[{type:i.Input}],customModules:[{type:i.Input}],trackChanges:[{type:i.Input}],preserveWhitespace:[{type:i.Input}],classes:[{type:i.Input}],trimOnValidation:[{type:i.Input}],linkPlaceholder:[{type:i.Input}],compareValues:[{type:i.Input}],filterNull:[{type:i.Input}],onEditorCreated:[{type:i.Output}],onEditorChanged:[{type:i.Output}],onContentChanged:[{type:i.Output}],onSelectionChanged:[{type:i.Output}],onFocus:[{type:i.Output}],onBlur:[{type:i.Output}],valueGetter:[{type:i.Input}],valueSetter:[{type:i.Input}]};var f=function(e){function t(t,i,n,r,o,s,l){return e.call(this,t,i,n,r,o,s,l)||this}return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Class extends value "+String(t)+" is not a constructor or null");function i(){this.constructor=e}o(e,t),e.prototype=null===t?Object.create(t):(i.prototype=t.prototype,new i)}(t,e),t}(p);f.decorators=[{type:i.Component,args:[{encapsulation:i.ViewEncapsulation.None,providers:[{multi:!0,provide:r.NG_VALUE_ACCESSOR,useExisting:i.forwardRef((function(){return f}))},{multi:!0,provide:r.NG_VALIDATORS,useExisting:i.forwardRef((function(){return f}))}],selector:"quill-editor",template:'\n <ng-content select="[quill-editor-toolbar]"></ng-content>\n'}]}],f.ctorParameters=function(){return[{type:i.ElementRef,decorators:[{type:i.Inject,args:[i.ElementRef]}]},{type:n.DomSanitizer,decorators:[{type:i.Inject,args:[n.DomSanitizer]}]},{type:void 0,decorators:[{type:i.Inject,args:[t.DOCUMENT]}]},{type:void 0,decorators:[{type:i.Inject,args:[i.PLATFORM_ID]}]},{type:i.Renderer2,decorators:[{type:i.Inject,args:[i.Renderer2]}]},{type:i.NgZone,decorators:[{type:i.Inject,args:[i.NgZone]}]},{type:d,decorators:[{type:i.Inject,args:[d]}]}]};var m=function(){function e(e,t){this.sanitizer=e,this.service=t,this.content="",this.innerHTML="",this.themeClass="ql-snow"}return e.prototype.ngOnChanges=function(e){if(e.theme){var t=e.theme.currentValue||(this.service.config.theme?this.service.config.theme:"snow");this.themeClass="ql-"+t+" ngx-quill-view-html"}else if(!this.theme){t=this.service.config.theme?this.service.config.theme:"snow";this.themeClass="ql-"+t+" ngx-quill-view-html"}e.content&&(this.innerHTML=this.sanitizer.bypassSecurityTrustHtml(e.content.currentValue))},e}();m.decorators=[{type:i.Component,args:[{encapsulation:i.ViewEncapsulation.None,selector:"quill-view-html",template:'\n <div class="ql-container" [ngClass]="themeClass">\n <div class="ql-editor" [innerHTML]="innerHTML">\n </div>\n </div>\n',styles:["\n.ql-container.ngx-quill-view-html {\n border: 0;\n}\n"]}]}],m.ctorParameters=function(){return[{type:n.DomSanitizer,decorators:[{type:i.Inject,args:[n.DomSanitizer]}]},{type:d}]},m.propDecorators={content:[{type:i.Input}],theme:[{type:i.Input}]};var g=function(){function e(e,t,n,r,o,s){var l=this;this.elementRef=e,this.renderer=t,this.zone=n,this.service=r,this.domSanitizer=o,this.platformId=s,this.sanitize=!1,this.strict=!0,this.customModules=[],this.customOptions=[],this.preserveWhitespace=!1,this.valueSetter=function(e,t){var n=c(l.format,l.service.config.format),r=t;if("text"===n)e.setText(r);else{if("html"===n)l.sanitize&&(t=l.domSanitizer.sanitize(i.SecurityContext.HTML,t)),r=e.clipboard.convert(t);else if("json"===n)try{r=JSON.parse(t)}catch(e){r=[{insert:t}]}e.setContents(r)}}}return e.prototype.ngOnChanges=function(e){this.quillEditor&&e.content&&this.valueSetter(this.quillEditor,e.content.currentValue)},e.prototype.ngAfterViewInit=function(){return s(this,void 0,void 0,(function(){var e,i,n,r,o,s=this;return l(this,(function(l){switch(l.label){case 0:return t.isPlatformServer(this.platformId)?[2]:[4,this.service.getQuill()];case 1:return e=l.sent(),(i=Object.assign({},this.modules||this.service.config.modules)).toolbar=!1,this.customOptions.forEach((function(t){var i=e.import(t.import);i.whitelist=t.whitelist,e.register(i,!0)})),this.customModules.forEach((function(t){var i=t.implementation,n=t.path;e.register(n,i)})),!(n=this.debug)&&!1!==n&&this.service.config.debug&&(n=this.service.config.debug),(r=this.formats)||void 0!==r||(r=this.service.config.formats?Object.assign({},this.service.config.formats):null===this.service.config.formats?null:void 0),o=this.theme||(this.service.config.theme?this.service.config.theme:"snow"),this.elementRef.nativeElement.insertAdjacentHTML("afterbegin",this.preserveWhitespace?"<pre quill-view-element></pre>":"<div quill-view-element></div>"),this.editorElem=this.elementRef.nativeElement.querySelector("[quill-view-element]"),this.zone.runOutsideAngular((function(){s.quillEditor=new e(s.editorElem,{debug:n,formats:r,modules:i,readOnly:!0,strict:s.strict,theme:o})})),this.renderer.addClass(this.editorElem,"ngx-quill-view"),this.content&&this.valueSetter(this.quillEditor,this.content),[2]}}))}))},e}();g.decorators=[{type:i.Component,args:[{encapsulation:i.ViewEncapsulation.None,selector:"quill-view",template:"\n",styles:["\n.ql-container.ngx-quill-view {\n border: 0;\n}\n"]}]}],g.ctorParameters=function(){return[{type:i.ElementRef},{type:i.Renderer2},{type:i.NgZone},{type:d},{type:n.DomSanitizer},{type:void 0,decorators:[{type:i.Inject,args:[i.PLATFORM_ID]}]}]},g.propDecorators={format:[{type:i.Input}],theme:[{type:i.Input}],modules:[{type:i.Input}],debug:[{type:i.Input}],formats:[{type:i.Input}],sanitize:[{type:i.Input}],strict:[{type:i.Input}],content:[{type:i.Input}],customModules:[{type:i.Input}],customOptions:[{type:i.Input}],preserveWhitespace:[{type:i.Input}]};var v=function(){function e(){}return e.forRoot=function(t){return{ngModule:e,providers:[{provide:h,useValue:t}]}},e}();v.decorators=[{type:i.NgModule,args:[{declarations:[f,g,m],exports:[f,g,m],imports:[t.CommonModule],providers:[d]}]}],e.QUILL_CONFIG_TOKEN=h,e.QuillEditorBase=p,e.QuillEditorComponent=f,e.QuillModule=v,e.QuillService=d,e.QuillViewComponent=g,e.QuillViewHTMLComponent=m,e.defaultModules=u,Object.defineProperty(e,"__esModule",{value:!0})}));
***************************************************************************** */var o=function(e,t){return(o=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var i in t)Object.prototype.hasOwnProperty.call(t,i)&&(e[i]=t[i])})(e,t)};function s(e,t,i,n){return new(i||(i=Promise))((function(r,o){function s(e){try{a(n.next(e))}catch(e){o(e)}}function l(e){try{a(n.throw(e))}catch(e){o(e)}}function a(e){var t;e.done?r(e.value):(t=e.value,t instanceof i?t:new i((function(e){e(t)}))).then(s,l)}a((n=n.apply(e,t||[])).next())}))}function l(e,t){var i,n,r,o,s={label:0,sent:function(){if(1&r[0])throw r[1];return r[1]},trys:[],ops:[]};return o={next:l(0),throw:l(1),return:l(2)},"function"==typeof Symbol&&(o[Symbol.iterator]=function(){return this}),o;function l(o){return function(l){return function(o){if(i)throw new TypeError("Generator is already executing.");for(;s;)try{if(i=1,n&&(r=2&o[0]?n.return:o[0]?n.throw||((r=n.return)&&r.call(n),0):n.next)&&!(r=r.call(n,o[1])).done)return r;switch(n=0,r&&(o=[2&o[0],r.value]),o[0]){case 0:case 1:r=o;break;case 4:return s.label++,{value:o[1],done:!1};case 5:s.label++,n=o[1],o=[0];continue;case 7:o=s.ops.pop(),s.trys.pop();continue;default:if(!(r=s.trys,(r=r.length>0&&r[r.length-1])||6!==o[0]&&2!==o[0])){s=0;continue}if(3===o[0]&&(!r||o[1]>r[0]&&o[1]<r[3])){s.label=o[1];break}if(6===o[0]&&s.label<r[1]){s.label=r[1],r=o;break}if(r&&s.label<r[2]){s.label=r[2],s.ops.push(o);break}r[2]&&s.ops.pop(),s.trys.pop();continue}o=t.call(e,s)}catch(e){o=[6,e],n=0}finally{i=r=0}if(5&o[0])throw o[1];return{value:o[0]?o[1]:void 0,done:!0}}([o,l])}}}Object.create;function a(e,t){var i="function"==typeof Symbol&&e[Symbol.iterator];if(!i)return e;var n,r,o=i.call(e),s=[];try{for(;(void 0===t||t-- >0)&&!(n=o.next()).done;)s.push(n.value)}catch(e){r={error:e}}finally{try{n&&!n.done&&(i=o.return)&&i.call(o)}finally{if(r)throw r.error}}return s}Object.create;var u={toolbar:[["bold","italic","underline","strike"],["blockquote","code-block"],[{header:1},{header:2}],[{list:"ordered"},{list:"bullet"}],[{script:"sub"},{script:"super"}],[{indent:"-1"},{indent:"+1"}],[{direction:"rtl"}],[{size:["small",!1,"large","huge"]}],[{header:[1,2,3,4,5,6,!1]}],[{color:[]},{background:[]}],[{font:[]}],[{align:[]}],["clean"],["link","image","video"]]},c=function(e,t){return e||t||"html"},h=new i.InjectionToken("config"),d=function(){function e(e){this.config=e,this.count=0,this.config||(this.config={modules:u})}return e.prototype.getQuill=function(){var e=this;return this.count++,this.Quill||1!==this.count||(this.$importPromise=new Promise((function(t){return s(e,void 0,void 0,(function(){var e,i,n,r=this;return l(this,(function(o){switch(o.label){case 0:return[4,import("quill")];case 1:return n=o.sent(),this.Quill=n.default?n.default:n,null===(e=this.config.customOptions)||void 0===e||e.forEach((function(e){var t=r.Quill.import(e.import);t.whitelist=e.whitelist,r.Quill.register(t,!0,r.config.suppressGlobalRegisterWarning)})),null===(i=this.config.customModules)||void 0===i||i.forEach((function(e){var t=e.implementation,i=e.path;r.Quill.register(i,t,r.config.suppressGlobalRegisterWarning)})),t(this.Quill),[2]}}))}))}))),this.$importPromise},e}();d.ɵprov=i.ɵɵdefineInjectable({factory:function(){return new d(i.ɵɵinject(h))},token:d,providedIn:"root"}),d.decorators=[{type:i.Injectable,args:[{providedIn:"root"}]}],d.ctorParameters=function(){return[{type:void 0,decorators:[{type:i.Inject,args:[h]}]}]};var p=function(){function e(e,t,n,r,o,s,l){var a=this;this.elementRef=e,this.domSanitizer=t,this.doc=n,this.platformId=r,this.renderer=o,this.zone=s,this.service=l,this.required=!1,this.customToolbarPosition="top",this.sanitize=!1,this.styles=null,this.strict=!0,this.customOptions=[],this.customModules=[],this.preserveWhitespace=!1,this.trimOnValidation=!1,this.compareValues=!1,this.filterNull=!1,this.onEditorCreated=new i.EventEmitter,this.onEditorChanged=new i.EventEmitter,this.onContentChanged=new i.EventEmitter,this.onSelectionChanged=new i.EventEmitter,this.onFocus=new i.EventEmitter,this.onBlur=new i.EventEmitter,this.disabled=!1,this.valueGetter=function(e,t){var i=t.querySelector(".ql-editor").innerHTML;"<p><br></p>"!==i&&"<div><br></div>"!==i||(i=null);var n=i,r=c(a.format,a.service.config.format);if("text"===r)n=e.getText();else if("object"===r)n=e.getContents();else if("json"===r)try{n=JSON.stringify(e.getContents())}catch(t){n=e.getText()}return n},this.valueSetter=function(e,t){var n=c(a.format,a.service.config.format);if("html"===n)return a.sanitize&&(t=a.domSanitizer.sanitize(i.SecurityContext.HTML,t)),e.clipboard.convert(t);if("json"===n)try{return JSON.parse(t)}catch(e){return[{insert:t}]}return t},this.selectionChangeHandler=function(e,t,i){var n=!e&&!!a.onModelTouched;(a.onBlur.observers.length||a.onFocus.observers.length||a.onSelectionChanged.observers.length||n)&&a.zone.run((function(){null===e?a.onBlur.emit({editor:a.quillEditor,source:i}):null===t&&a.onFocus.emit({editor:a.quillEditor,source:i}),a.onSelectionChanged.emit({editor:a.quillEditor,oldRange:t,range:e,source:i}),n&&a.onModelTouched()}))},this.textChangeHandler=function(e,t,i){var n=a.quillEditor.getText(),r=a.quillEditor.getContents(),o=a.editorElem.querySelector(".ql-editor").innerHTML;"<p><br></p>"!==o&&"<div><br></div>"!==o||(o=null);var s=a.trackChanges||a.service.config.trackChanges,l=("user"===i||s&&"all"===s)&&!!a.onModelChange;(a.onContentChanged.observers.length||l)&&a.zone.run((function(){l&&a.onModelChange(a.valueGetter(a.quillEditor,a.editorElem)),a.onContentChanged.emit({content:r,delta:e,editor:a.quillEditor,html:o,oldDelta:t,source:i,text:n})}))},this.editorChangeHandler=function(e,t,i,n){if(a.onEditorChanged.observers.length)if("text-change"===e){var r=a.quillEditor.getText(),o=a.quillEditor.getContents(),s=a.editorElem.querySelector(".ql-editor").innerHTML;"<p><br></p>"!==s&&"<div><br></div>"!==s||(s=null),a.zone.run((function(){a.onEditorChanged.emit({content:o,delta:t,editor:a.quillEditor,event:e,html:s,oldDelta:i,source:n,text:r})}))}else a.onEditorChanged.emit({editor:a.quillEditor,event:e,oldRange:i,range:t,source:n})}}return e.normalizeClassNames=function(e){return e.trim().split(" ").reduce((function(e,t){var i=t.trim();return i&&e.push(i),e}),[])},e.prototype.ngAfterViewInit=function(){return s(this,void 0,void 0,(function(){var e,i,n,r,o,s,h,d,p,f,m=this;return l(this,(function(l){switch(l.label){case 0:return t.isPlatformServer(this.platformId)?[2]:[4,this.service.getQuill()];case 1:return e=l.sent(),this.elementRef.nativeElement.insertAdjacentHTML("top"===this.customToolbarPosition?"beforeend":"afterbegin",this.preserveWhitespace?"<pre quill-editor-element></pre>":"<div quill-editor-element></div>"),this.editorElem=this.elementRef.nativeElement.querySelector("[quill-editor-element]"),i=this.elementRef.nativeElement.querySelector("[quill-editor-toolbar]"),n=Object.assign({},this.modules||this.service.config.modules),i?n.toolbar=i:void 0===n.toolbar&&(n.toolbar=u.toolbar),void 0===(r=void 0!==this.placeholder?this.placeholder:this.service.config.placeholder)&&(r="Insert text here ..."),this.styles&&Object.keys(this.styles).forEach((function(e){m.renderer.setStyle(m.editorElem,e,m.styles[e])})),this.classes&&this.addClasses(this.classes),this.customOptions.forEach((function(t){var i=e.import(t.import);i.whitelist=t.whitelist,e.register(i,!0)})),this.customModules.forEach((function(t){var i=t.implementation,n=t.path;e.register(n,i)})),(o=this.bounds&&"self"===this.bounds?this.editorElem:this.bounds)||(o=this.service.config.bounds?this.service.config.bounds:this.doc.body),!(s=this.debug)&&!1!==s&&this.service.config.debug&&(s=this.service.config.debug),(h=this.readOnly)||!1===this.readOnly||(h=void 0!==this.service.config.readOnly&&this.service.config.readOnly),(d=this.scrollingContainer)||null===this.scrollingContainer||(d=null===this.service.config.scrollingContainer||this.service.config.scrollingContainer?this.service.config.scrollingContainer:null),(p=this.formats)||void 0!==p||(p=this.service.config.formats?function(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(a(arguments[t]));return e}(this.service.config.formats):null===this.service.config.formats?null:void 0),this.zone.runOutsideAngular((function(){var t,i,l;if(m.quillEditor=new e(m.editorElem,{bounds:o,debug:s,formats:p,modules:n,placeholder:r,readOnly:h,scrollingContainer:d,strict:m.strict,theme:m.theme||(m.service.config.theme?m.service.config.theme:"snow")}),m.linkPlaceholder){var a=null===(i=null===(t=m.quillEditor)||void 0===t?void 0:t.theme)||void 0===i?void 0:i.tooltip,u=null===(l=null==a?void 0:a.root)||void 0===l?void 0:l.querySelector("input[data-link]");(null==u?void 0:u.dataset)&&(u.dataset.link=m.linkPlaceholder)}})),this.content&&("text"===c(this.format,this.service.config.format)?this.quillEditor.setText(this.content,"silent"):(f=this.valueSetter(this.quillEditor,this.content),this.quillEditor.setContents(f,"silent")),this.quillEditor.getModule("history").clear()),this.setDisabledState(),this.quillEditor.on("editor-change",this.editorChangeHandler),this.quillEditor.on("selection-change",this.selectionChangeHandler),this.quillEditor.on("text-change",this.textChangeHandler),setTimeout((function(){m.onValidatorChanged&&m.onValidatorChanged(),m.onEditorCreated.emit(m.quillEditor)})),[2]}}))}))},e.prototype.ngOnDestroy=function(){this.quillEditor&&(this.quillEditor.off("selection-change",this.selectionChangeHandler),this.quillEditor.off("text-change",this.textChangeHandler),this.quillEditor.off("editor-change",this.editorChangeHandler))},e.prototype.ngOnChanges=function(e){var t=this;if(this.quillEditor){if(e.readOnly&&this.quillEditor.enable(!e.readOnly.currentValue),e.placeholder&&(this.quillEditor.root.dataset.placeholder=e.placeholder.currentValue),e.styles){var i=e.styles.currentValue,n=e.styles.previousValue;n&&Object.keys(n).forEach((function(e){t.renderer.removeStyle(t.editorElem,e)})),i&&Object.keys(i).forEach((function(e){t.renderer.setStyle(t.editorElem,e,t.styles[e])}))}if(e.classes){var r=e.classes.currentValue,o=e.classes.previousValue;o&&this.removeClasses(o),r&&this.addClasses(r)}}},e.prototype.addClasses=function(t){var i=this;e.normalizeClassNames(t).forEach((function(e){i.renderer.addClass(i.editorElem,e)}))},e.prototype.removeClasses=function(t){var i=this;e.normalizeClassNames(t).forEach((function(e){i.renderer.removeClass(i.editorElem,e)}))},e.prototype.writeValue=function(e){if((!this.filterNull||null!==e)&&(this.content=e,this.quillEditor)){var t=c(this.format,this.service.config.format),i=this.valueSetter(this.quillEditor,e);if(this.compareValues){var n=this.quillEditor.getContents();if(JSON.stringify(n)===JSON.stringify(i))return}e?"text"===t?this.quillEditor.setText(e):this.quillEditor.setContents(i):this.quillEditor.setText("")}},e.prototype.setDisabledState=function(e){void 0===e&&(e=this.disabled),this.disabled=e,this.quillEditor&&(e?(this.quillEditor.disable(),this.renderer.setAttribute(this.elementRef.nativeElement,"disabled","disabled")):(this.readOnly||this.quillEditor.enable(),this.renderer.removeAttribute(this.elementRef.nativeElement,"disabled")))},e.prototype.registerOnChange=function(e){this.onModelChange=e},e.prototype.registerOnTouched=function(e){this.onModelTouched=e},e.prototype.registerOnValidatorChange=function(e){this.onValidatorChanged=e},e.prototype.validate=function(){if(!this.quillEditor)return null;var e={},t=!0,i=this.quillEditor.getText(),n=this.trimOnValidation?i.trim().length:1===i.length&&0===i.trim().length?0:i.length-1;return this.minLength&&n&&n<this.minLength&&(e.minLengthError={given:n,minLength:this.minLength},t=!1),this.maxLength&&n>this.maxLength&&(e.maxLengthError={given:n,maxLength:this.maxLength},t=!1),this.required&&!n&&(e.requiredError={empty:!0},t=!1),t?null:e},e}();p.decorators=[{type:i.Directive}],p.ctorParameters=function(){return[{type:i.ElementRef},{type:n.DomSanitizer},{type:void 0,decorators:[{type:i.Inject,args:[t.DOCUMENT]}]},{type:void 0,decorators:[{type:i.Inject,args:[i.PLATFORM_ID]}]},{type:i.Renderer2},{type:i.NgZone},{type:d}]},p.propDecorators={format:[{type:i.Input}],theme:[{type:i.Input}],modules:[{type:i.Input}],debug:[{type:i.Input}],readOnly:[{type:i.Input}],placeholder:[{type:i.Input}],maxLength:[{type:i.Input}],minLength:[{type:i.Input}],required:[{type:i.Input}],formats:[{type:i.Input}],customToolbarPosition:[{type:i.Input}],sanitize:[{type:i.Input}],styles:[{type:i.Input}],strict:[{type:i.Input}],scrollingContainer:[{type:i.Input}],bounds:[{type:i.Input}],customOptions:[{type:i.Input}],customModules:[{type:i.Input}],trackChanges:[{type:i.Input}],preserveWhitespace:[{type:i.Input}],classes:[{type:i.Input}],trimOnValidation:[{type:i.Input}],linkPlaceholder:[{type:i.Input}],compareValues:[{type:i.Input}],filterNull:[{type:i.Input}],onEditorCreated:[{type:i.Output}],onEditorChanged:[{type:i.Output}],onContentChanged:[{type:i.Output}],onSelectionChanged:[{type:i.Output}],onFocus:[{type:i.Output}],onBlur:[{type:i.Output}],valueGetter:[{type:i.Input}],valueSetter:[{type:i.Input}]};var f=function(e){function t(t,i,n,r,o,s,l){return e.call(this,t,i,n,r,o,s,l)||this}return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Class extends value "+String(t)+" is not a constructor or null");function i(){this.constructor=e}o(e,t),e.prototype=null===t?Object.create(t):(i.prototype=t.prototype,new i)}(t,e),t}(p);f.decorators=[{type:i.Component,args:[{encapsulation:i.ViewEncapsulation.None,providers:[{multi:!0,provide:r.NG_VALUE_ACCESSOR,useExisting:i.forwardRef((function(){return f}))},{multi:!0,provide:r.NG_VALIDATORS,useExisting:i.forwardRef((function(){return f}))}],selector:"quill-editor",template:'\n <ng-content select="[quill-editor-toolbar]"></ng-content>\n'}]}],f.ctorParameters=function(){return[{type:i.ElementRef,decorators:[{type:i.Inject,args:[i.ElementRef]}]},{type:n.DomSanitizer,decorators:[{type:i.Inject,args:[n.DomSanitizer]}]},{type:void 0,decorators:[{type:i.Inject,args:[t.DOCUMENT]}]},{type:void 0,decorators:[{type:i.Inject,args:[i.PLATFORM_ID]}]},{type:i.Renderer2,decorators:[{type:i.Inject,args:[i.Renderer2]}]},{type:i.NgZone,decorators:[{type:i.Inject,args:[i.NgZone]}]},{type:d,decorators:[{type:i.Inject,args:[d]}]}]};var m=function(){function e(e,t){this.sanitizer=e,this.service=t,this.content="",this.innerHTML="",this.themeClass="ql-snow"}return e.prototype.ngOnChanges=function(e){if(e.theme){var t=e.theme.currentValue||(this.service.config.theme?this.service.config.theme:"snow");this.themeClass="ql-"+t+" ngx-quill-view-html"}else if(!this.theme){t=this.service.config.theme?this.service.config.theme:"snow";this.themeClass="ql-"+t+" ngx-quill-view-html"}e.content&&(this.innerHTML=this.sanitizer.bypassSecurityTrustHtml(e.content.currentValue))},e}();m.decorators=[{type:i.Component,args:[{encapsulation:i.ViewEncapsulation.None,selector:"quill-view-html",template:'\n <div class="ql-container" [ngClass]="themeClass">\n <div class="ql-editor" [innerHTML]="innerHTML">\n </div>\n </div>\n',styles:["\n.ql-container.ngx-quill-view-html {\n border: 0;\n}\n"]}]}],m.ctorParameters=function(){return[{type:n.DomSanitizer,decorators:[{type:i.Inject,args:[n.DomSanitizer]}]},{type:d}]},m.propDecorators={content:[{type:i.Input}],theme:[{type:i.Input}]};var g=function(){function e(e,t,n,r,o,s){var l=this;this.elementRef=e,this.renderer=t,this.zone=n,this.service=r,this.domSanitizer=o,this.platformId=s,this.sanitize=!1,this.strict=!0,this.customModules=[],this.customOptions=[],this.preserveWhitespace=!1,this.onEditorCreated=new i.EventEmitter,this.valueSetter=function(e,t){var n=c(l.format,l.service.config.format),r=t;if("text"===n)e.setText(r);else{if("html"===n)l.sanitize&&(t=l.domSanitizer.sanitize(i.SecurityContext.HTML,t)),r=e.clipboard.convert(t);else if("json"===n)try{r=JSON.parse(t)}catch(e){r=[{insert:t}]}e.setContents(r)}}}return e.prototype.ngOnChanges=function(e){this.quillEditor&&e.content&&this.valueSetter(this.quillEditor,e.content.currentValue)},e.prototype.ngAfterViewInit=function(){return s(this,void 0,void 0,(function(){var e,i,n,r,o,s=this;return l(this,(function(l){switch(l.label){case 0:return t.isPlatformServer(this.platformId)?[2]:[4,this.service.getQuill()];case 1:return e=l.sent(),(i=Object.assign({},this.modules||this.service.config.modules)).toolbar=!1,this.customOptions.forEach((function(t){var i=e.import(t.import);i.whitelist=t.whitelist,e.register(i,!0)})),this.customModules.forEach((function(t){var i=t.implementation,n=t.path;e.register(n,i)})),!(n=this.debug)&&!1!==n&&this.service.config.debug&&(n=this.service.config.debug),(r=this.formats)||void 0!==r||(r=this.service.config.formats?Object.assign({},this.service.config.formats):null===this.service.config.formats?null:void 0),o=this.theme||(this.service.config.theme?this.service.config.theme:"snow"),this.elementRef.nativeElement.insertAdjacentHTML("afterbegin",this.preserveWhitespace?"<pre quill-view-element></pre>":"<div quill-view-element></div>"),this.editorElem=this.elementRef.nativeElement.querySelector("[quill-view-element]"),this.zone.runOutsideAngular((function(){s.quillEditor=new e(s.editorElem,{debug:n,formats:r,modules:i,readOnly:!0,strict:s.strict,theme:o})})),this.renderer.addClass(this.editorElem,"ngx-quill-view"),this.content&&this.valueSetter(this.quillEditor,this.content),setTimeout((function(){s.onEditorCreated.emit(s.quillEditor)})),[2]}}))}))},e}();g.decorators=[{type:i.Component,args:[{encapsulation:i.ViewEncapsulation.None,selector:"quill-view",template:"\n",styles:["\n.ql-container.ngx-quill-view {\n border: 0;\n}\n"]}]}],g.ctorParameters=function(){return[{type:i.ElementRef},{type:i.Renderer2},{type:i.NgZone},{type:d},{type:n.DomSanitizer},{type:void 0,decorators:[{type:i.Inject,args:[i.PLATFORM_ID]}]}]},g.propDecorators={format:[{type:i.Input}],theme:[{type:i.Input}],modules:[{type:i.Input}],debug:[{type:i.Input}],formats:[{type:i.Input}],sanitize:[{type:i.Input}],strict:[{type:i.Input}],content:[{type:i.Input}],customModules:[{type:i.Input}],customOptions:[{type:i.Input}],preserveWhitespace:[{type:i.Input}],onEditorCreated:[{type:i.Output}]};var v=function(){function e(){}return e.forRoot=function(t){return{ngModule:e,providers:[{provide:h,useValue:t}]}},e}();v.decorators=[{type:i.NgModule,args:[{declarations:[f,g,m],exports:[f,g,m],imports:[t.CommonModule],providers:[d]}]}],e.QUILL_CONFIG_TOKEN=h,e.QuillEditorBase=p,e.QuillEditorComponent=f,e.QuillModule=v,e.QuillService=d,e.QuillViewComponent=g,e.QuillViewHTMLComponent=m,e.defaultModules=u,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=ngx-quill.umd.min.js.map
import { __awaiter } from "tslib";
import { isPlatformServer } from '@angular/common';
import { Component, ElementRef, Inject, Input, PLATFORM_ID, Renderer2, ViewEncapsulation, NgZone, SecurityContext } from '@angular/core';
import { Component, ElementRef, EventEmitter, Inject, Input, Output, PLATFORM_ID, Renderer2, ViewEncapsulation, NgZone, SecurityContext } from '@angular/core';
import { getFormat } from './helpers';

@@ -20,2 +20,3 @@ import { QuillService } from './quill.service';

this.preserveWhitespace = false;
this.onEditorCreated = new EventEmitter();
this.valueSetter = (quillEditor, value) => {

@@ -97,2 +98,6 @@ const format = getFormat(this.format, this.service.config.format);

}
// trigger created in a timeout to avoid changed models after checked
setTimeout(() => {
this.onEditorCreated.emit(this.quillEditor);
});
});

@@ -133,4 +138,5 @@ }

customOptions: [{ type: Input }],
preserveWhitespace: [{ type: Input }]
preserveWhitespace: [{ type: Input }],
onEditorCreated: [{ type: Output }]
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quill-view.component.js","sourceRoot":"","sources":["../../../../projects/ngx-quill/src/lib/quill-view.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAA;AAIlD,OAAO,EAEL,SAAS,EACT,UAAU,EACV,MAAM,EACN,KAAK,EAEL,WAAW,EACX,SAAS,EAET,iBAAiB,EACjB,MAAM,EACN,eAAe,EAChB,MAAM,eAAe,CAAA;AAGtB,OAAO,EAAC,SAAS,EAAC,MAAM,WAAW,CAAA;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAA;AAaxD,MAAM,OAAO,kBAAkB;IAgB7B,YACS,UAAsB,EACnB,QAAmB,EACnB,IAAY,EACZ,OAAqB,EACrB,YAA0B,EACL,UAAe;QALvC,eAAU,GAAV,UAAU,CAAY;QACnB,aAAQ,GAAR,QAAQ,CAAW;QACnB,SAAI,GAAJ,IAAI,CAAQ;QACZ,YAAO,GAAP,OAAO,CAAc;QACrB,iBAAY,GAAZ,YAAY,CAAc;QACL,eAAU,GAAV,UAAU,CAAK;QAhBvC,aAAQ,GAAG,KAAK,CAAA;QAChB,WAAM,GAAG,IAAI,CAAA;QAEb,kBAAa,GAAmB,EAAE,CAAA;QAClC,kBAAa,GAAmB,EAAE,CAAA;QAClC,uBAAkB,GAAG,KAAK,CAAA;QAcnC,gBAAW,GAAG,CAAC,WAAsB,EAAE,KAAU,EAAO,EAAE;YACxD,MAAM,MAAM,GAAG,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;YACjE,IAAI,OAAO,GAAG,KAAK,CAAA;YACnB,IAAI,MAAM,KAAK,MAAM,EAAE;gBACrB,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;aAC7B;iBAAM;gBACL,IAAI,MAAM,KAAK,MAAM,EAAE;oBACrB,IAAI,IAAI,CAAC,QAAQ,EAAE;wBACjB,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;qBAChE;oBACD,OAAO,GAAG,WAAW,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;iBAC/C;qBAAM,IAAI,MAAM,KAAK,MAAM,EAAE;oBAC5B,IAAI;wBACF,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;qBAC5B;oBAAC,OAAO,CAAC,EAAE;wBACV,OAAO,GAAG,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAA;qBAC9B;iBACF;gBACD,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC,CAAA;aACjC;QACH,CAAC,CAAA;IAtBE,CAAC;IAwBJ,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACrB,OAAM;SACP;QACD,IAAI,OAAO,CAAC,OAAO,EAAE;YACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAA;SACjE;IACH,CAAC;IAEK,eAAe;;YACnB,IAAI,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;gBACrC,OAAM;aACP;YAED,gEAAgE;YAChE,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAA;YAE3C,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;YAC9E,OAAO,CAAC,OAAO,GAAG,KAAK,CAAA;YAEvB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,YAAY,EAAE,EAAE;gBAC1C,MAAM,eAAe,GAAG,KAAK,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,CAAA;gBACzD,eAAe,CAAC,SAAS,GAAG,YAAY,CAAC,SAAS,CAAA;gBAClD,KAAK,CAAC,QAAQ,CAAC,eAAe,EAAE,IAAI,CAAC,CAAA;YACvC,CAAC,CAAC,CAAA;YAEF,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,EAAC,cAAc,EAAE,IAAI,EAAC,EAAE,EAAE;gBACpD,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE,cAAc,CAAC,CAAA;YACtC,CAAC,CAAC,CAAA;YAEF,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAA;YACtB,IAAI,CAAC,KAAK,IAAI,KAAK,KAAK,KAAK,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE;gBAC1D,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAA;aAClC;YAED,IAAI,OAAO,GAAG,IAAI,CAAC,OAAO,CAAA;YAC1B,IAAI,CAAC,OAAO,IAAI,OAAO,KAAK,SAAS,EAAE;gBACrC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBACrC,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAA;aAC7G;YACD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAA;YAE5F,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,kBAAkB,CAC9C,YAAY,EACZ,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,gCAAgC,CAAC,CAAC,CAAC,gCAAgC,CAC9F,CAAA;YAED,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAC3D,sBAAsB,CACR,CAAA;YAEhB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE;oBAC5C,KAAK,EAAE,KAAY;oBACnB,OAAO,EAAE,OAAc;oBACvB,OAAO;oBACP,QAAQ,EAAE,IAAI;oBACd,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,KAAK;iBACN,CAAC,CAAA;YACJ,CAAC,CAAC,CAAA;YAEF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,gBAAgB,CAAC,CAAA;YAEzD,IAAI,IAAI,CAAC,OAAO,EAAE;gBAChB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;aACjD;QACH,CAAC;KAAA;;;YA7HF,SAAS,SAAC;gBACT,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,QAAQ,EAAE,YAAY;gBAMtB,QAAQ,EAAE;CACX;yBANU;;;;CAIV;aAGA;;;YA3BC,UAAU;YAKV,SAAS;YAGT,MAAM;YAMC,YAAY;YACZ,YAAY;4CAmChB,MAAM,SAAC,WAAW;;;qBArBpB,KAAK;oBACL,KAAK;sBACL,KAAK;oBACL,KAAK;sBACL,KAAK;uBACL,KAAK;qBACL,KAAK;sBACL,KAAK;4BACL,KAAK;4BACL,KAAK;iCACL,KAAK","sourcesContent":["import { isPlatformServer } from '@angular/common'\nimport QuillType from 'quill'\nimport { QuillModules } from './quill-editor.interfaces'\n\nimport {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  OnChanges,\n  PLATFORM_ID,\n  Renderer2,\n  SimpleChanges,\n  ViewEncapsulation,\n  NgZone,\n  SecurityContext\n} from '@angular/core'\n\nimport { CustomOption, CustomModule } from './quill-editor.interfaces'\nimport {getFormat} from './helpers'\nimport { QuillService } from './quill.service'\nimport { DomSanitizer } from '@angular/platform-browser'\n\n@Component({\n  encapsulation: ViewEncapsulation.None,\n  selector: 'quill-view',\n  styles: [`\n.ql-container.ngx-quill-view {\n  border: 0;\n}\n`],\n  template: `\n`\n})\nexport class QuillViewComponent implements AfterViewInit, OnChanges {\n  @Input() format?: 'object' | 'html' | 'text' | 'json'\n  @Input() theme?: string\n  @Input() modules?: QuillModules\n  @Input() debug?: 'warn' | 'log' | 'error' | false\n  @Input() formats?: string[] | null\n  @Input() sanitize = false\n  @Input() strict = true\n  @Input() content: any\n  @Input() customModules: CustomModule[] = []\n  @Input() customOptions: CustomOption[] = []\n  @Input() preserveWhitespace = false\n\n  quillEditor!: QuillType\n  editorElem!: HTMLElement\n\n  constructor(\n    public elementRef: ElementRef,\n    protected renderer: Renderer2,\n    protected zone: NgZone,\n    protected service: QuillService,\n    protected domSanitizer: DomSanitizer,\n    @Inject(PLATFORM_ID) protected platformId: any,\n  ) {}\n\n  valueSetter = (quillEditor: QuillType, value: any): any => {\n    const format = getFormat(this.format, this.service.config.format)\n    let content = value\n    if (format === 'text') {\n      quillEditor.setText(content)\n    } else {\n      if (format === 'html') {\n        if (this.sanitize) {\n          value = this.domSanitizer.sanitize(SecurityContext.HTML, value)\n        }\n        content = quillEditor.clipboard.convert(value)\n      } else if (format === 'json') {\n        try {\n          content = JSON.parse(value)\n        } catch (e) {\n          content = [{ insert: value }]\n        }\n      }\n      quillEditor.setContents(content)\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (!this.quillEditor) {\n      return\n    }\n    if (changes.content) {\n      this.valueSetter(this.quillEditor, changes.content.currentValue)\n    }\n  }\n\n  async ngAfterViewInit() {\n    if (isPlatformServer(this.platformId)) {\n      return\n    }\n\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const Quill = await this.service.getQuill()\n\n    const modules = Object.assign({}, this.modules || this.service.config.modules)\n    modules.toolbar = false\n\n    this.customOptions.forEach((customOption) => {\n      const newCustomOption = Quill.import(customOption.import)\n      newCustomOption.whitelist = customOption.whitelist\n      Quill.register(newCustomOption, true)\n    })\n\n    this.customModules.forEach(({implementation, path}) => {\n      Quill.register(path, implementation)\n    })\n\n    let debug = this.debug\n    if (!debug && debug !== false && this.service.config.debug) {\n      debug = this.service.config.debug\n    }\n\n    let formats = this.formats\n    if (!formats && formats === undefined) {\n      formats = this.service.config.formats ?\n        Object.assign({}, this.service.config.formats) : (this.service.config.formats === null ? null : undefined)\n    }\n    const theme = this.theme || (this.service.config.theme ? this.service.config.theme : 'snow')\n\n    this.elementRef.nativeElement.insertAdjacentHTML(\n      'afterbegin',\n      this.preserveWhitespace ? '<pre quill-view-element></pre>' : '<div quill-view-element></div>'\n    )\n\n    this.editorElem = this.elementRef.nativeElement.querySelector(\n      '[quill-view-element]'\n    ) as HTMLElement\n\n    this.zone.runOutsideAngular(() => {\n      this.quillEditor = new Quill(this.editorElem, {\n        debug: debug as any,\n        formats: formats as any,\n        modules,\n        readOnly: true,\n        strict: this.strict,\n        theme\n      })\n    })\n\n    this.renderer.addClass(this.editorElem, 'ngx-quill-view')\n\n    if (this.content) {\n      this.valueSetter(this.quillEditor, this.content)\n    }\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quill-view.component.js","sourceRoot":"","sources":["../../../../projects/ngx-quill/src/lib/quill-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformServer } from '@angular/common'\nimport QuillType from 'quill'\nimport { QuillModules } from './quill-editor.interfaces'\n\nimport {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  Output,\n  OnChanges,\n  PLATFORM_ID,\n  Renderer2,\n  SimpleChanges,\n  ViewEncapsulation,\n  NgZone,\n  SecurityContext\n} from '@angular/core'\n\nimport { CustomOption, CustomModule } from './quill-editor.interfaces'\nimport {getFormat} from './helpers'\nimport { QuillService } from './quill.service'\nimport { DomSanitizer } from '@angular/platform-browser'\n\n@Component({\n  encapsulation: ViewEncapsulation.None,\n  selector: 'quill-view',\n  styles: [`\n.ql-container.ngx-quill-view {\n  border: 0;\n}\n`],\n  template: `\n`\n})\nexport class QuillViewComponent implements AfterViewInit, OnChanges {\n  @Input() format?: 'object' | 'html' | 'text' | 'json'\n  @Input() theme?: string\n  @Input() modules?: QuillModules\n  @Input() debug?: 'warn' | 'log' | 'error' | false\n  @Input() formats?: string[] | null\n  @Input() sanitize = false\n  @Input() strict = true\n  @Input() content: any\n  @Input() customModules: CustomModule[] = []\n  @Input() customOptions: CustomOption[] = []\n  @Input() preserveWhitespace = false\n\n  @Output() onEditorCreated: EventEmitter<any> = new EventEmitter()\n\n  quillEditor!: QuillType\n  editorElem!: HTMLElement\n\n  constructor(\n    public elementRef: ElementRef,\n    protected renderer: Renderer2,\n    protected zone: NgZone,\n    protected service: QuillService,\n    protected domSanitizer: DomSanitizer,\n    @Inject(PLATFORM_ID) protected platformId: any,\n  ) {}\n\n  valueSetter = (quillEditor: QuillType, value: any): any => {\n    const format = getFormat(this.format, this.service.config.format)\n    let content = value\n    if (format === 'text') {\n      quillEditor.setText(content)\n    } else {\n      if (format === 'html') {\n        if (this.sanitize) {\n          value = this.domSanitizer.sanitize(SecurityContext.HTML, value)\n        }\n        content = quillEditor.clipboard.convert(value)\n      } else if (format === 'json') {\n        try {\n          content = JSON.parse(value)\n        } catch (e) {\n          content = [{ insert: value }]\n        }\n      }\n      quillEditor.setContents(content)\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (!this.quillEditor) {\n      return\n    }\n    if (changes.content) {\n      this.valueSetter(this.quillEditor, changes.content.currentValue)\n    }\n  }\n\n  async ngAfterViewInit() {\n    if (isPlatformServer(this.platformId)) {\n      return\n    }\n\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const Quill = await this.service.getQuill()\n\n    const modules = Object.assign({}, this.modules || this.service.config.modules)\n    modules.toolbar = false\n\n    this.customOptions.forEach((customOption) => {\n      const newCustomOption = Quill.import(customOption.import)\n      newCustomOption.whitelist = customOption.whitelist\n      Quill.register(newCustomOption, true)\n    })\n\n    this.customModules.forEach(({implementation, path}) => {\n      Quill.register(path, implementation)\n    })\n\n    let debug = this.debug\n    if (!debug && debug !== false && this.service.config.debug) {\n      debug = this.service.config.debug\n    }\n\n    let formats = this.formats\n    if (!formats && formats === undefined) {\n      formats = this.service.config.formats ?\n        Object.assign({}, this.service.config.formats) : (this.service.config.formats === null ? null : undefined)\n    }\n    const theme = this.theme || (this.service.config.theme ? this.service.config.theme : 'snow')\n\n    this.elementRef.nativeElement.insertAdjacentHTML(\n      'afterbegin',\n      this.preserveWhitespace ? '<pre quill-view-element></pre>' : '<div quill-view-element></div>'\n    )\n\n    this.editorElem = this.elementRef.nativeElement.querySelector(\n      '[quill-view-element]'\n    ) as HTMLElement\n\n    this.zone.runOutsideAngular(() => {\n      this.quillEditor = new Quill(this.editorElem, {\n        debug: debug as any,\n        formats: formats as any,\n        modules,\n        readOnly: true,\n        strict: this.strict,\n        theme\n      })\n    })\n\n    this.renderer.addClass(this.editorElem, 'ngx-quill-view')\n\n    if (this.content) {\n      this.valueSetter(this.quillEditor, this.content)\n    }\n\n    // trigger created in a timeout to avoid changed models after checked\n    setTimeout(() => {\n      this.onEditorCreated.emit(this.quillEditor)\n    })\n  }\n}\n"]}

@@ -651,2 +651,3 @@ import { isPlatformServer, DOCUMENT, CommonModule } from '@angular/common';

this.preserveWhitespace = false;
this.onEditorCreated = new EventEmitter();
this.valueSetter = (quillEditor, value) => {

@@ -728,2 +729,6 @@ const format = getFormat(this.format, this.service.config.format);

}
// trigger created in a timeout to avoid changed models after checked
setTimeout(() => {
this.onEditorCreated.emit(this.quillEditor);
});
});

@@ -764,3 +769,4 @@ }

customOptions: [{ type: Input }],
preserveWhitespace: [{ type: Input }]
preserveWhitespace: [{ type: Input }],
onEditorCreated: [{ type: Output }]
};

@@ -767,0 +773,0 @@

import QuillType from 'quill';
import { QuillModules } from './quill-editor.interfaces';
import { AfterViewInit, ElementRef, OnChanges, Renderer2, SimpleChanges, NgZone } from '@angular/core';
import { AfterViewInit, ElementRef, EventEmitter, OnChanges, Renderer2, SimpleChanges, NgZone } from '@angular/core';
import { CustomOption, CustomModule } from './quill-editor.interfaces';

@@ -25,2 +25,3 @@ import { QuillService } from './quill.service';

preserveWhitespace: boolean;
onEditorCreated: EventEmitter<any>;
quillEditor: QuillType;

@@ -27,0 +28,0 @@ editorElem: HTMLElement;

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

{"__symbolic":"module","version":4,"metadata":{"QuillModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":9,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"QuillEditorComponent"},{"__symbolic":"reference","name":"QuillViewComponent"},{"__symbolic":"reference","name":"QuillViewHTMLComponent"}],"exports":[{"__symbolic":"reference","name":"QuillEditorComponent"},{"__symbolic":"reference","name":"QuillViewComponent"},{"__symbolic":"reference","name":"QuillViewHTMLComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":16,"character":12}],"providers":[{"__symbolic":"reference","name":"QuillService"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"value":{"ngModule":{"__symbolic":"reference","name":"QuillModule"},"providers":[{"provide":{"__symbolic":"reference","name":"QUILL_CONFIG_TOKEN"},"useValue":{"__symbolic":"reference","name":"config"}}]}}}},"QuillService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":4,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":14,"character":5},"arguments":[{"__symbolic":"reference","name":"QUILL_CONFIG_TOKEN"}]}]],"parameters":[{"__symbolic":"reference","name":"QuillConfig"}]}],"getQuill":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"defaultModules":{"toolbar":[["bold","italic","underline","strike"],["blockquote","code-block"],[{"header":1},{"header":2}],[{"list":"ordered"},{"list":"bullet"}],[{"script":"sub"},{"script":"super"}],[{"indent":"-1"},{"indent":"+1"}],[{"direction":"rtl"}],[{"size":["small",false,"large","huge"]}],[{"header":[1,2,3,4,5,6,false]}],[{"color":[]},{"background":[]}],[{"font":[]}],[{"align":[]}],["clean"],["link","image","video"]]},"Range":{"__symbolic":"interface"},"ContentChange":{"__symbolic":"interface"},"SelectionChange":{"__symbolic":"interface"},"Blur":{"__symbolic":"interface"},"Focus":{"__symbolic":"interface"},"EditorChangeContent":{"__symbolic":"interface"},"EditorChangeSelection":{"__symbolic":"interface"},"QuillEditorBase":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":68,"character":1}}],"members":{"format":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":71,"character":3}}]}],"theme":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":72,"character":3}}]}],"modules":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":73,"character":3}}]}],"debug":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":74,"character":3}}]}],"readOnly":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":75,"character":3}}]}],"placeholder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":76,"character":3}}]}],"maxLength":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":77,"character":3}}]}],"minLength":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":78,"character":3}}]}],"required":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":79,"character":3}}]}],"formats":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":80,"character":3}}]}],"customToolbarPosition":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":81,"character":3}}]}],"sanitize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":82,"character":3}}]}],"styles":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":83,"character":3}}]}],"strict":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":84,"character":3}}]}],"scrollingContainer":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":85,"character":3}}]}],"bounds":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":86,"character":3}}]}],"customOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":87,"character":3}}]}],"customModules":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":88,"character":3}}]}],"trackChanges":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":89,"character":3}}]}],"preserveWhitespace":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":90,"character":3}}]}],"classes":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":91,"character":3}}]}],"trimOnValidation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":92,"character":3}}]}],"linkPlaceholder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":93,"character":3}}]}],"compareValues":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":94,"character":3}}]}],"filterNull":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":95,"character":3}}]}],"onEditorCreated":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":97,"character":3}}]}],"onEditorChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":98,"character":3}}]}],"onContentChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":99,"character":3}}]}],"onSelectionChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":100,"character":3}}]}],"onFocus":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":101,"character":3}}]}],"onBlur":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":102,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":116,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":116,"character":12}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":117,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":117,"character":12}]}],null,null,null],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":114,"character":23},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":115,"character":28},{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":118,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":119,"character":20},{"__symbolic":"reference","name":"QuillService"}]}],"valueGetter":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":135,"character":3}}]}],"valueSetter":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":159,"character":3}}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"addClasses":[{"__symbolic":"method"}],"removeClasses":[{"__symbolic":"method"}],"writeValue":[{"__symbolic":"method"}],"setDisabledState":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}],"registerOnValidatorChange":[{"__symbolic":"method"}],"validate":[{"__symbolic":"method"}]}},"QuillEditorComponent":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"QuillEditorBase"},"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":619,"character":1},"arguments":[{"encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":620,"character":17},"member":"None"},"providers":[{"multi":true,"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":624,"character":15},"useExisting":{"__symbolic":"reference","name":"QuillEditorComponent"}},{"multi":true,"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALIDATORS","line":630,"character":15},"useExisting":{"__symbolic":"reference","name":"QuillEditorComponent"}}],"selector":"quill-editor","template":"\n <ng-content select=\"[quill-editor-toolbar]\"></ng-content>\n"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":643,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":114,"character":23}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":644,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":115,"character":28}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":645,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":645,"character":12}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":646,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":646,"character":12}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":647,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":118,"character":24}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":648,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":119,"character":20}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":649,"character":5},"arguments":[{"__symbolic":"reference","name":"QuillService"}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":114,"character":23},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":115,"character":28},{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":118,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":119,"character":20},{"__symbolic":"reference","name":"QuillService"}]}]}},"QuillViewComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":24,"character":1},"arguments":[{"encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":25,"character":17},"member":"None"},"selector":"quill-view","styles":["\n.ql-container.ngx-quill-view {\n border: 0;\n}\n"],"template":"\n"}]}],"members":{"format":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"theme":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":37,"character":3}}]}],"modules":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":38,"character":3}}]}],"debug":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"formats":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"sanitize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":41,"character":3}}]}],"strict":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":3}}]}],"content":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":43,"character":3}}]}],"customModules":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":44,"character":3}}]}],"customOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3}}]}],"preserveWhitespace":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":46,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":57,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":57,"character":12}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":52,"character":23},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":53,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":54,"character":20},{"__symbolic":"reference","name":"QuillService"},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":56,"character":28},{"__symbolic":"reference","name":"any"}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}]}},"QuillViewHTMLComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":12,"character":1},"arguments":[{"encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":13,"character":17},"member":"None"},"selector":"quill-view-html","styles":["\n.ql-container.ngx-quill-view-html {\n border: 0;\n}\n"],"template":"\n <div class=\"ql-container\" [ngClass]=\"themeClass\">\n <div class=\"ql-editor\" [innerHTML]=\"innerHTML\">\n </div>\n </div>\n"}]}],"members":{"content":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":28,"character":3}}]}],"theme":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":35,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":35,"character":12}]}],null],"parameters":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":35,"character":45},{"__symbolic":"reference","name":"QuillService"}]}],"ngOnChanges":[{"__symbolic":"method"}]}},"CustomOption":{"__symbolic":"interface"},"CustomModule":{"__symbolic":"interface"},"QuillToolbarConfig":{"__symbolic":"interface"},"QuillModules":{"__symbolic":"interface"},"QuillFormat":{"__symbolic":"interface"},"QuillConfig":{"__symbolic":"interface"},"QUILL_CONFIG_TOKEN":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":69,"character":38},"arguments":["config"]}},"origins":{"QuillModule":"./lib/quill.module","QuillService":"./lib/quill.service","defaultModules":"./lib/quill-defaults","Range":"./lib/quill-editor.component","ContentChange":"./lib/quill-editor.component","SelectionChange":"./lib/quill-editor.component","Blur":"./lib/quill-editor.component","Focus":"./lib/quill-editor.component","EditorChangeContent":"./lib/quill-editor.component","EditorChangeSelection":"./lib/quill-editor.component","QuillEditorBase":"./lib/quill-editor.component","QuillEditorComponent":"./lib/quill-editor.component","QuillViewComponent":"./lib/quill-view.component","QuillViewHTMLComponent":"./lib/quill-view-html.component","CustomOption":"./lib/quill-editor.interfaces","CustomModule":"./lib/quill-editor.interfaces","QuillToolbarConfig":"./lib/quill-editor.interfaces","QuillModules":"./lib/quill-editor.interfaces","QuillFormat":"./lib/quill-editor.interfaces","QuillConfig":"./lib/quill-editor.interfaces","QUILL_CONFIG_TOKEN":"./lib/quill-editor.interfaces"},"importAs":"ngx-quill"}
{"__symbolic":"module","version":4,"metadata":{"QuillModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":9,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"QuillEditorComponent"},{"__symbolic":"reference","name":"QuillViewComponent"},{"__symbolic":"reference","name":"QuillViewHTMLComponent"}],"exports":[{"__symbolic":"reference","name":"QuillEditorComponent"},{"__symbolic":"reference","name":"QuillViewComponent"},{"__symbolic":"reference","name":"QuillViewHTMLComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":16,"character":12}],"providers":[{"__symbolic":"reference","name":"QuillService"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"value":{"ngModule":{"__symbolic":"reference","name":"QuillModule"},"providers":[{"provide":{"__symbolic":"reference","name":"QUILL_CONFIG_TOKEN"},"useValue":{"__symbolic":"reference","name":"config"}}]}}}},"QuillService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":4,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":14,"character":5},"arguments":[{"__symbolic":"reference","name":"QUILL_CONFIG_TOKEN"}]}]],"parameters":[{"__symbolic":"reference","name":"QuillConfig"}]}],"getQuill":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"defaultModules":{"toolbar":[["bold","italic","underline","strike"],["blockquote","code-block"],[{"header":1},{"header":2}],[{"list":"ordered"},{"list":"bullet"}],[{"script":"sub"},{"script":"super"}],[{"indent":"-1"},{"indent":"+1"}],[{"direction":"rtl"}],[{"size":["small",false,"large","huge"]}],[{"header":[1,2,3,4,5,6,false]}],[{"color":[]},{"background":[]}],[{"font":[]}],[{"align":[]}],["clean"],["link","image","video"]]},"Range":{"__symbolic":"interface"},"ContentChange":{"__symbolic":"interface"},"SelectionChange":{"__symbolic":"interface"},"Blur":{"__symbolic":"interface"},"Focus":{"__symbolic":"interface"},"EditorChangeContent":{"__symbolic":"interface"},"EditorChangeSelection":{"__symbolic":"interface"},"QuillEditorBase":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":68,"character":1}}],"members":{"format":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":71,"character":3}}]}],"theme":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":72,"character":3}}]}],"modules":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":73,"character":3}}]}],"debug":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":74,"character":3}}]}],"readOnly":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":75,"character":3}}]}],"placeholder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":76,"character":3}}]}],"maxLength":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":77,"character":3}}]}],"minLength":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":78,"character":3}}]}],"required":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":79,"character":3}}]}],"formats":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":80,"character":3}}]}],"customToolbarPosition":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":81,"character":3}}]}],"sanitize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":82,"character":3}}]}],"styles":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":83,"character":3}}]}],"strict":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":84,"character":3}}]}],"scrollingContainer":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":85,"character":3}}]}],"bounds":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":86,"character":3}}]}],"customOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":87,"character":3}}]}],"customModules":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":88,"character":3}}]}],"trackChanges":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":89,"character":3}}]}],"preserveWhitespace":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":90,"character":3}}]}],"classes":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":91,"character":3}}]}],"trimOnValidation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":92,"character":3}}]}],"linkPlaceholder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":93,"character":3}}]}],"compareValues":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":94,"character":3}}]}],"filterNull":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":95,"character":3}}]}],"onEditorCreated":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":97,"character":3}}]}],"onEditorChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":98,"character":3}}]}],"onContentChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":99,"character":3}}]}],"onSelectionChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":100,"character":3}}]}],"onFocus":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":101,"character":3}}]}],"onBlur":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":102,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":116,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":116,"character":12}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":117,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":117,"character":12}]}],null,null,null],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":114,"character":23},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":115,"character":28},{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":118,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":119,"character":20},{"__symbolic":"reference","name":"QuillService"}]}],"valueGetter":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":135,"character":3}}]}],"valueSetter":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":159,"character":3}}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"addClasses":[{"__symbolic":"method"}],"removeClasses":[{"__symbolic":"method"}],"writeValue":[{"__symbolic":"method"}],"setDisabledState":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}],"registerOnValidatorChange":[{"__symbolic":"method"}],"validate":[{"__symbolic":"method"}]}},"QuillEditorComponent":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"QuillEditorBase"},"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":619,"character":1},"arguments":[{"encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":620,"character":17},"member":"None"},"providers":[{"multi":true,"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":624,"character":15},"useExisting":{"__symbolic":"reference","name":"QuillEditorComponent"}},{"multi":true,"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALIDATORS","line":630,"character":15},"useExisting":{"__symbolic":"reference","name":"QuillEditorComponent"}}],"selector":"quill-editor","template":"\n <ng-content select=\"[quill-editor-toolbar]\"></ng-content>\n"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":643,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":114,"character":23}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":644,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":115,"character":28}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":645,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":645,"character":12}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":646,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":646,"character":12}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":647,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":118,"character":24}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":648,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":119,"character":20}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":649,"character":5},"arguments":[{"__symbolic":"reference","name":"QuillService"}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":114,"character":23},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":115,"character":28},{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":118,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":119,"character":20},{"__symbolic":"reference","name":"QuillService"}]}]}},"QuillViewComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":26,"character":1},"arguments":[{"encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":27,"character":17},"member":"None"},"selector":"quill-view","styles":["\n.ql-container.ngx-quill-view {\n border: 0;\n}\n"],"template":"\n"}]}],"members":{"format":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":38,"character":3}}]}],"theme":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"modules":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"debug":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":41,"character":3}}]}],"formats":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":3}}]}],"sanitize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":43,"character":3}}]}],"strict":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":44,"character":3}}]}],"content":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3}}]}],"customModules":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":46,"character":3}}]}],"customOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":47,"character":3}}]}],"preserveWhitespace":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":48,"character":3}}]}],"onEditorCreated":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":50,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":61,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":61,"character":12}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":56,"character":23},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":57,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":58,"character":20},{"__symbolic":"reference","name":"QuillService"},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":60,"character":28},{"__symbolic":"reference","name":"any"}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}]}},"QuillViewHTMLComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":12,"character":1},"arguments":[{"encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":13,"character":17},"member":"None"},"selector":"quill-view-html","styles":["\n.ql-container.ngx-quill-view-html {\n border: 0;\n}\n"],"template":"\n <div class=\"ql-container\" [ngClass]=\"themeClass\">\n <div class=\"ql-editor\" [innerHTML]=\"innerHTML\">\n </div>\n </div>\n"}]}],"members":{"content":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":28,"character":3}}]}],"theme":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":35,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":35,"character":12}]}],null],"parameters":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":35,"character":45},{"__symbolic":"reference","name":"QuillService"}]}],"ngOnChanges":[{"__symbolic":"method"}]}},"CustomOption":{"__symbolic":"interface"},"CustomModule":{"__symbolic":"interface"},"QuillToolbarConfig":{"__symbolic":"interface"},"QuillModules":{"__symbolic":"interface"},"QuillFormat":{"__symbolic":"interface"},"QuillConfig":{"__symbolic":"interface"},"QUILL_CONFIG_TOKEN":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":69,"character":38},"arguments":["config"]}},"origins":{"QuillModule":"./lib/quill.module","QuillService":"./lib/quill.service","defaultModules":"./lib/quill-defaults","Range":"./lib/quill-editor.component","ContentChange":"./lib/quill-editor.component","SelectionChange":"./lib/quill-editor.component","Blur":"./lib/quill-editor.component","Focus":"./lib/quill-editor.component","EditorChangeContent":"./lib/quill-editor.component","EditorChangeSelection":"./lib/quill-editor.component","QuillEditorBase":"./lib/quill-editor.component","QuillEditorComponent":"./lib/quill-editor.component","QuillViewComponent":"./lib/quill-view.component","QuillViewHTMLComponent":"./lib/quill-view-html.component","CustomOption":"./lib/quill-editor.interfaces","CustomModule":"./lib/quill-editor.interfaces","QuillToolbarConfig":"./lib/quill-editor.interfaces","QuillModules":"./lib/quill-editor.interfaces","QuillFormat":"./lib/quill-editor.interfaces","QuillConfig":"./lib/quill-editor.interfaces","QUILL_CONFIG_TOKEN":"./lib/quill-editor.interfaces"},"importAs":"ngx-quill"}
{
"name": "ngx-quill",
"version": "13.1.0",
"version": "13.2.0",
"license": "MIT",

@@ -5,0 +5,0 @@ "author": {

@@ -404,2 +404,6 @@ # ngx-quill ![Build Status](https://github.com/KillerCodeMonkey/ngx-quill/workflows/CI/badge.svg)

### Outputs
- onEditorCreated - editor instance
```HTML

@@ -406,0 +410,0 @@ <quill-view [content]="content" format="text" theme="snow"></quill-view>

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

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