From bdf0b600cfd3f8d5431936a145fe44ddbe96dae8 Mon Sep 17 00:00:00 2001 From: Henry Taeschner Date: Fri, 2 Feb 2024 20:39:20 +0100 Subject: [PATCH] feat: copy app --- src/_mixins.scss | 27 ++++++++++ .../app-detail/app-detail.component.ts | 51 ++++++++----------- .../app-search/app-search.component.scss | 27 ++-------- .../product-apps/product-apps.component.html | 4 +- .../product-apps/product-apps.component.scss | 24 +-------- .../product-apps/product-apps.component.ts | 2 +- .../product-detail.component.html | 2 +- .../product-detail.component.ts | 23 +++++++-- .../product-props/product-props.component.ts | 12 +++-- .../product.detail.component.spec.ts | 8 +-- src/assets/i18n/de.json | 1 + src/assets/i18n/en.json | 1 + 12 files changed, 89 insertions(+), 93 deletions(-) diff --git a/src/_mixins.scss b/src/_mixins.scss index facbc10..0d90ead 100644 --- a/src/_mixins.scss +++ b/src/_mixins.scss @@ -35,3 +35,30 @@ } } } + +@mixin card-badges { + :host ::ng-deep { + .card-badge-right { + display: inline-block; + position: absolute; + right: 2px; + &.badge-1 { + top: 3px; + } + &.badge-2 { + top: 30px; + } + } + .card-badge-left { + display: inline-block; + position: absolute; + left: 2px; + &.badge-1 { + top: 3px; + } + &.badge-2 { + top: 30px; + } + } + } +} diff --git a/src/app/product-store/app-detail/app-detail.component.ts b/src/app/product-store/app-detail/app-detail.component.ts index c056d6a..bbcc469 100644 --- a/src/app/product-store/app-detail/app-detail.component.ts +++ b/src/app/product-store/app-detail/app-detail.component.ts @@ -78,7 +78,6 @@ export class AppDetailComponent implements OnChanges { } ngOnChanges() { - console.log('app detail ngOnChanges() ' + this.changeMode, this.appAbstract) if (this.appAbstract && this.displayDetailDialog) { if (this.changeMode !== 'CREATE') { this.getApp() @@ -102,9 +101,12 @@ export class AppDetailComponent implements OnChanges { if (data) { this.app = data this.viewForm(this.app) - console.info('get app: ', data) if (this.changeMode === 'COPY') { - if (this.app && this.app.id) this.app.id = undefined + if (this.app && this.app.id) { + this.app.id = undefined + this.app.creationDate = undefined + this.app.modificationDate = undefined + } this.changeMode = 'CREATE' } else this.changeMode = 'EDIT' } @@ -148,31 +150,18 @@ export class AppDetailComponent implements OnChanges { } private createApp() { - console.log('app detail createApp() ') this.appApi.createMicrofrontend({ createMicrofrontendRequest: this.app as CreateMicrofrontendRequest }).subscribe({ next: () => { this.msgService.success({ summaryKey: 'ACTIONS.CREATE.APP.OK' }) this.displayDetailDialogChange.emit(false) }, error: (err) => { - this.msgService.error({ - summaryKey: 'ACTIONS.CREATE.APP.NOK', - detailKey: - err?.error?.errorCode && err?.error?.errorCode === 'PERSIST_ENTITY_FAILED' - ? err?.error?.detail.indexOf('microfrontend_app_id') > 0 - ? 'VALIDATION.APP.UNIQUE_CONSTRAINT.APP_ID' - : err?.error?.detail.indexOf('microfrontend_remote_module') > 0 - ? 'VALIDATION.APP.UNIQUE_CONSTRAINT.REMOTE_MODULE' - : 'VALIDATION.ERRORS.INTERNAL_ERROR' - : '' - }) - console.error('err', err) + this.displaySaveError(err) } }) } private updateApp() { - console.log('app detail updateApp() ' + this.app?.id) this.appApi .updateMicrofrontend({ id: this.app?.id ?? '', @@ -184,19 +173,23 @@ export class AppDetailComponent implements OnChanges { this.displayDetailDialogChange.emit(false) }, error: (err) => { - this.msgService.error({ - summaryKey: 'ACTIONS.EDIT.APP.NOK', - detailKey: - err?.error?.errorCode && err?.error?.errorCode === 'PERSIST_ENTITY_FAILED' - ? err?.error?.detail.indexOf('microfrontend_app_id') > 0 - ? 'VALIDATION.APP.UNIQUE_CONSTRAINT.APP_ID' - : err?.error?.detail.indexOf('microfrontend_remote_module') > 0 - ? 'VALIDATION.APP.UNIQUE_CONSTRAINT.REMOTE_MODULE' - : 'VALIDATION.ERRORS.INTERNAL_ERROR' - : '' - }) - console.error('err', err) + this.displaySaveError(err) } }) } + + private displaySaveError(err: any): void { + this.msgService.error({ + summaryKey: 'ACTIONS.' + this.changeMode + '.APP.NOK', + detailKey: + err?.error?.errorCode && err?.error?.errorCode === 'PERSIST_ENTITY_FAILED' + ? err?.error?.detail.indexOf('microfrontend_app_id') > 0 + ? 'VALIDATION.APP.UNIQUE_CONSTRAINT.APP_ID' + : err?.error?.detail.indexOf('microfrontend_remote_module') > 0 + ? 'VALIDATION.APP.UNIQUE_CONSTRAINT.REMOTE_MODULE' + : 'VALIDATION.ERRORS.INTERNAL_ERROR' + : '' + }) + console.error('err', err) + } } diff --git a/src/app/product-store/app-search/app-search.component.scss b/src/app/product-store/app-search/app-search.component.scss index 579d4a4..ca6dce5 100644 --- a/src/app/product-store/app-search/app-search.component.scss +++ b/src/app/product-store/app-search/app-search.component.scss @@ -1,27 +1,8 @@ -:host ::ng-deep { - .card-badge-right { - display: inline-block; - position: absolute; - right: 2px; - &.badge-1 { - top: 3px; - } - &.badge-2 { - top: 30px; - } - } - .card-badge-left { - display: inline-block; - position: absolute; - left: 2px; - &.badge-1 { - top: 3px; - } - &.badge-2 { - top: 30px; - } - } +@import '/src/_mixins.scss'; +@include card-badges; + +:host ::ng-deep { .danger-action-text { color: var(--danger-button-bg); } diff --git a/src/app/product-store/product-detail/product-apps/product-apps.component.html b/src/app/product-store/product-detail/product-apps/product-apps.component.html index 45897c8..137dcf3 100644 --- a/src/app/product-store/product-detail/product-apps/product-apps.component.html +++ b/src/app/product-store/product-detail/product-apps/product-apps.component.html @@ -21,7 +21,7 @@ - +