Revision as of 22:35, 19 August 2018 editTrappist the monk (talk | contribs)Administrators480,243 editsm ce;← Previous edit | Revision as of 13:41, 17 November 2018 edit undoTrappist the monk (talk | contribs)Administrators480,243 edits update;Next edit → | ||
Line 1: | Line 1: | ||
<!-- Please place categories where indicated at the bottom of this page and interwikis at Wikidata (see ]) --> | <!-- Please place categories where indicated at the bottom of this page and interwikis at Wikidata (see ]) --> | ||
⚫ | This module is to be used in wrapper templates to allow those templates to provide default parameter values and allow editors to pass additional parameters to the underlying working template. | ||
⚫ | When writing a wrapper template, give this module all of the normally required default parameters necessary to use the wrapper template in its base form. Editors then use the wrapper template as-is or may supply additional wrapper and canonical parameters. Any of the canonical parameters supported by the working template may be added to the wrapper template or supplied by editors in article space. When an editor supplies a parameter that has a default value in the wrapper template, the editor-supplied value overrides the default. When it is necessary to remove a default parameter, editors may set the parameter value to the special keyword <code>unset</code> which will cause this wrapper module to erase the wrapper template's default value for that parameter. This module discards empty named parameters. | ||
⚫ | Positional parameters are not normally passed on to the working template. Setting {{para|_include-positional|yes}} will pass all positional parameters to the working template. Positional parameters cannot be excluded; positional parameters may be <code>unset</code>. | ||
⚫ | Parameters that are used only by the wrapper should be either positional ({{param|{{var|n}}}}) or listed in {{para|_exclude}} (a comma-separated list of named parameters). This module will not pass <code>_excluded</code> parameters to the working template. | ||
== Usage == | == Usage == | ||
<code><nowiki>{{#invoke:</nowiki>{{BASEPAGENAME}}|wrap|_template={{var|working template}}|_exclude={{var|named parameter}}, {{var|named parameter}}, ...|_include-positional=}}</code> | <code><nowiki>{{#invoke:</nowiki>{{BASEPAGENAME}}|wrap|_template={{var|working template}}|_exclude={{var|named parameter}}, {{var|named parameter}}, ...|_reuse={{var|named parameter}}, {{var|named parameter}}, ...|_alias-map={{var|alias parameter}}:{{var|canonical parameter}}|_include-positional=yes|<{{var|default parameter}}>|<{{var|default parameter}}>|...}}</code> | ||
;Control parameters | |||
⚫ | This module is to be used in wrapper templates to allow those templates to provide default parameter values and allow editors to pass additional parameters to the underlying working template. | ||
⚫ | :{{para|_template}} – (required) the name, without namespace, of the working template (the template that is wrapped); see §] below | ||
:{{para|_exclude}} – comma-separated list of parameter names used by the wrapper template that are not to be passed to the working template; see §] below | |||
:{{para|_reuse}} – comma-separated list of canonical names that have meaning to both the wrapper template and to the working template; see §] below | |||
:{{para|_alias-map}} – comma-separated list of wrapper-template parameter names that are to be treated as aliases of specified working template canonical parameters; see §] below | |||
:{{para|_include-positional}} – pass all positional parameters to the working template; see §] below | |||
;Definitions | |||
⚫ | |||
:canonical parameter – a parameter supported and used by the working template | |||
:wrapper parameter – a parameter used by the wrapper template; may provide data for canonical parameters or control other aspects of the wrapper template | |||
:alias parameter – a wrapper parameter that is contextually meaningful to the wrapper template but must be renamed to a canonical parameter for use by the working template | |||
:reused parameter – a parameter that is shared by both wrapper and working templates and has been modified by wrapper template | |||
:default parameter – a canonical parameter given a default value in the wrapper template | |||
{| class="nowrap" | |||
⚫ | When writing a wrapper template, give this module all of the normally required default parameters necessary to use the template in its base form. Editors then use the wrapper template as |
||
|+parameter processing | |||
!style="border:1px solid black"|wrapper<br />template !! !!style="border:1px solid black" colspan="11"|Module:Template wrapper !! !! style="border:1px solid black"|working<br />template | |||
|- | |||
| style="border: 1px solid black;"|{{para|plain=yes|{{var|canonical parameters}}}}|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="border: 2px solid black;" rowspan="5"|filter<br />exclued<br />parameters|| ||style="border: 2px solid black;" rowspan="10"|working<br />template | |||
|- | |||
| style="border: 1px solid black;"|{{para|plain=yes|{{var|wrapper parameters}}}}|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → | |||
|- | |||
| || || style="border: 1px solid black;"|{{para|plain=yes|]}}|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → || → | |||
|- | |||
| || || style="border: 1px solid black;"|{{para|plain=yes|]}}|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → | |||
|- | |||
| || || style="border: 1px solid black;"|{{para|plain=yes|]}}|| → ||style="border: 2px solid black;" rowspan="3"|convert alias<br />parameters to<br />canonical<br />parameters|| → ||style="border: 1px solid black;" rowspan="2"|{{para|plain=yes|{{var|canonical parameters}}}}|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → || || → | |||
|- | |||
| || || || || → || → ||style="border: 2px solid black;" rowspan="4"|modify<br />reused<br />canonical<br />parameters | |||
|- | |||
| style="border: 1px solid black;"|{{para|plain=yes|{{var|alias parameters}}}}|| → ||style="text-align: center;"|–––––––→|| → || || || || → ||style="border: 1px solid black;"|{{para|plain=yes|{{var|reused parameters}}}}|| → ||style="text-align: center;"|–––→|| → | |||
|- | |||
| || || style="border: 1px solid black;"|{{para|plain=yes|]}}|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → | |||
|- | |||
| style="border: 1px solid black;"|{{para|plain=yes|{{var|canonical parameters}}}}|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → | |||
|- | |||
| || || style="border: 1px solid black;"|{{para|plain=yes|{{var|default parameters}}}}|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––––––→|| → ||style="text-align: center;"|–––→|| → | |||
|} | |||
==Parameter details== | |||
⚫ | Positional |
||
===_template=== | |||
The only required parameter, {{para|_template}} supplies the name, without namespace, of the working template (the template that is wrapped). If this parameter is omitted, Module:Template wrapper will emit the error message: | |||
:<span style="font-size:100%" class="error"><code style="color:inherit; border:inherit; padding:inherit;">|_template=</code> missing or empty</span> | |||
===_alias-map=== | |||
⚫ | Parameters that are used only by the wrapper should be either positional ({{param|{{var|n}}}}) or listed in {{para|_exclude}} (a comma-separated list of named parameters). This module will not pass <code>_excluded</code> parameters to the working template. | ||
{{para|alias-map}} takes a comma-separated list of wrapper-template parameters that are to be treated as aliases of specified working template canonical parameters. Each mapping element of the list has the form: | |||
:<code><{{var|from}}>:<{{var|to}}></code> – where: <code><{{var|from}}></code> is a wrapper parameter name and <code><{{var|to}}></code> is a canonical parameter name | |||
In this example, it may be preferable for a wrapper template to use {{para|assessor}} which may be unknown to the working template but the working template may have an equivalent {{para|author}} so in the <code><nowiki>{{#invoke:}}</nowiki></code> we would write: | |||
:{{para|_alias-map|assessor:author}} | |||
Positional parameters may also be mapped to canonical parameters: | |||
:{{para|_alias-map|1:author, 2:title, 3:language}} | |||
Enumerated wrapper parameters may be mapped to enumerated canonical parameters using the <code>#</code> enumerator specifier: | |||
:{{para|_alias-map|assessor#:author#}} | |||
Given the above example, {{para|assessor2}} will map to {{para|author2}}; also, {{para|assessor}} and {{para|assessor1}} will map to {{para|author1}} | |||
Multiple wrapper parameters can map to a single canonical parameter: | |||
:{{para|_alias-map|1:author, assessor:author}} | |||
Wrapper parameters listed in {{para|alias-map}} are not passed to the working template. Mapping positional parameters when {{para|_include-positional|yes}} may give undesirable results. {{para|_alias-map|1:author}} and {{para|_include-positional|yes}} will cause all other positional parameters to be passed to the working template as is: wrapper template <code><nowiki>{{{2}}}</nowiki></code> becomes working template <code><nowiki>{{{2}}}</nowiki></code>, etc; working template will not get <code><nowiki>{{{1}}}</nowiki></code> though it will get {{para|author}}. | |||
===_reuse=== | |||
{{para|_reuse}} takes a comma-separated list of canonical parameters that have meaning to both the wrapper template and to the working template | |||
In the simplest cases, a canonical parameter passed into the wrapper template overrides a default parameter provided in the wrapper template. Sometimes a wrapper parameter is the same as a canonical parameter and the wrapper template needs to modify the parameter value before it is passed to the working template. In this example, {{para|title}} is both a wrapper parameter and a canonical parameter that the wrapper template needs to modify before passing to the working template. To do this we first write: | |||
:{{para|_reuse|title}} | |||
then, in the wrapper template's <code><nowiki>{{#invoke:Template wapper|wrap|_template=...|...}}</nowiki></code> we write: | |||
:{{para|title|Modified <nowiki>{{{title}}}</nowiki>}} | |||
_reused parameters cannot be overridden. | |||
===_exclude=== | |||
{{para|_exclude}} takes a comma-separated list of parameters used by the wrapper template that are not to be passed to the working template. This list applies to all wrapper and canonical parameters (including those canonical parameters that are renamed alias parameters) received from the wrapper template. | |||
As an example, a wrapper template might use {{para|id}} to supply a portion of the value assigned to default parameter {{para|url}} so we would write: | |||
:{{para|_exclude|id}} | |||
then, in the wrapper template's <code><nowiki>{{#invoke:Template wapper|wrap|_template=...|...}}</nowiki></code> we write: | |||
:{{para|url|<nowiki>https://example.com/{{{id}}}</nowiki>}} | |||
The modified {{para|url}} value is passed on to working template but {{para|id}} and its value is not. | |||
_reused and default parameters cannot be excluded. | |||
===_include-positional=== | |||
{{para|_include-positional}} is a boolean parameter that takes only one value: <code>yes</code>; the default (empty, missing) is <code>no</code> (positional parameters normally excluded). When set to <code>yes</code>, Module:Template wrapper will pass all positional parameters to the working template. | |||
See also §]. | |||
===Overriding default parameters=== | |||
Editors may override default parameters by simply setting the default parameter to the desired value in the wrapper template. This module ignores empty parameters (those parameters that are named but which do not have an assigned value). When it is desirable to override a default parameter to no value, use the special keyword <code>unset</code>. Default parameters with this value are passed to the working template as empty (no assigned value) parameters. | |||
_reused parameters cannot be <code>unset</code> or overridden. | |||
<includeonly>{{sandbox other|| | <includeonly>{{sandbox other|| |
Revision as of 13:41, 17 November 2018
This module is to be used in wrapper templates to allow those templates to provide default parameter values and allow editors to pass additional parameters to the underlying working template.
When writing a wrapper template, give this module all of the normally required default parameters necessary to use the wrapper template in its base form. Editors then use the wrapper template as-is or may supply additional wrapper and canonical parameters. Any of the canonical parameters supported by the working template may be added to the wrapper template or supplied by editors in article space. When an editor supplies a parameter that has a default value in the wrapper template, the editor-supplied value overrides the default. When it is necessary to remove a default parameter, editors may set the parameter value to the special keyword unset
which will cause this wrapper module to erase the wrapper template's default value for that parameter. This module discards empty named parameters.
Positional parameters are not normally passed on to the working template. Setting |_include-positional=yes
will pass all positional parameters to the working template. Positional parameters cannot be excluded; positional parameters may be unset
.
Parameters that are used only by the wrapper should be either positional ({{{n}}}
) or listed in |_exclude=
(a comma-separated list of named parameters). This module will not pass _excluded
parameters to the working template.
Usage
{{#invoke:Template wrapper|wrap|_template=working template|_exclude=named parameter, named parameter, ...|_reuse=named parameter, named parameter, ...|_alias-map=alias parameter:canonical parameter|_include-positional=yes|<default parameter>|<default parameter>|...}}
- Control parameters
|_template=
– (required) the name, without namespace, of the working template (the template that is wrapped); see §_template below|_exclude=
– comma-separated list of parameter names used by the wrapper template that are not to be passed to the working template; see §_exclude below|_reuse=
– comma-separated list of canonical names that have meaning to both the wrapper template and to the working template; see §_reuse below|_alias-map=
– comma-separated list of wrapper-template parameter names that are to be treated as aliases of specified working template canonical parameters; see §_alias-map below|_include-positional=
– pass all positional parameters to the working template; see §_include-positional below
- Definitions
- canonical parameter – a parameter supported and used by the working template
- wrapper parameter – a parameter used by the wrapper template; may provide data for canonical parameters or control other aspects of the wrapper template
- alias parameter – a wrapper parameter that is contextually meaningful to the wrapper template but must be renamed to a canonical parameter for use by the working template
- reused parameter – a parameter that is shared by both wrapper and working templates and has been modified by wrapper template
- default parameter – a canonical parameter given a default value in the wrapper template
wrapper template |
Module:Template wrapper | working template | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|canonical parameters= |
→ | –––––––→ | → | –––––––→ | → | –––––––→ | → | –––––––→ | → | –––––––→ | → | filter exclued parameters |
working template | |
|wrapper parameters= |
→ | –––––––→ | → | –––––––→ | → | –––––––→ | → | –––––––→ | → | –––––––→ | → | |||
|_exclude= |
→ | –––––––→ | → | –––––––→ | → | –––––––→ | → | –––––––→ | → | → | ||||
|_include-positional= |
→ | –––––––→ | → | –––––––→ | → | –––––––→ | → | –––––––→ | → | |||||
|_alias-map= |
→ | convert alias parameters to canonical parameters |
→ | |canonical parameters= |
→ | –––––––→ | → | –––––––→ | → | → | ||||
→ | → | modify reused canonical parameters | ||||||||||||
|alias parameters= |
→ | –––––––→ | → | → | |reused parameters= |
→ | –––→ | → | ||||||
|_reuse= |
→ | –––––––→ | → | –––––––→ | → | |||||||||
|canonical parameters= |
→ | –––––––→ | → | –––––––→ | → | –––––––→ | → | |||||||
|default parameters= |
→ | –––––––→ | → | –––––––→ | → | –––––––→ | → | –––––––→ | → | –––→ | → |
Parameter details
_template
The only required parameter, |_template=
supplies the name, without namespace, of the working template (the template that is wrapped). If this parameter is omitted, Module:Template wrapper will emit the error message:
|_template=
missing or empty
_alias-map
|alias-map=
takes a comma-separated list of wrapper-template parameters that are to be treated as aliases of specified working template canonical parameters. Each mapping element of the list has the form:
<from>:<to>
– where:<from>
is a wrapper parameter name and<to>
is a canonical parameter name
In this example, it may be preferable for a wrapper template to use |assessor=
which may be unknown to the working template but the working template may have an equivalent |author=
so in the {{#invoke:}}
we would write:
|_alias-map=assessor:author
Positional parameters may also be mapped to canonical parameters:
|_alias-map=1:author, 2:title, 3:language
Enumerated wrapper parameters may be mapped to enumerated canonical parameters using the #
enumerator specifier:
|_alias-map=assessor#:author#
Given the above example, |assessor2=
will map to |author2=
; also, |assessor=
and |assessor1=
will map to |author1=
Multiple wrapper parameters can map to a single canonical parameter:
|_alias-map=1:author, assessor:author
Wrapper parameters listed in |alias-map=
are not passed to the working template. Mapping positional parameters when |_include-positional=yes
may give undesirable results. |_alias-map=1:author
and |_include-positional=yes
will cause all other positional parameters to be passed to the working template as is: wrapper template {{{2}}}
becomes working template {{{2}}}
, etc; working template will not get {{{1}}}
though it will get |author=
.
_reuse
|_reuse=
takes a comma-separated list of canonical parameters that have meaning to both the wrapper template and to the working template
In the simplest cases, a canonical parameter passed into the wrapper template overrides a default parameter provided in the wrapper template. Sometimes a wrapper parameter is the same as a canonical parameter and the wrapper template needs to modify the parameter value before it is passed to the working template. In this example, |title=
is both a wrapper parameter and a canonical parameter that the wrapper template needs to modify before passing to the working template. To do this we first write:
|_reuse=title
then, in the wrapper template's {{#invoke:Template wapper|wrap|_template=...|...}}
we write:
|title=Modified {{{title}}}
_reused parameters cannot be overridden.
_exclude
|_exclude=
takes a comma-separated list of parameters used by the wrapper template that are not to be passed to the working template. This list applies to all wrapper and canonical parameters (including those canonical parameters that are renamed alias parameters) received from the wrapper template.
As an example, a wrapper template might use |id=
to supply a portion of the value assigned to default parameter |url=
so we would write:
|_exclude=id
then, in the wrapper template's {{#invoke:Template wapper|wrap|_template=...|...}}
we write:
|url=https://example.com/{{{id}}}
The modified |url=
value is passed on to working template but |id=
and its value is not.
_reused and default parameters cannot be excluded.
_include-positional
|_include-positional=
is a boolean parameter that takes only one value: yes
; the default (empty, missing) is no
(positional parameters normally excluded). When set to yes
, Module:Template wrapper will pass all positional parameters to the working template.
See also §_alias-map.
Overriding default parameters
Editors may override default parameters by simply setting the default parameter to the desired value in the wrapper template. This module ignores empty parameters (those parameters that are named but which do not have an assigned value). When it is desirable to override a default parameter to no value, use the special keyword unset
. Default parameters with this value are passed to the working template as empty (no assigned value) parameters.
_reused parameters cannot be unset
or overridden.