Skip to content

Commit

Permalink
v1.18.1
Browse files Browse the repository at this point in the history
  • Loading branch information
www committed Jan 11, 2017
2 parents 32f3a0b + 91151c7 commit 7a205ce
Show file tree
Hide file tree
Showing 7 changed files with 98 additions and 8 deletions.
5 changes: 4 additions & 1 deletion dist/angular-openlayers-directive.js
Original file line number Diff line number Diff line change
Expand Up @@ -2324,16 +2324,19 @@ angular.module('openlayers-directive').factory('olHelpers', ["$q", "$log", "$htt
while (layers.getLength() < index) {
var nullLayer = new ol.layer.Image();
nullLayer.index = layers.getLength(); // add index which will be equal to the length in this case
nullLayer.name = '(null-layer)'; // we need a marker somehow
layers.push(nullLayer);
}
layer.index = index;
layers.push(layer);
} else {
layer.index = index;
layers.insertAt(layer.index, layer);

// remove eventual null layers
for (var i = index + 1; i < layers.getLength(); i++) {
var l = layers.item(i);
if (l === null) {
if (l.name === '(null-layer)') {
layers.removeAt(i);
break;
} else {
Expand Down
4 changes: 2 additions & 2 deletions dist/angular-openlayers-directive.min.js

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions dist/angular-openlayers-directive.min.no-header.js

Large diffs are not rendered by default.

5 changes: 4 additions & 1 deletion dist/angular-openlayers-directive.pre.js
Original file line number Diff line number Diff line change
Expand Up @@ -2324,16 +2324,19 @@ angular.module('openlayers-directive').factory('olHelpers', function($q, $log, $
while (layers.getLength() < index) {
var nullLayer = new ol.layer.Image();
nullLayer.index = layers.getLength(); // add index which will be equal to the length in this case
nullLayer.name = '(null-layer)'; // we need a marker somehow
layers.push(nullLayer);
}
layer.index = index;
layers.push(layer);
} else {
layer.index = index;
layers.insertAt(layer.index, layer);

// remove eventual null layers
for (var i = index + 1; i < layers.getLength(); i++) {
var l = layers.item(i);
if (l === null) {
if (l.name === '(null-layer)') {
layers.removeAt(i);
break;
} else {
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -65,5 +65,5 @@
"semantic-release": "semantic-release pre && npm publish && semantic-release post"
},
"main": "dist/angular-openlayers-directive",
"version": "1.18.0"
"version": "1.18.1"
}
5 changes: 4 additions & 1 deletion src/services/olHelpers.js
Original file line number Diff line number Diff line change
Expand Up @@ -1108,16 +1108,19 @@ angular.module('openlayers-directive').factory('olHelpers', function($q, $log, $
while (layers.getLength() < index) {
var nullLayer = new ol.layer.Image();
nullLayer.index = layers.getLength(); // add index which will be equal to the length in this case
nullLayer.name = '(null-layer)'; // we need a marker somehow
layers.push(nullLayer);
}
layer.index = index;
layers.push(layer);
} else {
layer.index = index;
layers.insertAt(layer.index, layer);

// remove eventual null layers
for (var i = index + 1; i < layers.getLength(); i++) {
var l = layers.item(i);
if (l === null) {
if (l.name === '(null-layer)') {
layers.removeAt(i);
break;
} else {
Expand Down
81 changes: 81 additions & 0 deletions test/unit/layersSpec.js
Original file line number Diff line number Diff line change
Expand Up @@ -405,4 +405,85 @@ describe('Directive: openlayers layers', function() {
expect(otherLayer.getLayers().getArray()[0].get('group')).toEqual('Other');

});

describe('when setting the index', function() {

it('should correctly fill up the layer collection with null layers', function() {
scope.layers = [
{
index: 2,
name: 'Spain',
source: {
type: 'GeoJSON',
url: 'json/ESP.geo.json'
}
}
];

var element = angular
.element('<openlayers custom-layers="true">' +
'<ol-layer ol-layer-properties="layer" ng-repeat="layer in layers"></ol-layer>' +
'</openlayers>');
element = $compile(element)(scope);

var layers;
olData.getMap().then(function(olMap) {
layers = olMap.getLayers();
});

scope.$digest();
expect(layers.getLength()).toBe(3);

expect(layers.item(2).getSource() instanceof ol.source.Vector).toBeTruthy();
});

it('should correctly populate the layer collection with when layers are provided in random order', function() {
scope.layers = [
{
index: 1,
name: 'Spain',
source: {
type: 'GeoJSON',
url: 'json/ESP.geo.json'
}
},
{
index: 2,
name: 'Italy',
source: {
type: 'GeoJSON',
url: 'json/ESP.geo.json'
}
},
{
index: 0,
name: 'Germany',
source: {
type: 'GeoJSON',
url: 'json/ESP.geo.json'
}
}
];

var element = angular
.element('<openlayers custom-layers="true">' +
'<ol-layer ol-layer-properties="layer" ng-repeat="layer in layers"></ol-layer>' +
'</openlayers>');
element = $compile(element)(scope);

var layers;
olData.getMap().then(function(olMap) {
layers = olMap.getLayers();
});

scope.$digest();
expect(layers.getLength()).toBe(3);

expect(layers.item(0).get('name')).toBe('Germany');
expect(layers.item(1).get('name')).toBe('Spain');
expect(layers.item(2).get('name')).toBe('Italy');
});

});

});

0 comments on commit 7a205ce

Please sign in to comment.