Update
This commit is contained in:
parent
9387cdca70
commit
242c50043d
|
@ -213,33 +213,7 @@ end
|
||||||
|
|
||||||
function groups_add_post()
|
function groups_add_post()
|
||||||
data = jsonpayload()
|
data = jsonpayload()
|
||||||
insert_into_table("groups",data)
|
insert_into_table("groups_requests",data)
|
||||||
end
|
end
|
||||||
#=
|
|
||||||
function compile_groups()
|
|
||||||
function table_to_json(name,t)
|
|
||||||
ar = []
|
|
||||||
for df_row in eachrow(t)
|
|
||||||
|
|
||||||
df_row = first(eachrow(df))
|
|
||||||
id = :town
|
|
||||||
location = String[]
|
|
||||||
for id in [:country,:state,:town]
|
|
||||||
if !isempty(df_row[id])
|
|
||||||
push!(location,df_row[id])
|
|
||||||
end
|
|
||||||
end
|
|
||||||
df = select_from_table(["groups" => ["*"]])
|
|
||||||
dict = Dict(
|
|
||||||
"location" => [location,[df_row[:latitude],df_row[:longitude]]],
|
|
||||||
"members" => df_row[:members],
|
|
||||||
"contact" => df_row[:contact]
|
|
||||||
)
|
|
||||||
end
|
|
||||||
return ar
|
|
||||||
end
|
|
||||||
df = select_from_table(["groups" => ["*"]])
|
|
||||||
|
|
||||||
end
|
end
|
||||||
=#
|
|
||||||
end
|
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
/*
|
||||||
export let groups = [
|
export let groups = [
|
||||||
{
|
{
|
||||||
location: [["Bulgaria","Varna"],[43.21582161671174, 27.89896092161012]],
|
location: [["Bulgaria","Varna"],[43.21582161671174, 27.89896092161012]],
|
||||||
|
@ -85,17 +86,7 @@ export let groups = [
|
||||||
contact: ["https://discord.gg/Qk8KUk787z","DiscordInviteLink"]
|
contact: ["https://discord.gg/Qk8KUk787z","DiscordInviteLink"]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
*/
|
||||||
export let groupsByCountry = {}
|
|
||||||
for (let g of groups) {
|
|
||||||
let country = g.location[0][0]
|
|
||||||
if (country in groupsByCountry) {
|
|
||||||
groupsByCountry[country].push(g)
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
groupsByCountry[country] = [g]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export let groupsMarkersLayer = L.layerGroup()
|
export let groupsMarkersLayer = L.layerGroup()
|
||||||
let groupsMarkersLayerOut = L.layerGroup()
|
let groupsMarkersLayerOut = L.layerGroup()
|
||||||
|
@ -116,13 +107,14 @@ export function translate(content, x) {
|
||||||
function addMarkersToLayer(g,layer,content,locale) {
|
function addMarkersToLayer(g,layer,content,locale) {
|
||||||
let coordinates
|
let coordinates
|
||||||
let text = "<b>"+content["Group"]+"</b><br>"
|
let text = "<b>"+content["Group"]+"</b><br>"
|
||||||
for (let field in g) {
|
for (let field of ["location","members","contact"]) {
|
||||||
|
|
||||||
let fieldText = content[field] + ": "
|
let fieldText = content[field] + ": "
|
||||||
if (field=="contact") {
|
if (field=="contact") {
|
||||||
text += fieldText + "<a href='" + g.contact[0] + "' target='_blank' rel=noreferrer>" + content[g.contact[1]] + "</a>"
|
text += fieldText + "<a href='" + g.contact + "' target='_blank' rel=noreferrer>" + g.contact + "</a>"
|
||||||
}
|
}
|
||||||
else if (field=="location") {
|
else if (field=="location") {
|
||||||
let location = g[field][0]
|
let location = [g.country,g.state,g.town].filter(x => x!=null && x!=undefined)
|
||||||
let locationString
|
let locationString
|
||||||
if (locale=="en") {
|
if (locale=="en") {
|
||||||
locationString = location.map(x => x).join(", ")
|
locationString = location.map(x => x).join(", ")
|
||||||
|
@ -131,7 +123,7 @@ function addMarkersToLayer(g,layer,content,locale) {
|
||||||
locationString = location.map(x => translate(content, x)).join(", ")
|
locationString = location.map(x => translate(content, x)).join(", ")
|
||||||
}
|
}
|
||||||
text += fieldText + locationString + "<br>"
|
text += fieldText + locationString + "<br>"
|
||||||
coordinates = g[field][1]
|
coordinates = [g.latitude,g.longitude]
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
text += fieldText + g[field] + "<br>"
|
text += fieldText + g[field] + "<br>"
|
||||||
|
@ -145,28 +137,29 @@ function addMarkersToLayer(g,layer,content,locale) {
|
||||||
popupAnchor: [1, -34],
|
popupAnchor: [1, -34],
|
||||||
shadowSize: [41, 41]
|
shadowSize: [41, 41]
|
||||||
})
|
})
|
||||||
|
//console.log(text)
|
||||||
let marker = L.marker(coordinates, {icon: markerIcon})
|
let marker = L.marker(coordinates, {icon: markerIcon})
|
||||||
marker.addTo(layer).bindPopup(text)
|
marker.addTo(layer).bindPopup(text)
|
||||||
}
|
}
|
||||||
|
|
||||||
export function addMarkersGroups(map,content,locale) {
|
export function addMarkersGroups(groups,groupsByCountry,map,content,locale) {
|
||||||
for (let g of groups) {
|
for (let g of groups) {
|
||||||
addMarkersToLayer(g,groupsMarkersLayerIn,content,locale)
|
addMarkersToLayer(g,groupsMarkersLayerIn,content,locale)
|
||||||
}
|
}
|
||||||
for (let gs of Object.values(groupsByCountry)) {
|
for (let gs of Object.values(groupsByCountry)) {
|
||||||
if (gs.length==1) {
|
if (gs.length==1) {
|
||||||
let g = {...gs[0]}
|
let g = {...gs[0]}
|
||||||
g.location[0] = [g.location[0][0]]
|
g.country = [g.country]
|
||||||
addMarkersToLayer(g,groupsMarkersLayerOut,content,locale)
|
addMarkersToLayer(g,groupsMarkersLayerOut,content,locale)
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
let locationName = [gs[0].location[0][0]]
|
let locationName = gs[0].country
|
||||||
let locationCoordinates = [0,0]
|
let locationCoordinates = [0,0]
|
||||||
let members = 0
|
let members = 0
|
||||||
let contact = gs[0].contact
|
let contact = gs[0].contact
|
||||||
for (let g of gs) {
|
for (let g of gs) {
|
||||||
locationCoordinates[0] += g.location[1][0]
|
locationCoordinates[0] += g.latitude
|
||||||
locationCoordinates[1] += g.location[1][1]
|
locationCoordinates[1] += g.longitude
|
||||||
members += g.members
|
members += g.members
|
||||||
if (g.contact[0]!=gs[0].contact[0]) {
|
if (g.contact[0]!=gs[0].contact[0]) {
|
||||||
contact = contactGeneral
|
contact = contactGeneral
|
||||||
|
@ -175,13 +168,16 @@ export function addMarkersGroups(map,content,locale) {
|
||||||
locationCoordinates[0] = locationCoordinates[0]/gs.length
|
locationCoordinates[0] = locationCoordinates[0]/gs.length
|
||||||
locationCoordinates[1] = locationCoordinates[1]/gs.length
|
locationCoordinates[1] = locationCoordinates[1]/gs.length
|
||||||
let gNew = {
|
let gNew = {
|
||||||
location: [locationName,locationCoordinates],
|
country: locationName,
|
||||||
|
latitude: locationCoordinates[0],
|
||||||
|
longitude: locationCoordinates[1],
|
||||||
members: members,
|
members: members,
|
||||||
contact: contact
|
contact: contact
|
||||||
}
|
}
|
||||||
addMarkersToLayer(gNew,groupsMarkersLayerOut,content,locale)
|
addMarkersToLayer(gNew,groupsMarkersLayerOut,content,locale)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
groupsMarkersLayerOut.addTo(groupsMarkersLayer)
|
groupsMarkersLayerOut.addTo(groupsMarkersLayer)
|
||||||
groupsMarkersLayer.addTo(map)
|
groupsMarkersLayer.addTo(map)
|
||||||
map.on("zoomend", () => onZoomEnd(map))
|
map.on("zoomend", () => onZoomEnd(map))
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
// Import statements
|
// Import statements
|
||||||
import { onMount } from 'svelte'
|
import { onMount } from 'svelte'
|
||||||
import { writable } from 'svelte/store';
|
import { writable } from 'svelte/store';
|
||||||
import { groupsByCountry, addMarkersGroups } from '/js/groups.js'
|
import { addMarkersGroups, translate } from '/js/groups.js'
|
||||||
import { loadLocaleContent, getData, sendData } from "/js/libraries/serverTools.js"
|
import { loadLocaleContent, getData, sendData } from "/js/libraries/serverTools.js"
|
||||||
|
|
||||||
// Import components
|
// Import components
|
||||||
|
@ -13,6 +13,30 @@
|
||||||
// Main code
|
// Main code
|
||||||
let loaded = writable(0)
|
let loaded = writable(0)
|
||||||
let content = writable({})
|
let content = writable({})
|
||||||
|
let groups
|
||||||
|
let groupsByCountry
|
||||||
|
|
||||||
|
let callback = (response) => {
|
||||||
|
groups = JSON.parse(response)
|
||||||
|
groupsByCountry = {}
|
||||||
|
for (let g of groups) {
|
||||||
|
let country = g.country
|
||||||
|
if (g.contact==null) {
|
||||||
|
g.contact = "https://discord.gg/Qk8KUk787z"
|
||||||
|
}
|
||||||
|
if (country in groupsByCountry) {
|
||||||
|
groupsByCountry[country].push(g)
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
groupsByCountry[country] = [g]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
loaded.update((val) => {
|
||||||
|
return val + 1
|
||||||
|
})
|
||||||
|
}
|
||||||
|
getData("/assets/groups.json",callback)
|
||||||
|
|
||||||
|
|
||||||
let confirmationMsg
|
let confirmationMsg
|
||||||
let addressInput
|
let addressInput
|
||||||
|
@ -76,7 +100,7 @@
|
||||||
|
|
||||||
function mapCallbackGroups(createMap,content,locale) {
|
function mapCallbackGroups(createMap,content,locale) {
|
||||||
let map = createMap([22, 0],2)
|
let map = createMap([22, 0],2)
|
||||||
addMarkersGroups(map,content,locale)
|
addMarkersGroups(groups,groupsByCountry,map,content,locale)
|
||||||
|
|
||||||
userPin.addTo(map)
|
userPin.addTo(map)
|
||||||
map.on('click', function(event) {
|
map.on('click', function(event) {
|
||||||
|
@ -111,8 +135,7 @@
|
||||||
town: addressVec[2],
|
town: addressVec[2],
|
||||||
latitude: userPinLat,
|
latitude: userPinLat,
|
||||||
longitude: userPinLng,
|
longitude: userPinLng,
|
||||||
contact: contactInput.value,
|
contact: contactInput.value
|
||||||
members: 1
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (data.state=="") {
|
if (data.state=="") {
|
||||||
|
@ -139,7 +162,7 @@
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
{#key $loaded}
|
{#key $loaded}
|
||||||
{#if $loaded==2}
|
{#if $loaded==3}
|
||||||
<div id="container">
|
<div id="container">
|
||||||
<!--<img src="img/crowd.png" id="crowd" alt="crowd">-->
|
<!--<img src="img/crowd.png" id="crowd" alt="crowd">-->
|
||||||
<div id="text-container">
|
<div id="text-container">
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
// Import statements
|
// Import statements
|
||||||
import { onMount } from 'svelte'
|
import { onMount } from 'svelte'
|
||||||
import { writable } from 'svelte/store';
|
import { writable } from 'svelte/store';
|
||||||
import { groupsByCountry, addMarkersGroups, translate } from '/js/groups.js'
|
import { addMarkersGroups, translate } from '/js/groups.js'
|
||||||
import { loadLocaleContent, getData, sendData } from "/js/libraries/serverTools.js"
|
import { loadLocaleContent, getData, sendData } from "/js/libraries/serverTools.js"
|
||||||
|
|
||||||
// Import components
|
// Import components
|
||||||
|
@ -13,21 +13,47 @@
|
||||||
// Main code
|
// Main code
|
||||||
let loaded = writable(0)
|
let loaded = writable(0)
|
||||||
let content = writable({})
|
let content = writable({})
|
||||||
|
let groups
|
||||||
|
let groupsByCountry
|
||||||
|
|
||||||
let locale = loadLocaleContent(content,"groups-component",loaded)
|
let locale = loadLocaleContent(content,"groups-component",loaded)
|
||||||
loadLocaleContent(content,"countries",loaded)
|
loadLocaleContent(content,"countries",loaded)
|
||||||
|
|
||||||
|
let callback = (response) => {
|
||||||
|
groups = JSON.parse(response)
|
||||||
|
groupsByCountry = {}
|
||||||
|
for (let g of groups) {
|
||||||
|
let country = g.country
|
||||||
|
if (g.contact==null) {
|
||||||
|
g.contact = "https://discord.gg/Qk8KUk787z"
|
||||||
|
}
|
||||||
|
if (country in groupsByCountry) {
|
||||||
|
groupsByCountry[country].push(g)
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
groupsByCountry[country] = [g]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
loaded.update((val) => {
|
||||||
|
return val + 1
|
||||||
|
})
|
||||||
|
}
|
||||||
|
getData("/assets/groups.json",callback)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
function mapCallbackGroups(createMap,content,locale) {
|
function mapCallbackGroups(createMap,content,locale) {
|
||||||
let map = createMap([22, 0],2)
|
let map = createMap([22, 0],2)
|
||||||
addMarkersGroups(map,content,locale)
|
addMarkersGroups(groups,groupsByCountry,map,content,locale)
|
||||||
}
|
}
|
||||||
|
|
||||||
function getCountry(x) {
|
function getCountry(x) {
|
||||||
return locale=="en" ? x : translate($content,x)
|
return locale=="en" ? x : translate($content,x)
|
||||||
}
|
}
|
||||||
|
|
||||||
function getAddress(group) {
|
function getAddress(g) {
|
||||||
return group.location[0].map(x => locale=="en" ? x : translate($content,x)).join(", ")
|
let location = [g.country,g.state,g.town].filter(x => x!=null)
|
||||||
|
return location.map(x => locale=="en" ? x : translate($content,x)).join(", ")
|
||||||
}
|
}
|
||||||
|
|
||||||
onMount(() => {
|
onMount(() => {
|
||||||
|
@ -36,7 +62,7 @@
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
{#key $loaded}
|
{#key $loaded}
|
||||||
{#if $loaded==2}
|
{#if $loaded==3}
|
||||||
<div id="container">
|
<div id="container">
|
||||||
<!--<img src="img/crowd.png" id="crowd" alt="crowd">-->
|
<!--<img src="img/crowd.png" id="crowd" alt="crowd">-->
|
||||||
<div id="text-container">
|
<div id="text-container">
|
||||||
|
@ -53,7 +79,7 @@
|
||||||
<div class="location-info">
|
<div class="location-info">
|
||||||
<p><b>{$content.location}: </b>{getAddress(group)}</p>
|
<p><b>{$content.location}: </b>{getAddress(group)}</p>
|
||||||
<p><b>{$content.members}: </b>{group.members}</p>
|
<p><b>{$content.members}: </b>{group.members}</p>
|
||||||
<p><b>{$content.contact}: </b><a href={group.contact[0]} target=;_blank; rel=noreferrer>{$content[group.contact[1]]}</a></p>
|
<p><b>{$content.contact}: </b><a href={group.contact} target=;_blank; rel=noreferrer>{group.contact}</a></p>
|
||||||
</div>
|
</div>
|
||||||
{/each}
|
{/each}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -0,0 +1,32 @@
|
||||||
|
module CreateTableGroupsRequests
|
||||||
|
|
||||||
|
import SearchLight.Migrations: create_table, column, primary_key, add_index, drop_table
|
||||||
|
|
||||||
|
include("../../lib/DatabaseSupport.jl")
|
||||||
|
using .DatabaseSupport
|
||||||
|
|
||||||
|
function up()
|
||||||
|
create_table(:groups_requests) do
|
||||||
|
[
|
||||||
|
primary_key()
|
||||||
|
column(:id_given, :integer)
|
||||||
|
column(:country, :string)
|
||||||
|
column(:state, :string)
|
||||||
|
column(:town, :string)
|
||||||
|
column(:contact, :string)
|
||||||
|
column(:latitude, :float)
|
||||||
|
column(:longitude, :float)
|
||||||
|
column(:verified, :bool)
|
||||||
|
column(:added, :bool)
|
||||||
|
]
|
||||||
|
end
|
||||||
|
|
||||||
|
set_default("groups_requests","verified",false)
|
||||||
|
set_default("groups_requests","added",false)
|
||||||
|
end
|
||||||
|
|
||||||
|
function down()
|
||||||
|
drop_table(:groups)
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -4,7 +4,7 @@ module DatabaseSupport
|
||||||
using SearchLight, SearchLightPostgreSQL, LibPQ
|
using SearchLight, SearchLightPostgreSQL, LibPQ
|
||||||
using DataFrames
|
using DataFrames
|
||||||
|
|
||||||
export exist_in_table, insert_into_table, update_table, select_from_table, add_foreign_key
|
export exist_in_table, insert_into_table, update_table, select_from_table, add_foreign_key, set_default
|
||||||
|
|
||||||
options = SearchLight.Configuration.read_db_connection_data("db/connection.yml")
|
options = SearchLight.Configuration.read_db_connection_data("db/connection.yml")
|
||||||
conn = SearchLight.connect(options)
|
conn = SearchLight.connect(options)
|
||||||
|
@ -12,7 +12,7 @@ conn = SearchLight.connect(options)
|
||||||
function format(x)
|
function format(x)
|
||||||
if (x isa String) || (x isa Symbol)
|
if (x isa String) || (x isa Symbol)
|
||||||
return string("'",x,"'")
|
return string("'",x,"'")
|
||||||
elseif (isnothing(x))
|
elseif (isnothing(x) || ismissing(x))
|
||||||
return "NULL"
|
return "NULL"
|
||||||
else
|
else
|
||||||
return x
|
return x
|
||||||
|
@ -33,7 +33,7 @@ end
|
||||||
function update_table(table_name,dict_values; where_data=nothing)
|
function update_table(table_name,dict_values; where_data=nothing)
|
||||||
ns = collect(keys(dict_values))
|
ns = collect(keys(dict_values))
|
||||||
vals_raw = values(dict_values)
|
vals_raw = values(dict_values)
|
||||||
vals = map(x -> x isa String ? string("'",x,"'") : x,vals_raw)
|
vals = map(x -> format(x),vals_raw)
|
||||||
ns_vals = join(map((x,y) -> string(x, " = ",y),ns,vals),", ")
|
ns_vals = join(map((x,y) -> string(x, " = ",y),ns,vals),", ")
|
||||||
|
|
||||||
query = "UPDATE $table_name SET $ns_vals"
|
query = "UPDATE $table_name SET $ns_vals"
|
||||||
|
@ -144,4 +144,11 @@ function add_foreign_key(table,name,table2,name2)
|
||||||
SearchLight.query(query)
|
SearchLight.query(query)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function set_default(table,column,value)
|
||||||
|
query = """
|
||||||
|
ALTER TABLE $table
|
||||||
|
ALTER COLUMN $column SET DEFAULT $value ;"""
|
||||||
|
SearchLight.query(query)
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,57 @@
|
||||||
|
|
||||||
|
using SearchLight, SearchLightPostgreSQL, LibPQ, JSON3
|
||||||
|
using DataFrames
|
||||||
|
include("../lib/DatabaseSupport.jl")
|
||||||
|
using .DatabaseSupport
|
||||||
|
|
||||||
|
function table_to_json(name,df)
|
||||||
|
ar = []
|
||||||
|
for df_row in eachrow(df)
|
||||||
|
dict = Dict()
|
||||||
|
for id in names(df_row)
|
||||||
|
dict[id] = df_row[id]
|
||||||
|
end
|
||||||
|
push!(ar,dict)
|
||||||
|
end
|
||||||
|
open("public/assets/"*name*".json", "w") do io
|
||||||
|
JSON3.write(io, ar)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function compile_groups()
|
||||||
|
df = select_from_table(["groups" => ["*"]])
|
||||||
|
table_to_json("groups",df)
|
||||||
|
end
|
||||||
|
|
||||||
|
function move_requests()
|
||||||
|
df_requests = select_from_table(["groups_requests" => ["*"]], where_data=["verified" => true, "added" => false])
|
||||||
|
df = select_from_table(["groups" => ["*"]])
|
||||||
|
latitudes = df.latitude
|
||||||
|
longitudes = df.longitude
|
||||||
|
for df_row in eachrow(df_requests)
|
||||||
|
ind_id_given = ismissing(df_row.id_given) ? nothing : findfirst(df_row.id_given.==df.id)
|
||||||
|
if (!isnothing(ind_id_given))
|
||||||
|
id = df[ind_id_given,:id]
|
||||||
|
row_found = df[ind_id_given,Not(:id)]
|
||||||
|
dict = Dict(zip(names(row_found),values(row_found)))
|
||||||
|
dict["members"] += 1
|
||||||
|
update_table("groups",dict, where_data=["id" => id])
|
||||||
|
else
|
||||||
|
id = df_row.id
|
||||||
|
dict_update = Dict("added" => true)
|
||||||
|
update_table("groups_requests",dict_update, where_data=["id" => id])
|
||||||
|
|
||||||
|
df_row_to_add = df_row[Not(:id_given)]
|
||||||
|
df_row_to_add = df_row_to_add[Not(:verified)]
|
||||||
|
df_row_to_add = df_row_to_add[Not(:added)]
|
||||||
|
df_row_to_add = df_row_to_add[Not(:id)]
|
||||||
|
dict = Dict(zip(names(df_row_to_add),values(df_row_to_add)))
|
||||||
|
dict["members"] = 1
|
||||||
|
insert_into_table("groups",dict)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
move_requests()
|
||||||
|
compile_groups()
|
|
@ -0,0 +1 @@
|
||||||
|
[{"town":"Atlanta","contact":null,"latitude":33.7243396617476,"longitude":-84.39697265625,"id":9,"members":1,"country":"United States","state":"Georgia"},{"town":null,"contact":null,"latitude":39.98855476000615,"longitude":-105.2105712890625,"id":10,"members":1,"country":"United States","state":"Colorado"},{"town":null,"contact":null,"latitude":28.27955105276024,"longitude":-81.47460937500001,"id":11,"members":1,"country":"United States","state":"Florida"},{"town":"Dublin","contact":null,"latitude":40.13360099478965,"longitude":-83.10607910156251,"id":12,"members":1,"country":"United States","state":"Ohio"},{"town":"Toronto","contact":null,"latitude":43.68959002213805,"longitude":-79.36523437500001,"id":13,"members":1,"country":"Canada","state":"Ontario"},{"town":"Halifax","contact":null,"latitude":44.64996307546047,"longitude":-63.60809326171876,"id":14,"members":1,"country":"Canada","state":"Nova Scotia"},{"town":null,"contact":null,"latitude":53.353612430518126,"longitude":-8.085937500000002,"id":15,"members":1,"country":"Ireland","state":null},{"town":"Cham","contact":null,"latitude":47.18444711300418,"longitude":8.461189270019533,"id":16,"members":1,"country":"Switzerland","state":"Zug"},{"town":"Wiesbaden","contact":null,"latitude":50.085975903187155,"longitude":8.240432739257814,"id":17,"members":1,"country":"Germany","state":"Hesse"},{"town":"Copenhagen","contact":null,"latitude":55.68832070332783,"longitude":12.568359375000002,"id":18,"members":1,"country":"Denmark","state":"Capital Region of Denmark"},{"town":"Kolding","contact":null,"latitude":55.5095568556412,"longitude":9.486694335937502,"id":19,"members":1,"country":"Denmark","state":null},{"town":"Municipal Unit of Moschato","contact":null,"latitude":37.950275539773436,"longitude":23.673992156982425,"id":20,"members":1,"country":"Greece","state":"Attica"},{"town":"Varna","contact":null,"latitude":43.18381722560103,"longitude":27.905273437500004,"id":21,"members":1,"country":"Bulgaria","state":null},{"town":"Riga","contact":null,"latitude":56.966939887376796,"longitude":24.142456054687504,"id":22,"members":1,"country":"Latvia","state":"Vidzeme"},{"town":"Kohtla-Järve linn","contact":null,"latitude":59.40196127188141,"longitude":27.28042602539063,"id":23,"members":1,"country":"Estonia","state":null},{"town":"Tallinn","contact":null,"latitude":59.39656672058008,"longitude":24.72610473655427,"id":24,"members":1,"country":"Estonia","state":null},{"town":"Chiang Mai","contact":null,"latitude":18.796128352413316,"longitude":98.98753015423392,"id":25,"members":1,"country":"Thailand","state":null}]
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -1,3 +1,4 @@
|
||||||
|
/*
|
||||||
export let groups = [
|
export let groups = [
|
||||||
{
|
{
|
||||||
location: [["Bulgaria","Varna"],[43.21582161671174, 27.89896092161012]],
|
location: [["Bulgaria","Varna"],[43.21582161671174, 27.89896092161012]],
|
||||||
|
@ -85,17 +86,7 @@ export let groups = [
|
||||||
contact: ["https://discord.gg/Qk8KUk787z","DiscordInviteLink"]
|
contact: ["https://discord.gg/Qk8KUk787z","DiscordInviteLink"]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
*/
|
||||||
export let groupsByCountry = {}
|
|
||||||
for (let g of groups) {
|
|
||||||
let country = g.location[0][0]
|
|
||||||
if (country in groupsByCountry) {
|
|
||||||
groupsByCountry[country].push(g)
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
groupsByCountry[country] = [g]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export let groupsMarkersLayer = L.layerGroup()
|
export let groupsMarkersLayer = L.layerGroup()
|
||||||
let groupsMarkersLayerOut = L.layerGroup()
|
let groupsMarkersLayerOut = L.layerGroup()
|
||||||
|
@ -116,13 +107,14 @@ export function translate(content, x) {
|
||||||
function addMarkersToLayer(g,layer,content,locale) {
|
function addMarkersToLayer(g,layer,content,locale) {
|
||||||
let coordinates
|
let coordinates
|
||||||
let text = "<b>"+content["Group"]+"</b><br>"
|
let text = "<b>"+content["Group"]+"</b><br>"
|
||||||
for (let field in g) {
|
for (let field of ["location","members","contact"]) {
|
||||||
|
|
||||||
let fieldText = content[field] + ": "
|
let fieldText = content[field] + ": "
|
||||||
if (field=="contact") {
|
if (field=="contact") {
|
||||||
text += fieldText + "<a href='" + g.contact[0] + "' target='_blank' rel=noreferrer>" + content[g.contact[1]] + "</a>"
|
text += fieldText + "<a href='" + g.contact + "' target='_blank' rel=noreferrer>" + g.contact + "</a>"
|
||||||
}
|
}
|
||||||
else if (field=="location") {
|
else if (field=="location") {
|
||||||
let location = g[field][0]
|
let location = [g.country,g.state,g.town].filter(x => x!=null && x!=undefined)
|
||||||
let locationString
|
let locationString
|
||||||
if (locale=="en") {
|
if (locale=="en") {
|
||||||
locationString = location.map(x => x).join(", ")
|
locationString = location.map(x => x).join(", ")
|
||||||
|
@ -131,7 +123,7 @@ function addMarkersToLayer(g,layer,content,locale) {
|
||||||
locationString = location.map(x => translate(content, x)).join(", ")
|
locationString = location.map(x => translate(content, x)).join(", ")
|
||||||
}
|
}
|
||||||
text += fieldText + locationString + "<br>"
|
text += fieldText + locationString + "<br>"
|
||||||
coordinates = g[field][1]
|
coordinates = [g.latitude,g.longitude]
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
text += fieldText + g[field] + "<br>"
|
text += fieldText + g[field] + "<br>"
|
||||||
|
@ -145,28 +137,29 @@ function addMarkersToLayer(g,layer,content,locale) {
|
||||||
popupAnchor: [1, -34],
|
popupAnchor: [1, -34],
|
||||||
shadowSize: [41, 41]
|
shadowSize: [41, 41]
|
||||||
})
|
})
|
||||||
|
//console.log(text)
|
||||||
let marker = L.marker(coordinates, {icon: markerIcon})
|
let marker = L.marker(coordinates, {icon: markerIcon})
|
||||||
marker.addTo(layer).bindPopup(text)
|
marker.addTo(layer).bindPopup(text)
|
||||||
}
|
}
|
||||||
|
|
||||||
export function addMarkersGroups(map,content,locale) {
|
export function addMarkersGroups(groups,groupsByCountry,map,content,locale) {
|
||||||
for (let g of groups) {
|
for (let g of groups) {
|
||||||
addMarkersToLayer(g,groupsMarkersLayerIn,content,locale)
|
addMarkersToLayer(g,groupsMarkersLayerIn,content,locale)
|
||||||
}
|
}
|
||||||
for (let gs of Object.values(groupsByCountry)) {
|
for (let gs of Object.values(groupsByCountry)) {
|
||||||
if (gs.length==1) {
|
if (gs.length==1) {
|
||||||
let g = {...gs[0]}
|
let g = {...gs[0]}
|
||||||
g.location[0] = [g.location[0][0]]
|
g.country = [g.country]
|
||||||
addMarkersToLayer(g,groupsMarkersLayerOut,content,locale)
|
addMarkersToLayer(g,groupsMarkersLayerOut,content,locale)
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
let locationName = [gs[0].location[0][0]]
|
let locationName = gs[0].country
|
||||||
let locationCoordinates = [0,0]
|
let locationCoordinates = [0,0]
|
||||||
let members = 0
|
let members = 0
|
||||||
let contact = gs[0].contact
|
let contact = gs[0].contact
|
||||||
for (let g of gs) {
|
for (let g of gs) {
|
||||||
locationCoordinates[0] += g.location[1][0]
|
locationCoordinates[0] += g.latitude
|
||||||
locationCoordinates[1] += g.location[1][1]
|
locationCoordinates[1] += g.longitude
|
||||||
members += g.members
|
members += g.members
|
||||||
if (g.contact[0]!=gs[0].contact[0]) {
|
if (g.contact[0]!=gs[0].contact[0]) {
|
||||||
contact = contactGeneral
|
contact = contactGeneral
|
||||||
|
@ -175,13 +168,16 @@ export function addMarkersGroups(map,content,locale) {
|
||||||
locationCoordinates[0] = locationCoordinates[0]/gs.length
|
locationCoordinates[0] = locationCoordinates[0]/gs.length
|
||||||
locationCoordinates[1] = locationCoordinates[1]/gs.length
|
locationCoordinates[1] = locationCoordinates[1]/gs.length
|
||||||
let gNew = {
|
let gNew = {
|
||||||
location: [locationName,locationCoordinates],
|
country: locationName,
|
||||||
|
latitude: locationCoordinates[0],
|
||||||
|
longitude: locationCoordinates[1],
|
||||||
members: members,
|
members: members,
|
||||||
contact: contact
|
contact: contact
|
||||||
}
|
}
|
||||||
addMarkersToLayer(gNew,groupsMarkersLayerOut,content,locale)
|
addMarkersToLayer(gNew,groupsMarkersLayerOut,content,locale)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
groupsMarkersLayerOut.addTo(groupsMarkersLayer)
|
groupsMarkersLayerOut.addTo(groupsMarkersLayer)
|
||||||
groupsMarkersLayer.addTo(map)
|
groupsMarkersLayer.addTo(map)
|
||||||
map.on("zoomend", () => onZoomEnd(map))
|
map.on("zoomend", () => onZoomEnd(map))
|
||||||
|
|
Loading…
Reference in New Issue