diff --git a/CHANGELOG.md b/CHANGELOG.md
index 0adb7f44..5949d81a 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,3 +1,22 @@
+## [4.9.0](https://github.com/onecx/onecx-portal-ui-libs/compare/v4.8.0...v4.9.0) (2024-02-28)
+
+
+### Features
+
+* column group floating label displayed ([#148](https://github.com/onecx/onecx-portal-ui-libs/issues/148)) ([70cf90e](https://github.com/onecx/onecx-portal-ui-libs/commit/70cf90ed8f906d640ea7280ec850a377b6b7f785))
+* lifecycle component ([#153](https://github.com/onecx/onecx-portal-ui-libs/issues/153)) ([c9c8cdf](https://github.com/onecx/onecx-portal-ui-libs/commit/c9c8cdfbc2071d65e21d3f809d97355e1201e079))
+* search header allows to provide subheader now ([#147](https://github.com/onecx/onecx-portal-ui-libs/issues/147)) ([d4bf6c5](https://github.com/onecx/onecx-portal-ui-libs/commit/d4bf6c5edb15f49f293290ddd2fdd4639e44fcd8))
+
+
+### Bug Fixes
+
+* adapt SearchConfig interface and use the type PrimeIcon for icons ([#152](https://github.com/onecx/onecx-portal-ui-libs/issues/152)) ([56e09ac](https://github.com/onecx/onecx-portal-ui-libs/commit/56e09acc4d312b9006da378817fa944f3f1eec59))
+
+
+### Refactoring
+
+* migrate icons in TS to PrimeIcons ([#151](https://github.com/onecx/onecx-portal-ui-libs/issues/151)) ([186fae8](https://github.com/onecx/onecx-portal-ui-libs/commit/186fae874a752f734b87c45d35a9c4c5c0e79bc2))
+
## [4.8.0](https://github.com/onecx/onecx-portal-ui-libs/compare/v4.7.0...v4.8.0) (2024-02-26)
diff --git a/libs/accelerator/package.json b/libs/accelerator/package.json
index caf7e084..0eef28af 100644
--- a/libs/accelerator/package.json
+++ b/libs/accelerator/package.json
@@ -1,6 +1,6 @@
{
"name": "@onecx/accelerator",
- "version": "4.8.0",
+ "version": "4.9.0",
"peerDependencies": {
"tslib": "^2.3.0",
"rxjs": "7.8.1"
diff --git a/libs/integration-interface/package.json b/libs/integration-interface/package.json
index e6718c07..e4845eee 100644
--- a/libs/integration-interface/package.json
+++ b/libs/integration-interface/package.json
@@ -1,6 +1,6 @@
{
"name": "@onecx/integration-interface",
- "version": "4.8.0",
+ "version": "4.9.0",
"peerDependencies": {
"tslib": "^2.3.0",
"rxjs": "7.8.1",
diff --git a/libs/keycloak-auth/package.json b/libs/keycloak-auth/package.json
index c6fda510..908f9533 100644
--- a/libs/keycloak-auth/package.json
+++ b/libs/keycloak-auth/package.json
@@ -1,6 +1,6 @@
{
"name": "@onecx/keycloak-auth",
- "version": "4.8.0",
+ "version": "4.9.0",
"peerDependencies": {
"@angular/common": ">=15.2.7",
"@angular/core": ">=15.2.7",
diff --git a/libs/portal-integration-angular/assets/i18n/de.json b/libs/portal-integration-angular/assets/i18n/de.json
index de1a09db..6f78e0cf 100644
--- a/libs/portal-integration-angular/assets/i18n/de.json
+++ b/libs/portal-integration-angular/assets/i18n/de.json
@@ -1,5 +1,6 @@
{
"OCX_CUSTOM_GROUP_COLUMN_SELECTOR": {
+ "DROPDOWN_LABEL": "Spalten",
"OPEN_BUTTON_TITLE": "Dialog zur Auswahl einer benutzerdefinierten Gruppe öffnen",
"ACTIVE_COLUMNS_LABEL": "Aktive Spalten",
"INACTIVE_COLUMNS_LABEL": "Inaktive Spalten",
diff --git a/libs/portal-integration-angular/assets/i18n/en.json b/libs/portal-integration-angular/assets/i18n/en.json
index 5a40f9cd..e9d19e17 100644
--- a/libs/portal-integration-angular/assets/i18n/en.json
+++ b/libs/portal-integration-angular/assets/i18n/en.json
@@ -1,5 +1,6 @@
{
"OCX_CUSTOM_GROUP_COLUMN_SELECTOR": {
+ "DROPDOWN_LABEL": "Columns",
"OPEN_BUTTON_TITLE": "Open custom group selection dialog",
"ACTIVE_COLUMNS_LABEL": "Active columns",
"INACTIVE_COLUMNS_LABEL": "Inactive columns",
diff --git a/libs/portal-integration-angular/package.json b/libs/portal-integration-angular/package.json
index 634c9706..e573df42 100644
--- a/libs/portal-integration-angular/package.json
+++ b/libs/portal-integration-angular/package.json
@@ -1,6 +1,6 @@
{
"name": "@onecx/portal-integration-angular",
- "version": "4.8.0",
+ "version": "4.9.0",
"peerDependencies": {
"@angular-architects/module-federation": "15.0.0",
"@angular/common": "^15.2.7",
diff --git a/libs/portal-integration-angular/src/index.ts b/libs/portal-integration-angular/src/index.ts
index e4189909..55151a9f 100644
--- a/libs/portal-integration-angular/src/index.ts
+++ b/libs/portal-integration-angular/src/index.ts
@@ -57,6 +57,7 @@ export * from './lib/core/components/loading-indicator/loading-indicator.compone
export * from './lib/core/components/content-container/content-container.component'
export * from './lib/core/components/content/content.component'
export * from './lib/core/components/create-or-edit-search-config-dialog/create-or-edit-search-config-dialog.component'
+export * from './lib/core/components/lifecycle/lifecycle.component'
// services
export * from './lib/services/app.menu.service'
@@ -127,3 +128,4 @@ export * from './lib/core/utils/add-initialize-module-guard.utils'
export * from './lib/core/utils/translate-service-initializer.utils'
export * from './lib/core/utils/portal-api-configuration.utils'
export * from './lib/core/utils/caching-translate-loader.utils'
+export * from './lib/core/utils/primeicon.utils'
diff --git a/libs/portal-integration-angular/src/lib/core/components/button-dialog/button-dialog.component.html b/libs/portal-integration-angular/src/lib/core/components/button-dialog/button-dialog.component.html
index d5e3ce3b..0f8b1934 100644
--- a/libs/portal-integration-angular/src/lib/core/components/button-dialog/button-dialog.component.html
+++ b/libs/portal-integration-angular/src/lib/core/components/button-dialog/button-dialog.component.html
@@ -1,25 +1,25 @@
\ No newline at end of file
+
+
+
+
+
+
+
diff --git a/libs/portal-integration-angular/src/lib/core/components/button-dialog/button-dialog.component.spec.ts b/libs/portal-integration-angular/src/lib/core/components/button-dialog/button-dialog.component.spec.ts
index 58894c26..47995ce2 100644
--- a/libs/portal-integration-angular/src/lib/core/components/button-dialog/button-dialog.component.spec.ts
+++ b/libs/portal-integration-angular/src/lib/core/components/button-dialog/button-dialog.component.spec.ts
@@ -9,6 +9,7 @@ import { ButtonDialogComponent } from './button-dialog.component'
import { MockAuthModule } from '../../../mock-auth/mock-auth.module'
import { ButtonDialogHarness, DivHarness } from '../../../../../testing'
import { ButtonDialogConfig } from '../../../model/button-dialog'
+import { PrimeIcons } from 'primeng/api'
@Component({
template: `
@@ -20,12 +21,12 @@ class TestBaseHostComponent {}
const config: ButtonDialogConfig = {
primaryButtonDetails: {
key: 'inlineMain',
- icon: 'pi pi-plus',
+ icon: PrimeIcons.PLUS,
},
secondaryButtonIncluded: true,
secondaryButtonDetails: {
key: 'inlineSide',
- icon: 'pi pi-times',
+ icon: PrimeIcons.TIMES,
},
}
@@ -121,12 +122,12 @@ describe('ButtonDialogComponent', () => {
component.dialogData.config = {
primaryButtonDetails: {
key: 'CustomMain',
- icon: 'pi pi-check',
+ icon: PrimeIcons.CHECK,
},
secondaryButtonIncluded: true,
secondaryButtonDetails: {
key: 'CustomSide',
- icon: 'pi pi-times',
+ icon: PrimeIcons.TIMES,
},
}
@@ -134,8 +135,8 @@ describe('ButtonDialogComponent', () => {
expect(await buttonDialogHarness.getPrimaryButtonLabel()).toBe('CustomMain')
expect(await buttonDialogHarness.getSecondaryButtonLabel()).toBe('CustomSide')
// expect correct icon
- expect(await buttonDialogHarness.getPrimaryButtonIcon()).toBe('pi pi-check')
- expect(await buttonDialogHarness.getSecondaryButtonIcon()).toBe('pi pi-times')
+ expect(await buttonDialogHarness.getPrimaryButtonIcon()).toBe(PrimeIcons.CHECK)
+ expect(await buttonDialogHarness.getSecondaryButtonIcon()).toBe(PrimeIcons.TIMES)
})
it('should translate button keys', async () => {
@@ -317,9 +318,9 @@ describe('ButtonDialogComponent', () => {
buttonDialogHarness = await harnessLoader.getHarness(ButtonDialogHarness)
expect(await buttonDialogHarness.getPrimaryButtonLabel()).toBe('inlineMain')
- expect(await buttonDialogHarness.getPrimaryButtonIcon()).toBe('pi pi-plus')
+ expect(await buttonDialogHarness.getPrimaryButtonIcon()).toBe(PrimeIcons.PLUS)
expect(await buttonDialogHarness.getSecondaryButtonLabel()).toBe('inlineSide')
- expect(await buttonDialogHarness.getSecondaryButtonIcon()).toBe('pi pi-times')
+ expect(await buttonDialogHarness.getSecondaryButtonIcon()).toBe(PrimeIcons.TIMES)
})
it('should use default emitter inline', async () => {
diff --git a/libs/portal-integration-angular/src/lib/core/components/column-group-selection/column-group-selection.component.html b/libs/portal-integration-angular/src/lib/core/components/column-group-selection/column-group-selection.component.html
index f1dc2548..ca6b3da4 100644
--- a/libs/portal-integration-angular/src/lib/core/components/column-group-selection/column-group-selection.component.html
+++ b/libs/portal-integration-angular/src/lib/core/components/column-group-selection/column-group-selection.component.html
@@ -1,13 +1,16 @@
-
- {{ item ? (item | translate) : ''}}
- {{ item ? (item | translate) : ''}}
-
+
+
+ {{ item ? (item | translate) : ''}}
+ {{ item ? (item | translate) : ''}}
+
+
+
\ No newline at end of file
diff --git a/libs/portal-integration-angular/src/lib/core/components/data-layout-selection/data-layout-selection.component.ts b/libs/portal-integration-angular/src/lib/core/components/data-layout-selection/data-layout-selection.component.ts
index 4580be60..c706e006 100644
--- a/libs/portal-integration-angular/src/lib/core/components/data-layout-selection/data-layout-selection.component.ts
+++ b/libs/portal-integration-angular/src/lib/core/components/data-layout-selection/data-layout-selection.component.ts
@@ -1,16 +1,18 @@
import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core'
+import { PrimeIcons } from 'primeng/api'
+import { PrimeIcon } from '../../utils/primeicon.utils'
interface ViewingLayouts {
- icon: string
+ icon: PrimeIcon
layout: 'grid' | 'list' | 'table'
title?: string
titleKey: string
}
const ALL_VIEW_LAYOUTS: ViewingLayouts[] = [
- { icon: 'pi pi-list', layout: 'list', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.LIST' },
- { icon: 'pi pi-th-large', layout: 'grid', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.GRID' },
- { icon: 'pi pi-table', layout: 'table', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.TABLE' },
+ { icon: PrimeIcons.LIST, layout: 'list', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.LIST' },
+ { icon: PrimeIcons.TH_LARGE, layout: 'grid', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.GRID' },
+ { icon: PrimeIcons.TABLE, layout: 'table', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.TABLE' },
]
@Component({
@@ -38,7 +40,7 @@ export class DataLayoutSelectionComponent implements OnInit {
this.layout = 'table'
}
- onDataViewLayoutChange(event: { icon: string; layout: 'grid' | 'list' | 'table' }): void {
+ onDataViewLayoutChange(event: { icon: PrimeIcon; layout: 'grid' | 'list' | 'table' }): void {
this.dataViewLayoutChange.emit(event.layout)
}
}
diff --git a/libs/portal-integration-angular/src/lib/core/components/data-list-grid/data-list-grid.component.ts b/libs/portal-integration-angular/src/lib/core/components/data-list-grid/data-list-grid.component.ts
index bef9b8c6..c2c162b7 100644
--- a/libs/portal-integration-angular/src/lib/core/components/data-list-grid/data-list-grid.component.ts
+++ b/libs/portal-integration-angular/src/lib/core/components/data-list-grid/data-list-grid.component.ts
@@ -13,7 +13,7 @@ import {
} from '@angular/core'
import { Router } from '@angular/router'
import { TranslateService } from '@ngx-translate/core'
-import { MenuItem } from 'primeng/api'
+import { MenuItem, PrimeIcons } from 'primeng/api'
import { BehaviorSubject, Observable, combineLatest, map, mergeMap } from 'rxjs'
import { DataAction } from '../../../model/data-action'
import { DataSortDirection } from '../../../model/data-sort-direction'
@@ -259,21 +259,21 @@ export class DataListGridComponent extends DataSortBase implements OnInit, DoChe
if (this.viewItem.observed && this.userService.hasPermission(this.viewPermission || '')) {
menuItems.push({
label: translations[this.viewMenuItemKey || 'OCX_DATA_LIST_GRID.MENU.VIEW'],
- icon: 'pi pi-eye',
+ icon: PrimeIcons.EYE,
command: () => this.viewItem.emit(this.selectedItem),
})
}
if (this.editItem.observed && this.userService.hasPermission(this.editPermission || '')) {
menuItems.push({
label: translations[this.editMenuItemKey || 'OCX_DATA_LIST_GRID.MENU.EDIT'],
- icon: 'pi pi-pencil',
+ icon: PrimeIcons.PENCIL,
command: () => this.editItem.emit(this.selectedItem),
})
}
if (this.deleteItem.observed && this.userService.hasPermission(this.deletePermission || '')) {
menuItems.push({
label: translations[this.deleteMenuItemKey || 'OCX_DATA_LIST_GRID.MENU.DELETE'],
- icon: 'pi pi-trash',
+ icon: PrimeIcons.TRASH,
command: () => this.deleteItem.emit(this.selectedItem),
})
}
diff --git a/libs/portal-integration-angular/src/lib/core/components/data-view-controls/data-view-controls.component.ts b/libs/portal-integration-angular/src/lib/core/components/data-view-controls/data-view-controls.component.ts
index 4fa3ff11..3ced3701 100644
--- a/libs/portal-integration-angular/src/lib/core/components/data-view-controls/data-view-controls.component.ts
+++ b/libs/portal-integration-angular/src/lib/core/components/data-view-controls/data-view-controls.component.ts
@@ -5,18 +5,26 @@ import { Column } from '../../../model/column'
import { ColumnViewTemplate } from '../../../model/column-view-template'
import { ColumnTogglerComponent } from './column-toggler-component/column-toggler.component'
import { ViewTemplatePickerComponent } from './view-template-picker/view-template-picker.component'
+import { PrimeIcons } from 'primeng/api'
+import { PrimeIcon } from '../../utils/primeicon.utils'
interface ViewingModes {
- icon: string
+ icon: PrimeIcon
mode: string
title?: string
titleKey?: string
}
-const ALL_VIEW_MODES = [
- { icon: 'pi pi-list', mode: 'list', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.LIST' },
- { icon: 'pi pi-th-large', mode: 'grid', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.GRID' },
- { icon: 'pi pi-table', mode: 'table', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.TABLE' },
+type ViewMode = {
+ icon: PrimeIcon
+ mode: string
+ titleKey: string
+}
+
+const ALL_VIEW_MODES: ViewMode[] = [
+ { icon: PrimeIcons.LIST, mode: 'list', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.LIST' },
+ { icon: PrimeIcons.TH_LARGE, mode: 'grid', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.GRID' },
+ { icon: PrimeIcons.TABLE, mode: 'table', titleKey: 'OCX_DATA_LAYOUT_SELECTION.LAYOUT.TABLE' },
]
interface DefaultColumnDefinition {
@@ -248,7 +256,7 @@ export class DataViewControlsComponent implements OnInit, OnChanges {
})
}
- viewModeChange(event: { icon: string; mode: string }): void {
+ viewModeChange(event: { icon: PrimeIcon; mode: string }): void {
this.dataViewChange.emit(event.mode)
this.enableToggleColumnButton(event.mode)
}
diff --git a/libs/portal-integration-angular/src/lib/core/components/diagram/diagram.component.ts b/libs/portal-integration-angular/src/lib/core/components/diagram/diagram.component.ts
index 55577114..f050e15c 100644
--- a/libs/portal-integration-angular/src/lib/core/components/diagram/diagram.component.ts
+++ b/libs/portal-integration-angular/src/lib/core/components/diagram/diagram.component.ts
@@ -6,9 +6,10 @@ import { PrimeIcons } from 'primeng/api'
import { DiagramData } from '../../../model/diagram-data'
import { DiagramType } from '../../../model/diagram-type'
import { ColorUtils } from '../../utils/colorutils'
+import { PrimeIcon } from '../../utils/primeicon.utils'
export interface DiagramLayouts {
- icon: string
+ icon: PrimeIcon
layout: DiagramType
title?: string
titleKey: string
@@ -16,14 +17,22 @@ export interface DiagramLayouts {
const allDiagramTypes: DiagramLayouts[] = [
{ icon: PrimeIcons.CHART_PIE, layout: DiagramType.PIE, titleKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.PIE' },
- { icon: PrimeIcons.BARS, layout: DiagramType.HORIZONTAL_BAR, titleKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.HORIZONTAL_BAR' },
- { icon: PrimeIcons.CHART_BAR, layout: DiagramType.VERTICAL_BAR, titleKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.VERTICAL_BAR' },
+ {
+ icon: PrimeIcons.BARS,
+ layout: DiagramType.HORIZONTAL_BAR,
+ titleKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.HORIZONTAL_BAR',
+ },
+ {
+ icon: PrimeIcons.CHART_BAR,
+ layout: DiagramType.VERTICAL_BAR,
+ titleKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.VERTICAL_BAR',
+ },
]
@Component({
selector: 'ocx-diagram',
templateUrl: './diagram.component.html',
- styleUrls: ['./diagram.component.scss']
+ styleUrls: ['./diagram.component.scss'],
})
export class DiagramComponent implements OnInit, OnChanges {
@Input() data: DiagramData[] | undefined
@@ -41,7 +50,7 @@ export class DiagramComponent implements OnInit, OnChanges {
this.chartType = this.diagramTypeToChartType(value)
}
private _supportedDiagramTypes: DiagramType[] = []
- @Input()
+ @Input()
get supportedDiagramTypes(): DiagramType[] {
return this._supportedDiagramTypes
}
diff --git a/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.html b/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.html
new file mode 100644
index 00000000..0d3daff1
--- /dev/null
+++ b/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.html
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
{{ step.title }}
+
{{ step.details }}
+
+
+
+
diff --git a/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.spec.ts b/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.spec.ts
new file mode 100644
index 00000000..02c84468
--- /dev/null
+++ b/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.spec.ts
@@ -0,0 +1,76 @@
+import { ComponentFixture, TestBed } from '@angular/core/testing'
+import { LifecycleComponent, LifecycleStep } from './lifecycle.component'
+import { TimelineModule } from 'primeng/timeline'
+import { LifecycleHarness, TestbedHarnessEnvironment } from '../../../../../testing'
+import { PrimeNgModule } from '../../primeng.module'
+import { BrowserAnimationsModule } from '@angular/platform-browser/animations'
+import { PortalCoreModule } from '../../portal-core.module'
+
+const mockSteps: LifecycleStep[] = [
+ {
+ id: 'test1',
+ title: 'Test 1',
+ },
+ {
+ id: 'test2',
+ title: 'Test 2',
+ details: 'Test 2 description',
+ },
+ {
+ id: 'test3',
+ title: 'Test 3',
+ },
+]
+
+describe('LifecycleComponent', () => {
+ let component: LifecycleComponent
+ let fixture: ComponentFixture
+ let lifecycle: LifecycleHarness
+
+ beforeEach(async () => {
+ await TestBed.configureTestingModule({
+ declarations: [LifecycleComponent],
+ imports: [TimelineModule, PrimeNgModule, BrowserAnimationsModule, PortalCoreModule],
+ }).compileComponents()
+
+ fixture = TestBed.createComponent(LifecycleComponent)
+ component = fixture.componentInstance
+ fixture.detectChanges()
+ lifecycle = await TestbedHarnessEnvironment.harnessForFixture(fixture, LifecycleHarness)
+ })
+
+ it('should create', () => {
+ expect(component).toBeTruthy()
+ expect(lifecycle).toBeTruthy()
+ })
+
+ it('should not render any initial lifecycle steps', async () => {
+ const steps = await lifecycle.getSteps()
+ expect(steps.length).toBe(0)
+ })
+
+ it('should render given lifecycle steps', async () => {
+ component.steps = mockSteps
+ const steps = await lifecycle.getSteps()
+ const highlightedSteps = await lifecycle.getHighlightedSteps()
+ expect(steps.length).toBe(3)
+ expect(highlightedSteps.length).toBe(0)
+ mockSteps.forEach(async (step, index) => {
+ expect(await steps[index].text()).toEqual(step.title + (step.details ?? ''))
+ })
+ })
+
+ it('should highlight a given lifecycle step', async () => {
+ component.steps = mockSteps
+ component.activeStepId = 'test2'
+ const steps = await lifecycle.getSteps()
+ const highlightedSteps = await lifecycle.getHighlightedSteps()
+ mockSteps.forEach(async (step, index) => {
+ if(step.id == component.activeStepId) {
+ expect(await steps[index].hasClass('bg-primary')).toEqual(true)
+ }
+ })
+ expect(steps.length).toBe(3)
+ expect(highlightedSteps.length).toBe(1)
+ })
+})
diff --git a/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.stories.ts b/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.stories.ts
new file mode 100644
index 00000000..f28ac41e
--- /dev/null
+++ b/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.stories.ts
@@ -0,0 +1,57 @@
+import { importProvidersFrom } from '@angular/core'
+import { BrowserModule } from '@angular/platform-browser'
+import { BrowserAnimationsModule } from '@angular/platform-browser/animations'
+import { Meta, StoryFn, applicationConfig, moduleMetadata } from '@storybook/angular'
+import { StorybookTranslateModule } from '../../storybook-translate.module'
+import { LifecycleComponent, LifecycleStep } from './lifecycle.component'
+import { TimelineModule } from 'primeng/timeline'
+import { CardModule } from 'primeng/card'
+
+export default {
+ title: 'LifecycleComponent',
+ component: LifecycleComponent,
+ decorators: [
+ applicationConfig({
+ providers: [importProvidersFrom(BrowserModule), importProvidersFrom(BrowserAnimationsModule)],
+ }),
+ moduleMetadata({
+ declarations: [LifecycleComponent],
+ imports: [StorybookTranslateModule, TimelineModule, CardModule],
+ }),
+ ],
+} as Meta
+
+const Template: StoryFn = (args: LifecycleComponent) => ({
+ props: args,
+})
+
+const mockData: LifecycleStep[] = [
+ {
+ id: "todo",
+ title: "ToDo"
+ },
+ {
+ id: "in_progress",
+ title: "In Progress",
+ details: "This event is currently in progress"
+ },
+ {
+ id: "done",
+ title: "Done"
+ }
+]
+
+export const WithoutHighlightedStep = {
+ render: Template,
+ args: {
+ steps: mockData
+ }
+}
+
+export const WithHighlightedStep = {
+ render: Template,
+ args: {
+ steps: mockData,
+ activeStepId: 'in_progress'
+ }
+ }
\ No newline at end of file
diff --git a/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.ts b/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.ts
new file mode 100644
index 00000000..cfdb33be
--- /dev/null
+++ b/libs/portal-integration-angular/src/lib/core/components/lifecycle/lifecycle.component.ts
@@ -0,0 +1,16 @@
+import { Component, Input } from '@angular/core'
+
+export interface LifecycleStep {
+ id: string
+ title: string,
+ details?: string,
+}
+
+@Component({
+ selector: 'ocx-lifecycle',
+ templateUrl: './lifecycle.component.html',
+})
+export class LifecycleComponent {
+ @Input() steps: LifecycleStep[] = []
+ @Input() activeStepId: string | undefined
+}
diff --git a/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.spec.ts b/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.spec.ts
index ebb3f250..90345b46 100644
--- a/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.spec.ts
+++ b/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.spec.ts
@@ -1,5 +1,5 @@
import { ComponentFixture, TestBed, getTestBed } from '@angular/core/testing'
-import { Action, PageHeaderComponent } from './page-header.component'
+import { Action, ObjectDetailItem, PageHeaderComponent } from './page-header.component'
import { RouterTestingModule } from '@angular/router/testing'
import { ConfigurationService } from '../../../services/configuration.service'
import { HttpClientTestingModule } from '@angular/common/http/testing'
@@ -115,22 +115,14 @@ describe('PageHeaderComponent', () => {
})
it('should check permissions and render buttons accordingly', async () => {
- expect(
- await pageHeaderHarness.getInlineActionButtons()
- ).toHaveLength(0)
- expect(
- await pageHeaderHarness.getOverflowActionButtons()
- ).toHaveLength(0)
+ expect(await pageHeaderHarness.getInlineActionButtons()).toHaveLength(0)
+ expect(await pageHeaderHarness.getOverflowActionButtons()).toHaveLength(0)
component.actions = mockActions
- expect(
- await pageHeaderHarness.getInlineActionButtons()
- ).toHaveLength(1)
+ expect(await pageHeaderHarness.getInlineActionButtons()).toHaveLength(1)
expect(await pageHeaderHarness.getElementByTitle('My Test Action')).toBeTruthy()
- expect(
- await pageHeaderHarness.getOverflowActionButtons()
- ).toHaveLength(1)
+ expect(await pageHeaderHarness.getOverflowActionButtons()).toHaveLength(1)
expect(await pageHeaderHarness.getElementByTitle('More actions')).toBeTruthy()
expect(userServiceSpy).toHaveBeenCalledTimes(3)
})
@@ -140,27 +132,19 @@ describe('PageHeaderComponent', () => {
userServiceSpy.mockReturnValue(false)
- expect(
- await pageHeaderHarness.getInlineActionButtons()
- ).toHaveLength(0)
- expect(
- await pageHeaderHarness.getOverflowActionButtons()
- ).toHaveLength(0)
+ expect(await pageHeaderHarness.getInlineActionButtons()).toHaveLength(0)
+ expect(await pageHeaderHarness.getOverflowActionButtons()).toHaveLength(0)
component.actions = mockActions
- expect(
- await pageHeaderHarness.getInlineActionButtons()
- ).toHaveLength(0)
+ expect(await pageHeaderHarness.getInlineActionButtons()).toHaveLength(0)
expect(await pageHeaderHarness.getElementByTitle('My Test Action')).toBeFalsy()
- expect(
- await pageHeaderHarness.getOverflowActionButtons()
- ).toHaveLength(0)
+ expect(await pageHeaderHarness.getOverflowActionButtons()).toHaveLength(0)
expect(await pageHeaderHarness.getElementByTitle('More actions')).toBeFalsy()
expect(userServiceSpy).toHaveBeenCalledTimes(3)
})
- it("should render objectDetails as object info in the page header", async () => {
+ it('should render objectDetails as object info in the page header', async () => {
const objectDetailsWithoutIcons = [
{
label: 'Venue',
@@ -174,7 +158,7 @@ describe('PageHeaderComponent', () => {
expect((await pageHeaderHarness.getObjectInfos()).length).toEqual(0)
component.objectDetails = objectDetailsWithoutIcons
-
+
expect((await pageHeaderHarness.getObjectInfos()).length).toEqual(2)
const objectDetailLabels = await pageHeaderHarness.getObjectDetailLabels()
const objectDetailValues = await pageHeaderHarness.getObjectDetailValues()
@@ -192,8 +176,8 @@ describe('PageHeaderComponent', () => {
})
})
- it("should render objectDetails with icons as object info in the page header", async () => {
- const objectDetailsWithIcons = [
+ it('should render objectDetails with icons as object info in the page header', async () => {
+ const objectDetailsWithIcons: ObjectDetailItem[] = [
{
label: 'Venue',
value: 'AIE Munich',
@@ -201,20 +185,20 @@ describe('PageHeaderComponent', () => {
{
label: 'Status',
value: 'Confirmed',
- icon: PrimeIcons.CHECK
+ icon: PrimeIcons.CHECK,
},
{
label: 'Done?',
- icon: PrimeIcons.EXCLAMATION_CIRCLE
+ icon: PrimeIcons.EXCLAMATION_CIRCLE,
},
{
- label: 'Empty'
- }
+ label: 'Empty',
+ },
]
expect((await pageHeaderHarness.getObjectInfos()).length).toEqual(0)
component.objectDetails = objectDetailsWithIcons
-
+
expect((await pageHeaderHarness.getObjectInfos()).length).toEqual(4)
const objectDetailLabels = await pageHeaderHarness.getObjectDetailLabels()
const objectDetailValues = await pageHeaderHarness.getObjectDetailValues()
@@ -228,7 +212,7 @@ describe('PageHeaderComponent', () => {
})
objectDetailValues.forEach(async (value, i) => {
- if(objectDetailsWithIcons[i].value) {
+ if (objectDetailsWithIcons[i].value) {
expect(await value.text()).toEqual(objectDetailsWithIcons[i].value)
}
})
@@ -248,8 +232,8 @@ describe('PageHeaderComponent', () => {
const menuItems = await pageHeaderHarness.getOverFlowMenuItems()
expect(menuItems.length).toBe(2)
- expect(await menuItems[0].getText()).toBe("My Test Overflow Action")
- expect(await menuItems[1].getText()).toBe("My Test Overflow Disabled Action")
+ expect(await menuItems[0].getText()).toBe('My Test Overflow Action')
+ expect(await menuItems[1].getText()).toBe('My Test Overflow Disabled Action')
})
it('should use provided action callback on overflow button click', async () => {
@@ -258,7 +242,7 @@ describe('PageHeaderComponent', () => {
component.actions = mockActions
const menuOverflowButtons = await pageHeaderHarness.getOverflowActionButtons()
-
+
expect(menuOverflowButtons).toBeTruthy()
expect(menuOverflowButtons.length).toBe(1)
await menuOverflowButtons[0].click()
@@ -266,7 +250,7 @@ describe('PageHeaderComponent', () => {
const menuItems = await pageHeaderHarness.getOverFlowMenuItems()
expect(menuItems.length).toBe(2)
const enabledActionElement = await menuItems[0].host()
- expect(await(enabledActionElement.hasClass('p-disabled'))).toBe(false)
+ expect(await enabledActionElement.hasClass('p-disabled')).toBe(false)
await enabledActionElement.click()
expect(console.log).toHaveBeenCalledTimes(1)
})
@@ -283,7 +267,7 @@ describe('PageHeaderComponent', () => {
const overFlowMenuItems = await pageHeaderHarness.getOverFlowMenuItems()
const disabledActionElement = overFlowMenuItems[1]
-
+
expect(overFlowMenuItems).toBeTruthy()
expect(overFlowMenuItems?.length).toBe(2)
expect(disabledActionElement).toBeTruthy()
diff --git a/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.stories.ts b/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.stories.ts
index 0db7d61c..d5a91c90 100644
--- a/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.stories.ts
+++ b/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.stories.ts
@@ -65,7 +65,7 @@ const demoActions: Action[] = [
},
title: 'Tooltip for Reload',
show: 'always',
- icon: 'pi pi-refresh',
+ icon: PrimeIcons.REFRESH,
},
{
label: 'Delete',
@@ -75,7 +75,7 @@ const demoActions: Action[] = [
},
title: 'Tooltip for Delete',
show: 'always',
- icon: 'pi pi-trash',
+ icon: PrimeIcons.TRASH,
},
{
label: 'Some action',
diff --git a/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.ts b/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.ts
index 39a5e681..e66a6a54 100644
--- a/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.ts
+++ b/libs/portal-integration-angular/src/lib/core/components/page-header/page-header.component.ts
@@ -17,6 +17,7 @@ import { BreadcrumbService } from '../../../services/breadcrumb.service'
import { TranslateService } from '@ngx-translate/core'
import { AppStateService } from '../../../services/app-state.service'
import { UserService } from '../../../services/user.service'
+import { PrimeIcon } from '../../utils/primeicon.utils'
/**
* Action definition.
@@ -47,7 +48,7 @@ export interface ObjectDetailItem {
label: string
value?: string
tooltip?: string
- icon?: PrimeIcons
+ icon?: PrimeIcon
labelPipe?: Type
valuePipe?: Type
valuePipeArgs?: string
@@ -125,8 +126,8 @@ export class PageHeaderComponent implements OnInit, OnChanges {
) {
this.breadcrumbs = breadcrumbs
this.home$ = concat(
- of({ icon: 'pi pi-home', routerLink: '/' }),
- this.appStateService.currentPortal$.pipe(map((portal) => ({ icon: 'pi pi-home', routerLink: portal.baseUrl })))
+ of({ icon: PrimeIcons.HOME, routerLink: '/' }),
+ this.appStateService.currentPortal$.pipe(map((portal) => ({ icon: PrimeIcons.HOME, routerLink: portal.baseUrl })))
)
}
ngOnChanges(changes: SimpleChanges): void {
diff --git a/libs/portal-integration-angular/src/lib/core/components/portal-header/header.component.html b/libs/portal-integration-angular/src/lib/core/components/portal-header/header.component.html
index 585bb609..6f839c5a 100644
--- a/libs/portal-integration-angular/src/lib/core/components/portal-header/header.component.html
+++ b/libs/portal-integration-angular/src/lib/core/components/portal-header/header.component.html
@@ -62,7 +62,7 @@
[pTooltip]="item.label || ''"
tooltipPosition="bottom"
>
-
+
diff --git a/libs/portal-integration-angular/src/lib/core/components/portal-header/header.component.ts b/libs/portal-integration-angular/src/lib/core/components/portal-header/header.component.ts
index 94a764fd..4fff49b1 100644
--- a/libs/portal-integration-angular/src/lib/core/components/portal-header/header.component.ts
+++ b/libs/portal-integration-angular/src/lib/core/components/portal-header/header.component.ts
@@ -14,6 +14,7 @@ import { ThemeService } from '../../../services/theme.service'
import { ImageLogoUrlUtils } from '../../utils/image-logo-url.utils'
import { UserService } from '../../../services/user.service'
import { AppStateService } from '../../../services/app-state.service'
+import { PrimeIcons } from 'primeng/api'
type MenuItemPerm = MenuItem & { permission: string }
@Component({
@@ -137,42 +138,42 @@ export class HeaderComponent implements OnInit {
this.moreMenuItems = [
{
command: (e) => this.onOpenFeedback(e),
- icon: 'comment',
+ icon: PrimeIcons.COMMENT,
label: 'Feedback',
disabled: this.feedbackDisabled,
permission: 'PORTAL_HEADER_GIVE_FEEDBACK#VIEW',
},
{
command: (e) => this.onAddToFavourites(e),
- icon: 'star',
+ icon: PrimeIcons.STAR,
label: 'Add to Favorites',
disabled: this.favoritesDisabled,
permission: 'PORTAL_HEADER_ADD_TO_MY_FAVORITES#VIEW',
},
{
command: (e) => this.onOpenSupportTicket(e),
- icon: 'ticket',
+ icon: PrimeIcons.TICKET,
label: 'Create Support Ticket',
disabled: this.supportTicketDisabled,
permission: 'PORTAL_HEADER_CREATE_SUPPORT_TICKET#VIEW',
},
{
command: (e) => this.onTopbarItemClick(e, 'search'),
- icon: 'search',
+ icon: PrimeIcons.SEARCH,
label: 'Search',
disabled: this.searchDisabled,
permission: 'PORTAL_HEADER_ENTERPRISE_SEARCH#VIEW',
},
{
command: (e) => this.onOpenHelpPage(e),
- icon: 'question-circle',
+ icon: PrimeIcons.QUESTION_CIRCLE,
label: 'Show Help for this article',
disabled: this.helpDisabled,
permission: 'PORTAL_HEADER_HELP#VIEW',
},
{
command: (e) => this.onOpenHelpPageEditor(e),
- icon: 'pencil',
+ icon: PrimeIcons.PENCIL,
label: 'Edit Help for this article',
disabled: this.helpEditorDisabled,
permission: 'PORTAL_HEADER_HELP_ITEM_EDITOR#VIEW',
diff --git a/libs/portal-integration-angular/src/lib/core/components/search-config/search-config.component.spec.ts b/libs/portal-integration-angular/src/lib/core/components/search-config/search-config.component.spec.ts
index b4ebfa1e..55df9b2a 100644
--- a/libs/portal-integration-angular/src/lib/core/components/search-config/search-config.component.spec.ts
+++ b/libs/portal-integration-angular/src/lib/core/components/search-config/search-config.component.spec.ts
@@ -34,16 +34,16 @@ describe('SearchConfigComponent', () => {
{
id: '01',
name: 'Simple search config',
- version: 1,
- readonly: true,
+ fieldListVersion: 1,
+ isReadonly: true,
isAdvanced: true,
values: searchConfigurations[0],
},
{
id: '02',
name: 'Adapted search config',
- version: 1,
- readonly: true,
+ fieldListVersion: 1,
+ isReadonly: true,
isAdvanced: true,
values: searchConfigurations[1],
},
diff --git a/libs/portal-integration-angular/src/lib/core/components/search-header/search-header.component.html b/libs/portal-integration-angular/src/lib/core/components/search-header/search-header.component.html
index 4da81cf2..31eacc6e 100644
--- a/libs/portal-integration-angular/src/lib/core/components/search-header/search-header.component.html
+++ b/libs/portal-integration-angular/src/lib/core/components/search-header/search-header.component.html
@@ -1,5 +1,6 @@
diff --git a/libs/portal-integration-angular/src/lib/core/components/search-header/search-header.component.ts b/libs/portal-integration-angular/src/lib/core/components/search-header/search-header.component.ts
index 313b40ac..61f11311 100644
--- a/libs/portal-integration-angular/src/lib/core/components/search-header/search-header.component.ts
+++ b/libs/portal-integration-angular/src/lib/core/components/search-header/search-header.component.ts
@@ -26,6 +26,7 @@ import { SearchConfig } from '../../../model/search-config'
export class SearchHeaderComponent implements AfterViewInit {
@Input() searchConfigs: SearchConfig[] | undefined
@Input() headline = ''
+ @Input() subheader: string | undefined
@Input() viewMode: 'basic' | 'advanced' = 'basic'
@Input() manualBreadcrumbs = false
_actions: Action[] = []
diff --git a/libs/portal-integration-angular/src/lib/core/portal-core.module.ts b/libs/portal-integration-angular/src/lib/core/portal-core.module.ts
index 393b6a49..059227d8 100644
--- a/libs/portal-integration-angular/src/lib/core/portal-core.module.ts
+++ b/libs/portal-integration-angular/src/lib/core/portal-core.module.ts
@@ -87,6 +87,7 @@ import { createTranslateLoader } from './utils/create-translate-loader.utils'
import { MessageService } from 'primeng/api'
import { TranslationCacheService } from '../services/translation-cache.service'
import { CreateOrEditSearchConfigDialogComponent } from './components/create-or-edit-search-config-dialog/create-or-edit-search-config-dialog.component'
+import { LifecycleComponent } from './components/lifecycle/lifecycle.component'
export class PortalMissingTranslationHandler implements MissingTranslationHandler {
handle(params: MissingTranslationHandlerParams) {
@@ -169,6 +170,7 @@ export class PortalMissingTranslationHandler implements MissingTranslationHandle
OcxContentContainerComponent,
SearchConfigComponent,
CreateOrEditSearchConfigDialogComponent,
+ LifecycleComponent,
],
providers: [
{
@@ -240,6 +242,7 @@ export class PortalMissingTranslationHandler implements MissingTranslationHandle
OcxContentContainerComponent,
SearchConfigComponent,
CreateOrEditSearchConfigDialogComponent,
+ LifecycleComponent
],
schemas: [CUSTOM_ELEMENTS_SCHEMA],
entryComponents: [ColumnTogglerComponent],
diff --git a/libs/portal-integration-angular/src/lib/core/primeng.module.ts b/libs/portal-integration-angular/src/lib/core/primeng.module.ts
index ec99f0a7..3983fe84 100644
--- a/libs/portal-integration-angular/src/lib/core/primeng.module.ts
+++ b/libs/portal-integration-angular/src/lib/core/primeng.module.ts
@@ -23,6 +23,7 @@ import { InputSwitchModule } from 'primeng/inputswitch'
import { DataViewModule } from 'primeng/dataview'
import { ChartModule } from 'primeng/chart'
import { CheckboxModule } from 'primeng/checkbox'
+import { TimelineModule } from 'primeng/timeline'
@NgModule({
imports: [
@@ -51,6 +52,7 @@ import { CheckboxModule } from 'primeng/checkbox'
ChartModule,
MessageModule,
CheckboxModule,
+ TimelineModule,
],
exports: [
BadgeModule,
@@ -78,6 +80,7 @@ import { CheckboxModule } from 'primeng/checkbox'
ChartModule,
MessageModule,
CheckboxModule,
+ TimelineModule,
],
})
export class PrimeNgModule {}
diff --git a/libs/portal-integration-angular/src/lib/core/utils/primeicon.utils.ts b/libs/portal-integration-angular/src/lib/core/utils/primeicon.utils.ts
new file mode 100644
index 00000000..f8fa2c41
--- /dev/null
+++ b/libs/portal-integration-angular/src/lib/core/utils/primeicon.utils.ts
@@ -0,0 +1,5 @@
+import { PrimeIcons } from 'primeng/api'
+/**
+ * @example let myIcon : PrimeIcon = PrimeIcons.myIcon
+ */
+export type PrimeIcon = (typeof PrimeIcons)[keyof Omit]
diff --git a/libs/portal-integration-angular/src/lib/model/button-dialog.ts b/libs/portal-integration-angular/src/lib/model/button-dialog.ts
index 9abb4994..2e5edaae 100644
--- a/libs/portal-integration-angular/src/lib/model/button-dialog.ts
+++ b/libs/portal-integration-angular/src/lib/model/button-dialog.ts
@@ -1,4 +1,5 @@
import { Type } from '@angular/core'
+import { PrimeIcon } from '../core/utils/primeicon.utils'
/**
* Object describing details for button rendering containing key for translation, optional icon and optional parameters for translation
@@ -21,7 +22,7 @@ import { Type } from '@angular/core'
*/
export interface ButtonDialogButtonDetails {
key: string
- icon?: string
+ icon?: PrimeIcon
parameters?: Record
}
diff --git a/libs/portal-integration-angular/src/lib/model/search-config.ts b/libs/portal-integration-angular/src/lib/model/search-config.ts
index a88a91a5..95c35bb3 100644
--- a/libs/portal-integration-angular/src/lib/model/search-config.ts
+++ b/libs/portal-integration-angular/src/lib/model/search-config.ts
@@ -2,8 +2,8 @@ export type SearchConfigPrimitive = string | number | bigint | boolean | Date |
export interface SearchConfig {
id: string
name: string
- version: number
- readonly: boolean
+ fieldListVersion: number
+ isReadonly: boolean
isAdvanced: boolean
values: Record
}
diff --git a/libs/portal-integration-angular/src/lib/services/portal-dialog.service.spec.ts b/libs/portal-integration-angular/src/lib/services/portal-dialog.service.spec.ts
index 3df6cd78..1831233f 100644
--- a/libs/portal-integration-angular/src/lib/services/portal-dialog.service.spec.ts
+++ b/libs/portal-integration-angular/src/lib/services/portal-dialog.service.spec.ts
@@ -20,6 +20,7 @@ import {
PortalDialogService,
} from './portal-dialog.service'
import { DivHarness, InputHarness, ButtonDialogHarness } from '../../../testing/index'
+import { PrimeIcons } from 'primeng/api'
@Component({
template: `BaseTestComponent
`,
@@ -336,33 +337,33 @@ describe('PortalDialogService', () => {
fixture.componentInstance.show(
'title',
'message',
- { key: 'BUTTON', icon: 'pi pi-times' },
- { key: 'BUTTON', icon: 'pi pi-trash' }
+ { key: 'BUTTON', icon: PrimeIcons.TIMES },
+ { key: 'BUTTON', icon: PrimeIcons.TRASH }
)
const dialogHarness = await rootLoader.getHarness(ButtonDialogHarness)
const primaryButtonLabel = await dialogHarness.getPrimaryButtonLabel()
const primaryButtonIcon = await dialogHarness.getPrimaryButtonIcon()
expect(primaryButtonLabel).toBe(translations['BUTTON'])
- expect(primaryButtonIcon).toBe('pi pi-times')
+ expect(primaryButtonIcon).toBe(PrimeIcons.TIMES)
const secondaryButtonLabel = await dialogHarness.getSecondaryButtonLabel()
const secondaryButtonIcon = await dialogHarness.getSecondaryButtonIcon()
expect(secondaryButtonLabel).toBe(translations['BUTTON'])
- expect(secondaryButtonIcon).toBe('pi pi-trash')
+ expect(secondaryButtonIcon).toBe(PrimeIcons.TRASH)
})
it('should display dialog with message and icon if DialogMessage provided as string and icon', async () => {
jest.spyOn(pDialogService, 'open')
- fixture.componentInstance.show('title', { message: 'MESSAGE', icon: 'pi pi-times' }, 'button1', 'button2')
+ fixture.componentInstance.show('title', { message: 'MESSAGE', icon: PrimeIcons.TIMES }, 'button1', 'button2')
const dialogHarness = await rootLoader.getHarness(ButtonDialogHarness)
const dialogMessageContentHarness = await dialogHarness.getDialogMessageContent()
const message = await dialogMessageContentHarness?.getMessageContent()
expect(message).toEqual(translations['MESSAGE'])
const icon = await dialogMessageContentHarness?.getIconValue()
- expect(icon).toContain('pi pi-times')
+ expect(icon).toContain(PrimeIcons.TIMES)
})
it('should display dialog with message and icon if DialogMessage provided as TranslationKey and icon', async () => {
@@ -370,7 +371,7 @@ describe('PortalDialogService', () => {
fixture.componentInstance.show(
'title',
- { message: { key: 'MESSAGE_PARAM', parameters: { val: 'dialogMessageParam' } }, icon: 'pi pi-times' },
+ { message: { key: 'MESSAGE_PARAM', parameters: { val: 'dialogMessageParam' } }, icon: PrimeIcons.TIMES },
'button1',
'button2'
)
@@ -380,7 +381,7 @@ describe('PortalDialogService', () => {
const message = await dialogMessageContentHarness?.getMessageContent()
expect(message).toEqual('myMessage dialogMessageParam')
const icon = await dialogMessageContentHarness?.getIconValue()
- expect(icon).toContain('pi pi-times')
+ expect(icon).toContain(PrimeIcons.TIMES)
})
it('should display dialog with custom component if provided', async () => {
diff --git a/libs/portal-integration-angular/src/lib/services/portal-dialog.service.ts b/libs/portal-integration-angular/src/lib/services/portal-dialog.service.ts
index 78fd25f1..86c87b61 100644
--- a/libs/portal-integration-angular/src/lib/services/portal-dialog.service.ts
+++ b/libs/portal-integration-angular/src/lib/services/portal-dialog.service.ts
@@ -6,6 +6,7 @@ import { DialogService, DynamicDialogConfig, DynamicDialogRef } from 'primeng/dy
import { ButtonDialogComponent } from '../core/components/button-dialog/button-dialog.component'
import { ButtonDialogButtonDetails, ButtonDialogData } from '../model/button-dialog'
import { DialogMessageContentComponent } from '../core/components/button-dialog/dialog-message-content/dialog-message-content.component'
+import { PrimeIcon } from '../core/utils/primeicon.utils'
/**
* Object containing key for translation with parameters object for translation
@@ -61,7 +62,7 @@ type TranslationKey = string | TranslationKeyWithParameters
* }
* ```
*/
-type DialogMessage = { message: TranslationKey; icon: string }
+type DialogMessage = { message: TranslationKey; icon: PrimeIcon }
/**
* Implement via component class to be displayed by {@link PortalDialogService.openDialog}
diff --git a/libs/portal-integration-angular/testing/data-layout-selection.harness.ts b/libs/portal-integration-angular/testing/data-layout-selection.harness.ts
index 64833aa9..3e7da442 100644
--- a/libs/portal-integration-angular/testing/data-layout-selection.harness.ts
+++ b/libs/portal-integration-angular/testing/data-layout-selection.harness.ts
@@ -1,5 +1,7 @@
import { ContentContainerComponentHarness, TestElement } from '@angular/cdk/testing'
import { PSelectButtonHarness } from './primeng/p-selectButton.harness'
+import { PrimeIcons } from 'primeng/api'
+import { PrimeIcon } from './utils/primeicon.utils'
export class DataLayoutSelectionHarness extends ContentContainerComponentHarness {
static hostSelector = 'ocx-data-layout-selection'
@@ -9,15 +11,15 @@ export class DataLayoutSelectionHarness extends ContentContainerComponentHarness
}
async getListLayoutSelectionButton() {
- return await this.isDesiredButton(await this.getAllSelectionButtons(), 'pi pi-list')
+ return await this.isDesiredButton(await this.getAllSelectionButtons(), PrimeIcons.LIST)
}
async getGridLayoutSelectionButton() {
- return await this.isDesiredButton(await this.getAllSelectionButtons(), 'pi pi-th-large')
+ return await this.isDesiredButton(await this.getAllSelectionButtons(), PrimeIcons.TH_LARGE)
}
async getTableLayoutSelectionButton() {
- return await this.isDesiredButton(await this.getAllSelectionButtons(), 'pi pi-table')
+ return await this.isDesiredButton(await this.getAllSelectionButtons(), PrimeIcons.TABLE)
}
async getCurrentLayout() {
@@ -28,7 +30,7 @@ export class DataLayoutSelectionHarness extends ContentContainerComponentHarness
await (await this.getListLayoutSelectionButton())?.click()
}
- private async isDesiredButton(value: TestElement[], icon: string) {
+ private async isDesiredButton(value: TestElement[], icon: PrimeIcon) {
for (let index = 0; index < value.length; index++) {
if ((await value[index].getAttribute('aria-labelledby')) === icon) {
return value[index]
diff --git a/libs/portal-integration-angular/testing/index.ts b/libs/portal-integration-angular/testing/index.ts
index d2744661..4dc030a1 100644
--- a/libs/portal-integration-angular/testing/index.ts
+++ b/libs/portal-integration-angular/testing/index.ts
@@ -35,6 +35,9 @@ export * from './span.harness'
export * from './page-header.harness'
export * from './p-tableCheckbox.harness'
export * from './create-or-edit-search-config-dialog.harness'
+export * from './lifecycle.harness'
+
+export * from './utils/primeicon.utils'
export * from '@angular/cdk/testing'
export * from '@angular/cdk/testing/testbed'
diff --git a/libs/portal-integration-angular/testing/lifecycle.harness.ts b/libs/portal-integration-angular/testing/lifecycle.harness.ts
new file mode 100644
index 00000000..4365e479
--- /dev/null
+++ b/libs/portal-integration-angular/testing/lifecycle.harness.ts
@@ -0,0 +1,8 @@
+import { ContentContainerComponentHarness } from "@angular/cdk/testing"
+
+export class LifecycleHarness extends ContentContainerComponentHarness {
+ static hostSelector = 'ocx-lifecycle'
+
+ getSteps = this.locatorForAll('.p-timeline-event-content .card')
+ getHighlightedSteps = this.locatorForAll('.p-timeline-event-content .card.bg-primary')
+}
\ No newline at end of file
diff --git a/libs/portal-integration-angular/testing/utils/primeicon.utils.ts b/libs/portal-integration-angular/testing/utils/primeicon.utils.ts
new file mode 100644
index 00000000..6386a7d2
--- /dev/null
+++ b/libs/portal-integration-angular/testing/utils/primeicon.utils.ts
@@ -0,0 +1,3 @@
+import { PrimeIcons } from 'primeng/api'
+
+export type PrimeIcon = (typeof PrimeIcons)[keyof Omit]
diff --git a/libs/portal-layout-styles/package.json b/libs/portal-layout-styles/package.json
index 46676cce..d5d0f5e1 100644
--- a/libs/portal-layout-styles/package.json
+++ b/libs/portal-layout-styles/package.json
@@ -1,6 +1,6 @@
{
"name": "@onecx/portal-layout-styles",
- "version": "4.8.0",
+ "version": "4.9.0",
"peerDependencies": {
"tslib": "^2.5.0"
},
diff --git a/package-lock.json b/package-lock.json
index 337af6ef..2e0e611a 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -1,12 +1,12 @@
{
"name": "@onecx/onecx-portal-ui-libs",
- "version": "4.5.0",
+ "version": "4.8.0",
"lockfileVersion": 2,
"requires": true,
"packages": {
"": {
"name": "@onecx/onecx-portal-ui-libs",
- "version": "4.5.0",
+ "version": "4.8.0",
"hasInstallScript": true,
"license": "Apache-2.0",
"dependencies": {
diff --git a/package.json b/package.json
index 72fa6f79..412efc60 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "@onecx/onecx-portal-ui-libs",
- "version": "4.8.0",
+ "version": "4.9.0",
"license": "Apache-2.0",
"scripts": {
"sass": "npx sass libs/portal-integration-angular/assets/styles.scss libs/portal-integration-angular/assets/output.css",