angular-incremental-list
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:
Add the specific module to your dependencies:
angular
Usage examples
<!-- Basic example --> <!-- --><!-- ilIncreaseOn example --><!-- First and last name are required, but age is optional -->
Directives
ilList
: Indicates the list that will auto-increment or decrement. Used in conjunction withngRepeat
. All the other directives require this one.ilItemModel
: Notify of changes on the list. RequiresngModel
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 nestedilList
. Used in anilList
to notify the parentilList
that changes were made.ilMinLength
: The minimum length that the list must have. If the list length is less thanilMinLength
when the directive is linked, new items are pushed to the list (usingilNewItem
). 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 thanilMaxLength
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 hasilItemModel
.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 emptyemptyView
: returns true if all input view values are empty (default forilDecreaseOn
)fullModel
: returns true if all input model values are not emptyfullView
: returns true if all input view values are not emptymodelExists
: returns true if the model value of the modified input exists (default forilIncreaseOn
)viewExists
: returns true if the view value of the modified input existshasFocus
: returns true if an input of the item has focus (enabled withilEnableHasFocus
)