Fixes after review

This commit is contained in:
PiotrP 2018-11-13 15:10:24 -08:00
parent 0e35d1c7f6
commit 618f966361
6 changed files with 27 additions and 31 deletions

View File

@ -71,6 +71,7 @@ import { SnapshotsComponent } from './components/snapshots/snapshots.component';
import { SnapshotMenuItemComponent } from './components/snapshots/snapshot-menu-item/snapshot-menu-item.component'; import { SnapshotMenuItemComponent } from './components/snapshots/snapshot-menu-item/snapshot-menu-item.component';
import { MATERIAL_IMPORTS } from './material.imports'; import { MATERIAL_IMPORTS } from './material.imports';
import { DrawingService } from './services/drawing.service'; import { DrawingService } from './services/drawing.service';
import { ProjectNameValidator } from './components/projects/models/projectNameValidator';
if (environment.production) { if (environment.production) {
@ -155,7 +156,8 @@ if (environment.production) {
InRectangleHelper, InRectangleHelper,
DrawingsDataSource, DrawingsDataSource,
ServerErrorHandler, ServerErrorHandler,
ServerDatabase ServerDatabase,
ProjectNameValidator
], ],
entryComponents: [ entryComponents: [
AddServerDialogComponent, AddServerDialogComponent,

View File

@ -1,11 +1,9 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing'; import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { AddBlankProjectDialogComponent } from "./add-blank-project-dialog.component"; import { AddBlankProjectDialogComponent } from "./add-blank-project-dialog.component";
import { Server } from "../../../models/server"; import { Server } from "../../../models/server";
import { FormBuilder, ReactiveFormsModule, FormsModule, Validators, FormControl } from '@angular/forms'; import { ReactiveFormsModule, FormsModule } from '@angular/forms';
import { MatDialogModule, MatInputModule, MatFormFieldModule, MatDialogRef, MAT_DIALOG_DATA, MatSnackBarModule } from '@angular/material'; import { MatDialogModule, MatInputModule, MatFormFieldModule, MatDialogRef, MAT_DIALOG_DATA, MatSnackBarModule } from '@angular/material';
import { NoopAnimationsModule } from '@angular/platform-browser/animations'; import { NoopAnimationsModule } from '@angular/platform-browser/animations';
import { DebugElement } from '@angular/core';
import { Validator } from '../models/validator';
import { ProjectService } from '../../../services/project.service'; import { ProjectService } from '../../../services/project.service';
import { ToasterService } from '../../../services/toaster.service'; import { ToasterService } from '../../../services/toaster.service';
import { of } from 'rxjs/internal/observable/of'; import { of } from 'rxjs/internal/observable/of';
@ -30,11 +28,11 @@ export class MockedProjectService {
snap_to_grid: false, snap_to_grid: false,
}]; }];
list(server: Server) { list() {
return of(this.projects); return of(this.projects);
} }
add(server: Server, projectname: string, uuid: string){ add(){
return of(this.projects.pop); return of(this.projects.pop);
} }
} }
@ -43,7 +41,6 @@ describe('AddBlankProjectDialogComponent', () => {
let component: AddBlankProjectDialogComponent; let component: AddBlankProjectDialogComponent;
let fixture: ComponentFixture<AddBlankProjectDialogComponent>; let fixture: ComponentFixture<AddBlankProjectDialogComponent>;
let server: Server; let server: Server;
let formBuilder: FormBuilder;
beforeEach(async(() => { beforeEach(async(() => {
TestBed.configureTestingModule({ TestBed.configureTestingModule({
@ -69,16 +66,12 @@ describe('AddBlankProjectDialogComponent', () => {
server = new Server(); server = new Server();
server.ip = "localhost"; server.ip = "localhost";
server.port = 80; server.port = 80;
formBuilder = new FormBuilder();
})); }));
beforeEach(() => { beforeEach(() => {
fixture = TestBed.createComponent(AddBlankProjectDialogComponent); fixture = TestBed.createComponent(AddBlankProjectDialogComponent);
component = fixture.componentInstance; component = fixture.componentInstance;
component.server = server; component.server = server;
component.projectNameForm = formBuilder.group({
projectName: new FormControl(null, [Validators.required, Validator.projectNameValidator])
});
component.projectNameForm.controls['projectName'].setValue("ValidName"); component.projectNameForm.controls['projectName'].setValue("ValidName");
fixture.detectChanges(); fixture.detectChanges();
}) })

View File

@ -6,13 +6,14 @@ import { Server } from '../../../models/server';
import { ProjectService } from '../../../services/project.service'; import { ProjectService } from '../../../services/project.service';
import { v4 as uuid } from 'uuid'; import { v4 as uuid } from 'uuid';
import { ConfirmationDialogComponent } from '../confirmation-dialog/confirmation-dialog.component'; import { ConfirmationDialogComponent } from '../confirmation-dialog/confirmation-dialog.component';
import { Validator } from '../models/validator'; import { ProjectNameValidator } from '../models/projectNameValidator';
import { ToasterService } from '../../../services/toaster.service'; import { ToasterService } from '../../../services/toaster.service';
@Component({ @Component({
selector: 'app-add-blank-project-dialog', selector: 'app-add-blank-project-dialog',
templateUrl: './add-blank-project-dialog.component.html', templateUrl: './add-blank-project-dialog.component.html',
styleUrls: ['./add-blank-project-dialog.component.css'] styleUrls: ['./add-blank-project-dialog.component.css'],
providers: [ProjectNameValidator]
}) })
export class AddBlankProjectDialogComponent implements OnInit { export class AddBlankProjectDialogComponent implements OnInit {
server: Server; server: Server;
@ -23,9 +24,10 @@ export class AddBlankProjectDialogComponent implements OnInit {
private dialog: MatDialog, private dialog: MatDialog,
private projectService: ProjectService, private projectService: ProjectService,
private toasterService: ToasterService, private toasterService: ToasterService,
private formBuilder: FormBuilder) { private formBuilder: FormBuilder,
private projectNameValidator: ProjectNameValidator) {
this.projectNameForm = this.formBuilder.group({ this.projectNameForm = this.formBuilder.group({
projectName: new FormControl(null, [Validators.required, Validator.projectNameValidator]) projectName: new FormControl(null, [Validators.required, projectNameValidator.get])
}); });
} }

View File

@ -4,14 +4,13 @@ import { Server } from "../../../models/server";
import { MatInputModule, MatIconModule, MatSortModule, MatTableModule, MatTooltipModule, MatDialogModule, MatFormFieldModule, MatDialogRef, MAT_DIALOG_DATA } from "@angular/material"; import { MatInputModule, MatIconModule, MatSortModule, MatTableModule, MatTooltipModule, MatDialogModule, MatFormFieldModule, MatDialogRef, MAT_DIALOG_DATA } from "@angular/material";
import { RouterTestingModule } from "@angular/router/testing"; import { RouterTestingModule } from "@angular/router/testing";
import { NoopAnimationsModule } from "@angular/platform-browser/animations"; import { NoopAnimationsModule } from "@angular/platform-browser/animations";
import { FileUploadModule, FileSelectDirective, FileItem, FileUploader, ParsedResponseHeaders } from "ng2-file-upload"; import { FileUploadModule, FileSelectDirective, FileItem, ParsedResponseHeaders } from "ng2-file-upload";
import { FormsModule, ReactiveFormsModule, FormBuilder, FormControl, Validators } from '@angular/forms'; import { FormsModule, ReactiveFormsModule } from '@angular/forms';
import { DebugElement } from '@angular/core'; import { DebugElement } from '@angular/core';
import { By } from '@angular/platform-browser'; import { By } from '@angular/platform-browser';
import { ProjectService } from '../../../services/project.service'; import { ProjectService } from '../../../services/project.service';
import { of } from 'rxjs/internal/observable/of'; import { of } from 'rxjs/internal/observable/of';
import { Project } from '../../../models/project'; import { Project } from '../../../models/project';
import { Validator } from '../models/validator';
export class MockedProjectService { export class MockedProjectService {
public projects: Project[] = [{ public projects: Project[] = [{
@ -32,7 +31,7 @@ export class MockedProjectService {
snap_to_grid: false, snap_to_grid: false,
}]; }];
list(server: Server) { list() {
return of(this.projects); return of(this.projects);
} }
} }
@ -43,7 +42,6 @@ describe('ImportProjectDialogComponent', () => {
let server: Server; let server: Server;
let debugElement: DebugElement; let debugElement: DebugElement;
let fileSelectDirective: FileSelectDirective; let fileSelectDirective: FileSelectDirective;
let formBuilder: FormBuilder;
beforeEach(async(() => { beforeEach(async(() => {
TestBed.configureTestingModule({ TestBed.configureTestingModule({
@ -73,7 +71,6 @@ describe('ImportProjectDialogComponent', () => {
server = new Server(); server = new Server();
server.ip = "localhost"; server.ip = "localhost";
server.port = 80; server.port = 80;
formBuilder = new FormBuilder();
})); }));
beforeEach(() => { beforeEach(() => {
@ -81,15 +78,12 @@ describe('ImportProjectDialogComponent', () => {
debugElement = fixture.debugElement; debugElement = fixture.debugElement;
component = fixture.componentInstance; component = fixture.componentInstance;
component.server = server; component.server = server;
component.projectNameForm = formBuilder.group({
projectName: new FormControl(null, [Validators.required, Validator.projectNameValidator])
});
component.projectNameForm.controls['projectName'].setValue("ValidName"); component.projectNameForm.controls['projectName'].setValue("ValidName");
fixture.detectChanges(); fixture.detectChanges();
debugElement = fixture.debugElement.query(By.directive(FileSelectDirective)); debugElement = fixture.debugElement.query(By.directive(FileSelectDirective));
fileSelectDirective = debugElement.injector.get(FileSelectDirective) as FileSelectDirective; fileSelectDirective = debugElement.injector.get(FileSelectDirective) as FileSelectDirective;
component.uploader.onErrorItem = (item: FileItem, response: string, status: number, headers: ParsedResponseHeaders) => {}; component.uploader.onErrorItem = () => {};
}); });
it('should be created', () => { it('should be created', () => {

View File

@ -8,12 +8,13 @@ import { ProjectService } from '../../../services/project.service';
import { Project } from '../../../models/project'; import { Project } from '../../../models/project';
import { ConfirmationDialogComponent } from '../confirmation-dialog/confirmation-dialog.component'; import { ConfirmationDialogComponent } from '../confirmation-dialog/confirmation-dialog.component';
import { ServerResponse } from '../../../models/serverResponse'; import { ServerResponse } from '../../../models/serverResponse';
import { Validator } from '../models/validator'; import { ProjectNameValidator } from '../models/projectNameValidator';
@Component({ @Component({
selector: 'app-import-project-dialog', selector: 'app-import-project-dialog',
templateUrl: 'import-project-dialog.component.html', templateUrl: 'import-project-dialog.component.html',
styleUrls: ['import-project-dialog.component.css'] styleUrls: ['import-project-dialog.component.css'],
providers: [ProjectNameValidator]
}) })
export class ImportProjectDialogComponent implements OnInit { export class ImportProjectDialogComponent implements OnInit {
uploader: FileUploader; uploader: FileUploader;
@ -31,9 +32,10 @@ export class ImportProjectDialogComponent implements OnInit {
public dialogRef: MatDialogRef<ImportProjectDialogComponent>, public dialogRef: MatDialogRef<ImportProjectDialogComponent>,
@Inject(MAT_DIALOG_DATA) public data: any, @Inject(MAT_DIALOG_DATA) public data: any,
private formBuilder: FormBuilder, private formBuilder: FormBuilder,
private projectService: ProjectService){ private projectService: ProjectService,
private projectNameValidator: ProjectNameValidator){
this.projectNameForm = this.formBuilder.group({ this.projectNameForm = this.formBuilder.group({
projectName: new FormControl(null, [Validators.required, Validator.projectNameValidator]) projectName: new FormControl(null, [Validators.required, projectNameValidator.get])
}); });
} }

View File

@ -1,5 +1,8 @@
export class Validator { import { Injectable } from "@angular/core";
static projectNameValidator(projectName) {
@Injectable()
export class ProjectNameValidator {
get(projectName) {
var pattern = new RegExp(/[~`!#$%\^&*+=\[\]\\';,/{}|\\":<>\?]/); var pattern = new RegExp(/[~`!#$%\^&*+=\[\]\\';,/{}|\\":<>\?]/);
if(!pattern.test(projectName.value)) { if(!pattern.test(projectName.value)) {