Ir al contenido

Diferencia entre revisiones de «Módulo:Ficha/doc»

De Wikipedia, la enciclopedia libre
Contenido eliminado Contenido añadido
Sin resumen de edición
mSin resumen de edición
Etiquetas: Reversión manual editor de código 2017
 
(No se muestran 17 ediciones intermedias de 5 usuarios)
Línea 1: Línea 1:
{{Fusionar desde|Módulo:Ficha animanga|t=20200920021153}}
=== Uso ===
=== Uso ===
Este módulo es para crear una ficha genérica para ser usado por otros módulos o plantillas para crear fichas específica.
Este módulo permite crear fichas específicas como, por ejemplo, las {{ep|ficha de persona}} o la {{ep|ficha de embalse}}.

Los argumentos de este módulo está traducidos al español con los mismos nombres que en la [[plantilla:Ficha]] de forma que pueden usarse directamente como párametros.
Para ello, el módulo puede llamarse desde una ficha que utilice la plantilla {{ep|ficha}}, la cual llama a este módulo, por ejemplo:
:<code><nowiki>{{Ficha
|titulo =
}}
</nowiki></code>

, la cual a su vez hace:
<code><nowiki>{{#invoke:Ficha|infobox}}</nowiki></code>

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:
<code><nowiki>{{#invoke:Ficha de persona|Ficha}}</nowiki></code>

Después en el módulo correspondiente hay que escribir algo de la forma:
<syntaxhighlight lang="Lua">
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
</syntaxhighlight>


Para invocarlo en plantillas <code><nowiki>{{#invoke:Ficha|Infovox}}</nowiki></code>''' '''''''''''''''
=== Parámetros ===
=== 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 {{ep|ficha}}.
'''Notas:'''
* Los parámetros que incluyan <code><número></code>, indican que se debe escribir al final del parámetro un número del 1 al ∞. Por ejemplo, el código «<code>|estilosección65 = font-style: italic;</code>» establecería el estilo de fuente de la sección 65 en [[bastardilla|itálica]].
* Si se define una sección, no se debe usar el mismo número de la sección en los campos de etiquetas o datos, si se hace, no se mostrará el contenido de estos campos.


==== Título y subtítulos ====
==== Título y subtítulos ====
Se recomienda '''siempre''' establecer título a la ficha. También se pueden establecer subtítulos a la ficha.
Se recomienda '''siempre''' establecer título a la ficha. También se pueden establecer subtítulos a la ficha.
:*'''<code>titulo</code>''': Título que aparecerá en la cabecera
:*'''<code>titulo</code>''': Título que aparecerá en la cabecera.
:*'''<code>clasetitulo</code>''':clase de la cabecera. Establece la imagen de la cabecera. Para usar cabecera mediana añadir <code>Media=si</code>.
:*'''<code>subtitulo<número></code>''': Subtítulos de la ficha.
:*'''<code>estilotitulo</code>''':
:*'''<code>arriba</code>''': Fila de la parte superior.
;Configuración
:*'''<code>subtitulo<número></code>'''
:*'''<code>clasesubtitulo<número></code>'''
:*'''<code>colorfondo</code>''': Color del fondo de la cabecera.
:*'''<code>estilosubtitulo<número></code>'''
:*'''<code>colortexto</code>''': Color del texto de la cabecera.
:*'''<code>arriba</code>'''
:*'''<code>tipocabecera</code>''': Tipo de imagen que aparecerá de fondo en la cabecera.

:*'''<code>datosup<número></code>'''
==== Imágenes ====
==== Imágenes ====
Todas las imágenes son centradas de manera predeterminada. Solo debe especificarse el nombre de las imágenes. Por ejemplo: «<nowiki>example.png</nowiki>». Si el valor no coincide con una imagen existente por ejemplo si se emplea una plantilla se mostrará solo el valor literal.
Todas las imágenes son centradas de manera predeterminada. Solo debe especificarse el nombre de las imágenes. Por ejemplo: «<nowiki>example.png</nowiki>». Si el valor no coincide con una imagen existente por ejemplo si se emplea una plantilla se mostrará solo el valor literal.
:*'''<code>imagen<número></code>''': 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).
:*'''<code>imagen<número><code>''':
:*'''<code>imagenizquierda</code>'''/'''<code>imagenderecha</code>''': 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.
:*'''<code>imagenizquierda</code>'''/'''<code>imagenderecha</code>''': 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.
:*'''<code>imageninferior</code>''': Imagen que apaecerá al pie de la ficha.
:*'''<code>imageninferior</code>''': Imagen que apaecerá al pie de la ficha.
;Todos tiene los siguiente parámetros adicionales:
;Todos tiene los siguiente parámetros adicionales:
:*'''<code>tamañoimagen<numero></code>'''
:*'''<code>tamañoimagen<numero></code>''': Tamaño de imagen. (si se pone número solo afectará a esa imagen)
:*'''<code>tamañoimagenizquierda</code>'''
:*'''<code>tamañoimagenizquierda</code>''': Tamaño de la imagen izquierda.
:*'''<code>tamañoimagenderecha</code>'''
:*'''<code>tamañoimagenderecha</code>''': Tamaño de la imagen derecha.
:*'''<code>tamañoimageninferior</code>'''
:*'''<code>tamañoimageninferior</code>''': Tamaño de la imagen de pie de tabla.
:*'''<code>pie</code>'''
:*'''<code>pie<número></code>''': Pie de imagen (si se pone número solo afectará a esa imagen).
:*'''<code>piederecho</code>'''
:*'''<code>piederecho</code>''': Pie de la imagen derecha.
:*'''<code>pieizquierdo</code>'''
:*'''<code>pieizquierdo</code>''': Pie de la imagen izquierda. (si se pone número solo afectará a esa imagen)
:*'''<code>pieimageninferior</code>'''
:*'''<code>pieimageninferior</code>''': Pie de la imagen de pie de tabla.


==== Estilos CSS ====
==== Estilos CSS ====
Línea 39: Línea 70:
:*'''<code>clase</code>''': Clase (class) de toda la ficha.
:*'''<code>clase</code>''': Clase (class) de toda la ficha.
:*'''<code>estilo</code>''': Estilo de toda la ficha
:*'''<code>estilo</code>''': Estilo de toda la ficha
:*'''<code>clasefila<número></code>'''
:*'''<code>clasefila</code>''': Clase de todas las filas
:*'''<code>clasetitulo</code>''': Clase de la cabecera. Establece la imagen de la cabecera. Para usar cabecera mediana añadir <code>Media=si</code>.
:*'''<code>estilotitulo</code>''':
:*'''<code>clasesubtitulo<número></code>'''
:*'''<code>estilosubtitulo<número></code>'''
:*'''<code>claseimagen</code>'''
:*'''<code>claseimagen</code>'''
:*'''<code>estiloimagen</code>'''
:*'''<code>estiloimagen</code>'''
:*'''<code>estiloetiqueta<número></code>'''
:*'''<code>estilodatos<número></code>'''


==== Campos ====
==== Filas ====
Para añadir una fila basta añadir una tabla de la forma:
Una fila con una etiqueta pero sin un campo de datos no se muestra. Esto facilita la creación de filas opcionales. Para hacer una fila opcional se tiene que incluir un parámetro que predetermine el contenido de esta a una cadena vacía:

:*'''<code>seccion<número></code>'''
<syntaxhighlight lang="Lua">
:*'''<code>etiqueta<número></code>'''
{..., ..., estiloetiqueta=..., estilodatos=..., clase=..., clasefila=...},
:*'''<code>datos<número></code>'''
</syntaxhighlight>

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:
<syntaxhighlight lang="Lua">
{'Residencia', arg['residencia'], estiloetiqueta='width:33%;', clase='plainlist'},
</syntaxhighlight>

==== Secciones ====
Para incluir una sección basta incluir una tabla Lua del tipo "sección":
<syntaxhighlight lang="Lua">
{tipo='sección', titulo=..., estilotitulo=..., lista de filas separadas por coma},
</syntaxhighlight>

donde:
*'''<code>titulo</code>''': 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.
*'''<code>estilotitulo</code>''': 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":
<syntaxhighlight lang="Lua">
{tipo='sucesión', anterior=..., ...},
</syntaxhighlight>

La lista completa de los parámetros son:
*'''<code>anterior</code>''':
*'''<code>actual</code>''':
*'''<code>siguiente</code>''':
*'''<code>año anterior</code>''':
*'''<code>año</code>''':
*'''<code>año siguiente</code>''':
*'''<code>estilo fuente</code>''':
*'''<code>color</code>''':


==== Otros campos ====
==== Otros campos ====
:*'''<code>piedetabla</code>'''
:*'''<code>piedetabla</code>''': Pie de la ficha. Generalmente este espacio se reserva para notas.
:*'''<code>nombre</code>'''
:*'''<code>nombre</code>''': Nombre de la plantilla que enlazará en la barra de navegación.

=== Ejemplo ===
<syntaxhighlight lang="Lua">
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
</syntaxhighlight>

debería producir:
{{Ficha
|estilo = background-color:#e0ffff; width:20em;
|titulo = Título de prueba
|tipocabecera = comunicación
|colorfondotitulo = #ff0000
|estiloetiqueta = width:33%;
|etiqueta1 = Etiqueta 1
|datos1 = Datos 1
|etiqueta2 = Etiqueta 2
|datos2 = Datos 2
|datos3 = Datos 3
|seccion4 = Sección de prueba
|etiqueta5 = Etiqueta 4
|datos5 = Datos 4
|datos6={{Ficha/Sucesión
|sección = Cronología de [[J. R. R. Tolkien]]|color sección =red
|[[Egidio, el granjero de Ham]]
|año anterior=1949
|[[El Señor de los Anillos]]
|año=1954
|[[Las aventuras de Tom Bombadil y otros poemas de El Libro Rojo]]
|año siguiente=1962
|estilo fuente=italic}}
|piedetabla = Pie de tabla
}}


<includeonly>
<includeonly>
<!-- Coloca las categorías del módulo a continuación y los interwikis en Wikidata -->
<!-- Coloca las categorías del módulo a continuación y los interwikis en Wikidata -->
[[Categoría:Wikipedia:Módulos de fichas]]
[[Categoría:Wikipedia:Módulos de fichas| ]]
</includeonly>
</includeonly>

Revisión actual - 17:21 18 oct 2020

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 ficha
  • clasefila: Clase de todas las filas
  • clasetitulo: Clase de la cabecera. Establece la imagen de la cabecera. Para usar cabecera mediana añadir Media=si.
  • estilotitulo:
  • clasesubtitulo<número>
  • estilosubtitulo<número>
  • claseimagen
  • estiloimagen

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:

Título de prueba
Etiqueta 1 Datos 1
Etiqueta 2 Datos 2
Datos 3
Sección de prueba
Etiqueta 4 Datos 4
Cronología de J. R. R. Tolkien
Egidio, el granjero de Ham
(1949)
El Señor de los Anillos
(1954)
Las aventuras de Tom Bombadil y otros poemas de El Libro Rojo
(1962)
Pie de tabla