UNPKG

ngx-firebase-cms

Version:

Angular Content Management System using Google Firebase (Authentication, Storage & Firestore)

258 lines 16.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Injectable, Inject } from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { DOCUMENT } from "@angular/common"; import * as i0 from "@angular/core"; import * as i1 from "@angular/common/http"; import * as i2 from "@angular/common"; /** * @record */ export function UploadResponse() { } if (false) { /** @type {?} */ UploadResponse.prototype.imageUrl; } var EditorService = /** @class */ (function () { function EditorService(http, _document) { this.http = http; this._document = _document; } /** * @param {?} command * @return {?} */ EditorService.prototype.executeCommand = /** * @param {?} command * @return {?} */ function (command) { /** @type {?} */ var commands = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'p', 'pre']; if (commands.includes(command)) { this._document.execCommand('formatBlock', false, command); } this._document.execCommand(command, false, null); }; /** * @param {?} url * @return {?} */ EditorService.prototype.createLink = /** * @param {?} url * @return {?} */ function (url) { if (!url.includes("http")) { this._document.execCommand('createlink', false, url); } else { /** @type {?} */ var newUrl = '<a href="' + url + '" target="_blank">' + this.selectedText + '</a>'; this.insertHtml(newUrl); } }; /** * @param {?} color * @param {?} where * @return {?} */ EditorService.prototype.insertColor = /** * @param {?} color * @param {?} where * @return {?} */ function (color, where) { /** @type {?} */ var restored = this.restoreSelection(); if (restored) { if (where === 'textColor') { this._document.execCommand('foreColor', false, color); } else { this._document.execCommand('hiliteColor', false, color); } } }; /** * @param {?} fontName * @return {?} */ EditorService.prototype.setFontName = /** * @param {?} fontName * @return {?} */ function (fontName) { this._document.execCommand("fontName", false, fontName); }; /** * @param {?} fontSize * @return {?} */ EditorService.prototype.setFontSize = /** * @param {?} fontSize * @return {?} */ function (fontSize) { this._document.execCommand("fontSize", false, fontSize); }; /** * Create raw HTML * @param html HTML string */ /** * Create raw HTML * @private * @param {?} html HTML string * @return {?} */ EditorService.prototype.insertHtml = /** * Create raw HTML * @private * @param {?} html HTML string * @return {?} */ function (html) { /** @type {?} */ var isHTMLInserted = this._document.execCommand('insertHTML', false, html); if (!isHTMLInserted) { throw new Error('Unable to perform the operation'); } }; /** * @return {?} */ EditorService.prototype.saveSelection = /** * @return {?} */ function () { if (window.getSelection) { /** @type {?} */ var sel = window.getSelection(); if (sel.getRangeAt && sel.rangeCount) { this.savedSelection = sel.getRangeAt(0); this.selectedText = sel.toString(); } } else if (this._document.getSelection && this._document.createRange) { this.savedSelection = document.createRange(); } else { this.savedSelection = null; } }; /** * @return {?} */ EditorService.prototype.restoreSelection = /** * @return {?} */ function () { if (this.savedSelection) { if (window.getSelection) { /** @type {?} */ var sel = window.getSelection(); sel.removeAllRanges(); sel.addRange(this.savedSelection); return true; } else if (this._document.getSelection) { return true; } } else { return false; } }; /** * @private * @return {?} */ EditorService.prototype.checkSelection = /** * @private * @return {?} */ function () { /** @type {?} */ var slectedText = this.savedSelection.toString(); if (slectedText.length === 0) { throw new Error('No Selection Made'); } return true; }; /** * @param {?} imageUrl * @return {?} */ EditorService.prototype.insertImage = /** * @param {?} imageUrl * @return {?} */ function (imageUrl) { this._document.execCommand('insertImage', false, imageUrl); }; /** * @param {?} separator * @return {?} */ EditorService.prototype.setDefaultParagraphSeparator = /** * @param {?} separator * @return {?} */ function (separator) { this._document.execCommand("defaultParagraphSeparator", false, separator); }; /** * @param {?} customClass * @return {?} */ EditorService.prototype.createCustomClass = /** * @param {?} customClass * @return {?} */ function (customClass) { /** @type {?} */ var newTag = this.selectedText; if (customClass) { /** @type {?} */ var tagName = customClass.tag ? customClass.tag : 'span'; newTag = '<' + tagName + ' class="' + customClass.class + '">' + this.selectedText + '</' + tagName + '>'; } this.insertHtml(newTag); }; EditorService.decorators = [ { type: Injectable, args: [{ providedIn: 'root' },] } ]; /** @nocollapse */ EditorService.ctorParameters = function () { return [ { type: HttpClient }, { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] } ]; }; /** @nocollapse */ EditorService.ngInjectableDef = i0.defineInjectable({ factory: function EditorService_Factory() { return new EditorService(i0.inject(i1.HttpClient), i0.inject(i2.DOCUMENT)); }, token: EditorService, providedIn: "root" }); return EditorService; }()); export { EditorService }; if (false) { /** @type {?} */ EditorService.prototype.savedSelection; /** @type {?} */ EditorService.prototype.selectedText; /** @type {?} */ EditorService.prototype.uploadUrl; /** * @type {?} * @private */ EditorService.prototype.http; /** * @type {?} * @private */ EditorService.prototype._document; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.service.js","sourceRoot":"ng://ngx-firebase-cms/","sources":["lib/service/editor.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from '@angular/core';\nimport { CustomClass } from '../interface/editor';\nimport { HttpClient } from '@angular/common/http';\nimport {DOCUMENT} from \"@angular/common\";\n\nexport interface UploadResponse {\n  imageUrl: string;\n}\n\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class EditorService {\n\n  \n  savedSelection: Range | null;\n  selectedText: string;\n  uploadUrl: string;\n\n\n  constructor(\n    private http: HttpClient, \n    @Inject(DOCUMENT) private _document: any\n  ) {\n  }\n\n  executeCommand(command: string) {\n    const commands = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'p', 'pre'];\n    if (commands.includes(command)) {\n      this._document.execCommand('formatBlock', false, command);\n    }\n\n    this._document.execCommand(command, false, null);\n  }\n\n  createLink(url: string) {\n    if (!url.includes(\"http\")) {\n      this._document.execCommand('createlink', false, url);\n    } else {\n      const newUrl = '<a href=\"' + url + '\" target=\"_blank\">' + this.selectedText + '</a>';\n      this.insertHtml(newUrl);\n    }\n  }\n\n  insertColor(color: string, where: string): void {\n    const restored = this.restoreSelection();\n    if (restored) {\n      if (where === 'textColor') {\n        this._document.execCommand('foreColor', false, color);\n      } else {\n        this._document.execCommand('hiliteColor', false, color);\n      }\n    }\n  }\n\n  setFontName(fontName: string) {\n    this._document.execCommand(\"fontName\", false, fontName);\n  }\n\n  setFontSize(fontSize: string) {\n    this._document.execCommand(\"fontSize\", false, fontSize);\n  }\n\n  /**\n   * Create raw HTML\n   * @param html HTML string\n   */\n  private insertHtml(html: string): void {\n\n    const isHTMLInserted = this._document.execCommand('insertHTML', false, html);\n\n    if (!isHTMLInserted) {\n      throw new Error('Unable to perform the operation');\n    }\n  }\n\n  saveSelection(): any {\n    if (window.getSelection) {\n      const sel = window.getSelection();\n      if (sel.getRangeAt && sel.rangeCount) {\n        this.savedSelection = sel.getRangeAt(0);\n        this.selectedText = sel.toString();\n      }\n    } else if (this._document.getSelection && this._document.createRange) {\n      this.savedSelection = document.createRange();\n    } else {\n      this.savedSelection = null;\n    }\n  }\n\n  restoreSelection(): boolean {\n    if (this.savedSelection) {\n      if (window.getSelection) {\n        const sel = window.getSelection();\n        sel.removeAllRanges();\n        sel.addRange(this.savedSelection);\n        return true;\n      } else if (this._document.getSelection) {\n        return true;\n      }\n    } else {\n      return false;\n    }\n  }\n\n  private checkSelection(): any {\n\n    const slectedText = this.savedSelection.toString();\n\n    if (slectedText.length === 0) {\n      throw new Error('No Selection Made');\n    }\n\n    return true;\n  }\n\n  insertImage(imageUrl: string) {\n    this._document.execCommand('insertImage', false, imageUrl);\n  }\n\n  setDefaultParagraphSeparator(separator: string) {\n    this._document.execCommand(\"defaultParagraphSeparator\", false, separator);\n  }\n\n  createCustomClass(customClass: CustomClass) {\n    let newTag = this.selectedText;\n    if(customClass){\n      const tagName = customClass.tag ? customClass.tag : 'span';\n      newTag = '<' + tagName + ' class=\"' + customClass.class + '\">' + this.selectedText + '</' + tagName + '>';\n    }\n    \n    this.insertHtml(newTag);\n  }\n}\n"]}