From 1d388676e3b97b6171fc498e82545bd437ee6fd1 Mon Sep 17 00:00:00 2001
From: Max
Date: Wed, 2 May 2012 18:51:31 +0200
Subject: fix(ngRepeat): expose $first, $middle and $last instead of $position
$position marker doesn't work well in cases when we have just one item
in the list because then the item is both the first and last. To solve
this properly we need to expose individual $first and $middle and $last
flags.
BREAKING CHANGE: $position is not exposed in repeater scopes any more
To update, search for $position and replace it with one of $first,
$middle or $last.
Closes #912
---
test/ng/directive/ngRepeatSpec.js | 38 +++++++++++++++++++++++++++-----------
1 file changed, 27 insertions(+), 11 deletions(-)
(limited to 'test')
diff --git a/test/ng/directive/ngRepeatSpec.js b/test/ng/directive/ngRepeatSpec.js
index 5cb7196b..72382591 100644
--- a/test/ng/directive/ngRepeatSpec.js
+++ b/test/ng/directive/ngRepeatSpec.js
@@ -104,42 +104,58 @@ describe('ngRepeat', function() {
}));
- it('should expose iterator position as $position when iterating over arrays',
+ it('should expose iterator position as $first, $middle and $last when iterating over arrays',
inject(function($rootScope, $compile) {
element = $compile(
'
' +
- '' +
+ '- {{item}}:{{$first}}-{{$middle}}-{{$last}}|
' +
'
')($rootScope);
$rootScope.items = ['misko', 'shyam', 'doug'];
$rootScope.$digest();
- expect(element.text()).toEqual('misko:first|shyam:middle|doug:last|');
+ expect(element.text()).
+ toEqual('misko:true-false-false|shyam:false-true-false|doug:false-false-true|');
$rootScope.items.push('frodo');
$rootScope.$digest();
- expect(element.text()).toEqual('misko:first|shyam:middle|doug:middle|frodo:last|');
+ expect(element.text()).
+ toEqual('misko:true-false-false|' +
+ 'shyam:false-true-false|' +
+ 'doug:false-true-false|' +
+ 'frodo:false-false-true|');
$rootScope.items.pop();
$rootScope.items.pop();
$rootScope.$digest();
- expect(element.text()).toEqual('misko:first|shyam:last|');
+ expect(element.text()).toEqual('misko:true-false-false|shyam:false-false-true|');
+
+ $rootScope.items.pop();
+ $rootScope.$digest();
+ expect(element.text()).toEqual('misko:true-false-true|');
}));
- it('should expose iterator position as $position when iterating over objects',
+ it('should expose iterator position as $first, $middle and $last when iterating over objects',
inject(function($rootScope, $compile) {
element = $compile(
'' +
- '- ' +
- '
' +
+ '- {{key}}:{{val}}:{{$first}}-{{$middle}}-{{$last}}|
' +
'
')($rootScope);
$rootScope.items = {'misko':'m', 'shyam':'s', 'doug':'d', 'frodo':'f'};
$rootScope.$digest();
- expect(element.text()).toEqual('doug:d:first|frodo:f:middle|misko:m:middle|shyam:s:last|');
+ expect(element.text()).
+ toEqual('doug:d:true-false-false|' +
+ 'frodo:f:false-true-false|' +
+ 'misko:m:false-true-false|' +
+ 'shyam:s:false-false-true|');
delete $rootScope.items.doug;
delete $rootScope.items.frodo;
$rootScope.$digest();
- expect(element.text()).toEqual('misko:m:first|shyam:s:last|');
+ expect(element.text()).toEqual('misko:m:true-false-false|shyam:s:false-false-true|');
+
+ delete $rootScope.items.shyam;
+ $rootScope.$digest();
+ expect(element.text()).toEqual('misko:m:true-false-true|');
}));
@@ -207,7 +223,7 @@ describe('ngRepeat', function() {
beforeEach(inject(function($rootScope, $compile) {
element = $compile(
'' +
- '' +
+ '- {{key}}:{{val}}|>
' +
'
')($rootScope);
a = {};
b = {};
--
cgit v1.2.3