@valtimo/dossier 12.5.1 → 12.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/dossier-detail/dossier-detail.component.mjs +101 -55
- package/esm2022/lib/components/dossier-detail/tab/notes/notes.component.mjs +3 -3
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.mjs +26 -13
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.mjs +27 -12
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.mjs +42 -21
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.mjs +25 -11
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.mjs +32 -13
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.mjs +2 -5
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/widget-process/widget-process.mjs +17 -0
- package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.permissions.mjs +30 -0
- package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.service.mjs +45 -0
- package/esm2022/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.mjs +11 -10
- package/esm2022/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.mjs +52 -47
- package/esm2022/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.mjs +38 -6
- package/esm2022/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +84 -7
- package/esm2022/lib/components/note-modal/note-modal.component.mjs +3 -3
- package/esm2022/lib/models/case-widget-content.model.mjs +1 -1
- package/esm2022/lib/models/case-widget-display.model.mjs +1 -1
- package/esm2022/lib/models/case-widget.model.mjs +1 -1
- package/esm2022/lib/permissions/dossier-detail.permissions.mjs +6 -2
- package/esm2022/lib/services/dossier-detail-layout.service.mjs +10 -10
- package/fesm2022/valtimo-dossier.mjs +512 -211
- package/fesm2022/valtimo-dossier.mjs.map +1 -1
- package/lib/components/dossier-detail/dossier-detail.component.d.ts +20 -10
- package/lib/components/dossier-detail/dossier-detail.component.d.ts.map +1 -1
- package/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.d.ts +11 -3
- package/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.d.ts.map +1 -1
- package/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.d.ts +12 -4
- package/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.d.ts.map +1 -1
- package/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.d.ts +15 -4
- package/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.d.ts.map +1 -1
- package/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.d.ts +11 -3
- package/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.d.ts.map +1 -1
- package/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.d.ts +11 -3
- package/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.d.ts.map +1 -1
- package/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.d.ts +0 -1
- package/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.d.ts.map +1 -1
- package/lib/components/dossier-detail/tab/widgets/components/widget-process/widget-process.d.ts +13 -0
- package/lib/components/dossier-detail/tab/widgets/components/widget-process/widget-process.d.ts.map +1 -0
- package/lib/components/dossier-detail/tab/widgets/widgets.component.d.ts.map +1 -1
- package/lib/components/dossier-detail/tab/widgets/widgets.permissions.d.ts +8 -0
- package/lib/components/dossier-detail/tab/widgets/widgets.permissions.d.ts.map +1 -0
- package/lib/components/dossier-detail/tab/widgets/widgets.service.d.ts +16 -0
- package/lib/components/dossier-detail/tab/widgets/widgets.service.d.ts.map +1 -0
- package/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.d.ts +5 -3
- package/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.d.ts.map +1 -1
- package/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.d.ts +14 -13
- package/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.d.ts.map +1 -1
- package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts +8 -3
- package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +1 -1
- package/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts +14 -4
- package/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts.map +1 -1
- package/lib/models/case-widget-content.model.d.ts.map +1 -1
- package/lib/models/case-widget-display.model.d.ts +6 -2
- package/lib/models/case-widget-display.model.d.ts.map +1 -1
- package/lib/models/case-widget.model.d.ts +7 -1
- package/lib/models/case-widget.model.d.ts.map +1 -1
- package/lib/permissions/dossier-detail.permissions.d.ts +2 -1
- package/lib/permissions/dossier-detail.permissions.d.ts.map +1 -1
- package/lib/services/dossier-detail-layout.service.d.ts +4 -5
- package/lib/services/dossier-detail-layout.service.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -126,7 +126,7 @@ export class WidgetBlockComponent {
|
|
|
126
126
|
return `size=${widgetConfiguration.properties.defaultPageSize}`;
|
|
127
127
|
}
|
|
128
128
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetBlockComponent, deps: [{ token: i1.DossierWidgetsLayoutService }, { token: i1.DossierTabService }, { token: i2.ActivatedRoute }, { token: i1.DossierWidgetsApiService }, { token: i3.CdsThemeService }, { token: i0.Renderer2 }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
129
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetBlockComponent, isStandalone: true, selector: "valtimo-dossier-widget-block", inputs: { widget: "widget" }, viewQueries: [{ propertyName: "_widgetBlockContentRef", first: true, predicate: ["widgetBlockContent"], descendants: true }
|
|
129
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetBlockComponent, isStandalone: true, selector: "valtimo-dossier-widget-block", inputs: { widget: "widget" }, viewQueries: [{ propertyName: "_widgetBlockContentRef", first: true, predicate: ["widgetBlockContent"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n documentId: documentId$ | async,\n tabKey: tabKey$ | async,\n widgetConfiguration: widget$ | async,\n widgetData: widgetData$ | async,\n theme: theme$ | async,\n blockHeightPx: blockHeightPx$ | async,\n blockWidthPercentage: blockWidthPercentage$ | async,\n } as obs\"\n>\n <div #widgetBlock class=\"widget-block\" [attr.data-carbon-theme]=\"obs.theme\">\n <div #widgetBlockContent class=\"widget-block__content\">\n @if (obs.widgetData) {\n @switch (obs.widgetConfiguration.type) {\n @case (CaseWidgetType.TABLE) {\n <valtimo-widget-table\n [documentId]=\"obs.documentId\"\n [tabKey]=\"obs.tabKey\"\n [widgetConfiguration]=\"obs.widgetConfiguration\"\n [widgetData]=\"obs.widgetData\"\n ></valtimo-widget-table>\n }\n\n @case (CaseWidgetType.COLLECTION) {\n <valtimo-widget-collection\n [documentId]=\"obs.documentId\"\n [tabKey]=\"obs.tabKey\"\n [widgetConfiguration]=\"obs.widgetConfiguration\"\n [widgetData]=\"obs.widgetData\"\n ></valtimo-widget-collection>\n }\n\n @case (CaseWidgetType.CUSTOM) {\n <valtimo-widget-custom [widgetConfig]=\"obs.widgetConfiguration\"></valtimo-widget-custom>\n }\n\n @case (CaseWidgetType.FIELDS) {\n <valtimo-widget-field\n [collapseVertically]=\"true\"\n [widgetConfiguration]=\"obs.widgetConfiguration\"\n [widgetData]=\"obs.widgetData\"\n ></valtimo-widget-field>\n }\n\n @case (CaseWidgetType.FORMIO) {\n <valtimo-widget-formio\n [widgetConfiguration]=\"obs.widgetConfiguration\"\n [documentId]=\"obs.documentId\"\n ></valtimo-widget-formio>\n }\n\n @default {\n <div class=\"widget-block__not-available\">\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noWidget' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n </div>\n }\n }\n } @else {\n <div class=\"widget-block__not-available\">\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n </div>\n }\n </div>\n </div>\n</ng-container>\n", styles: [":host{display:block;position:absolute}.widget-block{width:100%;height:100%;box-sizing:border-box;padding:8px;overflow-wrap:break-word;background-color:var(--cds-layer-01);background-clip:content-box}.widget-block__not-available{padding:16px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "ngmodule", type: LoadingModule }, { kind: "component", type: WidgetTableComponent, selector: "valtimo-widget-table", inputs: ["documentId", "tabKey", "widgetConfiguration", "widgetData"] }, { kind: "component", type: WidgetCustomComponent, selector: "valtimo-widget-custom", inputs: ["widgetConfig"] }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i3.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: TilesModule }, { kind: "component", type: WidgetFieldComponent, selector: "valtimo-widget-field", inputs: ["collapseVertically", "widgetConfiguration", "widgetData"] }, { kind: "component", type: WidgetFormioComponent, selector: "valtimo-widget-formio", inputs: ["documentId", "widgetConfiguration"] }, { kind: "component", type: WidgetCollectionComponent, selector: "valtimo-widget-collection", inputs: ["documentId", "tabKey", "widgetConfiguration", "widgetData"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
130
130
|
}
|
|
131
131
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetBlockComponent, decorators: [{
|
|
132
132
|
type: Component,
|
|
@@ -145,10 +145,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
145
145
|
}], ctorParameters: () => [{ type: i1.DossierWidgetsLayoutService }, { type: i1.DossierTabService }, { type: i2.ActivatedRoute }, { type: i1.DossierWidgetsApiService }, { type: i3.CdsThemeService }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }], propDecorators: { _widgetBlockContentRef: [{
|
|
146
146
|
type: ViewChild,
|
|
147
147
|
args: ['widgetBlockContent']
|
|
148
|
-
}], _widgetBlockRef: [{
|
|
149
|
-
type: ViewChild,
|
|
150
|
-
args: ['widgetBlock']
|
|
151
148
|
}], widget: [{
|
|
152
149
|
type: Input
|
|
153
150
|
}] } });
|
|
154
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-block.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {CommonModule} from '@angular/common';\nimport {HttpErrorResponse} from '@angular/common/http';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  Renderer2,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {\n  CARBON_THEME,\n  CarbonListModule,\n  CdsThemeService,\n  CurrentCarbonTheme,\n} from '@valtimo/components';\nimport {LoadingModule, TilesModule} from 'carbon-components-angular';\nimport {\n  BehaviorSubject,\n  catchError,\n  combineLatest,\n  filter,\n  map,\n  Observable,\n  of,\n  Subscription,\n  switchMap,\n  tap,\n} from 'rxjs';\nimport {CaseWidgetType, CaseWidgetWithUuid, WidgetTableContent} from '../../../../../../models';\nimport {\n  DossierTabService,\n  DossierWidgetsApiService,\n  DossierWidgetsLayoutService,\n} from '../../../../../../services';\nimport {WidgetCustomComponent} from '../custom/widget-custom.component';\nimport {WidgetFieldComponent} from '../field/widget-field.component';\nimport {WidgetFormioComponent} from '../formio/widget-formio.component';\nimport {WidgetTableComponent} from '../table/widget-table.component';\nimport {WidgetCollectionComponent} from '../collection/widget-collection.component';\nimport {WIDGET_HEIGHT_1X} from '../../../../../../constants';\n\n@Component({\n  selector: 'valtimo-dossier-widget-block',\n  templateUrl: './widget-block.component.html',\n  styleUrls: ['./widget-block.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    LoadingModule,\n    WidgetTableComponent,\n    WidgetCustomComponent,\n    CarbonListModule,\n    TranslateModule,\n    TilesModule,\n    WidgetFieldComponent,\n    WidgetFormioComponent,\n    WidgetCollectionComponent,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WidgetBlockComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('widgetBlockContent') private _widgetBlockContentRef: ElementRef<HTMLDivElement>;\n  @ViewChild('widgetBlock') private _widgetBlockRef: ElementRef<HTMLDivElement>;\n\n  @Input() public set widget(value: CaseWidgetWithUuid) {\n    this._widgetUuid = value.uuid;\n    this._widget$.next(value);\n  }\n\n  private readonly _widget$ = new BehaviorSubject<CaseWidgetWithUuid | null>(null);\n\n  public get widget$(): Observable<CaseWidgetWithUuid> {\n    return this._widget$.pipe(filter(widget => widget !== null));\n  }\n\n  private readonly _viewContainerRefSubject$ = new BehaviorSubject<ViewContainerRef | null>(null);\n\n  private get _viewContainerRef$(): Observable<ViewContainerRef> {\n    return this._viewContainerRefSubject$.pipe(filter(ref => !!ref));\n  }\n\n  private readonly _contentHeight$ = new BehaviorSubject<number>(0);\n\n  public readonly blockHeightPx$ = combineLatest([\n    this._contentHeight$,\n    this._viewContainerRef$,\n  ]).pipe(\n    filter(([contentHeight]) => contentHeight !== 0),\n    tap(([contentHeight, viewRef]) => {\n      const blockHeight = Math.ceil((contentHeight + 16) / WIDGET_HEIGHT_1X) * WIDGET_HEIGHT_1X;\n\n      this.renderer.setStyle(viewRef.element.nativeElement, 'height', `${blockHeight}px`);\n      this.dossierWidgetsLayoutService.triggerMuuriLayout();\n    })\n  );\n\n  public readonly blockWidthPercentage$ = combineLatest([\n    this.dossierWidgetsLayoutService.amountOfColumns$,\n    this.widget$,\n    this._viewContainerRef$,\n  ]).pipe(\n    tap(([amountOfColumns, widget, viewRef]) => {\n      const percentage =\n        widget.width > amountOfColumns ? 100 : (widget.width / amountOfColumns) * 100;\n\n      this.renderer.setStyle(viewRef.element.nativeElement, 'width', `${percentage}%`);\n      this.dossierWidgetsLayoutService.triggerMuuriLayout();\n    })\n  );\n\n  public readonly CaseWidgetType = CaseWidgetType;\n\n  public readonly documentId$ = this.route.params.pipe(\n    map(params => params?.documentId),\n    filter(documentId => !!documentId)\n  );\n\n  public readonly tabKey$: Observable<string> = this.dossierTabService.activeTabKey$;\n\n  public readonly widgetData$: Observable<any[] | {} | null> = combineLatest([\n    this.widget$,\n    this.tabKey$,\n    this.documentId$,\n  ]).pipe(\n    switchMap(([widget, tabkey, documentId]) =>\n      // custom component and formio widgets do not fetch additional data\n      widget.type === CaseWidgetType.CUSTOM || widget.type === CaseWidgetType.FORMIO\n        ? of({})\n        : this.widgetsApiService.getWidgetData(\n            documentId,\n            tabkey,\n            widget.key,\n            widget.type === CaseWidgetType.TABLE || widget.type === CaseWidgetType.COLLECTION\n              ? this.getPageSizeParam(widget)\n              : undefined\n          )\n    ),\n    tap(() => {\n      this.dossierWidgetsLayoutService.setCaseWidgetDataLoaded(this._widgetUuid);\n    }),\n    catchError((error: HttpErrorResponse) => {\n      if (error.status === 404)\n        this.dossierWidgetsLayoutService.setCaseWidgetDataLoaded(this._widgetUuid);\n\n      return of(null);\n    })\n  );\n\n  public readonly theme$ = combineLatest([this.cdsThemeService.currentTheme$, this.widget$]).pipe(\n    map(([currentTheme, widgetConfiguration]) => {\n      return currentTheme === CurrentCarbonTheme.G10\n        ? widgetConfiguration.highContrast\n          ? CARBON_THEME.G100\n          : CARBON_THEME.G10\n        : widgetConfiguration.highContrast\n          ? CARBON_THEME.WHITE\n          : CARBON_THEME.G90;\n    })\n  );\n\n  private readonly _subscriptions = new Subscription();\n\n  private _observer!: ResizeObserver;\n\n  private _widgetUuid!: string;\n\n  constructor(\n    private readonly dossierWidgetsLayoutService: DossierWidgetsLayoutService,\n    private readonly dossierTabService: DossierTabService,\n    private readonly route: ActivatedRoute,\n    private readonly widgetsApiService: DossierWidgetsApiService,\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly renderer: Renderer2,\n    private readonly viewRef: ViewContainerRef\n  ) {}\n\n  public ngAfterViewInit(): void {\n    this._viewContainerRefSubject$.next(this.viewRef);\n    this.openContentHeightObserver();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n    this._observer?.disconnect();\n  }\n\n  private openContentHeightObserver(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetBlockContentRef.nativeElement);\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const widgetContentHeight = event[0]?.borderBoxSize[0]?.blockSize;\n\n    if (typeof widgetContentHeight === 'number' && widgetContentHeight !== 0) {\n      this._contentHeight$.next(widgetContentHeight);\n    }\n  }\n\n  private getPageSizeParam(widgetConfiguration: CaseWidgetWithUuid): string {\n    return `size=${(widgetConfiguration.properties as WidgetTableContent).defaultPageSize}`;\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    documentId: documentId$ | async,\n    tabKey: tabKey$ | async,\n    widgetConfiguration: widget$ | async,\n    widgetData: widgetData$ | async,\n    theme: theme$ | async,\n    blockHeightPx: blockHeightPx$ | async,\n    blockWidthPercentage: blockWidthPercentage$ | async,\n  } as obs\"\n>\n  <div #widgetBlock class=\"widget-block\" [attr.data-carbon-theme]=\"obs.theme\">\n    <div #widgetBlockContent class=\"widget-block__content\">\n      @if (obs.widgetData) {\n        @switch (obs.widgetConfiguration.type) {\n          @case (CaseWidgetType.TABLE) {\n            <valtimo-widget-table\n              [documentId]=\"obs.documentId\"\n              [tabKey]=\"obs.tabKey\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-table>\n          }\n\n          @case (CaseWidgetType.COLLECTION) {\n            <valtimo-widget-collection\n              [documentId]=\"obs.documentId\"\n              [tabKey]=\"obs.tabKey\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-collection>\n          }\n\n          @case (CaseWidgetType.CUSTOM) {\n            <valtimo-widget-custom [widgetConfig]=\"obs.widgetConfiguration\"></valtimo-widget-custom>\n          }\n\n          @case (CaseWidgetType.FIELDS) {\n            <valtimo-widget-field\n              [collapseVertically]=\"true\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-field>\n          }\n\n          @case (CaseWidgetType.FORMIO) {\n            <valtimo-widget-formio\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [documentId]=\"obs.documentId\"\n            ></valtimo-widget-formio>\n          }\n\n          @default {\n            <div class=\"widget-block__not-available\">\n              <valtimo-no-results\n                [collapseVertically]=\"true\"\n                [description]=\"'dossier.widgets.noWidget' | translate\"\n                [smallPadding]=\"true\"\n              ></valtimo-no-results>\n            </div>\n          }\n        }\n      } @else {\n        <div class=\"widget-block__not-available\">\n          <valtimo-no-results\n            [collapseVertically]=\"true\"\n            [description]=\"'dossier.widgets.noData' | translate\"\n            [smallPadding]=\"true\"\n          ></valtimo-no-results>\n        </div>\n      }\n    </div>\n  </div>\n</ng-container>\n"]}
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-block.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {CommonModule} from '@angular/common';\nimport {HttpErrorResponse} from '@angular/common/http';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  Renderer2,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {\n  CARBON_THEME,\n  CarbonListModule,\n  CdsThemeService,\n  CurrentCarbonTheme,\n} from '@valtimo/components';\nimport {LoadingModule, TilesModule} from 'carbon-components-angular';\nimport {\n  BehaviorSubject,\n  catchError,\n  combineLatest,\n  filter,\n  map,\n  Observable,\n  of,\n  Subscription,\n  switchMap,\n  tap,\n} from 'rxjs';\nimport {CaseWidgetType, CaseWidgetWithUuid, WidgetTableContent} from '../../../../../../models';\nimport {\n  DossierTabService,\n  DossierWidgetsApiService,\n  DossierWidgetsLayoutService,\n} from '../../../../../../services';\nimport {WidgetCustomComponent} from '../custom/widget-custom.component';\nimport {WidgetFieldComponent} from '../field/widget-field.component';\nimport {WidgetFormioComponent} from '../formio/widget-formio.component';\nimport {WidgetTableComponent} from '../table/widget-table.component';\nimport {WidgetCollectionComponent} from '../collection/widget-collection.component';\nimport {WIDGET_HEIGHT_1X} from '../../../../../../constants';\n\n@Component({\n  selector: 'valtimo-dossier-widget-block',\n  templateUrl: './widget-block.component.html',\n  styleUrls: ['./widget-block.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    LoadingModule,\n    WidgetTableComponent,\n    WidgetCustomComponent,\n    CarbonListModule,\n    TranslateModule,\n    TilesModule,\n    WidgetFieldComponent,\n    WidgetFormioComponent,\n    WidgetCollectionComponent,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WidgetBlockComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('widgetBlockContent') private _widgetBlockContentRef: ElementRef<HTMLDivElement>;\n\n  @Input() public set widget(value: CaseWidgetWithUuid) {\n    this._widgetUuid = value.uuid;\n    this._widget$.next(value);\n  }\n\n  private readonly _widget$ = new BehaviorSubject<CaseWidgetWithUuid | null>(null);\n\n  public get widget$(): Observable<CaseWidgetWithUuid> {\n    return this._widget$.pipe(filter(widget => widget !== null));\n  }\n\n  private readonly _viewContainerRefSubject$ = new BehaviorSubject<ViewContainerRef | null>(null);\n\n  private get _viewContainerRef$(): Observable<ViewContainerRef> {\n    return this._viewContainerRefSubject$.pipe(filter(ref => !!ref));\n  }\n\n  private readonly _contentHeight$ = new BehaviorSubject<number>(0);\n\n  public readonly blockHeightPx$ = combineLatest([\n    this._contentHeight$,\n    this._viewContainerRef$,\n  ]).pipe(\n    filter(([contentHeight]) => contentHeight !== 0),\n    tap(([contentHeight, viewRef]) => {\n      const blockHeight = Math.ceil((contentHeight + 16) / WIDGET_HEIGHT_1X) * WIDGET_HEIGHT_1X;\n\n      this.renderer.setStyle(viewRef.element.nativeElement, 'height', `${blockHeight}px`);\n      this.dossierWidgetsLayoutService.triggerMuuriLayout();\n    })\n  );\n\n  public readonly blockWidthPercentage$ = combineLatest([\n    this.dossierWidgetsLayoutService.amountOfColumns$,\n    this.widget$,\n    this._viewContainerRef$,\n  ]).pipe(\n    tap(([amountOfColumns, widget, viewRef]) => {\n      const percentage =\n        widget.width > amountOfColumns ? 100 : (widget.width / amountOfColumns) * 100;\n\n      this.renderer.setStyle(viewRef.element.nativeElement, 'width', `${percentage}%`);\n      this.dossierWidgetsLayoutService.triggerMuuriLayout();\n    })\n  );\n\n  public readonly CaseWidgetType = CaseWidgetType;\n\n  public readonly documentId$ = this.route.params.pipe(\n    map(params => params?.documentId),\n    filter(documentId => !!documentId)\n  );\n\n  public readonly tabKey$: Observable<string> = this.dossierTabService.activeTabKey$;\n\n  public readonly widgetData$: Observable<any[] | {} | null> = combineLatest([\n    this.widget$,\n    this.tabKey$,\n    this.documentId$,\n  ]).pipe(\n    switchMap(([widget, tabkey, documentId]) =>\n      // custom component and formio widgets do not fetch additional data\n      widget.type === CaseWidgetType.CUSTOM || widget.type === CaseWidgetType.FORMIO\n        ? of({})\n        : this.widgetsApiService.getWidgetData(\n            documentId,\n            tabkey,\n            widget.key,\n            widget.type === CaseWidgetType.TABLE || widget.type === CaseWidgetType.COLLECTION\n              ? this.getPageSizeParam(widget)\n              : undefined\n          )\n    ),\n    tap(() => {\n      this.dossierWidgetsLayoutService.setCaseWidgetDataLoaded(this._widgetUuid);\n    }),\n    catchError((error: HttpErrorResponse) => {\n      if (error.status === 404)\n        this.dossierWidgetsLayoutService.setCaseWidgetDataLoaded(this._widgetUuid);\n\n      return of(null);\n    })\n  );\n\n  public readonly theme$ = combineLatest([this.cdsThemeService.currentTheme$, this.widget$]).pipe(\n    map(([currentTheme, widgetConfiguration]) => {\n      return currentTheme === CurrentCarbonTheme.G10\n        ? widgetConfiguration.highContrast\n          ? CARBON_THEME.G100\n          : CARBON_THEME.G10\n        : widgetConfiguration.highContrast\n          ? CARBON_THEME.WHITE\n          : CARBON_THEME.G90;\n    })\n  );\n\n  private readonly _subscriptions = new Subscription();\n\n  private _observer!: ResizeObserver;\n\n  private _widgetUuid!: string;\n\n  constructor(\n    private readonly dossierWidgetsLayoutService: DossierWidgetsLayoutService,\n    private readonly dossierTabService: DossierTabService,\n    private readonly route: ActivatedRoute,\n    private readonly widgetsApiService: DossierWidgetsApiService,\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly renderer: Renderer2,\n    private readonly viewRef: ViewContainerRef\n  ) {}\n\n  public ngAfterViewInit(): void {\n    this._viewContainerRefSubject$.next(this.viewRef);\n    this.openContentHeightObserver();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n    this._observer?.disconnect();\n  }\n\n  private openContentHeightObserver(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetBlockContentRef.nativeElement);\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const widgetContentHeight = event[0]?.borderBoxSize[0]?.blockSize;\n\n    if (typeof widgetContentHeight === 'number' && widgetContentHeight !== 0) {\n      this._contentHeight$.next(widgetContentHeight);\n    }\n  }\n\n  private getPageSizeParam(widgetConfiguration: CaseWidgetWithUuid): string {\n    return `size=${(widgetConfiguration.properties as WidgetTableContent).defaultPageSize}`;\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    documentId: documentId$ | async,\n    tabKey: tabKey$ | async,\n    widgetConfiguration: widget$ | async,\n    widgetData: widgetData$ | async,\n    theme: theme$ | async,\n    blockHeightPx: blockHeightPx$ | async,\n    blockWidthPercentage: blockWidthPercentage$ | async,\n  } as obs\"\n>\n  <div #widgetBlock class=\"widget-block\" [attr.data-carbon-theme]=\"obs.theme\">\n    <div #widgetBlockContent class=\"widget-block__content\">\n      @if (obs.widgetData) {\n        @switch (obs.widgetConfiguration.type) {\n          @case (CaseWidgetType.TABLE) {\n            <valtimo-widget-table\n              [documentId]=\"obs.documentId\"\n              [tabKey]=\"obs.tabKey\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-table>\n          }\n\n          @case (CaseWidgetType.COLLECTION) {\n            <valtimo-widget-collection\n              [documentId]=\"obs.documentId\"\n              [tabKey]=\"obs.tabKey\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-collection>\n          }\n\n          @case (CaseWidgetType.CUSTOM) {\n            <valtimo-widget-custom [widgetConfig]=\"obs.widgetConfiguration\"></valtimo-widget-custom>\n          }\n\n          @case (CaseWidgetType.FIELDS) {\n            <valtimo-widget-field\n              [collapseVertically]=\"true\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-field>\n          }\n\n          @case (CaseWidgetType.FORMIO) {\n            <valtimo-widget-formio\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [documentId]=\"obs.documentId\"\n            ></valtimo-widget-formio>\n          }\n\n          @default {\n            <div class=\"widget-block__not-available\">\n              <valtimo-no-results\n                [collapseVertically]=\"true\"\n                [description]=\"'dossier.widgets.noWidget' | translate\"\n                [smallPadding]=\"true\"\n              ></valtimo-no-results>\n            </div>\n          }\n        }\n      } @else {\n        <div class=\"widget-block__not-available\">\n          <valtimo-no-results\n            [collapseVertically]=\"true\"\n            [description]=\"'dossier.widgets.noData' | translate\"\n            [smallPadding]=\"true\"\n          ></valtimo-no-results>\n        </div>\n      }\n    </div>\n  </div>\n</ng-container>\n"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { BehaviorSubject, switchMap } from 'rxjs';
|
|
2
|
+
import { CAN_CREATE_CAMUNDA_EXECUTION_PERMISSION, WIDGET_PERMISSION_RESOURCE, } from '../../widgets.permissions';
|
|
3
|
+
export class WidgetProcess {
|
|
4
|
+
set baseWidgetConfiguration(value) {
|
|
5
|
+
this._baseWidgetConfiguration$.next(value);
|
|
6
|
+
}
|
|
7
|
+
constructor(documentService, permissionService) {
|
|
8
|
+
this.documentService = documentService;
|
|
9
|
+
this.permissionService = permissionService;
|
|
10
|
+
this._baseWidgetConfiguration$ = new BehaviorSubject(null);
|
|
11
|
+
this.canCreateCamundaExecution$ = this._baseWidgetConfiguration$.pipe(switchMap((widgetConfiguration) => this.documentService.findProcessDocumentDefinitionsByProcessDefinitionKey(widgetConfiguration?.actions?.[0].processDefinitionKey ?? '')), switchMap((processDefintions) => this.permissionService.requestPermission(CAN_CREATE_CAMUNDA_EXECUTION_PERMISSION, {
|
|
12
|
+
resource: WIDGET_PERMISSION_RESOURCE.camundaProcessDefinition,
|
|
13
|
+
identifier: processDefintions[0].latestVersionId,
|
|
14
|
+
})));
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LXByb2Nlc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0aW1vL2Rvc3NpZXIvc3JjL2xpYi9jb21wb25lbnRzL2Rvc3NpZXItZGV0YWlsL3RhYi93aWRnZXRzL2NvbXBvbmVudHMvd2lkZ2V0LXByb2Nlc3Mvd2lkZ2V0LXByb2Nlc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFDLGVBQWUsRUFBYyxTQUFTLEVBQU0sTUFBTSxNQUFNLENBQUM7QUFHakUsT0FBTyxFQUNMLHVDQUF1QyxFQUN2QywwQkFBMEIsR0FDM0IsTUFBTSwyQkFBMkIsQ0FBQztBQUVuQyxNQUFNLE9BQU8sYUFBYTtJQUV4QixJQUFjLHVCQUF1QixDQUFDLEtBQXNCO1FBQzFELElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQWlCRCxZQUNxQixlQUFnQyxFQUNoQyxpQkFBb0M7UUFEcEMsb0JBQWUsR0FBZixlQUFlLENBQWlCO1FBQ2hDLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBbUI7UUF0QnhDLDhCQUF5QixHQUFHLElBQUksZUFBZSxDQUF5QixJQUFJLENBQUMsQ0FBQztRQUsvRSwrQkFBMEIsR0FDeEMsSUFBSSxDQUFDLHlCQUF5QixDQUFDLElBQUksQ0FDakMsU0FBUyxDQUFDLENBQUMsbUJBQTJDLEVBQUUsRUFBRSxDQUN4RCxJQUFJLENBQUMsZUFBZSxDQUFDLG9EQUFvRCxDQUN2RSxtQkFBbUIsRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxvQkFBb0IsSUFBSSxFQUFFLENBQzdELENBQ0YsRUFDRCxTQUFTLENBQUMsQ0FBQyxpQkFBOEMsRUFBRSxFQUFFLENBQzNELElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxpQkFBaUIsQ0FBQyx1Q0FBdUMsRUFBRTtZQUNoRixRQUFRLEVBQUUsMEJBQTBCLENBQUMsd0JBQXdCO1lBQzdELFVBQVUsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxlQUFlO1NBQ2pELENBQUMsQ0FDSCxDQUNGLENBQUM7SUFLRCxDQUFDO0NBQ0wiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Jhc2ljQ2FzZVdpZGdldH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vbW9kZWxzJztcbmltcG9ydCB7QmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBzd2l0Y2hNYXAsIHRhcH0gZnJvbSAncnhqcyc7XG5pbXBvcnQge1Blcm1pc3Npb25SZXNwb25zZSwgUGVybWlzc2lvblNlcnZpY2V9IGZyb20gJ0B2YWx0aW1vL2FjY2Vzcy1jb250cm9sJztcbmltcG9ydCB7RG9jdW1lbnRTZXJ2aWNlLCBQcm9jZXNzRG9jdW1lbnREZWZpbml0aW9ufSBmcm9tICdAdmFsdGltby9kb2N1bWVudCc7XG5pbXBvcnQge1xuICBDQU5fQ1JFQVRFX0NBTVVOREFfRVhFQ1VUSU9OX1BFUk1JU1NJT04sXG4gIFdJREdFVF9QRVJNSVNTSU9OX1JFU09VUkNFLFxufSBmcm9tICcuLi8uLi93aWRnZXRzLnBlcm1pc3Npb25zJztcblxuZXhwb3J0IGNsYXNzIFdpZGdldFByb2Nlc3Mge1xuICBwcml2YXRlIHJlYWRvbmx5IF9iYXNlV2lkZ2V0Q29uZmlndXJhdGlvbiQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PEJhc2ljQ2FzZVdpZGdldCB8IG51bGw+KG51bGwpO1xuICBwcm90ZWN0ZWQgc2V0IGJhc2VXaWRnZXRDb25maWd1cmF0aW9uKHZhbHVlOiBCYXNpY0Nhc2VXaWRnZXQpIHtcbiAgICB0aGlzLl9iYXNlV2lkZ2V0Q29uZmlndXJhdGlvbiQubmV4dCh2YWx1ZSk7XG4gIH1cblxuICBwdWJsaWMgcmVhZG9ubHkgY2FuQ3JlYXRlQ2FtdW5kYUV4ZWN1dGlvbiQ6IE9ic2VydmFibGU8Ym9vbGVhbj4gPVxuICAgIHRoaXMuX2Jhc2VXaWRnZXRDb25maWd1cmF0aW9uJC5waXBlKFxuICAgICAgc3dpdGNoTWFwKCh3aWRnZXRDb25maWd1cmF0aW9uOiBCYXNpY0Nhc2VXaWRnZXQgfCBudWxsKSA9PlxuICAgICAgICB0aGlzLmRvY3VtZW50U2VydmljZS5maW5kUHJvY2Vzc0RvY3VtZW50RGVmaW5pdGlvbnNCeVByb2Nlc3NEZWZpbml0aW9uS2V5KFxuICAgICAgICAgIHdpZGdldENvbmZpZ3VyYXRpb24/LmFjdGlvbnM/LlswXS5wcm9jZXNzRGVmaW5pdGlvbktleSA/PyAnJ1xuICAgICAgICApXG4gICAgICApLFxuICAgICAgc3dpdGNoTWFwKChwcm9jZXNzRGVmaW50aW9uczogUHJvY2Vzc0RvY3VtZW50RGVmaW5pdGlvbltdKSA9PlxuICAgICAgICB0aGlzLnBlcm1pc3Npb25TZXJ2aWNlLnJlcXVlc3RQZXJtaXNzaW9uKENBTl9DUkVBVEVfQ0FNVU5EQV9FWEVDVVRJT05fUEVSTUlTU0lPTiwge1xuICAgICAgICAgIHJlc291cmNlOiBXSURHRVRfUEVSTUlTU0lPTl9SRVNPVVJDRS5jYW11bmRhUHJvY2Vzc0RlZmluaXRpb24sXG4gICAgICAgICAgaWRlbnRpZmllcjogcHJvY2Vzc0RlZmludGlvbnNbMF0ubGF0ZXN0VmVyc2lvbklkLFxuICAgICAgICB9KVxuICAgICAgKVxuICAgICk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGRvY3VtZW50U2VydmljZTogRG9jdW1lbnRTZXJ2aWNlLFxuICAgIHByb3RlY3RlZCByZWFkb25seSBwZXJtaXNzaW9uU2VydmljZTogUGVybWlzc2lvblNlcnZpY2VcbiAgKSB7fVxufVxuIl19
|
|
@@ -15,11 +15,11 @@
|
|
|
15
15
|
*/
|
|
16
16
|
import { CommonModule } from '@angular/common';
|
|
17
17
|
import { ChangeDetectionStrategy, Component, HostBinding } from '@angular/core';
|
|
18
|
-
import {
|
|
18
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
19
|
+
import { CarbonListModule } from '@valtimo/components';
|
|
19
20
|
import { LoadingModule } from 'carbon-components-angular';
|
|
21
|
+
import { BehaviorSubject, combineLatest, delay, filter, map, switchMap, tap } from 'rxjs';
|
|
20
22
|
import { WidgetsContainerComponent } from './components/widgets-container/widgets-container.component';
|
|
21
|
-
import { CarbonListModule } from '@valtimo/components';
|
|
22
|
-
import { TranslateModule } from '@ngx-translate/core';
|
|
23
23
|
import * as i0 from "@angular/core";
|
|
24
24
|
import * as i1 from "@angular/router";
|
|
25
25
|
import * as i2 from "../../../../services";
|
|
@@ -71,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
71
71
|
type: HostBinding,
|
|
72
72
|
args: ['class.tab--no-min-height']
|
|
73
73
|
}] } });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widgets.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/widgets.component.ts","../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/widgets.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAoB,MAAM,eAAe,CAAC;AAEjG,OAAO,EAAC,eAAe,EAAC,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAC,gBAAgB,EAAC,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAC,aAAa,EAAC,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAC,eAAe,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAc,SAAS,EAAE,GAAG,EAAC,MAAM,MAAM,CAAC;AAMpG,OAAO,EAAC,yBAAyB,EAAC,MAAM,4DAA4D,CAAC;;;;;;;;AAerG,MAAM,OAAO,6BAA6B;IAuBxC,YACmB,KAAqB,EACrB,iBAAoC,EACpC,iBAA2C,EAC3C,2BAAwD;QAHxD,UAAK,GAAL,KAAK,CAAgB;QACrB,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,sBAAiB,GAAjB,iBAAiB,CAA0B;QAC3C,gCAA2B,GAA3B,2BAA2B,CAA6B;QA1BrB,cAAS,GAAG,IAAI,CAAC;QACb,kBAAa,GAAG,IAAI,CAAC;QACrB,iBAAY,GAAG,IAAI,CAAC;QAE7D,iBAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CACpD,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,UAAU,CAAC,EACjC,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CACnC,CAAC;QAEe,aAAQ,GAAuB,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC;QAErE,gCAA2B,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAC;QAEjE,yBAAoB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAC3F,SAAS,CAAC,CAAC,CAAC,UAAU,EAAE,MAAM,CAAC,EAAE,EAAE,CACjC,IAAI,CAAC,iBAAiB,CAAC,yBAAyB,CAAC,UAAU,EAAE,MAAM,CAAC,CACrE,EACD,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CACxD,CAAC;QAEc,YAAO,GAAG,IAAI,CAAC,2BAA2B,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;IAOjF,CAAC;IAEG,QAAQ;QACb,IAAI,CAAC,iBAAiB,CAAC,4BAA4B,EAAE,CAAC;IACxD,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,2BAA2B,CAAC,KAAK,EAAE,CAAC;QACzC,IAAI,CAAC,iBAAiB,CAAC,2BAA2B,EAAE,CAAC;IACvD,CAAC;+GArCU,6BAA6B;mGAA7B,6BAA6B,+OC1C1C,4tDAkDA,iIDhBI,YAAY,uLACZ,aAAa,gKACb,yBAAyB,kGACzB,gBAAgB,oPAChB,eAAe;;4FAIN,6BAA6B;kBAbzC,SAAS;iCAGI,IAAI,WACP;wBACP,YAAY;wBACZ,aAAa;wBACb,yBAAyB;wBACzB,gBAAgB;wBAChB,eAAe;qBAChB,mBACgB,uBAAuB,CAAC,MAAM;oMAGO,SAAS;sBAA9D,WAAW;uBAAC,sBAAsB;gBACuB,aAAa;sBAAtE,WAAW;uBAAC,0BAA0B;gBACmB,YAAY;sBAArE,WAAW;uBAAC,0BAA0B","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {CommonModule} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, HostBinding, OnDestroy, OnInit} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {CarbonListModule} from '@valtimo/components';\nimport {LoadingModule} from 'carbon-components-angular';\nimport {BehaviorSubject, combineLatest, delay, filter, map, Observable, switchMap, tap} from 'rxjs';\nimport {\n  DossierTabService,\n  DossierWidgetsApiService,\n  DossierWidgetsLayoutService,\n} from '../../../../services';\nimport {WidgetsContainerComponent} from './components/widgets-container/widgets-container.component';\n\n@Component({\n  templateUrl: './widgets.component.html',\n  styleUrls: ['./widgets.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    LoadingModule,\n    WidgetsContainerComponent,\n    CarbonListModule,\n    TranslateModule,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DossierDetailWidgetsComponent implements OnInit, OnDestroy {\n  @HostBinding('class.tab--no-margin') private readonly _noMargin = true;\n  @HostBinding('class.tab--no-background') private readonly _noBackground = true;\n  @HostBinding('class.tab--no-min-height') private readonly _noMinHeight = true;\n\n  private readonly _documentId$ = this.route.params.pipe(\n    map(params => params?.documentId),\n    filter(documentId => !!documentId)\n  );\n\n  private readonly _tabKey$: Observable<string> = this.dossierTabService.activeTabKey$;\n\n  public readonly loadingWidgetConfiguration$ = new BehaviorSubject<boolean>(true);\n\n  public readonly widgetConfiguration$ = combineLatest([this._documentId$, this._tabKey$]).pipe(\n    switchMap(([documentId, tabKey]) =>\n      this.widgetsApiService.getWidgetTabConfiguration(documentId, tabKey)\n    ),\n    tap(() => this.loadingWidgetConfiguration$.next(false))\n  );\n\n  public readonly loaded$ = this.dossierWidgetsLayoutService.loaded$.pipe(delay(400));\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly dossierTabService: DossierTabService,\n    private readonly widgetsApiService: DossierWidgetsApiService,\n    private readonly dossierWidgetsLayoutService: DossierWidgetsLayoutService\n  ) {}\n\n  public ngOnInit(): void {\n    this.dossierTabService.disableTabHorizontalOverflow();\n  }\n\n  public ngOnDestroy(): void {\n    this.dossierWidgetsLayoutService.reset();\n    this.dossierTabService.enableTabHorizontalOverflow();\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    loadingWidgetConfiguration: loadingWidgetConfiguration$ | async,\n    widgetConfiguration: widgetConfiguration$ | async,\n    loaded: loaded$ | async,\n  } as obs\"\n>\n  <ng-container\n    *ngIf=\"{\n      noWidgetsConfigured:\n        obs.widgetConfiguration?.widgets && obs.widgetConfiguration.widgets.length === 0,\n    } as vars\"\n  >\n    @if (!obs.loaded && !vars.noWidgetsConfigured) {\n      <div class=\"loading-container\">\n        <cds-loading></cds-loading>\n      </div>\n    }\n\n    @if (vars.noWidgetsConfigured) {\n      <valtimo-no-results\n        [title]=\"'dossier.widgets.noWidgets' | translate\"\n        [description]=\"'dossier.widgets.noWidgetsDescription' | translate\"\n        illustration=\"valtimo-layout/img/no-widgets.svg\"\n      ></valtimo-no-results>\n    }\n\n    <div [style.visibility]=\"!obs.loaded ? 'hidden' : 'visible'\">\n      <valtimo-dossier-widgets-container\n        [widgets]=\"obs.widgetConfiguration?.widgets || []\"\n      ></valtimo-dossier-widgets-container>\n    </div>\n  </ng-container>\n</ng-container>\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2015-2024 Ritense BV, the Netherlands.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under EUPL, Version 1.2 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" basis,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
var PERMISSION_ACTION;
|
|
17
|
+
(function (PERMISSION_ACTION) {
|
|
18
|
+
PERMISSION_ACTION["create"] = "create";
|
|
19
|
+
})(PERMISSION_ACTION || (PERMISSION_ACTION = {}));
|
|
20
|
+
var WIDGET_PERMISSION_RESOURCE;
|
|
21
|
+
(function (WIDGET_PERMISSION_RESOURCE) {
|
|
22
|
+
WIDGET_PERMISSION_RESOURCE["camundaExecution"] = "com.ritense.valtimo.camunda.domain.CamundaExecution";
|
|
23
|
+
WIDGET_PERMISSION_RESOURCE["camundaProcessDefinition"] = "com.ritense.valtimo.camunda.domain.CamundaProcessDefinition";
|
|
24
|
+
})(WIDGET_PERMISSION_RESOURCE || (WIDGET_PERMISSION_RESOURCE = {}));
|
|
25
|
+
const CAN_CREATE_CAMUNDA_EXECUTION_PERMISSION = {
|
|
26
|
+
action: PERMISSION_ACTION.create,
|
|
27
|
+
resource: WIDGET_PERMISSION_RESOURCE.camundaExecution,
|
|
28
|
+
};
|
|
29
|
+
export { CAN_CREATE_CAMUNDA_EXECUTION_PERMISSION, WIDGET_PERMISSION_RESOURCE };
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0cy5wZXJtaXNzaW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vZG9zc2llci9zcmMvbGliL2NvbXBvbmVudHMvZG9zc2llci1kZXRhaWwvdGFiL3dpZGdldHMvd2lkZ2V0cy5wZXJtaXNzaW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUlILElBQUssaUJBRUo7QUFGRCxXQUFLLGlCQUFpQjtJQUNwQixzQ0FBaUIsQ0FBQTtBQUNuQixDQUFDLEVBRkksaUJBQWlCLEtBQWpCLGlCQUFpQixRQUVyQjtBQUVELElBQUssMEJBR0o7QUFIRCxXQUFLLDBCQUEwQjtJQUM3QixzR0FBd0UsQ0FBQTtJQUN4RSxzSEFBd0YsQ0FBQTtBQUMxRixDQUFDLEVBSEksMEJBQTBCLEtBQTFCLDBCQUEwQixRQUc5QjtBQUVELE1BQU0sdUNBQXVDLEdBQXNCO0lBQ2pFLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxNQUFNO0lBQ2hDLFFBQVEsRUFBRSwwQkFBMEIsQ0FBQyxnQkFBZ0I7Q0FDdEQsQ0FBQztBQUVGLE9BQU8sRUFBQyx1Q0FBdUMsRUFBRSwwQkFBMEIsRUFBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAyMDE1LTIwMjQgUml0ZW5zZSBCViwgdGhlIE5ldGhlcmxhbmRzLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIEVVUEwsIFZlcnNpb24gMS4yICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cHM6Ly9qb2ludXAuZWMuZXVyb3BhLmV1L2NvbGxlY3Rpb24vZXVwbC9ldXBsLXRleHQtZXVwbC0xMlxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBiYXNpcyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuaW1wb3J0IHtQZXJtaXNzaW9uUmVxdWVzdH0gZnJvbSAnQHZhbHRpbW8vYWNjZXNzLWNvbnRyb2wnO1xuXG5lbnVtIFBFUk1JU1NJT05fQUNUSU9OIHtcbiAgY3JlYXRlID0gJ2NyZWF0ZScsXG59XG5cbmVudW0gV0lER0VUX1BFUk1JU1NJT05fUkVTT1VSQ0Uge1xuICBjYW11bmRhRXhlY3V0aW9uID0gJ2NvbS5yaXRlbnNlLnZhbHRpbW8uY2FtdW5kYS5kb21haW4uQ2FtdW5kYUV4ZWN1dGlvbicsXG4gIGNhbXVuZGFQcm9jZXNzRGVmaW5pdGlvbiA9ICdjb20ucml0ZW5zZS52YWx0aW1vLmNhbXVuZGEuZG9tYWluLkNhbXVuZGFQcm9jZXNzRGVmaW5pdGlvbicsXG59XG5cbmNvbnN0IENBTl9DUkVBVEVfQ0FNVU5EQV9FWEVDVVRJT05fUEVSTUlTU0lPTjogUGVybWlzc2lvblJlcXVlc3QgPSB7XG4gIGFjdGlvbjogUEVSTUlTU0lPTl9BQ1RJT04uY3JlYXRlLFxuICByZXNvdXJjZTogV0lER0VUX1BFUk1JU1NJT05fUkVTT1VSQ0UuY2FtdW5kYUV4ZWN1dGlvbixcbn07XG5cbmV4cG9ydCB7Q0FOX0NSRUFURV9DQU1VTkRBX0VYRUNVVElPTl9QRVJNSVNTSU9OLCBXSURHRVRfUEVSTUlTU0lPTl9SRVNPVVJDRX07XG4iXX0=
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2015-2024 Ritense BV, the Netherlands.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under EUPL, Version 1.2 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" basis,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
import { EventEmitter, Injectable } from '@angular/core';
|
|
17
|
+
import { BehaviorSubject, distinctUntilChanged, filter, switchMap } from 'rxjs';
|
|
18
|
+
import * as i0 from "@angular/core";
|
|
19
|
+
import * as i1 from "@valtimo/document";
|
|
20
|
+
export class WidgetsService {
|
|
21
|
+
get activeProcess$() {
|
|
22
|
+
return this._activeProcessKey$.pipe(filter((processDocumentDefinition) => !!processDocumentDefinition), switchMap((processDefinitionKey) => this.documentService.findProcessDocumentDefinitionsByProcessDefinitionKey(processDefinitionKey)), distinctUntilChanged());
|
|
23
|
+
}
|
|
24
|
+
constructor(documentService) {
|
|
25
|
+
this.documentService = documentService;
|
|
26
|
+
this._activeProcessKey$ = new BehaviorSubject(null);
|
|
27
|
+
this.startProcessEvent = new EventEmitter();
|
|
28
|
+
}
|
|
29
|
+
startProcess(processDocumentDefinitionKey) {
|
|
30
|
+
this._activeProcessKey$.next(processDocumentDefinitionKey);
|
|
31
|
+
this.startProcessEvent.emit();
|
|
32
|
+
}
|
|
33
|
+
finishProcess() {
|
|
34
|
+
this._activeProcessKey$.next(null);
|
|
35
|
+
}
|
|
36
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetsService, deps: [{ token: i1.DocumentService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
37
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetsService, providedIn: 'root' }); }
|
|
38
|
+
}
|
|
39
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetsService, decorators: [{
|
|
40
|
+
type: Injectable,
|
|
41
|
+
args: [{
|
|
42
|
+
providedIn: 'root',
|
|
43
|
+
}]
|
|
44
|
+
}], ctorParameters: () => [{ type: i1.DocumentService }] });
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0cy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGltby9kb3NzaWVyL3NyYy9saWIvY29tcG9uZW50cy9kb3NzaWVyLWRldGFpbC90YWIvd2lkZ2V0cy93aWRnZXRzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0dBY0c7QUFFSCxPQUFPLEVBQUMsWUFBWSxFQUFFLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUV2RCxPQUFPLEVBQUMsZUFBZSxFQUFjLG9CQUFvQixFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUMsTUFBTSxNQUFNLENBQUM7OztBQUsxRixNQUFNLE9BQU8sY0FBYztJQUl6QixJQUFXLGNBQWM7UUFDdkIsT0FBTyxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUNqQyxNQUFNLENBQUMsQ0FBQyx5QkFBd0MsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLHlCQUF5QixDQUFDLEVBQ2pGLFNBQVMsQ0FBQyxDQUFDLG9CQUE0QixFQUFFLEVBQUUsQ0FDekMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxvREFBb0QsQ0FDdkUsb0JBQW9CLENBQ3JCLENBQ0YsRUFDRCxvQkFBb0IsRUFBRSxDQUN2QixDQUFDO0lBQ0osQ0FBQztJQUVELFlBQTZCLGVBQWdDO1FBQWhDLG9CQUFlLEdBQWYsZUFBZSxDQUFpQjtRQWY1Qyx1QkFBa0IsR0FBRyxJQUFJLGVBQWUsQ0FBZ0IsSUFBSSxDQUFDLENBQUM7UUFDL0Qsc0JBQWlCLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQWNTLENBQUM7SUFFMUQsWUFBWSxDQUFDLDRCQUFvQztRQUN0RCxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLDRCQUE0QixDQUFDLENBQUM7UUFDM0QsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFTSxhQUFhO1FBQ2xCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDckMsQ0FBQzsrR0F6QlUsY0FBYzttSEFBZCxjQUFjLGNBRmIsTUFBTTs7NEZBRVAsY0FBYztrQkFIMUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IDIwMTUtMjAyNCBSaXRlbnNlIEJWLCB0aGUgTmV0aGVybGFuZHMuXG4gKlxuICogTGljZW5zZWQgdW5kZXIgRVVQTCwgVmVyc2lvbiAxLjIgKHRoZSBcIkxpY2Vuc2VcIik7XG4gKiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gKiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbiAqXG4gKiBodHRwczovL2pvaW51cC5lYy5ldXJvcGEuZXUvY29sbGVjdGlvbi9ldXBsL2V1cGwtdGV4dC1ldXBsLTEyXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIGJhc2lzLFxuICogV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gKiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuXG5pbXBvcnQge0V2ZW50RW1pdHRlciwgSW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0RvY3VtZW50U2VydmljZSwgUHJvY2Vzc0RvY3VtZW50RGVmaW5pdGlvbn0gZnJvbSAnQHZhbHRpbW8vZG9jdW1lbnQnO1xuaW1wb3J0IHtCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUsIGRpc3RpbmN0VW50aWxDaGFuZ2VkLCBmaWx0ZXIsIHN3aXRjaE1hcH0gZnJvbSAncnhqcyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBXaWRnZXRzU2VydmljZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2FjdGl2ZVByb2Nlc3NLZXkkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxzdHJpbmcgfCBudWxsPihudWxsKTtcbiAgcHVibGljIHJlYWRvbmx5IHN0YXJ0UHJvY2Vzc0V2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIHB1YmxpYyBnZXQgYWN0aXZlUHJvY2VzcyQoKTogT2JzZXJ2YWJsZTxQcm9jZXNzRG9jdW1lbnREZWZpbml0aW9uW10+IHtcbiAgICByZXR1cm4gdGhpcy5fYWN0aXZlUHJvY2Vzc0tleSQucGlwZShcbiAgICAgIGZpbHRlcigocHJvY2Vzc0RvY3VtZW50RGVmaW5pdGlvbjogc3RyaW5nIHwgbnVsbCkgPT4gISFwcm9jZXNzRG9jdW1lbnREZWZpbml0aW9uKSxcbiAgICAgIHN3aXRjaE1hcCgocHJvY2Vzc0RlZmluaXRpb25LZXk6IHN0cmluZykgPT5cbiAgICAgICAgdGhpcy5kb2N1bWVudFNlcnZpY2UuZmluZFByb2Nlc3NEb2N1bWVudERlZmluaXRpb25zQnlQcm9jZXNzRGVmaW5pdGlvbktleShcbiAgICAgICAgICBwcm9jZXNzRGVmaW5pdGlvbktleVxuICAgICAgICApXG4gICAgICApLFxuICAgICAgZGlzdGluY3RVbnRpbENoYW5nZWQoKVxuICAgICk7XG4gIH1cblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGRvY3VtZW50U2VydmljZTogRG9jdW1lbnRTZXJ2aWNlKSB7fVxuXG4gIHB1YmxpYyBzdGFydFByb2Nlc3MocHJvY2Vzc0RvY3VtZW50RGVmaW5pdGlvbktleTogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5fYWN0aXZlUHJvY2Vzc0tleSQubmV4dChwcm9jZXNzRG9jdW1lbnREZWZpbml0aW9uS2V5KTtcbiAgICB0aGlzLnN0YXJ0UHJvY2Vzc0V2ZW50LmVtaXQoKTtcbiAgfVxuXG4gIHB1YmxpYyBmaW5pc2hQcm9jZXNzKCk6IHZvaWQge1xuICAgIHRoaXMuX2FjdGl2ZVByb2Nlc3NLZXkkLm5leHQobnVsbCk7XG4gIH1cbn1cbiJdfQ==
|
package/esm2022/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.mjs
CHANGED
|
@@ -18,7 +18,7 @@ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, signal
|
|
|
18
18
|
import { TranslateModule } from '@ngx-translate/core';
|
|
19
19
|
import { AssignUserToTaskComponent, CAN_ASSIGN_TASK_PERMISSION, TASK_DETAIL_PERMISSION_RESOURCE, TaskDetailContentComponent, TaskDetailIntermediateSaveComponent, } from '@valtimo/task';
|
|
20
20
|
import { ButtonModule, IconModule } from 'carbon-components-angular';
|
|
21
|
-
import { BehaviorSubject, switchMap } from 'rxjs';
|
|
21
|
+
import { BehaviorSubject, map, switchMap } from 'rxjs';
|
|
22
22
|
import * as i0 from "@angular/core";
|
|
23
23
|
import * as i1 from "@valtimo/config";
|
|
24
24
|
import * as i2 from "@valtimo/components";
|
|
@@ -27,13 +27,13 @@ import * as i4 from "@ngx-translate/core";
|
|
|
27
27
|
import * as i5 from "@angular/common";
|
|
28
28
|
import * as i6 from "carbon-components-angular";
|
|
29
29
|
export class DossierDetailsTaskDetailComponent {
|
|
30
|
-
set
|
|
30
|
+
set taskAndProcessLink(value) {
|
|
31
31
|
if (!value)
|
|
32
32
|
return;
|
|
33
|
-
this.
|
|
33
|
+
this.taskAndProcessLink$.next(value);
|
|
34
34
|
this.pageValue.set({
|
|
35
|
-
title: value?.name,
|
|
36
|
-
subtitle: `${this.translateService.instant('taskDetail.taskCreated')} ${value?.created}`,
|
|
35
|
+
title: value?.task.name,
|
|
36
|
+
subtitle: `${this.translateService.instant('taskDetail.taskCreated')} ${value?.task?.created}`,
|
|
37
37
|
});
|
|
38
38
|
}
|
|
39
39
|
constructor(configService, pageHeaderService, permissionService, translateService) {
|
|
@@ -46,7 +46,8 @@ export class DossierDetailsTaskDetailComponent {
|
|
|
46
46
|
this.activeChange = new EventEmitter();
|
|
47
47
|
this.formSubmit = new EventEmitter();
|
|
48
48
|
this.compactMode$ = this.pageHeaderService.compactMode$;
|
|
49
|
-
this.
|
|
49
|
+
this.taskAndProcessLink$ = new BehaviorSubject(null);
|
|
50
|
+
this.task$ = this.taskAndProcessLink$.pipe(map(taskAndProcessLink => taskAndProcessLink.task));
|
|
50
51
|
this.canAssignUserToTask$ = this.task$.pipe(switchMap((task) => this.permissionService.requestPermission(CAN_ASSIGN_TASK_PERMISSION, {
|
|
51
52
|
resource: TASK_DETAIL_PERMISSION_RESOURCE.task,
|
|
52
53
|
identifier: task?.id ?? '',
|
|
@@ -77,7 +78,7 @@ export class DossierDetailsTaskDetailComponent {
|
|
|
77
78
|
this.formSubmit.emit();
|
|
78
79
|
}
|
|
79
80
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailsTaskDetailComponent, deps: [{ token: i1.ConfigService }, { token: i2.PageHeaderService }, { token: i3.PermissionService }, { token: i4.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
80
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierDetailsTaskDetailComponent, isStandalone: true, selector: "valtimo-dossier-detail-task-detail", inputs: {
|
|
81
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierDetailsTaskDetailComponent, isStandalone: true, selector: "valtimo-dossier-detail-task-detail", inputs: { taskAndProcessLink: "taskAndProcessLink" }, outputs: { closeEvent: "closeEvent", assignmentOfTaskChanged: "assignmentOfTaskChanged", activeChange: "activeChange", formSubmit: "formSubmit" }, ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n *ngIf=\"{\n canAssignUserToTask: canAssignUserToTask$ | async,\n intermediateSaveValue: intermediateSaveValue$ | async,\n task: task$ | async,\n taskAndProcessLink: taskAndProcessLink$ | async,\n } as obs\"\n class=\"valtimo-dossier-detail-task-detail\"\n>\n <section class=\"valtimo-dossier-detail-task-detail__header\">\n <valtimo-task-detail-intermediate-save\n *ngIf=\"enableIntermediateSave\"\n [taskAndProcessLink]=\"obs.taskAndProcessLink\"\n (currentIntermediateSaveEvent)=\"onCurrentIntermediateSaveEvent($event)\"\n ></valtimo-task-detail-intermediate-save>\n\n <button cdsButton=\"ghost\" [iconOnly]=\"true\" (click)=\"onClose()\">\n <svg class=\"cds--btn__icon\" cdsIcon=\"close\" size=\"16\"></svg>\n </button>\n </section>\n\n <section\n class=\"valtimo-dossier-detail-task-detail__body\"\n [class.valtimo-dossier-detail-task-detail__body--compact]=\"compactMode$ | async\"\n >\n <div class=\"title-container\">\n <p class=\"valtimo-dossier-detail-task-detail__title\">{{ pageValue()?.title }}</p>\n\n <p class=\"cds--modal-header__label cds--type-delta\">{{ pageValue()?.subtitle }}</p>\n\n <p *ngIf=\"obs.intermediateSaveValue\" class=\"cds--modal-header__label\">\n {{ 'formManagement.intermediateSave.lastSavedBy' | translate }}:\n\n {{\n obs.intermediateSaveValue.editedBy\n ? obs.intermediateSaveValue.editedBy\n : obs.intermediateSaveValue.createdBy\n }}\n\n {{ 'formManagement.intermediateSave.on' | translate }}:\n\n {{\n obs.intermediateSaveValue.editedOn\n ? obs.intermediateSaveValue.editedOn\n : obs.intermediateSaveValue.createdOn\n }}\n </p>\n\n <valtimo-assign-user-to-task\n *ngIf=\"obs.task && obs.canAssignUserToTask\"\n [taskId]=\"obs.task.id\"\n [assigneeId]=\"obs.task.assignee\"\n ></valtimo-assign-user-to-task>\n </div>\n\n <valtimo-task-detail-content\n [taskAndProcessLink]=\"obs.taskAndProcessLink\"\n (activeChange)=\"onActiveChangeEvent($event)\"\n (formSubmit)=\"onFormSubmitEvent()\"\n ></valtimo-task-detail-content>\n </section>\n</div>\n", styles: [".valtimo-dossier-detail-task-detail{width:100%;display:flex;flex-direction:column;background-color:var(--cds-layer);padding:8px 16px 16px}.valtimo-dossier-detail-task-detail__header{display:flex;justify-content:flex-end}.valtimo-dossier-detail-task-detail__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.valtimo-dossier-detail-task-detail__body{overflow-y:auto;max-height:calc(100vh - 320px)}.valtimo-dossier-detail-task-detail__body--compact{max-height:calc(100vh - 280px)}.valtimo-dossier-detail-task-detail__body .title-container{position:sticky;background-color:var(--cds-layer);top:0;z-index:12;padding-bottom:16px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "component", type: TaskDetailContentComponent, selector: "valtimo-task-detail-content", inputs: ["task", "taskAndProcessLink", "modalClosed"], outputs: ["closeModalEvent", "formSubmit", "activeChange"] }, { kind: "component", type: TaskDetailIntermediateSaveComponent, selector: "valtimo-task-detail-intermediate-save", inputs: ["task", "taskAndProcessLink"], outputs: ["currentIntermediateSaveEvent", "showModalEvent"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i6.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "ngmodule", type: IconModule }, { kind: "directive", type: i6.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "component", type: AssignUserToTaskComponent, selector: "valtimo-assign-user-to-task", inputs: ["taskId", "assigneeId"], outputs: ["assignmentOfTaskChanged"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
81
82
|
}
|
|
82
83
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailsTaskDetailComponent, decorators: [{
|
|
83
84
|
type: Component,
|
|
@@ -89,8 +90,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
89
90
|
ButtonModule,
|
|
90
91
|
IconModule,
|
|
91
92
|
AssignUserToTaskComponent,
|
|
92
|
-
], template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n *ngIf=\"{\n canAssignUserToTask: canAssignUserToTask$ | async,\n intermediateSaveValue: intermediateSaveValue$ | async,\n task: task$ | async,\n } as obs\"\n class=\"valtimo-dossier-detail-task-detail\"\n>\n <section class=\"valtimo-dossier-detail-task-detail__header\">\n <valtimo-task-detail-intermediate-save\n *ngIf=\"enableIntermediateSave\"\n [
|
|
93
|
-
}], ctorParameters: () => [{ type: i1.ConfigService }, { type: i2.PageHeaderService }, { type: i3.PermissionService }, { type: i4.TranslateService }], propDecorators: {
|
|
93
|
+
], template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n *ngIf=\"{\n canAssignUserToTask: canAssignUserToTask$ | async,\n intermediateSaveValue: intermediateSaveValue$ | async,\n task: task$ | async,\n taskAndProcessLink: taskAndProcessLink$ | async,\n } as obs\"\n class=\"valtimo-dossier-detail-task-detail\"\n>\n <section class=\"valtimo-dossier-detail-task-detail__header\">\n <valtimo-task-detail-intermediate-save\n *ngIf=\"enableIntermediateSave\"\n [taskAndProcessLink]=\"obs.taskAndProcessLink\"\n (currentIntermediateSaveEvent)=\"onCurrentIntermediateSaveEvent($event)\"\n ></valtimo-task-detail-intermediate-save>\n\n <button cdsButton=\"ghost\" [iconOnly]=\"true\" (click)=\"onClose()\">\n <svg class=\"cds--btn__icon\" cdsIcon=\"close\" size=\"16\"></svg>\n </button>\n </section>\n\n <section\n class=\"valtimo-dossier-detail-task-detail__body\"\n [class.valtimo-dossier-detail-task-detail__body--compact]=\"compactMode$ | async\"\n >\n <div class=\"title-container\">\n <p class=\"valtimo-dossier-detail-task-detail__title\">{{ pageValue()?.title }}</p>\n\n <p class=\"cds--modal-header__label cds--type-delta\">{{ pageValue()?.subtitle }}</p>\n\n <p *ngIf=\"obs.intermediateSaveValue\" class=\"cds--modal-header__label\">\n {{ 'formManagement.intermediateSave.lastSavedBy' | translate }}:\n\n {{\n obs.intermediateSaveValue.editedBy\n ? obs.intermediateSaveValue.editedBy\n : obs.intermediateSaveValue.createdBy\n }}\n\n {{ 'formManagement.intermediateSave.on' | translate }}:\n\n {{\n obs.intermediateSaveValue.editedOn\n ? obs.intermediateSaveValue.editedOn\n : obs.intermediateSaveValue.createdOn\n }}\n </p>\n\n <valtimo-assign-user-to-task\n *ngIf=\"obs.task && obs.canAssignUserToTask\"\n [taskId]=\"obs.task.id\"\n [assigneeId]=\"obs.task.assignee\"\n ></valtimo-assign-user-to-task>\n </div>\n\n <valtimo-task-detail-content\n [taskAndProcessLink]=\"obs.taskAndProcessLink\"\n (activeChange)=\"onActiveChangeEvent($event)\"\n (formSubmit)=\"onFormSubmitEvent()\"\n ></valtimo-task-detail-content>\n </section>\n</div>\n", styles: [".valtimo-dossier-detail-task-detail{width:100%;display:flex;flex-direction:column;background-color:var(--cds-layer);padding:8px 16px 16px}.valtimo-dossier-detail-task-detail__header{display:flex;justify-content:flex-end}.valtimo-dossier-detail-task-detail__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.valtimo-dossier-detail-task-detail__body{overflow-y:auto;max-height:calc(100vh - 320px)}.valtimo-dossier-detail-task-detail__body--compact{max-height:calc(100vh - 280px)}.valtimo-dossier-detail-task-detail__body .title-container{position:sticky;background-color:var(--cds-layer);top:0;z-index:12;padding-bottom:16px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"] }]
|
|
94
|
+
}], ctorParameters: () => [{ type: i1.ConfigService }, { type: i2.PageHeaderService }, { type: i3.PermissionService }, { type: i4.TranslateService }], propDecorators: { taskAndProcessLink: [{
|
|
94
95
|
type: Input
|
|
95
96
|
}], closeEvent: [{
|
|
96
97
|
type: Output
|
|
@@ -101,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
101
102
|
}], formSubmit: [{
|
|
102
103
|
type: Output
|
|
103
104
|
}] } });
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-detail-task-detail.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.ts","../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {CommonModule} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  signal,\n} from '@angular/core';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {PermissionService} from '@valtimo/access-control';\nimport {PageHeaderService} from '@valtimo/components';\nimport {ConfigService} from '@valtimo/config';\nimport {ProcessInstanceTask} from '@valtimo/process';\nimport {\n  AssignUserToTaskComponent,\n  CAN_ASSIGN_TASK_PERMISSION,\n  IntermediateSubmission,\n  TASK_DETAIL_PERMISSION_RESOURCE,\n  TaskDetailContentComponent,\n  TaskDetailIntermediateSaveComponent,\n} from '@valtimo/task';\nimport {ButtonModule, IconModule} from 'carbon-components-angular';\nimport {BehaviorSubject, Observable, switchMap} from 'rxjs';\n\n@Component({\n  selector: 'valtimo-dossier-detail-task-detail',\n  templateUrl: './dossier-detail-task-detail.component.html',\n  styleUrl: './dossier-detail-task-detail.component.scss',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    TranslateModule,\n    TaskDetailContentComponent,\n    TaskDetailIntermediateSaveComponent,\n    ButtonModule,\n    IconModule,\n    AssignUserToTaskComponent,\n  ],\n})\nexport class DossierDetailsTaskDetailComponent implements OnDestroy {\n  @Input() public set task(value: ProcessInstanceTask | null) {\n    if (!value) return;\n\n    this.task$.next(value);\n    this.pageValue.set({\n      title: value?.name,\n      subtitle: `${this.translateService.instant('taskDetail.taskCreated')} ${value?.created}`,\n    });\n  }\n  @Output() public readonly closeEvent = new EventEmitter();\n  @Output() public readonly assignmentOfTaskChanged = new EventEmitter();\n  @Output() public readonly activeChange = new EventEmitter<boolean>();\n  @Output() public readonly formSubmit = new EventEmitter();\n\n  public readonly compactMode$: Observable<boolean> = this.pageHeaderService.compactMode$;\n  public readonly task$ = new BehaviorSubject<ProcessInstanceTask | null>(null);\n  public readonly canAssignUserToTask$: Observable<boolean> = this.task$.pipe(\n    switchMap((task: ProcessInstanceTask | null) =>\n      this.permissionService.requestPermission(CAN_ASSIGN_TASK_PERMISSION, {\n        resource: TASK_DETAIL_PERMISSION_RESOURCE.task,\n        identifier: task?.id ?? '',\n      })\n    )\n  );\n  public readonly intermediateSaveValue$ = new BehaviorSubject<IntermediateSubmission | null>(null);\n  public readonly pageValue = signal<{title: string; subtitle: string}>({\n    title: '',\n    subtitle: '',\n  });\n  public enableIntermediateSave = false;\n\n  constructor(\n    private readonly configService: ConfigService,\n    private readonly pageHeaderService: PageHeaderService,\n    private readonly permissionService: PermissionService,\n    private readonly translateService: TranslateService\n  ) {\n    this.enableIntermediateSave = !!this.configService.featureToggles?.enableIntermediateSave;\n  }\n\n  public ngOnDestroy(): void {\n    this.closeEvent.emit();\n  }\n\n  public onClose(): void {\n    this.closeEvent.emit();\n    this.onActiveChangeEvent(false);\n  }\n\n  public onCurrentIntermediateSaveEvent(value: IntermediateSubmission | null): void {\n    this.intermediateSaveValue$.next(value);\n    this.onActiveChangeEvent(false);\n  }\n\n  public onActiveChangeEvent(activeChange: boolean): void {\n    this.activeChange.emit(activeChange);\n  }\n\n  public onFormSubmitEvent(): void {\n    this.formSubmit.emit();\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div\n  *ngIf=\"{\n    canAssignUserToTask: canAssignUserToTask$ | async,\n    intermediateSaveValue: intermediateSaveValue$ | async,\n    task: task$ | async,\n  } as obs\"\n  class=\"valtimo-dossier-detail-task-detail\"\n>\n  <section class=\"valtimo-dossier-detail-task-detail__header\">\n    <valtimo-task-detail-intermediate-save\n      *ngIf=\"enableIntermediateSave\"\n      [task]=\"obs.task\"\n      (currentIntermediateSaveEvent)=\"onCurrentIntermediateSaveEvent($event)\"\n    ></valtimo-task-detail-intermediate-save>\n\n    <button cdsButton=\"ghost\" [iconOnly]=\"true\" (click)=\"onClose()\">\n      <svg class=\"cds--btn__icon\" cdsIcon=\"close\" size=\"16\"></svg>\n    </button>\n  </section>\n\n  <section\n    class=\"valtimo-dossier-detail-task-detail__body\"\n    [class.valtimo-dossier-detail-task-detail__body--compact]=\"compactMode$ | async\"\n  >\n    <div class=\"title-container\">\n      <p class=\"valtimo-dossier-detail-task-detail__title\">{{ pageValue()?.title }}</p>\n\n      <p class=\"cds--modal-header__label cds--type-delta\">{{ pageValue()?.subtitle }}</p>\n\n      <p *ngIf=\"obs.intermediateSaveValue\" class=\"cds--modal-header__label\">\n        {{ 'formManagement.intermediateSave.lastSavedBy' | translate }}:\n\n        {{\n          obs.intermediateSaveValue.editedBy\n            ? obs.intermediateSaveValue.editedBy\n            : obs.intermediateSaveValue.createdBy\n        }}\n\n        {{ 'formManagement.intermediateSave.on' | translate }}:\n\n        {{\n          obs.intermediateSaveValue.editedOn\n            ? obs.intermediateSaveValue.editedOn\n            : obs.intermediateSaveValue.createdOn\n        }}\n      </p>\n\n      <valtimo-assign-user-to-task\n        *ngIf=\"obs.task && obs.canAssignUserToTask\"\n        [taskId]=\"obs.task.id\"\n        [assigneeId]=\"obs.task.assignee\"\n      ></valtimo-assign-user-to-task>\n    </div>\n\n    <valtimo-task-detail-content\n      [task]=\"task$ | async\"\n      (activeChange)=\"onActiveChangeEvent($event)\"\n      (formSubmit)=\"onFormSubmitEvent()\"\n    ></valtimo-task-detail-content>\n  </section>\n</div>\n"]}
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-detail-task-detail.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.ts","../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {CommonModule} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  signal,\n} from '@angular/core';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {PermissionService} from '@valtimo/access-control';\nimport {PageHeaderService} from '@valtimo/components';\nimport {ConfigService} from '@valtimo/config';\nimport {ProcessInstanceTask} from '@valtimo/process';\nimport {\n  AssignUserToTaskComponent,\n  CAN_ASSIGN_TASK_PERMISSION,\n  IntermediateSubmission,\n  TASK_DETAIL_PERMISSION_RESOURCE,\n  TaskDetailContentComponent,\n  TaskDetailIntermediateSaveComponent,\n} from '@valtimo/task';\nimport {ButtonModule, IconModule} from 'carbon-components-angular';\nimport {BehaviorSubject, map, Observable, switchMap} from 'rxjs';\nimport {TaskWithProcessLink} from '@valtimo/process-link';\n\n@Component({\n  selector: 'valtimo-dossier-detail-task-detail',\n  templateUrl: './dossier-detail-task-detail.component.html',\n  styleUrl: './dossier-detail-task-detail.component.scss',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    TranslateModule,\n    TaskDetailContentComponent,\n    TaskDetailIntermediateSaveComponent,\n    ButtonModule,\n    IconModule,\n    AssignUserToTaskComponent,\n  ],\n})\nexport class DossierDetailsTaskDetailComponent implements OnDestroy {\n  @Input() public set taskAndProcessLink(value: TaskWithProcessLink | null) {\n    if (!value) return;\n\n    this.taskAndProcessLink$.next(value);\n    this.pageValue.set({\n      title: value?.task.name,\n      subtitle: `${this.translateService.instant('taskDetail.taskCreated')} ${value?.task?.created}`,\n    });\n  }\n  @Output() public readonly closeEvent = new EventEmitter();\n  @Output() public readonly assignmentOfTaskChanged = new EventEmitter();\n  @Output() public readonly activeChange = new EventEmitter<boolean>();\n  @Output() public readonly formSubmit = new EventEmitter();\n\n  public readonly compactMode$: Observable<boolean> = this.pageHeaderService.compactMode$;\n  public readonly taskAndProcessLink$ = new BehaviorSubject<TaskWithProcessLink | null>(null);\n  public readonly task$ = this.taskAndProcessLink$.pipe(\n    map(taskAndProcessLink => taskAndProcessLink.task)\n  );\n  public readonly canAssignUserToTask$: Observable<boolean> = this.task$.pipe(\n    switchMap((task: ProcessInstanceTask | null) =>\n      this.permissionService.requestPermission(CAN_ASSIGN_TASK_PERMISSION, {\n        resource: TASK_DETAIL_PERMISSION_RESOURCE.task,\n        identifier: task?.id ?? '',\n      })\n    )\n  );\n  public readonly intermediateSaveValue$ = new BehaviorSubject<IntermediateSubmission | null>(null);\n  public readonly pageValue = signal<{title: string; subtitle: string}>({\n    title: '',\n    subtitle: '',\n  });\n  public enableIntermediateSave = false;\n\n  constructor(\n    private readonly configService: ConfigService,\n    private readonly pageHeaderService: PageHeaderService,\n    private readonly permissionService: PermissionService,\n    private readonly translateService: TranslateService\n  ) {\n    this.enableIntermediateSave = !!this.configService.featureToggles?.enableIntermediateSave;\n  }\n\n  public ngOnDestroy(): void {\n    this.closeEvent.emit();\n  }\n\n  public onClose(): void {\n    this.closeEvent.emit();\n    this.onActiveChangeEvent(false);\n  }\n\n  public onCurrentIntermediateSaveEvent(value: IntermediateSubmission | null): void {\n    this.intermediateSaveValue$.next(value);\n    this.onActiveChangeEvent(false);\n  }\n\n  public onActiveChangeEvent(activeChange: boolean): void {\n    this.activeChange.emit(activeChange);\n  }\n\n  public onFormSubmitEvent(): void {\n    this.formSubmit.emit();\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div\n  *ngIf=\"{\n    canAssignUserToTask: canAssignUserToTask$ | async,\n    intermediateSaveValue: intermediateSaveValue$ | async,\n    task: task$ | async,\n    taskAndProcessLink: taskAndProcessLink$ | async,\n  } as obs\"\n  class=\"valtimo-dossier-detail-task-detail\"\n>\n  <section class=\"valtimo-dossier-detail-task-detail__header\">\n    <valtimo-task-detail-intermediate-save\n      *ngIf=\"enableIntermediateSave\"\n      [taskAndProcessLink]=\"obs.taskAndProcessLink\"\n      (currentIntermediateSaveEvent)=\"onCurrentIntermediateSaveEvent($event)\"\n    ></valtimo-task-detail-intermediate-save>\n\n    <button cdsButton=\"ghost\" [iconOnly]=\"true\" (click)=\"onClose()\">\n      <svg class=\"cds--btn__icon\" cdsIcon=\"close\" size=\"16\"></svg>\n    </button>\n  </section>\n\n  <section\n    class=\"valtimo-dossier-detail-task-detail__body\"\n    [class.valtimo-dossier-detail-task-detail__body--compact]=\"compactMode$ | async\"\n  >\n    <div class=\"title-container\">\n      <p class=\"valtimo-dossier-detail-task-detail__title\">{{ pageValue()?.title }}</p>\n\n      <p class=\"cds--modal-header__label cds--type-delta\">{{ pageValue()?.subtitle }}</p>\n\n      <p *ngIf=\"obs.intermediateSaveValue\" class=\"cds--modal-header__label\">\n        {{ 'formManagement.intermediateSave.lastSavedBy' | translate }}:\n\n        {{\n          obs.intermediateSaveValue.editedBy\n            ? obs.intermediateSaveValue.editedBy\n            : obs.intermediateSaveValue.createdBy\n        }}\n\n        {{ 'formManagement.intermediateSave.on' | translate }}:\n\n        {{\n          obs.intermediateSaveValue.editedOn\n            ? obs.intermediateSaveValue.editedOn\n            : obs.intermediateSaveValue.createdOn\n        }}\n      </p>\n\n      <valtimo-assign-user-to-task\n        *ngIf=\"obs.task && obs.canAssignUserToTask\"\n        [taskId]=\"obs.task.id\"\n        [assigneeId]=\"obs.task.assignee\"\n      ></valtimo-assign-user-to-task>\n    </div>\n\n    <valtimo-task-detail-content\n      [taskAndProcessLink]=\"obs.taskAndProcessLink\"\n      (activeChange)=\"onActiveChangeEvent($event)\"\n      (formSubmit)=\"onFormSubmitEvent()\"\n    ></valtimo-task-detail-content>\n  </section>\n</div>\n"]}
|