Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Editor: Fix error when creating new record #1061

Merged
merged 9 commits into from
Dec 19, 2024
16 changes: 10 additions & 6 deletions apps/metadata-editor/src/app/duplicate-record.resolver.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -75,12 +75,16 @@ describe('DuplicateRecordResolver', () => {
expect(resolvedData).toBeUndefined()
})
it('should show error notification', () => {
expect(notificationsService.showNotification).toHaveBeenCalledWith({
type: 'error',
title: 'editor.record.loadError.title',
text: 'editor.record.loadError.body oopsie',
closeMessage: 'editor.record.loadError.closeMessage',
})
expect(notificationsService.showNotification).toHaveBeenCalledWith(
{
type: 'error',
title: 'editor.record.loadError.title',
text: 'editor.record.loadError.body oopsie',
closeMessage: 'editor.record.loadError.closeMessage',
},
undefined,
expect.any(Error)
)
})
})
})
28 changes: 16 additions & 12 deletions apps/metadata-editor/src/app/duplicate-record.resolver.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,18 +23,22 @@ export class DuplicateRecordResolver {
.openRecordForDuplication(route.paramMap.get('uuid'))
.pipe(
catchError((error) => {
this.notificationsService.showNotification({
type: 'error',
title: this.translateService.instant(
'editor.record.loadError.title'
),
text: `${this.translateService.instant(
'editor.record.loadError.body'
)} ${error.message}`,
closeMessage: this.translateService.instant(
'editor.record.loadError.closeMessage'
),
})
this.notificationsService.showNotification(
{
type: 'error',
title: this.translateService.instant(
'editor.record.loadError.title'
),
text: `${this.translateService.instant(
'editor.record.loadError.body'
)} ${error.message}`,
closeMessage: this.translateService.instant(
'editor.record.loadError.closeMessage'
),
},
undefined,
error
)
return EMPTY
})
)
Expand Down
16 changes: 10 additions & 6 deletions apps/metadata-editor/src/app/edit-record.resolver.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -75,12 +75,16 @@ describe('EditRecordResolver', () => {
expect(resolvedData).toBeUndefined()
})
it('should show error notification', () => {
expect(notificationsService.showNotification).toHaveBeenCalledWith({
type: 'error',
title: 'editor.record.loadError.title',
text: 'editor.record.loadError.body oopsie',
closeMessage: 'editor.record.loadError.closeMessage',
})
expect(notificationsService.showNotification).toHaveBeenCalledWith(
{
type: 'error',
title: 'editor.record.loadError.title',
text: 'editor.record.loadError.body oopsie',
closeMessage: 'editor.record.loadError.closeMessage',
},
undefined,
expect.any(Error)
)
})
})
})
28 changes: 16 additions & 12 deletions apps/metadata-editor/src/app/edit-record.resolver.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,18 +23,22 @@ export class EditRecordResolver {
.openRecordForEdition(route.paramMap.get('uuid'))
.pipe(
catchError((error) => {
this.notificationsService.showNotification({
type: 'error',
title: this.translateService.instant(
'editor.record.loadError.title'
),
text: `${this.translateService.instant(
'editor.record.loadError.body'
)} ${error.message}`,
closeMessage: this.translateService.instant(
'editor.record.loadError.closeMessage'
),
})
this.notificationsService.showNotification(
{
type: 'error',
title: this.translateService.instant(
'editor.record.loadError.title'
),
text: `${this.translateService.instant(
'editor.record.loadError.body'
)} ${error.message}`,
closeMessage: this.translateService.instant(
'editor.record.loadError.closeMessage'
),
},
undefined,
error
)
return EMPTY
})
)
Expand Down
63 changes: 20 additions & 43 deletions apps/metadata-editor/src/app/edit/edit-page.component.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -121,24 +121,32 @@ describe('EditPageComponent', () => {
describe('publish version error', () => {
it('shows notification', () => {
;(facade.saveError$ as any).next(new PublicationVersionError('1.0.0'))
expect(notificationsService.showNotification).toHaveBeenCalledWith({
type: 'error',
title: 'editor.record.publishVersionError.title',
text: 'editor.record.publishVersionError.body',
closeMessage: 'editor.record.publishVersionError.closeMessage',
})
expect(notificationsService.showNotification).toHaveBeenCalledWith(
{
type: 'error',
title: 'editor.record.publishVersionError.title',
text: 'editor.record.publishVersionError.body',
closeMessage: 'editor.record.publishVersionError.closeMessage',
},
undefined,
expect.any(PublicationVersionError)
)
})
})

describe('publish error', () => {
it('shows notification', () => {
;(facade.saveError$ as any).next(new Error('oopsie'))
expect(notificationsService.showNotification).toHaveBeenCalledWith({
type: 'error',
title: 'editor.record.publishError.title',
text: 'editor.record.publishError.body oopsie',
closeMessage: 'editor.record.publishError.closeMessage',
})
expect(notificationsService.showNotification).toHaveBeenCalledWith(
{
type: 'error',
title: 'editor.record.publishError.title',
text: 'editor.record.publishError.body oopsie',
closeMessage: 'editor.record.publishError.closeMessage',
},
undefined,
expect.any(Error)
)
})
})

Expand All @@ -157,37 +165,6 @@ describe('EditPageComponent', () => {
})
})

describe('new record', () => {
beforeEach(() => {
const activatedRoute = TestBed.inject(ActivatedRoute)
activatedRoute.snapshot.routeConfig.path = '/create'
fixture.detectChanges()
})
it('navigate from /create to /edit/uuid on first change', () => {
const router = TestBed.inject(Router)
const navigateSpy = jest.spyOn(router, 'navigate')
;(facade.draftSaveSuccess$ as any).next()
expect(navigateSpy).toHaveBeenCalledWith(['edit', 'my-dataset-001'], {
replaceUrl: true,
})
})
})

describe('unique identifier of the current record changes', () => {
beforeEach(() => {
fixture.detectChanges()
})
it('navigates to /edit/newUuid', () => {
const router = TestBed.inject(Router)
const navigateSpy = jest.spyOn(router, 'navigate')
;(facade.record$ as any).next({
...datasetRecordsFixture()[0],
uniqueIdentifier: 'new-uuid',
})
expect(navigateSpy).toHaveBeenCalledWith(['edit', 'new-uuid'])
})
})

describe('isLastPage$', () => {
let editorFacade: EditorFacadeMock
beforeEach(() => {
Expand Down
80 changes: 33 additions & 47 deletions apps/metadata-editor/src/app/edit/edit-page.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -83,32 +83,40 @@ export class EditPageComponent implements OnInit, OnDestroy {
this.subscription.add(
this.facade.saveError$.subscribe((error) => {
if (error instanceof PublicationVersionError) {
this.notificationsService.showNotification({
type: 'error',
title: this.translateService.instant(
'editor.record.publishVersionError.title'
),
text: this.translateService.instant(
'editor.record.publishVersionError.body',
{ currentVersion: error.detectedApiVersion }
),
closeMessage: this.translateService.instant(
'editor.record.publishVersionError.closeMessage'
),
})
this.notificationsService.showNotification(
{
type: 'error',
title: this.translateService.instant(
'editor.record.publishVersionError.title'
),
text: this.translateService.instant(
'editor.record.publishVersionError.body',
{ currentVersion: error.detectedApiVersion }
),
closeMessage: this.translateService.instant(
'editor.record.publishVersionError.closeMessage'
),
},
undefined,
error
)
} else {
this.notificationsService.showNotification({
type: 'error',
title: this.translateService.instant(
'editor.record.publishError.title'
),
text: `${this.translateService.instant(
'editor.record.publishError.body'
)} ${error.message}`,
closeMessage: this.translateService.instant(
'editor.record.publishError.closeMessage'
),
})
this.notificationsService.showNotification(
{
type: 'error',
title: this.translateService.instant(
'editor.record.publishError.title'
),
text: `${this.translateService.instant(
'editor.record.publishError.body'
)} ${error.message}`,
closeMessage: this.translateService.instant(
'editor.record.publishError.closeMessage'
),
},
undefined,
error
)
}
})
)
Expand All @@ -129,28 +137,6 @@ export class EditPageComponent implements OnInit, OnDestroy {
)
})
)

// if we're on the /create route, go to /edit/{uuid} on first change
if (this.route.snapshot.routeConfig?.path.includes('create')) {
this.facade.draftSaveSuccess$.pipe(take(1)).subscribe(() => {
this.router.navigate(['edit', currentRecord.uniqueIdentifier], {
replaceUrl: true,
})
})
}

// if the record unique identifier changes, navigate to /edit/newUuid
this.facade.record$
.pipe(
filter(
(record) =>
record?.uniqueIdentifier !== currentRecord.uniqueIdentifier
),
take(1)
)
.subscribe((savedRecord) => {
this.router.navigate(['edit', savedRecord.uniqueIdentifier])
})
tkohr marked this conversation as resolved.
Show resolved Hide resolved
}

ngOnDestroy() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import { NotificationsService } from '@geonetwork-ui/feature/notifications'
import { RecordsRepositoryInterface } from '@geonetwork-ui/common/domain/repository/records-repository.interface'
import { of, throwError } from 'rxjs'
import { MockBuilder, MockComponent, MockModule, MockProviders } from 'ng-mocks'
import exp from 'constants'
tkohr marked this conversation as resolved.
Show resolved Hide resolved

describe('ImportRecordComponent', () => {
let component: ImportRecordComponent
Expand Down Expand Up @@ -112,7 +113,8 @@ describe('ImportRecordComponent', () => {
title: 'editor.record.importFromExternalFile.failure.title',
text: `editor.record.importFromExternalFile.failure.body `,
}),
2500
2500,
mockError
)

expect(component.isRecordImportInProgress).toBe(false)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -142,7 +142,8 @@ export class ImportRecordComponent {
'editor.record.importFromExternalFile.failure.body'
)} ${error.message ?? ''}`,
},
2500
2500,
error
)
this.isRecordImportInProgress = false
this.cdr.markForCheck()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -143,12 +143,16 @@ describe('FormFieldOnlineLinkResourcesComponent', () => {
expect(component.uploadProgress).toBeUndefined()
component.handleFileChange(file)
uploadSubject.error(new Error('something went wrong'))
expect(notificationsService.showNotification).toHaveBeenCalledWith({
type: 'error',
closeMessage: 'editor.record.onlineResourceError.closeMessage',
text: 'editor.record.onlineResourceError.body something went wrong',
title: 'editor.record.onlineResourceError.title',
})
expect(notificationsService.showNotification).toHaveBeenCalledWith(
{
type: 'error',
closeMessage: 'editor.record.onlineResourceError.closeMessage',
text: 'editor.record.onlineResourceError.body something went wrong',
title: 'editor.record.onlineResourceError.title',
},
undefined,
expect.any(Error)
)
})
})
describe('handleUploadCancel', () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -137,18 +137,22 @@ export class FormFieldOnlineLinkResourcesComponent {
private handleError(error: Error) {
this.uploadProgress = undefined
this.cd.detectChanges()
this.notificationsService.showNotification({
type: 'error',
title: this.translateService.instant(
'editor.record.onlineResourceError.title'
),
text: `${this.translateService.instant(
'editor.record.onlineResourceError.body'
)} ${error.message}`,
closeMessage: this.translateService.instant(
'editor.record.onlineResourceError.closeMessage'
),
})
this.notificationsService.showNotification(
{
type: 'error',
title: this.translateService.instant(
'editor.record.onlineResourceError.title'
),
text: `${this.translateService.instant(
'editor.record.onlineResourceError.body'
)} ${error.message}`,
closeMessage: this.translateService.instant(
'editor.record.onlineResourceError.closeMessage'
),
},
undefined,
error
)
}

private openEditDialog(resource: OnlineLinkResource, index: number) {
Expand Down
Loading
Loading