From df6b3ed952520f5f44da494d4cde3b439bd60885 Mon Sep 17 00:00:00 2001 From: MoritzWeber Date: Mon, 2 Sep 2024 16:29:14 +0200 Subject: [PATCH] ci: Apply ESLint 9 rules to code --- .pre-commit-config.yaml | 8 +++- .../api-documentation.component.ts | 4 +- .../error-handling.interceptor.ts | 4 +- .../app/general/nav-bar/nav-bar.service.ts | 4 +- .../confirmation-dialog.component.ts | 2 +- .../service/pipeline-run.service.ts | 8 ++-- .../service/pipeline.service.ts | 8 ++-- .../view-logs-dialog.component.ts | 4 +- .../model-diagram-code-block.stories.ts | 1 - .../model-diagram-dialog.component.ts | 8 ++-- .../model-diagram-preview-dialog.component.ts | 4 +- .../service/model-restrictions.service.ts | 4 +- .../manage-git-model.component.ts | 2 +- .../t4c/service/t4c-model.service.ts | 12 ++--- .../projects/models/service/model.service.ts | 2 +- .../model-detail/git-model.service.ts | 6 +-- .../service/project-user.service.ts | 4 +- .../app/projects/service/project.service.ts | 2 +- .../services/load-files/load-files.service.ts | 4 +- .../app/sessions/service/session.service.ts | 8 +--- .../app/sessions/session/session.component.ts | 2 +- .../tiling-window-manager.component.ts | 4 +- .../file-browser-dialog.component.ts | 30 ++++++------- .../session-sharing-dialog.component.ts | 6 +-- ...create-readonly-model-options.component.ts | 4 +- .../create-session-history.component.ts | 4 +- .../session-history.service.ts | 6 +-- .../service/monitoring.service.ts | 12 ++--- .../core/tools-settings/tool.service.ts | 44 +++++++++---------- .../tools-settings.component.ts | 2 +- .../service/pure-variants.service.ts | 4 +- .../service/git-instances.service.ts | 10 ++--- .../basic-auth-token.service.ts | 4 +- .../user-workspaces.component.ts | 8 ++-- frontend/src/storybook/diagram.ts | 2 +- frontend/src/storybook/model-badge.ts | 2 +- frontend/src/storybook/t4c.ts | 4 +- 37 files changed, 119 insertions(+), 128 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index c9640486a4..3d0b6ce2fc 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -166,7 +166,13 @@ repos: - 'eslint-plugin-unused-imports@^4.1.3' - 'eslint-plugin-tailwindcss@^3.17.4' - 'eslint-plugin-storybook@^0.9.0--canary.156.ed236ca.0' - args: ['--config', 'frontend/eslint.config.mjs', '--fix'] + args: + [ + '--config', + 'frontend/eslint.config.mjs', + '--fix', + '--no-warn-ignored', + ] types: [] files: '^frontend/' exclude: '.+\.spec(-helper)?\.ts$|^frontend/src/app/openapi' diff --git a/frontend/src/app/general/api-documentation/api-documentation.component.ts b/frontend/src/app/general/api-documentation/api-documentation.component.ts index 8a88ba21c2..e720de5d81 100644 --- a/frontend/src/app/general/api-documentation/api-documentation.component.ts +++ b/frontend/src/app/general/api-documentation/api-documentation.component.ts @@ -13,8 +13,8 @@ import { environment } from 'src/environments/environment'; imports: [MatIcon], }) export class ApiDocumentationComponent { - @Input() tag: string = ''; - @Input() hyperlink: string = ''; + @Input() tag = ''; + @Input() hyperlink = ''; getAPIDocsLink() { return `${environment.api_docs_url}/redoc#tag/${this.tag}/operation/${this.hyperlink}`; diff --git a/frontend/src/app/general/error-handling/error-handling.interceptor.ts b/frontend/src/app/general/error-handling/error-handling.interceptor.ts index 0c5a8fdf4a..deb81e8c9a 100644 --- a/frontend/src/app/general/error-handling/error-handling.interceptor.ts +++ b/frontend/src/app/general/error-handling/error-handling.interceptor.ts @@ -119,7 +119,7 @@ export class ErrorHandlingInterceptor implements HttpInterceptor { reader.onload = (e: Event) => { try { const errmsg = JSON.parse( - (e.target).result, + (e.target as FileReaderEventTarget).result, ); reject( new HttpErrorResponse({ @@ -130,7 +130,7 @@ export class ErrorHandlingInterceptor implements HttpInterceptor { url: err.url || undefined, }), ); - } catch (e) { + } catch { reject(err); } }; diff --git a/frontend/src/app/general/nav-bar/nav-bar.service.ts b/frontend/src/app/general/nav-bar/nav-bar.service.ts index e8a785d2eb..7d37118ca6 100644 --- a/frontend/src/app/general/nav-bar/nav-bar.service.ts +++ b/frontend/src/app/general/nav-bar/nav-bar.service.ts @@ -80,11 +80,11 @@ export class NavBarService { }; } -export type NavBarItem = { +export interface NavBarItem { name: string; routerLink?: string | string[]; href?: string; target?: string; requiredRole: Role; icon?: string; -}; +} diff --git a/frontend/src/app/helpers/confirmation-dialog/confirmation-dialog.component.ts b/frontend/src/app/helpers/confirmation-dialog/confirmation-dialog.component.ts index ed3c6a9c26..d18822e781 100644 --- a/frontend/src/app/helpers/confirmation-dialog/confirmation-dialog.component.ts +++ b/frontend/src/app/helpers/confirmation-dialog/confirmation-dialog.component.ts @@ -22,7 +22,7 @@ export interface ConfirmationDialogData { imports: [FormsModule, MatFormField, MatInput, MatButton], }) export class ConfirmationDialogComponent implements OnInit { - inputText: string = ''; + inputText = ''; constructor( public dialogRef: MatDialogRef, diff --git a/frontend/src/app/projects/models/backup-settings/pipeline-runs/service/pipeline-run.service.ts b/frontend/src/app/projects/models/backup-settings/pipeline-runs/service/pipeline-run.service.ts index 1d270bef0f..ea83b57d68 100644 --- a/frontend/src/app/projects/models/backup-settings/pipeline-runs/service/pipeline-run.service.ts +++ b/frontend/src/app/projects/models/backup-settings/pipeline-runs/service/pipeline-run.service.ts @@ -196,18 +196,16 @@ export class PipelineRunService { } } -export type PipelineRun = { +export interface PipelineRun { status: PipelineRunStatus; triggerer: User; id: number; trigger_time: string; environment: PipelineRunEnvironment; -}; - -interface PipelineRunEnvironment { - [key: string]: string; } +type PipelineRunEnvironment = Record; + export type PipelineRunStatus = | 'pending' | 'scheduled' diff --git a/frontend/src/app/projects/models/backup-settings/service/pipeline.service.ts b/frontend/src/app/projects/models/backup-settings/service/pipeline.service.ts index 8d155f16c2..a10a1094f3 100644 --- a/frontend/src/app/projects/models/backup-settings/service/pipeline.service.ts +++ b/frontend/src/app/projects/models/backup-settings/service/pipeline.service.ts @@ -93,17 +93,17 @@ export class PipelineService { } } -export type Pipeline = { +export interface Pipeline { id: number; t4c_model: SimpleT4CModel; git_model: BaseGitModel; run_nightly: boolean; include_commit_history: boolean; -}; +} -export type PostPipeline = { +export interface PostPipeline { t4cmodelId: number; gitmodelId: number; includeCommitHistory: boolean; runNightly: boolean; -}; +} diff --git a/frontend/src/app/projects/models/backup-settings/view-logs-dialog/view-logs-dialog.component.ts b/frontend/src/app/projects/models/backup-settings/view-logs-dialog/view-logs-dialog.component.ts index e35c29dbb9..9250d65b36 100644 --- a/frontend/src/app/projects/models/backup-settings/view-logs-dialog/view-logs-dialog.component.ts +++ b/frontend/src/app/projects/models/backup-settings/view-logs-dialog/view-logs-dialog.component.ts @@ -84,9 +84,9 @@ export class ViewLogsDialogComponent { } } -export type ViewLogsData = { +export interface ViewLogsData { projectSlug: string; modelSlug: string; job_id: string; backup_id: number; -}; +} diff --git a/frontend/src/app/projects/models/diagrams/model-diagram-dialog/model-diagram-code-block/model-diagram-code-block.stories.ts b/frontend/src/app/projects/models/diagrams/model-diagram-dialog/model-diagram-code-block/model-diagram-code-block.stories.ts index 1a343f5aa7..23bf5e246a 100644 --- a/frontend/src/app/projects/models/diagrams/model-diagram-dialog/model-diagram-code-block/model-diagram-code-block.stories.ts +++ b/frontend/src/app/projects/models/diagrams/model-diagram-dialog/model-diagram-code-block/model-diagram-code-block.stories.ts @@ -2,7 +2,6 @@ * SPDX-FileCopyrightText: Copyright DB InfraGO AG and contributors * SPDX-License-Identifier: Apache-2.0 */ - import { Meta, StoryObj } from '@storybook/angular'; import { mockModel } from 'src/storybook/model'; import { mockProject } from 'src/storybook/project'; diff --git a/frontend/src/app/projects/models/diagrams/model-diagram-dialog/model-diagram-dialog.component.ts b/frontend/src/app/projects/models/diagrams/model-diagram-dialog/model-diagram-dialog.component.ts index a8c1ea6a85..c1cbe65c76 100644 --- a/frontend/src/app/projects/models/diagrams/model-diagram-dialog/model-diagram-dialog.component.ts +++ b/frontend/src/app/projects/models/diagrams/model-diagram-dialog/model-diagram-dialog.component.ts @@ -193,11 +193,9 @@ export class ModelDiagramDialogComponent implements OnInit { } } -export interface Diagrams { - [uuid: string]: Diagram; -} +export type Diagrams = Record; -type Diagram = { +interface Diagram { loading: boolean; content?: string | ArrayBuffer | null; -}; +} diff --git a/frontend/src/app/projects/models/diagrams/model-diagram-preview-dialog/model-diagram-preview-dialog.component.ts b/frontend/src/app/projects/models/diagrams/model-diagram-preview-dialog/model-diagram-preview-dialog.component.ts index 12db2a09f2..0007064fab 100644 --- a/frontend/src/app/projects/models/diagrams/model-diagram-preview-dialog/model-diagram-preview-dialog.component.ts +++ b/frontend/src/app/projects/models/diagrams/model-diagram-preview-dialog/model-diagram-preview-dialog.component.ts @@ -42,7 +42,7 @@ export class ModelDiagramPreviewDialogComponent implements AfterViewInit { } } -export type MatDialogPreviewData = { +export interface MatDialogPreviewData { diagram: DiagramMetadata; content: string | ArrayBuffer; -}; +} diff --git a/frontend/src/app/projects/models/model-restrictions/service/model-restrictions.service.ts b/frontend/src/app/projects/models/model-restrictions/service/model-restrictions.service.ts index 65deba5947..b91cecd3e0 100644 --- a/frontend/src/app/projects/models/model-restrictions/service/model-restrictions.service.ts +++ b/frontend/src/app/projects/models/model-restrictions/service/model-restrictions.service.ts @@ -32,6 +32,6 @@ export function areRestrictionsEqual( return a.allow_pure_variants === b.allow_pure_variants; } -export type ModelRestrictions = { +export interface ModelRestrictions { allow_pure_variants: boolean; -}; +} diff --git a/frontend/src/app/projects/models/model-source/git/manage-git-model/manage-git-model.component.ts b/frontend/src/app/projects/models/model-source/git/manage-git-model/manage-git-model.component.ts index bb661474a2..f4a51b9d61 100644 --- a/frontend/src/app/projects/models/model-source/git/manage-git-model/manage-git-model.component.ts +++ b/frontend/src/app/projects/models/model-source/git/manage-git-model/manage-git-model.component.ts @@ -99,7 +99,7 @@ export class ManageGitModelComponent implements OnInit, OnDestroy { @Input() asStepper?: boolean; @Output() create = new EventEmitter(); - public availableGitInstances?: Array; + public availableGitInstances?: GitInstance[]; public selectedGitInstance?: GitInstance; private revisions?: Revisions; diff --git a/frontend/src/app/projects/models/model-source/t4c/service/t4c-model.service.ts b/frontend/src/app/projects/models/model-source/t4c/service/t4c-model.service.ts index 8352ee3d89..25eb1f5be7 100644 --- a/frontend/src/app/projects/models/model-source/t4c/service/t4c-model.service.ts +++ b/frontend/src/app/projects/models/model-source/t4c/service/t4c-model.service.ts @@ -122,20 +122,20 @@ export class T4CModelService { } } -export type SubmitT4CModel = { +export interface SubmitT4CModel { t4c_instance_id: number; t4c_repository_id: number; name: string; -}; +} -export type T4CModel = { +export interface T4CModel { name: string; id: number; repository: T4CRepository; -}; +} -export type SimpleT4CModel = { +export interface SimpleT4CModel { project_name: string; repository_name: string; instance_name: string; -}; +} diff --git a/frontend/src/app/projects/models/service/model.service.ts b/frontend/src/app/projects/models/service/model.service.ts index b499b666c7..a32367563b 100644 --- a/frontend/src/app/projects/models/service/model.service.ts +++ b/frontend/src/app/projects/models/service/model.service.ts @@ -140,7 +140,7 @@ export class ModelWrapperService { } asyncSlugValidator(ignoreModel?: ToolModel): AsyncValidatorFn { - const ignoreSlug = !!ignoreModel ? ignoreModel.slug : -1; + const ignoreSlug = ignoreModel ? ignoreModel.slug : -1; return (control: AbstractControl): Observable => { const modelSlug = slugify(control.value, { lower: true }); return this.models$.pipe( diff --git a/frontend/src/app/projects/project-detail/model-overview/model-detail/git-model.service.ts b/frontend/src/app/projects/project-detail/model-overview/model-detail/git-model.service.ts index 27820f5f42..8fb2bbed1e 100644 --- a/frontend/src/app/projects/project-detail/model-overview/model-detail/git-model.service.ts +++ b/frontend/src/app/projects/project-detail/model-overview/model-detail/git-model.service.ts @@ -26,7 +26,7 @@ export class GitModelService { loadGitModels(project_slug: string, model_slug: string): void { this.http .get< - Array + GetGitModel[] >(this.BACKEND_URL_PREFIX + `/projects/${project_slug}/models/${model_slug}/modelsources/git`) .subscribe((gitModels) => this._gitModels.next(gitModels)); } @@ -112,12 +112,12 @@ export class GitModelService { } } -export type BaseGitModel = { +export interface BaseGitModel { path: string; revision: string; entrypoint: string; username: string; -}; +} export type CreateGitModel = BaseGitModel & { password?: string; diff --git a/frontend/src/app/projects/project-detail/project-users/service/project-user.service.ts b/frontend/src/app/projects/project-detail/project-users/service/project-user.service.ts index 0899218da4..a2db1a9f8b 100644 --- a/frontend/src/app/projects/project-detail/project-users/service/project-user.service.ts +++ b/frontend/src/app/projects/project-detail/project-users/service/project-user.service.ts @@ -211,12 +211,12 @@ export class ProjectUserService { } } -export type ProjectUser = { +export interface ProjectUser { project_name: string; permission: ProjectUserPermission; role: ProjectUserRole; user: User; -}; +} export type ProjectUserPermission = 'read' | 'write'; export type ProjectUserRole = 'user' | 'manager' | 'administrator'; diff --git a/frontend/src/app/projects/service/project.service.ts b/frontend/src/app/projects/service/project.service.ts index 7ccffa3424..c011bb9bad 100644 --- a/frontend/src/app/projects/service/project.service.ts +++ b/frontend/src/app/projects/service/project.service.ts @@ -92,7 +92,7 @@ export class ProjectWrapperService { } asyncSlugValidator(ignoreProject?: Project): AsyncValidatorFn { - const ignoreSlug = !!ignoreProject ? ignoreProject.slug : -1; + const ignoreSlug = ignoreProject ? ignoreProject.slug : -1; return (control: AbstractControl): Observable => { const projectSlug = slugify(control.value, { lower: true }); return this.projects$.pipe( diff --git a/frontend/src/app/services/load-files/load-files.service.ts b/frontend/src/app/services/load-files/load-files.service.ts index 956cab89c5..5a7dd06879 100644 --- a/frontend/src/app/services/load-files/load-files.service.ts +++ b/frontend/src/app/services/load-files/load-files.service.ts @@ -41,6 +41,6 @@ export class LoadFilesService { } } -export type UploadResponse = { +export interface UploadResponse { message: string; -}; +} diff --git a/frontend/src/app/sessions/service/session.service.ts b/frontend/src/app/sessions/service/session.service.ts index 2d8b7fc9bb..563afa58c4 100644 --- a/frontend/src/app/sessions/service/session.service.ts +++ b/frontend/src/app/sessions/service/session.service.ts @@ -15,13 +15,9 @@ import { import { SessionHistoryService } from 'src/app/sessions/user-sessions-wrapper/create-sessions/create-session-history/session-history.service'; import { environment } from 'src/environments/environment'; -export interface LocalStorage { - [id: string]: string; -} +export type LocalStorage = Record; -export interface Cookies { - [id: string]: string; -} +export type Cookies = Record; export interface ReadonlySession extends Session { project: Project; diff --git a/frontend/src/app/sessions/session/session.component.ts b/frontend/src/app/sessions/session/session.component.ts index 32dbc7c6ab..8bba7f095e 100644 --- a/frontend/src/app/sessions/session/session.component.ts +++ b/frontend/src/app/sessions/session/session.component.ts @@ -49,7 +49,7 @@ import { TilingWindowManagerComponent } from './tiling-window-manager/tiling-win export class SessionComponent implements OnInit, OnDestroy { cachedSessions?: CachedSession[] = undefined; - selectedWindowType: string = 'floating'; + selectedWindowType = 'floating'; constructor( public userSessionService: UserSessionService, diff --git a/frontend/src/app/sessions/session/tiling-window-manager/tiling-window-manager.component.ts b/frontend/src/app/sessions/session/tiling-window-manager/tiling-window-manager.component.ts index 37e51ea6d3..7c91fcc99a 100644 --- a/frontend/src/app/sessions/session/tiling-window-manager/tiling-window-manager.component.ts +++ b/frontend/src/app/sessions/session/tiling-window-manager/tiling-window-manager.component.ts @@ -203,14 +203,14 @@ export class TilingWindowManagerComponent implements OnInit { } } -type ResizeState = { +interface ResizeState { index?: number; startX?: number; leftSession?: TilingSession; rightSession?: TilingSession; startWidthLeft?: number; startWidthRight?: number; -}; +} type ValidResizeState = Required; diff --git a/frontend/src/app/sessions/user-sessions-wrapper/active-sessions/file-browser-dialog/file-browser-dialog.component.ts b/frontend/src/app/sessions/user-sessions-wrapper/active-sessions/file-browser-dialog/file-browser-dialog.component.ts index eef6f09630..ec10c922d9 100644 --- a/frontend/src/app/sessions/user-sessions-wrapper/active-sessions/file-browser-dialog/file-browser-dialog.component.ts +++ b/frontend/src/app/sessions/user-sessions-wrapper/active-sessions/file-browser-dialog/file-browser-dialog.component.ts @@ -61,11 +61,11 @@ import { FileExistsDialogComponent } from './file-exists-dialog/file-exists-dial ], }) export class FileBrowserDialogComponent implements OnInit { - files: Array<[File, string]> = []; + files: [File, string][] = []; uploadProgress: number | null = null; loadingFiles = false; - treeControl = new NestedTreeControl((node) => node.children); + treeControl = new NestedTreeControl((node) => node.children); // eslint-disable-line @typescript-eslint/no-deprecated dataSource = new BehaviorSubject([]); constructor( @@ -111,8 +111,7 @@ export class FileBrowserDialogComponent implements OnInit { if (!this.files.includes([file, path]) && response) { this.files.push([file, path]); if (parentNode.children) { - for (let i = 0; i < parentNode.children.length; i++) { - const child = parentNode.children[i]; + for (const child of parentNode.children) { if (child.name === name) { child.isNew = true; break; @@ -144,8 +143,7 @@ export class FileBrowserDialogComponent implements OnInit { this.treeControl.expand(parentNode); return true; } else if (parentNode.children) { - for (let i = 0; i < parentNode.children.length; i++) { - const child = parentNode.children[i]; + for (const child of parentNode.children) { result = this.addFileToTree(child, path, name); if (result) { this.treeControl.expand(parentNode); @@ -158,8 +156,8 @@ export class FileBrowserDialogComponent implements OnInit { checkIfFileExists(parentNode: PathNode, fileName: string): boolean { if (parentNode.children) { - for (let i = 0; i < parentNode.children.length; i++) { - if (fileName == parentNode.children[i].name) return true; + for (const child of parentNode.children) { + if (fileName == child.name) return true; } } return false; @@ -175,8 +173,8 @@ export class FileBrowserDialogComponent implements OnInit { this.treeControl.expand(parentNode); result = true; } else if (parentNode.children) { - for (let i = 0; i < parentNode.children?.length; i++) { - result = this._expandToNode(parentNode.children[i], node); + for (const child of parentNode.children) { + result = this._expandToNode(child, node); if (result) { this.treeControl.expand(parentNode); } @@ -227,10 +225,10 @@ export class FileBrowserDialogComponent implements OnInit { removeFileFromSelection(path: string, filename: string): void { let file; let prefix = null; - for (let i = 0; i < this.files.length; i++) { - file = this.files[i][0]; - prefix = this.files[i][1]; - if (this.files[i][0].name === filename && this.files[i][1] === path) { + for (const fileIter of this.files) { + file = fileIter[0]; + prefix = fileIter[1]; + if (file.name === filename && prefix === path) { break; } } @@ -280,9 +278,7 @@ export class FileBrowserDialogComponent implements OnInit { next: (response: Blob) => { saveAs( response, - `${filename - .replace(/^[\/\\: ]+/, '') - .replace(/[\/\\: ]+/g, '_')}.zip`, + `${filename.replace(/^[/\\: ]+/, '').replace(/[/\\: ]+/g, '_')}.zip`, ); this.session.download_in_progress = false; }, diff --git a/frontend/src/app/sessions/user-sessions-wrapper/active-sessions/session-sharing-dialog/session-sharing-dialog.component.ts b/frontend/src/app/sessions/user-sessions-wrapper/active-sessions/session-sharing-dialog/session-sharing-dialog.component.ts index 9df3246556..2cbf101590 100644 --- a/frontend/src/app/sessions/user-sessions-wrapper/active-sessions/session-sharing-dialog/session-sharing-dialog.component.ts +++ b/frontend/src/app/sessions/user-sessions-wrapper/active-sessions/session-sharing-dialog/session-sharing-dialog.component.ts @@ -60,7 +60,7 @@ export class SessionSharingDialogComponent { }); loading = false; - users: Array = []; + users: AddedUser[] = []; constructor( @Inject(MAT_DIALOG_DATA) public session: Session, @@ -180,8 +180,8 @@ export class SessionSharingDialogComponent { } } -type AddedUser = { +interface AddedUser { username: string; state: 'success' | 'pending' | 'error'; tooltip: string; -}; +} diff --git a/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-readonly-session/create-readonly-model-options/create-readonly-model-options.component.ts b/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-readonly-session/create-readonly-model-options/create-readonly-model-options.component.ts index 74054d5859..aa53d45485 100644 --- a/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-readonly-session/create-readonly-model-options/create-readonly-model-options.component.ts +++ b/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-readonly-session/create-readonly-model-options/create-readonly-model-options.component.ts @@ -29,13 +29,13 @@ import { existingRevisionValidator, } from 'src/app/services/git/git.service'; -export type ModelOptions = { +export interface ModelOptions { model: ToolModel; primaryGitModel: GetGitModel; include: boolean; revision: string; deepClone: boolean; -}; +} @Component({ selector: 'create-readonly-model-options', diff --git a/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-session-history/create-session-history.component.ts b/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-session-history/create-session-history.component.ts index 92142bdd15..c902341bc0 100644 --- a/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-session-history/create-session-history.component.ts +++ b/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-session-history/create-session-history.component.ts @@ -140,10 +140,10 @@ export class CreateSessionHistoryComponent implements OnInit, OnDestroy { } } -export type ResolvedSessionRequestHistory = { +export interface ResolvedSessionRequestHistory { tool: Tool; version: ToolVersion; connectionMethod: ConnectionMethod; loading: boolean; lastTimeRequested: Date; -}; +} diff --git a/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-session-history/session-history.service.ts b/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-session-history/session-history.service.ts index 5165cd3670..5ad57adfde 100644 --- a/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-session-history/session-history.service.ts +++ b/frontend/src/app/sessions/user-sessions-wrapper/create-sessions/create-session-history/session-history.service.ts @@ -12,8 +12,6 @@ export class SessionHistoryService { LOCAL_STORAGE_SESSION_HISTORY_KEY = 'sessionRequestHistory'; MAX_SESSIONS_IN_HISTORY = 3; - constructor() {} - sessionHistory = new BehaviorSubject( undefined, ); @@ -92,9 +90,9 @@ export class SessionHistoryService { } } -export type SessionRequestHistory = { +export interface SessionRequestHistory { toolId: number; versionId: number; connectionMethodId: string; lastRequested: Date; -}; +} diff --git a/frontend/src/app/settings/core/pipelines-overview/service/monitoring.service.ts b/frontend/src/app/settings/core/pipelines-overview/service/monitoring.service.ts index ee79d9d422..40ba031658 100644 --- a/frontend/src/app/settings/core/pipelines-overview/service/monitoring.service.ts +++ b/frontend/src/app/settings/core/pipelines-overview/service/monitoring.service.ts @@ -32,13 +32,13 @@ export class MonitoringService { } } -export type GeneralHealth = { +export interface GeneralHealth { guacamole: boolean; database: boolean; operator: boolean; -}; +} -export type ToolmodelStatus = { +export interface ToolmodelStatus { project_slug: string; model_slug: string; @@ -47,13 +47,13 @@ export type ToolmodelStatus = { pipeline_status: PipelineRunStatus; model_badge_status: ModelModifierStatus; diagram_cache_status: ModelModifierStatus; -}; +} -export type ProjectStatus = { +export interface ProjectStatus { project_slug: string; warnings: string[]; -}; +} export type ModelModifierStatus = | 'success' diff --git a/frontend/src/app/settings/core/tools-settings/tool.service.ts b/frontend/src/app/settings/core/tools-settings/tool.service.ts index a0e1f4561c..8b2a0be498 100644 --- a/frontend/src/app/settings/core/tools-settings/tool.service.ts +++ b/frontend/src/app/settings/core/tools-settings/tool.service.ts @@ -18,63 +18,63 @@ import { environment } from 'src/environments/environment'; // The generator has a pretty long name, so we're going to shorten it. export type ConnectionMethod = ToolSessionConnectionOutputMethodsInner; -export type ToolSessionProvisioningConfiguration = { +export interface ToolSessionProvisioningConfiguration { max_number_of_models?: number; -}; +} -export type ToolSessionConnectionConfiguration = { +export interface ToolSessionConnectionConfiguration { methods: ConnectionMethod[]; -}; +} -export type WorkspaceConfiguration = { +export interface WorkspaceConfiguration { mounting_enabled: boolean; -}; +} -export type ToolSessionConfiguration = { +export interface ToolSessionConfiguration { connection: ToolSessionConnectionConfiguration; provisioning: ToolSessionProvisioningConfiguration; persistent_workspaces: WorkspaceConfiguration; -}; +} -export type CreateTool = { +export interface CreateTool { name: string; integrations: ToolIntegrations; config: ToolSessionConfiguration; -}; +} -export type ToolIntegrations = { +export interface ToolIntegrations { t4c: boolean | null; pure_variants: boolean | null; jupyter: boolean | null; -}; +} -export type CreateToolVersion = { +export interface CreateToolVersion { name: string; config: ToolVersionConfig; -}; +} -export type ToolVersionConfig = { +export interface ToolVersionConfig { is_recommended: boolean; is_deprecated: boolean; compatible_versions: number[]; -}; +} export type ToolVersionWithTool = ToolVersion & { tool: Tool }; -export type CreateToolNature = { +export interface CreateToolNature { name: string; -}; +} -export type ToolExtended = { +export interface ToolExtended { natures: ToolNature[]; versions: ToolVersion[]; -}; +} -export type ToolDockerimages = { +export interface ToolDockerimages { persistent: string; readonly: string | undefined; backup: string | undefined; -}; +} @Injectable({ providedIn: 'root', diff --git a/frontend/src/app/settings/core/tools-settings/tools-settings.component.ts b/frontend/src/app/settings/core/tools-settings/tools-settings.component.ts index e121649f3e..1cf06ef822 100644 --- a/frontend/src/app/settings/core/tools-settings/tools-settings.component.ts +++ b/frontend/src/app/settings/core/tools-settings/tools-settings.component.ts @@ -20,7 +20,7 @@ import { ToolExtended, ToolWrapperService } from './tool.service'; imports: [RouterLink, MatRipple, MatIconComponent, NgFor, NgIf, MatIcon], }) export class ToolsSettingsComponent { - tools: { [id: string]: ToolExtended } = {}; + tools: Record = {}; constructor(public toolService: ToolWrapperService) { this.tools = {}; diff --git a/frontend/src/app/settings/integrations/pure-variants/service/pure-variants.service.ts b/frontend/src/app/settings/integrations/pure-variants/service/pure-variants.service.ts index 6d6480564f..9c8a290600 100644 --- a/frontend/src/app/settings/integrations/pure-variants/service/pure-variants.service.ts +++ b/frontend/src/app/settings/integrations/pure-variants/service/pure-variants.service.ts @@ -41,7 +41,7 @@ export class PureVariantsService { } } -export type PureVariantsConfiguration = { +export interface PureVariantsConfiguration { license_server_url?: string; license_key_filename: string; -}; +} diff --git a/frontend/src/app/settings/modelsources/git-settings/service/git-instances.service.ts b/frontend/src/app/settings/modelsources/git-settings/service/git-instances.service.ts index b0a4ff0d4a..b2047a3638 100644 --- a/frontend/src/app/settings/modelsources/git-settings/service/git-instances.service.ts +++ b/frontend/src/app/settings/modelsources/git-settings/service/git-instances.service.ts @@ -88,7 +88,7 @@ export class GitInstancesService { } asyncNameValidator(ignoreInstance?: GitInstance): AsyncValidatorFn { - const ignoreId = !!ignoreInstance ? ignoreInstance.id : -1; + const ignoreId = ignoreInstance ? ignoreInstance.id : -1; return (control: AbstractControl): Observable => { return this.gitInstances$.pipe( take(1), @@ -104,23 +104,23 @@ export class GitInstancesService { } } -export type BackendBasicGitInstance = { +export interface BackendBasicGitInstance { id: number; name: string; url: string; api_url?: string; type: GitType; -}; +} export type BasicGitInstance = Omit; -export type GitInstance = { +export interface GitInstance { id: number; name: string; url: string; apiURL?: string; type: GitType; -}; +} export type GitType = 'general' | 'gitlab' | 'github' | 'azuredevops'; diff --git a/frontend/src/app/users/basic-auth-service/basic-auth-token.service.ts b/frontend/src/app/users/basic-auth-service/basic-auth-token.service.ts index 8eb932f87a..24c5296474 100644 --- a/frontend/src/app/users/basic-auth-service/basic-auth-token.service.ts +++ b/frontend/src/app/users/basic-auth-service/basic-auth-token.service.ts @@ -51,12 +51,12 @@ export class TokenService { } } -export type Token = { +export interface Token { description: string; expiration_date: string; source: string; id: number; -}; +} export type CreateTokenResponse = Token & { password: string; diff --git a/frontend/src/app/users/users-profile/user-workspaces/user-workspaces.component.ts b/frontend/src/app/users/users-profile/user-workspaces/user-workspaces.component.ts index 2ac619125d..963520c2c2 100644 --- a/frontend/src/app/users/users-profile/user-workspaces/user-workspaces.component.ts +++ b/frontend/src/app/users/users-profile/user-workspaces/user-workspaces.component.ts @@ -42,6 +42,10 @@ export class UserWorkspacesComponent { this.reloadWorkspaces(); } + get user(): User | undefined { + return this._user; + } + reloadWorkspaces() { this.workspaces = undefined; if ( @@ -59,10 +63,6 @@ export class UserWorkspacesComponent { }); } - get user(): User | undefined { - return this._user; - } - constructor( public userService: UserWrapperService, private usersService: UsersService, diff --git a/frontend/src/storybook/diagram.ts b/frontend/src/storybook/diagram.ts index 19bae480a0..3392bb8835 100644 --- a/frontend/src/storybook/diagram.ts +++ b/frontend/src/storybook/diagram.ts @@ -3,5 +3,5 @@ * SPDX-License-Identifier: Apache-2.0 */ -export const base64ModelDiagram: string = +export const base64ModelDiagram = ''; diff --git a/frontend/src/storybook/model-badge.ts b/frontend/src/storybook/model-badge.ts index e4b6ebf022..b9a663e3b5 100644 --- a/frontend/src/storybook/model-badge.ts +++ b/frontend/src/storybook/model-badge.ts @@ -3,5 +3,5 @@ * SPDX-License-Identifier: Apache-2.0 */ -export const base64ModelBadge: string = +export const base64ModelBadge = ''; diff --git a/frontend/src/storybook/t4c.ts b/frontend/src/storybook/t4c.ts index 074142f40d..c934e86cc3 100644 --- a/frontend/src/storybook/t4c.ts +++ b/frontend/src/storybook/t4c.ts @@ -71,7 +71,7 @@ export class MockT4CInstanceWrapperService }; } - resetT4CInstance(): void {} + resetT4CInstance(): void {} // eslint-disable-line @typescript-eslint/no-empty-function } export class MockT4CRepositoryWrapperService @@ -87,7 +87,7 @@ export class MockT4CRepositoryWrapperService this._repositories.next(repositories); } - reset() {} + reset() {} // eslint-disable-line @typescript-eslint/no-empty-function asyncNameValidator(): AsyncValidatorFn { return (_control: AbstractControl): Observable => {