Module:Infobox/Fonctions/Personne
< Module:Infobox | Fonctions
La documentation pour ce module peut être créée à Module:Infobox/Fonctions/Personne/doc
-- Functions utilisées par les infobox personnes local p = {} local wikidata = require "Module:Wikidata" local general = require "Module:Infobox/Fonctions" local datemodule = require "Module:Date" local function setgender() -- établit la valeur de la variable "gender" qui sert à adapter la grammaire au sexe de la personne local validvalues = { m = 'm', f = 'f', ['féminin'] = 'f', ['masculin'] = 'm', ['Q6581072'] = 'f', ['Q6581097'] = 'm', } local gender = localdata['sexe'] or localdata['genre'] or wikidata._formatStatements{item= item, property = 'P21', format = 'raw'} return validvalues[gender] end local gender = gender or setgender() local datelinks = { -- lien vers le domaine d'activité approprié Q483501 = 'en arts plastiques', -- artiste Q1028181 = 'en arts plastiques', -- peintre Q1281618 = 'en arts plastiques', -- sculpteur Q2309784 = 'en cyclisme', -- cycliste Q16947657 = 'en arts plastiques', -- lithographe } -- libellés spéciaux lorsque ceux de Wikidata ne conviennent pas local maleoccupations = {} local femaleoccupations = { Q33999 = '[[acteur|actrice]]',-- les liens internes sont-il nécessaires , Q177220 = '[[chanteur|chanteuse]]', Q639669 = '[[musicien|musicienne]]', Q1650915 = '[[chercheur|chercheuse]]', } local function getdatetopic() -- obtien le lien le plus approprié pour une date en fonction de la profession local claims = wikidata.getClaims{entity = item, property = 'P106', excludespecial = true} if not claims then return nil end for i, j in pairs(claims) do local v = wikidata.getRawvalue(j.mainsnak) if datelinks[v] then return datelinks[v] end end end local linktopic = getdatetopic() -- ========== Fonctions d'aide ==================================== local function dateandplace(thedate, theplace) if thedate and theplace then return thedate .. '<br />' .. theplace else return thedate or theplace --retourne tout ce qu'il trouve end end --Titre function p.title() return { type = 'title', value = 'nom', } end --Image function p.mainimage() return general.mainimage('Article à illustrer/Biographie', 'defaut.svg') end -- Noms function p.othernames() -- si "autres noms" existe, le renvoie, sinon, fait plusieurs lignes en utilisant diverses propriétés ed Wikidata if localdata['autres noms'] or localdata['nom de naissance'] then return {type = 'multi', rows = { {type = 'row', label = 'Autres noms', value = 'autres noms'}, {type = 'row', label ='Nom de naissance', value = 'nom de naissance'}, } } end local names = { {'P1477', 'Nom de naissance', 'Noms de naissance',}, {'P742', 'Peudonyme', 'Pseudonymes'}, {'P1782', 'Prénom social', 'Prénoms sociaux'}, {'P1787', 'Nom d’artiste', 'Noms d’artiste'}, } local function getval(row) local property = row[1] local claims = wikidata.getClaims{entity = item, property = property} if claims and #claims > 1 then label = row[3] else label = row[2] end local val = wikidata.formatAndCat{entity = item, property = property, showqualifiers = {'P1721'}, conjtype = ',<br />'} return val, label end local rows = {type = 'multi', rows = {}} for i, j in pairs(names) do local val, label = getval(j) if val then table.insert(rows.rows, {type = 'row', label = label, wikidata = function() return val end}) end end return rows end -- NAISSANCE ET MORT local function wikidatadate(prop) return wikidata.formatAndCat{entity = item, property = prop, conjtype = ' ou ', linktopic = linktopic} end local birthdate = localdata['naissance'] or localdata['date de naissance'] or wikidatadate('P569') or '' local deathdate = localdata['décès'] or localdata['date de décès'] or wikidatadate('P570') or '' function p.birth() -- date de naissance en première ligne, lieu de naissance en deuxième return { type = 'mixed', label = 'Naissance', value = function() local thedate = datemodule.dateInfobox{args = {[1] = 'naissance', [2] = birthdate, [3] = deathdate, qualificatif = linktopic}} local theplace = localdata['lieu de naissance'] or wikidata._formatAndCat({item = item, property= 'P19', rank = 'best', conjtype= ' ou '}) return dateandplace(thedate, theplace) end } end function p.death() -- même fonctionnement que la fonction p.birth return { type = 'mixed', label = 'Décès', value = function() local thedate = datemodule.dateInfobox{args = {[1] = 'décès', [3] = birthdate, [2] = deathdate, qualificatif = linktopic}} local theplace = localdata['lieu de décès'] or wikidata._formatAndCat({item = item, property= 'P20', rank = 'best', conjtype= ' ou '}) return dateandplace(thedate, theplace) end } end function p.floruit() return { type = 'row', label = 'Période d’activité' , value = 'Période d\'activité', wikidata = function() local claims = wikidata.getClaims{entity = item, property = 'P1317', numval = 1} if not claims then return end local startpoint = wikidata.getFormattedQualifiers(claims[1], {'P580'}) local endpoint = wikidata.getFormattedQualifiers(claims[1], {'P582'}) return require "Module:Date complexe".daterange(startpoint, endpoint) end } end function p.nationality() -- Wikidata désactivé avant 1800 (problème de fiabilité des données return { type = 'mixed', label = 'Nationalité', value = 'nationalité', wikidata = function() -- désactivé pour les personnes nées avant 1800, trop d'erreurs local timestamp = wikidata.formatStatements{entity = entity, property = 'P569', numval = 1, displayformat = 'raw'} if timestamp then local era, year = timestamp:match("(%W)(%d+)%-(%d+)%-(%d+)") if (not year) or tonumber(year) < 1800 then return nil end end -- local nation = require "Module:Country data".nationality return wikidata.formatAndCat{entity = item, property = 'P27', displayformat = function(snak) local val, success = nation(wikidata.getid(snak), 'f') if not success then val = wikidata.formatSnak(snak) end return val end } end } end -- parcours professionel function p.education() -- à améliorer return { type = 'mixed', label = 'Formation', value = function() return localdata['éducation'] or localdata['formation'] end, wikidata = function() return wikidata._formatAndCat{item=item, sorttype= 'chronological', property = 'P69', showdate = true, conjtype = '<br />'} end } end function p.occupation() return { type = 'mixed', label = 'Occupation', value = 'occupation', wikidata = function() if gender == 'f' then speciallabels = femaleoccupations elseif gender == 'm' then speciallabels = maleoccupations end return wikidata._formatAndCat{item=item, property = 'P106', showdate = true, conjtype = 'comma', speciallabels = speciallabels} end } end function p.politicalparty() return { type = 'mixed', label = 'Formation', value = 'parti politique', wikidata = function() return wikidata._formatAndCat{item=item, property = 'P102', sorttype= 'chronological', showdate = true, conjtype = '<br />'} end } end function p.awards() -- à améliorer return { type = 'mixed', label = 'Distinctions', value = function() return localdata['prix'] or localdata['récompenses'] or localdata['distinctions'] end, wikidata = function() return wikidata._formatAndCat{item = item, property= 'P166', sorttype= 'chronological' , showdate= true, conjtype= '<br />'} end, } end -- Influences function p.influencedby() return { type = 'mixed', label = function(localdata, item) if not gender then setgender(localdata, item) end if gender == 'f' then return 'Influencée par' elseif gender == 'm' then return 'Influencé par' else return 'Influencé(e) par' end end, value = 'influencé par', property = 'P737', } end function p.influenced() return { type = 'mixed', label = 'A influencé', value = function(localdata) return localdata['a influencé'] or localdata['influence de'] end, property = 'P738', } end -- Signature function p.signature(default) return { type = 'images', imageparameters = {'signature'}, defaultimage = default, defaultsize = '150px', captionparameter = 'légende signature', defaultcaption = 'signature', property = 'P109', numval = 1 } end --== Site web function p.website() return p.website() end return p