forked from angular/angular.js
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathheading-offsetSpec.js
88 lines (61 loc) · 2.48 KB
/
heading-offsetSpec.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
describe("heading-offset", function() {
describe("id directive", function() {
function check(element, child, offset, id) {
expect(child[0].nodeName).toMatch(/div/i);
expect(element.attr('id')).toBeUndefined();
expect(child.attr('id')).toEqual(id);
expect(child.css('margin-top')).toEqual('-'+offset);
expect(child.css('height')).toEqual(offset);
}
var $compile, $scope, headingOffset;
beforeEach(module('heading-offset'));
beforeEach(inject(function($rootScope, _$compile_, _headingOffset_) {
$scope = $rootScope;
$compile = _$compile_;
headingOffset = _headingOffset_;
headingOffset.value = '40px';
}));
it("should inject a child into headings with ids, while watching the headerOffset service value", function() {
var element = $compile('<h1 id="some-id"></h1>')($scope);
var child = element.children();
$scope.$digest();
check(element, child, '40px', 'some-id');
headingOffset.value = '100px';
$scope.$digest();
check(element, child, '100px', 'some-id');
});
it("should inject a child into anchors with ids, while watching the headerOffset service value", function() {
var element = $compile('<a id="some-id"></a>')($scope);
var child = element.children();
$scope.$digest();
check(element, child, '40px', 'some-id');
headingOffset.value = '100px';
$scope.$digest();
check(element, child, '100px', 'some-id');
});
it("should inject a child into heading elements, while observing the ngOffset attribute", function() {
var element = $compile('<h2 id="some-id" ng-offset="{{ x }}"></h2>')($scope);
var child = element.children();
$scope.$digest();
check(element, child, '40px', 'some-id');
$scope.x = '50px';
$scope.$digest();
check(element, child, '50px', 'some-id');
$scope.x = null;
$scope.$digest();
check(element, child, '40px', 'some-id');
});
it("should inject a child into non-heading elements, while observing the ngOffset attribute", function() {
var element = $compile('<li id="some-id" ng-offset="{{ x }}"></li>')($scope);
var child = element.children();
$scope.$digest();
check(element, child, '40px', 'some-id');
$scope.x = '50px';
$scope.$digest();
check(element, child, '50px', 'some-id');
$scope.x = null;
$scope.$digest();
check(element, child, '40px', 'some-id');
});
});
});