@sd-angular/core 1.2.86 → 1.2.87
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.__ivy_ngcc_bak +1 -1
- package/bundles/sd-angular-core-comment.umd.js.map +1 -1
- package/bundles/sd-angular-core-comment.umd.js.map.__ivy_ngcc_bak +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 +126 -20
- package/bundles/sd-angular-core-editor.umd.js.__ivy_ngcc_bak +126 -20
- package/bundles/sd-angular-core-editor.umd.js.map +1 -1
- package/bundles/sd-angular-core-editor.umd.js.map.__ivy_ngcc_bak +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/comment/sd-angular-core-comment.metadata.json +1 -1
- package/comment/src/lib/comment.model.d.ts +1 -0
- package/editor/sd-angular-core-editor.metadata.json +1 -1
- package/editor/src/lib/editor.component.d.ts +14 -4
- package/editor/src/lib/editor.model.d.ts +6 -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 +121 -18
- package/esm2015/editor/src/lib/editor.model.js +3 -0
- package/esm2015/editor/src/public-api.js +2 -1
- package/fesm2015/sd-angular-core-comment.js +1 -1
- package/fesm2015/sd-angular-core-comment.js.__ivy_ngcc_bak +1 -1
- package/fesm2015/sd-angular-core-comment.js.map +1 -1
- package/fesm2015/sd-angular-core-comment.js.map.__ivy_ngcc_bak +1 -1
- package/fesm2015/sd-angular-core-editor.js +122 -18
- package/fesm2015/sd-angular-core-editor.js.__ivy_ngcc_bak +122 -18
- package/fesm2015/sd-angular-core-editor.js.map +1 -1
- package/fesm2015/sd-angular-core-editor.js.map.__ivy_ngcc_bak +1 -1
- package/package.json +1 -1
- package/{sd-angular-core-1.2.86.tgz → sd-angular-core-1.2.87.tgz} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../node_modules/tslib/tslib.es6.js","../../../../projects/sd-core/comment/src/lib/comment.component.ts","../../../../projects/sd-core/comment/src/lib/comment.module.ts"],"names":["__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","__generator","body","f","y","t","g","_","label","sent","trys","ops","verb","throw","return","Symbol","iterator","this","n","v","op","TypeError","call","pop","length","push","Object","create","__classPrivateFieldGet","receiver","state","kind","has","get","SdComment","_this","_items","set","BehaviorSubject","_send","fullCommentStyles","min-height","onSend","message","_b","_a","commentOption","event","_c","textarea","focus","_load","items","results","_d","reload","_e","_f","clearAllData","defineProperty","prototype","option","ngOnInit","pipe","map","assign","picture","creator","count","ngOnDestroy","ngAfterViewInit","Component","args","selector","template","changeDetection","ChangeDetectionStrategy","OnPush","ViewChild","SdTextarea","Input","NgModule","imports","CommonModule","MatButtonModule","MatIconModule","MatTooltipModule","SdTranslateModule","SdButtonModule","SdInputModule","SdTextareaModule","SdEditorModule","SdUtilityModule","SdModalModule","declarations","exports","providers"],"mappings":"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","sourcesContent":["/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n","import {\r\n Component,\r\n AfterViewInit,\r\n OnInit,\r\n OnDestroy,\r\n Input,\r\n ChangeDetectionStrategy,\r\n ViewChild\r\n} from '@angular/core';\r\nimport {SdTextarea} from '@sd-angular/core/textarea';\r\nimport {BehaviorSubject, Observable} from 'rxjs';\r\nimport {map, switchMap} from 'rxjs/operators';\r\nimport {Comment, SdCommentOption} from './comment.model';\r\n\r\n@Component({\r\n selector: 'sd-comment',\r\n templateUrl: './comment.component.html',\r\n styleUrls: ['./comment.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdComment implements OnInit, AfterViewInit, OnDestroy {\r\n @ViewChild(SdTextarea) textarea: SdTextarea;\r\n #items = new BehaviorSubject<Comment[]>([]);\r\n #send = new BehaviorSubject<string>('');\r\n commentOption: SdCommentOption;\r\n\r\n @Input() set option(option: SdCommentOption) {\r\n this.commentOption = option;\r\n this.reload();\r\n };\r\n\r\n fullCommentStyles = {\r\n 'min-height': '150px'\r\n };\r\n items: Observable<Comment[]>;\r\n count: Observable<number>;\r\n message: string;\r\n\r\n constructor() {\r\n }\r\n\r\n ngOnInit(): void {\r\n this.items = this.#items.pipe(map(items => {\r\n return items.map(e => ({\r\n ...e,\r\n picture: e.picture ?? `https://ui-avatars.com/api/?size=32&rounded=true&background=random&name=${e.creator}`\r\n }));\r\n }));\r\n this.count = this.items.pipe(map(items => items.length));\r\n }\r\n\r\n ngOnDestroy(): void {\r\n }\r\n\r\n ngAfterViewInit(): void {\r\n }\r\n\r\n onSend = () => {\r\n if (this.message) {\r\n this.commentOption?.event?.onSend(this.message);\r\n this.message = null;\r\n this.textarea?.focus();\r\n }\r\n }\r\n\r\n #load = async () => {\r\n const {items} = this.commentOption;\r\n const results = items();\r\n if (results instanceof Promise) {\r\n return await results;\r\n }\r\n return results;\r\n }\r\n\r\n reload = async () => {\r\n this.#items.next(await this.#load());\r\n }\r\n\r\n clearAllData = () => {\r\n this.message = '';\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { SdTranslateModule } from '@sd-angular/core/translate';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { SdComment } from './comment.component';\r\nimport { SdButtonModule } from '@sd-angular/core/button';\r\nimport { SdInputModule } from '@sd-angular/core/input';\r\nimport { SdTextareaModule } from '@sd-angular/core/textarea';\r\nimport { SdUtilityModule } from '@sd-angular/core/utility';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport {SdEditorModule} from '@sd-angular/core/editor';\r\nimport {SdModalModule} from '@sd-angular/core/modal';\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n MatButtonModule,\r\n MatIconModule,\r\n MatTooltipModule,\r\n SdTranslateModule,\r\n SdButtonModule,\r\n SdInputModule,\r\n SdTextareaModule,\r\n SdEditorModule,\r\n SdUtilityModule,\r\n SdModalModule\r\n ],\r\n declarations: [\r\n SdComment\r\n ],\r\n exports: [\r\n SdComment\r\n ],\r\n providers: [\r\n ]\r\n})\r\nexport class SdCommentModule { }\r\n"]}
|
|
1
|
+
{"version":3,"sources":["../../../../node_modules/tslib/tslib.es6.js","../../../../projects/sd-core/comment/src/lib/comment.component.ts","../../../../projects/sd-core/comment/src/lib/comment.module.ts"],"names":["__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","__generator","body","f","y","t","g","_","label","sent","trys","ops","verb","throw","return","Symbol","iterator","this","n","v","op","TypeError","call","pop","length","push","Object","create","__classPrivateFieldGet","receiver","state","kind","has","get","SdComment","_this","_items","set","BehaviorSubject","_send","fullCommentStyles","min-height","onSend","message","_b","_a","commentOption","event","_c","textarea","focus","_load","items","results","_d","reload","_e","_f","clearAllData","defineProperty","prototype","option","ngOnInit","pipe","map","assign","picture","creator","count","ngOnDestroy","ngAfterViewInit","Component","args","selector","template","changeDetection","ChangeDetectionStrategy","OnPush","ViewChild","SdTextarea","Input","NgModule","imports","CommonModule","MatButtonModule","MatIconModule","MatTooltipModule","SdTranslateModule","SdButtonModule","SdInputModule","SdTextareaModule","SdEditorModule","SdUtilityModule","SdModalModule","declarations","exports","providers"],"mappings":"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","sourcesContent":["/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n","import {\r\n Component,\r\n AfterViewInit,\r\n OnInit,\r\n OnDestroy,\r\n Input,\r\n ChangeDetectionStrategy,\r\n ViewChild\r\n} from '@angular/core';\r\nimport {SdTextarea} from '@sd-angular/core/textarea';\r\nimport {BehaviorSubject, Observable} from 'rxjs';\r\nimport {map, switchMap} from 'rxjs/operators';\r\nimport {Comment, SdCommentOption} from './comment.model';\r\n\r\n@Component({\r\n selector: 'sd-comment',\r\n templateUrl: './comment.component.html',\r\n styleUrls: ['./comment.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdComment implements OnInit, AfterViewInit, OnDestroy {\r\n @ViewChild(SdTextarea) textarea: SdTextarea;\r\n #items = new BehaviorSubject<Comment[]>([]);\r\n #send = new BehaviorSubject<string>('');\r\n commentOption: SdCommentOption;\r\n\r\n @Input() set option(option: SdCommentOption) {\r\n this.commentOption = option;\r\n this.reload();\r\n };\r\n\r\n fullCommentStyles = {\r\n 'min-height': '150px'\r\n };\r\n items: Observable<Comment[]>;\r\n count: Observable<number>;\r\n message: string;\r\n\r\n constructor() {\r\n }\r\n\r\n ngOnInit(): void {\r\n this.items = this.#items.pipe(map(items => {\r\n return items.map(e => ({\r\n ...e,\r\n picture: e.picture ?? `https://ui-avatars.com/api/?size=32&rounded=true&background=random&name=${e.creator}`\r\n }));\r\n }));\r\n this.count = this.items.pipe(map(items => items.length));\r\n }\r\n\r\n ngOnDestroy(): void {\r\n }\r\n\r\n ngAfterViewInit(): void {\r\n }\r\n\r\n onSend = () => {\r\n if (this.message) {\r\n this.commentOption?.event?.onSend(this.message);\r\n this.message = null;\r\n this.textarea?.focus();\r\n }\r\n }\r\n\r\n #load = async () => {\r\n const {items} = this.commentOption;\r\n const results = items();\r\n if (results instanceof Promise) {\r\n return await results;\r\n }\r\n return results;\r\n }\r\n\r\n reload = async () => {\r\n this.#items.next(await this.#load());\r\n }\r\n\r\n clearAllData = () => {\r\n this.message = '';\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { SdTranslateModule } from '@sd-angular/core/translate';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { SdComment } from './comment.component';\r\nimport { SdButtonModule } from '@sd-angular/core/button';\r\nimport { SdInputModule } from '@sd-angular/core/input';\r\nimport { SdTextareaModule } from '@sd-angular/core/textarea';\r\nimport { SdUtilityModule } from '@sd-angular/core/utility';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport {SdEditorModule} from '@sd-angular/core/editor';\r\nimport {SdModalModule} from '@sd-angular/core/modal';\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n MatButtonModule,\r\n MatIconModule,\r\n MatTooltipModule,\r\n SdTranslateModule,\r\n SdButtonModule,\r\n SdInputModule,\r\n SdTextareaModule,\r\n SdEditorModule,\r\n SdUtilityModule,\r\n SdModalModule\r\n ],\r\n declarations: [\r\n SdComment\r\n ],\r\n exports: [\r\n SdComment\r\n ],\r\n providers: [\r\n ]\r\n})\r\nexport class SdCommentModule { }\r\n"]}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
(function (global, factory) {
|
|
2
|
-
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('ngx-quill'), require('@angular/forms'), require('uuid'), require('rxjs'), require('@sd-angular/core/api'), require('quill-mention'), require('@sd-angular/core/common'), require('@angular/common'), require('@sd-angular/core/translate'), require('@sd-angular/core/button'), require('@sd-angular/core/textarea')) :
|
|
3
|
-
typeof define === 'function' && define.amd ? define('@sd-angular/core/editor', ['exports', '@angular/core', 'ngx-quill', '@angular/forms', 'uuid', 'rxjs', '@sd-angular/core/api', 'quill-mention', '@sd-angular/core/common', '@angular/common', '@sd-angular/core/translate', '@sd-angular/core/button', '@sd-angular/core/textarea'], factory) :
|
|
4
|
-
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global['sd-angular'] = global['sd-angular'] || {}, global['sd-angular'].core = global['sd-angular'].core || {}, global['sd-angular'].core.editor = {}), global.ng.core, global['ngx-quill'], global.ng.forms, global.uuid, global.rxjs, global['sd-angular'].core.api, null, global['sd-angular'].core.common, global.ng.common, global['sd-angular'].core.translate, global['sd-angular'].core.button, global['sd-angular'].core.textarea));
|
|
5
|
-
}(this, (function (exports, core, ngxQuill, forms, uuid, rxjs, api, quillMention, common, common$1, translate, button, textarea) { 'use strict';
|
|
2
|
+
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('ngx-quill'), require('@angular/forms'), require('uuid'), require('rxjs'), require('@sd-angular/core/api'), require('quill-mention'), require('@sd-angular/core/common'), require('@sd-angular/core/loading'), require('@angular/common'), require('@sd-angular/core/translate'), require('@sd-angular/core/button'), require('@sd-angular/core/textarea')) :
|
|
3
|
+
typeof define === 'function' && define.amd ? define('@sd-angular/core/editor', ['exports', '@angular/core', 'ngx-quill', '@angular/forms', 'uuid', 'rxjs', '@sd-angular/core/api', 'quill-mention', '@sd-angular/core/common', '@sd-angular/core/loading', '@angular/common', '@sd-angular/core/translate', '@sd-angular/core/button', '@sd-angular/core/textarea'], factory) :
|
|
4
|
+
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global['sd-angular'] = global['sd-angular'] || {}, global['sd-angular'].core = global['sd-angular'].core || {}, global['sd-angular'].core.editor = {}), global.ng.core, global['ngx-quill'], global.ng.forms, global.uuid, global.rxjs, global['sd-angular'].core.api, null, global['sd-angular'].core.common, global['sd-angular'].core.loading, global.ng.common, global['sd-angular'].core.translate, global['sd-angular'].core.button, global['sd-angular'].core.textarea));
|
|
5
|
+
}(this, (function (exports, core, ngxQuill, forms, uuid, rxjs, api, quillMention, common, loading, common$1, translate, button, textarea) { 'use strict';
|
|
6
|
+
|
|
7
|
+
var EDITOR_CONFIG = new core.InjectionToken('editor.configuration');
|
|
6
8
|
|
|
7
9
|
/*! *****************************************************************************
|
|
8
10
|
Copyright (c) Microsoft Corporation.
|
|
@@ -427,13 +429,15 @@
|
|
|
427
429
|
}
|
|
428
430
|
};
|
|
429
431
|
|
|
430
|
-
var _name, _subscription, _model, _form, _updateValidator, _uploadImage;
|
|
432
|
+
var _name, _subscription, _model, _form, _updateValidator, _initUploadImage, _uploadImage, _uploadFile;
|
|
431
433
|
var SdEditor = /** @class */ (function () {
|
|
432
|
-
function SdEditor(ngZone, ref, sdApiService) {
|
|
434
|
+
function SdEditor(ngZone, ref, sdApiService, loadingService, configuration) {
|
|
433
435
|
var _this = this;
|
|
434
436
|
this.ngZone = ngZone;
|
|
435
437
|
this.ref = ref;
|
|
436
438
|
this.sdApiService = sdApiService;
|
|
439
|
+
this.loadingService = loadingService;
|
|
440
|
+
this.configuration = configuration;
|
|
437
441
|
_name.set(this, "N" + uuid.v4());
|
|
438
442
|
this.id = "I" + uuid.v4();
|
|
439
443
|
_subscription.set(this, new rxjs.Subscription());
|
|
@@ -510,8 +514,37 @@
|
|
|
510
514
|
}
|
|
511
515
|
}
|
|
512
516
|
};
|
|
513
|
-
this.
|
|
517
|
+
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>';
|
|
514
518
|
this.sdChange = new core.EventEmitter();
|
|
519
|
+
this.timerLoadQuillToolbar = null;
|
|
520
|
+
this.customFileHandler = function (e) {
|
|
521
|
+
var customButton = e.currentTarget;
|
|
522
|
+
var quillToolbar = customButton.closest('.ql-formats').closest('.ql-toolbar');
|
|
523
|
+
var quillBox = quillToolbar.closest('.ql-formats');
|
|
524
|
+
var fileInput = quillToolbar.querySelector('input.ql-customFile[type=file]');
|
|
525
|
+
if (fileInput == null) {
|
|
526
|
+
fileInput = document.createElement('input');
|
|
527
|
+
fileInput.setAttribute('type', Constants.FILE);
|
|
528
|
+
fileInput.setAttribute('accept', '*');
|
|
529
|
+
fileInput.classList.add('ql-customFile');
|
|
530
|
+
fileInput.addEventListener('change', function () {
|
|
531
|
+
var files = fileInput.files;
|
|
532
|
+
if (!files || !files.length) {
|
|
533
|
+
return;
|
|
534
|
+
}
|
|
535
|
+
var formData = new FormData();
|
|
536
|
+
formData.append(Constants.FILE, files[0]);
|
|
537
|
+
var range = localStorage.getItem('quillRange');
|
|
538
|
+
if (range) {
|
|
539
|
+
range = JSON.parse(range);
|
|
540
|
+
}
|
|
541
|
+
_this.quillEvent.enable(false);
|
|
542
|
+
__classPrivateFieldGet(_this, _uploadFile).call(_this, formData, _this.quillEvent, range, fileInput, quillToolbar.closest('quill-editor').id);
|
|
543
|
+
});
|
|
544
|
+
quillToolbar.appendChild(fileInput);
|
|
545
|
+
}
|
|
546
|
+
fileInput.click();
|
|
547
|
+
};
|
|
515
548
|
_updateValidator.set(this, function () {
|
|
516
549
|
_this.formControl.clearValidators();
|
|
517
550
|
_this.formControl.clearAsyncValidators();
|
|
@@ -568,14 +601,6 @@
|
|
|
568
601
|
var formData = new FormData();
|
|
569
602
|
formData.append(Constants.FILE, files[0]);
|
|
570
603
|
_this.quill.enable(false);
|
|
571
|
-
/*this.apiService.post(this.domain + this.urlUploadImage, formData).subscribe((resp: any) => {
|
|
572
|
-
this.quill.enable(true);
|
|
573
|
-
this.quill.editor.insertEmbed(range.index, 'image', resp.data.imageUrl || resp.data.publish_url || resp.url);
|
|
574
|
-
const content = this.quill.getContents();
|
|
575
|
-
this.quill.setContents(content);
|
|
576
|
-
this.quill.setSelection(range.index + 1, 'silent');
|
|
577
|
-
fileInput.value = '';
|
|
578
|
-
});*/
|
|
579
604
|
__classPrivateFieldGet(self, _uploadImage).call(self, formData, quill, range, fileInput);
|
|
580
605
|
});
|
|
581
606
|
this.container.appendChild(fileInput);
|
|
@@ -585,6 +610,34 @@
|
|
|
585
610
|
});
|
|
586
611
|
_this.ref.markForCheck();
|
|
587
612
|
};
|
|
613
|
+
_initUploadImage.set(this, function (quill) {
|
|
614
|
+
var self = _this;
|
|
615
|
+
_this.ngZone.runOutsideAngular(function () {
|
|
616
|
+
quill.getModule('toolbar').addHandler('image', function () {
|
|
617
|
+
var _this = this;
|
|
618
|
+
var fileInput = this.container.querySelector('input.ql-image[type=file]');
|
|
619
|
+
if (fileInput == null) {
|
|
620
|
+
fileInput = document.createElement('input');
|
|
621
|
+
fileInput.setAttribute('type', Constants.FILE);
|
|
622
|
+
fileInput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon');
|
|
623
|
+
fileInput.classList.add('ql-image');
|
|
624
|
+
fileInput.addEventListener('change', function () {
|
|
625
|
+
var files = fileInput.files;
|
|
626
|
+
var range = _this.quill.getSelection(true);
|
|
627
|
+
if (!files || !files.length) {
|
|
628
|
+
return;
|
|
629
|
+
}
|
|
630
|
+
var formData = new FormData();
|
|
631
|
+
formData.append(Constants.FILE, files[0]);
|
|
632
|
+
_this.quill.enable(false);
|
|
633
|
+
__classPrivateFieldGet(self, _uploadImage).call(self, formData, quill, range, fileInput);
|
|
634
|
+
});
|
|
635
|
+
this.container.appendChild(fileInput);
|
|
636
|
+
}
|
|
637
|
+
fileInput.click();
|
|
638
|
+
});
|
|
639
|
+
});
|
|
640
|
+
});
|
|
588
641
|
this.onModelChange = function (val) {
|
|
589
642
|
_this.formControl.setValue(val);
|
|
590
643
|
_this.modelHTML = val;
|
|
@@ -615,6 +668,31 @@
|
|
|
615
668
|
});
|
|
616
669
|
_this.ref.markForCheck();
|
|
617
670
|
});
|
|
671
|
+
_uploadFile.set(this, function (formData, quill, range, fileInput, loadingID) {
|
|
672
|
+
if (!_this.urlUploadFile) {
|
|
673
|
+
_this.urlUploadFile = '/partner/v2/merchandise/file/uploaduserfile';
|
|
674
|
+
}
|
|
675
|
+
// this.domain = 'https://api-commerce-qc.vinid.dev';
|
|
676
|
+
_this.loadingService.start('#box-' + loadingID);
|
|
677
|
+
_this.sdApiService.post(_this.urlUploadFile, formData).then(function (resp) {
|
|
678
|
+
_this.ngZone.runOutsideAngular(function () {
|
|
679
|
+
var _a, _b, _c, _d;
|
|
680
|
+
quill.enable(true);
|
|
681
|
+
// quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');
|
|
682
|
+
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) || '')
|
|
683
|
+
+ '">' + (((_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) || '') + '</a>', 'user');
|
|
684
|
+
// quill.insertText();
|
|
685
|
+
var content = quill.getContents();
|
|
686
|
+
quill.setContents(content);
|
|
687
|
+
quill.setSelection(range.index + 1, 'user');
|
|
688
|
+
fileInput.value = '';
|
|
689
|
+
});
|
|
690
|
+
_this.loadingService.stop('#box-' + loadingID);
|
|
691
|
+
}).catch(function (er) {
|
|
692
|
+
_this.loadingService.stop('#box-' + loadingID);
|
|
693
|
+
});
|
|
694
|
+
_this.ref.markForCheck();
|
|
695
|
+
});
|
|
618
696
|
}
|
|
619
697
|
Object.defineProperty(SdEditor.prototype, "model", {
|
|
620
698
|
set: function (val) {
|
|
@@ -680,11 +758,24 @@
|
|
|
680
758
|
configurable: true
|
|
681
759
|
});
|
|
682
760
|
SdEditor.prototype.ngOnInit = function () {
|
|
761
|
+
var _this = this;
|
|
683
762
|
var _a;
|
|
684
763
|
(_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.addControl(__classPrivateFieldGet(this, _name), this.formControl);
|
|
685
764
|
if (this.toolbar) {
|
|
686
765
|
this.quillConfig.toolbar.container = this.toolbar;
|
|
687
|
-
|
|
766
|
+
}
|
|
767
|
+
if (this.quillConfig.toolbar.container.toString().includes('customFile')) {
|
|
768
|
+
this.timerLoadQuillToolbar = setInterval(function () {
|
|
769
|
+
if (document.querySelector('button.ql-customFile')) {
|
|
770
|
+
clearInterval(_this.timerLoadQuillToolbar);
|
|
771
|
+
document.querySelector('button.ql-customFile').innerHTML = _this.customButtonFileSVG;
|
|
772
|
+
var customButton = document.querySelector('button.ql-customFile');
|
|
773
|
+
if (customButton.getAttribute('listener') !== '1') {
|
|
774
|
+
customButton.setAttribute('listener', '1');
|
|
775
|
+
customButton.addEventListener('click', _this.customFileHandler);
|
|
776
|
+
}
|
|
777
|
+
}
|
|
778
|
+
}, 1000);
|
|
688
779
|
}
|
|
689
780
|
this.ref.markForCheck();
|
|
690
781
|
};
|
|
@@ -700,21 +791,33 @@
|
|
|
700
791
|
(_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.removeControl(__classPrivateFieldGet(this, _name));
|
|
701
792
|
__classPrivateFieldGet(this, _subscription).unsubscribe();
|
|
702
793
|
};
|
|
794
|
+
SdEditor.prototype.onSelectionChanged = function (e) {
|
|
795
|
+
// localStorage.setItem('quillRange', e.range ? JSON.stringify(e.range) : (e.oldRange ? JSON.stringify(e.oldRange) : null));
|
|
796
|
+
localStorage.setItem('quillRange', e.editor.getSelection() ? JSON.stringify(e.editor.getSelection()) : null);
|
|
797
|
+
};
|
|
798
|
+
SdEditor.prototype.onContentChanged = function (e) {
|
|
799
|
+
localStorage.setItem('quillRange', JSON.stringify({
|
|
800
|
+
index: (e.editor.getLength() ? e.editor.getLength() - 1 : 0),
|
|
801
|
+
length: 0
|
|
802
|
+
}));
|
|
803
|
+
};
|
|
703
804
|
return SdEditor;
|
|
704
805
|
}());
|
|
705
|
-
_name = new WeakMap(), _subscription = new WeakMap(), _model = new WeakMap(), _form = new WeakMap(), _updateValidator = new WeakMap(), _uploadImage = new WeakMap();
|
|
806
|
+
_name = new WeakMap(), _subscription = new WeakMap(), _model = new WeakMap(), _form = new WeakMap(), _updateValidator = new WeakMap(), _initUploadImage = new WeakMap(), _uploadImage = new WeakMap(), _uploadFile = new WeakMap();
|
|
706
807
|
SdEditor.decorators = [
|
|
707
808
|
{ type: core.Component, args: [{
|
|
708
809
|
selector: 'sd-editor',
|
|
709
|
-
template: "<label *ngIf=\"label && !sdLabelDef?.templateRef\" class=\"d-block T14M\">{{label}} <span class=\"text-danger mb-2\"
|
|
810
|
+
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",
|
|
710
811
|
changeDetection: core.ChangeDetectionStrategy.OnPush,
|
|
711
|
-
styles: ["::ng-deep img[alt=c-image-editor-quill]{max-width:80%}"]
|
|
812
|
+
styles: ["::ng-deep img[alt=c-image-editor-quill]{max-width:80%}::ng-deep .ql-toolbar input.ql-customFile[type=file]{display:none}"]
|
|
712
813
|
},] }
|
|
713
814
|
];
|
|
714
815
|
SdEditor.ctorParameters = function () { return [
|
|
715
816
|
{ type: core.NgZone },
|
|
716
817
|
{ type: core.ChangeDetectorRef },
|
|
717
|
-
{ type: api.SdApiService }
|
|
818
|
+
{ type: api.SdApiService },
|
|
819
|
+
{ type: loading.SdLoadingService },
|
|
820
|
+
{ type: undefined, decorators: [{ type: core.Inject, args: [EDITOR_CONFIG,] }, { type: core.Optional }] }
|
|
718
821
|
]; };
|
|
719
822
|
SdEditor.propDecorators = {
|
|
720
823
|
editor: [{ type: core.ViewChild, args: ['editor',] }],
|
|
@@ -727,8 +830,10 @@
|
|
|
727
830
|
modelChange: [{ type: core.Output }],
|
|
728
831
|
placeholder: [{ type: core.Input }],
|
|
729
832
|
styles: [{ type: core.Input }],
|
|
833
|
+
args: [{ type: core.Input }],
|
|
730
834
|
domain: [{ type: core.Input }],
|
|
731
835
|
urlUploadImage: [{ type: core.Input }],
|
|
836
|
+
urlUploadFile: [{ type: core.Input }],
|
|
732
837
|
form: [{ type: core.Input }],
|
|
733
838
|
toolbar: [{ type: core.Input }],
|
|
734
839
|
enableHTMLButton: [{ type: core.Input }],
|
|
@@ -770,6 +875,7 @@
|
|
|
770
875
|
*/
|
|
771
876
|
|
|
772
877
|
exports.Constants = Constants;
|
|
878
|
+
exports.EDITOR_CONFIG = EDITOR_CONFIG;
|
|
773
879
|
exports.PROMOTION_FORM = PROMOTION_FORM;
|
|
774
880
|
exports.PROMOTION_PERMISSIONS = PROMOTION_PERMISSIONS;
|
|
775
881
|
exports.SdEditor = SdEditor;
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
(function (global, factory) {
|
|
2
|
-
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('ngx-quill'), require('@angular/forms'), require('uuid'), require('rxjs'), require('@sd-angular/core/api'), require('quill-mention'), require('@sd-angular/core/common'), require('@angular/common'), require('@sd-angular/core/translate'), require('@sd-angular/core/button'), require('@sd-angular/core/textarea')) :
|
|
3
|
-
typeof define === 'function' && define.amd ? define('@sd-angular/core/editor', ['exports', '@angular/core', 'ngx-quill', '@angular/forms', 'uuid', 'rxjs', '@sd-angular/core/api', 'quill-mention', '@sd-angular/core/common', '@angular/common', '@sd-angular/core/translate', '@sd-angular/core/button', '@sd-angular/core/textarea'], factory) :
|
|
4
|
-
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global['sd-angular'] = global['sd-angular'] || {}, global['sd-angular'].core = global['sd-angular'].core || {}, global['sd-angular'].core.editor = {}), global.ng.core, global['ngx-quill'], global.ng.forms, global.uuid, global.rxjs, global['sd-angular'].core.api, null, global['sd-angular'].core.common, global.ng.common, global['sd-angular'].core.translate, global['sd-angular'].core.button, global['sd-angular'].core.textarea));
|
|
5
|
-
}(this, (function (exports, core, ngxQuill, forms, uuid, rxjs, api, quillMention, common, common$1, translate, button, textarea) { 'use strict';
|
|
2
|
+
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('ngx-quill'), require('@angular/forms'), require('uuid'), require('rxjs'), require('@sd-angular/core/api'), require('quill-mention'), require('@sd-angular/core/common'), require('@sd-angular/core/loading'), require('@angular/common'), require('@sd-angular/core/translate'), require('@sd-angular/core/button'), require('@sd-angular/core/textarea')) :
|
|
3
|
+
typeof define === 'function' && define.amd ? define('@sd-angular/core/editor', ['exports', '@angular/core', 'ngx-quill', '@angular/forms', 'uuid', 'rxjs', '@sd-angular/core/api', 'quill-mention', '@sd-angular/core/common', '@sd-angular/core/loading', '@angular/common', '@sd-angular/core/translate', '@sd-angular/core/button', '@sd-angular/core/textarea'], factory) :
|
|
4
|
+
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global['sd-angular'] = global['sd-angular'] || {}, global['sd-angular'].core = global['sd-angular'].core || {}, global['sd-angular'].core.editor = {}), global.ng.core, global['ngx-quill'], global.ng.forms, global.uuid, global.rxjs, global['sd-angular'].core.api, null, global['sd-angular'].core.common, global['sd-angular'].core.loading, global.ng.common, global['sd-angular'].core.translate, global['sd-angular'].core.button, global['sd-angular'].core.textarea));
|
|
5
|
+
}(this, (function (exports, core, ngxQuill, forms, uuid, rxjs, api, quillMention, common, loading, common$1, translate, button, textarea) { 'use strict';
|
|
6
|
+
|
|
7
|
+
var EDITOR_CONFIG = new core.InjectionToken('editor.configuration');
|
|
6
8
|
|
|
7
9
|
/*! *****************************************************************************
|
|
8
10
|
Copyright (c) Microsoft Corporation.
|
|
@@ -427,13 +429,15 @@
|
|
|
427
429
|
}
|
|
428
430
|
};
|
|
429
431
|
|
|
430
|
-
var _name, _subscription, _model, _form, _updateValidator, _uploadImage;
|
|
432
|
+
var _name, _subscription, _model, _form, _updateValidator, _initUploadImage, _uploadImage, _uploadFile;
|
|
431
433
|
var SdEditor = /** @class */ (function () {
|
|
432
|
-
function SdEditor(ngZone, ref, sdApiService) {
|
|
434
|
+
function SdEditor(ngZone, ref, sdApiService, loadingService, configuration) {
|
|
433
435
|
var _this = this;
|
|
434
436
|
this.ngZone = ngZone;
|
|
435
437
|
this.ref = ref;
|
|
436
438
|
this.sdApiService = sdApiService;
|
|
439
|
+
this.loadingService = loadingService;
|
|
440
|
+
this.configuration = configuration;
|
|
437
441
|
_name.set(this, "N" + uuid.v4());
|
|
438
442
|
this.id = "I" + uuid.v4();
|
|
439
443
|
_subscription.set(this, new rxjs.Subscription());
|
|
@@ -510,8 +514,37 @@
|
|
|
510
514
|
}
|
|
511
515
|
}
|
|
512
516
|
};
|
|
513
|
-
this.
|
|
517
|
+
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>';
|
|
514
518
|
this.sdChange = new core.EventEmitter();
|
|
519
|
+
this.timerLoadQuillToolbar = null;
|
|
520
|
+
this.customFileHandler = function (e) {
|
|
521
|
+
var customButton = e.currentTarget;
|
|
522
|
+
var quillToolbar = customButton.closest('.ql-formats').closest('.ql-toolbar');
|
|
523
|
+
var quillBox = quillToolbar.closest('.ql-formats');
|
|
524
|
+
var fileInput = quillToolbar.querySelector('input.ql-customFile[type=file]');
|
|
525
|
+
if (fileInput == null) {
|
|
526
|
+
fileInput = document.createElement('input');
|
|
527
|
+
fileInput.setAttribute('type', Constants.FILE);
|
|
528
|
+
fileInput.setAttribute('accept', '*');
|
|
529
|
+
fileInput.classList.add('ql-customFile');
|
|
530
|
+
fileInput.addEventListener('change', function () {
|
|
531
|
+
var files = fileInput.files;
|
|
532
|
+
if (!files || !files.length) {
|
|
533
|
+
return;
|
|
534
|
+
}
|
|
535
|
+
var formData = new FormData();
|
|
536
|
+
formData.append(Constants.FILE, files[0]);
|
|
537
|
+
var range = localStorage.getItem('quillRange');
|
|
538
|
+
if (range) {
|
|
539
|
+
range = JSON.parse(range);
|
|
540
|
+
}
|
|
541
|
+
_this.quillEvent.enable(false);
|
|
542
|
+
__classPrivateFieldGet(_this, _uploadFile).call(_this, formData, _this.quillEvent, range, fileInput, quillToolbar.closest('quill-editor').id);
|
|
543
|
+
});
|
|
544
|
+
quillToolbar.appendChild(fileInput);
|
|
545
|
+
}
|
|
546
|
+
fileInput.click();
|
|
547
|
+
};
|
|
515
548
|
_updateValidator.set(this, function () {
|
|
516
549
|
_this.formControl.clearValidators();
|
|
517
550
|
_this.formControl.clearAsyncValidators();
|
|
@@ -568,14 +601,6 @@
|
|
|
568
601
|
var formData = new FormData();
|
|
569
602
|
formData.append(Constants.FILE, files[0]);
|
|
570
603
|
_this.quill.enable(false);
|
|
571
|
-
/*this.apiService.post(this.domain + this.urlUploadImage, formData).subscribe((resp: any) => {
|
|
572
|
-
this.quill.enable(true);
|
|
573
|
-
this.quill.editor.insertEmbed(range.index, 'image', resp.data.imageUrl || resp.data.publish_url || resp.url);
|
|
574
|
-
const content = this.quill.getContents();
|
|
575
|
-
this.quill.setContents(content);
|
|
576
|
-
this.quill.setSelection(range.index + 1, 'silent');
|
|
577
|
-
fileInput.value = '';
|
|
578
|
-
});*/
|
|
579
604
|
__classPrivateFieldGet(self, _uploadImage).call(self, formData, quill, range, fileInput);
|
|
580
605
|
});
|
|
581
606
|
this.container.appendChild(fileInput);
|
|
@@ -585,6 +610,34 @@
|
|
|
585
610
|
});
|
|
586
611
|
_this.ref.markForCheck();
|
|
587
612
|
};
|
|
613
|
+
_initUploadImage.set(this, function (quill) {
|
|
614
|
+
var self = _this;
|
|
615
|
+
_this.ngZone.runOutsideAngular(function () {
|
|
616
|
+
quill.getModule('toolbar').addHandler('image', function () {
|
|
617
|
+
var _this = this;
|
|
618
|
+
var fileInput = this.container.querySelector('input.ql-image[type=file]');
|
|
619
|
+
if (fileInput == null) {
|
|
620
|
+
fileInput = document.createElement('input');
|
|
621
|
+
fileInput.setAttribute('type', Constants.FILE);
|
|
622
|
+
fileInput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon');
|
|
623
|
+
fileInput.classList.add('ql-image');
|
|
624
|
+
fileInput.addEventListener('change', function () {
|
|
625
|
+
var files = fileInput.files;
|
|
626
|
+
var range = _this.quill.getSelection(true);
|
|
627
|
+
if (!files || !files.length) {
|
|
628
|
+
return;
|
|
629
|
+
}
|
|
630
|
+
var formData = new FormData();
|
|
631
|
+
formData.append(Constants.FILE, files[0]);
|
|
632
|
+
_this.quill.enable(false);
|
|
633
|
+
__classPrivateFieldGet(self, _uploadImage).call(self, formData, quill, range, fileInput);
|
|
634
|
+
});
|
|
635
|
+
this.container.appendChild(fileInput);
|
|
636
|
+
}
|
|
637
|
+
fileInput.click();
|
|
638
|
+
});
|
|
639
|
+
});
|
|
640
|
+
});
|
|
588
641
|
this.onModelChange = function (val) {
|
|
589
642
|
_this.formControl.setValue(val);
|
|
590
643
|
_this.modelHTML = val;
|
|
@@ -615,6 +668,31 @@
|
|
|
615
668
|
});
|
|
616
669
|
_this.ref.markForCheck();
|
|
617
670
|
});
|
|
671
|
+
_uploadFile.set(this, function (formData, quill, range, fileInput, loadingID) {
|
|
672
|
+
if (!_this.urlUploadFile) {
|
|
673
|
+
_this.urlUploadFile = '/partner/v2/merchandise/file/uploaduserfile';
|
|
674
|
+
}
|
|
675
|
+
// this.domain = 'https://api-commerce-qc.vinid.dev';
|
|
676
|
+
_this.loadingService.start('#box-' + loadingID);
|
|
677
|
+
_this.sdApiService.post(_this.urlUploadFile, formData).then(function (resp) {
|
|
678
|
+
_this.ngZone.runOutsideAngular(function () {
|
|
679
|
+
var _a, _b, _c, _d;
|
|
680
|
+
quill.enable(true);
|
|
681
|
+
// quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');
|
|
682
|
+
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) || '')
|
|
683
|
+
+ '">' + (((_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) || '') + '</a>', 'user');
|
|
684
|
+
// quill.insertText();
|
|
685
|
+
var content = quill.getContents();
|
|
686
|
+
quill.setContents(content);
|
|
687
|
+
quill.setSelection(range.index + 1, 'user');
|
|
688
|
+
fileInput.value = '';
|
|
689
|
+
});
|
|
690
|
+
_this.loadingService.stop('#box-' + loadingID);
|
|
691
|
+
}).catch(function (er) {
|
|
692
|
+
_this.loadingService.stop('#box-' + loadingID);
|
|
693
|
+
});
|
|
694
|
+
_this.ref.markForCheck();
|
|
695
|
+
});
|
|
618
696
|
}
|
|
619
697
|
Object.defineProperty(SdEditor.prototype, "model", {
|
|
620
698
|
set: function (val) {
|
|
@@ -680,11 +758,24 @@
|
|
|
680
758
|
configurable: true
|
|
681
759
|
});
|
|
682
760
|
SdEditor.prototype.ngOnInit = function () {
|
|
761
|
+
var _this = this;
|
|
683
762
|
var _a;
|
|
684
763
|
(_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.addControl(__classPrivateFieldGet(this, _name), this.formControl);
|
|
685
764
|
if (this.toolbar) {
|
|
686
765
|
this.quillConfig.toolbar.container = this.toolbar;
|
|
687
|
-
|
|
766
|
+
}
|
|
767
|
+
if (this.quillConfig.toolbar.container.toString().includes('customFile')) {
|
|
768
|
+
this.timerLoadQuillToolbar = setInterval(function () {
|
|
769
|
+
if (document.querySelector('button.ql-customFile')) {
|
|
770
|
+
clearInterval(_this.timerLoadQuillToolbar);
|
|
771
|
+
document.querySelector('button.ql-customFile').innerHTML = _this.customButtonFileSVG;
|
|
772
|
+
var customButton = document.querySelector('button.ql-customFile');
|
|
773
|
+
if (customButton.getAttribute('listener') !== '1') {
|
|
774
|
+
customButton.setAttribute('listener', '1');
|
|
775
|
+
customButton.addEventListener('click', _this.customFileHandler);
|
|
776
|
+
}
|
|
777
|
+
}
|
|
778
|
+
}, 1000);
|
|
688
779
|
}
|
|
689
780
|
this.ref.markForCheck();
|
|
690
781
|
};
|
|
@@ -700,21 +791,33 @@
|
|
|
700
791
|
(_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.removeControl(__classPrivateFieldGet(this, _name));
|
|
701
792
|
__classPrivateFieldGet(this, _subscription).unsubscribe();
|
|
702
793
|
};
|
|
794
|
+
SdEditor.prototype.onSelectionChanged = function (e) {
|
|
795
|
+
// localStorage.setItem('quillRange', e.range ? JSON.stringify(e.range) : (e.oldRange ? JSON.stringify(e.oldRange) : null));
|
|
796
|
+
localStorage.setItem('quillRange', e.editor.getSelection() ? JSON.stringify(e.editor.getSelection()) : null);
|
|
797
|
+
};
|
|
798
|
+
SdEditor.prototype.onContentChanged = function (e) {
|
|
799
|
+
localStorage.setItem('quillRange', JSON.stringify({
|
|
800
|
+
index: (e.editor.getLength() ? e.editor.getLength() - 1 : 0),
|
|
801
|
+
length: 0
|
|
802
|
+
}));
|
|
803
|
+
};
|
|
703
804
|
return SdEditor;
|
|
704
805
|
}());
|
|
705
|
-
_name = new WeakMap(), _subscription = new WeakMap(), _model = new WeakMap(), _form = new WeakMap(), _updateValidator = new WeakMap(), _uploadImage = new WeakMap();
|
|
806
|
+
_name = new WeakMap(), _subscription = new WeakMap(), _model = new WeakMap(), _form = new WeakMap(), _updateValidator = new WeakMap(), _initUploadImage = new WeakMap(), _uploadImage = new WeakMap(), _uploadFile = new WeakMap();
|
|
706
807
|
SdEditor.decorators = [
|
|
707
808
|
{ type: core.Component, args: [{
|
|
708
809
|
selector: 'sd-editor',
|
|
709
|
-
template: "<label *ngIf=\"label && !sdLabelDef?.templateRef\" class=\"d-block T14M\">{{label}} <span class=\"text-danger mb-2\"
|
|
810
|
+
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",
|
|
710
811
|
changeDetection: core.ChangeDetectionStrategy.OnPush,
|
|
711
|
-
styles: ["::ng-deep img[alt=c-image-editor-quill]{max-width:80%}"]
|
|
812
|
+
styles: ["::ng-deep img[alt=c-image-editor-quill]{max-width:80%}::ng-deep .ql-toolbar input.ql-customFile[type=file]{display:none}"]
|
|
712
813
|
},] }
|
|
713
814
|
];
|
|
714
815
|
SdEditor.ctorParameters = function () { return [
|
|
715
816
|
{ type: core.NgZone },
|
|
716
817
|
{ type: core.ChangeDetectorRef },
|
|
717
|
-
{ type: api.SdApiService }
|
|
818
|
+
{ type: api.SdApiService },
|
|
819
|
+
{ type: loading.SdLoadingService },
|
|
820
|
+
{ type: undefined, decorators: [{ type: core.Inject, args: [EDITOR_CONFIG,] }, { type: core.Optional }] }
|
|
718
821
|
]; };
|
|
719
822
|
SdEditor.propDecorators = {
|
|
720
823
|
editor: [{ type: core.ViewChild, args: ['editor',] }],
|
|
@@ -727,8 +830,10 @@
|
|
|
727
830
|
modelChange: [{ type: core.Output }],
|
|
728
831
|
placeholder: [{ type: core.Input }],
|
|
729
832
|
styles: [{ type: core.Input }],
|
|
833
|
+
args: [{ type: core.Input }],
|
|
730
834
|
domain: [{ type: core.Input }],
|
|
731
835
|
urlUploadImage: [{ type: core.Input }],
|
|
836
|
+
urlUploadFile: [{ type: core.Input }],
|
|
732
837
|
form: [{ type: core.Input }],
|
|
733
838
|
toolbar: [{ type: core.Input }],
|
|
734
839
|
enableHTMLButton: [{ type: core.Input }],
|
|
@@ -770,6 +875,7 @@
|
|
|
770
875
|
*/
|
|
771
876
|
|
|
772
877
|
exports.Constants = Constants;
|
|
878
|
+
exports.EDITOR_CONFIG = EDITOR_CONFIG;
|
|
773
879
|
exports.PROMOTION_FORM = PROMOTION_FORM;
|
|
774
880
|
exports.PROMOTION_PERMISSIONS = PROMOTION_PERMISSIONS;
|
|
775
881
|
exports.SdEditor = SdEditor;
|