Leaflet/spec/suites/layer/vector/PolygonSpec.js
2023-05-15 13:55:28 +02:00

364 lines
10 KiB
JavaScript

describe('Polygon', () => {
let map, container;
beforeEach(() => {
container = createContainer();
map = L.map(container, {center: [55.8, 37.6], zoom: 6});
});
afterEach(() => {
removeMapContainer(map, container);
});
describe('#initialize', () => {
it('should never be flat', () => {
const latLngs = [[1, 2], [3, 4]];
const polygon = L.polygon(latLngs);
expect(L.LineUtil.isFlat(polygon._latlngs)).to.be.false;
expect(polygon.getLatLngs()).to.eql(polygon._latlngs);
});
it('doesn\'t overwrite the given latlng array', () => {
const originalLatLngs = [
[1, 2],
[3, 4]
];
const sourceLatLngs = originalLatLngs.slice();
const polygon = L.polygon(sourceLatLngs);
expect(sourceLatLngs).to.eql(originalLatLngs);
expect(polygon._latlngs).to.not.eql(sourceLatLngs);
});
it('can be called with an empty array', () => {
const polygon = L.polygon([]);
expect(polygon._latlngs).to.eql([[]]);
expect(polygon.getLatLngs()).to.eql(polygon._latlngs);
});
it('can be initialized with holes', () => {
const originalLatLngs = [
[[0, 10], [10, 10], [10, 0]], // external ring
[[2, 3], [2, 4], [3, 4]] // hole
];
const polygon = L.polygon(originalLatLngs);
expect(polygon._latlngs).to.eql([
[L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])],
[L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4])]
]);
expect(polygon.getLatLngs()).to.eql(polygon._latlngs);
});
it('can be initialized with multi including hole', () => {
const latLngs = [
[[[10, 20], [30, 40], [50, 60]]],
[[[0, 10], [10, 10], [10, 0]], [[2, 3], [2, 4], [3, 4]]]
];
const polygon = L.polygon(latLngs);
expect(polygon._latlngs).to.eql([
[[L.latLng([10, 20]), L.latLng([30, 40]), L.latLng([50, 60])]],
[[L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])], [L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4])]]
]);
expect(polygon.getLatLngs()).to.eql(polygon._latlngs);
});
it('can be added to the map when empty', () => {
const polygon = L.polygon([]).addTo(map);
const isAdded = map.hasLayer(polygon);
expect(isAdded).to.be.true;
});
});
describe('#isEmpty', () => {
it('should return true for a polygon with no latlngs', () => {
const layer = L.polygon([]);
expect(layer.isEmpty()).to.be.true;
});
it('should return false for simple polygon', () => {
const latLngs = [[1, 2], [3, 4], [5, 6]];
const layer = L.polygon(latLngs);
expect(layer.isEmpty()).to.be.false;
});
it('should return false for a multi-polygon', () => {
const latLngs = [
[[[10, 20], [30, 40], [50, 60]]],
[[[0, 10], [10, 10], [10, 0]], [[2, 3], [2, 4], [3, 4]]]
];
const layer = L.polygon(latLngs);
expect(layer.isEmpty()).to.be.false;
});
});
describe('#setLatLngs', () => {
it('doesn\'t overwrite the given latlng array', () => {
const originalLatLngs = [
[1, 2],
[3, 4]
];
const sourceLatLngs = originalLatLngs.slice();
const polygon = L.polygon(sourceLatLngs);
polygon.setLatLngs(sourceLatLngs);
expect(sourceLatLngs).to.eql(originalLatLngs);
});
it('can be set external ring and holes', () => {
const latLngs = [
[[0, 10], [10, 10], [10, 0]], // external ring
[[2, 3], [2, 4], [3, 4]] // hole
];
const polygon = L.polygon([]);
polygon.setLatLngs(latLngs);
expect(polygon.getLatLngs()).to.eql([
[L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])],
[L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4])]
]);
});
it('can be set multi including hole', () => {
const latLngs = [
[[[10, 20], [30, 40], [50, 60]]],
[[[0, 10], [10, 10], [10, 0]], [[2, 3], [2, 4], [3, 4]]]
];
const polygon = L.polygon([]);
polygon.setLatLngs(latLngs);
expect(polygon.getLatLngs()).to.eql([
[[L.latLng([10, 20]), L.latLng([30, 40]), L.latLng([50, 60])]],
[[L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])], [L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4])]]
]);
});
});
describe('#getCenter', () => {
it('should compute center of a big simple polygon around equator', () => {
const latlngs = [
[[0, 0], [10, 0], [10, 10], [0, 10]]
];
const layer = L.polygon(latlngs).addTo(map);
expect(layer.getCenter()).to.be.nearLatLng([5.019148099025293, 5]);
});
it('should compute center of a small simple polygon', () => {
const latlngs = [
[[0, 0], [0.010, 0], [0.010, 0.010], [0, 0.010]]
];
const layer = L.polygon(latlngs).addTo(map);
map.setZoom(0); // Make the polygon disappear in screen.
expect(layer.getCenter()).to.be.nearLatLng([0.005, 0.005]);
});
it('throws error if not yet added to map', () => {
expect(() => {
const latlngs = [
[[0, 0], [10, 0], [10, 10], [0, 10]]
];
const layer = L.polygon(latlngs);
layer.getCenter();
}).to.throw('Must add layer to map before using getCenter()');
});
it('should compute same center for low and high zoom', () => {
const latlngs = [
[[0, 0], [0.010, 0], [0.010, 0.010], [0, 0.010]]
];
const layer = L.polygon(latlngs).addTo(map);
map.setZoom(0);
const center = layer.getCenter();
map.setZoom(18);
expect(layer.getCenter()).to.be.nearLatLng(center);
});
it('should compute center for multi-polygon including hole', () => {
const latlngs = [
[[[10, 20], [30, 40], [50, 60]]],
[[[0, 10], [10, 10], [10, 0]], [[2, 3], [2, 4], [3, 4]]]
];
const layer = L.polygon(latlngs).addTo(map);
expect(layer.getCenter()).to.be.nearLatLng([31.436532296911807, 39.99999999999979]);
});
});
describe('#_defaultShape', () => {
it('should return latlngs on a simple polygon', () => {
const latlngs = [
L.latLng([1, 2]),
L.latLng([3, 4])
];
const polygon = L.polygon(latlngs);
expect(polygon._defaultShape()).to.eql(latlngs);
});
it('should return first latlngs on a polygon with hole', () => {
const latlngs = [
[L.latLng([0, 12]), L.latLng([13, 14]), L.latLng([15, 16])],
[L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6])]
];
const polygon = L.polygon(latlngs);
expect(polygon._defaultShape()).to.eql(latlngs[0]);
});
it('should return first latlngs on a multipolygon', () => {
const latlngs = [
[[L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6])]],
[[L.latLng([11, 12]), L.latLng([13, 14]), L.latLng([15, 16])]]
];
const polygon = L.polygon(latlngs);
expect(polygon._defaultShape()).to.eql(latlngs[0][0]);
});
it('should return first latlngs on a multipolygon with hole', () => {
const latlngs = [
[[L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])],
[L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4])]],
[[L.latLng([10, 20]), L.latLng([30, 40]), L.latLng([50, 60])]]
];
const polygon = L.polygon(latlngs);
expect(polygon._defaultShape()).to.eql(latlngs[0][0]);
});
});
describe('#addLatLng', () => {
it('should add latlng to latlngs', () => {
const latLngs = [
[1, 2],
[3, 4]
];
const polygon = L.polygon(latLngs);
polygon.addLatLng([5, 6]);
expect(polygon._latlngs).to.eql([[L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6])]]);
});
it('should add latlng to first latlngs on a polygon with hole', () => {
const latLngs = [
[[0, 12], [13, 14], [15, 16]],
[[1, 2], [3, 4], [5, 6]]
];
const polygon = L.polygon(latLngs);
polygon.addLatLng([17, 0]);
expect(polygon._latlngs[0]).to.eql([L.latLng([0, 12]), L.latLng([13, 14]), L.latLng([15, 16]), L.latLng([17, 0])]);
expect(polygon._latlngs[1]).to.eql([L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6])]);
});
it('should add latlng by reference on a polygon with hole', () => {
const latLngs = [
[[0, 12], [13, 14], [15, 16]],
[[1, 2], [3, 4], [5, 6]]
];
const polygon = L.polygon(latLngs);
polygon.addLatLng([7, 8], polygon._latlngs[1]);
expect(polygon._latlngs[0]).to.eql([L.latLng([0, 12]), L.latLng([13, 14]), L.latLng([15, 16])]);
expect(polygon._latlngs[1]).to.eql([L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6]), L.latLng([7, 8])]);
});
it('should add latlng to first latlngs on a multi', () => {
const latLngs = [
[[[1, 2], [3, 4]]],
[[[11, 12], [13, 14], [15, 16]]]
];
const polygon = L.polygon(latLngs);
polygon.addLatLng([5, 6]);
expect(polygon._latlngs[0]).to.eql([[L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6])]]);
expect(polygon._latlngs[1]).to.eql([[L.latLng([11, 12]), L.latLng([13, 14]), L.latLng([15, 16])]]);
});
it('should add latlng to latlngs by reference on a multi', () => {
const latLngs = [
[[[11, 12], [13, 14], [15, 16]]],
[[[1, 2], [3, 4]]]
];
const polygon = L.polygon(latLngs);
polygon.addLatLng([5, 6], polygon._latlngs[1][0]);
expect(polygon._latlngs[1]).to.eql([[L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6])]]);
expect(polygon._latlngs[0]).to.eql([[L.latLng([11, 12]), L.latLng([13, 14]), L.latLng([15, 16])]]);
});
it('should add latlng on first latlngs by default on a multipolygon with hole', () => {
const latLngs = [
[[[0, 10], [10, 10], [10, 0]], [[2, 3], [2, 4], [3, 4]]],
[[[10, 20], [30, 40], [50, 60]]]
];
const polygon = L.polygon(latLngs);
polygon.addLatLng([-10, -10]);
expect(polygon._latlngs[0][0]).to.eql([L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0]), L.latLng([-10, -10])]);
expect(polygon._latlngs[0][1]).to.eql([L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4])]);
expect(polygon._latlngs[1][0]).to.eql([L.latLng([10, 20]), L.latLng([30, 40]), L.latLng([50, 60])]);
});
it('should add latlng by reference on a multipolygon with hole', () => {
const latLngs = [
[[[10, 20], [30, 40], [50, 60]]],
[[[0, 10], [10, 10], [10, 0]], [[2, 3], [2, 4], [3, 4]]]
];
const polygon = L.polygon(latLngs);
polygon.addLatLng([2, 2], polygon._latlngs[1][1]);
expect(polygon._latlngs[0][0]).to.eql([L.latLng([10, 20]), L.latLng([30, 40]), L.latLng([50, 60])]);
expect(polygon._latlngs[1][0]).to.eql([L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])]);
expect(polygon._latlngs[1][1]).to.eql([L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4]), L.latLng([2, 2])]);
});
});
describe('#setStyle', () => {
it('succeeds for empty Polygon already added to the map', () => {
const style = {
weight: 3
};
const polygon = L.polygon([]);
polygon.addTo(map);
polygon.setStyle(style);
for (const [prop, expectedValue] of Object.entries(style)) {
expect(polygon.options[prop]).to.equal(expectedValue);
}
});
});
});