src.app.modules.scenarios.components.execution.sub.right-side-bar.scenario-execution-menu.component.ts Maven / Gradle / Ivy
The newest version!
/*
* SPDX-FileCopyrightText: 2017-2024 Enedis
*
* SPDX-License-Identifier: Apache-2.0
*
*/
import { Component, Input, OnChanges, OnInit, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';
import { Authorization, ScenarioIndex, TestCase } from '@model';
import { JiraPluginService, LoginService, ScenarioService } from '@core/services';
import { ActivatedRoute, Router } from '@angular/router';
import { combineLatestWith, Observable, of, switchMap, tap } from 'rxjs';
import { FileSaverService } from 'ngx-filesaver';
import { BsModalService } from 'ngx-bootstrap/modal';
import { BsModalRef } from 'ngx-bootstrap/modal/bs-modal-ref.service';
import { EventManagerService } from '@shared';
import { MenuItem } from '@shared/components/layout/menuItem';
import { EnvironmentService } from '@core/services/environment.service';
import { ScenarioExecuteModalComponent } from '@shared/components/execute-modal/scenario-execute-modal.component';
import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
@Component({
selector: 'chutney-scenario-execution-menu',
templateUrl: './scenario-execution-menu.component.html',
styleUrls: ['./scenario-execution-menu.component.scss']
})
export class ScenarioExecutionMenuComponent implements OnInit, OnChanges {
testCaseId: string;
environments: Array;
testCaseMetadata: ScenarioIndex;
@Input() canReplay: boolean;
@ViewChild('delete_modal') deleteModal: TemplateRef;
Authorization = Authorization;
modalRef: BsModalRef;
rightMenuItems: MenuItem[];
executeLastMenuItem = {
label: 'global.actions.execute.last',
click: this.replay.bind(this),
iconClass: 'fa fa-play',
authorizations: [Authorization.SCENARIO_EXECUTE]
};
constructor(private environmentService: EnvironmentService,
private fileSaverService: FileSaverService,
private jiraLinkService: JiraPluginService,
private router: Router,
private scenarioService: ScenarioService,
private loginService: LoginService,
private modalService: BsModalService,
private ngbModalService: NgbModal,
private route: ActivatedRoute,
private eventManagerService: EventManagerService) {
}
ngOnInit(): void {
this.route.params
.pipe(
tap(params => this.testCaseId = params['id']),
switchMap(() => this.scenarioService.findScenarioMetadata(this.testCaseId)),
combineLatestWith(this.getEnvironments())
)
.subscribe(([scenarioMetadata, environments]) => {
this.testCaseMetadata = scenarioMetadata;
this.environments = environments;
this.initRightMenu();
});
}
ngOnChanges(changes: SimpleChanges) {
if (changes['canReplay']) {
if (!this.rightMenuItems?.find(item => item.label === 'global.actions.execute.last') && this.canReplay) {
this.rightMenuItems.splice(0, 0, this.executeLastMenuItem);
}
}
}
replay() {
this.eventManagerService.broadcast({ name: 'executeLast' });
}
executeScenario() {
const executeCallback = (env: string, dataset: string) => {
this.eventManagerService.broadcast({ name: 'execute', env: env, dataset: dataset});
}
let modalSize: "lg" | "xl" = "lg"
const changeModalSize = (size: "lg" | "xl") => {
modalSize = size;
modalRef.update({size: modalSize})
}
const modalRef = this.ngbModalService.open(ScenarioExecuteModalComponent, { centered: true, size: modalSize });
modalRef.componentInstance.environments = this.environments;
modalRef.componentInstance.executeCallback = executeCallback;
modalRef.componentInstance.changeModalSize = changeModalSize;
}
deleteScenario(id: string) {
let delete$ = this.scenarioService.delete(id);
delete$.subscribe(() => {
this.removeJiraLink(id);
this.router.navigateByUrl('/scenario')
.then(null);
});
}
duplicateScenario() {
this.router.navigateByUrl('/scenario/' + this.testCaseId + '/raw-edition' + '?duplicate=true');
}
exportScenario() {
const fileName = `${this.testCaseId}-${this.testCaseMetadata.title}.chutney.hjson`;
this.scenarioService.findRawTestCase(this.testCaseId).subscribe((testCase: TestCase) => {
this.fileSaverService.saveText(testCase.content, fileName);
});
}
openModal() {
this.modalRef = this.modalService.show(this.deleteModal, { class: 'modal-sm' });
}
confirm(): void {
this.modalRef.hide();
this.deleteScenario(this.testCaseId);
}
decline(): void {
this.modalRef.hide();
}
private removeJiraLink(id: string) {
this.jiraLinkService.removeForScenario(id).subscribe({
error: (error) => {
console.log(error);
}
});
}
private initRightMenu() {
const rightMenuItems: any[] = [
{
label: 'global.actions.execute',
click: this.executeScenario.bind(this),
iconClass: 'fa fa-play',
secondaryIconClass: 'fa-solid fa-gear fa-2xs',
authorizations: [Authorization.SCENARIO_EXECUTE]
},
{
label: 'global.actions.edit',
link: '/scenario/' + this.testCaseId + '/raw-edition',
iconClass: 'fa fa-pencil-alt',
authorizations: [Authorization.SCENARIO_WRITE]
},
{
label: 'global.actions.delete',
click: this.openModal.bind(this),
iconClass: 'fa fa-trash',
authorizations: [Authorization.SCENARIO_WRITE]
},
{
label: 'global.actions.clone',
click: this.duplicateScenario.bind(this),
iconClass: 'fa fa-clone',
authorizations: [Authorization.SCENARIO_WRITE]
},
{
label: 'global.actions.export',
click: this.exportScenario.bind(this),
iconClass: 'fa fa-file-code'
}
];
this.rightMenuItems = rightMenuItems;
}
private getEnvironments(): Observable> {
if (this.loginService.hasAuthorization(Authorization.SCENARIO_EXECUTE)) {
return this.environmentService.names();
}
return of([])
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy