Skip to content

Latest commit

 

History

History
462 lines (321 loc) · 14.4 KB

CHANGELOG.md

File metadata and controls

462 lines (321 loc) · 14.4 KB

0.8.3 (2015-08-09)

Bug Fixes

  • ngTableDefaultGetData: should ignore null and undefined filter values (64a33a85)

Features

  • NgTableParams:
    • filter function option to remove insignificant values (2f5f3016)
    • isSortBy direction parameter now optional (b3e02b92)
    • add response error interception (5613d1e0)
  • number.html: new filter template for numbers (78b02bbf)

0.8.2 (2015-08-06)

Bug Fixes

  • NgTableParams: datasetChanged event fires too early (9706a60b)
  • select-filter: select lists should not display an empty and '-' option (1ee441be)

Features

  • NgTableParams: generatePagesArray can be called without arguments (25fc82bd)

0.8.1 (2015-08-02)

Bug Fixes

  • ngTableController:
    • table not reloaded when new NgTableParams bound to scope (d8cbd771)
    • apply filter delay only when relevant (1ed42168)

Features

  • NgTableController: optimize calls to reload (e94ca5f7)
  • NgTableParams:
    • allow getData to return an array of data (ab9ffdfa)
    • add hasFilter function (1163e22c)
    • add isDataReloadRequired and hasFilterChanges methods (95b0f2ba)
    • better default implementation of getData that filters and sorts (8d912609)
    • extend getData with interceptor pipeline (f94c6357)
  • ngTableController: automatically reload table when settings data array changes (4817c203)
  • ngTableDefaultGetData: new service for applying NgTableParam filters (etc) to a data array (bdf5d9ee)
  • ngTableEventsChannel: publish strongly typed events using explicit service (1f3e7e4c)
  • ngTableFilterConfig: setConfig now merges with previous config values (155ef620)

0.8.0 (2015-07-25)

Bug Fixes

  • ngTableController: don't trigger reload whilst a reload is already in-flight (97d09ca4)

Features

  • ngTableFilterConfig: allow template urls for filters to be customized (032f6ff6)

Breaking Changes

The sortBy function previously declared by ngTableController has been moved to the new controller

  • ngTableSorterRowController.

  • ngTableController: due to 97d09ca4,

Calls to NgTableParams.filter, NgTableParams.sorting (etc) made in the then method of the promise returned by NgTableParams.reload will NOT trigger a subsequent call to NgTableParams.reload; the call to NgTableParams.reload must now be explicitly be made.

Previously:

tableParams.reload().then(function(){
  if (!tableParams.total() && _.size(tableParams.filter()) > 0) {
        tableParams.filter({});
  }
});

Now:

tableParams.reload().then(function(){
  if (!tableParams.total() && _.size(tableParams.filter()) > 0) {
        tableParams.filter({});
        return tableParams.reload();
  }
});

0.7.1 (2015-07-20)

Features

  • ngTableController: add function to parse the expression used to initialise ngTableDynamic (e9333f98)

0.7.0 (2015-07-13)

Breaking Changes

  • ngTable+ngTableDynamic: due to b226dec9,
  • showing/hiding columns now uses ng-if; ng-show is no longer supported

Previously:

<tr>
  <td ng-show="showColExpr">
</tr>

Now:

<tr>
  <td ng-if="showColExpr">
</tr>

0.6.0 (2015-07-12)

Breaking Changes

  • header.html: due to 6bb2aba8, anyone who relied on a specific 'position' field to order table columns will now need to change the order items's in the column array

Previously:

 cols[1].position = 2;
 cols[2].position = 1;

Now:

var swappedCol = cols[2];
cols[2] = cols[1];
cols[1] = swappedCol;

0.5.5 (2015-07-09)

Bug Fixes

  • example: updated code due to documentation total should be a number (ce15e94a)

Features

  • header.html: allow reordering of columns (23236e6f)
  • ngTableDynamic: add a column on the fly (01682774)
  • pagination: add setting paginationMaxBlocks now you can define the count of pagination blocks, minimum is 6 (bbdfaf38)

v0.5.4 (2015-02-26)

Features

  • ngTable: added setting sortingIndicator to show sorting indicator whether near header title or to the very right (10cdf358)

v0.5.0 (2015-02-15)

Bug Fixes

  • ngTableController:
    • fix regression in recent rename of ngTableParmas to NgTableParams (c7f2ac89)
    • prevent "stackoverflow" exception when data items are recursive data structures (4a344db0)

Features

  • filters:
    • filter expression now has access to scope (c2f83b98)
    • specify the filter template url using the filter value rather than a separate templateUrl field (7955f12b)
  • header:
    • add data-title-text attribute to table cells (43e5c4bf)
    • title and sortable expression now has access to the column definition (699b2a58)
    • header-title (502b717b)
    • header-class attribute is now a data binding expression (60de2066)
  • ngTable:
    • getter methods declared on $column no longer require a $scope to be supplied (f9090b47)
    • add title-alt for displaying an alternative header title for responsive tables (afc14234)
  • ngTableDynamic: new directive that accepts dynamic array of columns (03854d33)

Breaking Changes

  • Binding expressions used for generating thead>th attributes that reference the current column will need modifying

Previously:

 <td title="getTitle(column)">

Now:

 <td title="getTitle($column)">
  • Fields previously stored directly on a column object are now only available via the prototype chain

This will affect you only if you are enumerating / specifically checking for "own properties" of the column object.

Custom header.html templates will need to pass the current scope as a parameter to column.filter.

Previously:

<!-- snip -->
<div ng-repeat="(name, filter) in column.filter">
<!-- snip -->

... now becomes:

 <!-- snip -->
 <div ng-repeat="(name, filter) in column.filter(this)">
 <!-- snip -->
  • $$name field on filter definitions is not supported.

Previously:

<td filter="{'username': 'text', $$name: 'username'}"</td>

... now becomes:

<td filter="{'username': 'text'}"</td>
  • column.filterName has been dropped as this is no longer applicable. Custom filter templates will need to change.

Previously:

        <input type="text" name="{{column.filterName}}"

... now becomes:

        <input type="text" name="{{name}}"
  • Multiple filters defined by the same filter definition will now render each input with a seperate name.
  • column.filterTemplateURL has been dropped as this is no longer applicable. Custom header.html templates will need to change.

Previously:

        <tr class="ng-table-filters" ng-init="tableParams">
            <th ng-repeat="column in columns" ng-show="column.visible" class="filter">
                <div ng-repeat="(name, filter) in column.filter">
                    <div ng-if="column.filterTemplateURL" ng-show="column.filterTemplateURL">
                        <div ng-include="column.filterTemplateURL"></div>
                    </div>
                    <div ng-if="!column.filterTemplateURL" ng-show="!column.filterTemplateURL">
                        <div ng-include="'ng-table/filters/' + filter + '.html'"></div>
                    </div>
                </div>
            </th>
        </tr>

... now becomes:

        <tr class="ng-table-filters" ng-init="tableParams">
            <th ng-repeat="column in columns" ng-show="column.visible" class="filter">
                <div ng-repeat="(name, filter) in column.filter">
                    <div ng-if="filter.indexOf('/') !== -1" ng-include="filter"></div>
                    <div ng-if="filter.indexOf('/') === -1" ng-include="'ng-table/filters/' + filter + '.html'"></div>
                </div>
            </th>
        </tr>
  • Specifying the url to a filter template has changed.

Previously:

<td filter="{ 'name': 'text', templateURL: 'path/to/textFilter.html'}"</td>

... now becomes:

<td filter="{ 'name': 'path/to/textFilter.html'}"</td>
  • Multiple filters defined by the same filter definition will now specify their own url.

Previously:

<td filter="{
    'fname': 'text',
    'lname': 'text',
    templateURL: 'path/to/textFilter.html'}"</td>

... now becomes:

<td filter="{
    'fname': 'path/to/textFilter.html',
    'lname': 'path/to/textFilter.html'}"</td>

parse method on the ngTable scope has been removed as it's no longer required

Previously, a css class was added to TH elements thusly:

<tr ng-repeat="row in $data">
	<td header-class="myHeaderClass"></td>
</tr>

Now:

<tr ng-repeat="row in $data">
	<td header-class="'myHeaderClass'"></td>
</tr>

v0.3.2 (master)

  • add pagination directive ngTablePagination (see usage)
  • rename filter.name to filter.$$name according to issue #196
  • add debugMode setting
  • add defaultSort setting
  • add filterDelay setting
  • add multisorting (click on header with Ctrl-key)
  • add css classes (ng-table-pager, ng-table-pagination, ng-table-counts)

v0.3.1

  • add support of header-class attribute
  • add fixes for compatibility with early versions of AngularJS
  • add data field to ngTableParams
  • Allow expressions in the sortable & filter attribute (Issue #93)

v0.3.0

v0.2.2

In functions that return data for the filters were removed .promise

$scope.names = function(column) {
    ...
    def.resolve(names);
    // return def.promise; - old code
    return def;
};