@sd-angular/core 1.2.85 → 1.2.88
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/sd-angular-core-comment.umd.js +1 -1
- package/bundles/sd-angular-core-comment.umd.js.map +1 -1
- package/bundles/sd-angular-core-comment.umd.min.js +1 -1
- package/bundles/sd-angular-core-comment.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-editor.umd.js +199 -46
- package/bundles/sd-angular-core-editor.umd.js.map +1 -1
- package/bundles/sd-angular-core-editor.umd.min.js +2 -2
- package/bundles/sd-angular-core-editor.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-input-number.umd.js +3 -3
- package/bundles/sd-angular-core-input-number.umd.js.map +1 -1
- package/bundles/sd-angular-core-input-number.umd.min.js +1 -1
- package/bundles/sd-angular-core-input-number.umd.min.js.map +1 -1
- package/comment/sd-angular-core-comment.metadata.json +1 -1
- package/comment/src/lib/comment.model.d.ts +1 -1
- package/editor/sd-angular-core-editor.metadata.json +1 -1
- package/editor/src/lib/editor.component.d.ts +12 -5
- package/editor/src/lib/editor.model.d.ts +16 -0
- package/editor/src/public-api.d.ts +1 -0
- package/esm2015/comment/src/lib/comment.component.js +2 -2
- package/esm2015/comment/src/lib/comment.model.js +1 -1
- package/esm2015/editor/src/lib/editor.component.js +180 -44
- package/esm2015/editor/src/lib/editor.model.js +3 -0
- package/esm2015/editor/src/public-api.js +2 -1
- package/esm2015/input-number/src/lib/input-number.component.js +4 -4
- package/fesm2015/sd-angular-core-comment.js +1 -1
- package/fesm2015/sd-angular-core-comment.js.map +1 -1
- package/fesm2015/sd-angular-core-editor.js +181 -44
- package/fesm2015/sd-angular-core-editor.js.map +1 -1
- package/fesm2015/sd-angular-core-input-number.js +3 -3
- package/fesm2015/sd-angular-core-input-number.js.map +1 -1
- package/package.json +1 -1
- package/{sd-angular-core-1.2.85.tgz → sd-angular-core-1.2.88.tgz} +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
var _name, _subscription, _model, _form, _updateValidator,
|
|
1
|
+
var _name, _subscription, _model, _form, _updateValidator, _initUploadImage;
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
-
import {
|
|
3
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, Inject, Input, NgZone, Optional, Output, ViewChild } from '@angular/core';
|
|
4
4
|
import * as uuid from 'uuid';
|
|
5
5
|
import { FormControl, NgForm, Validators } from '@angular/forms';
|
|
6
6
|
import { Constants } from './constant';
|
|
@@ -8,11 +8,15 @@ import { Subscription } from 'rxjs';
|
|
|
8
8
|
import { SdApiService } from '@sd-angular/core/api';
|
|
9
9
|
import 'quill-mention';
|
|
10
10
|
import { SdLabelDefDirective } from '@sd-angular/core/common';
|
|
11
|
+
import { SdLoadingService } from "@sd-angular/core/loading";
|
|
12
|
+
import { EDITOR_CONFIG } from './editor.model';
|
|
11
13
|
export class SdEditor {
|
|
12
|
-
constructor(ngZone, ref, sdApiService) {
|
|
14
|
+
constructor(ngZone, ref, sdApiService, loadingService, configuration) {
|
|
13
15
|
this.ngZone = ngZone;
|
|
14
16
|
this.ref = ref;
|
|
15
17
|
this.sdApiService = sdApiService;
|
|
18
|
+
this.loadingService = loadingService;
|
|
19
|
+
this.configuration = configuration;
|
|
16
20
|
_name.set(this, `N${uuid.v4()}`);
|
|
17
21
|
this.id = `I${uuid.v4()}`;
|
|
18
22
|
_subscription.set(this, new Subscription());
|
|
@@ -89,8 +93,9 @@ export class SdEditor {
|
|
|
89
93
|
}
|
|
90
94
|
}
|
|
91
95
|
};
|
|
92
|
-
this.
|
|
96
|
+
this.customButtonFileSVG = '<svg xmlns="http://www.w3.org/2000/svg" enable-background="new 0 0 24 24" height="24px" viewBox="0 0 24 24" width="24px" fill="#000000"><g><rect fill="none" height="24" width="24"/><path d="M20.41,8.41l-4.83-4.83C15.21,3.21,14.7,3,14.17,3H5C3.9,3,3,3.9,3,5v14c0,1.1,0.9,2,2,2h14c1.1,0,2-0.9,2-2V9.83 C21,9.3,20.79,8.79,20.41,8.41z M7,7h7v2H7V7z M17,17H7v-2h10V17z M17,13H7v-2h10V13z"/></g></svg>';
|
|
93
97
|
this.sdChange = new EventEmitter();
|
|
98
|
+
this.timerLoadQuillToolbar = null;
|
|
94
99
|
_updateValidator.set(this, () => {
|
|
95
100
|
this.formControl.clearValidators();
|
|
96
101
|
this.formControl.clearAsyncValidators();
|
|
@@ -128,6 +133,35 @@ export class SdEditor {
|
|
|
128
133
|
// // }
|
|
129
134
|
// // this.formControl.setValue(html);
|
|
130
135
|
// });
|
|
136
|
+
const self = this;
|
|
137
|
+
__classPrivateFieldGet(this, _initUploadImage).call(this, quill);
|
|
138
|
+
// this.ngZone.runOutsideAngular(() => {
|
|
139
|
+
// quill.getModule('toolbar').addHandler('image', function () {
|
|
140
|
+
// let fileInput = this.container.querySelector('input.ql-image[type=file]');
|
|
141
|
+
// if (fileInput == null) {
|
|
142
|
+
// fileInput = document.createElement('input');
|
|
143
|
+
// fileInput.setAttribute('type', Constants.FILE);
|
|
144
|
+
// fileInput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon');
|
|
145
|
+
// fileInput.classList.add('ql-image');
|
|
146
|
+
// fileInput.addEventListener('change', () => {
|
|
147
|
+
// const files = fileInput.files;
|
|
148
|
+
// const range = this.quill.getSelection(true);
|
|
149
|
+
// if (!files || !files.length) {
|
|
150
|
+
// return;
|
|
151
|
+
// }
|
|
152
|
+
// const formData = new FormData();
|
|
153
|
+
// formData.append(Constants.FILE, files[0]);
|
|
154
|
+
// this.quill.enable(false);
|
|
155
|
+
// self.#uploadImage(formData, quill, range, fileInput);
|
|
156
|
+
// });
|
|
157
|
+
// this.container.appendChild(fileInput);
|
|
158
|
+
// }
|
|
159
|
+
// fileInput.click();
|
|
160
|
+
// });
|
|
161
|
+
// });
|
|
162
|
+
this.ref.markForCheck();
|
|
163
|
+
};
|
|
164
|
+
_initUploadImage.set(this, (quill) => {
|
|
131
165
|
const self = this;
|
|
132
166
|
this.ngZone.runOutsideAngular(() => {
|
|
133
167
|
quill.getModule('toolbar').addHandler('image', function () {
|
|
@@ -138,6 +172,7 @@ export class SdEditor {
|
|
|
138
172
|
fileInput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon');
|
|
139
173
|
fileInput.classList.add('ql-image');
|
|
140
174
|
fileInput.addEventListener('change', () => {
|
|
175
|
+
var _a;
|
|
141
176
|
const files = fileInput.files;
|
|
142
177
|
const range = this.quill.getSelection(true);
|
|
143
178
|
if (!files || !files.length) {
|
|
@@ -146,23 +181,27 @@ export class SdEditor {
|
|
|
146
181
|
const formData = new FormData();
|
|
147
182
|
formData.append(Constants.FILE, files[0]);
|
|
148
183
|
this.quill.enable(false);
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
184
|
+
// self.#uploadImage(formData, quill, range, fileInput);
|
|
185
|
+
(_a = self.configuration) === null || _a === void 0 ? void 0 : _a.uploadImage(formData, self.args).then(url => {
|
|
186
|
+
self.ngZone.runOutsideAngular(() => {
|
|
187
|
+
quill.enable(true);
|
|
188
|
+
// quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');
|
|
189
|
+
quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target="_blank" href="' + (url || '')
|
|
190
|
+
+ '"><img src="' + (url || '') + '" alt="c-image-editor-quill"></a>', 'user');
|
|
191
|
+
// quill.insertText();
|
|
192
|
+
const content = quill.getContents();
|
|
193
|
+
quill.setContents(content);
|
|
194
|
+
quill.setSelection(range.index + 1, 'user');
|
|
195
|
+
fileInput.value = '';
|
|
196
|
+
});
|
|
197
|
+
});
|
|
158
198
|
});
|
|
159
199
|
this.container.appendChild(fileInput);
|
|
160
200
|
}
|
|
161
201
|
fileInput.click();
|
|
162
202
|
});
|
|
163
203
|
});
|
|
164
|
-
|
|
165
|
-
};
|
|
204
|
+
});
|
|
166
205
|
this.onModelChange = (val) => {
|
|
167
206
|
this.formControl.setValue(val);
|
|
168
207
|
this.modelHTML = val;
|
|
@@ -172,27 +211,6 @@ export class SdEditor {
|
|
|
172
211
|
this.showHtmlEditor = !this.showHtmlEditor;
|
|
173
212
|
this.ref.markForCheck();
|
|
174
213
|
};
|
|
175
|
-
_uploadImage.set(this, (formData, quill, range, fileInput) => {
|
|
176
|
-
if (!this.urlUploadImage) {
|
|
177
|
-
this.urlUploadImage = '/partner/v2/merchandise/file/uploaduserfile';
|
|
178
|
-
}
|
|
179
|
-
// this.domain = 'https://api-commerce-qc.vinid.dev';
|
|
180
|
-
this.sdApiService.post(this.urlUploadImage, formData).then((resp) => {
|
|
181
|
-
this.ngZone.runOutsideAngular(() => {
|
|
182
|
-
var _a, _b, _c, _d;
|
|
183
|
-
quill.enable(true);
|
|
184
|
-
// quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');
|
|
185
|
-
quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target="_blank" href="' + (((_a = resp === null || resp === void 0 ? void 0 : resp.data) === null || _a === void 0 ? void 0 : _a.imageUrl) || ((_b = resp === null || resp === void 0 ? void 0 : resp.data) === null || _b === void 0 ? void 0 : _b.publish_url) || (resp === null || resp === void 0 ? void 0 : resp.url) || '')
|
|
186
|
-
+ '"><img src="' + (((_c = resp === null || resp === void 0 ? void 0 : resp.data) === null || _c === void 0 ? void 0 : _c.imageUrl) || ((_d = resp === null || resp === void 0 ? void 0 : resp.data) === null || _d === void 0 ? void 0 : _d.publish_url) || (resp === null || resp === void 0 ? void 0 : resp.url) || '') + '" alt="c-image-editor-quill"></a>', 'user');
|
|
187
|
-
// quill.insertText();
|
|
188
|
-
const content = quill.getContents();
|
|
189
|
-
quill.setContents(content);
|
|
190
|
-
quill.setSelection(range.index + 1, 'user');
|
|
191
|
-
fileInput.value = '';
|
|
192
|
-
});
|
|
193
|
-
});
|
|
194
|
-
this.ref.markForCheck();
|
|
195
|
-
});
|
|
196
214
|
}
|
|
197
215
|
set model(val) {
|
|
198
216
|
__classPrivateFieldSet(this, _model, val);
|
|
@@ -234,14 +252,76 @@ export class SdEditor {
|
|
|
234
252
|
}
|
|
235
253
|
}
|
|
236
254
|
ngOnInit() {
|
|
237
|
-
var _a;
|
|
255
|
+
var _a, _b;
|
|
238
256
|
(_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.addControl(__classPrivateFieldGet(this, _name), this.formControl);
|
|
239
257
|
if (this.toolbar) {
|
|
240
258
|
this.quillConfig.toolbar.container = this.toolbar;
|
|
241
|
-
console.log('toolbar', this.quillConfig);
|
|
242
259
|
}
|
|
260
|
+
for (const action of (((_b = this.configuration) === null || _b === void 0 ? void 0 : _b.actions) || [])) {
|
|
261
|
+
if (this.quillConfig.toolbar.container.toString().includes(action.key)) {
|
|
262
|
+
const qlKey = `button.ql-${action.key}`;
|
|
263
|
+
const interval = setInterval(() => {
|
|
264
|
+
if (document.querySelector(qlKey)) {
|
|
265
|
+
clearInterval(interval);
|
|
266
|
+
document.querySelector(qlKey).innerHTML = this.customButtonFileSVG;
|
|
267
|
+
const customButton = document.querySelector(qlKey);
|
|
268
|
+
if (customButton.getAttribute('listener') !== '1') {
|
|
269
|
+
customButton.setAttribute('listener', '1');
|
|
270
|
+
customButton.addEventListener('click', (e) => {
|
|
271
|
+
const cursorPosition = localStorage.getItem('quillRange');
|
|
272
|
+
action.click(e, {
|
|
273
|
+
cursorPosition: JSON.parse(cursorPosition),
|
|
274
|
+
args: this.args
|
|
275
|
+
});
|
|
276
|
+
});
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
}, 1000);
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
// if (this.quillConfig.toolbar.container.toString().includes('customFile')) {
|
|
283
|
+
// this.timerLoadQuillToolbar = setInterval(() => {
|
|
284
|
+
// if (document.querySelector('button.ql-customFile')) {
|
|
285
|
+
// clearInterval(this.timerLoadQuillToolbar);
|
|
286
|
+
// document.querySelector('button.ql-customFile').innerHTML = this.customButtonFileSVG;
|
|
287
|
+
// const customButton = document.querySelector('button.ql-customFile');
|
|
288
|
+
// if (customButton.getAttribute('listener') !== '1') {
|
|
289
|
+
// customButton.setAttribute('listener', '1');
|
|
290
|
+
// customButton.addEventListener('click', this.customFileHandler);
|
|
291
|
+
// }
|
|
292
|
+
// }
|
|
293
|
+
// }, 1000);
|
|
294
|
+
// }
|
|
243
295
|
this.ref.markForCheck();
|
|
244
296
|
}
|
|
297
|
+
// customFileHandler = (e) => {
|
|
298
|
+
// const customButton = e.currentTarget;
|
|
299
|
+
// const quillToolbar = customButton.closest('.ql-formats').closest('.ql-toolbar');
|
|
300
|
+
// const quillBox = quillToolbar.closest('.ql-formats')
|
|
301
|
+
// let fileInput: HTMLInputElement = quillToolbar.querySelector('input.ql-customFile[type=file]');
|
|
302
|
+
// if (fileInput == null) {
|
|
303
|
+
// fileInput = document.createElement('input');
|
|
304
|
+
// fileInput.setAttribute('type', Constants.FILE);
|
|
305
|
+
// fileInput.setAttribute('accept', '*');
|
|
306
|
+
// fileInput.classList.add('ql-customFile');
|
|
307
|
+
// fileInput.addEventListener('change', () => {
|
|
308
|
+
// const files = fileInput.files;
|
|
309
|
+
// if (!files || !files.length) {
|
|
310
|
+
// return;
|
|
311
|
+
// }
|
|
312
|
+
// const formData = new FormData();
|
|
313
|
+
// formData.append(Constants.FILE, files[0]);
|
|
314
|
+
// let range = localStorage.getItem('quillRange');
|
|
315
|
+
// if (range) {
|
|
316
|
+
// range = JSON.parse(range);
|
|
317
|
+
// }
|
|
318
|
+
// this.quillEvent.enable(false);
|
|
319
|
+
// this.#uploadFile(formData, this.quillEvent, range, fileInput, quillToolbar.closest('quill-editor').id);
|
|
320
|
+
// });
|
|
321
|
+
// quillToolbar.appendChild(fileInput);
|
|
322
|
+
// }
|
|
323
|
+
// fileInput.click();
|
|
324
|
+
// }
|
|
245
325
|
ngAfterViewInit() {
|
|
246
326
|
__classPrivateFieldGet(this, _subscription).add(this.formControl.valueChanges.subscribe((val) => {
|
|
247
327
|
this.modelChange.emit(val);
|
|
@@ -253,20 +333,76 @@ export class SdEditor {
|
|
|
253
333
|
(_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.removeControl(__classPrivateFieldGet(this, _name));
|
|
254
334
|
__classPrivateFieldGet(this, _subscription).unsubscribe();
|
|
255
335
|
}
|
|
336
|
+
// #uploadImage = (formData, quill, range, fileInput) => {
|
|
337
|
+
// if (!this.urlUploadImage) {
|
|
338
|
+
// this.urlUploadImage = '/partner/v2/merchandise/file/uploaduserfile';
|
|
339
|
+
// }
|
|
340
|
+
// // this.domain = 'https://api-commerce-qc.vinid.dev';
|
|
341
|
+
// this.sdApiService.post(this.urlUploadImage, formData).then((resp: any) => {
|
|
342
|
+
// this.ngZone.runOutsideAngular(() => {
|
|
343
|
+
// quill.enable(true);
|
|
344
|
+
// // quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');
|
|
345
|
+
// quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target="_blank" href="' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '')
|
|
346
|
+
// + '"><img src="' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '') + '" alt="c-image-editor-quill"></a>', 'user');
|
|
347
|
+
// // quill.insertText();
|
|
348
|
+
// const content = quill.getContents();
|
|
349
|
+
// quill.setContents(content);
|
|
350
|
+
// quill.setSelection(range.index + 1, 'user');
|
|
351
|
+
// fileInput.value = '';
|
|
352
|
+
// });
|
|
353
|
+
// });
|
|
354
|
+
// this.ref.markForCheck();
|
|
355
|
+
// }
|
|
356
|
+
// #uploadFile = (formData, quill, range, fileInput, loadingID) => {
|
|
357
|
+
// if (!this.urlUploadFile) {
|
|
358
|
+
// this.urlUploadFile = '/partner/v2/merchandise/file/uploaduserfile';
|
|
359
|
+
// }
|
|
360
|
+
// // this.domain = 'https://api-commerce-qc.vinid.dev';
|
|
361
|
+
// this.loadingService.start('#box-' + loadingID);
|
|
362
|
+
// this.sdApiService.post(this.urlUploadFile, formData).then((resp: any) => {
|
|
363
|
+
// this.ngZone.runOutsideAngular(() => {
|
|
364
|
+
// quill.enable(true);
|
|
365
|
+
// // quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');
|
|
366
|
+
// quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target="_blank" href="' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '')
|
|
367
|
+
// + '">' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '') + '</a>', 'user');
|
|
368
|
+
// // quill.insertText();
|
|
369
|
+
// const content = quill.getContents();
|
|
370
|
+
// quill.setContents(content);
|
|
371
|
+
// quill.setSelection(range.index + 1, 'user');
|
|
372
|
+
// fileInput.value = '';
|
|
373
|
+
// });
|
|
374
|
+
// this.loadingService.stop('#box-' + loadingID);
|
|
375
|
+
// }).catch((er) => {
|
|
376
|
+
// this.loadingService.stop('#box-' + loadingID);
|
|
377
|
+
// });
|
|
378
|
+
// this.ref.markForCheck();
|
|
379
|
+
// }
|
|
380
|
+
onSelectionChanged(e) {
|
|
381
|
+
// localStorage.setItem('quillRange', e.range ? JSON.stringify(e.range) : (e.oldRange ? JSON.stringify(e.oldRange) : null));
|
|
382
|
+
localStorage.setItem('quillRange', e.editor.getSelection() ? JSON.stringify(e.editor.getSelection()) : null);
|
|
383
|
+
}
|
|
384
|
+
onContentChanged(e) {
|
|
385
|
+
localStorage.setItem('quillRange', JSON.stringify({
|
|
386
|
+
index: (e.editor.getLength() ? e.editor.getLength() - 1 : 0),
|
|
387
|
+
length: 0
|
|
388
|
+
}));
|
|
389
|
+
}
|
|
256
390
|
}
|
|
257
|
-
_name = new WeakMap(), _subscription = new WeakMap(), _model = new WeakMap(), _form = new WeakMap(), _updateValidator = new WeakMap(),
|
|
391
|
+
_name = new WeakMap(), _subscription = new WeakMap(), _model = new WeakMap(), _form = new WeakMap(), _updateValidator = new WeakMap(), _initUploadImage = new WeakMap();
|
|
258
392
|
SdEditor.decorators = [
|
|
259
393
|
{ type: Component, args: [{
|
|
260
394
|
selector: 'sd-editor',
|
|
261
|
-
template: "<label *ngIf=\"label && !sdLabelDef?.templateRef\" class=\"d-block T14M\">{{label}} <span class=\"text-danger mb-2\"
|
|
395
|
+
template: "<div id=\"box-{{id}}\">\r\n <label *ngIf=\"label && !sdLabelDef?.templateRef\" class=\"d-block T14M\">{{label}} <span class=\"text-danger mb-2\"\r\n *ngIf=\"required\">*</span></label>\r\n <ng-container *ngIf=\"sdLabelDef?.templateRef\" matSuffix>\r\n <ng-container *ngTemplateOutlet=\"sdLabelDef.templateRef\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!formControl.disabled && !showHtmlEditor\">\r\n <quill-editor #editor [styles]=\"styles\" (onEditorCreated)=\"editorInit($event)\" [ngModel]=\"formControl.value\"\r\n (onSelectionChanged)=\"onSelectionChanged($event)\"\r\n (onContentChanged)=\"onContentChanged($event)\"\r\n (ngModelChange)=\"onModelChange($event)\" [id]=\"id\" [modules]=\"quillConfig\" [placeholder]=\"placeholder\"\r\n [maxLength]=\"maxlength\">\r\n </quill-editor>\r\n <span class=\"d-block text-danger mt-5\" *ngIf=\"formControl.errors?.required\">\r\n {{'This field is required' | sdTranslate}}\r\n </span>\r\n <span class=\"d-block text-danger mt-5\" *ngIf=\"formControl.errors?.minlength\">\r\n {{'Max length' | sdTranslate}} <strong>{{minlength}}</strong>\r\n </span>\r\n <span class=\"d-block text-danger mt-5\" *ngIf=\"formControl.errors?.maxlength\">\r\n {{'Max length' | sdTranslate}} <strong>{{maxlength}}</strong>\r\n </span>\r\n </ng-container>\r\n <ng-container *ngIf=\"formControl.disabled\">\r\n <div [innerHtml]=\"formControl.value\"></div>\r\n </ng-container>\r\n <ng-container *ngIf=\"enableHTMLButton\">\r\n <sd-textarea [(model)]=\"modelHTML\" *ngIf=\"showHtmlEditor\" rows=\"20\"\r\n (modelChange)=\"onModelChange($event)\"></sd-textarea>\r\n <sd-button\r\n title=\"{{showHtmlEditor?'\u1EA8n':'Hi\u1EC7n'}} m\u00E3 HTML\"\r\n class=\"mr-8\"\r\n fontSet=\"material-icons-outlined\"\r\n (action)=\"onClickShowHtmlEditor()\"\r\n type=\"light\"\r\n ></sd-button>\r\n </ng-container>\r\n</div>\r\n",
|
|
262
396
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
263
|
-
styles: ["::ng-deep img[alt=c-image-editor-quill]{max-width:80%}"]
|
|
397
|
+
styles: ["::ng-deep img[alt=c-image-editor-quill]{max-width:80%}::ng-deep .ql-toolbar input.ql-customFile[type=file]{display:none}"]
|
|
264
398
|
},] }
|
|
265
399
|
];
|
|
266
400
|
SdEditor.ctorParameters = () => [
|
|
267
401
|
{ type: NgZone },
|
|
268
402
|
{ type: ChangeDetectorRef },
|
|
269
|
-
{ type: SdApiService }
|
|
403
|
+
{ type: SdApiService },
|
|
404
|
+
{ type: SdLoadingService },
|
|
405
|
+
{ type: undefined, decorators: [{ type: Inject, args: [EDITOR_CONFIG,] }, { type: Optional }] }
|
|
270
406
|
];
|
|
271
407
|
SdEditor.propDecorators = {
|
|
272
408
|
editor: [{ type: ViewChild, args: ['editor',] }],
|
|
@@ -279,8 +415,8 @@ SdEditor.propDecorators = {
|
|
|
279
415
|
modelChange: [{ type: Output }],
|
|
280
416
|
placeholder: [{ type: Input }],
|
|
281
417
|
styles: [{ type: Input }],
|
|
418
|
+
args: [{ type: Input }],
|
|
282
419
|
domain: [{ type: Input }],
|
|
283
|
-
urlUploadImage: [{ type: Input }],
|
|
284
420
|
form: [{ type: Input }],
|
|
285
421
|
toolbar: [{ type: Input }],
|
|
286
422
|
enableHTMLButton: [{ type: Input }],
|
|
@@ -289,4 +425,4 @@ SdEditor.propDecorators = {
|
|
|
289
425
|
sdLabelDef: [{ type: ContentChild, args: [SdLabelDefDirective,] }],
|
|
290
426
|
sdChange: [{ type: Output }]
|
|
291
427
|
};
|
|
292
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/editor/","sources":["src/lib/editor.component.ts"],"names":[],"mappings":";;AAAA,OAAO,EACL,SAAS,EACT,SAAS,EACT,KAAK,EAEL,MAAM,EACN,YAAY,EACZ,iBAAiB,EACS,uBAAuB,EAAE,MAAM,EAAE,YAAY,EACxE,MAAM,eAAe,CAAC;AAEvB,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAC,WAAW,EAAa,MAAM,EAAe,UAAU,EAAC,MAAM,gBAAgB,CAAC;AACvF,OAAO,EAAC,SAAS,EAAC,MAAM,YAAY,CAAC;AACrC,OAAO,EAAC,YAAY,EAAC,MAAM,MAAM,CAAC;AAClC,OAAO,EAAC,YAAY,EAAC,MAAM,sBAAsB,CAAC;AAClD,OAAO,eAAe,CAAC;AACvB,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAQ9D,MAAM,OAAO,QAAQ;IAkJnB,YACU,MAAc,EACd,GAAsB,EACtB,YAA0B;QAF1B,WAAM,GAAN,MAAM,CAAQ;QACd,QAAG,GAAH,GAAG,CAAmB;QACtB,iBAAY,GAAZ,YAAY,CAAc;QApJpC,gBAAQ,IAAI,IAAI,CAAC,EAAE,EAAE,EAAE,EAAC;QACxB,OAAE,GAAW,IAAI,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC;QAC7B,wBAAgB,IAAI,YAAY,EAAE,EAAC;QAGnC,yBAAe;QAmBf,aAAQ,GAAG,KAAK,CAAC;QAqBP,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QAE1C,gBAAW,GAAW,EAAE,CAAC;QAEzB,WAAM,GAAQ,EAAC,MAAM,EAAE,OAAO,EAAC,CAAC;QAEzC,gBAAW,GAAG,IAAI,WAAW,EAAE,CAAC;QAEvB,WAAM,GAAG,EAAE,CAAC;QAErB,wBAAiB;QAYR,qBAAgB,GAAG,KAAK,CAAC;QAClC,mBAAc,GAAG,KAAK,CAAC;QAOvB,gBAAW,GAAG;YACZ,uBAAuB;YACvB,OAAO,EAAE;gBACP,SAAS,EAAE;oBACT,CAAC,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,CAAC;oBACzC,CAAC,YAAY,EAAE,YAAY,CAAC;oBAE5B,CAAC,EAAC,QAAQ,EAAE,CAAC,EAAC,EAAE,EAAC,QAAQ,EAAE,CAAC,EAAC,CAAC;oBAC9B,CAAC,EAAC,MAAM,EAAE,SAAS,EAAC,EAAE,EAAC,MAAM,EAAE,QAAQ,EAAC,CAAC;oBACzC,CAAC,EAAC,QAAQ,EAAE,KAAK,EAAC,EAAE,EAAC,QAAQ,EAAE,OAAO,EAAC,CAAC;oBACxC,CAAC,EAAC,QAAQ,EAAE,IAAI,EAAC,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC;oBACpC,CAAC,EAAC,WAAW,EAAE,KAAK,EAAC,CAAC;oBAEtB,CAAC,EAAC,MAAM,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,CAAC,EAAC,CAAC;oBAC7C,CAAC,EAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,EAAC,CAAC;oBAEvC,CAAC,EAAC,OAAO,EAAE,EAAE,EAAC,EAAE,EAAC,YAAY,EAAE,EAAE,EAAC,CAAC;oBACnC,CAAC,EAAC,MAAM,EAAE,EAAE,EAAC,CAAC;oBACd,CAAC,EAAC,OAAO,EAAE,EAAE,EAAC,CAAC;oBAEf,CAAC,OAAO,CAAC;oBAET,CAAC,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,CAAyB,wBAAwB;iBAC5E;aACF;YACD,OAAO,EAAE;gBACP,YAAY,EAAE,2BAA2B;gBACzC,sBAAsB,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;gBAClC,MAAM,EAAE,CAAC,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,EAAE;oBAC9C,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,WAAW,KAAK,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,WAAW,KAAK,GAAG,CAAC,EAAE;wBAC9F,IAAI,MAAM,CAAC;wBACX,IAAI,WAAW,KAAK,GAAG,EAAE;4BACvB,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC;yBAC7B;6BAAM,IAAI,WAAW,KAAK,GAAG,EAAE;4BAC9B,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC;yBAC7B;6BAAM;4BACL,MAAM,GAAG,EAAE,CAAC;yBACb;wBAED,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;4BAC3B,UAAU,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;yBAChC;6BAAM;4BACL,MAAM,OAAO,GAAG,EAAE,CAAC;4BACnB,yCAAyC;4BACzC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gCACtC,sCAAsC;gCACtC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,EAAE;oCACpE,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;iCACzB;6BACF;4BACD,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;yBACjC;qBACF;gBACH,CAAC;aACF;YACD,QAAQ,EAAE;gBACR,QAAQ,EAAE;oBACR,KAAK,EAAE;wBACL,GAAG,EAAE,EAAE;wBACP,OAAO,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;4BAC1B,OAAO,IAAI,CAAC;wBACd,CAAC;qBACF;iBACF;aACF;SACF,CAAC;QAEF,eAAU,GAAW,CAAC,CAAC;QACb,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;QA8BhD,2BAAmB,GAAG,EAAE;YACtB,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,CAAC;YACnC,IAAI,CAAC,WAAW,CAAC,oBAAoB,EAAE,CAAC;YACxC,MAAM,UAAU,GAAkB,EAAE,CAAC;YACrC,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;aACtC;YACD,IAAI,IAAI,CAAC,SAAS,GAAG,CAAC,EAAE;gBACtB,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;aACvD;YACD,IAAI,IAAI,CAAC,SAAS,GAAG,CAAC,EAAE;gBACtB,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;aACvD;YACD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;YAC3C,IAAI,CAAC,WAAW,CAAC,sBAAsB,EAAE,CAAC;YAC1C,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,EAAA;QAED,eAAU,GAAG,CAAC,KAAK,EAAE,EAAE;YACrB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,sDAAsD;YACtD,0BAA0B;YAC1B,6DAA6D;YAC7D,0DAA0D;YAC1D,qDAAqD;YACrD,oGAAoG;YACpG,qEAAqE;YAErE,sDAAsD;YACtD,mCAAmC;YAEnC,oCAAoC;YACpC,yDAAyD;YACzD,iDAAiD;YACjD,0BAA0B;YAC1B,iDAAiD;YACjD,8DAA8D;YAC9D,SAAS;YACT,wCAAwC;YACxC,MAAM;YAEN,MAAM,IAAI,GAAG,IAAI,CAAC;YAClB,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBACjC,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,UAAU,CAAC,OAAO,EAAE;oBAC7C,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,2BAA2B,CAAC,CAAC;oBAE1E,IAAI,SAAS,IAAI,IAAI,EAAE;wBACrB,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;wBAC5C,SAAS,CAAC,YAAY,CAAC,MAAM,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;wBAC/C,SAAS,CAAC,YAAY,CAAC,QAAQ,EAAE,2DAA2D,CAAC,CAAC;wBAC9F,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;wBACpC,SAAS,CAAC,gBAAgB,CAAC,QAAQ,EAAE,GAAG,EAAE;4BACxC,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC;4BAC9B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;4BAC5C,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;gCAC3B,OAAO;6BACR;4BAED,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;4BAChC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;4BAE1C,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;4BACzB;;;;;;;iCAOK;4BACL,gDAAA,IAAI,EAAc,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;wBACvD,CAAC,CAAC,CAAC;wBACH,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;qBACvC;oBACD,SAAS,CAAC,KAAK,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAA;YACF,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAA;QAED,kBAAa,GAAG,CAAC,GAAW,EAAE,EAAE;YAC9B,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAC/B,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;YACrB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAA;QAED,0BAAqB,GAAG,GAAG,EAAE;YAC3B,IAAI,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC;YAC3C,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAA;QAED,uBAAe,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE;YACnD,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;gBACxB,IAAI,CAAC,cAAc,GAAG,6CAA6C,CAAC;aACrE;YACD,qDAAqD;YACrD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,IAAS,EAAE,EAAE;gBACvE,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;;oBACjC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;oBACnB,sHAAsH;oBACtH,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,oBAAoB,CAAC,KAAK,CAAC,KAAK,EAAE,2BAA2B,GAAG,CAAC,OAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,IAAI,0CAAE,QAAQ,YAAI,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,IAAI,0CAAE,WAAW,CAAA,KAAI,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,GAAG,CAAA,IAAI,EAAE,CAAC;0BAC7J,cAAc,GAAG,CAAC,OAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,IAAI,0CAAE,QAAQ,YAAI,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,IAAI,0CAAE,WAAW,CAAA,KAAI,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,GAAG,CAAA,IAAI,EAAE,CAAC,GAAG,mCAAmC,EAAE,MAAM,CAAC,CAAC;oBACzI,sBAAsB;oBACtB,MAAM,OAAO,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;oBACpC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;oBAC3B,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,EAAE,MAAM,CAAC,CAAC;oBAC5C,SAAS,CAAC,KAAK,GAAG,EAAE,CAAC;gBACvB,CAAC,CAAC,CAAA;YACJ,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,EAAA;IArID,CAAC;IAhJD,IAAa,KAAK,CAAC,GAAW;QAC5B,uBAAA,IAAI,UAAU,GAAG,EAAC;QAClB,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;QACrB,IAAI,CAAC,WAAW,CAAC,QAAQ,uCAAc;YACrC,SAAS,EAAE,KAAK;SACjB,CAAC,CAAC;QACH,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,IAAa,QAAQ,CAAC,GAAiB;QACrC,GAAG,GAAG,CAAC,GAAG,KAAK,EAAE,CAAC,IAAI,GAAG,CAAC;QAC1B,IAAI,GAAG,EAAE;YACP,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;SAC5B;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;SAC3B;IACH,CAAC;IAID,IAAa,SAAS,CAAC,GAAiB;QACtC,IAAI,CAAC,QAAQ,GAAG,CAAC,GAAG,KAAK,EAAE,CAAC,IAAI,GAAG,CAAC;QACpC,oDAAA,IAAI,CAAmB,CAAC;IAC1B,CAAC;IAID,IAAwB,UAAU,CAAC,GAAW;QAC5C,IAAI,CAAC,SAAS,GAAG,CAAC,GAAG,CAAC;QACtB,oDAAA,IAAI,CAAmB,CAAC;IAC1B,CAAC;IAID,IAAwB,UAAU,CAAC,GAAW;QAC5C,IAAI,CAAC,SAAS,GAAG,CAAC,GAAG,CAAC;QACtB,oDAAA,IAAI,CAAmB,CAAC;IAC1B,CAAC;IAaD,IAAa,IAAI,CAAC,GAAuB;QACvC,IAAI,GAAG,EAAE;YACP,IAAI,GAAG,YAAY,MAAM,EAAE;gBACzB,uBAAA,IAAI,SAAS,GAAG,CAAC,IAAI,EAAC;aACvB;iBAAM;gBACL,uBAAA,IAAI,SAAS,GAAG,EAAC;aAClB;SACF;IACH,CAAC;IAwFD,QAAQ;;QACN,mFAAY,UAAU,sCAAa,IAAI,CAAC,WAAW,EAAE;QACrD,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC;YAClD,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;SAC1C;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,eAAe;QACb,4CAAmB,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACrE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC3B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC,CAAC;IACN,CAAC;IAED,WAAW;;QACT,mFAAY,aAAa,sCAAa;QACtC,4CAAmB,WAAW,EAAE,CAAC;IACnC,CAAC;;;;YAlLF,SAAS,SAAC;gBACT,QAAQ,EAAE,WAAW;gBACrB,uwDAAsC;gBAEtC,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aAChD;;;YAhBoD,MAAM;YADzD,iBAAiB;YAQX,YAAY;;;qBAcjB,SAAS,SAAC,QAAQ;oBAClB,KAAK;oBAEL,KAAK;uBASL,KAAK;wBAWL,KAAK;yBAOL,KAAK,SAAC,WAAW;yBAOjB,KAAK,SAAC,WAAW;0BAKjB,MAAM;0BAEN,KAAK;qBAEL,KAAK;qBAIL,KAAK;6BACL,KAAK;mBAEL,KAAK;sBAUL,KAAK;+BACL,KAAK;4BAKL,KAAK;4BACL,KAAK;yBACL,YAAY,SAAC,mBAAmB;uBAqEhC,MAAM","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  EventEmitter,\r\n  ChangeDetectorRef,\r\n  AfterViewInit, OnDestroy, ChangeDetectionStrategy, NgZone, ContentChild\r\n} from '@angular/core';\r\nimport {QuillEditorComponent} from 'ngx-quill';\r\nimport * as uuid from 'uuid';\r\nimport {FormControl, FormGroup, NgForm, ValidatorFn, Validators} from '@angular/forms';\r\nimport {Constants} from './constant';\r\nimport {Subscription} from 'rxjs';\r\nimport {SdApiService} from '@sd-angular/core/api';\r\nimport 'quill-mention';\r\nimport { SdLabelDefDirective } from '@sd-angular/core/common';\r\n\r\n@Component({\r\n  selector: 'sd-editor',\r\n  templateUrl: './editor.component.html',\r\n  styleUrls: ['./editor.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdEditor implements OnInit, AfterViewInit, OnDestroy {\r\n  #name = `N${uuid.v4()}`;\r\n  id: string = `I${uuid.v4()}`;\r\n  #subscription = new Subscription();\r\n  @ViewChild('editor') editor: QuillEditorComponent;\r\n  @Input() label: string;\r\n  #model: string;\r\n  @Input() set model(val: string) {\r\n    this.#model = val;\r\n    this.modelHTML = val;\r\n    this.formControl.setValue(this.#model, {\r\n      emitEvent: false\r\n    });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  @Input() set disabled(val: boolean | '') {\r\n    val = (val === '') || val;\r\n    if (val) {\r\n      this.formControl.disable();\r\n    } else {\r\n      this.formControl.enable();\r\n    }\r\n  }\r\n\r\n  required = false;\r\n\r\n  @Input() set pRequired(val: boolean | '') {\r\n    this.required = (val === '') || val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  minlength: number;\r\n\r\n  @Input('minlength') set _minlength(val: number) {\r\n    this.minlength = +val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  maxlength: number;\r\n\r\n  @Input('maxlength') set _maxlength(val: number) {\r\n    this.maxlength = +val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  @Output() modelChange = new EventEmitter<string>();\r\n\r\n  @Input() placeholder: string = '';\r\n\r\n  @Input() styles: any = {height: '250px'};\r\n\r\n  formControl = new FormControl();\r\n\r\n  @Input() domain = '';\r\n  @Input() urlUploadImage: string;\r\n  #form: FormGroup;\r\n  @Input() set form(val: NgForm | FormGroup) {\r\n    if (val) {\r\n      if (val instanceof NgForm) {\r\n        this.#form = val.form;\r\n      } else {\r\n        this.#form = val;\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input() toolbar: any;\r\n  @Input() enableHTMLButton = false;\r\n  showHtmlEditor = false;\r\n  modelHTML: string;\r\n\r\n  quillEvent: any;\r\n  @Input() mentionValues: { id: string, value: string, link?: string }[];\r\n  @Input() hashTagValues: { id: string, value: string, link?: string }[];\r\n  @ContentChild(SdLabelDefDirective) sdLabelDef: SdLabelDefDirective;\r\n  quillConfig = {\r\n    // toolbar: '.toolbar',\r\n    toolbar: {\r\n      container: [\r\n        ['bold', 'italic', 'underline', 'strike'],        // toggled buttons\r\n        ['blockquote', 'code-block'],\r\n\r\n        [{'header': 1}, {'header': 2}],               // custom button values\r\n        [{'list': 'ordered'}, {'list': 'bullet'}],\r\n        [{'script': 'sub'}, {'script': 'super'}],      // superscript/subscript\r\n        [{'indent': '-1'}, {'indent': '+1'}],          // outdent/indent\r\n        [{'direction': 'rtl'}],                         // text direction\r\n\r\n        [{'size': ['small', false, 'large', 'huge']}],  // custom dropdown\r\n        [{'header': [1, 2, 3, 4, 5, 6, false]}],\r\n\r\n        [{'color': []}, {'background': []}],          // dropdown with defaults from theme\r\n        [{'font': []}],\r\n        [{'align': []}],\r\n\r\n        ['clean'],                                         // remove formatting button\r\n\r\n        ['link', 'image', 'video']                         // link and image, video\r\n      ]\r\n    },\r\n    mention: {\r\n      allowedChars: /^[A-Za-z0-9\\sÅÄÖåäö._-]*$/,\r\n      mentionDenotationChars: ['@', '#'],\r\n      source: (searchTerm, renderList, mentionChar) => {\r\n        if ((this.mentionValues && mentionChar === '@') || (this.hashTagValues && mentionChar === '#')) {\r\n          let values;\r\n          if (mentionChar === '@') {\r\n            values = this.mentionValues;\r\n          } else if (mentionChar === '#') {\r\n            values = this.hashTagValues;\r\n          } else {\r\n            values = [];\r\n          }\r\n\r\n          if (searchTerm.length === 0) {\r\n            renderList(values, searchTerm);\r\n          } else {\r\n            const matches = [];\r\n            // tslint:disable-next-line:prefer-for-of\r\n            for (let i = 0; i < values.length; i++) {\r\n              // tslint:disable-next-line:no-bitwise\r\n              if (~values[i].value.toLowerCase().indexOf(searchTerm.toLowerCase())) {\r\n                matches.push(values[i]);\r\n              }\r\n            }\r\n            renderList(matches, searchTerm);\r\n          }\r\n        }\r\n      },\r\n    },\r\n    keyboard: {\r\n      bindings: {\r\n        enter: {\r\n          key: 13,\r\n          handler: (range, context) => {\r\n            return true;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  };\r\n\r\n  textLength: number = 0;\r\n  @Output() sdChange = new EventEmitter<string>();\r\n\r\n  constructor(\r\n    private ngZone: NgZone,\r\n    private ref: ChangeDetectorRef,\r\n    private sdApiService: SdApiService\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.#form?.addControl(this.#name, this.formControl);\r\n    if (this.toolbar) {\r\n      this.quillConfig.toolbar.container = this.toolbar;\r\n      console.log('toolbar', this.quillConfig);\r\n    }\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.formControl.valueChanges.subscribe((val) => {\r\n      this.modelChange.emit(val);\r\n      this.sdChange.emit(val);\r\n    }));\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#form?.removeControl(this.#name);\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  #updateValidator = () => {\r\n    this.formControl.clearValidators();\r\n    this.formControl.clearAsyncValidators();\r\n    const validators: ValidatorFn[] = [];\r\n    if (this.required) {\r\n      validators.push(Validators.required);\r\n    }\r\n    if (this.minlength > 0) {\r\n      validators.push(Validators.minLength(this.minlength));\r\n    }\r\n    if (this.maxlength > 0) {\r\n      validators.push(Validators.maxLength(this.maxlength));\r\n    }\r\n    this.formControl.setValidators(validators);\r\n    this.formControl.updateValueAndValidity();\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  editorInit = (quill) => {\r\n    this.quillEvent = quill;\r\n    // const txtArea = document.createElement('textarea');\r\n    // txtArea.style.cssText =\r\n    //   'width: 100%;margin: 0px;background: rgb(29, 29, 29);' +\r\n    //   'box-sizing: border-box;color: rgb(204, 204, 204);' +\r\n    //   'font-size: 15px;outline: none;padding: 20px;' +\r\n    //   'line-height: 24px;font-family: Consolas, Menlo, Monaco, &quot;Courier New&quot;, monospace;' +\r\n    //   'position: absolute;top: 0;bottom: 0;border: none;display:none';\r\n\r\n    // const htmlEditor = quill.addContainer('ql-custom');\r\n    // htmlEditor.appendChild(txtArea);\r\n\r\n    // const myEditor = quill.container;\r\n    // quill.on('text-change', (delta, oldDelta, source) => {\r\n    //   const html = myEditor.children[0].innerHTML;\r\n    //   txtArea.value = html;\r\n    //   // if (quill.getLength() > this.maxlength) {\r\n    //   //   quill.deleteText(this.maxlength, quill.getLength());\r\n    //   // }\r\n    //   // this.formControl.setValue(html);\r\n    // });\r\n\r\n    const self = this;\r\n    this.ngZone.runOutsideAngular(() => {\r\n      quill.getModule('toolbar').addHandler('image', function () {\r\n        let fileInput = this.container.querySelector('input.ql-image[type=file]');\r\n  \r\n        if (fileInput == null) {\r\n          fileInput = document.createElement('input');\r\n          fileInput.setAttribute('type', Constants.FILE);\r\n          fileInput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon');\r\n          fileInput.classList.add('ql-image');\r\n          fileInput.addEventListener('change', () => {\r\n            const files = fileInput.files;\r\n            const range = this.quill.getSelection(true);\r\n            if (!files || !files.length) {\r\n              return;\r\n            }\r\n  \r\n            const formData = new FormData();\r\n            formData.append(Constants.FILE, files[0]);\r\n  \r\n            this.quill.enable(false);\r\n            /*this.apiService.post(this.domain + this.urlUploadImage, formData).subscribe((resp: any) => {\r\n              this.quill.enable(true);\r\n              this.quill.editor.insertEmbed(range.index, 'image', resp.data.imageUrl || resp.data.publish_url ||  resp.url);\r\n              const content = this.quill.getContents();\r\n              this.quill.setContents(content);\r\n              this.quill.setSelection(range.index + 1, 'silent');\r\n              fileInput.value = '';\r\n            });*/\r\n            self.#uploadImage(formData, quill, range, fileInput);\r\n          });\r\n          this.container.appendChild(fileInput);\r\n        }\r\n        fileInput.click();\r\n      });\r\n    })\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  onModelChange = (val: string) => {\r\n    this.formControl.setValue(val);\r\n    this.modelHTML = val;\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  onClickShowHtmlEditor = () => {\r\n    this.showHtmlEditor = !this.showHtmlEditor;\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  #uploadImage = (formData, quill, range, fileInput) => {\r\n    if (!this.urlUploadImage) {\r\n      this.urlUploadImage = '/partner/v2/merchandise/file/uploaduserfile';\r\n    }\r\n    // this.domain = 'https://api-commerce-qc.vinid.dev';\r\n    this.sdApiService.post(this.urlUploadImage, formData).then((resp: any) => {\r\n      this.ngZone.runOutsideAngular(() => {\r\n        quill.enable(true);\r\n        // quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');\r\n        quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target=\"_blank\" href=\"' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '')\r\n          + '\"><img src=\"' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '') + '\" alt=\"c-image-editor-quill\"></a>', 'user');\r\n        // quill.insertText();\r\n        const content = quill.getContents();\r\n        quill.setContents(content);\r\n        quill.setSelection(range.index + 1, 'user');\r\n        fileInput.value = '';\r\n      })\r\n    });\r\n    this.ref.markForCheck();\r\n  }\r\n}\r\n"]}
|
|
428
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/editor/","sources":["src/lib/editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ContentChild,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  NgZone,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ContentChange, QuillEditorComponent, SelectionChange } from 'ngx-quill';\r\nimport * as uuid from 'uuid';\r\nimport { FormControl, FormGroup, NgForm, ValidatorFn, Validators } from '@angular/forms';\r\nimport { Constants } from './constant';\r\nimport { Subscription } from 'rxjs';\r\nimport { SdApiService } from '@sd-angular/core/api';\r\nimport 'quill-mention';\r\nimport { SdLabelDefDirective } from '@sd-angular/core/common';\r\nimport { SdLoadingService } from \"@sd-angular/core/loading\";\r\nimport { EDITOR_CONFIG, IEditorConfiguration } from './editor.model';\r\nimport Quill from 'quill';\r\n\r\n@Component({\r\n  selector: 'sd-editor',\r\n  templateUrl: './editor.component.html',\r\n  styleUrls: ['./editor.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdEditor implements OnInit, AfterViewInit, OnDestroy {\r\n  #name = `N${uuid.v4()}`;\r\n  id: string = `I${uuid.v4()}`;\r\n  #subscription = new Subscription();\r\n  @ViewChild('editor') editor: QuillEditorComponent;\r\n  @Input() label: string;\r\n  #model: string;\r\n  @Input() set model(val: string) {\r\n    this.#model = val;\r\n    this.modelHTML = val;\r\n    this.formControl.setValue(this.#model, {\r\n      emitEvent: false\r\n    });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  @Input() set disabled(val: boolean | '') {\r\n    val = (val === '') || val;\r\n    if (val) {\r\n      this.formControl.disable();\r\n    } else {\r\n      this.formControl.enable();\r\n    }\r\n  }\r\n\r\n  required = false;\r\n\r\n  @Input() set pRequired(val: boolean | '') {\r\n    this.required = (val === '') || val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  minlength: number;\r\n\r\n  @Input('minlength') set _minlength(val: number) {\r\n    this.minlength = +val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  maxlength: number;\r\n\r\n  @Input('maxlength') set _maxlength(val: number) {\r\n    this.maxlength = +val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  @Output() modelChange = new EventEmitter<string>();\r\n\r\n  @Input() placeholder: string = '';\r\n\r\n  @Input() styles: any = { height: '250px' };\r\n\r\n  @Input() args: any;\r\n\r\n  formControl = new FormControl();\r\n\r\n  @Input() domain = '';\r\n  #form: FormGroup;\r\n  @Input() set form(val: NgForm | FormGroup) {\r\n    if (val) {\r\n      if (val instanceof NgForm) {\r\n        this.#form = val.form;\r\n      } else {\r\n        this.#form = val;\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input() toolbar: any;\r\n  @Input() enableHTMLButton = false;\r\n  showHtmlEditor = false;\r\n  modelHTML: string;\r\n\r\n  quillEvent: any;\r\n  @Input() mentionValues: { id: string, value: string, link?: string }[];\r\n  @Input() hashTagValues: { id: string, value: string, link?: string }[];\r\n  @ContentChild(SdLabelDefDirective) sdLabelDef: SdLabelDefDirective;\r\n  quillConfig = {\r\n    // toolbar: '.toolbar',\r\n    toolbar: {\r\n      container: [\r\n        ['bold', 'italic', 'underline', 'strike'],        // toggled buttons\r\n        ['blockquote', 'code-block'],\r\n\r\n        [{ 'header': 1 }, { 'header': 2 }],               // custom button values\r\n        [{ 'list': 'ordered' }, { 'list': 'bullet' }],\r\n        [{ 'script': 'sub' }, { 'script': 'super' }],      // superscript/subscript\r\n        [{ 'indent': '-1' }, { 'indent': '+1' }],          // outdent/indent\r\n        [{ 'direction': 'rtl' }],                         // text direction\r\n\r\n        [{ 'size': ['small', false, 'large', 'huge'] }],  // custom dropdown\r\n        [{ 'header': [1, 2, 3, 4, 5, 6, false] }],\r\n\r\n        [{ 'color': [] }, { 'background': [] }],          // dropdown with defaults from theme\r\n        [{ 'font': [] }],\r\n        [{ 'align': [] }],\r\n\r\n        ['clean'],                                         // remove formatting button\r\n\r\n        ['link', 'image', 'video']                         // link and image, video\r\n      ]\r\n    },\r\n    mention: {\r\n      allowedChars: /^[A-Za-z0-9\\sÅÄÖåäö._-]*$/,\r\n      mentionDenotationChars: ['@', '#'],\r\n      source: (searchTerm, renderList, mentionChar) => {\r\n        if ((this.mentionValues && mentionChar === '@') || (this.hashTagValues && mentionChar === '#')) {\r\n          let values;\r\n          if (mentionChar === '@') {\r\n            values = this.mentionValues;\r\n          } else if (mentionChar === '#') {\r\n            values = this.hashTagValues;\r\n          } else {\r\n            values = [];\r\n          }\r\n\r\n          if (searchTerm.length === 0) {\r\n            renderList(values, searchTerm);\r\n          } else {\r\n            const matches = [];\r\n            // tslint:disable-next-line:prefer-for-of\r\n            for (let i = 0; i < values.length; i++) {\r\n              // tslint:disable-next-line:no-bitwise\r\n              if (~values[i].value.toLowerCase().indexOf(searchTerm.toLowerCase())) {\r\n                matches.push(values[i]);\r\n              }\r\n            }\r\n            renderList(matches, searchTerm);\r\n          }\r\n        }\r\n      },\r\n    },\r\n    keyboard: {\r\n      bindings: {\r\n        enter: {\r\n          key: 13,\r\n          handler: (range, context) => {\r\n            return true;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  };\r\n  customButtonFileSVG = '<svg xmlns=\"http://www.w3.org/2000/svg\" enable-background=\"new 0 0 24 24\" height=\"24px\" viewBox=\"0 0 24 24\" width=\"24px\" fill=\"#000000\"><g><rect fill=\"none\" height=\"24\" width=\"24\"/><path d=\"M20.41,8.41l-4.83-4.83C15.21,3.21,14.7,3,14.17,3H5C3.9,3,3,3.9,3,5v14c0,1.1,0.9,2,2,2h14c1.1,0,2-0.9,2-2V9.83 C21,9.3,20.79,8.79,20.41,8.41z M7,7h7v2H7V7z M17,17H7v-2h10V17z M17,13H7v-2h10V13z\"/></g></svg>';\r\n  @Output() sdChange = new EventEmitter<string>();\r\n  timerLoadQuillToolbar = null;\r\n  constructor(\r\n    private ngZone: NgZone,\r\n    private ref: ChangeDetectorRef,\r\n    private sdApiService: SdApiService,\r\n    private loadingService: SdLoadingService,\r\n    @Inject(EDITOR_CONFIG) @Optional() private configuration: IEditorConfiguration,\r\n  ) {\r\n\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.#form?.addControl(this.#name, this.formControl);\r\n\r\n    if (this.toolbar) {\r\n      this.quillConfig.toolbar.container = this.toolbar;\r\n    }\r\n\r\n    for (const action of (this.configuration?.actions || [])) {\r\n      if (this.quillConfig.toolbar.container.toString().includes(action.key)) {\r\n        const qlKey = `button.ql-${action.key}`\r\n        const interval = setInterval(() => {\r\n          if (document.querySelector(qlKey)) {\r\n            clearInterval(interval);\r\n            document.querySelector(qlKey).innerHTML = this.customButtonFileSVG;\r\n            const customButton = document.querySelector(qlKey);\r\n            if (customButton.getAttribute('listener') !== '1') {\r\n              customButton.setAttribute('listener', '1');\r\n              customButton.addEventListener('click', (e) => {\r\n                const cursorPosition = localStorage.getItem('quillRange');\r\n                action.click(e, {\r\n                  cursorPosition: JSON.parse(cursorPosition),\r\n                  args: this.args\r\n                });\r\n              });\r\n            }\r\n          }\r\n        }, 1000);\r\n      }\r\n    }\r\n\r\n    // if (this.quillConfig.toolbar.container.toString().includes('customFile')) {\r\n    //   this.timerLoadQuillToolbar = setInterval(() => {\r\n    //     if (document.querySelector('button.ql-customFile')) {\r\n    //       clearInterval(this.timerLoadQuillToolbar);\r\n    //       document.querySelector('button.ql-customFile').innerHTML = this.customButtonFileSVG;\r\n    //       const customButton = document.querySelector('button.ql-customFile');\r\n    //       if (customButton.getAttribute('listener') !== '1') {\r\n    //         customButton.setAttribute('listener', '1');\r\n    //         customButton.addEventListener('click', this.customFileHandler);\r\n    //       }\r\n    //     }\r\n    //   }, 1000);\r\n    // }\r\n\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  // customFileHandler = (e) => {\r\n  //   const customButton = e.currentTarget;\r\n  //   const quillToolbar = customButton.closest('.ql-formats').closest('.ql-toolbar');\r\n  //   const quillBox = quillToolbar.closest('.ql-formats')\r\n  //   let fileInput: HTMLInputElement = quillToolbar.querySelector('input.ql-customFile[type=file]');\r\n  //   if (fileInput == null) {\r\n  //     fileInput = document.createElement('input');\r\n  //     fileInput.setAttribute('type', Constants.FILE);\r\n  //     fileInput.setAttribute('accept', '*');\r\n  //     fileInput.classList.add('ql-customFile');\r\n  //     fileInput.addEventListener('change', () => {\r\n  //       const files = fileInput.files;\r\n  //       if (!files || !files.length) {\r\n  //         return;\r\n  //       }\r\n\r\n  //       const formData = new FormData();\r\n  //       formData.append(Constants.FILE, files[0]);\r\n  //       let range = localStorage.getItem('quillRange');\r\n  //       if (range) {\r\n  //         range = JSON.parse(range);\r\n  //       }\r\n  //       this.quillEvent.enable(false);\r\n  //       this.#uploadFile(formData, this.quillEvent, range, fileInput, quillToolbar.closest('quill-editor').id);\r\n  //     });\r\n  //     quillToolbar.appendChild(fileInput);\r\n  //   }\r\n  //   fileInput.click();\r\n  // }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.formControl.valueChanges.subscribe((val) => {\r\n      this.modelChange.emit(val);\r\n      this.sdChange.emit(val);\r\n    }));\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#form?.removeControl(this.#name);\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  #updateValidator = () => {\r\n    this.formControl.clearValidators();\r\n    this.formControl.clearAsyncValidators();\r\n    const validators: ValidatorFn[] = [];\r\n    if (this.required) {\r\n      validators.push(Validators.required);\r\n    }\r\n    if (this.minlength > 0) {\r\n      validators.push(Validators.minLength(this.minlength));\r\n    }\r\n    if (this.maxlength > 0) {\r\n      validators.push(Validators.maxLength(this.maxlength));\r\n    }\r\n    this.formControl.setValidators(validators);\r\n    this.formControl.updateValueAndValidity();\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  editorInit = (quill) => {\r\n    this.quillEvent = quill;\r\n    // const txtArea = document.createElement('textarea');\r\n    // txtArea.style.cssText =\r\n    //   'width: 100%;margin: 0px;background: rgb(29, 29, 29);' +\r\n    //   'box-sizing: border-box;color: rgb(204, 204, 204);' +\r\n    //   'font-size: 15px;outline: none;padding: 20px;' +\r\n    //   'line-height: 24px;font-family: Consolas, Menlo, Monaco, &quot;Courier New&quot;, monospace;' +\r\n    //   'position: absolute;top: 0;bottom: 0;border: none;display:none';\r\n\r\n    // const htmlEditor = quill.addContainer('ql-custom');\r\n    // htmlEditor.appendChild(txtArea);\r\n\r\n    // const myEditor = quill.container;\r\n    // quill.on('text-change', (delta, oldDelta, source) => {\r\n    //   const html = myEditor.children[0].innerHTML;\r\n    //   txtArea.value = html;\r\n    //   // if (quill.getLength() > this.maxlength) {\r\n    //   //   quill.deleteText(this.maxlength, quill.getLength());\r\n    //   // }\r\n    //   // this.formControl.setValue(html);\r\n    // });\r\n    const self = this;\r\n    this.#initUploadImage(quill);\r\n    // this.ngZone.runOutsideAngular(() => {\r\n    //   quill.getModule('toolbar').addHandler('image', function () {\r\n    //     let fileInput = this.container.querySelector('input.ql-image[type=file]');\r\n\r\n    //     if (fileInput == null) {\r\n    //       fileInput = document.createElement('input');\r\n    //       fileInput.setAttribute('type', Constants.FILE);\r\n    //       fileInput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon');\r\n    //       fileInput.classList.add('ql-image');\r\n    //       fileInput.addEventListener('change', () => {\r\n    //         const files = fileInput.files;\r\n    //         const range = this.quill.getSelection(true);\r\n    //         if (!files || !files.length) {\r\n    //           return;\r\n    //         }\r\n\r\n    //         const formData = new FormData();\r\n    //         formData.append(Constants.FILE, files[0]);\r\n\r\n    //         this.quill.enable(false);\r\n\r\n    //         self.#uploadImage(formData, quill, range, fileInput);\r\n    //       });\r\n    //       this.container.appendChild(fileInput);\r\n    //     }\r\n    //     fileInput.click();\r\n    //   });\r\n\r\n    // });\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  #initUploadImage = (quill: Quill) => {\r\n    const self = this;\r\n    this.ngZone.runOutsideAngular(() => {\r\n      quill.getModule('toolbar').addHandler('image', function () {\r\n        let fileInput = this.container.querySelector('input.ql-image[type=file]');\r\n        if (fileInput == null) {\r\n          fileInput = document.createElement('input');\r\n          fileInput.setAttribute('type', Constants.FILE);\r\n          fileInput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon');\r\n          fileInput.classList.add('ql-image');\r\n          fileInput.addEventListener('change', () => {\r\n            const files = fileInput.files;\r\n            const range = this.quill.getSelection(true);\r\n            if (!files || !files.length) {\r\n              return;\r\n            }\r\n            const formData = new FormData();\r\n            formData.append(Constants.FILE, files[0]);\r\n            this.quill.enable(false);\r\n            // self.#uploadImage(formData, quill, range, fileInput);\r\n            self.configuration?.uploadImage(formData, self.args).then(url => {\r\n              self.ngZone.runOutsideAngular(() => {\r\n                quill.enable(true);\r\n                // quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');\r\n                quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target=\"_blank\" href=\"' + (url || '')\r\n                  + '\"><img src=\"' + (url || '') + '\" alt=\"c-image-editor-quill\"></a>', 'user');\r\n                // quill.insertText();\r\n                const content = quill.getContents();\r\n                quill.setContents(content);\r\n                quill.setSelection(range.index + 1, 'user');\r\n                fileInput.value = '';\r\n              });\r\n            });\r\n          });\r\n          this.container.appendChild(fileInput);\r\n        }\r\n        fileInput.click();\r\n      });\r\n\r\n    });\r\n  }\r\n\r\n  onModelChange = (val: string) => {\r\n    this.formControl.setValue(val);\r\n    this.modelHTML = val;\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  onClickShowHtmlEditor = () => {\r\n    this.showHtmlEditor = !this.showHtmlEditor;\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  // #uploadImage = (formData, quill, range, fileInput) => {\r\n  //   if (!this.urlUploadImage) {\r\n  //     this.urlUploadImage = '/partner/v2/merchandise/file/uploaduserfile';\r\n  //   }\r\n  //   // this.domain = 'https://api-commerce-qc.vinid.dev';\r\n  //   this.sdApiService.post(this.urlUploadImage, formData).then((resp: any) => {\r\n  //     this.ngZone.runOutsideAngular(() => {\r\n  //       quill.enable(true);\r\n  //       // quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');\r\n  //       quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target=\"_blank\" href=\"' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '')\r\n  //         + '\"><img src=\"' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '') + '\" alt=\"c-image-editor-quill\"></a>', 'user');\r\n  //       // quill.insertText();\r\n  //       const content = quill.getContents();\r\n  //       quill.setContents(content);\r\n  //       quill.setSelection(range.index + 1, 'user');\r\n  //       fileInput.value = '';\r\n  //     });\r\n  //   });\r\n  //   this.ref.markForCheck();\r\n  // }\r\n\r\n  // #uploadFile = (formData, quill, range, fileInput, loadingID) => {\r\n  //   if (!this.urlUploadFile) {\r\n  //     this.urlUploadFile = '/partner/v2/merchandise/file/uploaduserfile';\r\n  //   }\r\n  //   // this.domain = 'https://api-commerce-qc.vinid.dev';\r\n  //   this.loadingService.start('#box-' + loadingID);\r\n  //   this.sdApiService.post(this.urlUploadFile, formData).then((resp: any) => {\r\n  //     this.ngZone.runOutsideAngular(() => {\r\n  //       quill.enable(true);\r\n  //       // quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');\r\n  //       quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target=\"_blank\" href=\"' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '')\r\n  //         + '\">' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '') + '</a>', 'user');\r\n  //       // quill.insertText();\r\n  //       const content = quill.getContents();\r\n  //       quill.setContents(content);\r\n  //       quill.setSelection(range.index + 1, 'user');\r\n  //       fileInput.value = '';\r\n  //     });\r\n  //     this.loadingService.stop('#box-' + loadingID);\r\n  //   }).catch((er) => {\r\n  //     this.loadingService.stop('#box-' + loadingID);\r\n  //   });\r\n  //   this.ref.markForCheck();\r\n  // }\r\n\r\n  onSelectionChanged(e: SelectionChange) {\r\n    // localStorage.setItem('quillRange', e.range ? JSON.stringify(e.range) : (e.oldRange ? JSON.stringify(e.oldRange) : null));\r\n    localStorage.setItem('quillRange', e.editor.getSelection() ? JSON.stringify(e.editor.getSelection()) : null);\r\n  }\r\n\r\n  onContentChanged(e: ContentChange) {\r\n    localStorage.setItem('quillRange', JSON.stringify({\r\n      index: (e.editor.getLength() ? e.editor.getLength() - 1 : 0),\r\n      length: 0\r\n    }));\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { InjectionToken } from "@angular/core";
|
|
2
|
+
export const EDITOR_CONFIG = new InjectionToken('editor.configuration');
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9lZGl0b3IvIiwic291cmNlcyI6WyJzcmMvbGliL2VkaXRvci5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBaUIvQyxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUcsSUFBSSxjQUFjLENBQXVCLHNCQUFzQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElFZGl0b3JDb25maWd1cmF0aW9uIHtcclxuICB1cGxvYWRJbWFnZT86IChmb3JtRGF0YTogRm9ybURhdGEsIGFyZ3M/OiBhbnkpID0+IFByb21pc2U8c3RyaW5nPjtcclxuICBhY3Rpb25zOiB7XHJcbiAgICBrZXk6IHN0cmluZztcclxuICAgIGljb246IHN0cmluZztcclxuICAgIGNsaWNrOiAoZXZlbnQ6IEV2ZW50LCBhcmdzPzoge1xyXG4gICAgICBjdXJzb3JQb3NpdGlvbjoge1xyXG4gICAgICAgIGluZGV4OiBudW1iZXI7XHJcbiAgICAgICAgbGVuZ3RoOiBudW1iZXI7XHJcbiAgICAgIH0sXHJcbiAgICAgIGFyZ3M/OiBhbnlcclxuICAgIH0pID0+IHZvaWRcclxuICB9W107XHJcbn1cclxuXHJcbmV4cG9ydCBjb25zdCBFRElUT1JfQ09ORklHID0gbmV3IEluamVjdGlvblRva2VuPElFZGl0b3JDb25maWd1cmF0aW9uPignZWRpdG9yLmNvbmZpZ3VyYXRpb24nKTsiXX0=
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
/*
|
|
2
2
|
* Public API Surface of superdev-angular-core
|
|
3
3
|
*/
|
|
4
|
+
export * from './lib/editor.model';
|
|
4
5
|
export * from './lib/editor.module';
|
|
5
6
|
export * from './lib/constant';
|
|
6
7
|
export * from './lib/editor.component';
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvZWRpdG9yLyIsInNvdXJjZXMiOlsic3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHN1cGVyZGV2LWFuZ3VsYXItY29yZVxyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VkaXRvci5tb2RlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VkaXRvci5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb25zdGFudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VkaXRvci5jb21wb25lbnQnO1xyXG4iXX0=
|