Skip to content
New issue

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

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

Already on GitHub? Sign in to your account

feat: search config slot in search header and column group slot in interactive-data-view #369

Merged
merged 61 commits into from
Oct 7, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
61 commits
Select commit Hold shift + click to select a range
334e13e
feat: slot passes down inputs and outputs
markuczy Jul 31, 2024
a725b2b
feat: update remote components inputs and outputs
markuczy Aug 1, 2024
fb97c3f
feat: change type of emitters
markuczy Aug 1, 2024
3ba9a16
feat: slot used in search header
markuczy Aug 5, 2024
22e7760
feat: correct prop passing not optimised
markuczy Aug 5, 2024
61f1a67
Merge branch 'main' into feat/search-config-remote-component
markuczy Aug 14, 2024
82e9f28
feat: emitter column type change
markuczy Aug 16, 2024
63fc40c
Merge branch 'main' into feat/search-config-remote-component
markuczy Aug 20, 2024
c5852a5
feat: column group slot + search-config slot adjustment
markuczy Aug 28, 2024
38c0e8d
fix: removed redundant sub
markuczy Aug 28, 2024
d5ebf3a
feat: viewMode passing added
markuczy Aug 30, 2024
255e467
feat: added search config topic
markuczy Sep 4, 2024
d831797
feat: formgroup viewchild prep
markuczy Sep 4, 2024
ff606ae
Merge branch 'main' into feat/search-config-remote-component
markuczy Sep 4, 2024
fa273cd
feat: prop passing adjustments
markuczy Sep 4, 2024
627bf13
feat: default column group and bug fixes
markuczy Sep 4, 2024
930cbc5
refactor: comment out unused code
markuczy Sep 4, 2024
ddc8322
feat: removed pageName and search header comment
markuczy Sep 5, 2024
d535591
feat: disable search button when form is invalid
markuczy Sep 5, 2024
d89509e
refactor: removed not needed log
markuczy Sep 5, 2024
2a3890a
feat: removed topic
markuczy Sep 5, 2024
9bd5b1c
feat: lowered debounce time
markuczy Sep 10, 2024
d866fd3
feat: allow undefined in config selection changed
markuczy Sep 11, 2024
b603fb1
feat: search header passes visible values only
markuczy Sep 11, 2024
783ff6b
feat: added skeletons for slots
markuczy Sep 12, 2024
90939b6
feat: display search config slot only if client observes config changes
markuczy Sep 13, 2024
b06e4a3
feat: tests for search header and interactive data view
markuczy Sep 16, 2024
edd0b29
feat: search header state changed on selected search config
markuczy Sep 16, 2024
0f99fba
fix: fix interactive data view tests
markuczy Sep 16, 2024
7fafc82
Merge branch 'main' into feat/search-config-remote-component
markuczy Sep 16, 2024
b0e9609
refactor: lint
markuczy Sep 16, 2024
883034f
fix: fix data table reload
markuczy Sep 17, 2024
8894131
feat: interactive data view adjustments to correctly choose columns
markuczy Sep 17, 2024
36cb153
feat: add layout as input for search config slot
markuczy Sep 17, 2024
f755c89
feat: correct reinit of column group selection remtoe component
markuczy Sep 18, 2024
bf2cb7a
refactor: lint
markuczy Sep 18, 2024
665f485
Merge branch 'main' into feat/search-config-remote-component
markuczy Sep 18, 2024
3e56ad8
feat: permission directive adjusted and permissions for slot displayi…
markuczy Sep 19, 2024
8b1dbe3
Merge branch 'main' into feat/search-config-remote-component
markuczy Sep 19, 2024
fb210e8
feat: search header and interactive data view params change, guard fo…
markuczy Sep 19, 2024
65e19b4
fix: tests fixed
markuczy Sep 19, 2024
def86c3
feat: saving only search config name in search header state
markuczy Sep 24, 2024
b9bda6a
feat: provide slot service token in module instead of component
markuczy Sep 24, 2024
0d52509
feat: slot error on slot service
markuczy Sep 24, 2024
50470b8
fix: lint
markuczy Sep 24, 2024
8eb6a35
Merge branch 'main' into feat/search-config-remote-component
markuczy Sep 24, 2024
6d314af
fix: lint
markuczy Sep 24, 2024
c587642
Merge branch 'main' into feat/search-config-remote-component
markuczy Sep 30, 2024
b983583
feat: remote translate loader with mfe translations
markuczy Oct 1, 2024
6a8178b
feat: SLOT_SERVICE provided in remote components module
markuczy Oct 1, 2024
674a88b
fix: group selection change async
markuczy Oct 1, 2024
9e49eaf
feat: pageName default and search config selection change emitters split
markuczy Oct 1, 2024
6f514ea
fix: async behavior in layout change sub
markuczy Oct 1, 2024
dea8ad0
refactor: changed name of translate loader
markuczy Oct 1, 2024
139cca8
feat: dropdown harness update
markuczy Oct 1, 2024
e4169a0
feat: slot-service mock in angular remote components
markuczy Oct 1, 2024
3c4af41
feat: emitter now use types
markuczy Oct 1, 2024
f4a61f7
fix: fixed slot hiding mechanism
markuczy Oct 1, 2024
fa4f502
feat: search-config cleanup
markuczy Oct 2, 2024
3d1b741
fix: lint fixes
markuczy Oct 2, 2024
df79cb1
Merge branch 'main' into feat/search-config-remote-component
markuczy Oct 7, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 1 addition & 3 deletions libs/angular-accelerator/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,14 +17,12 @@ export * from './lib/components/diagram/diagram.component'
export * from './lib/components/group-by-count-diagram/group-by-count-diagram.component'
export * from './lib/components/interactive-data-view/interactive-data-view.component'
export * from './lib/components/page-header/page-header.component'
export * from './lib/components/search-config/search-config.component'
export * from './lib/components/search-header/search-header.component'
export * from './lib/components/data-loading-error/data-loading-error.component'

// services
export * from './lib/services/breadcrumb.service'
export * from './lib/services/translation-cache.service'
export * from './lib/services/app-config-service'

// pipes
export * from './lib/pipes/dynamic.pipe'
Expand All @@ -40,7 +38,6 @@ export * from './lib/model/data-table-column.model'
export * from './lib/model/diagram-column'
// export * from './lib/model/diagram-data'
export * from './lib/model/diagram-type'
export * from './lib/model/search-config-info'

// core
export * from './lib/angular-accelerator.module'
Expand All @@ -59,6 +56,7 @@ export * from './lib/utils/dateutils'
export * from './lib/utils/objectutils'
export * from './lib/utils/primeicon.utils'
export * from './lib/utils/translate.combined.loader'
export * from './lib/utils/create-remote-component-and-mfe-translate-loader.utils'
export * from './lib/utils/create-remote-component-translate-loader.utils'
export * from './lib/utils/enum-to-dropdown-options.utils'
export * from './lib/utils/criteria.utils'
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,8 @@ import { FormsModule, ReactiveFormsModule } from '@angular/forms'
import { RouterModule } from '@angular/router'
import { MissingTranslationHandler, MissingTranslationHandlerParams, TranslateModule } from '@ngx-translate/core'

import { UserService } from '@onecx/angular-integration-interface'
import { AppConfigService, UserService } from '@onecx/angular-integration-interface'
import { AngularRemoteComponentsModule } from '@onecx/angular-remote-components'

import { firstValueFrom, skip } from 'rxjs'
import { AngularAcceleratorPrimeNgModule } from './angular-accelerator-primeng.module'
Expand All @@ -20,7 +21,6 @@ import { GroupByCountDiagramComponent } from './components/group-by-count-diagra
import { InteractiveDataViewComponent } from './components/interactive-data-view/interactive-data-view.component'
import { PageHeaderComponent } from './components/page-header/page-header.component'
import { DataLoadingErrorComponent } from './components/data-loading-error/data-loading-error.component'
import { SearchConfigComponent } from './components/search-config/search-config.component'
import { SearchHeaderComponent } from './components/search-header/search-header.component'
import { AdvancedDirective } from './directives/advanced.directive'
import { IfBreakpointDirective } from './directives/if-breakpoint.directive'
Expand All @@ -29,7 +29,6 @@ import { SrcDirective } from './directives/src.directive'
import { TooltipOnOverflowDirective } from './directives/tooltipOnOverflow.directive'
import { DynamicPipe } from './pipes/dynamic.pipe'
import { OcxTimeAgoPipe } from './pipes/ocxtimeago.pipe'
import { AppConfigService } from './services/app-config-service'
import { DynamicLocaleId } from './utils/dynamic-locale-id'

export class AngularAcceleratorMissingTranslationHandler implements MissingTranslationHandler {
Expand All @@ -49,6 +48,7 @@ function appInitializer(userService: UserService) {
imports: [
CommonModule,
AngularAcceleratorPrimeNgModule,
AngularRemoteComponentsModule,
TranslateModule,
FormsModule,
RouterModule,
Expand All @@ -63,7 +63,6 @@ function appInitializer(userService: UserService) {
DataTableComponent,
DataViewComponent,
InteractiveDataViewComponent,
SearchConfigComponent,
PageHeaderComponent,
DynamicPipe,
SearchHeaderComponent,
Expand Down Expand Up @@ -96,14 +95,14 @@ function appInitializer(userService: UserService) {
AppConfigService,
],
exports: [
AngularRemoteComponentsModule,
ColumnGroupSelectionComponent,
CustomGroupColumnSelectorComponent,
DataLayoutSelectionComponent,
DataListGridComponent,
DataTableComponent,
DataViewComponent,
InteractiveDataViewComponent,
SearchConfigComponent,
PageHeaderComponent,
SearchHeaderComponent,
DiagramComponent,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,18 +23,32 @@
></ocx-data-list-grid-sorting>
</div>

<div *ngIf="layout === 'table'" class="flex flex-wrap justify-content-between align-items-center gap-2">
<ocx-column-group-selection
[selectedGroupKey]="selectedGroupKey"
[columns]="columns"
[defaultGroupKey]="defaultGroupKey"
[customGroupKey]="customGroupKey"
[placeholderKey]="groupSelectionNoGroupSelectedKey"
(groupSelectionChanged)="onColumnGroupSelectionChange($event)"
(componentStateChanged)="columnGroupSelectionComponentState$.next($event)"
></ocx-column-group-selection>
<div
[ngStyle]="layout !== 'table' ? {
'position': 'absolute'
} : {}"
class="flex flex-wrap justify-content-between align-items-center gap-2"
>
markuczy marked this conversation as resolved.
Show resolved Hide resolved
<ng-container *ngIf="isColumnGroupSelectionComponentDefined$ | async; else defaultColumnGroupSelectionComponent">
<ng-container *ngIf="displayedColumnKeys$ | async as displayedColumnKeys">
<ocx-slot
[ngStyle]="layout !== 'table' ? {'display' : 'none'} : {}"
*ocxIfPermission="searchConfigPermission; elseTemplate: defaultColumnGroupSelectionComponent"
name="{{columnGroupSlotName}}"
[inputs]="{ placeholderKey: groupSelectionNoGroupSelectedKey, defaultGroupKey: defaultGroupKey, customGroupKey: customGroupKey, columns: columns, selectedGroupKey: selectedGroupKey, layout: layout, displayedColumnsIds: displayedColumnKeys }"
[outputs]="{ groupSelectionChanged: groupSelectionChangedSlotEmitter }"
>
<ng-template #skeleton>
<div class="flex">
<p-skeleton width="18rem" height="3rem"></p-skeleton>
</div>
</ng-template>
</ocx-slot>
</ng-container>
</ng-container>

<ocx-custom-group-column-selector
*ngIf="layout === 'table'"
[columns]="columns"
[displayedColumns]="(displayedColumns$ | async) ?? []"
(columnSelectionChanged)="onColumnSelectionChange($event)"
Expand Down Expand Up @@ -118,6 +132,19 @@
>
</ocx-data-view>
</div>

<ng-template #defaultColumnGroupSelectionComponent>
<ocx-column-group-selection
[selectedGroupKey]="selectedGroupKey ?? defaultGroupKey"
[columns]="columns"
[defaultGroupKey]="defaultGroupKey"
[customGroupKey]="customGroupKey"
[placeholderKey]="groupSelectionNoGroupSelectedKey"
(groupSelectionChanged)="onColumnGroupSelectionChange($event)"
(componentStateChanged)="columnGroupSelectionComponentState$.next($event)"
></ocx-column-group-selection>
</ng-template>

<ng-template #stringTableCell let-rowObject="rowObject" let-column="column">
<ng-container
*ngIf="_stringTableCell"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,9 +38,13 @@ import {
DefaultGridItemHarness,
DefaultListItemHarness,
InteractiveDataViewHarness,
SlotHarness,
} from '../../../../testing'
import { DateUtils } from '../../utils/dateutils'
import { provideRouter } from '@angular/router'
import { SlotService } from '@onecx/angular-remote-components'
import { SlotServiceMock } from '@onecx/angular-remote-components/mocks'
import { IfPermissionDirective } from '../../directives/if-permission.directive'

describe('InteractiveDataViewComponent', () => {
const mutationObserverMock = jest.fn(function MutationObserver(callback) {
Expand All @@ -63,6 +67,7 @@ describe('InteractiveDataViewComponent', () => {
let deleteItemEvent: RowListGridData | undefined

let dateUtils: DateUtils
let slotService: SlotServiceMock

const mockData = [
{
Expand Down Expand Up @@ -229,6 +234,7 @@ describe('InteractiveDataViewComponent', () => {
DataViewComponent,
ColumnGroupSelectionComponent,
CustomGroupColumnSelectorComponent,
IfPermissionDirective,
],
imports: [
TranslateModule.forRoot(),
Expand All @@ -244,6 +250,10 @@ describe('InteractiveDataViewComponent', () => {
],
providers: [
{ provide: UserService, useClass: MockUserService },
{
provide: SlotService,
useClass: SlotServiceMock,
},
provideHttpClient(withInterceptorsFromDi()),
provideRouter([]),
provideAppStateServiceMock(),
Expand All @@ -256,6 +266,7 @@ describe('InteractiveDataViewComponent', () => {
component.editPermission = 'TEST_MGMT#TEST_EDIT'
component.deletePermission = 'TEST_MGMT#TEST_DELETE'
component.defaultGroupKey = 'PREDEFINED_GROUP.DEFAULT'
component.searchConfigPermission = 'PRODUCT#USE_SEARCHCONFIG'
component.viewItem.subscribe((event) => (viewItemEvent = event))
component.editItem.subscribe((event) => (editItemEvent = event))
component.deleteItem.subscribe((event) => (deleteItemEvent = event))
Expand All @@ -270,6 +281,7 @@ describe('InteractiveDataViewComponent', () => {
interactiveDataViewHarness = await TestbedHarnessEnvironment.harnessForFixture(fixture, InteractiveDataViewHarness)

dateUtils = TestBed.inject(DateUtils)
slotService = TestBed.inject(SlotService) as any as SlotServiceMock

viewItemEvent = undefined
editItemEvent = undefined
Expand All @@ -290,9 +302,26 @@ describe('InteractiveDataViewComponent', () => {
expect(dataLayoutSelection).toBeTruthy()
})

it('should load column-group-selection slot', async () => {
slotService.assignComponentToSlot('column-group-selection', component.columnGroupSlotName)
const userService = TestBed.inject(UserService)
jest.spyOn(userService, 'hasPermission').mockReturnValue(true)
fixture.detectChanges()

const slot = await loader.getHarness(SlotHarness)
expect(slot).toBeTruthy()
})

it('should load ColumnGroupSelectionDropdown', async () => {
const columnGroupSelectionDropdown = await loader.getHarness(ColumnGroupSelectionHarness)
expect(columnGroupSelectionDropdown).toBeTruthy()

slotService.assignComponentToSlot('column-group-selection', component.columnGroupSlotName)
const userService = TestBed.inject(UserService)
jest.spyOn(userService, 'hasPermission').mockReturnValue(false)

const columnGroupSelectionDropdownNoPermission = await loader.getHarness(ColumnGroupSelectionHarness)
expect(columnGroupSelectionDropdownNoPermission).toBeTruthy()
})

it('should load CustomGroupColumnSelector', async () => {
Expand Down Expand Up @@ -933,18 +962,18 @@ describe('InteractiveDataViewComponent', () => {
it('should move item up in picklist active columns list', async () => {
const spy = jest.spyOn(CustomGroupColumnSelectorComponent.prototype, 'onSaveClick')
const expectedHeaders = [
'COLUMN_HEADER_NAME.DESCRIPTION',
'COLUMN_HEADER_NAME.NAME',
'COLUMN_HEADER_NAME.DESCRIPTION',
'COLUMN_HEADER_NAME.STATUS',
'COLUMN_HEADER_NAME.RESPONSIBLE',
'Actions',
]
const expectedRowsData = [
['', 'some name', 'some status', 'someone responsible'],
['example description', 'example', 'status example', ''],
['', 'name 1', 'status name 1', ''],
['', 'name 2', 'status name 2', ''],
['', 'name 3', 'status name 3', ''],
['some name', '', 'some status', 'someone responsible'],
['example', 'example description', 'status example', ''],
['name 1', '', 'status name 1', ''],
['name 2', '', 'status name 2', ''],
['name 3', '', 'status name 3', ''],
]
await activeColumnsList[1].selectItem()
await sourceControlsButtons[0].click()
Expand All @@ -963,17 +992,17 @@ describe('InteractiveDataViewComponent', () => {
const spy = jest.spyOn(CustomGroupColumnSelectorComponent.prototype, 'onSaveClick')
const expectedHeaders = [
'COLUMN_HEADER_NAME.NAME',
'COLUMN_HEADER_NAME.STATUS',
'COLUMN_HEADER_NAME.DESCRIPTION',
'COLUMN_HEADER_NAME.STATUS',
'COLUMN_HEADER_NAME.RESPONSIBLE',
'Actions',
]
const expectedRowsData = [
['some name', 'some status', '', 'someone responsible'],
['example', 'status example', 'example description', ''],
['name 1', 'status name 1', '', ''],
['name 2', 'status name 2', '', ''],
['name 3', 'status name 3', '', ''],
['some name', '', 'some status', 'someone responsible'],
['example', 'example description', 'status example', ''],
['name 1', '', 'status name 1', ''],
['name 2', '', 'status name 2', ''],
['name 3', '', 'status name 3', ''],
]

await activeColumnsList[1].selectItem()
Expand Down Expand Up @@ -1698,4 +1727,26 @@ describe('InteractiveDataViewComponent', () => {
})
})
})

it('should react on group selection change event emit', () => {
const columnsChangeSpy = jest.spyOn(component.displayedColumnsChange, 'emit')
const columnKeysChangeSpy = jest.spyOn(component.displayedColumnKeysChange, 'emit')

component.groupSelectionChangedSlotEmitter.emit({
activeColumns: [
{
id: 'first-col',
} as any,
{
id: 'second-col',
} as any,
],
groupKey: 'my-search-config',
})

expect(component.displayedColumnKeys).toStrictEqual(['first-col', 'second-col'])
expect(component.selectedGroupKey).toBe('my-search-config')
expect(columnsChangeSpy).toHaveBeenCalled()
expect(columnKeysChangeSpy).toHaveBeenCalledWith(['first-col', 'second-col'])
})
})
Loading
Loading