Skip to content

Commit

Permalink
Merge branch 'calendar-css-classes' of https://github.com/IgniteUI/ig…
Browse files Browse the repository at this point in the history
…niteui-angular into calendar-css-classes
  • Loading branch information
simeonoff committed Nov 23, 2018
2 parents ea002f5 + f357e52 commit aa80aed
Show file tree
Hide file tree
Showing 4 changed files with 82 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import { DateRangeDescriptor, DateRangeType } from '../core/dates/dateRange';

import { configureTestSuite } from '../test-utils/configure-suite';

fdescribe('IgxCalendar', () => {
describe('IgxCalendar', () => {
configureTestSuite();
beforeEach(() => {
TestBed.configureTestingModule({
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
[(ngModel)]="value"
[type]="type"
[readonly]="isUnaryCondition"
(click)="onInputClick()"
(keydown)="onInputKeyDown($event)"/>
<igx-suffix *ngIf="input.value.length > 0" (keydown)="onClearKeyDown($event)" (click)="clearInput()" tabindex="0">
<igx-icon>clear</igx-icon>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -216,6 +216,10 @@ export class IgxGridFilteringRowComponent implements AfterViewInit, OnDestroy {
get placeholder(): string {
if (this.expression.condition && this.expression.condition.isUnary) {
return this.filteringService.getChipLabel(this.expression);
} else if (this.column.dataType === DataType.Date) {
return 'Pick up date';
} else if (this.column.dataType === DataType.Boolean) {
return 'All';
} else {
return 'Add filter value';
}
Expand All @@ -240,6 +244,19 @@ export class IgxGridFilteringRowComponent implements AfterViewInit, OnDestroy {
* Event handler for keydown on the input.
*/
public onInputKeyDown(event: KeyboardEvent) {
if (this.column.dataType === DataType.Boolean) {
if ((event.key === KEYS.ENTER || event.key === KEYS.SPACE || event.key === KEYS.SPACE_IE) &&
this.dropDownConditions.collapsed) {
this.toggleConditionsDropDown(this.inputGroupPrefix.nativeElement);
event.stopPropagation();
return;
} else if ((event.key === KEYS.ESCAPE || event.key === KEYS.ESCAPE_IE) && !this.dropDownConditions.collapsed) {
this.toggleConditionsDropDown(this.inputGroupPrefix.nativeElement);
event.stopPropagation();
return;
}
}

if (event.key === KEYS.ENTER) {
this.chipsArea.chipsList.filter(chip => chip.selected = false);

Expand Down Expand Up @@ -268,6 +285,15 @@ export class IgxGridFilteringRowComponent implements AfterViewInit, OnDestroy {
event.stopPropagation();
}

/**
* Event handler for input click event.
*/
public onInputClick() {
if (this.column.dataType === DataType.Boolean) {
this.toggleConditionsDropDown(this.inputGroupPrefix.nativeElement);
}
}

/**
* Event handler for datepicker's close.
*/
Expand Down
56 changes: 54 additions & 2 deletions projects/igniteui-angular/src/lib/grids/grid/grid.sorting.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,8 @@ import { IgxGridModule } from './index';
import { GridTemplateStrings, ColumnDefinitions } from '../../test-utils/template-strings.spec';
import { BasicGridComponent } from '../../test-utils/grid-base-components.spec';
import { SampleTestData } from '../../test-utils/sample-test-data.spec';
import { DefaultSortingStrategy } from '../../data-operations/sorting-strategy';
import { DefaultSortingStrategy, ISortingStrategy } from '../../data-operations/sorting-strategy';
import { IgxGridCellComponent } from '../cell.component';
import { configureTestSuite } from '../../test-utils/configure-suite';

const SORTING_ICON_NONE_CONTENT = 'none';
Expand All @@ -22,7 +23,8 @@ describe('IgxGrid - Grid Sorting', () => {

TestBed.configureTestingModule({
declarations: [
GridDeclaredColumnsComponent
GridDeclaredColumnsComponent,
SortByParityComponent
],
imports: [IgxGridModule.forRoot()]
})
Expand Down Expand Up @@ -315,6 +317,30 @@ describe('IgxGrid - Grid Sorting', () => {
fixture.detectChanges();
expect(sortingIcon.nativeElement.textContent.trim()).toEqual(SORTING_ICON_NONE_CONTENT);
});

it(`Should allow sorting using a custom Sorting Strategy.`, () => {
fixture = TestBed.createComponent(SortByParityComponent);
grid = fixture.componentInstance.grid;
fixture.componentInstance.data.push(
{ ID: 8, Name: 'Brad', LastName: 'Walker', Region: 'DD' },
{ ID: 9, Name: 'Mary', LastName: 'Smith', Region: 'OC' },
{ ID: 10, Name: 'Brad', LastName: 'Smith', Region: 'BD' },
);
fixture.detectChanges();
grid.sort({
fieldName: 'ID',
dir: SortingDirection.Desc,
ignoreCase: false,
strategy: new SortByParityComponent()
});
fixture.detectChanges();
const oddHalf: IgxGridCellComponent[] = grid.getColumnByName('ID').cells.slice(0, 5);
const evenHalf: IgxGridCellComponent[] = grid.getColumnByName('ID').cells.slice(5);
const isFirstHalfOdd: boolean = oddHalf.every(cell => cell.value % 2 === 1);
const isSecondHalfEven: boolean = evenHalf.every(cell => cell.value % 2 === 0);
expect(isFirstHalfOdd).toEqual(true);
expect(isSecondHalfEven).toEqual(true);
});
});

@Component({
Expand All @@ -333,6 +359,32 @@ export class GridDeclaredColumnsComponent extends BasicGridComponent {
public width = '800px';
}

@Component({
template: GridTemplateStrings.declareGrid(
'',
'',
ColumnDefinitions.idFirstLastNameSortable)
})
export class SortByParityComponent extends GridDeclaredColumnsComponent implements ISortingStrategy {
public sort(data: any[], fieldName: string, dir: SortingDirection) {
const key = fieldName;
const reverse = (dir === SortingDirection.Desc ? -1 : 1);
const cmpFunc = (obj1, obj2) => {
return this.compareObjects(obj1, obj2, key, reverse);
};
return data.sort(cmpFunc);
}
protected sortByParity(a: any, b: any) {
return a % 2 === 0 ? -1 : b % 2 === 0 ? 1 : 0;
}
protected compareObjects(obj1: object, obj2: object, key: string, reverse: number) {
const a = obj1[key];
const b = obj2[key];
return reverse * this.sortByParity(a, b);
}
}


function getCurrentCellFromGrid(grid, row, cell) {
const gridRow = grid.rowList.toArray()[row];
const gridCell = gridRow.cells.toArray()[cell];
Expand Down

0 comments on commit aa80aed

Please sign in to comment.