Commit ddeadce5082d6391f500446b495814aa8d06387b
1 parent
92c924ed
plugin update
Showing
1 changed file
with
19 additions
and
10 deletions
datalets/leafletjs-geojson-datalet/leafletjs-geojson-datalet.html
@@ -89,34 +89,43 @@ Example: | @@ -89,34 +89,43 @@ Example: | ||
89 | 89 | ||
90 | L.Icon.Default.imagePath = 'http://services.routetopa.eu/DEEalerProvider/COMPONENTS/datalets/leafletjs-datalet/leafletsjs/images'; | 90 | L.Icon.Default.imagePath = 'http://services.routetopa.eu/DEEalerProvider/COMPONENTS/datalets/leafletjs-datalet/leafletsjs/images'; |
91 | 91 | ||
92 | - var coordinates = []; | ||
93 | - var coordinates_index = 0; | 92 | + //var coordinates = []; |
93 | + //var coordinates_index = 0; | ||
94 | + var geo_layer = L.geoJson(); | ||
94 | var geo; | 95 | var geo; |
95 | 96 | ||
96 | for (var i = 0; i < t.data[0].data.length; i++) | 97 | for (var i = 0; i < t.data[0].data.length; i++) |
97 | { | 98 | { |
98 | - if(typeof t.data[0].data[0] == 'Array') | 99 | + if(Array.isArray(t.data[0].data[i])) |
99 | { | 100 | { |
100 | - if(!isNaN(t.data[0].data[i][0]) && !isNaN(t.data[0].data[i][1])) | ||
101 | - coordinates.push([parseFloat(t.data[0].data[i][0]), parseFloat(t.data[0].data[i][1])]); | ||
102 | - else | 101 | + if(!isNaN(t.data[0].data[i][0]) && !isNaN(t.data[0].data[i][1])) { |
102 | + //coordinates.push([parseFloat(t.data[0].data[i][0]), parseFloat(t.data[0].data[i][1])]); | ||
103 | + geo_layer.addData({"type": "Feature","geometry": {"type": "Point", "coordinates": [parseFloat(t.data[0].data[i][0]), parseFloat(t.data[0].data[i][1])]}}); | ||
104 | + }else | ||
103 | continue; | 105 | continue; |
104 | } | 106 | } |
107 | + else if(typeof t.data[0].data[i] == 'object') | ||
108 | + { | ||
109 | + geo = L.geoJson(t.data[0].data[i]).addTo(t._component.map); | ||
110 | + geo_layer.addData(t.data[0].data[i]); | ||
111 | + } | ||
105 | else if(typeof t.data[0].data[i] == 'string' && t.data[0].data[i].startsWith('{"type":"')) | 112 | else if(typeof t.data[0].data[i] == 'string' && t.data[0].data[i].startsWith('{"type":"')) |
106 | { | 113 | { |
107 | try | 114 | try |
108 | { | 115 | { |
109 | t.data[0].data[i] = JSON.parse(t.data[0].data[i]); | 116 | t.data[0].data[i] = JSON.parse(t.data[0].data[i]); |
110 | geo = L.geoJson(t.data[0].data[i]).addTo(t._component.map); | 117 | geo = L.geoJson(t.data[0].data[i]).addTo(t._component.map); |
118 | + geo_layer.addData(t.data[0].data[i]); | ||
111 | }catch(e) {continue;} | 119 | }catch(e) {continue;} |
112 | } | 120 | } |
113 | else if(typeof t.data[0].data[i] == 'string' && t.data[0].data[i].indexOf(",")) | 121 | else if(typeof t.data[0].data[i] == 'string' && t.data[0].data[i].indexOf(",")) |
114 | { | 122 | { |
115 | var coords = t.data[0].data[i].split(","); | 123 | var coords = t.data[0].data[i].split(","); |
116 | if(!isNaN(coords[0]) && !isNaN(coords[1])) { | 124 | if(!isNaN(coords[0]) && !isNaN(coords[1])) { |
117 | - coordinates.push([parseFloat(coords[0]), parseFloat(coords[1])]); | ||
118 | - geo = L.marker([coordinates[coordinates_index][0], coordinates[coordinates_index][1]]).addTo(t._component.map); | ||
119 | - coordinates_index++; | 125 | + //coordinates.push([parseFloat(coords[0]), parseFloat(coords[1])]); |
126 | + geo_layer.addData({"type": "Feature","geometry": {"type": "Point", "coordinates": [parseFloat(coords[0]), parseFloat(coords[1])]}}); | ||
127 | + geo = L.marker([parseFloat(coords[0]), parseFloat(coords[1])]).addTo(t._component.map); | ||
128 | + //coordinates_index++; | ||
120 | }else | 129 | }else |
121 | continue; | 130 | continue; |
122 | } | 131 | } |
@@ -142,7 +151,7 @@ Example: | @@ -142,7 +151,7 @@ Example: | ||
142 | 151 | ||
143 | t._component.map._onResize(); | 152 | t._component.map._onResize(); |
144 | t._component.map.invalidateSize(false); | 153 | t._component.map.invalidateSize(false); |
145 | - t._component.map.fitBounds(coordinates); | 154 | + t._component.map.fitBounds(geo_layer); |
146 | 155 | ||
147 | } | 156 | } |
148 | }; | 157 | }; |