ngx-firebase-cms
Version:
Angular Content Management System using Google Firebase (Authentication, Storage & Firestore)
207 lines • 15.2 kB
JavaScript
/**
* @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;
}
export class EditorService {
/**
* @param {?} http
* @param {?} _document
*/
constructor(http, _document) {
this.http = http;
this._document = _document;
}
/**
* @param {?} command
* @return {?}
*/
executeCommand(command) {
/** @type {?} */
const 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 {?}
*/
createLink(url) {
if (!url.includes("http")) {
this._document.execCommand('createlink', false, url);
}
else {
/** @type {?} */
const newUrl = '<a href="' + url + '" target="_blank">' + this.selectedText + '</a>';
this.insertHtml(newUrl);
}
}
/**
* @param {?} color
* @param {?} where
* @return {?}
*/
insertColor(color, where) {
/** @type {?} */
const restored = this.restoreSelection();
if (restored) {
if (where === 'textColor') {
this._document.execCommand('foreColor', false, color);
}
else {
this._document.execCommand('hiliteColor', false, color);
}
}
}
/**
* @param {?} fontName
* @return {?}
*/
setFontName(fontName) {
this._document.execCommand("fontName", false, fontName);
}
/**
* @param {?} fontSize
* @return {?}
*/
setFontSize(fontSize) {
this._document.execCommand("fontSize", false, fontSize);
}
/**
* Create raw HTML
* @private
* @param {?} html HTML string
* @return {?}
*/
insertHtml(html) {
/** @type {?} */
const isHTMLInserted = this._document.execCommand('insertHTML', false, html);
if (!isHTMLInserted) {
throw new Error('Unable to perform the operation');
}
}
/**
* @return {?}
*/
saveSelection() {
if (window.getSelection) {
/** @type {?} */
const 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 {?}
*/
restoreSelection() {
if (this.savedSelection) {
if (window.getSelection) {
/** @type {?} */
const sel = window.getSelection();
sel.removeAllRanges();
sel.addRange(this.savedSelection);
return true;
}
else if (this._document.getSelection) {
return true;
}
}
else {
return false;
}
}
/**
* @private
* @return {?}
*/
checkSelection() {
/** @type {?} */
const slectedText = this.savedSelection.toString();
if (slectedText.length === 0) {
throw new Error('No Selection Made');
}
return true;
}
/**
* @param {?} imageUrl
* @return {?}
*/
insertImage(imageUrl) {
this._document.execCommand('insertImage', false, imageUrl);
}
/**
* @param {?} separator
* @return {?}
*/
setDefaultParagraphSeparator(separator) {
this._document.execCommand("defaultParagraphSeparator", false, separator);
}
/**
* @param {?} customClass
* @return {?}
*/
createCustomClass(customClass) {
/** @type {?} */
let newTag = this.selectedText;
if (customClass) {
/** @type {?} */
const 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 = () => [
{ 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" });
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"]}