« Module:Infobox/Fonctions/Bâtiment » : différence entre les versions

De Lagny-sur-Marne Wiki
Aller à la navigation Aller à la recherche
0x010D (discussion | contributions)
typo
0x010D (discussion | contributions)
meilleure gestion des matériaux (pas de liens partout, et prépare les cas comme "huile sur toile", rationalisation de la fonction protection
Ligne 13 : Ligne 13 :
function p.mainimage(cat, defaultimage)
function p.mainimage(cat, defaultimage)
if not cat then  
if not cat then  
cat = 'Article à illustrer Bâtiment divers'
cat = 'Article à illusmtrer Bâtiment divers'
end
end
return general.mainimage(cat, defaultimage)
return general.mainimage(cat, defaultimage)
Ligne 212 : Ligne 212 :
label = 'Matériau',
label = 'Matériau',
value = 'matériau',  
value = 'matériau',  
wikidata = wikidatamod.formatAndCat{item = item, property = 'P186', showqualifiers = {'P518'}, showdate = true}
wikidata = function(item)
-- affiche le matériau en fonction de Property:P186, et de son qualificatif s'applique à
local linguistic = require('Module:Linguistique')
local materials = wikidatamod.getClaims{item = item, property = 'P186'}
if not materials then
return nil
end
local mainvals = {}
local supportvals = {} -- comme dans huile ''sur toile''
for i, j in pairs(materials) do
local val = wikidatamod.formatSnak(j.mainsnak)
local typ = 'main' -- changé en 'support' s'il faut la mettre sur supportstr
if j.qualifiers and j.qualifiers.P518 then -- P518: "s'applique à "
if wikidatamod.getRawvalue(j.qualifiers.P518[1]) == 'Q861259'  then
typ = 'support'
else
val = val ..linguistic.inparentheses(wikidatamod.formatSnak(j.qualifiers.P518[1], {link = '-'})) -- enlève le lien qui fait moche ici
end
end
if typ == 'support' then
table.insert(supportvals, val)
else
table.insert(mainvals, val)
end
local main = linguistic.conj(mainvals) or ''
local support = linguistic.conj(supportvals)
if support then
return main .. ' sur ' .. support
else
return main
end
end
end
}
}
end
end
Ligne 218 : Ligne 250 :


local function protectionline(localdata, item)
local function protectionline(localdata, item)
local logos = require('Module:Classement/Logo')
local protmodule = mw.loadData('Module:Classement/Données')
local texts = require('Module:Classement/Texte')
local claims = wikidatamod.getClaims({item=item, property = 'P1435', exludespecial = true})
local claims = wikidatamod.getClaims({item=item, property = 'P1435', exludespecial = true})
if not claims then return nil end
if not claims then
return nil
end
 
local statuses = {}-- nouvelle table pour ne pas afficher séparément deux statements décrivant le même statut
local statuses = {}-- nouvelle table pour ne pas afficher séparément deux statements décrivant le même statut
for i, j in pairs(claims) do
for i, j in pairs(claims) do
Ligne 233 : Ligne 267 :
local stringtable = {} -- liste des chaînes à retourner
local stringtable = {} -- liste des chaînes à retourner
for i, j in pairs(statuses) do
for i, j in pairs(statuses) do
local mainstr = texts[i] or wikidatamod.formatEntity(i) -- nom de la protection
local mainstr = ''
if protmodule[i] then
local logostr = '' -- logo
mainstr = protmodule[i][1]
local logo = logos[i]
else
if logo then  
mainstr = wikidatamod.formatEntity(i)
logostr = '[[File:' .. logo .. '|x18px]] '  
end
local logostr = ''
if protmodule[i] and protmodule[i][2] then
logostr = '[[File:' .. protmodule[i][2] .. '|x18px]] '  
end
end



Version du 7 mars 2015 à 07:01

local p = {} local wikidatamod = require 'Module:Wikidata' local general = require 'Module:Infobox/Fonctions' local coordfunctions = require 'Module:Infobox/Fonctions/Géolocalisation'

--Titre function p.title() -- local class = en-tête par défaut à définir ici ? return general.title() end

--Image function p.mainimage(cat, defaultimage) if not cat then cat = 'Article à illusmtrer Bâtiment divers' end return general.mainimage(cat, defaultimage) end

function p.country(default) return coordfunctions.country(default) end

function p.address() return nil end -- pour éviter un bug de tansitions, si vous lisez cela vous pouvez effacer la fonctions

function p.historicalregion() return { type = 'row', -- pour les régions historiques, non adminstratives value = 'région', label = 'Région', } end

function p.adminlocation() -- Fonction assez compliquée du fait des différences entre infobox. Simlifiable si on harmonise les infobox -- infobox à prendre en compte : bâtiment, gratte-ciel, gare, château return {type = 'multi', rows = { { type = 'row', value = function(localdata, item) return localdata['subdivision'] or localdata['subdivision1']end, label = function(localdata, item) return localdata['intitulé subdivision'] or localdata['lien subdivision1'] or localdata['lien subdivision'] or 'Subdivision administrative' end }, { type = 'row', value = 'subdivision2', label = function(localdata, item) return localdata['intitulé subdivision2'] or localdata['lien subdivision2'] or 'Subdivision administrative' end }, { type = 'row', value = 'subdivision3', label = function(localdata, item) return localdata['intitulé subdivision3'] or localdata['lien subdivision3'] or 'Subdivision administrative' end }, { type = 'row', value = function(localdata, item) return localdata['commune'] or localdata['ville'] end, label = function(localdata, item) return localdata['intitulé commune'] or localdata['lien commune'] or 'Commune' end }, { type = 'row', value = 'quartier', label = function(localdata, item) return localdata['intitulé quartier'] or localdata['titre quartier'] or 'Quartier' end }, { type = 'row', value = 'adresse', label = 'Adresse', wikidata = function(item) return require('Module:Adresse').wikidataAddress(item) end, } } } end

function p.coordinates(coordspecs) return coordfunctions.coordinates(coordspecs) end

function p.website() return general.website() end


function p.construction() return {type = 'multi', rows = { -- début construction (legacy infobox Stade) { type = 'mixed', label = 'Début de construction', value = 'début construction', }, -- construction { type = 'mixed', label = 'Date de construction', value = 'date de construction' or 'construction', wikidata = wikidatamod.getTheDate{property = 'P793', targetvalue = 'Q385378', addcat = true} or wikidatamod.formatAndCat{item = item, property = 'P571', showqualifiers = {'P518'}} }, -- ouverture { type = 'row', label = 'Ouverture', value = 'ouverture', --wikidata valeur de P793 ? }, -- inauguration { type = 'row', label = 'Inauguration', function(localdata, item) -- déactivé si le paramètre "ouverture" este renseigné : risques de doublon if localdata['ouverture'] then return nil end if localdata['inauguration'] then return localdata['inauguration'] end if item then return wikidatamod.getTheDate{property = 'P793', targetvalue = 'Q1417098', addcat = true, item=item} end end } } } end

function p.closure() return {type = 'row', label = 'Fermeture', value = function(localdata, item) return wikidatamod.getTheDate{property = 'P793', targetvalue = 'Q14954904', addcat = true, item=item} end } end

function p.operator() return {type = 'row', label = 'Gestionnaire', property = 'P137', value = function(localdata, item) return localdata['administration'] or localdata['gestionnaire'] end} end

function p.transport() return { {type = 'table', title = 'Accès et transport', rows = { {type = 'row', label = 'Stationnement', value = 'stationnement'}, {type = 'row', label = 'Gare', value = 'gare'}, {type = 'row', label = 'Métro', value = 'métro'}, {type = 'row', label = 'Tramway', value = 'bus'}, {type = 'row', label = 'Autobus', value = 'gare'}, }, } } end

function p.archistyle() return { type = 'row', label = 'Style architectural', value = function(localdata, item) return localdata['style architectural'] or localdata['style'] end, wikidata = function (item) return wikidatamod.formatAndCat{item = item, property = 'P149'} or wikidatamod.formatAndCat{item = item, property = 'P135'} end } end

function p.creator() -- toute sorte de créateurs, pourraient peut-être être partagé avec infobox oeuvre d'art return {type = 'multi', rows = { -- architect { type = 'row', label = function(localdata, item) return localdata['titre architecte'] or 'Architecte' end, value = 'architecte', wikidata = wikidatamod.formatAndCat{item = item, property = 'P84', showqualifiers = {'P518'}, showdate = true} }, -- ingénieur { type = 'row', label = 'Ingénieur', value = 'ingénieur', property = 'P631', }, -- créateur (quand les autres noms ne conviennent pas) { type = 'row', label = 'Créateur', value = function(localdata, item) if localdata['architecte'] then return nil end if localdata['créateur'] then return localdata['créateur'] end if item then return wikidatamod.formatAndCat{item = item, property = 'P170', showqualifiers = {'P518'}} end end }, } } end


function p.owner() return { type = 'row', label = 'Propriétaire', value = 'propriétaire', property = 'P631' } end

function p.material() return { type = 'row', label = 'Matériau', value = 'matériau', wikidata = function(item) -- affiche le matériau en fonction de Property:P186, et de son qualificatif s'applique à local linguistic = require('Module:Linguistique') local materials = wikidatamod.getClaims{item = item, property = 'P186'} if not materials then return nil end local mainvals = {} local supportvals = {} -- comme dans huile sur toile for i, j in pairs(materials) do local val = wikidatamod.formatSnak(j.mainsnak) local typ = 'main' -- changé en 'support' s'il faut la mettre sur supportstr if j.qualifiers and j.qualifiers.P518 then -- P518: "s'applique à " if wikidatamod.getRawvalue(j.qualifiers.P518[1]) == 'Q861259' then typ = 'support' else val = val ..linguistic.inparentheses(wikidatamod.formatSnak(j.qualifiers.P518[1], {link = '-'})) -- enlève le lien qui fait moche ici end end if typ == 'support' then table.insert(supportvals, val) else table.insert(mainvals, val) end local main = linguistic.conj(mainvals) or local support = linguistic.conj(supportvals) if support then return main .. ' sur ' .. support else return main end end end } end


local function protectionline(localdata, item) local protmodule = mw.loadData('Module:Classement/Données') local claims = wikidatamod.getClaims({item=item, property = 'P1435', exludespecial = true}) if not claims then return nil end

local statuses = {}-- nouvelle table pour ne pas afficher séparément deux statements décrivant le même statut for i, j in pairs(claims) do local pstatus = wikidatamod.getmainid(j) if not statuses[pstatus] then statuses[pstatus] = {j} else table.insert(statuses[pstatus], j) end end local stringtable = {} -- liste des chaînes à retourner for i, j in pairs(statuses) do local mainstr = if protmodule[i] then mainstr = protmodule[i][1] else mainstr = wikidatamod.formatEntity(i) end local logostr = if protmodule[i] and protmodule[i][2] then logostr = '[[File:' .. protmodule[i][2] .. '|x18px]] ' end

local t = {} -- informations complémentaires sur les dates et les parties concernées for k, l in pairs(j) do local protectiondate = wikidatamod.getFormattedQualifiers(l, {'P580'}, {precision = 'year'}) if protectiondate then table.insert(t, protectiondate) end end local details = table.concat(t, ", ") if details ~= then details = ' (' .. details .. ')' else details = end table.insert(stringtable, logostr .. mainstr .. details) end return table.concat(stringtable, '
') .. end

function p.protection(localdata, item) return { type = 'row', label = 'Protection', value = 'classement', wikidata = protectionline(locadata, item) } end

function p.geoloc(params) return coordfunctions.geoloc(params) end

return p