Vai al contenuto

Modulo:P703

Da Wikipedia, l'enciclopedia libera.

Descrizione

[modifica wikitesto]

Questo modulo mostra gli organismi provenienti dalla proprietà Wikidata P703 (“trovato nel taxon”) con citazioni integrate estratte direttamente dai riferimenti Wikidata. È “completamente autonomo” e non dipende da alcun modulo esterno, il che lo rende facilmente trasferibile a tutti i progetti Wikimedia.

Caratteristiche principali

[modifica wikitesto]
  • Nessuna dipendenza : nessuna dipendenza da citazioni specifiche di una lingua o da moduli Wikidata
  • Citazioni integrate : estrae e formatta automaticamente i dati bibliografici da Wikidata
  • Collegamenti interwiki intelligenti : collegamenti ad articoli locali, reindirizzamento ad altre lingue o Wikidata
  • Altamente configurabile : numero di visualizzazioni e comportamento delle citazioni personalizzabili
  • Pronto per l'internazionalizzazione: facile da tradurre tramite la tabella i18n

Sintassi di base

[modifica wikitesto]
{{#invoke:P703|main}}

Con parametri personalizzati

[modifica wikitesto]
{{#invoke:P703|main|qid=Q3613679|numval=10|sources=true}}

Nelle infobox

[modifica wikitesto]
|organisms={{#if: {{#property:P703}} | {{#invoke:P703|main}} | }}
Parametro Descrizione Valore predefinito Valori validi
qid ID dell'entità Wikidata da interrogare QID della pagina corrente Qualsiasi identificativo Q valido (ad esempio, Q3613679)
numval Numero massimo di organismi da visualizzare 5 Qualsiasi numero intero positivo
sources Visualizza le citazioni online true true, false, yes, no

Comportamento

[modifica wikitesto]

Il modulo adatta il proprio output in base al numero di organismi trovati:

Scenario Formato di output Esempio
Nessun organismo Restituisce il messaggio localizzato “nessun organismo conosciuto” nessun organismo conosciuto
Da 1 a n organismi Visualizza il numero e l'elenco completo 3 organismi: umano, topo, ratto
Più di n organismi Visualizza il numero con il prefisso «fra cui» 15 organismi, fra cui: umano, topo, ratto, cane, gatto

Esempio 1: uso standard (pagina corrente)

[modifica wikitesto]
{{#invoke:P703|main}}

Risultato: 2 organismi: umano, topo

Esempio 2: entità specifica

[modifica wikitesto]
{{#invoke:P703|main|qid=Q3613679}}

Risultato: Visualizza gli organismi per l'elemento Wikidata Q3613679.

Esempio 3: Visualizza 20 organismi

[modifica wikitesto]
{{#invoke:P703|main|numval=20}}

Risultato: 25 organismi, tra cui: [i primi 20 organismi]

Esempio 4: senza citazioni

[modifica wikitesto]
{{#invoke:P703|main|sources=false}}

Risultato: 5 organismi: umano, topo, ratto, cane, gatto ‘’(senza tag di riferimento)‘’

Esempio 5: combinare tutti i parametri

[modifica wikitesto]
{{#invoke:P703|main|qid=Q2079986|numval=3|sources=true}}

‘’'Risultato:‘’' 10 organismi, tra cui: Organismo₁[1], Organismo₂[2], Organismo₃[3]

Formato di citazione

[modifica wikitesto]

Quando sources=true (impostazione predefinita), il modulo estrae e formatta automaticamente i dati bibliografici dai riferimenti Wikidata:

Campi supportati:

  • Autori (fino a 3, poi “et al.”)
  • Titolo dell'articolo (con URL facoltativo)
  • Nome della rivista (in corsivo)
  • Volume (in grassetto) e numero di pubblicazione
  • Numeri di pagina
  • Anno di pubblicazione
  • Identificatori DOI e PMID

Esempio di citazione:

Smith J, Jones A, Williams B et al. « Protein Expression in Model Organisms ». 
Nature Genetics 45 (3): pp. 123-130. (2023). doi:10.1038/ng.3456. pmid:12345678.

Logica dei collegamenti interwiki

[modifica wikitesto]

Il modulo sceglie in modo intelligente il collegamento migliore per ogni organismo:

  1. Articolo wiki locale esistente[[Articolo locale|Etichetta]]
  2. Articolo esistente su un altro wikiEtichetta (lang)
  3. Nessun articolo trovatoEtichetta (d)

Ciò garantisce che gli utenti possano sempre accedere alle informazioni sull'organismo, anche se non esiste alcun articolo locale.

Internazionalizzazione

[modifica wikitesto]

Per adattare questo modulo ad altre lingue, modificare la tabella i18n nel codice:

local i18n = {
    no_organism = nessun organismo conosciuto,     -- Esempio in italiano
    including = di cui,
    wd_label = d,
    separator = ,,
    organism = organismo,
    organisms = organismi
}

Dettagli tecnici

[modifica wikitesto]

Ottimizzazioni delle prestazioni

[modifica wikitesto]
  • Caching delle entità: impedisce chiamate API ridondanti per le fonti referenziate.
  • Valutazione pigra: recupera i dati solo quando necessario.
  • Elaborazione efficiente delle richieste: si ferma al limite numval.

Nessuna dipendenza

[modifica wikitesto]

A differenza della maggior parte dei moduli, P703 è “completamente autonomo”:

  • Nessun Module:LanguageSpecificModule
  • Utilizzo diretto solo dell'API Wikibase

Questo lo rende:

  • Facile da implementare su qualsiasi progetto Wikimedia
  • Facile da mantenere senza aggiornamenti esterni del modulo
  • Coerente tra wiki in lingue diverse

Gestione degli errori

[modifica wikitesto]
Scenario Risposta del modulo
Nessun QID fornito Utilizza l'elemento Wikidata della pagina corrente
QID non valido Restituisce “nessun organismo conosciuto”
Nessuna rivendicazione P703 Restituisce “nessun organismo conosciuto”
Dati di riferimento mancanti Omette gentilmente la citazione
Dati di citazione non corretti Include solo i campi disponibili

Vedi anche

[modifica wikitesto]

Questo modulo è pubblicato sotto licenza CC0 (pubblico dominio). Non esitare ad adattarlo, tradurlo e implementarlo su qualsiasi progetto Wikimedia senza attribuzione.


  1. ^ ...
  2. ^ ...
  3. ^ ...
--[[
╔════════════════════════════════════════════════════════════════════════════╗
║ Module:P703 - Organism Display with Inline Citations                       ║
║                                                                            ║
║ Author: AdrianoRutz                                                        ║
║ License: CC0 / Public Domain                                               ║
║                                                                            ║
║ Description:                                                               ║
║   Displays organisms (P703 "found in taxon") with formatted citations      ║
║   extracted directly from Wikidata references. Zero external dependencies. ║
║                                                                            ║
║ Usage:                                                                     ║
║   {{#invoke:P703|main|qid=Q2079986|numval=5|sources=true}}                 ║
║                                                                            ║
║ Parameters:                                                                ║
║   - qid: Wikidata entity ID (defaults to current page)                     ║
║   - numval: Maximum organisms to display (default: 5)                      ║
║   - sources: Show inline citations (default: true)                         ║
╚════════════════════════════════════════════════════════════════════════════╝
--]]
local p = {}

--[[────────────────────────────────────────────────────────────────────────────
  SECTION 1: CONFIGURATION & INTERNATIONALIZATION
────────────────────────────────────────────────────────────────────────────]]
-- Localization strings - edit these for language-specific deployments
local i18n = {
    no_organism = "nessun organismo conosciuto",
    including = "tra cui",
    wd_label = "d", -- Label for Wikidata link
    separator = ", ", -- List separator
    organism = "organismo", -- Singular form
    organisms = "organismi" -- Plural form
}

-- Entity cache prevents redundant API calls for the same Wikidata item
local entityCache = {}

--[[────────────────────────────────────────────────────────────────────────────
  SECTION 2: CITATION ENGINE
  
  Extracts and formats bibliographic data from Wikidata references.
  Supports: authors, title, journal, volume, issue, pages, DOI, PMID, dates
────────────────────────────────────────────────────────────────────────────]]
--- Safely extracts a property value from a Wikidata entity
-- @param entity table The Wikidata entity object
-- @param prop string The property ID (e.g., "P1476")
-- @return string|nil The property value or nil if not found
local function getPropertyValue(entity, prop)
    local claims = entity.claims and entity.claims[prop]
    if not claims or not claims[1].mainsnak.datavalue then
        return nil
    end

    local datavalue = claims[1].mainsnak.datavalue.value

    -- Handle different datavalue types
    if type(datavalue) == "table" then
        return datavalue.text or datavalue.id or datavalue.time
    end

    return datavalue
end

--- Extracts and formats author list from Wikidata
-- @param entity table The source entity containing author claims
-- @param maxAuthors number Maximum authors to list before "et al."
-- @return string|nil Formatted author string or nil
local function getAuthors(entity, maxAuthors)
    maxAuthors = maxAuthors or 3

    local authorClaims = entity.claims and (entity.claims.P50 or entity.claims.P2093)
    if not authorClaims then
        return nil
    end

    local authors = {}
    for i, snak in ipairs(authorClaims) do
        if i > maxAuthors then
            table.insert(authors, "et al.")
            break
        end

        if snak.mainsnak.datavalue then
            local authorValue = snak.mainsnak.datavalue.value
            local authorId = (type(authorValue) == "table") and authorValue.id or authorValue
            table.insert(authors, mw.wikibase.getLabel(authorId) or authorId)
        end
    end

    return #authors > 0 and table.concat(authors, ", ") or nil
end

--- Generates formatted citation from Wikidata reference
-- @param frame table MediaWiki frame object (for extensionTag)
-- @param claim table The Wikidata claim containing references
-- @return string Formatted MediaWiki reference(s) or empty string
local function getCleanRef(frame, claim)
    if not claim.references then
        return ""
    end

    local refs = {}

    for _, ref in ipairs(claim.references) do
        local cite = {}
        local sourceQid = nil

        -- Extract source (P248 = "stated in")
        if ref.snaks and ref.snaks.P248 then
            sourceQid = ref.snaks.P248[1].datavalue.value.id
        end

        if sourceQid then
            -- Use cached entity if available to reduce API calls
            local srcEntity = entityCache[sourceQid] or mw.wikibase.getEntity(sourceQid)

            if srcEntity then
                entityCache[sourceQid] = srcEntity

                -- Extract bibliographic metadata
                cite.title = getPropertyValue(srcEntity, "P1476") or mw.wikibase.getLabel(sourceQid)
                cite.journal = mw.wikibase.getLabel(getPropertyValue(srcEntity, "P1433"))
                cite.vol = getPropertyValue(srcEntity, "P478")
                cite.issue = getPropertyValue(srcEntity, "P433")
                cite.pages = getPropertyValue(srcEntity, "P304")
                cite.doi = getPropertyValue(srcEntity, "P356")
                cite.pmid = getPropertyValue(srcEntity, "P698")
                cite.authors = getAuthors(srcEntity, 3)

                -- Extract publication year from date
                local rawDate = getPropertyValue(srcEntity, "P577")
                if type(rawDate) == "string" then
                    cite.date = rawDate:match("+?(%d%d%d%d)")
                end
            end
        elseif ref.snaks and ref.snaks.P854 then
            -- Fallback to URL reference (P854 = "reference URL")
            cite.url = ref.snaks.P854[1].datavalue.value
        end

        -- Assemble citation in bibliographic format
        local parts = {}

        -- Authors
        if cite.authors and cite.authors ~= "" then
            table.insert(parts, cite.authors .. ".")
        end

        -- Title (with optional URL)
        if cite.title then
            local titleStr = cite.url and ("[" .. cite.url .. ' "' .. cite.title .. '"]') or ('"' .. cite.title .. '"')
            table.insert(parts, titleStr .. ".")
        elseif cite.url then
            table.insert(parts, "[" .. cite.url .. " Wikidata Source].")
        end

        -- Journal information
        if cite.journal then
            local journalStr = "''" .. cite.journal .. "''"

            if cite.vol then
                journalStr = journalStr .. " '''" .. cite.vol .. "'''"
            end
            if cite.issue then
                journalStr = journalStr .. " (" .. cite.issue .. ")"
            end
            if cite.pages then
                journalStr = journalStr .. ": pp. " .. cite.pages
            end

            table.insert(parts, journalStr .. ".")
        end

        -- Publication date
        if cite.date then
            table.insert(parts, "(" .. cite.date .. ").")
        end

        -- Identifiers
        if cite.doi then
            table.insert(parts, "[[doi:" .. cite.doi .. "|doi:" .. cite.doi .. "]].")
        end
        if cite.pmid then
            table.insert(parts, "[[pmid:" .. cite.pmid .. "|pmid:" .. cite.pmid .. "]].")
        end

        -- Create MediaWiki reference tag
        if #parts > 0 then
            table.insert(refs, frame:extensionTag("ref", table.concat(parts, " ")))
        end
    end

    -- Using a span with vertical-align: super ensures it matches the ref marker height exactly
    return table.concat(refs, '<span style="vertical-align: 0.9em; font-size: 0.7em;">,</span>')
end

--[[────────────────────────────────────────────────────────────────────────────
  SECTION 3: DYNAMIC INTERWIKI LINKING
  
  Creates smart links that:
  1. Link to local wiki article if it exists
  2. Link to another language wiki with lang code if no local article
  3. Link to Wikidata as fallback
────────────────────────────────────────────────────────────────────────────]]
--- Generates optimal interwiki link for a Wikidata item
-- @param itemId string The Wikidata Q-identifier
-- @return string Formatted wikilink with fallback to interwiki or Wikidata
local function getDynamicLink(itemId)
    local label = mw.wikibase.getLabel(itemId) or itemId
    local entity = mw.wikibase.getEntity(itemId)
    local sitelinks = (entity and entity.sitelinks) or {}

    -- Priority 1: Local wiki article
    local currentWiki = mw.language.getContentLanguage():getCode() .. "wiki"
    if sitelinks[currentWiki] then
        return "[[" .. sitelinks[currentWiki].title .. "|" .. label .. "]]"
    end

    -- Priority 2: First available interwiki link (excluding Wikidata/Commons)
    for wiki, data in pairs(sitelinks) do
        if wiki:match("wiki$") and wiki ~= "wikidatawiki" and wiki ~= "commonswiki" then
            local langCode = wiki:gsub("wiki$", ""):gsub("_", "-")
            return label .. " <small>([[:" .. langCode .. ":" .. data.title .. "|" .. langCode .. "]])</small>"
        end
    end

    -- Priority 3: Wikidata fallback
    return label .. " <small>([[:d:" .. itemId .. "|" .. i18n.wd_label .. "]])</small>"
end

--[[────────────────────────────────────────────────────────────────────────────
  SECTION 4: MAIN ENTRY POINT
────────────────────────────────────────────────────────────────────────────]]
--- Main function to display organism list with citations
-- @param frame table MediaWiki frame object containing arguments
-- @return string Formatted organism list with references
function p.main(frame)
    -- Handle both direct invoke and template parameter passing
    local args = frame.args
    if not args.qid or args.qid == "" then
        args = frame:getParent().args
    end

    -- Extract parameters with defaults
    local qid = (args.qid and args.qid ~= "") and args.qid or mw.wikibase.getEntityIdForCurrentPage()
    local numval = tonumber(args.numval) or 5
    local showSources = (args.sources ~= "false" and args.sources ~= "no")

    -- Validate entity and P703 claims exist
    local entity = mw.wikibase.getEntity(qid)
    if not entity or not entity.claims or not entity.claims.P703 then
        return i18n.no_organism
    end

    -- Process claims
    local claims = entity.claims.P703
    local count = #claims
    local results = {}

    for i = 1, math.min(count, numval) do
        local claim = claims[i]
        if claim.mainsnak and claim.mainsnak.datavalue then
            local id = claim.mainsnak.datavalue.value.id
            local link = getDynamicLink(id)
            local ref = showSources and getCleanRef(frame, claim) or ""
            table.insert(results, link .. ref)
        end
    end

    -- Format output with proper pluralization
    local lang = mw.getContentLanguage()
    local label = lang:plural(count, i18n.organism, i18n.organisms)
    local listStr = table.concat(results, i18n.separator)

    if count > numval then
        return count .. " " .. label .. ", " .. i18n.including .. ": " .. listStr
    else
        return count .. " " .. label .. ": " .. listStr
    end
end

--[[────────────────────────────────────────────────────────────────────────────
  SECTION 5: METATABLE FOR DIRECT INVOCATION
  
  Allows calling the module as {{#invoke:P703|...}} or simply {{P703|...}}
────────────────────────────────────────────────────────────────────────────]]
setmetatable(
    p,
    {
        __call = function(t, frame)
            return p.main(frame)
        end
    }
)

return p