mirror of
https://github.com/GNS3/gns3-web-ui.git
synced 2025-04-25 05:19:43 +00:00
Fixes after review
This commit is contained in:
parent
0e35d1c7f6
commit
618f966361
@ -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,
|
||||||
|
@ -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();
|
||||||
})
|
})
|
||||||
|
@ -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])
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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', () => {
|
||||||
|
@ -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])
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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)) {
|
Loading…
x
Reference in New Issue
Block a user