clearml-web/src/app/webapp-common/pipelines/edit-pipeline-page/pipeline-step-info/pipeline-step-info.component.ts
2024-02-28 14:28:04 +05:30

92 lines
2.8 KiB
TypeScript

import {Component, EventEmitter, Input, Output, ViewChild} from '@angular/core';
import {Store} from '@ngrx/store';
import {Artifact} from '~/business-logic/model/tasks/artifact';
import {
PipelineItem,
StepStatusEnum,
TreeStep
} from '@common/pipelines-controller/pipeline-controller-info/pipeline-controller-info.component';
import {TaskTypeEnum} from '~/business-logic/model/tasks/taskTypeEnum';
import {addMessage} from '@common/core/actions/layout.actions';
import {fileSizeConfigStorage} from '@common/shared/pipes/filesize.pipe';
import {ICONS, IOption, MESSAGES_SEVERITY} from '@common/constants';
import {IExperimentInfo} from '~/features/experiments/shared/experiment-info.model';
import { MatOptionSelectionChange } from '@angular/material/core';
import { NgModel } from '@angular/forms';
import { trackByValue } from '@common/shared/utils/forms-track-by';
import { cloneDeep } from 'lodash-es';
@Component({
selector: 'sm-pipeline-step-info',
templateUrl: './pipeline-step-info.component.html',
styleUrls: ['./pipeline-step-info.component.scss']
})
export class PipelineStepInfoComponent {
readonly icons = ICONS;
//private _entity: IExperimentInfo;
public controller: boolean;
public fileSizeConfigStorage = fileSizeConfigStorage;
private _step;
@Output() deleteStep = new EventEmitter<unknown>();
@Output() stepParamsChanged = new EventEmitter<unknown>();
@Input() set step(step) {
this._step = step ? cloneDeep(step) : null;
}
get step() {
return this._step;
}
// for auto complete
@ViewChild('optsInput') optsInput: NgModel;
public trackByValue = trackByValue;
isAutoCompleteOpen: boolean;
public incommingInputOptions: { label: string; value: string }[] = [
{label: "test", value: "test1"}
];
setIsAutoCompleteOpen(focus: boolean) {
this.isAutoCompleteOpen = focus;
}
displayFn(opt: IOption | string) {
return typeof opt === 'string' ? opt : opt?.label;
}
// eslint-disable-next-line @typescript-eslint/no-unused-vars
paramSelected($event: MatOptionSelectionChange) {
}
/* @Input() set entity(task: IExperimentInfo) {
this._entity = task;
this.controller = task?.type === TaskTypeEnum.Controller;
}
get entity() {
return this._entity;
} */
paramsChanged() {
setTimeout(()=> {
this.stepParamsChanged.emit(this._step.data.parameters);
}, 2000)
}
@Input() project: string;
constructor(private store: Store) {
}
public deleteClicked() {
this.deleteStep.emit(this._step);
/* setTimeout(() => {
// eslint-disable-next-line no-console
console.log(this._step);
}, 3000) */
}
trackByFn = (index: number, artifact: Artifact) => artifact.hash || artifact.uri;
copyToClipboard() {
this.store.dispatch(addMessage(MESSAGES_SEVERITY.SUCCESS, 'ID copied successfully'));
}
}