From d93e92d61068d469d82413f90ef1b5c9297177f8 Mon Sep 17 00:00:00 2001 From: volodymyro Date: Sat, 18 Nov 2017 18:05:08 +0200 Subject: [PATCH 01/18] - pre compile step is disabled (temporary) Refactoring: - Generate ngx-toolbar-component - Move toolbar code into the ngx-toolbar-component --- package.json | 3 +- src/app/ngx-editor/ngx-editor.component.html | 119 +----------------- src/app/ngx-editor/ngx-editor.component.scss | 50 +------- src/app/ngx-editor/ngx-editor.component.ts | 8 -- src/app/ngx-editor/ngx-editor.module.ts | 3 +- .../{ => ngx-toolbar}/ngx-editor.utils.ts | 0 .../ngx-toolbar/ngx-toolbar.component.html | 115 +++++++++++++++++ .../ngx-toolbar/ngx-toolbar.component.scss | 47 +++++++ .../ngx-toolbar/ngx-toolbar.component.ts | 23 ++++ 9 files changed, 192 insertions(+), 176 deletions(-) rename src/app/ngx-editor/{ => ngx-toolbar}/ngx-editor.utils.ts (100%) create mode 100644 src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html create mode 100644 src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.scss create mode 100644 src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts diff --git a/package.json b/package.json index d4199dcf..1ee5a33b 100644 --- a/package.json +++ b/package.json @@ -13,7 +13,6 @@ "build": "ng build --prod", "build:package": "ng build --prod && sh scripts/build.sh", "test:single-run": "ng test --watch false", - "precommit": "ng test --watch false && yarn run build:package", "cz": "git-cz", "release": "sh scripts/release.sh" }, @@ -79,4 +78,4 @@ "path": "node_modules/cz-conventional-changelog" } } -} \ No newline at end of file +} diff --git a/src/app/ngx-editor/ngx-editor.component.html b/src/app/ngx-editor/ngx-editor.component.html index 1f9a743a..e18deb92 100644 --- a/src/app/ngx-editor/ngx-editor.component.html +++ b/src/app/ngx-editor/ngx-editor.component.html @@ -1,121 +1,6 @@
- -
-
- - - - - - -
-
- - - - - - -
-
- - - - - - -
-
- - - - - - -
-
- - - -
-
- +
-
\ No newline at end of file +
diff --git a/src/app/ngx-editor/ngx-editor.component.scss b/src/app/ngx-editor/ngx-editor.component.scss index 81164e98..58a7c867 100644 --- a/src/app/ngx-editor/ngx-editor.component.scss +++ b/src/app/ngx-editor/ngx-editor.component.scss @@ -8,53 +8,7 @@ content: attr(placeholder); display: block; // for firefox } - .ngx-toolbar { - background-color: #f5f5f5; - border-bottom: 1px solid #ddd; - font-size: 0.8rem; - padding: 0.2rem; - border: 1px solid #ddd; - .ngx-toolbar-set { - display: inline-block; - border: 1px solid #ddd; - border-radius: 5px; - background-color: white; - .ngx-editor-button { - background-color: #f5f5f5; - background-color: transparent; - border: 0; - padding: 0.4rem; - min-width: 2.5rem; - float: left; - border-right: 1px solid #ddd; - &:hover { - cursor: pointer; - background-color: #f1f1f1; - transition: 0.2s ease; - } - &:focus, - &.focus { - outline: 0; - } - &:last-child { - border-right: transparent; - } - &:first-child { - border-top-left-radius: 5px; - border-bottom-left-radius: 5px; - } - &:last-child { - border-top-right-radius: 5px; - border-bottom-right-radius: 5px; - } - &:disabled { - background-color: #f5f5f5; - pointer-events: none; - cursor: not-allowed; - } - } - } - } + .ngx-editor-textarea { min-height: 5rem; padding: 0.5rem 0.8rem 1rem 0.8rem; @@ -81,4 +35,4 @@ padding-bottom: 0.1rem; transition: 0.5s ease-in; } -} \ No newline at end of file +} diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index fe6fcf84..46914820 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -1,6 +1,5 @@ import { Component, OnInit, HostListener, Input, Output, ElementRef, EventEmitter, ViewChild } from '@angular/core'; import { ngxEditorConfig } from './ngx-editor.defaults'; -import * as Utils from './ngx-editor.utils'; @Component({ selector: 'app-ngx-editor', @@ -163,13 +162,6 @@ export class NgxEditorComponent implements OnInit { } } - /* - * enable or diable toolbar based on configuration - */ - canEnableToolbarOptions(value) { - return Utils.canEnableToolbarOptions(value, this.config['toolbar']); - } - /* * resizing text area */ diff --git a/src/app/ngx-editor/ngx-editor.module.ts b/src/app/ngx-editor/ngx-editor.module.ts index fa317b27..230989c0 100644 --- a/src/app/ngx-editor/ngx-editor.module.ts +++ b/src/app/ngx-editor/ngx-editor.module.ts @@ -2,12 +2,13 @@ import { NgModule } from '@angular/core'; import { CommonModule } from '@angular/common'; import { NgxEditorComponent } from './ngx-editor.component'; import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; +import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; @NgModule({ imports: [ CommonModule ], - declarations: [NgxEditorComponent, NgxGrippieComponent], + declarations: [NgxEditorComponent, NgxGrippieComponent, NgxToolbarComponent], exports: [NgxEditorComponent, NgxGrippieComponent] }) diff --git a/src/app/ngx-editor/ngx-editor.utils.ts b/src/app/ngx-editor/ngx-toolbar/ngx-editor.utils.ts similarity index 100% rename from src/app/ngx-editor/ngx-editor.utils.ts rename to src/app/ngx-editor/ngx-toolbar/ngx-editor.utils.ts diff --git a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html new file mode 100644 index 00000000..e9ee77f4 --- /dev/null +++ b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html @@ -0,0 +1,115 @@ + +
+
+ + + + + + +
+
+ + + + + + +
+
+ + + + + + +
+
+ + + + + + +
+
+ + + +
+
diff --git a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.scss b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.scss new file mode 100644 index 00000000..44e5625f --- /dev/null +++ b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.scss @@ -0,0 +1,47 @@ +.ngx-toolbar { + background-color: #f5f5f5; + border-bottom: 1px solid #ddd; + font-size: 0.8rem; + padding: 0.2rem; + border: 1px solid #ddd; + .ngx-toolbar-set { + display: inline-block; + border: 1px solid #ddd; + border-radius: 5px; + background-color: white; + .ngx-editor-button { + background-color: #f5f5f5; + background-color: transparent; + border: 0; + padding: 0.4rem; + min-width: 2.5rem; + float: left; + border-right: 1px solid #ddd; + &:hover { + cursor: pointer; + background-color: #f1f1f1; + transition: 0.2s ease; + } + &:focus, + &.focus { + outline: 0; + } + &:last-child { + border-right: transparent; + } + &:first-child { + border-top-left-radius: 5px; + border-bottom-left-radius: 5px; + } + &:last-child { + border-top-right-radius: 5px; + border-bottom-right-radius: 5px; + } + &:disabled { + background-color: #f5f5f5; + pointer-events: none; + cursor: not-allowed; + } + } + } +} diff --git a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts new file mode 100644 index 00000000..65ad0a1a --- /dev/null +++ b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts @@ -0,0 +1,23 @@ +import {Component, Input} from '@angular/core'; +import * as Utils from './ngx-editor.utils'; + +@Component({ + selector: 'app-ngx-toolbar', + templateUrl: './ngx-toolbar.component.html', + styleUrls: ['./ngx-toolbar.component.scss'] +}) +export class NgxToolbarComponent { + + @Input() config: any; + @Input() enableToolbar = false; + + constructor() { + } + + /* + * enable or diable toolbar based on configuration + */ + canEnableToolbarOptions(value) { + return Utils.canEnableToolbarOptions(value, this.config['toolbar']); + } +} From e33dd7ee663f61e811da3e5b5e4b8d8f200a1edc Mon Sep 17 00:00:00 2001 From: volodymyro Date: Sat, 18 Nov 2017 18:10:40 +0200 Subject: [PATCH 02/18] Refactoring: - Generate ngx-editor-message - Move message code into the ngx-editor-message --- .../ngx-editor-message.component.html | 3 +++ .../ngx-editor-message.component.scss | 9 +++++++ .../ngx-editor-message.component.spec.ts | 25 +++++++++++++++++++ .../ngx-editor-message.component.ts | 17 +++++++++++++ src/app/ngx-editor/ngx-editor.component.html | 5 +--- src/app/ngx-editor/ngx-editor.component.scss | 9 ------- src/app/ngx-editor/ngx-editor.module.ts | 3 ++- 7 files changed, 57 insertions(+), 14 deletions(-) create mode 100644 src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.html create mode 100644 src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.scss create mode 100644 src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts create mode 100644 src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.html b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.html new file mode 100644 index 00000000..68e2e555 --- /dev/null +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.html @@ -0,0 +1,3 @@ +
+ {{ngxMessage}} +
diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.scss b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.scss new file mode 100644 index 00000000..a8d05e6b --- /dev/null +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.scss @@ -0,0 +1,9 @@ +.ngx-editor-message { + font-size: 80%; + background-color: #f1f1f1; + border: 1px solid #ddd; + border-top: transparent; + padding: 0 0.5rem; + padding-bottom: 0.1rem; + transition: 0.5s ease-in; +} diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts new file mode 100644 index 00000000..0b369836 --- /dev/null +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { NgxEditorMessageComponent } from './ngx-editor-message.component'; + +describe('NgxEditorMessageComponent', () => { + let component: NgxEditorMessageComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ NgxEditorMessageComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(NgxEditorMessageComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts new file mode 100644 index 00000000..24426fb1 --- /dev/null +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts @@ -0,0 +1,17 @@ +import {Component, Input, OnInit} from '@angular/core'; + +@Component({ + selector: 'app-ngx-editor-message', + templateUrl: './ngx-editor-message.component.html', + styleUrls: ['./ngx-editor-message.component.scss'] +}) +export class NgxEditorMessageComponent implements OnInit { + + @Input() ngxMessage = ''; + + constructor() { } + + ngOnInit() { + } + +} diff --git a/src/app/ngx-editor/ngx-editor.component.html b/src/app/ngx-editor/ngx-editor.component.html index e18deb92..46f60f66 100644 --- a/src/app/ngx-editor/ngx-editor.component.html +++ b/src/app/ngx-editor/ngx-editor.component.html @@ -7,9 +7,6 @@ [style.resize]="canResize()" (focus)="onFocus()" #ngxTextArea> -
- {{ngxMessage}} -
- + diff --git a/src/app/ngx-editor/ngx-editor.component.scss b/src/app/ngx-editor/ngx-editor.component.scss index 58a7c867..39f82a29 100644 --- a/src/app/ngx-editor/ngx-editor.component.scss +++ b/src/app/ngx-editor/ngx-editor.component.scss @@ -26,13 +26,4 @@ padding-left: 0.5rem; } } - .ngx-editor-message { - font-size: 80%; - background-color: #f1f1f1; - border: 1px solid #ddd; - border-top: transparent; - padding: 0 0.5rem; - padding-bottom: 0.1rem; - transition: 0.5s ease-in; - } } diff --git a/src/app/ngx-editor/ngx-editor.module.ts b/src/app/ngx-editor/ngx-editor.module.ts index 230989c0..341a1d83 100644 --- a/src/app/ngx-editor/ngx-editor.module.ts +++ b/src/app/ngx-editor/ngx-editor.module.ts @@ -3,12 +3,13 @@ import { CommonModule } from '@angular/common'; import { NgxEditorComponent } from './ngx-editor.component'; import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; +import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; @NgModule({ imports: [ CommonModule ], - declarations: [NgxEditorComponent, NgxGrippieComponent, NgxToolbarComponent], + declarations: [NgxEditorComponent, NgxGrippieComponent, NgxToolbarComponent, NgxEditorMessageComponent], exports: [NgxEditorComponent, NgxGrippieComponent] }) From f480c2836903be3e896b374de063183e5e782f8c Mon Sep 17 00:00:00 2001 From: volodymyro Date: Sat, 18 Nov 2017 18:30:35 +0200 Subject: [PATCH 03/18] Generalize command execution method and extract it into the CommandExecutor class --- src/app/ngx-editor/command-executor.ts | 49 +++++++++++++++++ src/app/ngx-editor/ngx-editor.component.html | 2 +- src/app/ngx-editor/ngx-editor.component.ts | 46 ++-------------- .../ngx-toolbar/ngx-toolbar.component.html | 54 +++++++++---------- .../ngx-toolbar/ngx-toolbar.component.ts | 7 ++- 5 files changed, 86 insertions(+), 72 deletions(-) create mode 100644 src/app/ngx-editor/command-executor.ts diff --git a/src/app/ngx-editor/command-executor.ts b/src/app/ngx-editor/command-executor.ts new file mode 100644 index 00000000..f146ff28 --- /dev/null +++ b/src/app/ngx-editor/command-executor.ts @@ -0,0 +1,49 @@ +export class CommandExecutor { + constructor(private document) {} + + public execute(command: string): void { + if (command === 'removeBlockquote') { + this.document.execCommand('formatBlock', false, 'div'); + } else if (command === 'blockquote') { + this.document.execCommand('formatBlock', false, '
'); + } else if (command === 'link') { + this.createLink(); + } else if (command === 'image') { + this.insertImage(); + } else { + this.document.execCommand(command, false, null); + } + } + + // insert image + insertImage() { + const imageURI = prompt('Enter Image URL', 'http://'); + if (imageURI) { + const inserted = this.document.execCommand('insertImage', false, imageURI); + if (!inserted) { + //this.createMessage('Invalid URL'); + } + } + } + + // insert link + createLink() { + const selection = document.getSelection(); + + if (selection.anchorNode.parentElement.tagName === 'A') { + const linkURL = prompt('Enter URL', selection.anchorNode.parentElement.getAttribute('href')); + if (linkURL) { + this.document.execCommand('createLink', false, linkURL); + } + } else { + if (selection['type'] === 'None') { + //this.createMessage('No selection made'); + } else { + const linkURL = prompt('Enter URL', 'http://'); + if (linkURL) { + document.execCommand('createLink', false, linkURL); + } + } + } + } +} diff --git a/src/app/ngx-editor/ngx-editor.component.html b/src/app/ngx-editor/ngx-editor.component.html index 46f60f66..cb67109f 100644 --- a/src/app/ngx-editor/ngx-editor.component.html +++ b/src/app/ngx-editor/ngx-editor.component.html @@ -1,6 +1,6 @@
- +
'); - } - - removeQuote() { - document.execCommand('formatBlock', false, 'div'); - } - - // insert link - createLink() { - const selection = document.getSelection(); - - if (selection.anchorNode.parentElement.tagName === 'A') { - const linkURL = prompt('Enter URL', selection.anchorNode.parentElement.getAttribute('href')); - if (linkURL) { - document.execCommand('createLink', false, linkURL); - } - } else { - if (selection['type'] === 'None') { - this.createMessage('No selection made'); - } else { - const linkURL = prompt('Enter URL', 'http://'); - if (linkURL) { - document.execCommand('createLink', false, linkURL); - } - } - } - } - - // insert image - insertImage() { - const imageURI = prompt('Enter Image URL', 'http://'); - if (imageURI) { - const inserted = document.execCommand('insertImage', false, imageURI); - if (!inserted) { - this.createMessage('Invalid URL'); - } - } - } - /* * message box */ diff --git a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html index e9ee77f4..db9c6fa7 100644 --- a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html +++ b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html @@ -1,114 +1,114 @@
- - - - - -
- - - - - -
- - - - - -
- - - - - -
- - -
diff --git a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts index 65ad0a1a..933f1c5a 100644 --- a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts +++ b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts @@ -1,4 +1,4 @@ -import {Component, Input} from '@angular/core'; +import {Component, EventEmitter, Input, Output} from '@angular/core'; import * as Utils from './ngx-editor.utils'; @Component({ @@ -10,6 +10,7 @@ export class NgxToolbarComponent { @Input() config: any; @Input() enableToolbar = false; + @Output('triggerCommand') _triggerCommand = new EventEmitter(); constructor() { } @@ -20,4 +21,8 @@ export class NgxToolbarComponent { canEnableToolbarOptions(value) { return Utils.canEnableToolbarOptions(value, this.config['toolbar']); } + + triggerCommand(command: string): void { + this._triggerCommand.emit(command); + } } From 2599eddc3fd4d3dfcf805cfc7d527ca2756d2ebe Mon Sep 17 00:00:00 2001 From: volodymyro Date: Sat, 18 Nov 2017 19:02:25 +0200 Subject: [PATCH 04/18] Move enableObjectResizing into the command executor Provide messages exceptions handling --- src/app/ngx-editor/command-executor.ts | 42 ++++++++++++++-------- src/app/ngx-editor/ngx-editor.component.ts | 33 ++++++++++------- 2 files changed, 48 insertions(+), 27 deletions(-) diff --git a/src/app/ngx-editor/command-executor.ts b/src/app/ngx-editor/command-executor.ts index f146ff28..4579f309 100644 --- a/src/app/ngx-editor/command-executor.ts +++ b/src/app/ngx-editor/command-executor.ts @@ -1,43 +1,55 @@ export class CommandExecutor { - constructor(private document) {} - public execute(command: string): void { + if (command === 'enableObjectResizing') { + document.execCommand('enableObjectResizing', true, true); + return; + } + if (command === 'removeBlockquote') { - this.document.execCommand('formatBlock', false, 'div'); - } else if (command === 'blockquote') { - this.document.execCommand('formatBlock', false, '
'); - } else if (command === 'link') { + document.execCommand('formatBlock', false, 'div'); + return; + } + + if (command === 'blockquote') { + document.execCommand('formatBlock', false, '
'); + return; + } + + if (command === 'link') { this.createLink(); - } else if (command === 'image') { + return; + } + + if (command === 'image') { this.insertImage(); - } else { - this.document.execCommand(command, false, null); + return; } + + document.execCommand(command, false, null); } - // insert image insertImage() { const imageURI = prompt('Enter Image URL', 'http://'); if (imageURI) { - const inserted = this.document.execCommand('insertImage', false, imageURI); + const inserted = document.execCommand('insertImage', false, imageURI); + console.log('inserted', inserted) if (!inserted) { - //this.createMessage('Invalid URL'); + throw new Error('Invalid URL'); } } } - // insert link createLink() { const selection = document.getSelection(); if (selection.anchorNode.parentElement.tagName === 'A') { const linkURL = prompt('Enter URL', selection.anchorNode.parentElement.getAttribute('href')); if (linkURL) { - this.document.execCommand('createLink', false, linkURL); + document.execCommand('createLink', false, linkURL); } } else { if (selection['type'] === 'None') { - //this.createMessage('No selection made'); + throw new Error('No selection made'); } else { const linkURL = prompt('Enter URL', 'http://'); if (linkURL) { diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index ce186f96..4d5e0d2b 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -1,5 +1,5 @@ -import { Component, OnInit, HostListener, Input, Output, ElementRef, EventEmitter, ViewChild } from '@angular/core'; -import { ngxEditorConfig } from './ngx-editor.defaults'; +import {Component, OnInit, HostListener, Input, Output, ElementRef, EventEmitter, ViewChild} from '@angular/core'; +import {ngxEditorConfig} from './ngx-editor.defaults'; import {CommandExecutor} from './command-executor'; @Component({ @@ -19,7 +19,7 @@ export class NgxEditorComponent implements OnInit { _resizer: string; ngxMessage: string; enableToolbar = false; - commandExecutor = new CommandExecutor(document); + commandExecutor = new CommandExecutor(); @Input() editable: boolean; @Input() spellcheck: boolean; @@ -41,6 +41,7 @@ export class NgxEditorComponent implements OnInit { this._resizer = 'stack'; } } + get resizer(): string { return this._resizer || 'stack'; } @@ -61,6 +62,7 @@ export class NgxEditorComponent implements OnInit { } this._config = value; } + get config(): JSON { return this._config || ngxEditorConfig; } @@ -70,6 +72,7 @@ export class NgxEditorComponent implements OnInit { set html(value: any) { this._html = value; } + get html(): any { return this._html; } @@ -85,14 +88,9 @@ export class NgxEditorComponent implements OnInit { } } - constructor(private _element: ElementRef) { } - - /* - * editor actions - */ - executeCommand(commandName) { - this.commandExecutor.execute(commandName); + constructor(private _element: ElementRef) { } + /* * message box */ @@ -114,7 +112,8 @@ export class NgxEditorComponent implements OnInit { this.enableToolbar = true; } - @HostListener('document:click', ['$event']) onDocumentClick(event) { + @HostListener('document:click', ['$event']) + onDocumentClick(event) { if (this._element.nativeElement.contains(event.target)) { this.enableToolbar = true; } else { @@ -148,7 +147,17 @@ export class NgxEditorComponent implements OnInit { this.height = this.height || this.textArea.nativeElement.offsetHeight; - document.execCommand('enableObjectResizing', true, true); + this.executeCommand('enableObjectResizing'); } + /* + * editor actions + */ + executeCommand(commandName) { + try { + this.commandExecutor.execute(commandName); + } catch (error) { + this.ngxMessage = error && error.message; + } + } } From cc288dc4637ea8158483b9364626a715d002414b Mon Sep 17 00:00:00 2001 From: volodymyro Date: Sat, 18 Nov 2017 19:03:20 +0200 Subject: [PATCH 05/18] Simplify condition --- src/app/ngx-editor/ngx-editor.component.ts | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index 4d5e0d2b..b3f565cb 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -114,11 +114,7 @@ export class NgxEditorComponent implements OnInit { @HostListener('document:click', ['$event']) onDocumentClick(event) { - if (this._element.nativeElement.contains(event.target)) { - this.enableToolbar = true; - } else { - this.enableToolbar = false; - } + this.enableToolbar = !!this._element.nativeElement.contains(event.target); } /* From db63284dc826bada2dd7bab7e6a95064bccdaf95 Mon Sep 17 00:00:00 2001 From: volodymyro Date: Sun, 19 Nov 2017 18:26:34 +0200 Subject: [PATCH 06/18] Use createMessage method instead of directly set error message --- src/app/ngx-editor/ngx-editor.component.ts | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index b3f565cb..f678af5a 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -91,16 +91,6 @@ export class NgxEditorComponent implements OnInit { constructor(private _element: ElementRef) { } - /* - * message box - */ - createMessage(message) { - this.ngxMessage = message; - setTimeout(() => { - this.clearMessage(); - }, 5000); - } - clearMessage() { this.ngxMessage = undefined; } @@ -153,7 +143,17 @@ export class NgxEditorComponent implements OnInit { try { this.commandExecutor.execute(commandName); } catch (error) { - this.ngxMessage = error && error.message; + this.createMessage(error.message); } } + + /* + * message box + */ + createMessage(message) { + this.ngxMessage = message; + setTimeout(() => { + this.clearMessage(); + }, 5000); + } } From 85fd159923af23c2fed581ae7cc32aa4a368a49a Mon Sep 17 00:00:00 2001 From: volodymyro Date: Sun, 19 Nov 2017 19:10:42 +0200 Subject: [PATCH 07/18] Deliver message to ngx-editor-message via the message service Encapsulate message auto clean on 5 seconds --- .../ngx-editor-message/message.service.ts | 30 +++++++++++++++++++ .../ngx-editor-message.component.html | 2 +- .../ngx-editor-message.component.ts | 16 ++++++---- src/app/ngx-editor/ngx-editor.component.html | 3 +- src/app/ngx-editor/ngx-editor.component.ts | 29 +++++------------- src/app/ngx-editor/ngx-editor.module.ts | 4 ++- 6 files changed, 53 insertions(+), 31 deletions(-) create mode 100644 src/app/ngx-editor/ngx-editor-message/message.service.ts diff --git a/src/app/ngx-editor/ngx-editor-message/message.service.ts b/src/app/ngx-editor/ngx-editor-message/message.service.ts new file mode 100644 index 00000000..b74a867a --- /dev/null +++ b/src/app/ngx-editor/ngx-editor-message/message.service.ts @@ -0,0 +1,30 @@ +import {Injectable} from '@angular/core'; +import 'rxjs/add/operator/map'; +import {Subject} from 'rxjs/Subject'; +import {Observable} from 'rxjs/Observable'; + +const FIVE_SECONDS = 5000; + + +@Injectable() +export class MessageService { + private message: Subject = new Subject(); + + constructor() { + } + + messages(): Observable { + return this.message.asObservable(); + } + + send(message: string) { + this.message.next(message); + this.clearMessageOn(FIVE_SECONDS); + } + + private clearMessageOn(milliseconds: number): void { + setTimeout(() => { + this.message.next(undefined); + }, milliseconds); + } +} diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.html b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.html index 68e2e555..c0192d2d 100644 --- a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.html +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.html @@ -1,3 +1,3 @@ -
+
{{ngxMessage}}
diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts index 24426fb1..ba290b2c 100644 --- a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts @@ -1,17 +1,21 @@ -import {Component, Input, OnInit} from '@angular/core'; +import {Component} from '@angular/core'; +import {MessageService} from './message.service'; + @Component({ selector: 'app-ngx-editor-message', templateUrl: './ngx-editor-message.component.html', styleUrls: ['./ngx-editor-message.component.scss'] }) -export class NgxEditorMessageComponent implements OnInit { - - @Input() ngxMessage = ''; +export class NgxEditorMessageComponent { - constructor() { } + ngxMessage = ''; - ngOnInit() { + constructor(private messageService: MessageService) { + this.messageService.messages().subscribe((message: string) => this.ngxMessage = message); } + clearMessage() { + this.ngxMessage = undefined; + } } diff --git a/src/app/ngx-editor/ngx-editor.component.html b/src/app/ngx-editor/ngx-editor.component.html index cb67109f..35f02186 100644 --- a/src/app/ngx-editor/ngx-editor.component.html +++ b/src/app/ngx-editor/ngx-editor.component.html @@ -6,7 +6,6 @@ [attr.translate]="config['translate']" [attr.spellcheck]="config['spellcheck']" [style.height]="config['height']" [style.minHeight]="minHeight || config['minHeight']" [style.resize]="canResize()" (focus)="onFocus()" #ngxTextArea>
- - +
diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index f678af5a..912363e0 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -1,6 +1,7 @@ import {Component, OnInit, HostListener, Input, Output, ElementRef, EventEmitter, ViewChild} from '@angular/core'; import {ngxEditorConfig} from './ngx-editor.defaults'; import {CommandExecutor} from './command-executor'; +import {MessageService} from "./ngx-editor-message/message.service"; @Component({ selector: 'app-ngx-editor', @@ -17,7 +18,6 @@ export class NgxEditorComponent implements OnInit { _config: any; _html: any; _resizer: string; - ngxMessage: string; enableToolbar = false; commandExecutor = new CommandExecutor(); @@ -88,11 +88,7 @@ export class NgxEditorComponent implements OnInit { } } - constructor(private _element: ElementRef) { - } - - clearMessage() { - this.ngxMessage = undefined; + constructor(private _element: ElementRef, private messageService: MessageService) { } /* @@ -140,20 +136,11 @@ export class NgxEditorComponent implements OnInit { * editor actions */ executeCommand(commandName) { - try { - this.commandExecutor.execute(commandName); - } catch (error) { - this.createMessage(error.message); - } - } - - /* - * message box - */ - createMessage(message) { - this.ngxMessage = message; - setTimeout(() => { - this.clearMessage(); - }, 5000); + this.messageService.send(commandName); + try { + this.commandExecutor.execute(commandName); + } catch (error) { + this.messageService.send(error.message); + } } } diff --git a/src/app/ngx-editor/ngx-editor.module.ts b/src/app/ngx-editor/ngx-editor.module.ts index 341a1d83..cabfb3a2 100644 --- a/src/app/ngx-editor/ngx-editor.module.ts +++ b/src/app/ngx-editor/ngx-editor.module.ts @@ -4,13 +4,15 @@ import { NgxEditorComponent } from './ngx-editor.component'; import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; +import {MessageService} from './ngx-editor-message/message.service'; @NgModule({ imports: [ CommonModule ], declarations: [NgxEditorComponent, NgxGrippieComponent, NgxToolbarComponent, NgxEditorMessageComponent], - exports: [NgxEditorComponent, NgxGrippieComponent] + exports: [NgxEditorComponent, NgxGrippieComponent], + providers: [MessageService] }) export class NgxEditorModule { } From a5ea88aeaf7bff84ff61fe87ad91decd8a73b0ef Mon Sep 17 00:00:00 2001 From: volodymyro Date: Sun, 19 Nov 2017 19:15:24 +0200 Subject: [PATCH 08/18] Do command executor as Injectable --- src/app/ngx-editor/command-executor.ts | 8 +++++--- src/app/ngx-editor/ngx-editor.component.ts | 5 ++--- src/app/ngx-editor/ngx-editor.module.ts | 3 ++- 3 files changed, 9 insertions(+), 7 deletions(-) diff --git a/src/app/ngx-editor/command-executor.ts b/src/app/ngx-editor/command-executor.ts index 4579f309..9c2c36e7 100644 --- a/src/app/ngx-editor/command-executor.ts +++ b/src/app/ngx-editor/command-executor.ts @@ -1,3 +1,6 @@ +import {Injectable} from '@angular/core'; + +@Injectable() export class CommandExecutor { public execute(command: string): void { if (command === 'enableObjectResizing') { @@ -28,18 +31,17 @@ export class CommandExecutor { document.execCommand(command, false, null); } - insertImage() { + private insertImage() { const imageURI = prompt('Enter Image URL', 'http://'); if (imageURI) { const inserted = document.execCommand('insertImage', false, imageURI); - console.log('inserted', inserted) if (!inserted) { throw new Error('Invalid URL'); } } } - createLink() { + private createLink() { const selection = document.getSelection(); if (selection.anchorNode.parentElement.tagName === 'A') { diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index 912363e0..7c53b3f3 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -1,7 +1,7 @@ import {Component, OnInit, HostListener, Input, Output, ElementRef, EventEmitter, ViewChild} from '@angular/core'; import {ngxEditorConfig} from './ngx-editor.defaults'; import {CommandExecutor} from './command-executor'; -import {MessageService} from "./ngx-editor-message/message.service"; +import {MessageService} from './ngx-editor-message/message.service'; @Component({ selector: 'app-ngx-editor', @@ -19,7 +19,6 @@ export class NgxEditorComponent implements OnInit { _html: any; _resizer: string; enableToolbar = false; - commandExecutor = new CommandExecutor(); @Input() editable: boolean; @Input() spellcheck: boolean; @@ -88,7 +87,7 @@ export class NgxEditorComponent implements OnInit { } } - constructor(private _element: ElementRef, private messageService: MessageService) { + constructor(private _element: ElementRef, private messageService: MessageService, private commandExecutor: CommandExecutor) { } /* diff --git a/src/app/ngx-editor/ngx-editor.module.ts b/src/app/ngx-editor/ngx-editor.module.ts index cabfb3a2..4af3b9ff 100644 --- a/src/app/ngx-editor/ngx-editor.module.ts +++ b/src/app/ngx-editor/ngx-editor.module.ts @@ -5,6 +5,7 @@ import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; import {MessageService} from './ngx-editor-message/message.service'; +import {CommandExecutor} from './command-executor'; @NgModule({ imports: [ @@ -12,7 +13,7 @@ import {MessageService} from './ngx-editor-message/message.service'; ], declarations: [NgxEditorComponent, NgxGrippieComponent, NgxToolbarComponent, NgxEditorMessageComponent], exports: [NgxEditorComponent, NgxGrippieComponent], - providers: [MessageService] + providers: [CommandExecutor, MessageService] }) export class NgxEditorModule { } From b475231771bbdbbf0afb3d1341e1afc1f0d11a90 Mon Sep 17 00:00:00 2001 From: Volodymyr O Date: Mon, 20 Nov 2017 09:52:52 +0200 Subject: [PATCH 09/18] Remove extra line --- src/app/ngx-editor/ngx-editor.component.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index 7c53b3f3..1e59c476 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -131,11 +131,10 @@ export class NgxEditorComponent implements OnInit { this.executeCommand('enableObjectResizing'); } - /* +/* * editor actions */ executeCommand(commandName) { - this.messageService.send(commandName); try { this.commandExecutor.execute(commandName); } catch (error) { From 65cb2d1c0b68f24ff4ec6538db8b691ea67a3ee1 Mon Sep 17 00:00:00 2001 From: Sibiraj Date: Tue, 21 Nov 2017 11:51:52 +0530 Subject: [PATCH 10/18] chore: update angular/cli to v1.5.3 angular/cli v1.5.3 fixes a security vulnerability that was reported for Handlebars --- package-lock.json | 241 ++++++++++++++++++---------------------------- package.json | 2 +- yarn.lock | 128 +++++++++--------------- 3 files changed, 141 insertions(+), 230 deletions(-) diff --git a/package-lock.json b/package-lock.json index d1b63491..00627db5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -46,15 +46,15 @@ } }, "@angular/cli": { - "version": "1.5.0", - "resolved": "https://registry.npmjs.org/@angular/cli/-/cli-1.5.0.tgz", - "integrity": "sha512-nCXvqNCdi+8aOU2v6EABZsMg5bB7iM+wfaoWKnu9M5fOW2Rm+7/3Y1gDQKyFkgXCzXdy3J/xpfmwT0gjmjlvIA==", + "version": "1.5.3", + "resolved": "https://registry.npmjs.org/@angular/cli/-/cli-1.5.3.tgz", + "integrity": "sha512-PuMcYmnoPP/RqCVIguiJrkc+vek9eVPi+iQ+UE3W/JTDQhZsAkm4qm8zLYR/Z2bp1a5xHuP+PFMtAQysPFag+Q==", "dev": true, "requires": { "@angular-devkit/build-optimizer": "0.0.32", "@angular-devkit/schematics": "0.0.35", "@ngtools/json-schema": "1.1.0", - "@ngtools/webpack": "1.8.0", + "@ngtools/webpack": "1.8.3", "@schematics/angular": "0.1.0", "autoprefixer": "6.7.7", "chalk": "2.2.2", @@ -79,14 +79,15 @@ "license-webpack-plugin": "1.1.1", "lodash": "4.17.4", "memory-fs": "0.4.1", + "minimatch": "3.0.4", "node-modules-path": "1.0.1", "node-sass": "4.5.3", "nopt": "4.0.1", "opn": "5.1.0", "portfinder": "1.0.13", "postcss-custom-properties": "6.2.0", - "postcss-loader": "1.3.3", - "postcss-url": "5.1.2", + "postcss-loader": "2.0.8", + "postcss-url": "7.2.1", "raw-loader": "0.5.1", "resolve": "1.5.0", "rxjs": "5.5.2", @@ -108,6 +109,78 @@ "webpack-sources": "1.0.1", "webpack-subresource-integrity": "1.0.1", "zone.js": "0.8.18" + }, + "dependencies": { + "@ngtools/webpack": { + "version": "1.8.3", + "resolved": "https://registry.npmjs.org/@ngtools/webpack/-/webpack-1.8.3.tgz", + "integrity": "sha512-Yf6leN/IuBhhZ93qq3NRJL1NlAtn1NsowRagZ2y5gpIw64wheuaHNg52EB+HiyQ23Mejc811gKYCbs1KpcaYVw==", + "dev": true, + "requires": { + "chalk": "2.2.2", + "enhanced-resolve": "3.4.1", + "loader-utils": "1.1.0", + "magic-string": "0.22.4", + "semver": "5.4.1", + "source-map": "0.5.7", + "tree-kill": "1.2.0" + } + }, + "postcss": { + "version": "6.0.14", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-6.0.14.tgz", + "integrity": "sha512-NJ1z0f+1offCgadPhz+DvGm5Mkci+mmV5BqD13S992o0Xk9eElxUfPPF+t2ksH5R/17gz4xVK8KWocUQ5o3Rog==", + "dev": true, + "requires": { + "chalk": "2.3.0", + "source-map": "0.6.1", + "supports-color": "4.5.0" + }, + "dependencies": { + "chalk": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.3.0.tgz", + "integrity": "sha512-Az5zJR2CBujap2rqXGaJKaPHyJ0IrUimvYNX+ncCy8PJP4ltOGTrHUIo097ZaL2zMeKYpiCdqDvS6zdrTFok3Q==", + "dev": true, + "requires": { + "ansi-styles": "3.2.0", + "escape-string-regexp": "1.0.5", + "supports-color": "4.5.0" + } + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "postcss-loader": { + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-2.0.8.tgz", + "integrity": "sha512-KtXBiQ/r/WYW8LxTSJK7h8wLqvCMSub/BqmRnud/Mu8RzwflW9cmXxwsMwbn15TNv287Hcufdb3ZSs7xHKnG8Q==", + "dev": true, + "requires": { + "loader-utils": "1.1.0", + "postcss": "6.0.14", + "postcss-load-config": "1.2.0", + "schema-utils": "0.3.0" + } + }, + "postcss-url": { + "version": "7.2.1", + "resolved": "https://registry.npmjs.org/postcss-url/-/postcss-url-7.2.1.tgz", + "integrity": "sha512-jycW2XYgU39SpA+MJOOP7Fe7I2NxiCq8rOXiG61NBoJ4vG/WFn2IhS18vGiphla4VTN3WoHJOBMMJz1n4h1VYQ==", + "dev": true, + "requires": { + "mime": "1.4.1", + "minimatch": "3.0.4", + "mkdirp": "0.5.1", + "postcss": "6.0.14", + "xxhashjs": "0.2.1" + } + } } }, "@angular/common": { @@ -221,21 +294,6 @@ "integrity": "sha1-w6DFRNYjkqzCgTpCyKDcb1j4aSI=", "dev": true }, - "@ngtools/webpack": { - "version": "1.8.0", - "resolved": "https://registry.npmjs.org/@ngtools/webpack/-/webpack-1.8.0.tgz", - "integrity": "sha512-QefALj8VUakHMI/Z/7RjyQR4UpAAfCXeoHqqD9+7Td3CZkuryyGQILqOSAg3d+cP+64iCwIb2jSKC+YAIy722Q==", - "dev": true, - "requires": { - "chalk": "2.2.2", - "enhanced-resolve": "3.4.1", - "loader-utils": "1.1.0", - "magic-string": "0.22.4", - "semver": "5.4.1", - "source-map": "0.5.7", - "tree-kill": "1.2.0" - } - }, "@schematics/angular": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/@schematics/angular/-/angular-0.1.0.tgz", @@ -2101,6 +2159,12 @@ "source-map": "0.5.7" } }, + "cuint": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/cuint/-/cuint-0.2.2.tgz", + "integrity": "sha1-QICG1AlVDCYxFVYZ6fp7ytw7mRs=", + "dev": true + }, "currently-unhandled": { "version": "0.4.1", "resolved": "https://registry.npmjs.org/currently-unhandled/-/currently-unhandled-0.4.1.tgz", @@ -2334,40 +2398,6 @@ "randombytes": "2.0.5" } }, - "directory-encoder": { - "version": "0.7.2", - "resolved": "https://registry.npmjs.org/directory-encoder/-/directory-encoder-0.7.2.tgz", - "integrity": "sha1-WbTiqk8lQi9sY7UntGL14tDdLFg=", - "dev": true, - "requires": { - "fs-extra": "0.23.1", - "handlebars": "1.3.0", - "img-stats": "0.5.2" - }, - "dependencies": { - "fs-extra": { - "version": "0.23.1", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-0.23.1.tgz", - "integrity": "sha1-ZhHbpq3yq43Jxp+rN83fiBgVfj0=", - "dev": true, - "requires": { - "graceful-fs": "4.1.11", - "jsonfile": "2.4.0", - "path-is-absolute": "1.0.1", - "rimraf": "2.6.2" - } - }, - "jsonfile": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-2.4.0.tgz", - "integrity": "sha1-NzaitCi4e72gzIO1P6PWM6NcKug=", - "dev": true, - "requires": { - "graceful-fs": "4.1.11" - } - } - } - }, "dns-equal": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/dns-equal/-/dns-equal-1.0.0.tgz", @@ -3970,47 +4000,6 @@ "integrity": "sha1-/Xqtcmvxpf0W38KbL3pmAdJxOcQ=", "dev": true }, - "handlebars": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-1.3.0.tgz", - "integrity": "sha1-npsTCpPjiUkTItl1zz7BgYw3zjQ=", - "dev": true, - "requires": { - "optimist": "0.3.7", - "uglify-js": "2.3.6" - }, - "dependencies": { - "async": { - "version": "0.2.10", - "resolved": "https://registry.npmjs.org/async/-/async-0.2.10.tgz", - "integrity": "sha1-trvgsGdLnXGXCMo43owjfLUmw9E=", - "dev": true, - "optional": true - }, - "source-map": { - "version": "0.1.43", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.1.43.tgz", - "integrity": "sha1-wkvBRspRfBRx9drL4lcbK3+eM0Y=", - "dev": true, - "optional": true, - "requires": { - "amdefine": "1.0.1" - } - }, - "uglify-js": { - "version": "2.3.6", - "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.3.6.tgz", - "integrity": "sha1-+gmEdwtCi3qbKoBY9GNV0U/vIRo=", - "dev": true, - "optional": true, - "requires": { - "async": "0.2.10", - "optimist": "0.3.7", - "source-map": "0.1.43" - } - } - } - }, "har-schema": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-1.0.5.tgz", @@ -4462,15 +4451,6 @@ "dev": true, "optional": true }, - "img-stats": { - "version": "0.5.2", - "resolved": "https://registry.npmjs.org/img-stats/-/img-stats-0.5.2.tgz", - "integrity": "sha1-wgNJbELy2esuWrgjL6dWurMsnis=", - "dev": true, - "requires": { - "xmldom": "0.1.27" - } - }, "import-local": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/import-local/-/import-local-0.1.1.tgz", @@ -6632,15 +6612,6 @@ "is-wsl": "1.1.0" } }, - "optimist": { - "version": "0.3.7", - "resolved": "https://registry.npmjs.org/optimist/-/optimist-0.3.7.tgz", - "integrity": "sha1-yQlBrVnkJzMokjB00s8ufLxuwNk=", - "dev": true, - "requires": { - "wordwrap": "0.0.3" - } - }, "options": { "version": "0.0.6", "resolved": "https://registry.npmjs.org/options/-/options-0.0.6.tgz", @@ -7219,18 +7190,6 @@ "object-assign": "4.1.1" } }, - "postcss-loader": { - "version": "1.3.3", - "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-1.3.3.tgz", - "integrity": "sha1-piHqH6KQYqg5cqRvVEhncTAZFus=", - "dev": true, - "requires": { - "loader-utils": "1.1.0", - "object-assign": "4.1.1", - "postcss": "5.2.18", - "postcss-load-config": "1.2.0" - } - }, "postcss-merge-idents": { "version": "2.1.7", "resolved": "https://registry.npmjs.org/postcss-merge-idents/-/postcss-merge-idents-2.1.7.tgz", @@ -7525,21 +7484,6 @@ "uniqs": "2.0.0" } }, - "postcss-url": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/postcss-url/-/postcss-url-5.1.2.tgz", - "integrity": "sha1-mLMWW+jVkkccsMqt3iwNH4MvEz4=", - "dev": true, - "requires": { - "directory-encoder": "0.7.2", - "js-base64": "2.3.2", - "mime": "1.4.1", - "minimatch": "3.0.4", - "mkdirp": "0.5.1", - "path-is-absolute": "1.0.1", - "postcss": "5.2.18" - } - }, "postcss-value-parser": { "version": "3.3.0", "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.0.tgz", @@ -10608,12 +10552,6 @@ "integrity": "sha1-UZy0ymhtAFqEINNJbz8MruzKWA8=", "dev": true }, - "xmldom": { - "version": "0.1.27", - "resolved": "https://registry.npmjs.org/xmldom/-/xmldom-0.1.27.tgz", - "integrity": "sha1-1QH5ezvbQDr4757MIFcxh6rawOk=", - "dev": true - }, "xmlhttprequest-ssl": { "version": "1.5.3", "resolved": "https://registry.npmjs.org/xmlhttprequest-ssl/-/xmlhttprequest-ssl-1.5.3.tgz", @@ -10626,6 +10564,15 @@ "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=", "dev": true }, + "xxhashjs": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/xxhashjs/-/xxhashjs-0.2.1.tgz", + "integrity": "sha1-m76b6JYUKXbfo0wGGy0GjEPTDeA=", + "dev": true, + "requires": { + "cuint": "0.2.2" + } + }, "y18n": { "version": "3.2.1", "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz", diff --git a/package.json b/package.json index 1ee5a33b..4c7b85a3 100644 --- a/package.json +++ b/package.json @@ -49,7 +49,7 @@ "zone.js": "^0.8.14" }, "devDependencies": { - "@angular/cli": "1.5.0", + "@angular/cli": "1.5.3", "@angular/compiler-cli": "^5.0.0", "@angular/language-service": "^5.0.0", "@types/jasmine": "~2.5.53", diff --git a/yarn.lock b/yarn.lock index cf6df331..6fdba1e5 100644 --- a/yarn.lock +++ b/yarn.lock @@ -32,14 +32,14 @@ dependencies: tslib "^1.7.1" -"@angular/cli@1.5.0": - version "1.5.0" - resolved "https://registry.yarnpkg.com/@angular/cli/-/cli-1.5.0.tgz#2abc3ff1648d54ad4a14f82f9d517f371370406c" +"@angular/cli@1.5.3": + version "1.5.3" + resolved "https://registry.yarnpkg.com/@angular/cli/-/cli-1.5.3.tgz#9d98abbfdf42706853dfeb10f33410adf6b8038b" dependencies: "@angular-devkit/build-optimizer" "~0.0.31" "@angular-devkit/schematics" "~0.0.34" "@ngtools/json-schema" "1.1.0" - "@ngtools/webpack" "1.8.0" + "@ngtools/webpack" "1.8.3" "@schematics/angular" "~0.1.0" autoprefixer "^6.5.3" chalk "~2.2.0" @@ -64,13 +64,14 @@ license-webpack-plugin "^1.0.0" lodash "^4.11.1" memory-fs "^0.4.1" + minimatch "^3.0.4" node-modules-path "^1.0.0" nopt "^4.0.1" opn "~5.1.0" portfinder "~1.0.12" postcss-custom-properties "^6.1.0" - postcss-loader "^1.3.3" - postcss-url "^5.1.2" + postcss-loader "^2.0.8" + postcss-url "^7.1.2" raw-loader "^0.5.1" resolve "^1.1.7" rxjs "^5.5.2" @@ -166,9 +167,9 @@ version "1.1.0" resolved "https://registry.yarnpkg.com/@ngtools/json-schema/-/json-schema-1.1.0.tgz#c3a0c544d62392acc2813a42c8a0dc6f58f86922" -"@ngtools/webpack@1.8.0": - version "1.8.0" - resolved "https://registry.yarnpkg.com/@ngtools/webpack/-/webpack-1.8.0.tgz#443204e016aa3a287544eacadb4c95964ae6e2c4" +"@ngtools/webpack@1.8.3": + version "1.8.3" + resolved "https://registry.yarnpkg.com/@ngtools/webpack/-/webpack-1.8.3.tgz#8bafa749fc2626d11e146899e5b14e3e85bc787f" dependencies: chalk "~2.2.0" enhanced-resolve "^3.1.0" @@ -480,10 +481,6 @@ async@^2.0.0-rc.5, async@^2.1.2, async@^2.1.4, async@^2.1.5, async@^2.4.1, async dependencies: lodash "^4.14.0" -async@~0.2.6: - version "0.2.10" - resolved "https://registry.yarnpkg.com/async/-/async-0.2.10.tgz#b6bbe0b0674b9d719708ca38de8c237cb526c3d1" - asynckit@^0.4.0: version "0.4.0" resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" @@ -946,7 +943,7 @@ chalk@1.1.3, chalk@^1.0.0, chalk@^1.1.1, chalk@^1.1.3: strip-ansi "^3.0.0" supports-color "^2.0.0" -chalk@^2.0.0, chalk@^2.1.0: +chalk@^2.0.0, chalk@^2.1.0, chalk@^2.3.0: version "2.3.0" resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.3.0.tgz#b5ea48efc9c1793dccc9b4767c93914d3f2d52ba" dependencies: @@ -1504,6 +1501,10 @@ csso@~2.3.1: clap "^1.0.9" source-map "^0.5.3" +cuint@latest: + version "0.2.2" + resolved "https://registry.yarnpkg.com/cuint/-/cuint-0.2.2.tgz#408086d409550c2631155619e9fa7bcadc3b991b" + currently-unhandled@^0.4.1: version "0.4.1" resolved "https://registry.yarnpkg.com/currently-unhandled/-/currently-unhandled-0.4.1.tgz#988df33feab191ef799a61369dd76c17adf957ea" @@ -1702,14 +1703,6 @@ diffie-hellman@^5.0.0: miller-rabin "^4.0.0" randombytes "^2.0.0" -directory-encoder@^0.7.2: - version "0.7.2" - resolved "https://registry.yarnpkg.com/directory-encoder/-/directory-encoder-0.7.2.tgz#59b4e2aa4f25422f6c63b527b462f5e2d0dd2c58" - dependencies: - fs-extra "^0.23.1" - handlebars "^1.3.0" - img-stats "^0.5.2" - dns-equal@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/dns-equal/-/dns-equal-1.0.0.tgz#b39e7f1da6eb0a75ba9c17324b34753c47e0654d" @@ -2435,15 +2428,6 @@ fs-exists-sync@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/fs-exists-sync/-/fs-exists-sync-0.1.0.tgz#982d6893af918e72d08dec9e8673ff2b5a8d6add" -fs-extra@^0.23.1: - version "0.23.1" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-0.23.1.tgz#6611dba6adf2ab8dc9c69fab37cddf8818157e3d" - dependencies: - graceful-fs "^4.1.2" - jsonfile "^2.1.0" - path-is-absolute "^1.0.0" - rimraf "^2.2.8" - fs-extra@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-1.0.0.tgz#cd3ce5f7e7cb6145883fcae3191e9877f8587950" @@ -2734,14 +2718,6 @@ handle-thing@^1.2.5: version "1.2.5" resolved "https://registry.yarnpkg.com/handle-thing/-/handle-thing-1.2.5.tgz#fd7aad726bf1a5fd16dfc29b2f7a6601d27139c4" -handlebars@^1.3.0: - version "1.3.0" - resolved "https://registry.yarnpkg.com/handlebars/-/handlebars-1.3.0.tgz#9e9b130a93e389491322d975cf3ec1818c37ce34" - dependencies: - optimist "~0.3" - optionalDependencies: - uglify-js "~2.3" - handlebars@^4.0.3: version "4.0.11" resolved "https://registry.yarnpkg.com/handlebars/-/handlebars-4.0.11.tgz#630a35dfe0294bc281edae6ffc5d329fc7982dcc" @@ -3027,12 +3003,6 @@ image-size@~0.5.0: version "0.5.5" resolved "https://registry.yarnpkg.com/image-size/-/image-size-0.5.5.tgz#09dfd4ab9d20e29eb1c3e80b8990378df9e3cb9c" -img-stats@^0.5.2: - version "0.5.2" - resolved "https://registry.yarnpkg.com/img-stats/-/img-stats-0.5.2.tgz#c203496c42f2d9eb2e5ab8232fa756bab32c9e2b" - dependencies: - xmldom "^0.1.19" - import-local@^0.1.1: version "0.1.1" resolved "https://registry.yarnpkg.com/import-local/-/import-local-0.1.1.tgz#b1179572aacdc11c6a91009fb430dbcab5f668a8" @@ -3452,7 +3422,7 @@ jasminewd2@^2.1.0: version "2.2.0" resolved "https://registry.yarnpkg.com/jasminewd2/-/jasminewd2-2.2.0.tgz#e37cf0b17f199cce23bea71b2039395246b4ec4e" -js-base64@^2.1.5, js-base64@^2.1.8, js-base64@^2.1.9: +js-base64@^2.1.8, js-base64@^2.1.9: version "2.3.2" resolved "https://registry.yarnpkg.com/js-base64/-/js-base64-2.3.2.tgz#a79a923666372b580f8e27f51845c6f7e8fbfbaf" @@ -4377,7 +4347,7 @@ object-assign@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-3.0.0.tgz#9bedd5ca0897949bca47e7ff408062d549f587f2" -object-assign@^4.0.0, object-assign@^4.0.1, object-assign@^4.1.0, object-assign@^4.1.1: +object-assign@^4.0.0, object-assign@^4.0.1, object-assign@^4.1.0: version "4.1.1" resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" @@ -4433,12 +4403,6 @@ optimist@^0.6.1, optimist@~0.6.0: minimist "~0.0.1" wordwrap "~0.0.2" -optimist@~0.3, optimist@~0.3.5: - version "0.3.7" - resolved "https://registry.yarnpkg.com/optimist/-/optimist-0.3.7.tgz#c90941ad59e4273328923074d2cf2e7cbc6ec0d9" - dependencies: - wordwrap "~0.0.2" - options@>=0.0.5: version "0.0.6" resolved "https://registry.yarnpkg.com/options/-/options-0.0.6.tgz#ec22d312806bb53e731773e7cdaefcf1c643128f" @@ -4779,14 +4743,14 @@ postcss-load-plugins@^2.3.0: cosmiconfig "^2.1.1" object-assign "^4.1.0" -postcss-loader@^1.3.3: - version "1.3.3" - resolved "https://registry.yarnpkg.com/postcss-loader/-/postcss-loader-1.3.3.tgz#a621ea1fa29062a83972a46f54486771301916eb" +postcss-loader@^2.0.8: + version "2.0.8" + resolved "https://registry.yarnpkg.com/postcss-loader/-/postcss-loader-2.0.8.tgz#8c67ddb029407dfafe684a406cfc16bad2ce0814" dependencies: - loader-utils "^1.0.2" - object-assign "^4.1.1" - postcss "^5.2.15" + loader-utils "^1.1.0" + postcss "^6.0.0" postcss-load-config "^1.2.0" + schema-utils "^0.3.0" postcss-merge-idents@^2.1.5: version "2.1.7" @@ -4944,17 +4908,15 @@ postcss-unique-selectors@^2.0.2: postcss "^5.0.4" uniqs "^2.0.0" -postcss-url@^5.1.2: - version "5.1.2" - resolved "https://registry.yarnpkg.com/postcss-url/-/postcss-url-5.1.2.tgz#98b3165be8d592471cb0caadde2c0d1f832f133e" +postcss-url@^7.1.2: + version "7.2.1" + resolved "https://registry.yarnpkg.com/postcss-url/-/postcss-url-7.2.1.tgz#bf47ff1b5395538567cea19ef3241a70fb925f5c" dependencies: - directory-encoder "^0.7.2" - js-base64 "^2.1.5" - mime "^1.2.11" - minimatch "^3.0.0" + mime "^1.4.1" + minimatch "^3.0.4" mkdirp "^0.5.0" - path-is-absolute "^1.0.0" - postcss "^5.0.0" + postcss "^6.0.1" + xxhashjs "^0.2.1" postcss-value-parser@^3.0.1, postcss-value-parser@^3.0.2, postcss-value-parser@^3.1.1, postcss-value-parser@^3.1.2, postcss-value-parser@^3.2.3, postcss-value-parser@^3.3.0: version "3.3.0" @@ -4968,7 +4930,7 @@ postcss-zindex@^2.0.1: postcss "^5.0.4" uniqs "^2.0.0" -postcss@^5.0.0, postcss@^5.0.10, postcss@^5.0.11, postcss@^5.0.12, postcss@^5.0.13, postcss@^5.0.14, postcss@^5.0.16, postcss@^5.0.2, postcss@^5.0.4, postcss@^5.0.5, postcss@^5.0.6, postcss@^5.0.8, postcss@^5.2.15, postcss@^5.2.16: +postcss@^5.0.10, postcss@^5.0.11, postcss@^5.0.12, postcss@^5.0.13, postcss@^5.0.14, postcss@^5.0.16, postcss@^5.0.2, postcss@^5.0.4, postcss@^5.0.5, postcss@^5.0.6, postcss@^5.0.8, postcss@^5.2.16: version "5.2.18" resolved "https://registry.yarnpkg.com/postcss/-/postcss-5.2.18.tgz#badfa1497d46244f6390f58b319830d9107853c5" dependencies: @@ -4977,6 +4939,14 @@ postcss@^5.0.0, postcss@^5.0.10, postcss@^5.0.11, postcss@^5.0.12, postcss@^5.0. source-map "^0.5.6" supports-color "^3.2.3" +postcss@^6.0.0: + version "6.0.14" + resolved "https://registry.yarnpkg.com/postcss/-/postcss-6.0.14.tgz#5534c72114739e75d0afcf017db853099f562885" + dependencies: + chalk "^2.3.0" + source-map "^0.6.1" + supports-color "^4.4.0" + postcss@^6.0.1, postcss@^6.0.13, postcss@^6.0.2: version "6.0.13" resolved "https://registry.yarnpkg.com/postcss/-/postcss-6.0.13.tgz#b9ecab4ee00c89db3ec931145bd9590bbf3f125f" @@ -5873,7 +5843,7 @@ source-map-support@^0.4.0, source-map-support@^0.4.1, source-map-support@^0.4.2, dependencies: source-map "^0.5.6" -source-map@0.1.x, source-map@~0.1.7: +source-map@0.1.x: version "0.1.43" resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.1.43.tgz#c24bc146ca517c1471f5dacbe2571b2b7f9e3346" dependencies: @@ -6432,14 +6402,6 @@ uglify-js@^2.6, uglify-js@^2.8.29: optionalDependencies: uglify-to-browserify "~1.0.0" -uglify-js@~2.3: - version "2.3.6" - resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-2.3.6.tgz#fa0984770b428b7a9b2a8058f46355d14fef211a" - dependencies: - async "~0.2.6" - optimist "~0.3.5" - source-map "~0.1.7" - uglify-to-browserify@~1.0.0: version "1.0.2" resolved "https://registry.yarnpkg.com/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz#6e0924d6bda6b5afe349e39a6d632850a0f882b7" @@ -6919,10 +6881,6 @@ xmlbuilder@>=1.0.0, xmlbuilder@~9.0.1: version "9.0.4" resolved "https://registry.yarnpkg.com/xmlbuilder/-/xmlbuilder-9.0.4.tgz#519cb4ca686d005a8420d3496f3f0caeecca580f" -xmldom@^0.1.19: - version "0.1.27" - resolved "https://registry.yarnpkg.com/xmldom/-/xmldom-0.1.27.tgz#d501f97b3bdb403af8ef9ecc20573187aadac0e9" - xmlhttprequest-ssl@1.5.3: version "1.5.3" resolved "https://registry.yarnpkg.com/xmlhttprequest-ssl/-/xmlhttprequest-ssl-1.5.3.tgz#185a888c04eca46c3e4070d99f7b49de3528992d" @@ -6931,6 +6889,12 @@ xmlhttprequest-ssl@1.5.3: version "4.0.1" resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.1.tgz#a5c6d532be656e23db820efb943a1f04998d63af" +xxhashjs@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/xxhashjs/-/xxhashjs-0.2.1.tgz#9bbe9be896142976dfa34c061b2d068c43d30de0" + dependencies: + cuint latest + y18n@^3.2.1: version "3.2.1" resolved "https://registry.yarnpkg.com/y18n/-/y18n-3.2.1.tgz#6d15fba884c08679c0d77e88e7759e811e07fa41" From ef1cc05db6010e546fc9e8f6cc675df3708df683 Mon Sep 17 00:00:00 2001 From: Sibiraj Date: Tue, 21 Nov 2017 12:04:34 +0530 Subject: [PATCH 11/18] test: corrects existing tests --- src/app/ngx-editor/command-executor.ts | 3 ++- .../ngx-editor/ngx-editor-message/message.service.ts | 7 +++---- .../ngx-editor-message.component.spec.ts | 6 ++++-- src/app/ngx-editor/ngx-editor.component.spec.ts | 11 ++++++++++- .../ngx-editor/ngx-grippie/ngx-grippie.component.html | 2 +- .../ngx-editor/ngx-grippie/ngx-grippie.component.scss | 3 ++- .../ngx-grippie/ngx-grippie.component.spec.ts | 9 +++++++-- .../ngx-editor/ngx-toolbar/ngx-toolbar.component.ts | 3 ++- 8 files changed, 31 insertions(+), 13 deletions(-) diff --git a/src/app/ngx-editor/command-executor.ts b/src/app/ngx-editor/command-executor.ts index 9c2c36e7..f4078208 100644 --- a/src/app/ngx-editor/command-executor.ts +++ b/src/app/ngx-editor/command-executor.ts @@ -1,7 +1,8 @@ -import {Injectable} from '@angular/core'; +import { Injectable } from '@angular/core'; @Injectable() export class CommandExecutor { + public execute(command: string): void { if (command === 'enableObjectResizing') { document.execCommand('enableObjectResizing', true, true); diff --git a/src/app/ngx-editor/ngx-editor-message/message.service.ts b/src/app/ngx-editor/ngx-editor-message/message.service.ts index b74a867a..08eb0e4b 100644 --- a/src/app/ngx-editor/ngx-editor-message/message.service.ts +++ b/src/app/ngx-editor/ngx-editor-message/message.service.ts @@ -1,11 +1,10 @@ -import {Injectable} from '@angular/core'; +import { Injectable } from '@angular/core'; import 'rxjs/add/operator/map'; -import {Subject} from 'rxjs/Subject'; -import {Observable} from 'rxjs/Observable'; +import { Subject } from 'rxjs/Subject'; +import { Observable } from 'rxjs/Observable'; const FIVE_SECONDS = 5000; - @Injectable() export class MessageService { private message: Subject = new Subject(); diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts index 0b369836..2bcb15c2 100644 --- a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts @@ -1,6 +1,7 @@ import { async, ComponentFixture, TestBed } from '@angular/core/testing'; import { NgxEditorMessageComponent } from './ngx-editor-message.component'; +import { MessageService } from './message.service'; describe('NgxEditorMessageComponent', () => { let component: NgxEditorMessageComponent; @@ -8,9 +9,10 @@ describe('NgxEditorMessageComponent', () => { beforeEach(async(() => { TestBed.configureTestingModule({ - declarations: [ NgxEditorMessageComponent ] + providers: [MessageService], + declarations: [NgxEditorMessageComponent] }) - .compileComponents(); + .compileComponents(); })); beforeEach(() => { diff --git a/src/app/ngx-editor/ngx-editor.component.spec.ts b/src/app/ngx-editor/ngx-editor.component.spec.ts index 80a72641..9cdb173c 100644 --- a/src/app/ngx-editor/ngx-editor.component.spec.ts +++ b/src/app/ngx-editor/ngx-editor.component.spec.ts @@ -2,6 +2,10 @@ import { async, ComponentFixture, TestBed } from '@angular/core/testing'; import { NgxEditorComponent } from './ngx-editor.component'; import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; +import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; +import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; +import { MessageService } from './ngx-editor-message/message.service'; +import { CommandExecutor } from './command-executor'; describe('NgxEditorComponent', () => { let component: NgxEditorComponent; @@ -9,7 +13,12 @@ describe('NgxEditorComponent', () => { beforeEach(async(() => { TestBed.configureTestingModule({ - declarations: [NgxEditorComponent, NgxGrippieComponent] + providers: [MessageService, CommandExecutor], + declarations: [NgxEditorComponent, + NgxGrippieComponent, + NgxToolbarComponent, + NgxEditorMessageComponent + ] }) .compileComponents(); })); diff --git a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.html b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.html index 411dd0e8..2e3bd6a4 100644 --- a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.html +++ b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.html @@ -6,4 +6,4 @@ fill="rgb(147,153,159)" /> -
\ No newline at end of file +
diff --git a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.scss b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.scss index 1c904de2..7901bb5b 100644 --- a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.scss +++ b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.scss @@ -6,8 +6,9 @@ cursor: s-resize; border: 1px solid #ddd; border-top: transparent; + svg { position: absolute; top: 1.5px; } -} \ No newline at end of file +} diff --git a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts index 24e461e2..003839f3 100644 --- a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts +++ b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts @@ -1,8 +1,10 @@ import { async, ComponentFixture, TestBed } from '@angular/core/testing'; - import { ElementRef } from '@angular/core'; + import { NgxGrippieComponent } from './ngx-grippie.component'; import { NgxEditorComponent } from '../ngx-editor.component'; +import { MessageService } from '../ngx-editor-message/message.service'; +import { CommandExecutor } from '../command-executor'; export class MockElementRef extends ElementRef { constructor() { super(null); } @@ -15,7 +17,10 @@ describe('NgxGrippieComponent', () => { beforeEach(async(() => { TestBed.configureTestingModule({ declarations: [NgxGrippieComponent], - providers: [NgxEditorComponent, + providers: [ + NgxEditorComponent, + MessageService, + CommandExecutor, { provide: ElementRef, useClass: MockElementRef }] }) .compileComponents(); diff --git a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts index 933f1c5a..25604549 100644 --- a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts +++ b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts @@ -1,4 +1,4 @@ -import {Component, EventEmitter, Input, Output} from '@angular/core'; +import { Component, EventEmitter, Input, Output } from '@angular/core'; import * as Utils from './ngx-editor.utils'; @Component({ @@ -6,6 +6,7 @@ import * as Utils from './ngx-editor.utils'; templateUrl: './ngx-toolbar.component.html', styleUrls: ['./ngx-toolbar.component.scss'] }) + export class NgxToolbarComponent { @Input() config: any; From 91cf0afdfc85c233b3237014418bb2e0b9f08d5f Mon Sep 17 00:00:00 2001 From: Sibiraj Date: Tue, 21 Nov 2017 13:28:09 +0530 Subject: [PATCH 12/18] style: format files" --- src/app/app.component.html | 2 +- src/app/app.component.scss | 6 +- .../ngx-editor-message.component.scss | 14 +-- .../ngx-editor-message.component.ts | 4 +- src/app/ngx-editor/ngx-editor.component.html | 2 +- src/app/ngx-editor/ngx-editor.component.scss | 8 +- src/app/ngx-editor/ngx-editor.component.ts | 30 +++--- src/app/ngx-editor/ngx-editor.module.ts | 4 +- .../ngx-toolbar/ngx-toolbar.component.html | 47 +++++----- .../ngx-toolbar/ngx-toolbar.component.scss | 94 ++++++++++--------- .../ngx-toolbar/ngx-toolbar.component.ts | 3 +- 11 files changed, 114 insertions(+), 100 deletions(-) diff --git a/src/app/app.component.html b/src/app/app.component.html index 3bab1fb2..4772ba04 100644 --- a/src/app/app.component.html +++ b/src/app/app.component.html @@ -26,4 +26,4 @@
Documentation

Check wiki for more information

- \ No newline at end of file + diff --git a/src/app/app.component.scss b/src/app/app.component.scss index d25471ff..b4b54fa1 100644 --- a/src/app/app.component.scss +++ b/src/app/app.component.scss @@ -1,14 +1,18 @@ .container { padding-top: 1rem; + .block { margin-bottom: 1rem; } + .logo { text-align: center; + img { margin-bottom: 0.3rem; } } + .htmlblock { .html { border: 1px solid #ddd; @@ -31,4 +35,4 @@ mark { background-color: #f1f1f1; padding: 0.1rem 0.4rem; border-radius: 3px; -} \ No newline at end of file +} diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.scss b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.scss index a8d05e6b..b368807e 100644 --- a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.scss +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.scss @@ -1,9 +1,9 @@ .ngx-editor-message { - font-size: 80%; - background-color: #f1f1f1; - border: 1px solid #ddd; - border-top: transparent; - padding: 0 0.5rem; - padding-bottom: 0.1rem; - transition: 0.5s ease-in; + font-size: 80%; + background-color: #f1f1f1; + border: 1px solid #ddd; + border-top: transparent; + padding: 0 0.5rem; + padding-bottom: 0.1rem; + transition: 0.5s ease-in; } diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts index ba290b2c..597ed301 100644 --- a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts @@ -1,5 +1,5 @@ -import {Component} from '@angular/core'; -import {MessageService} from './message.service'; +import { Component } from '@angular/core'; +import { MessageService } from './message.service'; @Component({ diff --git a/src/app/ngx-editor/ngx-editor.component.html b/src/app/ngx-editor/ngx-editor.component.html index 35f02186..788c2521 100644 --- a/src/app/ngx-editor/ngx-editor.component.html +++ b/src/app/ngx-editor/ngx-editor.component.html @@ -3,7 +3,7 @@
diff --git a/src/app/ngx-editor/ngx-editor.component.scss b/src/app/ngx-editor/ngx-editor.component.scss index 39f82a29..ea606ca2 100644 --- a/src/app/ngx-editor/ngx-editor.component.scss +++ b/src/app/ngx-editor/ngx-editor.component.scss @@ -4,9 +4,11 @@ .ngx-editor { position: relative; - ::ng-deep [contenteditable=true]:empty:before { + + ::ng-deep [contenteditable=true]:empty:before { content: attr(placeholder); display: block; // for firefox + } .ngx-editor-textarea { @@ -16,11 +18,13 @@ border-top: transparent !important; background-color: #fff; overflow: auto; + &:focus, &.focus { outline: 0; } - ::ng-deep blockquote { + + ::ng-deep blockquote { margin-left: 1rem; border-left: 0.2em solid #dfe2e5; padding-left: 0.5rem; diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index 1e59c476..6a2434b6 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -1,7 +1,7 @@ -import {Component, OnInit, HostListener, Input, Output, ElementRef, EventEmitter, ViewChild} from '@angular/core'; -import {ngxEditorConfig} from './ngx-editor.defaults'; -import {CommandExecutor} from './command-executor'; -import {MessageService} from './ngx-editor-message/message.service'; +import { Component, OnInit, HostListener, Input, Output, ElementRef, EventEmitter, ViewChild } from '@angular/core'; +import { ngxEditorConfig } from './ngx-editor.defaults'; +import { CommandExecutor } from './command-executor'; +import { MessageService } from './ngx-editor-message/message.service'; @Component({ selector: 'app-ngx-editor', @@ -31,8 +31,7 @@ export class NgxEditorComponent implements OnInit { @Input() toolbar: any; // set resizer - @Input() - set resizer(value: string) { + @Input() set resizer(value: string) { console.log(value); if (value === 'basic') { this._resizer = value; @@ -46,8 +45,7 @@ export class NgxEditorComponent implements OnInit { } // set configuration - @Input() - set config(value: JSON) { + @Input() set config(value: JSON) { for (const i in ngxEditorConfig) { if (i) { @@ -131,14 +129,14 @@ export class NgxEditorComponent implements OnInit { this.executeCommand('enableObjectResizing'); } -/* - * editor actions - */ + /* + * editor actions + */ executeCommand(commandName) { - try { - this.commandExecutor.execute(commandName); - } catch (error) { - this.messageService.send(error.message); - } + try { + this.commandExecutor.execute(commandName); + } catch (error) { + this.messageService.send(error.message); + } } } diff --git a/src/app/ngx-editor/ngx-editor.module.ts b/src/app/ngx-editor/ngx-editor.module.ts index 4af3b9ff..f82a82f8 100644 --- a/src/app/ngx-editor/ngx-editor.module.ts +++ b/src/app/ngx-editor/ngx-editor.module.ts @@ -4,8 +4,8 @@ import { NgxEditorComponent } from './ngx-editor.component'; import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; -import {MessageService} from './ngx-editor-message/message.service'; -import {CommandExecutor} from './command-executor'; +import { MessageService } from './ngx-editor-message/message.service'; +import { CommandExecutor } from './command-executor'; @NgModule({ imports: [ diff --git a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html index db9c6fa7..47f314d7 100644 --- a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html +++ b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html @@ -5,49 +5,49 @@
@@ -59,11 +59,11 @@ -
-
diff --git a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.scss b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.scss index 44e5625f..21066462 100644 --- a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.scss +++ b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.scss @@ -1,47 +1,55 @@ .ngx-toolbar { - background-color: #f5f5f5; - border-bottom: 1px solid #ddd; - font-size: 0.8rem; - padding: 0.2rem; - border: 1px solid #ddd; - .ngx-toolbar-set { - display: inline-block; + background-color: #f5f5f5; + border-bottom: 1px solid #ddd; + font-size: 0.8rem; + padding: 0.2rem; border: 1px solid #ddd; - border-radius: 5px; - background-color: white; - .ngx-editor-button { - background-color: #f5f5f5; - background-color: transparent; - border: 0; - padding: 0.4rem; - min-width: 2.5rem; - float: left; - border-right: 1px solid #ddd; - &:hover { - cursor: pointer; - background-color: #f1f1f1; - transition: 0.2s ease; - } - &:focus, - &.focus { - outline: 0; - } - &:last-child { - border-right: transparent; - } - &:first-child { - border-top-left-radius: 5px; - border-bottom-left-radius: 5px; - } - &:last-child { - border-top-right-radius: 5px; - border-bottom-right-radius: 5px; - } - &:disabled { - background-color: #f5f5f5; - pointer-events: none; - cursor: not-allowed; - } + + .ngx-toolbar-set { + display: inline-block; + border: 1px solid #ddd; + border-radius: 5px; + background-color: white; + + .ngx-editor-button { + background-color: #f5f5f5; + background-color: transparent; + border: 0; + padding: 0.4rem; + min-width: 2.5rem; + float: left; + border-right: 1px solid #ddd; + + &:hover { + cursor: pointer; + background-color: #f1f1f1; + transition: 0.2s ease; + } + + &:focus, + &.focus { + outline: 0; + } + + &:last-child { + border-right: transparent; + } + + &:first-child { + border-top-left-radius: 5px; + border-bottom-left-radius: 5px; + } + + &:last-child { + border-top-right-radius: 5px; + border-bottom-right-radius: 5px; + } + + &:disabled { + background-color: #f5f5f5; + pointer-events: none; + cursor: not-allowed; + } + } } - } } diff --git a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts index 25604549..66bdb084 100644 --- a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts +++ b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.ts @@ -13,8 +13,7 @@ export class NgxToolbarComponent { @Input() enableToolbar = false; @Output('triggerCommand') _triggerCommand = new EventEmitter(); - constructor() { - } + constructor() { } /* * enable or diable toolbar based on configuration From 0f43193c0a42d2197a24efa31cfaae48dc1c0b20 Mon Sep 17 00:00:00 2001 From: Sibiraj Date: Tue, 21 Nov 2017 21:28:56 +0530 Subject: [PATCH 13/18] chore: organise files --- src/app/ngx-editor/{ => common/services}/command-executor.ts | 0 src/app/ngx-editor/ngx-editor.component.spec.ts | 2 +- src/app/ngx-editor/ngx-editor.component.ts | 2 +- src/app/ngx-editor/ngx-editor.module.ts | 2 +- src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts | 2 +- 5 files changed, 4 insertions(+), 4 deletions(-) rename src/app/ngx-editor/{ => common/services}/command-executor.ts (100%) diff --git a/src/app/ngx-editor/command-executor.ts b/src/app/ngx-editor/common/services/command-executor.ts similarity index 100% rename from src/app/ngx-editor/command-executor.ts rename to src/app/ngx-editor/common/services/command-executor.ts diff --git a/src/app/ngx-editor/ngx-editor.component.spec.ts b/src/app/ngx-editor/ngx-editor.component.spec.ts index 9cdb173c..7a0b51b7 100644 --- a/src/app/ngx-editor/ngx-editor.component.spec.ts +++ b/src/app/ngx-editor/ngx-editor.component.spec.ts @@ -5,7 +5,7 @@ import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; import { MessageService } from './ngx-editor-message/message.service'; -import { CommandExecutor } from './command-executor'; +import { CommandExecutor } from './common/services/command-executor'; describe('NgxEditorComponent', () => { let component: NgxEditorComponent; diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index 6a2434b6..c4179ed4 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -1,6 +1,6 @@ import { Component, OnInit, HostListener, Input, Output, ElementRef, EventEmitter, ViewChild } from '@angular/core'; import { ngxEditorConfig } from './ngx-editor.defaults'; -import { CommandExecutor } from './command-executor'; +import { CommandExecutor } from './common/services/command-executor'; import { MessageService } from './ngx-editor-message/message.service'; @Component({ diff --git a/src/app/ngx-editor/ngx-editor.module.ts b/src/app/ngx-editor/ngx-editor.module.ts index f82a82f8..1da6f7a9 100644 --- a/src/app/ngx-editor/ngx-editor.module.ts +++ b/src/app/ngx-editor/ngx-editor.module.ts @@ -5,7 +5,7 @@ import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; import { MessageService } from './ngx-editor-message/message.service'; -import { CommandExecutor } from './command-executor'; +import { CommandExecutor } from './common/services/command-executor'; @NgModule({ imports: [ diff --git a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts index 003839f3..26e8ea4d 100644 --- a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts +++ b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts @@ -4,7 +4,7 @@ import { ElementRef } from '@angular/core'; import { NgxGrippieComponent } from './ngx-grippie.component'; import { NgxEditorComponent } from '../ngx-editor.component'; import { MessageService } from '../ngx-editor-message/message.service'; -import { CommandExecutor } from '../command-executor'; +import { CommandExecutor } from '../common/services/command-executor'; export class MockElementRef extends ElementRef { constructor() { super(null); } From 1bcc021d38eaaa0e25735c2f88600a81fb2b2acd Mon Sep 17 00:00:00 2001 From: Sibiraj Date: Tue, 21 Nov 2017 21:40:40 +0530 Subject: [PATCH 14/18] chore: organise files --- .../services}/message.service.ts | 5 ++--- .../ngx-editor-message/ngx-editor-message.component.spec.ts | 2 +- .../ngx-editor-message/ngx-editor-message.component.ts | 2 +- src/app/ngx-editor/ngx-editor.component.spec.ts | 2 +- src/app/ngx-editor/ngx-editor.component.ts | 2 +- src/app/ngx-editor/ngx-editor.module.ts | 2 +- src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts | 2 +- 7 files changed, 8 insertions(+), 9 deletions(-) rename src/app/ngx-editor/{ngx-editor-message => common/services}/message.service.ts (96%) diff --git a/src/app/ngx-editor/ngx-editor-message/message.service.ts b/src/app/ngx-editor/common/services/message.service.ts similarity index 96% rename from src/app/ngx-editor/ngx-editor-message/message.service.ts rename to src/app/ngx-editor/common/services/message.service.ts index 08eb0e4b..dd15966e 100644 --- a/src/app/ngx-editor/ngx-editor-message/message.service.ts +++ b/src/app/ngx-editor/common/services/message.service.ts @@ -1,7 +1,7 @@ import { Injectable } from '@angular/core'; -import 'rxjs/add/operator/map'; import { Subject } from 'rxjs/Subject'; import { Observable } from 'rxjs/Observable'; +import 'rxjs/add/operator/map'; const FIVE_SECONDS = 5000; @@ -9,8 +9,7 @@ const FIVE_SECONDS = 5000; export class MessageService { private message: Subject = new Subject(); - constructor() { - } + constructor() { } messages(): Observable { return this.message.asObservable(); diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts index 2bcb15c2..6cb21838 100644 --- a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.spec.ts @@ -1,7 +1,7 @@ import { async, ComponentFixture, TestBed } from '@angular/core/testing'; import { NgxEditorMessageComponent } from './ngx-editor-message.component'; -import { MessageService } from './message.service'; +import { MessageService } from '../common/services/message.service'; describe('NgxEditorMessageComponent', () => { let component: NgxEditorMessageComponent; diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts index 597ed301..34b579c4 100644 --- a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts @@ -1,5 +1,5 @@ import { Component } from '@angular/core'; -import { MessageService } from './message.service'; +import { MessageService } from '../common/services/message.service'; @Component({ diff --git a/src/app/ngx-editor/ngx-editor.component.spec.ts b/src/app/ngx-editor/ngx-editor.component.spec.ts index 7a0b51b7..11da1560 100644 --- a/src/app/ngx-editor/ngx-editor.component.spec.ts +++ b/src/app/ngx-editor/ngx-editor.component.spec.ts @@ -4,7 +4,7 @@ import { NgxEditorComponent } from './ngx-editor.component'; import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; -import { MessageService } from './ngx-editor-message/message.service'; +import { MessageService } from './common/services/message.service'; import { CommandExecutor } from './common/services/command-executor'; describe('NgxEditorComponent', () => { diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index c4179ed4..0fbe3a68 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -1,7 +1,7 @@ import { Component, OnInit, HostListener, Input, Output, ElementRef, EventEmitter, ViewChild } from '@angular/core'; import { ngxEditorConfig } from './ngx-editor.defaults'; import { CommandExecutor } from './common/services/command-executor'; -import { MessageService } from './ngx-editor-message/message.service'; +import { MessageService } from './common/services/message.service'; @Component({ selector: 'app-ngx-editor', diff --git a/src/app/ngx-editor/ngx-editor.module.ts b/src/app/ngx-editor/ngx-editor.module.ts index 1da6f7a9..8c5b7af8 100644 --- a/src/app/ngx-editor/ngx-editor.module.ts +++ b/src/app/ngx-editor/ngx-editor.module.ts @@ -4,7 +4,7 @@ import { NgxEditorComponent } from './ngx-editor.component'; import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; -import { MessageService } from './ngx-editor-message/message.service'; +import { MessageService } from './common/services/message.service'; import { CommandExecutor } from './common/services/command-executor'; @NgModule({ diff --git a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts index 26e8ea4d..b825f04a 100644 --- a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts +++ b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts @@ -3,7 +3,7 @@ import { ElementRef } from '@angular/core'; import { NgxGrippieComponent } from './ngx-grippie.component'; import { NgxEditorComponent } from '../ngx-editor.component'; -import { MessageService } from '../ngx-editor-message/message.service'; +import { MessageService } from '../common/services/message.service'; import { CommandExecutor } from '../common/services/command-executor'; export class MockElementRef extends ElementRef { From 6f7751c480b3b146e27264fd0084c7aba9f60197 Mon Sep 17 00:00:00 2001 From: Sibiraj Date: Tue, 21 Nov 2017 22:04:55 +0530 Subject: [PATCH 15/18] chore: add spec files --- .../services/command-executor.service.spec.ts | 15 ++++++++++ ...xecutor.ts => command-executor.service.ts} | 3 +- .../common/services/message.service.spec.ts | 15 ++++++++++ .../common/services/message.service.ts | 2 ++ .../ngx-editor/ngx-editor.component.spec.ts | 4 +-- src/app/ngx-editor/ngx-editor.component.ts | 8 ++++-- src/app/ngx-editor/ngx-editor.module.ts | 4 +-- .../ngx-grippie/ngx-grippie.component.spec.ts | 4 +-- .../ngx-toolbar/ngx-toolbar.component.spec.ts | 28 +++++++++++++++++++ 9 files changed, 73 insertions(+), 10 deletions(-) create mode 100644 src/app/ngx-editor/common/services/command-executor.service.spec.ts rename src/app/ngx-editor/common/services/{command-executor.ts => command-executor.service.ts} (97%) create mode 100644 src/app/ngx-editor/common/services/message.service.spec.ts create mode 100644 src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.spec.ts diff --git a/src/app/ngx-editor/common/services/command-executor.service.spec.ts b/src/app/ngx-editor/common/services/command-executor.service.spec.ts new file mode 100644 index 00000000..7728715a --- /dev/null +++ b/src/app/ngx-editor/common/services/command-executor.service.spec.ts @@ -0,0 +1,15 @@ +import { TestBed, inject } from '@angular/core/testing'; + +import { CommandExecutorService } from './command-executor.service'; + +describe('CommandExecutorService', () => { + beforeEach(() => { + TestBed.configureTestingModule({ + providers: [CommandExecutorService] + }); + }); + + it('should be created', inject([CommandExecutorService], (service: CommandExecutorService) => { + expect(service).toBeTruthy(); + })); +}); diff --git a/src/app/ngx-editor/common/services/command-executor.ts b/src/app/ngx-editor/common/services/command-executor.service.ts similarity index 97% rename from src/app/ngx-editor/common/services/command-executor.ts rename to src/app/ngx-editor/common/services/command-executor.service.ts index f4078208..821da4be 100644 --- a/src/app/ngx-editor/common/services/command-executor.ts +++ b/src/app/ngx-editor/common/services/command-executor.service.ts @@ -1,7 +1,7 @@ import { Injectable } from '@angular/core'; @Injectable() -export class CommandExecutor { +export class CommandExecutorService { public execute(command: string): void { if (command === 'enableObjectResizing') { @@ -61,4 +61,5 @@ export class CommandExecutor { } } } + } diff --git a/src/app/ngx-editor/common/services/message.service.spec.ts b/src/app/ngx-editor/common/services/message.service.spec.ts new file mode 100644 index 00000000..63ecfd8f --- /dev/null +++ b/src/app/ngx-editor/common/services/message.service.spec.ts @@ -0,0 +1,15 @@ +import { TestBed, inject } from '@angular/core/testing'; + +import { MessageService } from './message.service'; + +describe('MessageService', () => { + beforeEach(() => { + TestBed.configureTestingModule({ + providers: [MessageService] + }); + }); + + it('should be created', inject([MessageService], (service: MessageService) => { + expect(service).toBeTruthy(); + })); +}); diff --git a/src/app/ngx-editor/common/services/message.service.ts b/src/app/ngx-editor/common/services/message.service.ts index dd15966e..edfe5b4d 100644 --- a/src/app/ngx-editor/common/services/message.service.ts +++ b/src/app/ngx-editor/common/services/message.service.ts @@ -7,6 +7,7 @@ const FIVE_SECONDS = 5000; @Injectable() export class MessageService { + private message: Subject = new Subject(); constructor() { } @@ -25,4 +26,5 @@ export class MessageService { this.message.next(undefined); }, milliseconds); } + } diff --git a/src/app/ngx-editor/ngx-editor.component.spec.ts b/src/app/ngx-editor/ngx-editor.component.spec.ts index 11da1560..e69d7b1d 100644 --- a/src/app/ngx-editor/ngx-editor.component.spec.ts +++ b/src/app/ngx-editor/ngx-editor.component.spec.ts @@ -5,7 +5,7 @@ import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; import { MessageService } from './common/services/message.service'; -import { CommandExecutor } from './common/services/command-executor'; +import { CommandExecutorService } from './common/services/command-executor.service'; describe('NgxEditorComponent', () => { let component: NgxEditorComponent; @@ -13,7 +13,7 @@ describe('NgxEditorComponent', () => { beforeEach(async(() => { TestBed.configureTestingModule({ - providers: [MessageService, CommandExecutor], + providers: [MessageService, CommandExecutorService], declarations: [NgxEditorComponent, NgxGrippieComponent, NgxToolbarComponent, diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index 0fbe3a68..640e7380 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -1,6 +1,6 @@ import { Component, OnInit, HostListener, Input, Output, ElementRef, EventEmitter, ViewChild } from '@angular/core'; import { ngxEditorConfig } from './ngx-editor.defaults'; -import { CommandExecutor } from './common/services/command-executor'; +import { CommandExecutorService } from './common/services/command-executor.service'; import { MessageService } from './common/services/message.service'; @Component({ @@ -85,8 +85,10 @@ export class NgxEditorComponent implements OnInit { } } - constructor(private _element: ElementRef, private messageService: MessageService, private commandExecutor: CommandExecutor) { - } + constructor( + private _element: ElementRef, + private messageService: MessageService, + private commandExecutor: CommandExecutorService) { } /* * focus event diff --git a/src/app/ngx-editor/ngx-editor.module.ts b/src/app/ngx-editor/ngx-editor.module.ts index 8c5b7af8..d94521e2 100644 --- a/src/app/ngx-editor/ngx-editor.module.ts +++ b/src/app/ngx-editor/ngx-editor.module.ts @@ -5,7 +5,7 @@ import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; import { MessageService } from './common/services/message.service'; -import { CommandExecutor } from './common/services/command-executor'; +import { CommandExecutorService } from './common/services/command-executor.service'; @NgModule({ imports: [ @@ -13,7 +13,7 @@ import { CommandExecutor } from './common/services/command-executor'; ], declarations: [NgxEditorComponent, NgxGrippieComponent, NgxToolbarComponent, NgxEditorMessageComponent], exports: [NgxEditorComponent, NgxGrippieComponent], - providers: [CommandExecutor, MessageService] + providers: [CommandExecutorService, MessageService] }) export class NgxEditorModule { } diff --git a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts index b825f04a..83fabfdf 100644 --- a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts +++ b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.spec.ts @@ -4,7 +4,7 @@ import { ElementRef } from '@angular/core'; import { NgxGrippieComponent } from './ngx-grippie.component'; import { NgxEditorComponent } from '../ngx-editor.component'; import { MessageService } from '../common/services/message.service'; -import { CommandExecutor } from '../common/services/command-executor'; +import { CommandExecutorService } from '../common/services/command-executor.service'; export class MockElementRef extends ElementRef { constructor() { super(null); } @@ -20,7 +20,7 @@ describe('NgxGrippieComponent', () => { providers: [ NgxEditorComponent, MessageService, - CommandExecutor, + CommandExecutorService, { provide: ElementRef, useClass: MockElementRef }] }) .compileComponents(); diff --git a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.spec.ts b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.spec.ts new file mode 100644 index 00000000..982c9621 --- /dev/null +++ b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.spec.ts @@ -0,0 +1,28 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { NgxToolbarComponent } from './ngx-toolbar.component'; +import { ngxEditorConfig } from '../ngx-editor.defaults'; + +describe('NgxToolbarComponent', () => { + let component: NgxToolbarComponent; + let fixture: ComponentFixture; + + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [NgxToolbarComponent] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(NgxToolbarComponent); + component = fixture.componentInstance; + component.config = ngxEditorConfig; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); From 234cc92b1c31ee1d16a63d3d963f45c6ea7b9fdd Mon Sep 17 00:00:00 2001 From: Sibiraj Date: Tue, 21 Nov 2017 22:26:54 +0530 Subject: [PATCH 16/18] chore: add directory TREE structure --- TREE.md | 111 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 111 insertions(+) create mode 100644 TREE.md diff --git a/TREE.md b/TREE.md new file mode 100644 index 00000000..f7acd3a2 --- /dev/null +++ b/TREE.md @@ -0,0 +1,111 @@ +``` +. +├── e2e +│   ├── app.e2e-spec.ts +│   ├── app.po.ts +│   └── tsconfig.e2e.json +├── scripts +│   ├── build.sh +│   └── release.sh +├── src +│   ├── app +│   │   ├── ngx-editor +│   │   │   ├── common +│   │   │   │   └── services +│   │   │   │   ├── command-executor.service.spec.ts +│   │   │   │   ├── command-executor.service.ts +│   │   │   │   ├── message.service.spec.ts +│   │   │   │   └── message.service.ts +│   │   │   ├── ngx-editor-message +│   │   │   │   ├── ngx-editor-message.component.html +│   │   │   │   ├── ngx-editor-message.component.scss +│   │   │   │   ├── ngx-editor-message.component.spec.ts +│   │   │   │   └── ngx-editor-message.component.ts +│   │   │   ├── ngx-grippie +│   │   │   │   ├── ngx-grippie.component.html +│   │   │   │   ├── ngx-grippie.component.scss +│   │   │   │   ├── ngx-grippie.component.spec.ts +│   │   │   │   └── ngx-grippie.component.ts +│   │   │   ├── ngx-toolbar +│   │   │   │   ├── ngx-editor.utils.ts +│   │   │   │   ├── ngx-toolbar.component.html +│   │   │   │   ├── ngx-toolbar.component.scss +│   │   │   │   ├── ngx-toolbar.component.spec.ts +│   │   │   │   └── ngx-toolbar.component.ts +│   │   │   ├── ngx-editor.component.html +│   │   │   ├── ngx-editor.component.scss +│   │   │   ├── ngx-editor.component.spec.ts +│   │   │   ├── ngx-editor.component.ts +│   │   │   ├── ngx-editor.defaults.ts +│   │   │   └── ngx-editor.module.ts +│   │   ├── app.component.html +│   │   ├── app.component.scss +│   │   ├── app.component.spec.ts +│   │   ├── app.component.ts +│   │   ├── app.module.ts +│   │   ├── app.service.spec.ts +│   │   └── app.service.ts +│   ├── assets +│   │   └── icons +│   │   ├── ngx-editor-opt1 +│   │   │   ├── ang_edit1_128.ico +│   │   │   ├── ang_edit1_128.png +│   │   │   ├── ang_edit1_256.ico +│   │   │   ├── ang_edit1_256.png +│   │   │   ├── ang_edit1_32.png +│   │   │   ├── ang_edit1_64.ico +│   │   │   ├── ang_edit1_64.png +│   │   │   ├── ang_editv1_32_128.ico +│   │   │   ├── ang_editv1_32_256.ico +│   │   │   ├── ngx-editor1_64x64.ico +│   │   │   ├── ngx-editor1.gvdesign +│   │   │   ├── ngx-editor1.png +│   │   │   └── ngx-editor1.svg +│   │   ├── ngx-editor-opt2 +│   │   │   ├── ang_editv4_128.ico +│   │   │   ├── ang_editv4_128.png +│   │   │   ├── ang_editv4_256.ico +│   │   │   ├── ang_editv4_256.png +│   │   │   ├── ang_editv4_32_128.ico +│   │   │   ├── ang_editv4_32_256.ico +│   │   │   ├── ang_editv4_32.ico +│   │   │   ├── ang_editv4_32.png +│   │   │   ├── ang_editv4_64.ico +│   │   │   ├── ang_editv4_64.png +│   │   │   ├── ngx-editor2_64x64.ico +│   │   │   ├── ngx-editor2.gvdesign +│   │   │   ├── ngx-editor2.png +│   │   │   └── ngx-editor2.svg +│   │   ├── ngx-editor.png +│   │   └── ngx-editor.svg +│   ├── environments +│   │   ├── environment.prod.ts +│   │   └── environment.ts +│   ├── favicon.ico +│   ├── index.html +│   ├── main.ts +│   ├── polyfills.ts +│   ├── styles.scss +│   ├── test.ts +│   ├── tsconfig.app.json +│   ├── tsconfig.spec.json +│   └── typings.d.ts +├── .vscode +│   └── settings.json +├── .angular-cli.json +├── .editorconfig +├── karma.conf.js +├── LICENSE +├── ng-package.json +├── package.json +├── package-lock.json +├── protractor.conf.js +├── public_api.ts +├── .pullapprove.yml +├── README.md +├── .travis.yml +├── TREE.md +├── tsconfig.json +├── tslint.json +└── yarn.lock +``` From 0630f7b94d05f6e750a4997d5469db09a98cee8b Mon Sep 17 00:00:00 2001 From: Sibiraj Date: Wed, 22 Nov 2017 00:05:04 +0530 Subject: [PATCH 17/18] chchore: linting and naming --- .../services/command-executor.service.ts | 9 +++---- .../common/services/message.service.ts | 8 +++---- .../ngx-editor-message.component.ts | 7 +++--- src/app/ngx-editor/ngx-editor.component.html | 3 +++ src/app/ngx-editor/ngx-editor.component.ts | 24 +++++++++---------- src/app/ngx-editor/ngx-editor.module.ts | 4 ++++ .../ngx-grippie/ngx-grippie.component.ts | 8 +++---- .../ngx-toolbar/ngx-toolbar.component.html | 2 +- .../ngx-toolbar/ngx-toolbar.component.ts | 6 ++--- tsconfig.json | 2 +- 10 files changed, 39 insertions(+), 34 deletions(-) diff --git a/src/app/ngx-editor/common/services/command-executor.service.ts b/src/app/ngx-editor/common/services/command-executor.service.ts index 821da4be..82841977 100644 --- a/src/app/ngx-editor/common/services/command-executor.service.ts +++ b/src/app/ngx-editor/common/services/command-executor.service.ts @@ -4,18 +4,19 @@ import { Injectable } from '@angular/core'; export class CommandExecutorService { public execute(command: string): void { + if (command === 'enableObjectResizing') { document.execCommand('enableObjectResizing', true, true); return; } - if (command === 'removeBlockquote') { - document.execCommand('formatBlock', false, 'div'); + if (command === 'blockquote') { + document.execCommand('formatBlock', false, '
'); return; } - if (command === 'blockquote') { - document.execCommand('formatBlock', false, '
'); + if (command === 'removeBlockquote') { + document.execCommand('formatBlock', false, 'div'); return; } diff --git a/src/app/ngx-editor/common/services/message.service.ts b/src/app/ngx-editor/common/services/message.service.ts index edfe5b4d..a8758487 100644 --- a/src/app/ngx-editor/common/services/message.service.ts +++ b/src/app/ngx-editor/common/services/message.service.ts @@ -12,16 +12,16 @@ export class MessageService { constructor() { } - messages(): Observable { + getMessage(): Observable { return this.message.asObservable(); } - send(message: string) { + sendMessage(message: string) { this.message.next(message); - this.clearMessageOn(FIVE_SECONDS); + this.clearMessageIn(FIVE_SECONDS); } - private clearMessageOn(milliseconds: number): void { + private clearMessageIn(milliseconds: number): void { setTimeout(() => { this.message.next(undefined); }, milliseconds); diff --git a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts index 34b579c4..3fbbcbf7 100644 --- a/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts +++ b/src/app/ngx-editor/ngx-editor-message/ngx-editor-message.component.ts @@ -1,18 +1,19 @@ import { Component } from '@angular/core'; -import { MessageService } from '../common/services/message.service'; +import { MessageService } from '../common/services/message.service'; @Component({ selector: 'app-ngx-editor-message', templateUrl: './ngx-editor-message.component.html', styleUrls: ['./ngx-editor-message.component.scss'] }) + export class NgxEditorMessageComponent { ngxMessage = ''; - constructor(private messageService: MessageService) { - this.messageService.messages().subscribe((message: string) => this.ngxMessage = message); + constructor(private _messageService: MessageService) { + this._messageService.getMessage().subscribe((message: string) => this.ngxMessage = message); } clearMessage() { diff --git a/src/app/ngx-editor/ngx-editor.component.html b/src/app/ngx-editor/ngx-editor.component.html index 788c2521..16ae872a 100644 --- a/src/app/ngx-editor/ngx-editor.component.html +++ b/src/app/ngx-editor/ngx-editor.component.html @@ -1,11 +1,14 @@
+
+ +
diff --git a/src/app/ngx-editor/ngx-editor.component.ts b/src/app/ngx-editor/ngx-editor.component.ts index 640e7380..11aaad53 100644 --- a/src/app/ngx-editor/ngx-editor.component.ts +++ b/src/app/ngx-editor/ngx-editor.component.ts @@ -1,4 +1,5 @@ -import { Component, OnInit, HostListener, Input, Output, ElementRef, EventEmitter, ViewChild } from '@angular/core'; +import { Component, OnInit, Input, Output, ViewChild, HostListener, ElementRef, EventEmitter } from '@angular/core'; + import { ngxEditorConfig } from './ngx-editor.defaults'; import { CommandExecutorService } from './common/services/command-executor.service'; import { MessageService } from './common/services/message.service'; @@ -32,7 +33,6 @@ export class NgxEditorComponent implements OnInit { // set resizer @Input() set resizer(value: string) { - console.log(value); if (value === 'basic') { this._resizer = value; } else { @@ -65,8 +65,7 @@ export class NgxEditorComponent implements OnInit { } // set HTML value - @Input() - set html(value: any) { + @Input() set html(value: any) { this._html = value; } @@ -77,7 +76,7 @@ export class NgxEditorComponent implements OnInit { /* * update html on changes in content editable */ - htmlContentChange(value) { + htmlContentChange(value: string) { if (value === '
') { this.htmlChange.emit(''); } else { @@ -87,8 +86,8 @@ export class NgxEditorComponent implements OnInit { constructor( private _element: ElementRef, - private messageService: MessageService, - private commandExecutor: CommandExecutorService) { } + private _messageService: MessageService, + private _commandExecutor: CommandExecutorService) { } /* * focus event @@ -97,15 +96,14 @@ export class NgxEditorComponent implements OnInit { this.enableToolbar = true; } - @HostListener('document:click', ['$event']) - onDocumentClick(event) { + @HostListener('document:click', ['$event']) onDocumentClick(event) { this.enableToolbar = !!this._element.nativeElement.contains(event.target); } /* * resizing text area */ - resizeTextArea(offsetY) { + resizeTextArea(offsetY: number) { let newHeight = parseInt(this.height, 10); newHeight += offsetY; this.height = newHeight + 'px'; @@ -134,11 +132,11 @@ export class NgxEditorComponent implements OnInit { /* * editor actions */ - executeCommand(commandName) { + executeCommand(commandName: string) { try { - this.commandExecutor.execute(commandName); + this._commandExecutor.execute(commandName); } catch (error) { - this.messageService.send(error.message); + this._messageService.sendMessage(error.message); } } } diff --git a/src/app/ngx-editor/ngx-editor.module.ts b/src/app/ngx-editor/ngx-editor.module.ts index d94521e2..a43a7c0b 100644 --- a/src/app/ngx-editor/ngx-editor.module.ts +++ b/src/app/ngx-editor/ngx-editor.module.ts @@ -1,9 +1,13 @@ import { NgModule } from '@angular/core'; import { CommonModule } from '@angular/common'; + +// components import { NgxEditorComponent } from './ngx-editor.component'; import { NgxGrippieComponent } from './ngx-grippie/ngx-grippie.component'; import { NgxToolbarComponent } from './ngx-toolbar/ngx-toolbar.component'; import { NgxEditorMessageComponent } from './ngx-editor-message/ngx-editor-message.component'; + +// services import { MessageService } from './common/services/message.service'; import { CommandExecutorService } from './common/services/command-executor.service'; diff --git a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.ts b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.ts index 0d40445b..d2ddd6b9 100644 --- a/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.ts +++ b/src/app/ngx-editor/ngx-grippie/ngx-grippie.component.ts @@ -1,4 +1,4 @@ -import { Component, OnInit, HostListener, EventEmitter } from '@angular/core'; +import { Component, OnInit, HostListener } from '@angular/core'; import { NgxEditorComponent } from '../ngx-editor.component'; @Component({ @@ -15,8 +15,7 @@ export class NgxGrippieComponent { constructor(private _editorComponent: NgxEditorComponent) { } - @HostListener('document:mousemove', ['$event']) - onMouseMove(event: MouseEvent) { + @HostListener('document:mousemove', ['$event']) onMouseMove(event: MouseEvent) { if (!this.grabber) { return; @@ -26,8 +25,7 @@ export class NgxGrippieComponent { this.oldY = event.clientY; } - @HostListener('document:mouseup', ['$event']) - onMouseUp(event: MouseEvent) { + @HostListener('document:mouseup', ['$event']) onMouseUp(event: MouseEvent) { this.grabber = false; } diff --git a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html index 47f314d7..f2203118 100644 --- a/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html +++ b/src/app/ngx-editor/ngx-toolbar/ngx-toolbar.component.html @@ -1,4 +1,4 @@ - +