mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-24 17:32:15 +00:00
[ADF-5213] Metadata - select list filter (#5961)
* select filter input component * include theme * add filter input * show input conditionally * convert value to string for d:int type values * filter list options pipe * add components to module * convert int value to string * i18n * update tests * tests * update config * remove unneeded decorator * fix lint * update schema * remove filter pipe * provide a filtered list
This commit is contained in:
@@ -24,12 +24,13 @@ import { setupTestBed } from '../../../testing/setup-test-bed';
|
||||
import { CoreTestingModule } from '../../../testing/core.testing.module';
|
||||
import { of } from 'rxjs';
|
||||
import { TranslateModule } from '@ngx-translate/core';
|
||||
import { AppConfigService } from '../../../app-config/app-config.service';
|
||||
|
||||
describe('CardViewSelectItemComponent', () => {
|
||||
|
||||
let fixture: ComponentFixture<CardViewSelectItemComponent>;
|
||||
let component: CardViewSelectItemComponent;
|
||||
let overlayContainer: OverlayContainer;
|
||||
let appConfig: AppConfigService;
|
||||
const mockData = [{ key: 'one', label: 'One' }, { key: 'two', label: 'Two' }, { key: 'three', label: 'Three' }];
|
||||
const mockDefaultProps = {
|
||||
label: 'Select box label',
|
||||
@@ -50,6 +51,7 @@ describe('CardViewSelectItemComponent', () => {
|
||||
fixture = TestBed.createComponent(CardViewSelectItemComponent);
|
||||
component = fixture.componentInstance;
|
||||
overlayContainer = TestBed.inject(OverlayContainer);
|
||||
appConfig = TestBed.inject(AppConfigService);
|
||||
component.property = new CardViewSelectItemModel(mockDefaultProps);
|
||||
});
|
||||
|
||||
@@ -143,5 +145,80 @@ describe('CardViewSelectItemComponent', () => {
|
||||
const label = fixture.debugElement.query(By.css('[data-automation-class="select-box"] .mat-form-field-label'));
|
||||
expect(label).toBeNull();
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('Filter', () => {
|
||||
it('should render a list of filtered options', () => {
|
||||
appConfig.config['content-metadata'] = {
|
||||
selectFilterLimit: 0
|
||||
};
|
||||
let optionsElement: any[];
|
||||
component.property = new CardViewSelectItemModel({
|
||||
...mockDefaultProps,
|
||||
editable: true
|
||||
});
|
||||
component.editable = true;
|
||||
component.displayNoneOption = false;
|
||||
component.ngOnChanges();
|
||||
fixture.detectChanges();
|
||||
|
||||
const selectBox = fixture.debugElement.query(By.css('.mat-select-trigger'));
|
||||
selectBox.triggerEventHandler('click', {});
|
||||
|
||||
fixture.detectChanges();
|
||||
optionsElement = Array.from(overlayContainer.getContainerElement().querySelectorAll('mat-option'));
|
||||
expect(optionsElement.length).toBe(3);
|
||||
|
||||
const filterInput = fixture.debugElement.query(By.css('.adf-select-filter-input input'));
|
||||
filterInput.nativeElement.value = mockData[0].label;
|
||||
filterInput.nativeElement.dispatchEvent(new Event('input'));
|
||||
|
||||
fixture.detectChanges();
|
||||
optionsElement = Array.from(overlayContainer.getContainerElement().querySelectorAll('mat-option'));
|
||||
expect(optionsElement.length).toBe(1);
|
||||
expect(optionsElement[0].innerText).toEqual(mockData[0].label);
|
||||
});
|
||||
|
||||
it('should hide filter if options are less then limit', () => {
|
||||
appConfig.config['content-metadata'] = {
|
||||
selectFilterLimit: mockData.length + 1
|
||||
};
|
||||
component.property = new CardViewSelectItemModel({
|
||||
...mockDefaultProps,
|
||||
editable: true
|
||||
});
|
||||
component.editable = true;
|
||||
component.displayNoneOption = false;
|
||||
component.ngOnChanges();
|
||||
fixture.detectChanges();
|
||||
|
||||
const selectBox = fixture.debugElement.query(By.css('.mat-select-trigger'));
|
||||
selectBox.triggerEventHandler('click', {});
|
||||
fixture.detectChanges();
|
||||
|
||||
const filterInput = fixture.debugElement.query(By.css('.adf-select-filter-input'));
|
||||
expect(filterInput).toBe(null);
|
||||
});
|
||||
|
||||
it('should show filter if options are greater then limit', () => {
|
||||
appConfig.config['content-metadata'] = {
|
||||
selectFilterLimit: mockData.length - 1
|
||||
};
|
||||
component.property = new CardViewSelectItemModel({
|
||||
...mockDefaultProps,
|
||||
editable: true
|
||||
});
|
||||
component.editable = true;
|
||||
component.displayNoneOption = false;
|
||||
component.ngOnChanges();
|
||||
fixture.detectChanges();
|
||||
|
||||
const selectBox = fixture.debugElement.query(By.css('.mat-select-trigger'));
|
||||
selectBox.triggerEventHandler('click', {});
|
||||
fixture.detectChanges();
|
||||
|
||||
const filterInput = fixture.debugElement.query(By.css('.adf-select-filter-input'));
|
||||
expect(filterInput).not.toBe(null);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
Reference in New Issue
Block a user