Módulo:Proofreadpage index template
[editar] [ ]
Documentación del módulo
Uso
Módulo que construye la información visible de un Índice (Index).
El módulo está pensado para ser llamado por MediaWiki:Proofreadpage index template, pero puede ser probado con el siguiente código:
{{#invoke:Proofreadpage index template|fields|parámetros}}
fields
es la función del módulo encargada de construir la página, según el resto de parámetros.
- Parámetros:
Wikidata
(obligatorio): es el identificador de Wikidata del Índice. Por ejemplo, «Q107297266». A partir de éste se capturan de Wikidata los datos del Índice "capturables", comoAutor
,Traductor
,Titulo
, etc. Más información en Ayuda:Índices.
- -Si un campo está informado a mano se ignorará lo que se hubiera capturado de Wikidata.
- -Si un campo no está informado a mano y se recupera algún dato de Wikidata, entonces se mostrará este último.
- -Si un campo no está informado a mano y no se recupera nada de Wikidata, el campo no aparecerá.
Paginas
(obligatorio): es la tabla con las páginas del Índice (<pagelist/>
) que MediaWiki:Proofreadpage index data config se encarga de pasar a MediaWiki:Proofreadpage index template. Para hacer pruebas, podemos poner cualquier literal (ya que<pagelist/>
sólo funcionará en el namespace Índice).
NomPag
(obligatorio): es el {{NOMPAGE}} de la página del Índice. Para hacer pruebas podemos poner el nombre del archivo, como «El Robinson suizo (1864).pdf». Se utiliza para mostrar la imagen del archivo así como el enlace para purgar las páginas.
NomPagE
(obligatorio): es el {{NOMPAGEE}} de la página del Índice. Para hacer pruebas podemos poner el nombre del archivo, como «El_Robinson_suizo_(1864).pdf». Se utiliza para mostrar la imagen del archivo.
Ejemplo
- Código mínimo de pruebas que captura datos de Wikidata:
{{#invoke:Proofreadpage index template|fields|NomPag=El Robinson suizo (1864).pdf|NomPagE=El_Robinson_suizo_(1864).pdf|Paginas=test|Wikidata=Q107297266}}
Esta documentación está transcluida desde Módulo:Proofreadpage index template/doc.
Los editores pueden experimentar en la zona de pruebas
Por favor, añade las categorías a la subpágina de documentación.
(subpáginas - enlaces)
Los editores pueden experimentar en la zona de pruebas
Por favor, añade las categorías a la subpágina de documentación.
(subpáginas - enlaces)
--------------------------------------------------------------------------------
-- Adaptado de https://en.wikisource.org/wiki/Module:Proofreadpage_index_template
-- y https://ca.wikisource.org/wiki/Module:Proofreadpage_index_template
-- This is a module to implement logic for [[MediaWiki:Proofreadpage index template]]
--------------------------------------------------------------------------------
-- Ejemplo (función p.fields):
-- {{#invoke:Proofreadpage index template|fields|NomPag=El Robinson suizo (1864).pdf|NomPagE=El_Robinson_suizo_(1864).pdf|Paginas=tabla|Wikidata=Q107297266}}
--------------------------------------------------------------------------------
local Wikidata = require('Module:Wikidata')
local getArgs = require('Module:Arguments').getArgs
local p = {} --p stands for package
-- mapping of field ID to field properties
local headings = {
title = { txt = 'Título', 'P1476'},
subtitle = { txt = 'Subtítulo', 'P1680'},
serie = { txt = 'Serie o colección', ''},
volum = { txt = 'Volumen', 'P478'},
author = { txt = 'Autor [[Archivo:Commons-emblem-notice.svg|20px|enlace=|alt=|frameless|link=Ayuda:Autores]]', 'P50'},
editor = { txt = 'Editor', 'P98'},
illustrator = { txt = 'Ilustrador', 'P110'},
translator = { txt = 'Traductor', 'P655'},
introducer = { txt = 'Prologuista', 'P2679'},
year = { txt = 'Año', 'P577'},
editorial = { txt = 'Editorial', 'P123'},
printer = { txt = 'Imprenta', 'P872'},
place = { txt = 'Lugar', 'P291'},
country = { txt = 'País', ''}, --derechos (P495) pasar a Wikidata realmente?
source = { txt = 'Fuente', ''},
modernizar = { txt = 'Modernización de la ortografía', ''},
quality = { txt = 'Progreso', ''},
wikidata = { txt = 'Metadatos', ''},
cadena_autor= {'P2093'},
}
local function get_heading(id)
if headings[id] then
return headings[id]['txt']
end
error( "Can't find heading for ID: " .. id )
end
local function construct_image(content, nompage, qid, nompag)
if nompage == nil or nompage == '' then error('nompage no puede ser nulo') end
local s = ''
--Miramos si en WD hay 1 o más P996, capturamos el que coincida, y le miramos el P4714 (nº pág. con título).
local P4714 = ''
if qid then
local FileOnCommonsStmts = mw.wikibase.getAllStatements (qid, 'P996');
if FileOnCommonsStmts then
for _, stmt in pairs( FileOnCommonsStmts ) do
local commonsFilename = stmt['mainsnak']['datavalue']['value']
--decode: nompag podría venir con "'" en lugar de "'" (apóstrofe)
if mw.text.decode(nompag) == commonsFilename then
P4714 = Wikidata.claim{item=qid, property="P996", qualifier="P4714", lang="es", list=false}
end
end
end
end
s = s .. '<tr><td valign="top">'
if content then
else
if P4714 == '' then
content = '1' --si no hay nada de nada
else
content = P4714
end
if content == nil then content = '1' end
end
if tonumber(content) == nil then
s = s .. content
else
s = s .. '<span id="ws-cover" style="display:none; speak:none;">'
s = s .. nompage .. "/" .. content .. "</span>"
s = s .. '[[File:' .. nompage .. '|page=' .. content .. '|frameless]]'
end
s = s .. '</td>'
s = s .. '<td valign="top"><table style="margin-left:0">' --se cierran en construct_field_paginas
return s
end
local function construct_field_paginas(content, nompage)
if nompage == nil or nompage == '' then return "Error en construct_field_pagines (nompage)" end
if content == nil or content == '' then return "Error en construct_field_pagines (content)" end
local s = ''
s = s .. '</table></td></tr>'
s = s .. '<tr><td valign="top" colspan="2"><span class="plainlinks">'
s = s .. '<b>[//es.wikisource.org/wiki/File:' .. nompage .. '?action=purge Páginas]</b></span>'
s = s .. ' ([[Ayuda:Nivel_de_las_páginas|Nivel]])\n'
s = s .. '<div style="padding-left:0.5em; background-color:#F0F0F0;">\n' .. content .. '</div></td></tr>'
s = s .. '</table></td>'
return s
end
local function construct_field_sumario(content)
local s = ''
if content then
s = '<td width="33%" valign="top">' .. content .. '</td>'
end
return s
end
--------------------------------------------------------------------------------
-- Get an Item based on what's passed in the 'wikidata' or 'page' parameters of
-- the args, or the current page's ID otherwise.
local function getItem( args )
local id = nil
if type( args ) == 'string' and args ~= '' then
id = args
end
return mw.wikibase.getEntity( id )
end
--------------------------------------------------------------------------------
-- Exported method. Get wikitext for displaying an edition's badges from Wikidata.
-- Adaptado de https://ca.wikisource.org/wiki/Module:Edition
local function badge( args )
local item = getItem( args ) --por defecto, id de la página
if args.qid ~= nil then --pero si pasamos un qid, id pasado
item = mw.wikibase.getEntity(args.qid)
end
if not ( item and item.sitelinks and item.sitelinks.eswikisource and item.sitelinks.eswikisource.badges ) then
return ''
end
local badges = item.sitelinks.eswikisource.badges
local out = ''
for _, badge in pairs( badges ) do
local badgeOut = ''
local badgeItem = mw.wikibase.getEntity( badge )
local wikisourceBadgeClass = 'Q75042035'
if badgeItem.claims.P31[1].mainsnak.datavalue.value.id == wikisourceBadgeClass and badgeItem.claims.P18 ~= nil then
if badge ~= nil then
badgeOut = badgeOut .. badge --Q20748091 (no corr.), Q20748092 (corr.), Q20748093 (val.), Q20748094 (err.)
end
out = out .. badgeOut
end
end
return mw.getCurrentFrame():preprocess( out )
end
local function wdws(args)
--básicos
local id = args.id
local qid = args.qid
local WS = args.content
--variables
local list = args.list or false
local fmt = args.formatting or ''
local siWDsiWS = false
local noWDsiWS = false
local P = headings[id][1]
if not P or P == '' then return WS, false, false end
if qid then
local WD = Wikidata.claim{item=qid, property=P, lang="es", list=list, formatting=fmt}
if WD then
if WS then
siWDsiWS = true
else
WS = WD
end
end
if not WD and WS then noWDsiWS = true end
end
return WS, siWDsiWS, noWDsiWS
end
-- construct a basic "field" row
local function construct_field(id, content, qid, nompag)
if id == nil then error( "Error en construct_field" ) end
local CatError = "[[Categoría:Índices con discrepancias respecto a Wikidata"
local contentAux = content
local siWDsiWS = false --hay contenido en WD y en WS (se puede borrar)
local noWDsiWS = false --no hay contenido en WD pero sí en WS (no borrar hasta migrarlo a WD)
local caterror = false --campo generó error
-- casos generales
---- list = true: admite valores múltiples
if id == 'translator' or id =='illustrator' or id == 'editor' or id == 'introducer' or id == 'editorial' or id == 'printer' then
content, siWDsiWS, noWDsiWS = wdws{id=id, content=content, qid=qid, list=true}
end
---- formatting = label: enlaza sólo cuando corresponda
if id == 'place' or id == 'country' then
content, siWDsiWS, noWDsiWS = wdws{id=id, content=content, qid=qid, formatting='label'}
end
---- formato para fecha
if id == 'year' then
content, siWDsiWS, noWDsiWS = wdws{id=id, content=content, qid=qid, formatting=" j xg Y"}
end
---- resto de casos
if id == 'subtitle' or id == 'volum' then
content, siWDsiWS, noWDsiWS = wdws{id=id, content=content, qid=qid}
end
-- casos especiales
if id == 'author' then
content, siWDsiWS, noWDsiWS = wdws{id=id, content=content, qid=qid, list=true}
if content == 'valor desconocido' then
content = '[[:Categoría:Obras de autores anónimos|Anónimo]]'
elseif not content then
content, siWDsiWS, noWDsiWS = wdws{id='cadena_autor', content=content, qid=qid, list=true}
end
end
if id == 'title' then
wTitulo, siWDsiWS, noWDsiWS = wdws{id=id, content=content, qid=qid}
if not content then
local wSiteLink = mw.wikibase.getSitelink(qid)
if wSiteLink then
if wTitulo then
content = "''[[" .. wSiteLink .. "|" .. wTitulo .. "]]''"
else
content = "''[[" .. wSiteLink .. "]]''"
end
elseif wTitulo then
content = "''[["..wTitulo.."]]''"
end
end
end
if id == 'serie' then
end
if id == 'modernizar' then
if content then
if content == 'S' then
content = '[[Wikisource:Modernización de textos|Ortografía antigua — El lector puede elegir modernizar la ortografía]]'
else
content = 'No modernizar'
end
end
end
if id == 'source' then
if content == nil then
if nompag == nil then
content = content .. CatError .. "|Nompag]]"
caterror = 'ERROR: Nompag'
else --todo: se podría buscar los identificadores de Wikidata P675 (GB), P724 (IA), etc.
content = "[[:File:" .. nompag .. "|Archivo]]"
end
else
-- revisar: en general la fuente la explicitamos localmente con una plantilla
-- tenemos que trackear si está en Wikidata? cual propiedad?
-- noWDsiWS = true
end
end
if id == 'wikidata' then
if nompag == nil then
return CatError .. "|Pagename]]"
end
if content == nil then
return "[[Categoría:Índices no conectados a Wikidata]]"
end
content = "[[File:Wikidata-logo.svg|20px|link=d:" .. contentAux .. "]] [[d:" .. contentAux .. "|" .. contentAux .. "]]"
if mw.wikibase.entityExists(qid) == false then
content = content .. CatError .. "|Qid]]"
caterror = 'ERROR: QID NO EXISTE'
end
if #mw.wikibase.getBestStatements(qid,'P996') == 0 then
local wTitulo = mw.title.getCurrentTitle() --Nombre sin "Índice:"
if wTitulo.text then
local wArchivo = mw.title.new( wTitulo.text, 'File' )
if wArchivo.exists then
--Archivo no está en Commons pero sí localmente en Wikisource (casos excepcionales)
else
--No hay archivo local ni P996: hay que añadirlo (archivo en Commons) al ítem en Wikidata.
content = content .. CatError .. "|Commons]]"
caterror = 'ERROR: SIN P996 (archivo en Commons)'
end
else
content = content .. CatError .. "|Error]]"
caterror = 'ERROR: SIN TEXTO EN ÍNDICE'
end
else
local FileMatch = ''
local FileOnCommonsStmts = mw.wikibase.getAllStatements (qid, 'P996');
for _, stmt in pairs( FileOnCommonsStmts ) do
local commonsFilename = stmt['mainsnak']['datavalue']['value']
if mw.text.decode(nompag) == mw.text.decode(commonsFilename) then --decode por si apóstrofe llega como "'"
FileMatch = commonsFilename
end
end
if FileMatch == '' then
content = content .. CatError .. "|Fichero]]"
caterror = 'ERROR: P996 REFIERE OTRO FICHERO'
end
end
end
if id == 'quality' then
if qid then
local badges = badge(qid)
if badges then
-- revisar: lo mismo que en source, necesidad de trackear?
-- if content then siWDsiWS = true end
content = "C"
if badges == "Q20748091" then content = "C" end
if badges == "Q20748092" then content = "V" end
if badges == "Q20748093" then content = "T" end
if badges == "Q20748094" then content = "L" end
else
--if content then noWDsiWS = true end
end
if contentAux then --tiene preferecia lo informado a mano
content = contentAux
end
end
if content == nil then
content = "[[Categoría:Índices no corregidos]][[:Categoría:Índices no corregidos|Por corregir]]"
elseif content == 'C' then
content = "[[Categoría:Índices no corregidos]][[:Categoría:Índices no corregidos|Por corregir]]"
elseif content == 'P' then
content = "[[Categoría:Índices sin pagelist]][[:Categoría:Índices sin pagelist|Por corregir - pendiente crear <nowiki><pagelist/></nowiki>]]"
elseif content == 'V' then
content = "[[Categoría:Índices corregidos]][[:Categoría:Índices corregidos|Corregido — Todas las páginas corregidas pero no todas validadas]]"
elseif content == 'T' then
content = "[[Categoría:Índices validados]][[:Categoría:Índices validados|Terminado — Todas las páginas validadas]]"
elseif content == 'L' then
content = "[[Categoría:Índices dañados]][[:Categoría:Índices dañados|Archivo fuente debe ser arreglado antes de corregirlo]]"
else
content = "[[Categoría:Índices no corregidos]][[:Categoría:Índices no corregidos|Por corregir]]"
end
end
if content == nil or content == '' then
return ''
end
local title = get_heading( id )
if siWDsiWS == true then
content = content .. "[[Categoría:Índices con datos en Wikidata]]"
title = title .. "<span style='color:red; font-size:75%;' title='Datos en Wikidata'>*</span>"
end
if noWDsiWS == true then
content = content .. "[[Categoría:índices con datos para Wikidata]]"
title = title .. "<span style='color:green; font-size:75%;' title='Datos para Wikidata'>*</span>"
end
if caterror and caterror ~= '' then
title = title .. "<span style='color:red; font-size:75%;' title='"..caterror.."'>*</span>"
end
local s = ''
s = s .. '\n<tr>'
s = s .. '<th valign="top" align="left"><b>' .. title .. '</b></th>\n'
s = s .. '<td>' .. content .. '</td>\n'
s = s .. '</tr>\n'
return s
end
function p.fields(frame)
local args = getArgs(frame)
local s = ""
s = s .. '<table width="100%"><tr><td valign="top"><table>'
s = s .. construct_image(args['Imagen'], args['NomPagE'], args['Wikidata'], args['NomPag'])
-- Tras la imagen, intentamos mostrar una fila por campo (si no hay contenido, no aparece)
s = s .. construct_field('author', args['Autor'], args['Wikidata'])
s = s .. construct_field('translator', args['Traductor'], args['Wikidata'])
s = s .. construct_field('editor', args['Editor'], args['Wikidata'])
s = s .. construct_field('introducer', args['Prologuista'], args['Wikidata'])
s = s .. construct_field('title', args['Titulo'], args['Wikidata'])
s = s .. construct_field('subtitle', args['Subtitulo'], args['Wikidata'])
s = s .. construct_field('volum', args['Volumen'], args['Wikidata'])
s = s .. construct_field('year', args['Ano'], args['Wikidata'])
s = s .. construct_field('place', args['Lugar'], args['Wikidata'])
s = s .. construct_field('country', args['derechos'], args['Wikidata'])
s = s .. construct_field('printer', args['Imprenta'], args['Wikidata'])
s = s .. construct_field('editorial', args['Editorial'], args['Wikidata'])
s = s .. construct_field('illustrator', args['Ilustrador'], args['Wikidata'])
s = s .. construct_field('source', args['Fuente'], args['Wikidata'], args['NomPag'])
s = s .. construct_field('serie', args['Serie'], args['Wikidata']) --a mano
s = s .. construct_field('modernizar', args['Modernizacion'], args['Wikidata']) --a mano
s = s .. construct_field('wikidata', args['Wikidata'], args['Wikidata'], args['NomPag'])
s = s .. construct_field('quality', args['Progreso'], args['Wikidata'])
s = s .. '<tr><td colspan="2">[[Archivo:Commons-emblem-notice.svg|20px|enlace=|alt=|frameless]] [[Ayuda:Índices|Ayuda]]</td></tr>'
s = s .. construct_field_paginas(args['Paginas'], args['NomPagE'])
s = s .. construct_field_sumario(args['Notas'])
s = s .. '</tr></table>'
return s
end
return p