Module:Infobox/Fonctions/Géolocalisation
La documentation pour ce module peut être créée à Module:Infobox/Fonctions/Géolocalisation/doc
local localdata = require( 'Module:Infobox/Localdata' )
local item = localdata.item
local id
if item then
id = item.id
end
local wd = require "Module:Wikidata-fr"
-- Modules chargés si necessaire :
-- local countrymodule = require "Module:Country data"
-- local coord = require "Module:Coordinates"
local p = {}
function p.country()
local function formatCountry(country)
if not country then
return nil
end
local countrymodule = require "Module:Country data"
local val, success = countrymodule.standarddisplay(country) -- val = nil si country n'est pas reconnu
if success then
return val
end
end
return {
type = 'mixed',
label = 'Pays',
value = function() return formatCountry(localdata['pays']) or localdata['pays'] end,
wikidata = {
property = 'P17',
conjtype = 'new line',
displayformat = function(snak)
local id = wd.getId(snak)
return formatCountry(id) or wd.formatSnak(snak)
end
}
}
end
function p.coordvalue(moduleparams) -- valeurs des coordonnées, sans mise en infoboîte
local coord = require "Module:Coordinates"
if not moduleparams then
moduleparams = {}
end
local function toboolean(val) -- transforme un "-" en false au moment voulu
if val == '-' or val == 'non' then
return false
end
return true
end
-- paramètres Wikidata
local wikidata = tostring(toboolean(localdata['wikidata'] or true)) -- doit être string dans Module:Coordinates
local maxdistance = moduleparams.maxdistance
local wikidataquery = moduleparams.wikidataquery or {property = 'P625'}
if not wikidataquery.entity then
wikidataquery.entity = item
end
-- paramètres d'affichage
local displayformat = localdata['format coordonnées'], moduleparams.displayformat
local displayplace = ''
local displayinline = toboolean(localdata['coords en ligne'] or moduleparams.displayinline or true)
-- par défaut : on met dans les coordonnées de l'infobox principale en titre
local displaytitle = localdata['coords en titre']
or moduleparams.displaytitle
or (localdata['infoboxrank'] == 'main')
if displayinline and (displayinline ~= '-') then
displayplace = displayplace .. 'inline'
end
if displaytitle and (displaytitle ~= '-') then
displayplace = displayplace .. 'title,'
end
-- données sur géograhiques
local globe = localdata['globe'] or localdata['planète'] or moduleparams['globe'] or 'earth'
local latitude = moduleparams['latitude'] or localdata['latitude']
local longitude = moduleparams['longitude'] or localdata['longitude']
local parameterlist = {
latitude = latitude,
longitude = longitude,
format = displayformat,
display= displayplace,
globe = globe,
wikidata = wikidata,
wikidataquery = wikidataquery,
maxdistance = maxdistance,
}
local val = coord._coord(parameterlist)
if (not val) and moduleparams.fallbackquery then -- si pas de valeur, essayer la query de sustitution
parameterlist.wikidataquery = moduleparams.fallbackquery
parameterlist.wikidataquery.entity = item
val = coord._coord(parameterlist)
end
if val and latitude and longitude and localdata['référence géolocalisation'] then
val = val .. ' ' .. localdata['référence géolocalisation']
end
if val and not localdata['latitude'] then
val = wd.addLinkBack(val, item, wikidataquery.property)
end
if displayinline == false then
return -- type: external text pour ne pas avoir de ligne vide en infobox
{
type = 'external text',
sortkey = sortkey,
value = val
}
else
return val
end
end
function p.coordinates(moduleparams)
if not moduleparams then
moduleparams = {}
end
-- paramètre coordonnées a la priorité sur "géolocalisation" (=carte)
local relevant = localdata['coordonnées'] or localdata['géolocalisation']
if relevant == '-' or relevant == 'non' or relevant == 'pas pertinent' or relevant == 'non pertinent' then
return nil
end
-- initialise les paramètres avec les valeurs du module d'infobox (moduleparams)
return {
type = 'mixed',
label = 'Coordonnées',
maintenancecat = moduleparams.maintenancecat or 'Page géolocalisable sans coordonnées paramétrées',
sortkey = moduleparams.sortkey,
value = function (localdata) return p.coordvalue(moduleparams) end
}
end
function p.geoloc(params)
if not params then
params = {}
end
if (localdata['géolocalisation'] == '-') or (localdata['géolocalisation'] == 'pas pertinent') then
return nil
end
return {
type = 'map',
latitude = 'latitude',
longitude = 'longitude',
wikidata = params.wikidata or {{property = 'P625'}},
entity = item,
maps = function() return localdata['géolocalisation'] or params.defaultmaps or "interactive" end, -- paramètre pour la liste des cartes à utiliser
staticmaps = 'carte', -- carte en mode image simple
staticmapsWD = {property = "P242", numval = 1}, -- p
width = params.width,
pointtype = params.pointtype,
maptype = params.maptype,
globe = localdata.globe or localdata['planète'] or params.globe,
marker = params.marker,
markercolor = params.markercolor,
shapecolor = params.shapecolor,
default_zoom = localdata['zoom'] or params.default_zoom,
ids = params.ids or id,
params = {guessmaps = params.guessmaps} -- = quelles cartes utiliser en l'absence de données fournies dans |gélocalisation
}
end
function p.locationmap(upright)
return {
type = 'images',
imageparameters = {'carte','imageloc'},
sizeparameter = 'taille carte',
captionparameter = {'légende carte','légende imageloc'},
defaultupright = upright or '1',
property = 'P242',
numval = 1,
}
end
function p.detailedmap(defaultsize)
return {
type = 'images',
imageparameters = {'carte'},
sizeparameter = 'taille carte',
captionparameter = {'légende carte'},
defaultsize = defaultsize,
defaultupright = '1',
property = 'P1621',
numval = 1,
}
end
return p