mirror of
https://github.com/GNS3/gns3-web-ui.git
synced 2025-01-11 23:43:05 +00:00
Update new-template-dialog.component.ts
This commit is contained in:
parent
87aa6c4b59
commit
81bc3cb3bd
@ -430,10 +430,7 @@ export class NewTemplateDialogComponent implements OnInit {
|
|||||||
}
|
}
|
||||||
|
|
||||||
createIouTemplate (image: Image) {
|
createIouTemplate (image: Image) {
|
||||||
if (!this.validateTemplateName()) return;
|
|
||||||
|
|
||||||
let iouTemplate: IouTemplate = new IouTemplate();
|
let iouTemplate: IouTemplate = new IouTemplate();
|
||||||
iouTemplate.name = this.applianceToInstall.name;
|
|
||||||
iouTemplate.nvram = this.applianceToInstall.iou.nvram;
|
iouTemplate.nvram = this.applianceToInstall.iou.nvram;
|
||||||
iouTemplate.ram = this.applianceToInstall.iou.ram;
|
iouTemplate.ram = this.applianceToInstall.iou.ram;
|
||||||
iouTemplate.ethernet_adapters = this.applianceToInstall.iou.ethernet_adapters;
|
iouTemplate.ethernet_adapters = this.applianceToInstall.iou.ethernet_adapters;
|
||||||
@ -448,18 +445,40 @@ export class NewTemplateDialogComponent implements OnInit {
|
|||||||
iouTemplate.path = image.filename;
|
iouTemplate.path = image.filename;
|
||||||
iouTemplate.template_type = 'iou';
|
iouTemplate.template_type = 'iou';
|
||||||
|
|
||||||
|
if (this.templates.filter(t => t.name === this.applianceToInstall.name).length === 0) {
|
||||||
|
iouTemplate.name = this.applianceToInstall.name;
|
||||||
|
|
||||||
this.iouService.addTemplate(this.server, iouTemplate).subscribe((template) => {
|
this.iouService.addTemplate(this.server, iouTemplate).subscribe((template) => {
|
||||||
this.templateService.newTemplateCreated.next(template);
|
this.templateService.newTemplateCreated.next(template);
|
||||||
this.toasterService.success('Template added');
|
this.toasterService.success('Template added');
|
||||||
this.dialogRef.close();
|
this.dialogRef.close();
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
const dialogRef = this.dialog.open(TemplateNameDialogComponent, {
|
||||||
|
width: '400px',
|
||||||
|
height: '250px',
|
||||||
|
autoFocus: false,
|
||||||
|
disableClose: true
|
||||||
|
});
|
||||||
|
dialogRef.componentInstance.server = this.server;
|
||||||
|
dialogRef.afterClosed().subscribe((answer: string) => {
|
||||||
|
if (answer) {
|
||||||
|
iouTemplate.name = answer;
|
||||||
|
|
||||||
|
this.iouService.addTemplate(this.server, iouTemplate).subscribe((template) => {
|
||||||
|
this.templateService.newTemplateCreated.next(template);
|
||||||
|
this.toasterService.success('Template added');
|
||||||
|
this.dialogRef.close();
|
||||||
|
});
|
||||||
|
} else{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
createIosTemplate(image: Image) {
|
createIosTemplate(image: Image) {
|
||||||
if (!this.validateTemplateName()) return;
|
|
||||||
|
|
||||||
let iosTemplate: IosTemplate = new IosTemplate();
|
let iosTemplate: IosTemplate = new IosTemplate();
|
||||||
iosTemplate.name = this.applianceToInstall.name;
|
|
||||||
iosTemplate.chassis = this.applianceToInstall.dynamips.chassis;
|
iosTemplate.chassis = this.applianceToInstall.dynamips.chassis;
|
||||||
iosTemplate.nvram = this.applianceToInstall.dynamips.nvram;
|
iosTemplate.nvram = this.applianceToInstall.dynamips.nvram;
|
||||||
iosTemplate.platform = this.applianceToInstall.dynamips.platform;
|
iosTemplate.platform = this.applianceToInstall.dynamips.platform;
|
||||||
@ -482,18 +501,40 @@ export class NewTemplateDialogComponent implements OnInit {
|
|||||||
iosTemplate.image = image.filename;
|
iosTemplate.image = image.filename;
|
||||||
iosTemplate.template_type = 'dynamips';
|
iosTemplate.template_type = 'dynamips';
|
||||||
|
|
||||||
|
if (this.templates.filter(t => t.name === this.applianceToInstall.name).length === 0) {
|
||||||
|
iosTemplate.name = this.applianceToInstall.name;
|
||||||
|
|
||||||
this.iosService.addTemplate(this.server, iosTemplate).subscribe((template) => {
|
this.iosService.addTemplate(this.server, iosTemplate).subscribe((template) => {
|
||||||
this.templateService.newTemplateCreated.next(template as any as Template);
|
this.templateService.newTemplateCreated.next(template as any as Template);
|
||||||
this.toasterService.success('Template added');
|
this.toasterService.success('Template added');
|
||||||
this.dialogRef.close();
|
this.dialogRef.close();
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
const dialogRef = this.dialog.open(TemplateNameDialogComponent, {
|
||||||
|
width: '400px',
|
||||||
|
height: '250px',
|
||||||
|
autoFocus: false,
|
||||||
|
disableClose: true
|
||||||
|
});
|
||||||
|
dialogRef.componentInstance.server = this.server;
|
||||||
|
dialogRef.afterClosed().subscribe((answer: string) => {
|
||||||
|
if (answer) {
|
||||||
|
iosTemplate.name = answer;
|
||||||
|
|
||||||
|
this.iosService.addTemplate(this.server, iosTemplate).subscribe((template) => {
|
||||||
|
this.templateService.newTemplateCreated.next(template as any as Template);
|
||||||
|
this.toasterService.success('Template added');
|
||||||
|
this.dialogRef.close();
|
||||||
|
});
|
||||||
|
} else{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
createDockerTemplate() {
|
createDockerTemplate() {
|
||||||
if (!this.validateTemplateName()) return;
|
|
||||||
|
|
||||||
let dockerTemplate: DockerTemplate = new DockerTemplate();
|
let dockerTemplate: DockerTemplate = new DockerTemplate();
|
||||||
dockerTemplate.name = this.applianceToInstall.name;
|
|
||||||
dockerTemplate.adapters = this.applianceToInstall.docker.adapters;
|
dockerTemplate.adapters = this.applianceToInstall.docker.adapters;
|
||||||
dockerTemplate.console_type = this.applianceToInstall.docker.console_type;
|
dockerTemplate.console_type = this.applianceToInstall.docker.console_type;
|
||||||
dockerTemplate.builtin = this.applianceToInstall.builtin;
|
dockerTemplate.builtin = this.applianceToInstall.builtin;
|
||||||
@ -505,11 +546,36 @@ export class NewTemplateDialogComponent implements OnInit {
|
|||||||
dockerTemplate.image = this.applianceToInstall.docker.image;
|
dockerTemplate.image = this.applianceToInstall.docker.image;
|
||||||
dockerTemplate.template_type = 'docker';
|
dockerTemplate.template_type = 'docker';
|
||||||
|
|
||||||
|
if (this.templates.filter(t => t.name === this.applianceToInstall.name).length === 0) {
|
||||||
|
dockerTemplate.name = this.applianceToInstall.name;
|
||||||
|
|
||||||
this.dockerService.addTemplate(this.server, dockerTemplate).subscribe((template) => {
|
this.dockerService.addTemplate(this.server, dockerTemplate).subscribe((template) => {
|
||||||
this.templateService.newTemplateCreated.next(template as any as Template);
|
this.templateService.newTemplateCreated.next(template as any as Template);
|
||||||
this.toasterService.success('Template added');
|
this.toasterService.success('Template added');
|
||||||
this.dialogRef.close();
|
this.dialogRef.close();
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
const dialogRef = this.dialog.open(TemplateNameDialogComponent, {
|
||||||
|
width: '400px',
|
||||||
|
height: '250px',
|
||||||
|
autoFocus: false,
|
||||||
|
disableClose: true
|
||||||
|
});
|
||||||
|
dialogRef.componentInstance.server = this.server;
|
||||||
|
dialogRef.afterClosed().subscribe((answer: string) => {
|
||||||
|
if (answer) {
|
||||||
|
dockerTemplate.name = answer;
|
||||||
|
|
||||||
|
this.dockerService.addTemplate(this.server, dockerTemplate).subscribe((template) => {
|
||||||
|
this.templateService.newTemplateCreated.next(template as any as Template);
|
||||||
|
this.toasterService.success('Template added');
|
||||||
|
this.dialogRef.close();
|
||||||
|
});
|
||||||
|
} else{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
createQemuTemplateFromVersion(version: Version) {
|
createQemuTemplateFromVersion(version: Version) {
|
||||||
@ -577,28 +643,6 @@ export class NewTemplateDialogComponent implements OnInit {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
validateTemplateName() {
|
|
||||||
if (this.templates.filter(t => t.name === this.applianceToInstall.name).length === 0) {
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
const dialogRef = this.dialog.open(TemplateNameDialogComponent, {
|
|
||||||
width: '400px',
|
|
||||||
height: '300px',
|
|
||||||
autoFocus: false,
|
|
||||||
disableClose: true
|
|
||||||
});
|
|
||||||
dialogRef.componentInstance.server = this.server;
|
|
||||||
dialogRef.afterClosed().subscribe((answer: string) => {
|
|
||||||
if (answer) {
|
|
||||||
this.applianceToInstall.name = answer;
|
|
||||||
return true;
|
|
||||||
} else{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function compareNames(a: string, b: string, isAsc: boolean) {
|
function compareNames(a: string, b: string, isAsc: boolean) {
|
||||||
|
Loading…
Reference in New Issue
Block a user