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",