angular-incremental-list

0.4.3 • Public • Published

angular-incremental-list

npm version bower version build status

List that auto-increments and decrements depending on the changes of the items in the list.

Requirements

Load into your app

You can get it from Bower

bower install angular-incremental-list

Load the script files in your application:

<script type="text/javascript" src="bower_components/angular/angular.js"></script>
<script type="text/javascript" src="bower_components/angular-incremental-list/angular-incremental-list.js"></script>

Add the specific module to your dependencies:

angular.module('myApp', ['incrementalList', ...])

Usage examples

Live demo

<!-- Basic example -->
<ul>
  <li ng-repeat="item in list" il-list="list">
    <input type="text" ng-model="item.name" il-item-model>
  </li>
</ul>
<!-- -->
<!-- ilIncreaseOn example -->
<!-- First and last name are required, but age is optional -->
<ul>
  <li ng-repeat="person in list" il-list="list" il-increase-on="person.firstName && person.lastName">
    <input type="text" ng-model="person.firstName" il-item-model required>
    <input type="text" ng-model="person.lastName" il-item-model required>
    <input type="number" ng-model="person.age" il-item-model>
  </li>
</ul>
<ul>

Directives

  • ilList: Indicates the list that will auto-increment or decrement. Used in conjunction with ngRepeat. All the other directives require this one.
  • ilItemModel: Notify of changes on the list. Requires ngModel directive.
  • ilNewItem: The item that is pushed to the list when it is increased. It is evaluated with the scope of the last item. Default: {}.
  • ilIncreaseOn: The conditions that must be met to increase the list. It is evaluated with the scope of the last item. Default: the changed input must be truthy or 0.
  • ilDecreaseOn: The conditions that must be met to decrease the list. It is evaluated with the scope of the last and the second to last item. Default: all inputs must be empty.
  • ilListModel: This is used when there are nested ilList. Used in an ilList to notify the parent ilList that changes were made.
  • ilMinLength: The minimum length that the list must have. If the list length is less than ilMinLength when the directive is linked, new items are pushed to the list (using ilNewItem). When decreasing the list, it will stop at this value. Default: 1.
  • ilMaxLength: The maximum length that the list can have. If the list length is greater than ilMaxLength when the directive is linked, the items after its value are removed. When increasing the list, it will stop at this value. Default: 9007199254740991 (Number.MAX_SAFE_INTEGER).
  • ilEnableHasFocus: Enables the $ilList.hasFocus function (see below). This will add a focus and blur listener to every input that has ilItemModel.
  • ilDecreaseMiddle: Allows items in the middle to be removed. It is recommended to use it with $ilList.hasFocus so that focus is not stolen.

The directives ilIncreaseOn, ilDecreaseOn and ilNewItem have a local scope with an $ilList object that has the following functions:

  • emptyModel: returns true if all input model values are empty
  • emptyView: returns true if all input view values are empty (default for ilDecreaseOn)
  • fullModel: returns true if all input model values are not empty
  • fullView: returns true if all input view values are not empty
  • modelExists: returns true if the model value of the modified input exists (default for ilIncreaseOn)
  • viewExists: returns true if the view value of the modified input exists
  • hasFocus: returns true if an input of the item has focus (enabled with ilEnableHasFocus)

Package Sidebar

Install

npm i angular-incremental-list

Weekly Downloads

20

Version

0.4.3

License

MIT

Last publish

Collaborators

  • tfoxy