Finished groups
This commit is contained in:
		| @@ -1,12 +1,15 @@ | ||||
|  | ||||
| import {getData, sendData} from "/js/libraries/serverTools.js" | ||||
|  | ||||
| export function getUser(user,callbackOuter) { | ||||
| export function getUser(user,loaded,callbackOuter) { | ||||
|     let callback = function(response) { | ||||
|         Object.assign(user,JSON.parse(response)) | ||||
|         if(callbackOuter!=undefined) { | ||||
|             callbackOuter() | ||||
|         } | ||||
|         loaded.update((val) => { | ||||
|             return val + 1 | ||||
|         }) | ||||
|     } | ||||
|     getData("/xx/get-user",callback) | ||||
| } | ||||
|   | ||||
| @@ -10,7 +10,7 @@ export function translate(content, x) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| function addMarkersToLayer(g,layer,content,locale,addPinContent,markerColor) { | ||||
| function addMarkersToLayer(g,layer,content,locale,addPinContent,markerColor,options) { | ||||
|     let {text,coordinates} = addPinContent(g,content,locale) | ||||
|     var markerIcon = new L.Icon({ | ||||
|         iconUrl: 'https://www.libsoc.org/img/common/markers/marker-' + markerColor + '.png', | ||||
| @@ -21,57 +21,69 @@ function addMarkersToLayer(g,layer,content,locale,addPinContent,markerColor) { | ||||
|         shadowSize: [41, 41] | ||||
|     }) | ||||
|     let marker = L.marker(coordinates, {icon: markerIcon}) | ||||
|     marker.id = g.id | ||||
|     marker.members = g.members | ||||
|     marker.contact = g.contact | ||||
|     marker.addTo(layer).bindPopup(text) | ||||
|      | ||||
|     if (options.pinCallback!=undefined) { | ||||
|         marker.on('click', (event) => options.pinCallback(marker,event)) | ||||
|     } | ||||
| } | ||||
|  | ||||
| export function addMarkersEntries(entries,entriesByCountry,map,content,locale,addPinContent,markerColor) { | ||||
| export function addMarkersEntries(entries,entriesByCountry,map,content,locale,addPinContent,markerColor,options) { | ||||
|     let entriesMarkersLayer = L.layerGroup() | ||||
|     let entriesMarkersLayerOut = L.layerGroup() | ||||
|     let entriesMarkersLayerIn = L.layerGroup() | ||||
|     for (let g of entries) { | ||||
|         if (g.country!="Online" && g.country!="Worldwide") { | ||||
|             addMarkersToLayer(g,entriesMarkersLayerIn,content,locale,addPinContent,markerColor) | ||||
|             addMarkersToLayer(g,entriesMarkersLayerIn,content,locale,addPinContent,markerColor,options) | ||||
|         } | ||||
|     } | ||||
|     for (let gs of Object.values(entriesByCountry)) { | ||||
|         if (gs.length==1) { | ||||
|             let g = {...gs[0]} | ||||
|             g.country = [g.country] | ||||
|             if (g.country!="Online" && g.country!="Worldwide") { | ||||
|                 addMarkersToLayer(g,entriesMarkersLayerOut,content,locale,addPinContent,markerColor) | ||||
|     if (options.enableCountryGrouping) { | ||||
|         for (let gs of Object.values(entriesByCountry)) { | ||||
|             if (gs.length==1) { | ||||
|                 let g = {...gs[0]} | ||||
|                 g.country = [g.country] | ||||
|                 if (g.country!="Online" && g.country!="Worldwide") { | ||||
|                     addMarkersToLayer(g,entriesMarkersLayerOut,content,locale,addPinContent,markerColor,options) | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         else { | ||||
|             if (gs[0].country!="Online" && gs[0].country!="Worldwide") { | ||||
|                 let locationName = gs[0].country | ||||
|                 let locationCoordinates = [0,0] | ||||
|                 let members = 0 | ||||
|                 let contact = gs[0].contact | ||||
|                 for (let g of gs) { | ||||
|                     locationCoordinates[0] += g.latitude | ||||
|                     locationCoordinates[1] += g.longitude | ||||
|                     members += g.members | ||||
|                     if (g.contact[0]!=gs[0].contact[0]) { | ||||
|                         contact = contactGeneral | ||||
|             else { | ||||
|                 if (gs[0].country!="Online" && gs[0].country!="Worldwide") { | ||||
|                     let locationName = gs[0].country | ||||
|                     let locationCoordinates = [0,0] | ||||
|                     let members = 0 | ||||
|                     let contact = gs[0].contact | ||||
|                     for (let g of gs) { | ||||
|                         locationCoordinates[0] += g.latitude | ||||
|                         locationCoordinates[1] += g.longitude | ||||
|                         members += g.members | ||||
|                         if (g.contact[0]!=gs[0].contact[0]) { | ||||
|                             contact = contactGeneral | ||||
|                         } | ||||
|                     } | ||||
|                     locationCoordinates[0] = locationCoordinates[0]/gs.length | ||||
|                     locationCoordinates[1] = locationCoordinates[1]/gs.length | ||||
|                     let gNew = { | ||||
|                         country: locationName, | ||||
|                         latitude: locationCoordinates[0], | ||||
|                         longitude: locationCoordinates[1], | ||||
|                         members: members, | ||||
|                         contact: contact | ||||
|                     } | ||||
|                     addMarkersToLayer(gNew,entriesMarkersLayerOut,content,locale,addPinContent,markerColor,options) | ||||
|                 } | ||||
|                 locationCoordinates[0] = locationCoordinates[0]/gs.length | ||||
|                 locationCoordinates[1] = locationCoordinates[1]/gs.length | ||||
|                 let gNew = { | ||||
|                     country: locationName, | ||||
|                     latitude: locationCoordinates[0], | ||||
|                     longitude: locationCoordinates[1], | ||||
|                     members: members, | ||||
|                     contact: contact | ||||
|                 } | ||||
|                 addMarkersToLayer(gNew,entriesMarkersLayerOut,content,locale,addPinContent,markerColor) | ||||
|             } | ||||
|         } | ||||
|         entriesMarkersLayerOut.addTo(entriesMarkersLayer) | ||||
|         map.on("zoomend", () => onZoomEnd(map,entriesMarkersLayer,entriesMarkersLayerOut,entriesMarkersLayerIn)) | ||||
|     } | ||||
|     else { | ||||
|         entriesMarkersLayerIn.addTo(entriesMarkersLayer) | ||||
|     } | ||||
|  | ||||
|     entriesMarkersLayerOut.addTo(entriesMarkersLayer) | ||||
|     entriesMarkersLayer.addTo(map) | ||||
|     map.on("zoomend", () => onZoomEnd(map,entriesMarkersLayer,entriesMarkersLayerOut,entriesMarkersLayerIn)) | ||||
|      | ||||
|     return entriesMarkersLayer | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 a-ill
					a-ill