Skip to content

Commit

Permalink
Merge branch '7.0.x' into rkolev/toolbar-template-7.0.x
Browse files Browse the repository at this point in the history
  • Loading branch information
rmkrmk authored Nov 28, 2018
2 parents c1e99eb + 57ed275 commit e6f5dd7
Show file tree
Hide file tree
Showing 17 changed files with 251 additions and 47 deletions.
58 changes: 51 additions & 7 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,20 +4,64 @@ All notable changes for each version of this project will be documented in this

## 7.0.0
- Updated package dependencies to Angular 7 ([#3000](https://github.com/IgniteUI/igniteui-angular/pull/3000))
- Themes: Add dark schemas and mixins (PR [#3025](https://github.com/IgniteUI/igniteui-angular/pull/3025))

## 6.2.2
- `igx-checkbox`:
- Added a new input property - `disableTransitions`. It allows disabling all CSS transitions on the `igx-checkbox` component for performance optimization.

## 6.2.1
- `igx-drop-down`:
- Added a new property `maxHeight`, defining the max height of the drop down.
- `igx-grid`:
- Added a new `igxToolbarCustomContent` directive which can be used to mark an `ng-template` which provides a custom content for the IgxGrid's toolbar.
The template's context provides two properties: `grid` and `toolbar` referencing respectively the `IgxGridBaseComponent` and the `IgxGridToolbarComponent`.

### Features
- `igxGrid`, `igxChip`: Add display density DI token to igxGrid and igxChip ([#2804](https://github.com/IgniteUI/igniteui-angular/issues/2804))
- `igxGrid`
- Quick filter auto close ([#2979](https://github.com/IgniteUI/igniteui-angular/issues/2979))
- Group By: Added title to chip in Group By area ([#3035](https://github.com/IgniteUI/igniteui-angular/issues/3035))
- Improve UX for boolean and date columns, ([#3092](https://github.com/IgniteUI/igniteui-angular/issues/3092))
- Added a new `igxToolbarCustomContent` directive which can be used to mark an `ng-template` which provides a custom content for the IgxGrid's toolbar ([#2983](https://github.com/IgniteUI/igniteui-angular/issues/2983))
- `igxCombo`:
- Added a new input property - `displayDensity`. It allows configuring the `displayDensity` of the combo's `value` and `search` inputs. (PR [#3007](https://github.com/IgniteUI/igniteui-angular/pull/3007))
- `igxDropDown`
- Added a new property `maxHeight`, defining the max height of the drop down. ([#3001](https://github.com/IgniteUI/igniteui-angular/issues/3001))
- Added migrations for Sass theme properties changes in 6.2.0 ([#2994](https://github.com/IgniteUI/igniteui-angular/issues/2994))
- Themes
- Introducing schemas for easier bootstrapping of component themes.
- **Breaking change** removed $variant from `igx-checkbox-theme`, `igx-ripple-theme`, `igx-switch-theme`, `igx-input-group-theme`, `igx-slider-theme`, and `igx-tooltip-theme`. Use the `$schema` prop, now available on all component themes to change the look for a specific theme. See the [Theming](https://www.infragistics.com/products/ignite-ui-angular/angular/components/themes/schemas.html) documentation to learn more.
- `igx-combo`:
- Added a new input property - `displayDensity`. It allows configuring the `displayDensity` of the combo's `value` and `search` inputs.


### Bug fixes

- `igxGrid`
- Filtering condition icon is not updated for boolean columns ([#2936](https://github.com/IgniteUI/igniteui-angular/issues/2936))
- Batch editing: Updating a cell with a value that evaluates to false does not mark it as dirty ([#2940](https://github.com/IgniteUI/igniteui-angular/issues/2940))
- Filtering input accepts value from calendar for unary conditions ([#2937](https://github.com/IgniteUI/igniteui-angular/issues/2937))
- When a number filter's value is deleted the grid is not refreshed ([#2945](https://github.com/IgniteUI/igniteui-angular/issues/2945))
- Improve keyboard navigation in filtering ([#2951](https://github.com/IgniteUI/igniteui-angular/issues/2951), [#2941](https://github.com/IgniteUI/igniteui-angular/issues/2941))
- Group By: Alt+ Arrow left/Right keys should not toggle the group row ([#2950](https://github.com/IgniteUI/igniteui-angular/issues/2950))
- Multi Column Header can be grouped ([#2944](https://github.com/IgniteUI/igniteui-angular/issues/2944))
- Group By: groupsRecords is not updated yet at the time of onGroupingDone event. ([#2967](https://github.com/IgniteUI/igniteui-angular/issues/2967))
- Paging: Blank space in rows area after vertical scrolling and navigating to next page ([#2957](https://github.com/IgniteUI/igniteui-angular/issues/2957))
- When date or boolean cell is in edit mode and press arrowUp or arrowDown key the page is scrolled ([#2507](https://github.com/IgniteUI/igniteui-angular/issues/2507))
- When deleting a row the Row Editing dialog should be closed ([#2977](https://github.com/IgniteUI/igniteui-angular/issues/2977))
- Group header with columns which width is defined as number throws an exception ([#3020](https://github.com/IgniteUI/igniteui-angular/issues/3020))
- Refactor header and filter cell components, Closes [#2972](https://github.com/IgniteUI/igniteui-angular/issues/2972), [#2926](https://github.com/IgniteUI/igniteui-angular/issues/2926), [#2923](https://github.com/IgniteUI/igniteui-angular/issues/2923), [#2917](https://github.com/IgniteUI/igniteui-angular/issues/2917), [#2783](https://github.com/IgniteUI/igniteui-angular/issues/2783), [#3027](https://github.com/IgniteUI/igniteui-angular/issues/3027), [#2938](https://github.com/IgniteUI/igniteui-angular/issues/2938)
- Filter's UI dropdown is hidden under the bottom level of the grid ([#2928](https://github.com/IgniteUI/igniteui-angular/issues/2928))
- Cell is not editable on iOS ([#2538](https://github.com/IgniteUI/igniteui-angular/issues/2538))
- `IgxTreeGrid`
- Cell selection wrong behavior when collapsing rows ([#2935](https://github.com/IgniteUI/igniteui-angular/issues/2935))
- `igxCombo`
- Keyboard doesn't scroll virtualized items ([#2999](https://github.com/IgniteUI/igniteui-angular/issues/2999))
- `igxDatePicker`
- Error emitting when value property is initialized with empty string. ([#3021](https://github.com/IgniteUI/igniteui-angular/issues/3021))
- `igxOverlay`
- Drop-down flickers in IE and EDGE ([#2867](https://github.com/IgniteUI/igniteui-angular/issues/2867))
- `igxTabs`
- Tabs don't not handle width change ([#3030](https://github.com/IgniteUI/igniteui-angular/issues/3030))
- `igxCalendar`
- make all css class names unique ([#2287](https://github.com/IgniteUI/igniteui-angular/issues/2287))
- Fixed runtime errors when using the package in applications targeting es2015(es6) and newer ([#3011](https://github.com/IgniteUI/igniteui-angular/pull/3011))


## 6.2.0
- Updated typography following the Material guidelines. Type system is now also optional and can be applied via class to the desired containers. [#2112](https://github.com/IgniteUI/igniteui-angular/pull/2112)
- **Breaking change:** Applications using Ignite UI for Angular now require the `igx-typography` class to be applied on wrapping element, like the body element for instance.
Expand Down
12 changes: 11 additions & 1 deletion extras/docs/themes/sassdoc/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ const sassPlug = require('sassdoc-plugin-localization');
const process = require('process');
const fs = require('fs');
const path = require('path');
const shell = JSON.parse(fs.readFileSync('./extras/template/strings/shell-strings.json'));

themeleon.use({

Expand Down Expand Up @@ -83,7 +84,7 @@ const theme = themeleon(__dirname, function (t) {
infraHead: 'partials/infragistics/header',
infraFoot: 'partials/infragistics/footer',
infraHeadJA: 'partials/infragistics/infranav.ja',
infraFooJA: 'partials/infragistics/infrafoot.ja'
infraFootJA: 'partials/infragistics/infrafoot.ja'
},
helpers: {
debug: function (content) {
Expand Down Expand Up @@ -147,6 +148,15 @@ const theme = themeleon(__dirname, function (t) {
default:
return options.inverse(this);
}
},
localize: (options) => {
const value = options.fn(this).trim();
const lang = process.env.SASSDOC_LANG;
if (lang && shell[lang.trim()]) {
return shell[lang.trim()][value];
}

return value;
}
}
};
Expand Down
3 changes: 1 addition & 2 deletions extras/docs/themes/sassdoc/views/index.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,6 @@
! 2. Loop over types mapped to each group
! 3. Loop over items mapped to each type
}}

<main class="main-content" role="main">
<div class="nav-wrapper">
<div class="search-form">
Expand Down Expand Up @@ -139,7 +138,7 @@
</main>

<div id="footer-container">
{{#ifCond lang '==' 'jp'}}{{> infraFooJA }}{{else}}{{> infraFoot }}{{/ifCond}}
{{#ifCond lang '==' 'jp'}}{{> infraFootJA }}{{else}}{{> infraFoot }}{{/ifCond}}
</div>
{{!
! If your theme needs some JavaScript, feel free to create a JS file in `assets/js/` folder
Expand Down
6 changes: 3 additions & 3 deletions extras/docs/themes/sassdoc/views/partials/header.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
<div class="header__secondary">
<div class="header__logo">
<span class="header__logo-name">{{package.name}}</span>
<span class="header__logo-version">API ver. 6.2.x</span>
<span class="header__logo-version">API ver. 7.0.x</span>
</div>

<div class="tsd-nav-toggle align-end">
Expand All @@ -14,12 +14,12 @@
<ul class="tsd-nav">
<li class="tsd-nav-item">
<button class="infra-button--flat">
<a href="https://www.infragistics.com/products/ignite-ui-angular">Components</a>
<a href="https://www.infragistics.com/products/ignite-ui-angular">{{#localize}}Components{{/localize}}</a>
</button>
</li>
<li class="tsd-nav-item">
<button class="infra-button">
<a href="https://infragistics.com/products/ignite-ui-angular/getting-started/">Get Started</a>
<a href="https://infragistics.com/products/ignite-ui-angular/getting-started/">{{#localize}}Get Started{{/localize}}</a>
</button>
</li>
</ul>
Expand Down
6 changes: 3 additions & 3 deletions extras/docs/themes/typedoc/src/partials/header.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
<div class="tsd-header-group">
<h1 class="tsd-header-logo">
<a href="{{relativeURL "index.html"}}" class="title">{{project.name}}</a>
<span class="version">API ver. <strong>6.2.x</strong></span>
<span class="version">API ver. <strong>7.0.x</strong></span>
</h1>
<div class="tsd-nav-toggle">
<input id="tsd-toggle-cbx" type="checkbox">
Expand All @@ -14,12 +14,12 @@
<ul class="tsd-nav">
<li class="tsd-nav-item">
<button class="tsd-button--flat">
<a href="https://www.infragistics.com/products/ignite-ui-angular">Components</a>
<a href="https://www.infragistics.com/products/ignite-ui-angular">{{#localize}}Components{{/localize}}</a>
</button>
</li>
<li class="tsd-nav-item">
<button class="tsd-button">
<a href="https://infragistics.com/products/ignite-ui-angular/getting-started/">Get Started</a>
<a href="https://infragistics.com/products/ignite-ui-angular/getting-started/">{{#localize}}Get Started{{/localize}}</a>
</button>
</li>
</ul>
Expand Down
6 changes: 4 additions & 2 deletions extras/template/strings/shell-strings.json
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,8 @@
"Class": "クラス",
"Interface": "インターフェイス",
"Enumeration": "列挙",
"Static": "スタティック"
"Static": "スタティック",
"Components": "コンポーネント",
"Get Started": "はじめに"
}
}
}
3 changes: 2 additions & 1 deletion projects/igniteui-angular/src/lib/checkbox/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,8 @@ To disable the ripple effect, do:
| `@Input()` indeterminate | boolean | Specifies the indeterminate state of the checkbox. |
| `@Input()` required | boolean | Specifies the required state of the checkbox. |
| `@Input()` disabled | boolean | Specifies the disabled state of the checkbox. |
| `@Input()` disableRipple | boolean | Specifies the whether the ripple effect should be disabled for the checkbox. |
| `@Input()` disableRipple | boolean | Specifies whether the ripple effect should be disabled for the checkbox. |
| `@Input()` disableTransitions | boolean | Specifies whether CSS transitions should be disabled for the checkbox. |
| `@Input()` labelPosition | string `|` enum LabelPosition | Specifies the position of the text label relative to the checkbox element. |
| `@Input("aria-labelledby")` ariaLabelledBy | string | Specify an external element by id to be used as label for the checkbox. |
| `@Output()` change | EventEmitter<IChangeCheckboxEventArgs> | Emitted when the checkbox checked value changes. |
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ describe('IgxCheckbox', () => {
CheckboxRequiredComponent,
CheckboxExternalLabelComponent,
CheckboxInvisibleLabelComponent,
CheckboxDisabledTransitionsComponent,
IgxCheckboxComponent
],
imports: [FormsModule, IgxRippleModule]
Expand Down Expand Up @@ -156,6 +157,21 @@ describe('IgxCheckbox', () => {
expect(testInstance.subscribed).toBe(false);
});

it('Should be able to enable/disable CSS transitions', () => {
const fixture = TestBed.createComponent(CheckboxDisabledTransitionsComponent);
const testInstance = fixture.componentInstance;
const checkboxInstance = testInstance.cb;
const checkboxHost = fixture.debugElement.query(By.css('igx-checkbox')).nativeElement;
fixture.detectChanges();

expect(checkboxInstance.disableTransitions).toBe(true);
expect(checkboxHost.classList).toContain('igx-checkbox--plain');

testInstance.cb.disableTransitions = false;
fixture.detectChanges();
expect(checkboxHost.classList).not.toContain('igx-checkbox--plain');
});

it('Required state', () => {
const fixture = TestBed.createComponent(CheckboxRequiredComponent);
const testInstance = fixture.componentInstance;
Expand Down Expand Up @@ -281,3 +297,10 @@ class CheckboxInvisibleLabelComponent {
@ViewChild('cb') public cb: IgxCheckboxComponent;
label = 'Invisible Label';
}

@Component({
template: `<igx-checkbox #cb [disableTransitions]="true"></igx-checkbox>`
})
class CheckboxDisabledTransitionsComponent {
@ViewChild('cb') public cb: IgxCheckboxComponent;
}
13 changes: 13 additions & 0 deletions projects/igniteui-angular/src/lib/checkbox/checkbox.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -264,6 +264,19 @@ export class IgxCheckboxComponent implements ControlValueAccessor, EditorProvide
*/
@HostBinding('class.igx-checkbox--disabled')
@Input() public disabled = false;
/**
* Sets/gets whether the checkbox should disable all css transitions.
* Default value is `false`.
* ```html
* <igx-checkbox [disableTransitions]="true"></igx-checkbox>
* ```
* ```typescript
* let disableTransitions = this.checkbox.disableTransitions;
* ```
* @memberof IgxCheckboxComponent
*/
@HostBinding('class.igx-checkbox--plain')
@Input() public disableTransitions = false;
/**
*@hidden
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,10 @@
}
}

@include m(plain) {
@extend %cbx-display--plain !optional;
}

@include mx(focused, checked) {
@include e(ripple) {
@extend %cbx-ripple--focused !optional;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -271,6 +271,15 @@
opacity: .12;
}
}

%cbx-display--plain {
%cbx-composite,
%cbx-composite::after,
%cbx-composite-mark,
%cbx-composite-mark--x {
transition: none;
}
}
}

/// Adds typography styles for the igx-checkbox component.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3500,7 +3500,10 @@ export abstract class IgxGridBaseComponent extends DisplayDensityBase implements

if (this._width && this._width.indexOf('%') !== -1) {
/* width in %*/
const width = parseInt(computed.getPropertyValue('width'), 10);
const width = computed.getPropertyValue('width').indexOf('%') === -1 ?
parseInt(computed.getPropertyValue('width'), 10) :
this.document.getElementById(this.nativeElement.id).offsetWidth;

if (Number.isFinite(width) && width !== this.calcWidth) {
this.calcWidth = width;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ describe('IgxTreeGrid - Expanding / Collapsing', () => {
BrowserAnimationsModule,
IgxTreeGridModule]
})
.compileComponents();
.compileComponents();
}));

describe('Child Collection', () => {
Expand Down Expand Up @@ -286,7 +286,6 @@ describe('IgxTreeGrid - Expanding / Collapsing', () => {
});

it('should update current page when \'collapseAll\' ', () => {
pending('Tree Grid issue: curent page is not updated when collapseAll');
// Test prerequisites
treeGrid.paging = true;
treeGrid.perPage = 4;
Expand Down Expand Up @@ -573,7 +572,6 @@ describe('IgxTreeGrid - Expanding / Collapsing', () => {
});

it('should update current page when \'collapseAll\' ', () => {
pending('Tree Grid issue: curent page is not updated when collapseAll');
// Test prerequisites
treeGrid.paging = true;
treeGrid.perPage = 2;
Expand All @@ -596,8 +594,8 @@ describe('IgxTreeGrid - Expanding / Collapsing', () => {
treeGrid.collapseAll();
fix.detectChanges();

// Verify current page is the first one and only root rows are visible.
verifyGridPager(fix, 2, '1', '1 of 2', [true, true, false, false]);
// Verify current page is the last one and only root rows are visible.
verifyGridPager(fix, 1, '10', '2 of 2', [false, false, true, true]);
expect(treeGrid.totalPages).toBe(2);
});
});
Expand All @@ -618,7 +616,7 @@ describe('Row editing expanding/collapsing', () => {
NoopAnimationsModule,
IgxTreeGridModule]
})
.compileComponents();
.compileComponents();
}));

beforeEach(() => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -234,18 +234,23 @@ export class IgxTreeGridPagingPipe implements PipeTransform {
}

public transform(collection: ITreeGridRecord[], page = 0, perPage = 15, id: string, pipeTrigger: number): ITreeGridRecord[] {
if (!this.gridAPI.get(id).paging) {
const grid: IgxTreeGridComponent = this.gridAPI.get(id) as IgxTreeGridComponent;
if (!grid.paging) {
return collection;
}

const len = collection.length;
const totalPages = Math.ceil(len / perPage);

const state = {
index: page,
index: (totalPages > 0 && page >= totalPages) ? totalPages - 1 : page,
recordsPerPage: perPage
};

const result: ITreeGridRecord[] = DataUtil.page(cloneArray(collection), state);
grid.pagingState = state;
(grid as any)._page = state.index;

this.gridAPI.get(id).pagingState = state;
return result;
}
}
Expand Down
Loading

0 comments on commit e6f5dd7

Please sign in to comment.