| Contenidos de Wikipedia en español bajo licencia CC BY-SA 4.0 ⇔ Mapas de OpenStreetMap bajo licencia ODbL |
Diferencia entre revisiones de «Módulo:Ficha»
imported>Miguillen Página creada con «-- -- This module will implement {{Infobox}} -- local p = {} local HtmlBuilder = require('Module:HtmlBuilder') local args local root function union(t1, t2) -- r...» |
imported>Miguillen Sin resumen de edición |
||
| Línea 205: | Línea 205: | ||
root | root | ||
.addClass(' | .addClass('infobox_v2') | ||
.addClass(args.bodyclass) | .addClass(args.bodyclass) | ||
.attr('cellspacing', 3) | .attr('cellspacing', 3) | ||
.css(' | .css('padding', '23em') | ||
.css('width', ' | .css('line-height', '1.4em') | ||
.css('text-align:', 'left') | |||
.css('width', '22.7em') | |||
.cssText(args.bodystyle) | .cssText(args.bodystyle) | ||
Revisión del 14:33 30 abr 2013
Uso
Este módulo permite crear fichas específicas como, por ejemplo, las {{ficha de persona}} o la {{ficha de embalse}}.
Para ello, el módulo puede llamarse desde una ficha que utilice la plantilla {{ficha}}, la cual llama a este módulo, por ejemplo:
{{Ficha |titulo = }}
, la cual a su vez hace:
{{#invoke:Ficha|infobox}}
o que llame a otro módulo Lua, por ejemplo, el módulo:ficha de persona que llame a su vez a este módulo. Para ello en la ficha de persona:
{{#invoke:Ficha de persona|Ficha}}
Después en el módulo correspondiente hay que escribir algo de la forma:
local z = {}
-- Módulos y funciones externas
local moduloArgumentos = require('Módulo:Argumentos')
local moduloFicha = require('Módulo:Ficha')
function z.Ficha(frame)
--Obtener una copia de los argumentos eliminando los argumentos sin valor
local args = moduloArgumentos.obtenerArgumentosConValor(frame)
local fichaXXX = {
titulo = args.titulo,
resto de parámetros
...
}
return moduloFicha.infobox(fichaXXX)
end
return z
Parámetros
Lo que sigue es una descripción de los parámetros utilizados cuando se llama al módulo directamente desde otro módulo utilizando las ventajas que dan las tablas de Lua. Para los parámetros cuando se llama al módulo desde una plantilla que utiliza la plantilla de Ficha véase {{ficha}}.
Título y subtítulos
Se recomienda siempre establecer título a la ficha. También se pueden establecer subtítulos a la ficha.
titulo: Título que aparecerá en la cabecera.subtitulo<número>: Subtítulos de la ficha.arriba: Fila de la parte superior.
- Configuración
-
colorfondo: Color del fondo de la cabecera.colortexto: Color del texto de la cabecera.tipocabecera: Tipo de imagen que aparecerá de fondo en la cabecera.
Imágenes
Todas las imágenes son centradas de manera predeterminada. Solo debe especificarse el nombre de las imágenes. Por ejemplo: «example.png». Si el valor no coincide con una imagen existente por ejemplo si se emplea una plantilla se mostrará solo el valor literal.
imagen<número>: Imágenes de la ficha. Tiene número ilimitado y se comprueba si la imagen existe y de lo contrario devuelve el valor literal (pensado para se puedan usar plantillas).imagenizquierda/imagenderecha: Aprecerán una junto a la otra centrado el conjunto de ambas si se dan las dos o centrada una sola imagen si se da solo una.imageninferior: Imagen que apaecerá al pie de la ficha.
- Todos tiene los siguiente parámetros adicionales
-
tamañoimagen<numero>: Tamaño de imagen. (si se pone número solo afectará a esa imagen)tamañoimagenizquierda: Tamaño de la imagen izquierda.tamañoimagenderecha: Tamaño de la imagen derecha.tamañoimageninferior: Tamaño de la imagen de pie de tabla.pie<número>: Pie de imagen (si se pone número solo afectará a esa imagen).piederecho: Pie de la imagen derecha.pieizquierdo: Pie de la imagen izquierda. (si se pone número solo afectará a esa imagen)pieimageninferior: Pie de la imagen de pie de tabla.
Estilos CSS
Estos parámetros son usados para agregar código CSS en el atributo «style» de los elementos de la plantilla; son los que permiten cambiar la apariencia de estos elementos. Por lo tanto, deberán ser usados con sutileza para mantener un aspecto general estético y atractivo.
clase: Clase (class) de toda la ficha.estilo: Estilo de toda la fichaclasefila: Clase de todas las filasclasetitulo: Clase de la cabecera. Establece la imagen de la cabecera. Para usar cabecera mediana añadirMedia=si.estilotitulo:clasesubtitulo<número>estilosubtitulo<número>claseimagenestiloimagen
Filas
Para añadir una fila basta añadir una tabla de la forma:
{..., ..., estiloetiqueta=..., estilodatos=..., clase=..., clasefila=...},
donde el primer parámetro es la etiqueta y el segundo parámetro son los datos. La fila solo se mostrará si está informado el parámetro para los datos. Por ejemplo:
{'Residencia', arg['residencia'], estiloetiqueta='width:33%;', clase='plainlist'},
Secciones
Para incluir una sección basta incluir una tabla Lua del tipo "sección":
{tipo='sección', titulo=..., estilotitulo=..., lista de filas separadas por coma},
donde:
titulo: título de la sección. La sección solo se mostrará si alguna de las filas se muestra no debiendo a diferencia de lo que ocurre cuando se utiliza la plantilla Ficha de validarlo espresamente.estilotitulo: estilo CSS del título de la sección
Sucesiones
Para añadir una sucesión habrá que añadir una table del tipo "sucesión":
{tipo='sucesión', anterior=..., ...},
La lista completa de los parámetros son:
anterior:actual:siguiente:año anterior:año:año siguiente:estilo fuente:color:
Otros campos
piedetabla: Pie de la ficha. Generalmente este espacio se reserva para notas.nombre: Nombre de la plantilla que enlazará en la barra de navegación.
Ejemplo
local z = {}
-- Módulos y funciones externas
local moduloArgumentos = require('Módulo:Argumentos')
local moduloFicha = require('Módulo:Ficha')
function z.Ficha(frame)
--Obtener una copia de los argumentos eliminando los argumentos sin valor
local args = moduloArgumentos.obtenerArgumentosConValor(frame)
local fichaEjemplo = {
titulo = 'Título de prueba',
estilo = 'background-color:#e0ffff; width:20em;',
tipocabecera = 'comunicación',
colorfondotitulo = '#ff0000',
estiloetiqueta = 'width:33%;',
{'Etiqueta1', 'Datos1'},
{'Etiqueta2', 'Datos2'},
{'', 'Datos3'},
{tipo='sección',
titulo='Sección de prueba',
{'Etiqueta4', 'Datos4'},
},
{tipo='sección',
titulo = 'Cronología de [[J. R. R. Tolkien]]',
estilotitulo = 'background-color:#ff0000;',
{tipo='sucesión',
['anterior'] = '[[Egidio, el granjero de Ham]]',
['año anterior'] = '1949',
['actual'] = '[[El Señor de los Anillos]]',
['año'] = '1954',
['siguiente'] = '[[Las aventuras de Tom Bombadil y otros poemas de El Libro Rojo]]',
['año siguiente'] = '1962',
['estilo fuente'] = 'italic',
},
},
piedetabla = 'Pie de tabla',
}
return moduloFicha.infobox(fichaEjemplo)
end
return z
debería producir:
--
-- This module will implement {{Infobox}}
--
local p = {}
local HtmlBuilder = require('Module:HtmlBuilder')
local args
local root
function union(t1, t2)
-- return the union of the values of two tables, as a sequence
local vals = {}
for k, v in pairs(t1) do
vals[v] = true
end
for k, v in pairs(t2) do
vals[v] = true
end
local ret = {}
for k, v in pairs(vals) do
table.insert(ret, k)
end
return ret
end
local function getArgNums(prefix)
local nums = {}
for k, v in pairs(args) do
local num = ('' .. k):match('^' .. prefix .. '(%d+)$')
if num then table.insert(nums, tonumber(num)) end
end
table.sort(nums)
return nums
end
local function addRow(rowArgs)
if rowArgs.header then
root
.tag('tr')
.tag('th')
.attr('colspan', 2)
.addClass(rowArgs.class)
.css('text-align', 'center')
.cssText(args.headerstyle)
.wikitext(rowArgs.header)
elseif rowArgs.data then
local row = root.tag('tr')
row.addClass(rowArgs.rowclass)
if rowArgs.label then
row
.tag('th')
.attr('scope', 'row')
.css('text-align', 'left')
.cssText(args.labelstyle)
.wikitext(rowArgs.label)
.done()
end
local dataCell = row.tag('td')
if not rowArgs.label then
dataCell
.attr('colspan', 2)
.css('text-align', 'center')
end
dataCell
.addClass(rowArgs.class)
.cssText(rowArgs.datastyle)
.wikitext(rowArgs.data)
end
end
local function renderTitle()
if not args.title then return end
root
.tag('caption')
.addClass(args.titleclass)
.cssText(args.titlestyle)
.wikitext(args.title)
end
local function renderAboveRow()
if not args.above then return end
root
.tag('tr')
.tag('th')
.attr('colspan', 2)
.addClass(args.aboveclass)
.css('text-align', 'center')
.css('font-size', '125%')
.css('font-weight', 'bold')
.cssText(args.abovestyle)
.wikitext(args.above)
end
local function renderBelowRow()
if not args.below then return end
root
.tag('tr')
.tag('td')
.attr('colspan', '2')
.addClass(args.belowclass)
.css('text-align', 'center')
.cssText(args.belowstyle)
.newline()
.wikitext(args.below)
.newline()
end
local function renderSubheaders()
if args.subheader then
args.subheader1 = args.subheader
end
if args.subheaderrowclass then
args.subheaderrowclass1 = args.subheaderrowclass
end
local subheadernums = getArgNums('subheader')
for k, num in ipairs(subheadernums) do
addRow({
data = args['subheader' .. num],
datastyle = args.subheaderstyle or args['subheaderstyle' .. num],
class = args.subheaderclass,
rowclass = args['subheaderrowclass' .. num]
})
end
end
local function renderImages()
if args.image then
args.image1 = args.image
end
if args.caption then
args.caption1 = args.caption
end
local imagenums = getArgNums('image')
for k, num in ipairs(imagenums) do
local caption = args['caption' .. num]
local data = HtmlBuilder.create().wikitext(args['image' .. num])
if caption then
data
.tag('br', {selfClosing = true})
.done()
.tag('span')
.cssText(args.captionstyle)
.wikitext(caption)
end
addRow({
data = tostring(data),
datastyle = args.imagestyle,
class = args.imageclass,
rowclass = args['imagerowclass' .. num]
})
end
end
local function renderRows()
local rownums = union(getArgNums('header'), getArgNums('data'))
table.sort(rownums)
for k, num in ipairs(rownums) do
addRow({
header = args['header' .. num],
label = args['label' .. num],
data = args['data' .. num],
datastyle = args.datastyle,
class = args['class' .. num],
rowclass = args['rowclass' .. num]
})
end
end
local function renderNavBar()
if not args.name then return end
root
.tag('tr')
.tag('td')
.attr('colspan', '2')
.css('text-align', 'right')
.wikitext(mw.getCurrentFrame():expandTemplate({
title = 'navbar',
args = { args.name, mini = 1 }
}))
end
local function renderItalicTitle()
local italicTitle = args['italic title'] and mw.ustring.lower(args['italic title'])
if italicTitle == '' or italicTitle == 'force' or italicTitle == 'yes' then
root.wikitext(mw.getCurrentFrame():expandTemplate({title = 'italic title'}))
end
end
local function renderTrackingCategories()
if args.decat ~= 'yes' and #(getArgNums('data')) == 0 and mw.title.getCurrentTitle().namespace == 0 then
root.wikitext('[[Category:Articles which use infobox templates with no data rows]]')
end
end
local function _infobox()
if args.child ~= 'yes' then
root = HtmlBuilder.create('table')
root
.addClass('infobox_v2')
.addClass(args.bodyclass)
.attr('cellspacing', 3)
.css('padding', '23em')
.css('line-height', '1.4em')
.css('text-align:', 'left')
.css('width', '22.7em')
.cssText(args.bodystyle)
renderTitle()
renderAboveRow()
else
root = HtmlBuilder.create()
if args.title then
root.wikitext("'''" .. args.title .. "'''")
end
end
renderSubheaders()
renderImages()
renderRows()
renderBelowRow()
renderNavBar()
renderItalicTitle()
renderTrackingCategories()
return tostring(root)
end
function p.infobox(frame)
local origArgs
-- If called via #invoke, use the args passed into the invoking template.
-- Otherwise, for testing purposes, assume args are being passed directly in.
if frame == mw.getCurrentFrame() then
origArgs = frame:getParent().args
else
origArgs = frame
end
-- ParserFunctions considers the empty string to be false, so to preserve the previous
-- behavior of {{infobox}}, change any empty arguments to nil, so Lua will consider
-- them false too. (Except the 'italic title' param, which specifies different behavior
-- depending on whether it's absent or empty)
args = {}
for k, v in pairs(origArgs) do
if v ~= '' or k == 'italic title' then
args[k] = v
end
end
return _infobox()
end
return p