Módulo:WikidataIB
26x26px | This module is rated as alpha. It is ready for third-party input, and may be used on a few pages to see if problems arise, but should be watched. Suggestions for new features or changes in their input and output mechanisms are welcome. |
40px | Este módulo toma dados de uma ou mais propriedades do Wikidata
|
Este módulo foi projetado especificamente para implementar um mecanismo que move o controle de se os valores do Wikidata são usados em uma infobox do programador da predefinição no nível de design da infobox para o editor no nível de artigo. Ele só deve ser usado dentro de uma infobox.
Índice
- 1 Uso
- 2 Adendo sobre o idioma de retorno
- 3 Ver também
Uso
O módulo provê essas chamadas especificamente para o uso em infoboxes no presente:
getValue
getPreferredValue
getSourcedValue
getCoords
getQualifierValue
A chamada getSourcedValue é mantida para compatibilidade com versões anteriores, pois agora é redundante para getValue que pode fazer o mesmo trabalho usando o parâmetro
.
|onlysourced=true
Existem também essas chamadas úteis:
getLink
getLabel
getAT
formatDate
checkBlacklist
predDni
predMorte
Chamadas generalizadas:
{{#invoke:WikidataIB |getValue |<PropertyID> |name=<fieldname> |suppressfields=<list of fields which will never display> |fetchwikidata=<list of fields to fetch values from Wikidata> |onlysourced=<yes/no> |noicon=<yes/no> |df=<dmy/mdy/y> |bc=<BC/BCE> |<local parameter>}}
{{#invoke:WikidataIB |getPreferredValue |<PropertyID> |name=<fieldname> |suppressfields=<list of fields which will never display> |fetchwikidata=<list of fields to fetch values from Wikidata> |onlysourced=<yes/no> |noicon=<yes/no> |df=<dmy/mdy/y> |bc=<BC/BCE> |<local parameter>}}
{{#invoke:WikidataIB |getSourcedValue |<PropertyID> |name=<fieldname> |suppressfields=<list of fields which will never display> |fetchwikidata=<list of fields to fetch values from Wikidata> |<local parameter>}}
{{#invoke:WikidataIB |getCoords |name=<fieldname> |suppressfields=<list of fields which will never display> |fetchwikidata=<list of fields to fetch values from Wikidata> |<local parameter>}}
{{#invoke:WikidataIB |getQualifierValue |<PropertyID> |pval=<ID of target value for the property> |qual=<qualifier ID for that target value> |name=<fieldname> |suppressfields=<list of fields which will never display> |fetchwikidata=<list of fields to fetch values from Wikidata> |onlysourced=<yes/no>}}
Função getValue
- getValue pode também pegar um parâmetro
que é o ID do Wikidata para o artigo. Isto não será normalmente usado, mas está disponível para teste, embora faça a chamada cara.|qid=
- A propriedade a ser retornada é passada na primeira propriedade não nomeada.
- O nome do campo que a função é chamada é passada no parâmetro
, que é primeiramente checado em uma blacklist de campos que não devem ser mostradas nunca, (i.e. a chamada retorna nil em todas as circunstâncias). Se o campo não está na blacklist, é então checado contra uma whitelist. Se o nome do campo concorda, a chamada retornará qualquer valor fornecido localmente se é fornecido como segundo parâmetro não nomeado, ou o valor do Wikidata caso contrário.|name=
- O nome é compulsório quando a blacklist ou a whitelist é usada, então o módulo retorna nil se não é fornecido.
- A blacklist é passada no parâmetro
|suppressfields=
- A whitelist é passada no parâmetro
|fetchwikidata=
A função getValue aceitará um parâmetro booleano
que irá suprimir retornos dos valores do Wikidata que estão sem fontes ou somente referenciados a wIRChelp. A ausência do parâmetro, um parâmetro |onlysourced=
|onlysourced
vazio e uma string vazia (""
) têm como default para verdadeiro (i.e. somente os valores referenciados são retornados). Os valores no
, false
e 0
são tratados como falsos (i.e. todos os valores são retornados); qualquer outro valor é verdadeiro (embora
seja recomendado para legibilidade).
|onlysourced=yes
A função getValue aceitará um parâmetro booleano noicon
que suprimirá o ícone "edite no Wikidata" para quando o valor retornado for processado futuramente pela infobox (e.g. uma url). A ausência do parâmetro ou um parâmetro |noicon
vazio default para falso (i.e. o parâmetro é adicionado). A string vazia (""
) e os valores no
, false
e 0
são tratados como falsos; qualquer outro valor é verdadeiro (embora
seja recomendado para legibilidade).
|noicon=true
Em ordem de lidar com o requerimento para datas em my, dmy ou y, getValue aceita um parâmetro
que pode pegar valores "dmy", "my" ou "y" - default é "dmy".
|df=
Se um artigo exigir o sufixo a.C., getValue retornará a data com esse sufixo;
Em uma invocação do módulo para extrair datas, getValue aceita um parâmetro
que pode receber o valor "pt" para formatar a data de acordo com o português europeu (única diferença se dá nas datas envolvendo o primeiro dia do mês. Por exemplo: 1º de maio de 2017 (em português brasileiro) e 1 de maio de 2017 (em português europeu)).
|idioma=
- A propriedade a ser retornada é passada na primeira propriedade não nomeada.
A função getValue aceitará um especificador de uso de unidade de medida (ao invés da unidade por extenso) na terceira propriedade não nomeada. A unidade de medida será exibida somente se o valor passado for unidade
Função getPreferredValue
A função getPreferredValue trabalha exatamente como getValue, tomando os mesmos parâmetros, mas se qualquer um dos valores para a propriedade tem um rank set preferido, ela retornará esses valores.
Exemplo
Obtendo o(s) nome(s) da Predefinição:Q de Predefinição:Q:
{{#invoke:WikidataIB |getValue |P170 |fetchwikidata=ALL |qid=Q29016906 |onlysourced=no}}
→ Erro em Lua na linha 279: attempt to index field 'wikibase' (a nil value).{{#invoke:WikidataIB |getPreferredValue |P170 |fetchwikidata=ALL |qid=Q29016906 |onlysourced=no}}
→ Erro em Lua na linha 279: attempt to index field 'wikibase' (a nil value).
Função getSourcedValue
- getSourcedValue trabalha exatamente como getValue, mas somente retorna valores que tenham referência a algo mais do que a wIRChelp. Não há garantias de fontes confiáveis, mas ajuda separar o joio do trigo.
Exemplo de getSourcedValue
De Predefinição:Q:
Burton correntemente tem quatro valores para Predefinição:Q no Wikidata:
- Predefinição:Q (referenciado a Dutch wIRChelp);
- Predefinição:Q (referenciado a http://www.nytimes.com/1983/05/09/theater/theater-private-lives-burton-and-miss-taylor.html);
- Predefinição:Q (referenciado a wIRChelp);
- Predefinição:Q (não referenciado).
Usando getValue em Richard Burton:
{{#invoke:WikidataIB |getValue |P106 |name=occupation |fetchwikidata=ALL}}
-> Erro em Lua na linha 279: attempt to index field 'wikibase' (a nil value).
Usando getSourcedValue em Richard Burton:
{{#invoke:WikidataIB |getSourcedValue |P106 |name=occupation |fetchwikidata=ALL}}
-> Erro em Lua na linha 279: attempt to index field 'wikibase' (a nil value).
Função getCoords
- getCoords pode também pegar um parâmetro
que é o ID do Wikidata para o artigo. Isto não será normalmente usado, mas está disponível para testes, embora faça a chamada cara.|qid=
- As coordenadas do Wikidata são passadas a Predefinição:Coord que retorna o display como se fosse chamado manualmente.
- O nome do campo que a função é chamada é passada no parâmetro
|name
, que é primeiramente checado em uma blacklist de campos que não devem ser mostradas nunca, (i.e. a chamada retorna nil em todas as circunstâncias). Se o campo não está na blacklist, é então checado contra uma whitelist. Se o nome do campo concorda, a chamada retornará qualquer valor fornecido localmente se é fornecido como segundo parâmetro não nomeado, ou o valor do Wikidata caso contrário. - O nome é compulsório quando a blacklist ou a whitelist é usada, então o módulo retorna nil se não é fornecido.
- A blacklist é passada no parâmetro
|suppressfields=
- A whitelist é passada no parâmetro
|fetchwikidata=
Função getQualifierValue
O getQualifierValue é para usar quando queremos concordar o valor de um qualificador. Nós precisamos saber a propriedade e o valor da propriedade que a qualifica. Os parâmetros são:
- A propriedade ID passada no parâmetro não nomeado (ou
|1
) - O valor alvo para esta propriedade em
|pval
- O ID qualificador para o valor alvo em
|qual
- O nome do campo onde é chamada para implementar "whitelisting" e "blacklisting" da propriedade nele
- A lista de campos para concordância ("whitelist") em
- aceita|fetchwikidata=
para concordar todos os campos|fetchwikidata=ALL
- Lista opcional de campos para não serem exibidos ("blacklist") em
|suppressfields=
- booleano opcional para especificar se apenas valores referenciados da propriedade são retornados (default para "no") em
|onlysourced=
- Item ID opcional para acesso arbitrário (chamada carísssima!) em
|qid=
Exemplo de getQualifierValue
Em Predefinição:Q existe uma propriedade Predefinição:Q, que tem um valor Predefinição:Q. Tem dois qualificadores, Predefinição:Q e Predefinição:Q. Para obter a data de início:
{{#invoke:WikidataIB |getQualifierValue |P793 |pval=Q385378 |qual=P580 |name=xyz |fetchwikidata=ALL }}
Em Telescópio do Polo Sul retorna:
- Erro em Lua na linha 279: attempt to index field 'wikibase' (a nil value).
Função getLink
getLink retorna o rótulo para um Qid ligado a wiki para o artigo local (se o artigo existe).
Função getLabel
getLabel retorna o rótulo para uma Qid. Se o rótulo não existe, retorna o Qid. Note que este é o rótulo dado para a entrada no Wikidata na mesma linguagem da corrende wIRChelp, se o rótulo existe.
{{#invoke:WikidataIB |getLabel |Q29016906}}
→ Erro em Lua na linha 216: attempt to index field 'wikibase' (a nil value).{{#invoke:WikidataIB |getLabel |Q3621491}}
→ Erro em Lua na linha 216: attempt to index field 'wikibase' (a nil value).
Função getAT
getAT retorna o título do artigo para uma Qid. Se o título do artigo não existe, não retorna nada. Note que este é o título do artigo na corrente wIRChelp, se o interwiki existe na entrada Wikidata.
{{#invoke:WikidataIB |getAT |Q29016906}}
→ Erro em Lua na linha 920: attempt to index field 'wikibase' (a nil value).{{#invoke:WikidataIB |getAT |Q3621491}}
→ Erro em Lua na linha 920: attempt to index field 'wikibase' (a nil value).
Função predDni
predDni toma uma data de nascimento passada pelo usuário (tal como devolvida pela função getValue ou getPreferredValue ou da forma DD{{!}}MM{{!}}AAAA) e a insere dentro da predefinição:Dni. Também aceita os argumentos "|idioma=" caso se deseje exibir a data na variante do português angolano e a variável não nomeada "sem idade" quando não se desejar exibir a idade.
{{#invoke:WikidataIB |predDni |<data de nascimento obtida através da função getValue ou getPreferredValue acrescentada opcionalmente dos parâmetros "|idioma=" e "|sem idade" ou então a data por extenso como "01{{!}}04{{!}}2018">}}
Exemplo:
{{#invoke:WikidataIB|predDni|01{{!}}04{{!}}2016}}
→ 01 de Abril de 2016 (9 anos){{#invoke:WikidataIB|predDni|01{{!}}04{{!}}2020|idioma=pt-ao|sem idade}}
→ 01 de Abril de 2020
Função predMorte
Tal qual predDni, predMorte toma uma data de morte e uma data de nascimento passada pelo usuário (novamente: tal como devolvida pela função getValue ou getPreferredValue ou da forma DD{{!}}MM{{!}}AAAA) e a insere dentro da predefinição:Morte. Também aceita o argumento "|idioma=" caso se deseje exibir a data na variante do português angolano.
{{#invoke:WikidataIB |predMorte |<data de morte obtida através da função getValue ou getPreferredValue ou então a data por extenso como "01{{!}}04{{!}}2018">|<data de nascimento obtida através da função getValue ou getPreferredValue ou então a data por extenso como "01{{!}}04{{!}}2017">}}
Exemplo:
{{#invoke:WikidataIB|predMorte|01{{!}}04{{!}}2018|01{{!}}04{{!}}2016}}
→ Erro em lua: expandTemplate: template "Morte" does not exist.
Função formatDate*
formatDate aceita uma data no formato usual de mw.wikibase.entity:formatPropertyValues, como "1 de agosto de 30 a.C." como parâmetro 1 e o formata de acordo com os parâmetros df e bc.
{{#invoke:WikidataIB |formatDate | 1 de agosto de 30 | bc=BC |df=dmy}}
→ 1{{#invoke:WikidataIB |formatDate | 1 de agosto de 20 | bc=BCE |df=mdy}}
→ 1- df = "dmy" / "mdy" / "y" - default é "dmy"
- bc = "BC" / "BCE" - default é "BCE"
* Não está funcionando normalmente
Adendo sobre o idioma de retorno
Por padrão, os rótulos retornados pelo módulo serão retornados por default na variante brasileira do português. Caso um editor deseje que o rótulo seja retornado em português europeu (essas são, infelizmente, as duas únicas variantes implementadas no Wikidata), ao utilizar qualquer uma das funções apresentadas, basta adicionar |idioma=pt
ou |idioma=pt-ao
(neste caso, os rótulos serão retornados em português europeu, e as datas serão retornadas no formato angolano) nos parâmetros da função.
Ver também
- Módulo:Wikidata, lidando com o Wikidata de forma mais básica
-- Módulo para experimentar o uso de uma lista de campos proibidos e uma lista de campos permitidos -- Pode pegar um parâmetro nomeado |qid que é o identificador do artigo no Wikidata. Em geral, seu uso deve ser restrito a páginas de teste e documentações. -- Os campos colocados na lista de proibições não serão exibidos de forma alguma, ou seja, o módulo deverá retornar nul para esses campos -- Os campos colocados na lista de permissões terão valores devolvidos sempre que existirem localmente -- O nome do campo em que esta função é chamada é passado através do parâmetro nomeado |nome -- O nome é obrigatório somente quando a lista de proibições e/ou a lista de permissões são usadas. O módulo retornará nul caso ele não seja passado -- A lista de proibições é passada através do parâmetro nomeado |supressfields -- A lista de permissões é passada através do parâmetro nomeado |fetchwikidata local p = {} local wiki = { langcode = mw.language.getContentLanguage().code } local i18n = { ["errors"] = { ["property-not-found"] = "Propriedade não encontrada.", ["entity-not-found"] = "Entidade Wikidata desconhecida.", ["unknown-claim-type"] = "Tipo claim com valor desconhecido.", ["unknown-entity-type"] = "Tipo entity com valor desconhecido.", ["qualifier-not-found"] = "Qualificador não encontrado.", ["site-not-found"] = "Projeto Wikimedia não encontrado.", ["unknown-datetime-format"] = "Formato datatempo desconhecido.", ["local-article-not-found"] = "Artigo ainda não se encontra disponível nesta wiki." }, ["editenowikidata"] = "Edite no Wikidata", ["filespace"] = "Ficheiro", ["months"] = { "janeiro", "fevereiro", "março", "abril", "maio", "junho", "julho", "agosto", "setembro", "outubro", "novembro", "dezembro" }, ["ac"] = "a.C.", ["century"] = "[[Século $1]]", ["centurysemlink"] = "século $1", ["decade"] = "[[Década de $1]]", ["decadesemlink"] = "década de $1" } ------------------------------------------------------------------------------- -- Private functions ------------------------------------------------------------------------------- ------------------------------------------------------------------------------- -- formatDate pega uma data no formato usual de mw.wikibase.entity:formatPropertyValues -- como "1 de agosto de 30 aC" como primeiro parâmetro e o formata de acordo com os parâmetros dateformat (formato de data), bc (indicador de era), idioma e datasemlink -- df = <"dmy"/"mdy"/"y">. O valor padrão é "dmy" -- bc = <"a.C.">. O valor padrão será "a.C." -- idioma = <"pt"/"pt-ao"/"">. O valor padrão é "", e significa que a data será exibida no formato português brasileiro. "pt" representa o formato português europeu e "pt-ao" o formato do português angolano. -- datasemlink = <"sim"/"">. O valor padrão é "", e significa que a data será devolvida em formato wiki. -- primeiro a versão local local format_Date = function(frame,datetime, dateformat, bc, idioma, datasemlink) local datetime = datetime or "14 de fevereiro 1 August 30 BCE" -- in case of nil value -- chop off multiple vales and/or any hours, mins, etc. -- keep anything before punctuation - we just want a single date: local dateval = string.match( datetime, "[%w ç]+") local dateformat = string.lower(dateformat or "dmy") -- default to dmy local datasemlink = datasemlink local c1 local c2 if datasemlink == "sim" then c1 = "" c2 = "" else c1 = "[[" c2 = "]]" end local bc = string.upper(bc or "") -- can't use nil for bc -- we only want to accept two possibilities: BC or default to BCE if bc=="BCE" then bc = " " .. i18n["ac"] -- prepend the space. **internationalise later** else bc = " " .. i18n["ac"] end local postchrist = true -- start by assuming no BCE local dateparts = {} for word in string.gmatch(dateval,"([%w-ç]+)") do if word == "BC" or word=="BCE" then -- **internationalise later** postchrist = false else -- we'll keep the parts that are not 'BCE' in a table dateparts[#dateparts + 1] = word end end if postchrist then bc = "" end -- set AD dates to no suffstring.("$1","$1",**internationalise later** local sep = " de " -- separator is nbsp local fdate = table.concat(dateparts, " de ") -- formatted date defaults to same order as input -- if we have day month year, check dateformat if #dateparts == 3 then --por padrão dmy --se é dia primeiro if idioma == "pt" then fdate = c1..dateparts[1]..sep..dateparts[2]..c2..sep..c1..dateparts[3]..bc..c2 elseif idioma =="pt-ao" then fdate = c1..dateparts[1]..sep..dateparts[2]:gsub("^%l", string.upper)..c2..sep..c1..dateparts[3]..bc..c2 else if dateparts[1]==tostring(1) then fdate = c1..dateparts[1].."º"..sep..dateparts[2]..c2..sep..c1..dateparts[3]..bc..c2 else fdate = c1..dateparts[1]..sep..dateparts[2]..c2..sep..c1..dateparts[3]..bc..c2 end end if dateformat == "y" then fdate = c1..dateparts[3]..bc..c2 elseif dateformat == "my" then if idioma =="pt-ao" then fdate = c1..dateparts[2]:gsub("^%l", string.upper) ..c2.. sep .. c1 .. dateparts[3] ..bc.. c2 else fdate = c1..dateparts[2]:gsub("^%l", string.upper) ..c2.. sep .. c1 .. dateparts[3] ..bc.. c2 end end elseif #dateparts == 2 then if dateformat == "y" then fdate = c1..dateparts[2]..bc..c2 else if idioma == "pt-ao" then fdate = c1..dateparts[1]:gsub("^%l", string.upper)..c2..sep..c1..dateparts[2]..bc..c2 else fdate = c1..dateparts[1]..c2..sep..c1..dateparts[2]..bc..c2 end end else fdate = c1..dateparts[1]..bc..c2 end return fdate end local format_Date_template = function(frame,datetime, dateformat, bc, idioma) local datetime = datetime or "14 de fevereiro" local dateval = string.match( datetime, "[%w ç]+") local dateformat = string.lower(dateformat or "dmy") local bc = string.upper(bc or "") bc = "-" local function _numes(mes) local result = mes for k, v in ipairs(i18n["months"]) do if mes == v then result = tostring(k) end end return result end local postchrist = true -- start by assuming no BCE local dateparts = {} for word in string.gmatch(dateval,"([%w-ç]+)") do if word == "BC" or word=="BCE" then -- **internationalise later** postchrist = false else -- we'll keep the parts that are not 'BCE' in a table dateparts[#dateparts + 1] = _numes(word) end end if postchrist then bc = " " end local sep = "|" local fdate = table.concat(dateparts, sep) if #dateparts == 3 then if dateformat == "y" then fdate = sep..sep..mw.text.trim(bc)..dateparts[3] elseif dateformat == "my" then fdate = sep..dateparts[2]..sep..mw.text.trim(bc)..dateparts[3] else fdate = dateparts[1]..sep..dateparts[2]..sep..mw.text.trim(bc)..dateparts[3] end elseif #dateparts == 2 then if dateformat == "y" then fdate = sep..sep..mw.text.trim(bc)..dateparts[2] else fdate = sep..dateparts[1]..sep..mw.text.trim(bc)..dateparts[2] end else fdate = sep..sep..mw.text.trim(bc)..dateparts[1] end return fdate end ------------------------------------------------------------------------------- -- parseParam takes a (string) parameter, e.g. from the list of frame arguments, -- and makes "false", "no", and "0" into the (boolean) false -- it makes the empty string and nil into the (boolean) value passed as default -- allowing the parameter to be true or false by default. local parseParam = function(param, default) if param and (#param > 0) then param = param:lower() if (param == "false") or (param == "no") or (param == "não") or (param == "0") then return false else return true end else return default end end ------------------------------------------------------------------------------- -- The label in a Wikidata item is subject to vulnerabilities -- that an attacker might try to exploit. -- It needs to be 'sanitised' by removing any wikitext before use. -- If it doesn't exist, just return the id for the item local labelOrId = function (id,idioma) local label = "" if idioma == "pt" or idioma == "pt-ao" then label = mw.wikibase.getLabelByLang(id,'pt') or mw.wikibase.getLabelByLang(id,'pt-br') or "" else label = mw.wikibase.getLabelByLang(id,'pt-br') or mw.wikibase.getLabelByLang(id,'pt') or "" end if label ~= "" then return mw.text.nowiki(label) else return id end end ------------------------------------------------------------------------------- -- sourced takes a table representing a statement that may or may not have references -- it counts how many references are sourced to something not contianing the word "wIRChelp" -- the reference string "ref" is available for debugging -- it returns a boolean = true if there are any sourced references. local sourced = function(claim) local refs = 0 if claim.references then for kr, vr in pairs(claim.references) do local ref = mw.wikibase.renderSnaks(vr.snaks) if not ref:find("wIRChelp") then refs = refs + 1 end end end return refs > 0 end ------------------------------------------------------------------------------- -- parseInput processes the Q-id , the blacklist and the whitelist -- if an input parameter is supplied, it returns that and ends the call. -- it returns a boolean indicating whether or not the call should continue -- and an object containing all of the Wikidata for the Qid supplied or the current page local parseInput = function(frame, input_parm, property_id) -- can take a named parameter |qid which is the Wikidata ID for the article. -- This will not normally be used because it's an expensive call. local qid = frame.args.qid if qid and (#qid == 0) then qid = nil end -- The blacklist is passed in named parameter |suppressfields local blacklist = frame.args.suppressfields -- The whitelist is passed in named parameter |fetchwikidata local whitelist = frame.args.fetchwikidata -- The name of the field that this function is called from is passed in named parameter |name local fieldname = frame.args.name if blacklist then -- The name is compulsory when blacklist is used, so return nil if it is not supplied if not fieldname or (#fieldname == 0) then return false, nil, nil end -- If this field is on the blacklist, then return nil if blacklist:find(fieldname) then return false, nil, nil end end -- If we got this far then we're not on the blacklist -- The blacklist overrides any locally supplied parameter as well -- If a non-blank input parameter was supplied return it if input_parm then return false, input_parm, nil end -- Otherwise see if this field is on the whitelist: if not (whitelist and (whitelist == 'ALL' or whitelist:find(fieldname))) then -- not on the whitelist so just return what should be a nil input parameter return false, input_parm, nil end -- See what's on Wikidata: local entity = mw.wikibase.getEntityObject(qid) if entity and entity.claims then local props = entity.claims[property_id] if props and props[1] then return true, entity, props end end -- no property on Wikidata return false, input_parm, nil end ------------------------------------------------------------------------------- local function _getvalue(frame, entity, props, filter, propertyID, unit) -- onlysourced is a boolean passed to return only values sourced to other than wIRChelp -- if nothing or an empty string is passed set it true -- if "false" or "no" or "0" is passed set it false local onlysrc = parseParam(frame.args.onlysourced, true) -- noicon is a boolean passed to suppress the trailing "edit at Wikidata" icon -- for use when the value is processed further by the infobox -- if nothing or an empty string is passed set it false -- if "false" or "no" or "0" is passed set it false local noic = parseParam(frame.args.noicon, false) -- wdlinks is a boolean passed to enable links to Wikidata when no article exists -- if nothing or an empty string is passed set it false -- if "false" or "no" or "0" is passed set it false local wdl = parseParam(frame.args.wdlinks, false) -- sorted is a boolean passed to enable sorting of the values returned -- if nothing or an empty string is passed set it false -- if "false" or "no" or "0" is passed set it false local sorted = parseParam(frame.args.sorted, false) -- separator is a string that is used to separate multiple returned values -- if nothing or an empty string is passed set it to the default -- any double-quotes " are stripped out, so that spaces may be passed -- e.g. |sep=" - " local sepdefault = ", " -- **internationalise later** local separator = frame.args.sep or "" if separator=="nenhum" then separator = "" else separator = string.gsub(separator, '"', '') if #separator == 0 then separator = sepdefault end end -- list is a string that may be "", "hlist" or "ubl" -- this controls whether multiple values are output as comma-separated -- as a horizontal list (hlist) or unbulleted list (ubl) local list = frame.args.list or "" if list~="hlist" and list~="ubl" then list = "" end -- prefix is a string that may be nil, empty (""), or a string of characters -- this is prefixed to each value -- useful when when multiple values are returned -- any double-quotes " are stripped out, so that spaces may be passed local prefix = frame.args.prefix or "" prefix = string.gsub(prefix, '"', '') -- postfix is a string that may be nil, empty (""), or a string of characters -- this is postfixed to each value -- useful when when multiple values are returned -- any double-quotes " are stripped out, so that spaces may be passed local postfix = frame.args.postfix or "" postfix = string.gsub(postfix, '"', '') -- linkprefix is a string that may be nil, empty (""), or a string of characters -- this creates a link and is then prefixed to each value -- useful when when multiple values are returned and indirect links are needed -- any double-quotes " are stripped out, so that spaces may be passed local lprefix = frame.args.linkprefix or "" lprefix = string.gsub(lprefix, '"', '') -- linkpostfix is a string that may be nil, empty (""), or a string of characters -- this is postfixed to each value when linking is enabled with lprefix -- useful when when multiple values are returned -- any double-quotes " are stripped out, so that spaces may be passed local lpostfix = frame.args.linkpostfix or "" lpostfix = string.gsub(lpostfix, '"', '') -- maxvals is a string that may be nil, empty (""), or a number -- this determines how many items may be returned when multiple values are available -- the behaviour is customisable for each different data type local maxvals = tonumber(frame.args.maxvals) or -1 -- contagem is a string that may be empty (""), or "sim" -- for use when one wants to get the quantity of values returned local contagem = frame.args.contagem or "" -- So now we have something to return: deal with: -- (1) ["datatype"] = "wikibase-item"; -- (2) ["datatype"] = "time"; -- (3) ["datatype"] = "commonsMedia", -- ["datatype"] = "external-id", -- ["datatype"] = "string", -- ["datatype"] = "url" -- (4) ["datatype"] = "quantity" -- (5) ["datatype"] = "globe-coordinate", or anything else local lang = mw.language.getContentLanguage().code local thisQid = entity.id -- table 'out' is going to to store the return value(s): local out = {} local semlink = frame.args.semlink or "não" local semlink = frame.args.artigosemlink or "não" local icon = " [[" .. i18n["filespace"] .. ":Blue pencil.svg |frameless |text-top |10px |alt=" .. i18n["editenowikidata"] .. "|link=https://www.wikidata.org/wiki/" .. thisQid .. "?uselang=" .. lang .. "#" .. propertyID .. "|" .. i18n["editenowikidata"] .. "]]" local dni = frame.args.dni or "não" -- data type is a wikibase item: if props[1].mainsnak.datatype == "wikibase-item" then -- it's wiki-linked value, so output as link if possible for k, v in pairs(props) do if filter(v) and ((onlysrc == false) or sourced(v)) then -- has valid refs or all values required if v.mainsnak.snaktype == "somevalue" then -- check for value is unknown out[#out + 1] = "Desconhecido" elseif v.mainsnak.snaktype == "novalue" then -- check for value is none -- out[#out + 1] = "No value" -- don't return a value for this else local qnumber = "Q" .. v.mainsnak.datavalue.value["numeric-id"] local sitelink = mw.wikibase.sitelink(qnumber) local label = labelOrId(qnumber,frame.args.idioma or "pt-br") local gender = frame.args.gender or "" if gender ~= "" and entity.claims["P21"] then local genderID = entity.claims["P21"][1].mainsnak.datavalue.value["id"] if genderID == "F" or genderID == "Q6581072" or genderID == "Q1052281" or genderID == "Q43445" then local genderEntity = mw.wikibase.getEntityObject(qnumber) if genderEntity.claims["P2521"] then for k2,v2 in pairs(genderEntity.claims["P2521"]) do if filter(v2) and (v2.mainsnak.datavalue.value["language"] == "pt-br" or v2.mainsnak.datavalue.value["language"] == "pt") then label = v2.mainsnak.datavalue.value["text"] end end end end end if label ~= qnumber then if sitelink then if semlink == "sim" then out[#out + 1] = label else if sitelink ~= label then if artigosemlink == "sim" then out[#out + 1] = sitelink else out[#out + 1] = "[[" .. sitelink .. "|" .. label .. "]]" -- devolve o link pro artigo com um rótulo label end else if artigosemlink == "sim" then out[#out + 1] = sitelink else out[#out + 1] = "[[" .. sitelink .. "]]" -- devolve o link pro artigo com um rótulo sitelink end end end else -- no sitelink, so check first for a redirect with that label local artitle = mw.title.new(label, 0) if artitle.id > 0 then if artitle.isRedirect then -- no sitelink, but there's a redirect with the same title as the label -- let's link to that out[#out + 1] = label -- Devolve só o label, pois ter um redirecionamento com o mesmo rótulo não implica que os itens estão ligados. else -- no sitelink and not a redirect but an article exists with the same title as the label -- that's probably a dab page, so output the plain label out[#out + 1] = label -- Devolve só o label, pois título do artigo igual ao label não implica que os itens estão ligados. end else -- no article or redirect with the same title as the label if wdl then -- show that there's a Wikidata entry available out[#out + 1] = "[[:d:Q" .. v.mainsnak.datavalue.value["numeric-id"] .. "|" .. label .. "]] <span title='" .. i18n["errors"]["local-article-not-found"] .. "'>[[File:Wikidata-logo.svg|16px|alt=|link=]]</span>" else -- no wikidata links required, so don't show it out[#out + 1] = label end end end end -- If the property has a qualifier of latest date, add that in all cases: if v.qualifiers then local quals = v.qualifiers["P1326"] -- latest date qualifier if quals and #out>0 then out[#out] = out[#out] .. " (" ..mw.wikibase.renderSnaks(quals) .. ")" end end end -- check for unknown value end -- check for sourced if maxvals > 0 and #out >= maxvals then break end end -- loop through k-v pairs -- data type is time: elseif props[1].mainsnak.datatype == "time" then local datamorte = "" -- it's a date value, so output according to formatting preferences for k, v in pairs(props) do -- check for references, and count valid references if filter(v) and ((onlysrc == false) or sourced(v)) then if v.mainsnak.snaktype == "somevalue" then -- check for value is unknown out[#out + 1] = "Desconhecido" elseif v.mainsnak.snaktype == "novalue" then -- check for value is none -- out[#out + 1] = "No value" -- don't return a value for this else local timestamp = v.mainsnak.datavalue.value.time -- A year can be stored like this: "+1872-00-00T00:00:00Z", -- which is processed here as if it were the day before "+1872-01-01T00:00:00Z", -- and that's the last day of 1871, so the year is wrong. -- So fix the month 0, day 0 timestamp to become 1 January instead: timestamp = timestamp:gsub("%-00%-00T", "-01-01T") local dateprecision = v.mainsnak.datavalue.value.precision local fpvdate = tonumber(timestamp:sub(2, 5)) local fdate if dateprecision >= 9 then -- 9 is year precision local dateformat = "y" if dateprecision >= 10 then -- prepend month if dni ~= "não" then fpvdate = tonumber(timestamp:sub(7, 8)) .. " " .. fpvdate else fpvdate = i18n.months[tonumber(timestamp:sub(7, 8))] .. " " .. fpvdate end dateformat = frame.args.df if dateprecision >= 11 then -- prepend day fpvdate = tonumber(timestamp:sub(10, 11)) .. " " .. fpvdate end if timestamp:sub(1, 1) == "-" then fpvdate = fpvdate .. " BCE" end else if timestamp:sub(1, 1) == "-" then fpvdate = fpvdate.." BCE" end end local idioma = frame.args.idioma or "pt-br" local datasemlink = frame.args.datasemlink or semlink if dni ~= "não" then if entity.claims["P570"] then datamorte = "existe" end end if frame.args.display=="predefinição" then fdate = format_Date_template(frame,fpvdate,dateformat,frame.args.bc,frame.args.idioma) else fdate = format_Date(frame,fpvdate, dateformat, frame.args.bc,frame.args.idioma,frame.args.datasemlink,datamorte,dni) end elseif dateprecision == 8 then -- decade local datasemlink = frame.args.datasemlink or semlink local decade = fpvdate or "" if timestamp:sub(1, 1) == "-" then -- date is BC if datasemlink == "sim" then fdate = mw.ustring.gsub(i18n["decadesemlink"], "$1", decade.." "..i18n["ac"]) else fdate = mw.ustring.gsub(i18n["decade"], "$1", decade.." "..i18n["ac"]) end else if datasemlink == "sim" then fdate = mw.ustring.gsub(i18n["decadesemlink"], "$1", decade) else fdate = mw.ustring.gsub(i18n["decade"], "$1", decade) end end if frame.args.display=="predefinição" then fdate = decade end elseif dateprecision == 7 then -- century local datasemlink = frame.args.datasemlink or semlink local century = require("Módulo:Romano")._main({math.floor((fpvdate - 1) / 100) + 1}) if timestamp:sub(1, 1) == "-" then -- date is BC if datasemlink == "sim" then fdate = mw.ustring.gsub(i18n["centurysemlink"], "$1", century.." "..i18n["ac"]) else fdate = mw.ustring.gsub(i18n["century"], "$1", century.." "..i18n["ac"]) end else if datasemlink == "sim" then fdate = mw.ustring.gsub(i18n["centurysemlink"], "$1", century) else fdate = mw.ustring.gsub(i18n["century"], "$1", century) end end else -- date precisions 0 to 6 (billion years to millenium) TODO: -- end out[#out+1] = fdate end -- check for unknown value end -- check for sourced if maxvals > 0 and #out >= maxvals then break end end -- loop through k-v pairs -- data types which are strings: elseif props[1].mainsnak.datatype == "commonsMedia" or props[1].mainsnak.datatype == "external-id" or props[1].mainsnak.datatype == "string" or props[1].mainsnak.datatype == "url" then -- commonsMedia or external-id or string or url -- all have mainsnak.datavalue.value as string for k, v in pairs(props) do if filter(v) and ((onlysrc == false) or sourced(v)) then -- has valid refs or all values required if v.mainsnak.snaktype == "somevalue" then -- check for value is unknown out[#out + 1] = "Desconhecido" elseif v.mainsnak.snaktype == "novalue" then -- check for value is none -- out[#out + 1] = "No value" -- don't return a value for this else if lprefix > "" then out[#out+1] = "[[" .. lprefix .. v.mainsnak.datavalue.value .. lpostfix .. "|" .. prefix .. v.mainsnak.datavalue.value .. postfix .. "]]" else if postfix == "ref" then out[#out+1] = "<ref name =" .. string.match(v.mainsnak.datavalue.value, "%.(.-)%.") .. "-" .. string.match(v.mainsnak.datavalue.value, "^.+/(.-)$") .. ">" .. v.mainsnak.datavalue.value .. "</ref>" else out[#out+1] = prefix .. v.mainsnak.datavalue.value .. postfix end end -- check for link requested end -- check for unknown value end -- check for sourced if maxvals > 0 and #out >= maxvals then break end end -- loop through k-v pairspairs -- data types which are quantities: elseif props[1].mainsnak.datatype == "quantity" then for k, v in pairs(props) do if filter(v) and ((onlysrc == false) or sourced(v)) then -- has valid refs or all values required if v.mainsnak.snaktype == "somevalue" then -- check for value is unknown out[#out + 1] = "Desconhecido" elseif v.mainsnak.snaktype == "novalue" then -- check for value is none -- out[#out + 1] = "No value" -- don't return a value for this else local amount = v.mainsnak.datavalue.value.amount amount = mw.ustring.gsub(amount, "%+", "") local sortkey = string.format("%09d", amount) local lang = mw.language.new(wiki.langcode) amount = lang:formatNum(tonumber(amount)) -- This is used to get the unit name for a numeric value local suffix = "" local unitID = v.mainsnak.datavalue.value.unit unitID = mw.ustring.sub(unitID, mw.ustring.find(unitID, "Q"), -1) if mw.ustring.sub(unitID, 1, 1) == "Q" then local unit_label = mw.wikibase.label(unitID) suffix = " " .. require("Módulo:Wikidata/Unidades").getUnit(amount, unit_label, unitID, unit == "unidade") end out[#out+1] = amount .. suffix .. postfix end end if maxvals > 0 and #out >= maxvals then break end end -- data types which are monolingualtext: elseif props[1].mainsnak.datatype == "monolingualtext" then for k, v in pairs(props) do if filter(v) and ((onlysrc == false) or sourced(v)) then -- has valid refs or all values required if v.mainsnak.datavalue.value.language == 'pt-br' or v.mainsnak.datavalue.value.language == 'pt' then out[#out+1] = v.mainsnak.datavalue.value.text end -- check for language values end -- check for sourced if maxvals > 0 and #out >= maxvals then break end end -- some other data type: else -- some other data type -- e.g. globe-coordinate where mainsnak.datavalue.value is a table -- either write a specific handler -- or we can use formatPropertyValues() as a temporary measure. This won't work with multiple valid values. for k, v in pairs(props) do if filter(v) and ((onlysrc == false) or sourced(v)) then -- has valid refs or all values required local propertyValue = entity:formatPropertyValues(propertyID).value out[#out+1] = propertyValue break end -- check for sourced if maxvals > 0 and #out >= maxvals then break end end end -- if there's anything to return, then return a list -- comma-separated by default, but may be specified by the sep parameter -- optionally specify a hlist or ubl if #out > 0 then if sorted then table.sort(out) end if list == "hlist" then return frame:expandTemplate{title = 'Hlist', args = out} elseif list == "ubl" then return frame:expandTemplate{title = 'Unbulleted list', args = out} else if noic then if contagem == "sim" then return #out else return table.concat(out, separator) end else if contagem == "sim" then return #out else return table.concat(out, separator) .. icon end end end else return nil -- no items had valid reference end end ------------------------------------------------------------------------------- -- Public functions ------------------------------------------------------------------------------- -- getValue is used to get a value, or a comma separated list of them if multiple values exist -- p.getValue = function(frame) local propertyID = mw.text.trim(frame.args[1] or "") -- There may be a local parameter supplied, if it's blank, set it to nil local input_parm = mw.text.trim(frame.args[2] or "") local unit = mw.text.trim(frame.args[3] or "") if input_parm and (#input_parm == 0) then input_parm = nil end local success, errorOrEntity, props = parseInput(frame, input_parm, propertyID) if not success then return errorOrEntity else entity = errorOrEntity end local function filter(claim) return true end return _getvalue(frame, entity, props, filter, propertyID, unit) end ------------------------------------------------------------------------------- -- getPreferredValue is used to get a value, or a comma separated list of them if multiple values exist -- If preferred ranks are set, it will return those values, otherwise values with normal ranks -- p.getPreferredValue = function(frame) local propertyID = mw.text.trim(frame.args[1] or "") -- There may be a local parameter supplied, if it's blank, set it to nil local input_parm = mw.text.trim(frame.args[2] or "") local unit = mw.text.trim(frame.args[3] or "") if input_parm and (#input_parm == 0) then input_parm = nil end local success, errorOrEntity, props = parseInput(frame, input_parm, propertyID) if not success then return errorOrEntity else entity = errorOrEntity end local prefflag = false for k, v in pairs(props) do if v.rank == "preferred" then prefflag = true break end end local function filter(claim) return claim.rank == "preferred" or prefflag == false end return _getvalue(frame, entity, props, filter, propertyID, unit) end ------------------------------------------------------------------------------- -- getSourcedValue is used to get a value, or a comma separated list of them if multiple values exist -- but only values that are sourced are returned -- redundant to getValue with onlysourced=true but kept for backwards compatibility -- now defined via getValue -- p.getSourcedValue = function(frame) frame.args.onlysourced = "yes" return p.getValue(frame) end ------------------------------------------------------------------------------- -- getCoords is used to get coordinates for display in an infobox -- whitelist and blacklist are implemented -- optional 'display' parameter is allowed, defaults to "inline, title" -- p.getCoords = function(frame) local propertyID = "P625" local input_parm = mw.text.trim(frame.args[1] or "") if input_parm and (#input_parm == 0) then input_parm = nil end -- if there is a 'display' parameter supplied, use it -- otherwise default to "inline, title" local disp = frame.args.display if (not disp) or (#disp == 0) then disp = "inline, title" end local success, errorOrEntity = parseInput(frame, input_parm, property_id) if not success then return errorOrEntity else local entity = errorOrEntity local lat_long = {} local coords = entity:formatPropertyValues(propertyID).value -- the latitude and longitude are returned like this: nn°nn'nn.n" -- using html entities with hex values really screws up parsing the numbers - thanks devs local lat = mw.ustring.match(coords, "^[^,]*") -- everything from the start to before the comma local long = mw.ustring.match(coords, "[^ ]*$") -- everything from after the space to the end lat = lat:gsub("&#%d%d;", ":") -- clean out the html entities long = long:gsub("&#%d%d;", ":") -- clean out the html entities -- read the latitude numbers into a table for num in mw.ustring.gmatch(lat, "%d+%.?%d*") do lat_long[#lat_long + 1] = num end -- add the N/S lat_long[#lat_long + 1] = lat:sub(-1) -- read the longitude numbers into a table for num in mw.ustring.gmatch(long, "%d+%.?%d*") do lat_long[#lat_long + 1] = num end -- add E/W for long lat_long[#lat_long + 1] = long:sub(-1) -- add named parameter for display lat_long["display"] = disp -- invoke template Coor dms with the values stored in the table return frame:expandTemplate{title = 'Coor dms', args = lat_long} end end ------------------------------------------------------------------------------- -- getQualifierValue is used to get a formatted value of a qualifier -- -- The call needs: a property (the unnamed parameter or 1=) -- a target value for that property (pval=) -- a qualifier for that target value (qual=) -- The usual whitelisting and blacklisting of the property is implemented -- The boolean onlysourced= parameter can be set to return nothing -- when the property is unsourced (or only sourced to wIRChelp) -- p.getQualifierValue = function(frame) local propertyID = mw.text.trim(frame.args[1] or "") -- The PropertyID of the target value of the property -- whose qualifier is to be returned is passed in named parameter |pval= local propvalue = frame.args.pval -- The PropertyID of the qualifier -- whose value is to be returned is passed in named parameter |qual= local qualifierID = frame.args.qual -- onlysourced is a boolean passed to return qualifiers -- only when property values are sourced to something other than wIRChelp -- if nothing or an empty string is passed set it false -- if "false" or "no" or 0 is passed set it false local onlysrc = parseParam(frame.args.onlysourced,false) local success, errorOrEntity, props = parseInput(frame,nil, propertyID) if not success then return errorOrEntity else local entity = errorOrEntity -- Scan through the values of the property -- we want something like property is P793, significant event (in propertyID) -- whose value is something like Q385378, construction (in propvalue) -- then we can return the value(s) of a qualifier such as P580, start time (in qualifierID) for k1, v1 in pairs(props) do if v1.mainsnak.snaktype == "value" and v1.mainsnak.datavalue.type == "wikibase-entityid" then -- It's a wiki-linked value, so check if it's the target (in propvalue) -- and if it has qualifiers if v1.mainsnak.datavalue.value.id == propvalue and v1.qualifiers then if (onlysrc == true) and not sourced(v1) then return end -- if we've got this far, we have a (sourced) claim with qualifiers -- which matches the target, so find the value(s) of the qualifier we want local quals = v1.qualifiers[qualifierID] local out = {} if quals then if quals[1].datatype == "wikibase-item" then for k2, v2 in pairs(quals) do local valueID = v2.datavalue.value.id local sitelink = mw.wikibase.sitelink(valueID) local label = labelOrId(valueID,frame.args.idioma or "pt-br") if sitelink then out[#out + 1] = "[[" .. sitelink .. "|" .. label .. "]]" else out[#out + 1] = "[[:d:" .. valueID .. "|" .. label .. "]] <span title='" .. i18n["errors"]["local-article-not-found"] .. "'>[[Ficheiro:Wikidata-logo.svg|16px|alt=|link=]]</span>" end end return table.concat(out, ", ") else return mw.wikibase.renderSnaks(quals) end end end end -- of loop through values of propertyID end end return nil end ------------------------------------------------------------------------------- -- getLink returns the label for a Qid wiki-linked to the local article (if the article exists) -- if label doesn't exist, it returns the Qid wiki-linked to the local article (if the article exists) -- p.getLink = function(frame) local itemID = mw.text.trim(frame.args[1] or "") if itemID == "" then return end local sitelink = mw.wikibase.sitelink(itemID) local idioma = frame.args.idioma or "pt-br" local label = labelOrId(itemID,idioma) if sitelink then return "[[" .. sitelink .. "|" .. label .. "]]" else return label end end ------------------------------------------------------------------------------- -- getID returns the qid for the local article (if the article has one) -- if qid doesn't exist, it returns an empty string -- p.getID = function() local entity = mw.wikibase.getEntityObject() if entity == nil then return "" end return entity.id end ------------------------------------------------------------------------------- -- getLabel returns the label for a Qid -- if label doesn't exist, it returns the Qid -- p.getLabel = function(frame) local itemID = mw.text.trim(frame.args[1] or "") if itemID == "" then return end return labelOrId(itemID,frame.args.idioma or "pt-br") end ------------------------------------------------------------------------------- -- getAT returns the article title for a Qid -- or nothing if it doesn't exist -- p.getAT = function(frame) local itemID = mw.text.trim(frame.args[1] or "") if itemID == "" then return end return mw.wikibase.sitelink(itemID) end ------------------------------------------------------------------------------- -- getSitelink returns the article title for a Qid in a globalSiteId wiki (like "enwiki" or "ptwiki") -- or nothing if it doesn't exist -- p.getSitelink = function(frame) local itemID = mw.text.trim(frame.args[1] or "") local globalSiteId = mw.text.trim(frame.args[2] or "") return mw.wikibase.sitelink(itemID,globalSiteId) end local _getSitelink = function(qid,wiki) local qid = qid or "" local wiki = wiki or "" return mw.wikibase.sitelink(qid,wiki) end ------------------------------------------------------------------------------- -- formatDate is a wrapper to export the private function format_Date -- p.formatDate = function(frame) return format_Date(frame,frame.args[1], frame.args.df, frame.args.bc,frame.args.idioma, frame.args.datasemlink) end ------------------------------------------------------------------------------- -- checkBlacklist allows a test to check whether a named field is suppressed -- {{#if:{{#invoke:WikidataIB |checkBlacklist |name=Joe |suppressfields=Dave; Joe; Fred}} | not blacklisted | blacklisted}} -- displays "blacklisted" -- {{#if:{{#invoke:WikidataIB |checkBlacklist |name=Jim |suppressfields=Dave; Joe; Fred}} | not blacklisted | blacklisted}} -- displays "not blacklisted" -- p.checkBlacklist = function(frame) local blacklist = frame.args.suppressfields local fieldname = frame.args.name if blacklist and fieldname then if blacklist:find(fieldname) then return nil end return true end end p.predMorte = function(frame) local result1 = {} local result2 = {} local idioma for word in string.gmatch(frame.args[1],"[^|]+") do result1[#result1+1] = word end for word2 in string.gmatch(frame.args[2],"[^|]+") do result2[#result2+1] = word2 end if #result1 == 2 then result1[3] = result1[2] result1[2] = result1[1] result1[1] = "" elseif #result1 == 1 then result1[3] = result1[1] result1[2] = "" result1[1] = "" end if #result2 == 2 then result2[3] = result2[2] result2[2] = result2[1] result2[1] = "" elseif #result2 == 1 then result2[3] = result2[1] result2[2] = "" result2[1] = "" end if frame.args.idioma == "pt-ao" then idioma = "ao" else idioma = "br" end if (result1[1]=="Desconhecido") or (result1[2]== "Desconhecido") or (result1[3]== "Desconhecido") then return "Desconhecido" else if (result2[1]=="Desconhecido") or (result2[2]== "Desconhecido") or (result2[3]== "Desconhecido") then return frame:expandTemplate{ title = 'Morte', args = {result1[1],result1[2],result1[3],lang = idioma}} else return frame:expandTemplate{ title = 'Morte', args = {result1[1],result1[2],result1[3],result2[1],result2[2],result2[3],lang = idioma}} end end end p.predDni = function(frame) local result = {} local idioma local comidade = frame.args[2] or "" for word in string.gmatch(frame.args[1],"[^|]+") do result[#result+1] = word end if #result == 2 then result[3] = result[2] result[2] = result[1] result[1] = "" elseif #result == 1 then result[3] = result[1] result[2] = "" result[1] = "" elseif #result == 0 then result[3] = "" result[2] = "" result[1] = "" end if frame.args.idioma == "pt-ao" then idioma = "ao" else idioma = "br" end if (result[1]=="Desconhecido") or (result[2]== "Desconhecido") or (result[3]== "Desconhecido") then return "Desconhecido" end if result[3]~="" and tonumber(result[3])<1900 then comidade = "si" end if string.match(result[3], "-") then result[3] = string.gsub(result[3], "-", "") result[3] = result[3].." a.C." end if comidade then return frame:expandTemplate{ title = 'Dni', args = {result[1],result[2],result[3],comidade,lang = idioma}} else return frame:expandTemplate{ title = 'Dni', args = {result[1],result[2],result[3],lang = idioma}} end end p.getValueQualIndirect = function(frame) local propertyID = mw.text.trim(frame.args[1] or "") -- The PropertyID of the qualifier -- whose value is to be returned is passed in named parameter |qual= local qualifierID = frame.args.qual -- onlysourced is a boolean passed to return qualifiers -- only when property values are sourced to something other than wIRChelp -- if nothing or an empty string is passed set it false -- if "false" or "no" or 0 is passed set it false local onlysrc = parseParam(frame.args.onlysourced,false) local artigosemlink = frame.args.artigosemlink or "não" local success, errorOrEntity, props = parseInput(frame,nil, propertyID) if not success then return errorOrEntity else local entity = errorOrEntity -- Scan through the values of the property -- we want something like property is P793, significant event (in propertyID) -- whose value is something like Q385378, construction (in propvalue) -- then we can return the value(s) of a qualifier such as P580, start time (in qualifierID) local sep = frame.args.sep or ", " local out = {} local onlyvalue = frame.args.onlyvalue or "" local comlink = frame.args.comlink or "" for k1, v1 in pairs(props) do if v1.mainsnak.snaktype == "value" then --and v1.mainsnak.datavalue.type == "wikibase-entityid" then -- It's a wiki-linked value, so check if it's the target (in propvalue) -- and if it has qualifiers if v1.mainsnak.datatype == "wikibase-item" then local propid = v1.mainsnak.datavalue.value.id local propsitelink = mw.wikibase.sitelink(propid) local proplabel = labelOrId(propid,frame.args.idioma or "pt-br") if propsitelink then if propsitelink == proplabel then propvalue = "[["..propsitelink.."]]" else propvalue = "[["..propsitelink.."|"..proplabel.."]]" end else if comlink == "sim" then propvalue = "[["..proplabel.."]]" else propvalue = proplabel end end end --elseif quantity, url etc TODO if v1.qualifiers then --v1.mainsnak.datavalue.value.id == propvalue and if (onlysrc == true) and not sourced(v1) then return end -- if we've got this far, we have a (sourced) claim with qualifiers -- which matches the target, so find the value(s) of the qualifier we want local quals = v1.qualifiers[qualifierID] if quals then local sep_qual = frame.args.sep_qual or ": " local sep_inter_qual = frame.args.sep_inter_qual or ", " local valuequal = {} local postfix = frame.args.postfix or "" if quals[1].datatype == "wikibase-item" then for k2, v2 in pairs(quals) do local valueID = v2.datavalue.value.id local sitelink = mw.wikibase.sitelink(valueID) local label = labelOrId(valueID,frame.args.idioma or "pt-br") if sitelink then if sitelink ~= label then if artigosemlink == "sim" then valuequal[#valuequal+1] = sitelink..postfix else valuequal[#valuequal+1] = "[[" .. sitelink .. "|" .. label .. "]]"..postfix end else if artigosemlink == "sim" then valuequal[#valuequal+1] = sitelink..postfix else valuequal[#valuequal+1] = "[["..label.."]]"..postfix end end else if artigosemlink == "sim" then valuequal[#valuequal+1] = label..postfix else valuequal[#valuequal+1] = "[["..label.."]]"..postfix end end end if onlyvalue == "sim" then out[#out+1] = table.concat(valuequal, sep_inter_qual) else out[#out+1] = propvalue .. sep_qual .. table.concat(valuequal, sep_inter_qual) end else for k2, v2 in pairs(quals) do valuequal[#valuequal+1] = mw.wikibase.renderSnak(v2)..postfix end if onlyvalue == "sim" then out[#out+1] = table.concat(valuequal, sep_inter_qual) else out[#out+1] = propvalue .." ".. sep_qual .. table.concat(valuequal, sep_inter_qual) end end end end end -- of loop through values of propertyID end return table.concat(out, sep) end return nil end p.getValueIndirect = function(frame) local property1 = mw.text.trim(frame.args[1] or "") local property2 = mw.text.trim(frame.args[2] or "") -- Can take a named parameter |qid which is the Wikidata ID for the article. -- This will not normally be used because it's an expensive call. local qid1 = frame.args.qid if qid1 and (#qid1 == 0) then qid1 = nil end local entity1 = mw.wikibase.getEntityObject(qid1) local props1 if entity1 and entity1.claims then props1 = entity1.claims[property1] end local out = {} local oo = {} local sep = frame.args.sep or "," if props1 then -- Check that the first value of the property is a wikibase-item for k1, v1 in pairs(props1) do if v1.mainsnak.datatype == "wikibase-item" then local qid2 = v1.mainsnak.datavalue.value.id local entity2 = mw.wikibase.getEntityObject(qid2) if entity2.claims then -- only need props2 if we want a more sophisticated parsing, e.g. mdy dates -- local props2 = entity2.claims[property2] out[#out+1] = entity2:formatPropertyValues(property2).value else out[#out+1] = qid2 .. " has no claims." end else out[#out+1] = "not wikibase-item: " .. v1.mainsnak.datatype --debug end end end return table.concat(out, sep.." ") end ------------------------------------------------------------------------------- -- _getCommonslink takes an optional qid of a Wikidata entity passed as |qid= -- It returns one of the following in order of preference: -- the Commons sitelink of the linked Wikidata item; -- the Commons sitelink of the topic's main category of the linked Wikidata item; -- the Commons category. -- If the optional parameter onlycat is true/yes/1 then only categories are returned -- defaults to false. ------------------------------------------------------------------------------- -- Dependencies: _getSitelink(); parseParam() ------------------------------------------------------------------------------- local _getCommonslink = function(qid, onlycat, fallback) qid = (qid or ""):upper() if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid then return nil end onlycat = parseParam(onlycat, false) local sitelink = _getSitelink(qid, "commonswiki") if onlycat and sitelink and sitelink:sub(1,9) ~= "Category:" then sitelink = nil end if not sitelink then -- check for topic's main category local prop910 = mw.wikibase.getBestStatements(qid, "P910")[1] if prop910 then local tmcid = prop910.mainsnak.datavalue.value.id sitelink = _getSitelink(tmcid, "commonswiki") end end if not sitelink and fallback then -- check for Commons category (string value) local prop373 = mw.wikibase.getBestStatements(qid, "P373")[1] if prop373 then sitelink = prop373.mainsnak.datavalue.value if sitelink then sitelink = "Category:" .. sitelink end end end return sitelink end ------------------------------------------------------------------------------- -- getCommonsLink takes an optional qid of a Wikidata entity passed as |qid= -- It returns one of the following in order of preference: -- the Commons sitelink of the linked Wikidata item; -- the Commons sitelink of the topic's main category of the linked Wikidata item; ------------------------------------------------------------------------------- -- Dependencies: _getCommonslink(); _getSitelink(); parseParam() ------------------------------------------------------------------------------- p.getCommonsLink = function(frame) local oc = frame.args.onlycat or frame.args.onlycategories local fb = parseParam(frame.args.fallback or frame.args.fb, true) return _getCommonslink(frame.args.qid, oc, fb) end ------------------------------------------------------------------------------- local ArtsIDs = { ['P347'] = 'http://www.culture.gouv.fr/public/mistral/joconde_fr?ACTION=CHERCHER&FIELD_1=REF&VALUE_1=$1', ['P350'] = 'https://rkd.nl/explore/images/$1', ['P1212'] = 'http://cartelfr.louvre.fr/cartelfr/visite?srv=car_not_frame&idNotice=$1', ['P1428'] = 'http://www.lostart.de/EN/Verlust/$1', ['P1679'] = 'https://artuk.org/discover/artworks/$1', ['P1726'] = 'http://www.polomuseale.firenze.it/inv1890/scheda.asp?position=1&ninv=$1', ['P2014'] = 'http://www.moma.org/collection/works/$1', ['P2092'] = 'http://www.bildindex.de/obj$1.html', ['P2108'] = 'https://www.kulturarv.dk/kid/VisVaerk.do?vaerkId=$1', ['P2242'] = 'http://www.polomuseale.firenze.it/catalogo/scheda.asp?nctn=$1&value=1', ['P2282'] = 'http://groeningemuseum.be/collection/work/id/$1', ['P2344'] = 'http://www.purl.org/inha/agorha/003/$1', ['P2511'] = 'http://mskgent.be/collection/work/id/$1', ['P2539'] = 'http://collection.nationalmuseum.se/eMuseumPlus?service=ExternalInterface&module=collection&objectId=$1&viewType=detailView', ['P2582'] = 'http://www.getty.edu/art/collection/objects/$1', ['P3272'] = 'http://catalogo.fondazionezeri.unibo.it/scheda/opera/$1/', ['P3293'] = 'http://balat.kikirpa.be/object/$1', ['P3386'] = 'http://frenchsculpture.org/sculpture/$1', ['P3386'] = 'https://frenchsculpture.org/fr/sculpture/$1', ['P3467'] = 'http://www.polomuseale.firenze.it/invSculture/scheda.asp?position=1&ninv=$1', ['P3504'] = 'http://www.polomuseale.firenze.it/invpalatina/scheda.asp?position=1&ninv=$1', ['P3634'] = 'http://www.metmuseum.org/art/collection/search/$1', ['P3711'] = 'http://vanderkrogt.net/statues/object.php?record=$1', ['P3855'] = 'http://www.lombardiabeniculturali.it/opere-arte/schede/$1/', ['P3929'] = 'http://collections.vam.ac.uk/item/$1', ['P4144'] = 'http://www.the-athenaeum.org/art/detail.php?id=$1', ['P4257'] = 'http://www.emuseum.jp/detail/$1', ['P4373'] = 'http://www.nationaltrustcollections.org.uk/object/$1', ['P4380'] = 'http://ta.sandrart.net/-artwork-$1', ['P4399'] = 'http://enciclopedia.itaucultural.org.br/$1', ['P4525'] = 'http://opendata.muis.ee/object/$1', ['P4564'] = 'https://digikogu.ekm.ee/oid-$1', ['P4582'] = 'https://www.kulturelles-erbe-koeln.de/documents/obj/$1', ['P4610'] = 'https://www.artic.edu/artworks/$1', ['P4611'] = 'https://collections.lacma.org/node/$1', ['P4625'] = 'http://www.mfa.org/collections/object/$1', ['P4643'] = 'http://www.philamuseum.org/collections/permanent/$1.html', ['P4659'] = 'http://www.musee-orsay.fr/en/collections/index-of-works/notice.html?nnumid=$1', ['P4659'] = 'http://www.musee-orsay.fr/fr/collections/catalogue-des-oeuvres/notice.html?nnumid=$1', ['P4673'] = 'https://www.mfah.org/art/detail/$1', ['P4674'] = 'http://collection.imamuseum.org/artwork/$1/', ['P4683'] = 'https://www.nga.gov/content/ngaweb/Collection/art-object-page.$1.html', ['P4684'] = 'https://www.ngv.vic.gov.au/explore/collection/work/$1/', ['P4686'] = 'https://collection.cmoa.org/objects/$1', ['P4692'] = 'http://browse.americanartcollaborative.org/object/$1.html', ['P4701'] = 'https://www.google.com/culturalinstitute/beta/asset/wd/$1', ['P4704'] = 'https://americanart.si.edu/collections/search/artwork/?id=$1', ['P4709'] = 'https://collection.barnesfoundation.org/objects/$1/details', ['P4712'] = 'https://collections.artsmia.org/art/$1', ['P4713'] = 'http://art.thewalters.org/detail/$1', ['P4721'] = 'http://mubevirtual.com.br/pt_br?Dados&area=ver&id=$1', ['P4737'] = 'https://www.guggenheim.org/artwork/$1', ['P4738'] = 'http://collections.britishart.yale.edu/vufind/Record/$1', ['P4739'] = 'https://www.augustins.org/fr/oeuvre/-/oeuvre/$1', ['P4740'] = 'https://www.brooklynmuseum.org/opencollection/objects/$1', ['P4761'] = 'http://art.rmngp.fr/en/library/artworks/$1', ['P4761'] = 'http://art.rmngp.fr/fr/library/artworks/$1', ['P4764'] = 'http://www.culture.gouv.fr/public/mistral/arcade_fr?ACTION=CHERCHER&FIELD_1=REF&VALUE_1=$1', ['P4814'] = 'https://siris-artinventories.si.edu/ipac20/ipac.jsp?&menu=search&index=.NW&term=$1', ['P4905'] = 'http://kmska.be/collection/work/id/$1', ['P5210'] = 'http://www.gallery.am/en/database/item/$1/', ['P5223'] = 'http://museum.imj.org.il/artcenter/includes/item.asp?id=$1', ['P5265'] = 'https://www.dordrechtsmuseum.nl/objecten/id/$1', ['P5268'] = 'http://acervo.mnav.gub.uy/obras.php?q=ni:$1', ['P5269'] = 'https://www.webumenia.sk/dielo/$1', ['P5407'] = 'http://datenbank.museum-kassel.de/$1', ['P5499'] = 'http://collectie.boijmans.nl/en/collection/artworks/$1', ['P5783'] = 'http://lucascranach.org/$1', ['P5823'] = 'https://digital.belvedere.at/objects/$1/', ['P5891'] = 'http://www.bpk-images.de/id/$1', ['P6004'] = 'https://www.brasilianaiconografica.art.br/obras/$1/wd', ['P6007'] = 'http://salons.musee-orsay.fr/index/notice/$1', ['P6020'] = 'https://www.france.tv/france-2/d-art-d-art/$1.html', ['P6141'] = 'https://anosgrandshommes.musee-orsay.fr/index.php/Detail/objects/$1', ['P6152'] = 'http://npg.si.edu/object/npg_$1', ['P6238'] = 'https://monumentsmorts.univ-lille.fr/monument/$1/wd/', ['P6239'] = 'https://monuments.iec.cat/fitxa.asp?id=$1', ['P6246'] = 'http://parismuseescollections.paris.fr/en/node/$1', ['P6246'] = 'http://parismuseescollections.paris.fr/fr/node/$1', ['P6246'] = 'http://parismuseescollections.paris.fr/es/node/$1', ['P6310'] = 'http://museosphere.paris.fr/oeuvres/$1', ['P6332'] = 'https://www.panoramadelart.com/$1', ['P6355'] = 'https://collection.centrepompidou.fr/#/artwork/$1', ['P6356'] = 'http://www.ihoi.org/app/photopro.sk/ihoi_icono/detail?docid=$1&lang=eng', ['P6358'] = 'https://www.navigart.fr/picassoparis/#/artwork/$1', ['P6372'] = 'https://www.interpol.int/notice/search/woa/$1', ['P6374'] = 'http://www.mam.paris.fr/en/online-collections#/artwork/$1' } ------------------------------------------------------------------------------- -- getArtIdentifiers takes an optional qid of a Wikidata entity passed as |qid= -- It returns all art identifiers of that entity ------------------------------------------------------------------------------- function p.getArtIdentifiers(frame) local qid = frame.args.qid or "" if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end local entity = mw.wikibase.getEntityObject(qid) local props local out = {} for k, v in pairs(ArtsIDs) do if entity and entity.claims[k] then props = entity.claims[k] for k2, v2 in pairs(props) do if v2.mainsnak.snaktype ~= 'novalue' then out[#out+1] = '[' .. mw.ustring.gsub(v, '$1', v2.mainsnak.datavalue.value) .. ']' end end end end return table.concat(out,"") end return p