From 7af04be43fabae94073fad80ebfdc95581701738 Mon Sep 17 00:00:00 2001 From: markuczy <129275100+markuczy@users.noreply.github.com> Date: Wed, 31 Jan 2024 19:54:03 +0100 Subject: [PATCH] feat: name in paths instead of id (#58) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Henry Täschner <129834483+HenryT-CG@users.noreply.github.com> --- .../theme-designer.component.spec.ts | 41 ++++++++++--------- .../theme-designer.component.ts | 21 ++++++---- .../theme-detail.component.spec.ts | 28 ++++++------- .../theme-detail/theme-detail.component.ts | 5 ++- .../theme-search/theme-search.component.html | 4 +- src/app/theme/theme.module.ts | 4 +- 6 files changed, 54 insertions(+), 49 deletions(-) diff --git a/src/app/theme/theme-designer/theme-designer.component.spec.ts b/src/app/theme/theme-designer/theme-designer.component.spec.ts index a7e129e..f1e3c2a 100644 --- a/src/app/theme/theme-designer/theme-designer.component.spec.ts +++ b/src/app/theme/theme-designer/theme-designer.component.spec.ts @@ -44,7 +44,8 @@ describe('ThemeDesignerComponent', () => { 'getThemes', 'updateTheme', 'createTheme', - 'getThemeById' + 'getThemeById', + 'getThemeByName' ]) beforeEach(waitForAsync(() => { @@ -79,6 +80,7 @@ describe('ThemeDesignerComponent', () => { msgServiceSpy.error.calls.reset() msgServiceSpy.info.calls.reset() themeApiSpy.getThemeById.calls.reset() + themeApiSpy.getThemeByName.calls.reset() themeApiSpy.updateTheme.calls.reset() themeApiSpy.createTheme.calls.reset() themeApiSpy.getThemes.calls.reset() @@ -88,6 +90,7 @@ describe('ThemeDesignerComponent', () => { themeApiSpy.updateTheme.and.returnValue(of({}) as any) themeApiSpy.createTheme.and.returnValue(of({}) as any) themeApiSpy.getThemeById.and.returnValue(of({}) as any) + themeApiSpy.getThemeByName.and.returnValue(of({}) as any) })) describe('when constructing', () => { @@ -117,13 +120,13 @@ describe('ThemeDesignerComponent', () => { it('should populate state and create forms', () => { const activatedRoute = TestBed.inject(ActivatedRoute) - spyOn(activatedRoute.snapshot.paramMap, 'get').and.returnValue('themeId') + spyOn(activatedRoute.snapshot.paramMap, 'get').and.returnValue('themeName') fixture = TestBed.createComponent(ThemeDesignerComponent) component = fixture.componentInstance fixture.detectChanges() - expect(component.themeId).toBe('themeId') + expect(component.themeName).toBe('themeName') expect(component.themeIsCurrentUsedTheme).toBeFalse() expect(Object.keys(component.fontForm.controls).length).toBe(themeVariables.font.length) expect(Object.keys(component.generalForm.controls).length).toBe(themeVariables.general.length) @@ -239,20 +242,21 @@ describe('ThemeDesignerComponent', () => { const themeResponse = { resource: themeData } - themeApiSpy.getThemeById.and.returnValue(of(themeResponse) as any) + themeApiSpy.getThemeByName.and.returnValue(of(themeResponse) as any) component.mode = 'EDIT' - component.themeId = 'themeId' + component.themeName = 'themeName' component.ngOnInit() expect(component.theme).toBe(themeData) - expect(themeApiSpy.getThemeById).toHaveBeenCalledOnceWith({ id: 'themeId' }) + expect(themeApiSpy.getThemeByName).toHaveBeenCalledOnceWith({ name: 'themeName' }) expect(component.basicForm.controls['name'].value).toBe(themeData.name) expect(component.basicForm.controls['description'].value).toBe(themeData.description) expect(component.basicForm.controls['logoUrl'].value).toBe(themeData.logoUrl) expect(component.basicForm.controls['faviconUrl'].value).toBe(themeData.faviconUrl) expect(component.fontForm.controls['font-family'].value).toBe('myFont') expect(component.generalForm.controls['primary-color'].value).toBe('rgb(0,0,0)') + expect(component.themeId).toBe('id') }) it('should fetch logo and favicon from backend on edit mode when no http[s] present', () => { @@ -264,9 +268,9 @@ describe('ThemeDesignerComponent', () => { const themeResponse = { resource: themeData } - themeApiSpy.getThemeById.and.returnValue(of(themeResponse) as any) + themeApiSpy.getThemeByName.and.returnValue(of(themeResponse) as any) component.mode = 'EDIT' - component.themeId = 'themeId' + component.themeName = 'themeName' component.ngOnInit() @@ -282,9 +286,9 @@ describe('ThemeDesignerComponent', () => { const themeResponse = { resource: themeData } - themeApiSpy.getThemeById.and.returnValue(of(themeResponse) as any) + themeApiSpy.getThemeByName.and.returnValue(of(themeResponse) as any) component.mode = 'EDIT' - component.themeId = 'themeId' + component.themeName = 'themeName' component.ngOnInit() @@ -376,7 +380,7 @@ describe('ThemeDesignerComponent', () => { const themeResponse = { resource: themeData } - themeApiSpy.getThemeById.and.returnValue(of(themeResponse) as any) + themeApiSpy.getThemeByName.and.returnValue(of(themeResponse) as any) themeApiSpy.updateTheme.and.returnValue(throwError(() => new Error())) component.actions$?.subscribe((actions) => { @@ -408,7 +412,7 @@ describe('ThemeDesignerComponent', () => { const themeResponse = { resource: themeData } - themeApiSpy.getThemeById.and.returnValue(of(themeResponse) as any) + themeApiSpy.getThemeByName.and.returnValue(of(themeResponse) as any) component.fontForm.patchValue({ 'font-family': 'updatedFont' @@ -471,7 +475,7 @@ describe('ThemeDesignerComponent', () => { const themeResponse = { resource: themeData } - themeApiSpy.getThemeById.and.returnValue(of(themeResponse) as any) + themeApiSpy.getThemeByName.and.returnValue(of(themeResponse) as any) const updateThemeData = { resource: { @@ -552,7 +556,7 @@ describe('ThemeDesignerComponent', () => { themeApiSpy.createTheme.and.returnValue( of({ resource: { - id: 'myThemeId' + name: 'myTheme' } }) as any ) @@ -578,7 +582,7 @@ describe('ThemeDesignerComponent', () => { }) ) expect(router.navigate).toHaveBeenCalledOnceWith( - [`../../myThemeId`], + [`../../myTheme`], jasmine.objectContaining({ relativeTo: route }) ) }) @@ -605,7 +609,7 @@ describe('ThemeDesignerComponent', () => { themeApiSpy.createTheme.and.returnValue( of({ resource: { - id: 'myThemeId' + name: 'myTheme' } }) as any ) @@ -613,10 +617,7 @@ describe('ThemeDesignerComponent', () => { component.saveTheme('myTheme') - expect(router.navigate).toHaveBeenCalledOnceWith( - [`../myThemeId`], - jasmine.objectContaining({ relativeTo: route }) - ) + expect(router.navigate).toHaveBeenCalledOnceWith([`../myTheme`], jasmine.objectContaining({ relativeTo: route })) }) it('should display save as new popup on save as click', (done: DoneFn) => { diff --git a/src/app/theme/theme-designer/theme-designer.component.ts b/src/app/theme/theme-designer/theme-designer.component.ts index 8302e1f..6fbcf97 100644 --- a/src/app/theme/theme-designer/theme-designer.component.ts +++ b/src/app/theme/theme-designer/theme-designer.component.ts @@ -24,7 +24,8 @@ export class ThemeDesignerComponent implements OnInit { public actions$: Observable | undefined public themes: Theme[] = [] public theme: Theme | undefined - public themeId: string | null + public themeId: string | undefined + public themeName: string | null public themeVars = themeVariables public themeTemplates!: SelectItem[] public themeTemplateSelectedId = '' @@ -62,9 +63,8 @@ export class ThemeDesignerComponent implements OnInit { private confirmation: ConfirmationService, private msgService: PortalMessageService ) { - this.mode = route.snapshot.paramMap.has('id') ? 'EDIT' : 'NEW' - this.themeId = route.snapshot.paramMap.get('id') - this.themeIsCurrentUsedTheme = this.themeId === this.appStateService.currentPortal$.getValue()?.themeId + this.mode = route.snapshot.paramMap.has('name') ? 'EDIT' : 'NEW' + this.themeName = route.snapshot.paramMap.get('name') this.prepareActionButtons() this.fontForm = new FormGroup({}) @@ -138,14 +138,16 @@ export class ThemeDesignerComponent implements OnInit { } ngOnInit(): void { - if (this.mode === 'EDIT' && this.themeId) { - this.getThemeById(this.themeId).subscribe((data) => { + if (this.mode === 'EDIT' && this.themeName) { + this.themeApi.getThemeByName({ name: this.themeName }).subscribe((data) => { this.theme = data.resource this.basicForm.patchValue(data.resource) this.propertiesForm.reset() this.propertiesForm.patchValue(data.resource.properties || {}) this.fetchingLogoUrl = prepareUrl(this.basicForm.value.logoUrl) this.fetchingFaviconUrl = prepareUrl(this.basicForm.value.faviconUrl) + this.themeId = data.resource.id + this.themeIsCurrentUsedTheme = this.themeId === this.appStateService.currentPortal$.getValue()?.themeId }) } else { const currentVars: { [key: string]: { [key: string]: string } } = {} @@ -286,7 +288,8 @@ export class ThemeDesignerComponent implements OnInit { this.msgService.error({ summaryKey: 'ACTIONS.EDIT.MESSAGE.CHANGE_NOK' }) } else { // eslint-disable-next-line @typescript-eslint/no-non-null-assertion - this.getThemeById(this.themeId!) + this.themeApi + .getThemeByName({ name: this.themeName! }) .pipe( switchMap((data) => { data.resource.properties = this.propertiesForm.value @@ -322,11 +325,11 @@ export class ThemeDesignerComponent implements OnInit { this.themeApi.createTheme({ createThemeRequest: { resource: newTheme } }).subscribe({ next: (data) => { if (this.mode === 'EDIT') { - this.router.navigate([`../../${data.resource.id}`], { + this.router.navigate([`../../${data.resource.name}`], { relativeTo: this.route }) } else { - this.router.navigate([`../${data.resource.id}`], { relativeTo: this.route }) + this.router.navigate([`../${data.resource.name}`], { relativeTo: this.route }) } this.msgService.success({ summaryKey: 'ACTIONS.CREATE.MESSAGE.CREATE_OK' }) }, diff --git a/src/app/theme/theme-detail/theme-detail.component.spec.ts b/src/app/theme/theme-detail/theme-detail.component.spec.ts index d392557..b93c940 100644 --- a/src/app/theme/theme-detail/theme-detail.component.spec.ts +++ b/src/app/theme/theme-detail/theme-detail.component.spec.ts @@ -32,7 +32,7 @@ describe('ThemeDetailComponent', () => { }) } const themesApiSpy = jasmine.createSpyObj('ThemesAPIService', [ - 'getThemeById', + 'getThemeByName', 'deleteTheme', 'exportThemes' ]) @@ -58,8 +58,8 @@ describe('ThemeDetailComponent', () => { }).compileComponents() msgServiceSpy.success.calls.reset() msgServiceSpy.error.calls.reset() - themesApiSpy.getThemeById.and.returnValue(of({}) as any) - themesApiSpy.getThemeById.calls.reset() + themesApiSpy.getThemeByName.and.returnValue(of({}) as any) + themesApiSpy.getThemeByName.calls.reset() themesApiSpy.exportThemes.and.returnValue(of({}) as any) themesApiSpy.exportThemes.calls.reset() })) @@ -76,9 +76,9 @@ describe('ThemeDetailComponent', () => { }) it('should create with provided id and get theme', async () => { - const id = 'themeId' + const name = 'themeName' const route = TestBed.inject(ActivatedRoute) - spyOn(route.snapshot.paramMap, 'get').and.returnValue(id) + spyOn(route.snapshot.paramMap, 'get').and.returnValue(name) translateService.use('de') // recreate component to test constructor @@ -86,13 +86,13 @@ describe('ThemeDetailComponent', () => { component = fixture.componentInstance fixture.detectChanges() - themesApiSpy.getThemeById.calls.reset() + themesApiSpy.getThemeByName.calls.reset() component.loading = true await component.ngOnInit() - expect(component.themeId).toBe(id) + expect(component.themeName).toBe(name) expect(component.dateFormat).toBe('medium') - expect(themesApiSpy.getThemeById).toHaveBeenCalledOnceWith({ id: id }) + expect(themesApiSpy.getThemeByName).toHaveBeenCalledOnceWith({ name: name }) expect(component.loading).toBe(false) }) @@ -117,7 +117,7 @@ describe('ThemeDetailComponent', () => { } ] } - themesApiSpy.getThemeById.and.returnValue(of(themeResponse) as any) + themesApiSpy.getThemeByName.and.returnValue(of(themeResponse) as any) const translateService = TestBed.inject(TranslateService) const actionsTranslations = { @@ -195,7 +195,7 @@ describe('ThemeDetailComponent', () => { } ] } - themesApiSpy.getThemeById.and.returnValue(of(themeResponse) as any) + themesApiSpy.getThemeByName.and.returnValue(of(themeResponse) as any) const translateService = TestBed.inject(TranslateService) const actionsTranslations = { @@ -241,7 +241,7 @@ describe('ThemeDetailComponent', () => { it('should display not found error and close page on theme fetch failure', () => { spyOn(component, 'close') - themesApiSpy.getThemeById.and.returnValue( + themesApiSpy.getThemeByName.and.returnValue( throwError( () => new HttpErrorResponse({ @@ -261,7 +261,7 @@ describe('ThemeDetailComponent', () => { it('should display catched error and close page on theme fetch failure', () => { spyOn(component, 'close') - themesApiSpy.getThemeById.and.returnValue( + themesApiSpy.getThemeByName.and.returnValue( throwError( () => new HttpErrorResponse({ @@ -303,7 +303,7 @@ describe('ThemeDetailComponent', () => { }, workspaces: [] } - themesApiSpy.getThemeById.and.returnValue(of(themeResponse) as any) + themesApiSpy.getThemeByName.and.returnValue(of(themeResponse) as any) await component.ngOnInit() @@ -319,7 +319,7 @@ describe('ThemeDetailComponent', () => { }, workspaces: [] } - themesApiSpy.getThemeById.and.returnValue(of(themeResponse) as any) + themesApiSpy.getThemeByName.and.returnValue(of(themeResponse) as any) await component.ngOnInit() expect(component.headerImageUrl).toBe(url) }) diff --git a/src/app/theme/theme-detail/theme-detail.component.ts b/src/app/theme/theme-detail/theme-detail.component.ts index a8ca13b..bd487d1 100644 --- a/src/app/theme/theme-detail/theme-detail.component.ts +++ b/src/app/theme/theme-detail/theme-detail.component.ts @@ -17,6 +17,7 @@ import { ExportThemeRequest, Theme, ThemesAPIService, Workspace } from 'src/app/ export class ThemeDetailComponent implements OnInit { theme: Theme | undefined usedInWorkspace: Workspace[] | undefined + themeName!: string themeId!: string themeDeleteVisible = false themeDeleteMessage = '' @@ -36,13 +37,13 @@ export class ThemeDetailComponent implements OnInit { private msgService: PortalMessageService, private translate: TranslateService ) { - this.themeId = this.route.snapshot.paramMap.get('id') || '' + this.themeName = this.route.snapshot.paramMap.get('name') || '' this.dateFormat = this.user.lang$.getValue() === 'de' ? 'dd.MM.yyyy HH:mm:ss' : 'medium' } ngOnInit(): void { this.themeApi - .getThemeById({ id: this.themeId }) + .getThemeByName({ name: this.themeName }) .pipe( finalize(() => { this.loading = false diff --git a/src/app/theme/theme-search/theme-search.component.html b/src/app/theme/theme-search/theme-search.component.html index 456b14c..a7e6ee2 100644 --- a/src/app/theme/theme-search/theme-search.component.html +++ b/src/app/theme/theme-search/theme-search.component.html @@ -44,7 +44,7 @@
@@ -69,7 +69,7 @@
-
+