(update imminent) |
(doc update) |
||
Line 4: | Line 4: | ||
''NOTE:This template is currently undergoing a major revision. If navbox's look strange to you, you may need to [[Wikipedia:Clear your cache|clear your cache]] in order to reload the proper [[CSS]]. If they still look strange, wait a few hours, as certain pages will have known side effects to the recent changes, which should be corrected quickly. If problems persist, post a note on the talk page.'' | ''NOTE:This template is currently undergoing a major revision. If navbox's look strange to you, you may need to [[Wikipedia:Clear your cache|clear your cache]] in order to reload the proper [[CSS]]. If they still look strange, wait a few hours, as certain pages will have known side effects to the recent changes, which should be corrected quickly. If problems persist, post a note on the talk page.'' | ||
This template allows a [[Wikipedia:Navigational templates|navigational template]] to be set up relatively quickly by supplying it one or more lists of links. It | This template allows a [[Wikipedia:Navigational templates|navigational template]] to be set up relatively quickly by supplying it one or more lists of links. It comes equipped with default styles that should work for most navigational templates. It is not recommended that one modifies the default styles but it is possible if one wishes to do so. | ||
== Usage == | == Usage == | ||
Please remove the parameters that are left blank. | Please remove the parameters that are left blank. | ||
<pre>{{Navbox | <pre style="overflow:scroll;">{{Navbox | ||
|name = {{subst:PAGENAME}} | |name = {{subst:PAGENAME}} | ||
|title = | |title = | ||
|image = | |image = | ||
Line 18: | Line 17: | ||
|group1 = | |group1 = | ||
|list1 = | |list1 = | ||
|group2 = | |group2 = | ||
|list2 = | |list2 = | ||
Line 28: | Line 28: | ||
==Parameter list== | ==Parameter list== | ||
{{Navbox | {{Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
|state = uncollapsed | |state = uncollapsed | ||
|image = {{{image}}} | |image = {{{image}}} | ||
|title = {{{title}}} | |title = {{{title}}} | ||
Line 52: | Line 43: | ||
|below = {{{below}}}<br/>See alternate navbox formats under: [[#Layout of table|''Layout of table'']] | |below = {{{below}}}<br/>See alternate navbox formats under: [[#Layout of table|''Layout of table'']] | ||
}} | }} | ||
The navbox uses lowercase parameter names, as shown in the box (''at right''). The mandatory ''name'' and ''title'' will create a one-line box if other parameters are omitted. | The navbox uses lowercase parameter names, as shown in the box (''at right''). The mandatory ''name'' and ''title'' will create a one-line box if other parameters are omitted. | ||
<br/> | <br/> | ||
Notice "group1" (etc.) is optional, as are sections named "above/below". | Notice "group1" (etc.) is optional, as are sections named "above/below". | ||
{{-}} | {{-}} | ||
The | The basic and most common parameters are as follows (see below for the full list): | ||
:<code>name -</code> the name of the template. | :<code>name -</code> the name of the template. | ||
:<code>title -</code> text in the title bar, such as: <nowiki>[[Widget stuff]]</nowiki>. | :<code>title -</code> text in the title bar, such as: <nowiki>[[Widget stuff]]</nowiki>. | ||
:<code>state - autocollapse, | :<code>state - autocollapse, uncollapsed, collapsed</code>: the status of box expansion, where "autocollapse" hides stacked navboxes automatically. | ||
:<code>titlestyle - </code>a CSS style for the title-bar, such as: <code>background:gray;</code> | :<code>titlestyle - </code>a CSS style for the title-bar, such as: <code>background:gray;</code> | ||
:<code>groupstyle - </code>a CSS style for the group-cells, such as: <code>background: | :<code>groupstyle - </code>a CSS style for the group-cells, such as: <code>background:#eee;</code> | ||
:<code>image - </code>an optional right-side image (coded as the whole image tag: <nowiki>[[Image:XX.jpg|90px]]</nowiki> ). | :<code>image - </code>an optional right-side image (coded as the whole image tag: <nowiki>[[Image:XX.jpg|90px]]</nowiki> ). | ||
:<code>imageleft - </code>an optional left-side image | :<code>imageleft - </code>an optional left-side image (code the same was as the "image" parameter). | ||
:<code>above - </code>text to appear above the group/list section (could be a list of overall wikilinks). | :<code>above - </code>text to appear above the group/list section (could be a list of overall wikilinks). | ||
Line 78: | Line 65: | ||
:<code>list<sub>n</sub> - </code>text listing wikilinks, often separated by middot templates, such as: [<font/>[A]]<code>{<font/>{·}}</code> [<font/>[B]] | :<code>list<sub>n</sub> - </code>text listing wikilinks, often separated by middot templates, such as: [<font/>[A]]<code>{<font/>{·}}</code> [<font/>[B]] | ||
:<code>below - </code>optional text to appear below the group/list section. | :<code>below - </code>optional text to appear below the group/list section. | ||
Further details, and complex restrictions, are explained below under section ''[[#Parameter descriptions|Parameter descriptions]]''. See some alternate navbox formats under: [[#Layout of table|''Layout of table'']]. | Further details, and complex restrictions, are explained below under section ''[[#Parameter descriptions|Parameter descriptions]]''. See some alternate navbox formats under: [[#Layout of table|''Layout of table'']]. | ||
==Parameter descriptions== | ==Parameter descriptions== | ||
The following is a complete list of parameters for using {{t1|Navbox}}. In most cases, the only required parameters are <code>name</code>, <code>title</code>, and <code>list1</code>, though [[User:CapitalR/Navbox/doc#Child_navboxes|child navboxes]] do not even require those to be set. | |||
{{t1|Navbox}} shares numerous common parameter names as its sister templates {{t1|Navbox with columns}} and {{t1|Navbox with collapsible sections}} for consistency and ease of use. Parameters marked with a cross<sup><span style="font-weight:bold;">†</span></sup> are common to all three master templates. | |||
: '''' | ===Mandatory parameters=== | ||
:: | :; ''name''<sup>†</sup> | ||
:: The name of the template, which is needed for the "v{{·}} d{{·}} e" ("view{{·}} discuss{{·}} edit") links to work properly on all pages where the template is used. You can enter <code><nowiki>{{subst:PAGENAME}}</nowiki></code> for this value as a shortcut. The name parameter is only mandatory if a <code>title</code> is specified, and the <code>border</code> parameter is not set. | |||
===Optional=== | :; ''title''<sup>†</sup> | ||
:: Text that appears centered in the top row of the table. It is usually the template's topic, i.e. a succinct description of the body contents. This should be a single line, but if a second line is needed, use <code><nowiki>{{-}}</nowiki></code> to ensure proper centering. This parameter is technically not mandatory, but using {{t1|Navbox}} is rather pointless without a title. | |||
: '''''list<sub>n</sub>''''' | |||
:: (i.e. ''list1'', ''list2'', etc.) The body of the template, usually a list of links. Format is inline, although the text can be entered on separate lines if the entire list is enclosed within <code><nowiki><div> </div></nowiki></code>. At least one ''list'' parameter is required; each additional ''list'' is displayed in a separate row of the table. Each ''list<sub>n</sub>'' may be preceded by a corresponding ''group<sub>n</sub>'' parameter, if provided (see below). | |||
===Optional parameters=== | |||
====Cells==== | ====Cells==== | ||
Line 99: | Line 89: | ||
:: (i.e. ''group1'', ''group2'', etc.) If specified, text appears in a header cell displayed to the left of ''list<sub>n</sub>''. If omitted, ''list<sub>n</sub>'' uses the full width of the table. | :: (i.e. ''group1'', ''group2'', etc.) If specified, text appears in a header cell displayed to the left of ''list<sub>n</sub>''. If omitted, ''list<sub>n</sub>'' uses the full width of the table. | ||
:; ''image'' | :; ''image''<sup>†</sup> | ||
:: An image to be displayed in a cell below the title and to the right of the body (the groups/lists). For the image to display properly, the ''list1'' parameter must be specified. The ''image'' parameter accepts standard wikicode for displaying an image, i.e. | :: An image to be displayed in a cell below the title and to the right of the body (the groups/lists). For the image to display properly, the ''list1'' parameter must be specified. The ''image'' parameter accepts standard wikicode for displaying an image, i.e. | ||
::: <code><nowiki>[[Image:Example.jpg|100px]]</nowiki></code> | ::: <code><nowiki>image = [[Image:Example.jpg|100px]]</nowiki></code> | ||
:; ''imageleft'' | :; ''imageleft''<sup>†</sup> | ||
:: An image to be displayed in a cell below the title and to the left of the body (lists). For the image to display properly, the ''list1'' parameter must be specified and no groups can be specified. The ''imageleft'' parameter accepts standard wikicode for displaying an image, i.e. | :: An image to be displayed in a cell below the title and to the left of the body (lists). For the image to display properly, the ''list1'' parameter must be specified and no groups can be specified. The ''imageleft'' parameter accepts standard wikicode for displaying an image, i.e. | ||
::: <code><nowiki>[[Image:Example.jpg|100px]]</nowiki></code> | ::: <code><nowiki>imageleft = [[Image:Example.jpg|100px]]</nowiki></code> | ||
:; ''above'' | :; ''above''<sup>†</sup> | ||
:: A full-width cell displayed between the titlebar and first group/list, i.e. ''above'' the template's body (groups, lists and image). In a template without an image, ''above'' behaves in the same way as the ''list1'' parameter without the ''group1'' parameter. | :: A full-width cell displayed between the titlebar and first group/list, i.e. ''above'' the template's body (groups, lists and image). In a template without an image, ''above'' behaves in the same way as the ''list1'' parameter without the ''group1'' parameter. | ||
:; ''below'' | :; ''below''<sup>†</sup> | ||
:: A full-width cell displayed ''below'' the template's body (groups, lists and image). In a template without an image, ''below'' behaves in the same way as the template's final ''list<sub>n</sub>'' parameter without a ''group<sub>n</sub>'' parameter. For an example of the ''below'' parameter in use, see {{tl|Lists of the provinces and territories of Canada}}. | :: A full-width cell displayed ''below'' the template's body (groups, lists and image). In a template without an image, ''below'' behaves in the same way as the template's final ''list<sub>n</sub>'' parameter without a ''group<sub>n</sub>'' parameter. For an example of the ''below'' parameter in use, see {{tl|Lists of the provinces and territories of Canada}}. | ||
==== | ====Style parameters==== | ||
Styles are generally not recommended as to maintain consistency among templates and pages in Wikipedia. However, the option to modify styles is given. | Styles are generally not recommended as to maintain consistency among templates and pages in Wikipedia. However, the option to modify styles is given. | ||
:; ''titlestyle'' | :; ''style''<sup>†</sup> | ||
:: Specifies [[Cascading Style Sheets|CSS]] styles to apply to the template body. The parameter ''bodystyle'' also does the example same thing and can be used in place of this ''style'' parameter. This option should be used sparingly as it can lead to visual inconsistencies. Examples: | |||
::: <code>style = background:#''nnnnnn'';</code> | |||
::: <code>style = width:''N'' [em/%/px or width:auto];</code> | |||
::: <code>style = float:[''left/right/none''];</code> | |||
::: <code>style = clear:[''right/left/both/none''];</code> | |||
:; ''titlestyle''<sup>†</sup> | |||
:: [[Cascading Style Sheets|CSS]] styles to apply to ''title'', most often the titlebar's background color: | :: [[Cascading Style Sheets|CSS]] styles to apply to ''title'', most often the titlebar's background color: | ||
::: <code><nowiki>titlestyle = background:</nowiki>''#nnnnnn'';</code> | ::: <code><nowiki>titlestyle = background:</nowiki>''#nnnnnn'';</code> | ||
::: <code><nowiki>titlestyle = background:</nowiki>''name'';</code> | ::: <code><nowiki>titlestyle = background:</nowiki>''name'';</code> | ||
:; ''groupstyle'' | :; ''groupstyle'' | ||
:: CSS styles to apply to the ''groupN'' cells. This option overrides any styles that are applied to the entire table. Examples: | :: CSS styles to apply to the ''groupN'' cells. This option overrides any styles that are applied to the entire table. Examples: | ||
::: <code>background:#''nnnnnn'';</code> | ::: <code>groupstyle = background:#''nnnnnn'';</code> | ||
::: <code>text-align:[''left/center/right''];</code> | ::: <code>groupstyle = text-align:[''left/center/right''];</code> | ||
::: <code>vertical-align:[''top/middle/bottom''];</code> | ::: <code>groupstyle = vertical-align:[''top/middle/bottom''];</code> | ||
:; ''group<sub>n</sub>style'' | |||
:: CSS styles to apply to a specific group, in addition to any styles specified by the ''groupstyle'' parameter. This parameter should only be used when absolutely necessary in order to maintain standardization and simplicity. Examples: | |||
::: <code>group3style = background:red;color:white;</code> | |||
:; ''liststyle'' | :; ''liststyle'' | ||
:: CSS styles to apply to all lists. Overruled by the ''oddstyle'' and ''evenstyle'' parameters (if specified) below. | :: CSS styles to apply to all lists. Overruled by the ''oddstyle'' and ''evenstyle'' parameters (if specified) below. | ||
:; ''list<sub>n</sub>style'' | |||
:: CSS styles to apply to a specific group, in addition to any styles specified by the ''groupstyle'' parameter. This parameter should only be used when absolutely necessary in order to maintain standardization and simplicity. Examples: | |||
::: <code>list5style = background:#ddddff;</code> | |||
:; ''listpadding'' | |||
:: A number and unit specifying the padding in each ''list'' cell. The ''list'' cells come equipped with a default padding of 0.25em on the left and right, and 0em on the top and bottom. Due to complex technical reasons, simply setting "liststyle=padding:0.5em;" (or any other padding setting) will not work. Examples: | |||
::: <code>listpadding = 0.5em 0em; </code> (sets 0.5em padding for the left/right, and 0em padding for the top/bottom.) | |||
::: <code>listpadding = 0em; </code> (removes all list padding.) | |||
:; ''oddstyle'' | :; ''oddstyle'' | ||
Line 141: | Line 144: | ||
::Applies to odd/even list numbers. Overrules styles defined by ''liststyle''. The default behavior is to add striped colors (white and gray) to odd/even rows, respectively, in order to improve readability. These should not be changed except in extraordinary circumstances. | ::Applies to odd/even list numbers. Overrules styles defined by ''liststyle''. The default behavior is to add striped colors (white and gray) to odd/even rows, respectively, in order to improve readability. These should not be changed except in extraordinary circumstances. | ||
:; ''abovestyle'' | :; ''abovestyle''<sup>†</sup> | ||
:; ''belowstyle'' | :; ''belowstyle''<sup>†</sup> | ||
:: CSS styles to apply to the top cell (specified via the ''above'' parameter) and bottom cell (specified via the ''below'' parameter). Typically used to set background color or text alignment: | :: CSS styles to apply to the top cell (specified via the ''above'' parameter) and bottom cell (specified via the ''below'' parameter). Typically used to set background color or text alignment: | ||
::: <code>background:#''nnnnnn'';</code> | ::: <code>abovestyle = background:#''nnnnnn'';</code> | ||
::: <code>text-align:[''left/center/right''];</code> | ::: <code>abovestyle = text-align:[''left/center/right''];</code> | ||
:; ''basestyle''<sup>†</sup> | |||
:: CSS styles to apply to the ''title'', ''above'', ''below'', and ''group'' cells all at once. The style are not applied to ''list'' cells. This is convenient for easily changing the basic color of the navbox without having to repeat the style specifications for the different parts of the navbox. Examples: | |||
::: <code>basestyle = background:lightskyblue;</code> | |||
:; ''imagestyle''<sup>†</sup> | |||
:; ''imageleftstyle''<sup>†</sup> | |||
:: CSS styles to apply to the cells where the image/imageleft sits. These styles should only be used in exceptional circumstances, usually to fix width problems if the width of groups is set and the width of the image cell grows too large. Examples: | |||
::: <code>imagestyle = width:5em;</code> | |||
===== Default styles ===== | ===== Default styles ===== | ||
The style settings listed here are those that editors using the navbox change most often. The other more complex style settings were left out of this list to keep it simple. Most styles are set in [[MediaWiki:Common.css]]. | |||
:<code>bodystyle = background:#fdfdfd; width:100%; vertical-align:middle;</code> | |||
:<code>titlestyle = background:#ccccff; padding-left:1em; padding-right:1em; text-align:center;</code> | |||
:<code>abovestyle = background:#ddddff; padding-left:1em; padding-right:1em; text-align:center;</code> | |||
:<code>belowstyle = background:#ddddff; padding-left:1em; padding-right:1em; text-align:center;</code> | |||
:<code>groupstyle = background:#ddddff; padding-left:1em; padding-right:1em; text-align:right;</code> | |||
:<code>liststyle = background:transparent; text-align:left/center;</code> | |||
:<code>oddstyle = background:transparent;</code> | |||
:<code>evenstyle = background:#f7f7f7;</code> | |||
Since ''liststyle'' and ''oddstyle'' are transparent odd lists have the color of the ''bodystyle'', which defaults to #fdfdfd (white with a hint of gray). A list has <code>text-align:left;</code> if it has a group, if not it has <code>text-align:center;</code>. Since only ''bodystyle'' has a vertical-align all the others inherit its <code>vertical-align:middle;</code>. | |||
====Setup parameters==== | |||
: '''''state'''''<sup>†</sup> [<code>autocollapse, uncollapsed, collapsed, plain, off</code>] | |||
:* Defaults to <code>autocollapse</code>. A navbox with <code>autocollapse</code> will start out collapsed if there are two or more tables on the same page that use other collapsible tables. Otherwise, the navbox will be expanded. For the technically minded, see [[MediaWiki:Common.js]]. | |||
:* If set to <code>collapsed</code>, the navbox will always start out in a collapsed state. | |||
:* If set to <code>plain</code>, the navbox will always be expanded with no [hide] link on the right, and the title will remain centered (by using padding to offset the <small>v • d • e</small> links). | |||
:* If set to <code>off</code>, the navbox will always be expanded with no [hide] link on the right, but no padding will be used to keep the title centered. This is for advanced use only; the "plain" option should suffice for most applications where the [show]/[hide] button needs to be hidden. | |||
:*If set to blank or anything other than <code>autocollapse</code>, <code>collapsed</code>, <code>plain</code>, or <code>off</code> (such as "uncollapsed"), the navbox will always start out in an expanded state, but have the "hide" button. | |||
: To show the box when standalone (non-included) but then auto-hide contents when in an article, put "uncollapsed" inside <noinclude> tags: | |||
: | :* <code>state = </code><nowiki><noinclude>uncollapsed</noinclude></nowiki> | ||
: | :* That setting will force the box visible when standalone (even when followed by other boxes), displaying "[hide]" but then auto-collapse the box when stacked inside an article. | ||
: | |||
: | : Often times, editors will want a default initial state for a navbox, which may be overridden in an article. Here is the trick to do this: | ||
: | :*In your intermediate template, create a parameter also named "state" as a pass-through like this: | ||
:*<tt><nowiki>| state = {{{state<includeonly>|your_desired_initial_state</includeonly>}}}</nowiki></tt> | |||
:*The <nowiki><includeonly>|</nowiki> will make the template expanded when viewing the template page by itself. | |||
: | ::*Example: {{tl|peso}} with autocollapse as the default initial state. [[Bolivian peso]] transcludes it and has only one navbox. So the peso navbox shows. [[Chilean peso]] has two navboxes. So the peso navbox collapses. | ||
:: | ::*Example: {{tl|Historical currencies of Hungary}} with expanded as the default initial state. All transcluding articles shows the content by default, unless there were an hypothetical article that specifies state = collapsed when transcluding. | ||
:: | :; ''navbar''<sup>†</sup> | ||
:: Defaults to <code>Tnavbar</code>. If set to <code>plain</code>, the <small>v • d • e</small> links on the left side of the titlebar will not be displayed, and padding will be automatically used to keep the title centered. Use <code>off</code> to remove the <small>v • d • e</small> links, but not apply padding (this is for advanced use only; the "plain" option should suffice for most applications where a navbar is not desired). Note that it is highly recommended that one does not hide the navbar, in order to make it easier for users to edit the template, and to keep a standard style across pages. | |||
:: | :; ''border''<sup>†</sup> | ||
:: ''See section below on using navboxes within one another for examples and a more complete description.'' If set to <code>child</code> or <code>subgroup</code>, then the navbox can be used as a borderless child that fits snuggly in another navbox. The border is hidden and there is no padding on the sides of the table, so it fits into the ''list'' area of its parent navbox. If set to <code>none</code>, then the border is hidden and padding is removed, and the navbox may be used as a child of another container (do not use the <code>none</code> option inside of another navbox; similarly, only use the <code>child</code>/<code>subgroup</code> option inside of another navbox). If set to anything else (default), then a regular navbox is displayed with a 1px border. An alternate way to specify the border to be a subgroup style is like this (i.e. use the first unnamed parameter instead of the named ''border'' parameter): | |||
:::<code><nowiki>{{Navbox|child</nowiki></code> | |||
::::<code>... | |||
:::<code><nowiki>}}</nowiki></code> | |||
:: | :; ''evenodd'' | ||
:: If set to <code>swap</code>, then the automatic striping of even and odd rows is reversed. Normally, even rows get a light gray background for striping; when this parameter is used, the odd rows receive the gray striping instead of the even rows. This advanced parameter should only be used to fix problems when the navbox is being used as a child of another navbox and the stripes do not match up. Examples and a further description can be found in the section on child navboxes below. | |||
:; '' | |||
:: | ====Advanced parameters==== | ||
:; ''titlegroup'' | |||
:: This puts a group in the title area, with the same default styles as ''group<sub>n</sub>''. It should be used only in exceptional circumstances (usually advanced meta-templates) and its use requires some knowledge of the internal code of {{t1|Navbox}}; you should be ready to manually set up CSS styles to get everything to work properly if you wish to use it. If you think you have an application for this parameter, it might be best to change your mind, or consult the talk page first. | |||
:; ''titlegroupstyle'' | |||
:: The styles for the titlegroup cell. | |||
:; ''innerstyle'' | |||
:: A very advanced parameter to be used ''only'' for advanced meta-templates employing the navbox. Internally, the navbox uses an outer table to draw the border, and then an inner table for everything else (title/above/groups/lists/below/images, etc.). The ''style''/''bodystyle'' parameter sets the style for the outer table, which the inner table inherits, but in advanced cases (meta-templates) it may be necessary to directly set the style for the inner table. This parameter provides access to that inner table so styles can be applied. Use at your own risk. | |||
== Layout of table == | == Layout of table == | ||
Table generated by {{tl|Navbox}} '''without''' ''image'', ''above'' and ''below'' parameters ( | Table generated by {{tl|Navbox}} '''without''' ''image'', ''above'' and ''below'' parameters (gray list background color added for illustration only): | ||
{{Navbox | {{User:CapitalR/Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
|state = uncollapsed | |state = uncollapsed | ||
|liststyle = background:silver; | |||
|liststyle = | |||
|title = {{{title}}} | |title = {{{title}}} | ||
|group1 = {{{group1}}} | |group1 = {{{group1}}} | ||
Line 206: | Line 234: | ||
Table generated by {{tl|Navbox}} '''with''' ''image'', ''above'' and ''below'' parameters ( | Table generated by {{tl|Navbox}} '''with''' ''image'', ''above'' and ''below'' parameters (gray list background color added for illustration only): | ||
{{Navbox | {{User:CapitalR/Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
|state = uncollapsed | |state = uncollapsed | ||
|liststyle = background:silver; | |||
|liststyle = | |||
|image = {{{image}}} | |image = {{{image}}} | ||
|title = {{{title}}} | |title = {{{title}}} | ||
Line 229: | Line 253: | ||
Table generated by {{tl|Navbox}} '''with''' ''image'', ''imageleft'', ''lists'', and '''without''' ''groups'', ''above'', ''below'': | Table generated by {{tl|Navbox}} '''with''' ''image'', ''imageleft'', ''lists'', and '''without''' ''groups'', ''above'', ''below'' (gray list background color added for illustration only): | ||
{{Navbox | {{User:CapitalR/Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
|state = uncollapsed | |state = uncollapsed | ||
|liststyle = | |liststyle = background:silver; | ||
|image = {{{image}}} | |image = {{{image}}} | ||
|imageleft = {{{imageleft}}} | |imageleft = {{{imageleft}}} | ||
Line 242: | Line 265: | ||
|list3 = {{{list3}}} | |list3 = {{{list3}}} | ||
|list4 = {{{list4}}} | |list4 = {{{list4}}} | ||
}} | }} | ||
== Examples == | == Examples == | ||
<!--Please don't encourage | <!--Please don't encourage folks to use <div>s within Navboxes as (unless handled carefully) they can negate liststyles/groupstyles/etc settings.--> | ||
=== No image === | === No image === | ||
<pre> | <pre style="overflow:scroll;"> | ||
{{Navbox | {{Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
Line 328: | Line 294: | ||
</pre> | </pre> | ||
{{Navbox | {{User:CapitalR/Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
|state = uncollapsed | |state = uncollapsed | ||
Line 346: | Line 312: | ||
=== With image, without groups === | === With image, without groups === | ||
<pre> | <pre style="overflow:scroll;"> | ||
{{Navbox | {{Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
Line 354: | Line 320: | ||
}} | }} | ||
</pre> | </pre> | ||
{{Navbox | {{User:CapitalR/Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
|state = uncollapsed | |state = uncollapsed | ||
Line 364: | Line 330: | ||
=== With two images, without groups, multiple lists === | === With two images, without groups, multiple lists === | ||
<pre> | <pre style="overflow:scroll;"> | ||
{{Navbox | {{Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
Line 377: | Line 343: | ||
</pre> | </pre> | ||
{{Navbox | {{User:CapitalR/Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
|state = uncollapsed | |state = uncollapsed | ||
Line 391: | Line 357: | ||
=== With image, groups, above, below === | === With image, groups, above, below === | ||
<pre> | <pre style="overflow:scroll;"> | ||
{{Navbox | {{Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
Line 418: | Line 384: | ||
</pre> | </pre> | ||
{{Navbox | {{User:CapitalR/Navbox | ||
|name = Navbox/doc | |name = Navbox/doc | ||
|state = uncollapsed | |state = uncollapsed | ||
Line 436: | Line 402: | ||
|below = Website: [http://www.msc.com.my/ www.msc.com.my] | |below = Website: [http://www.msc.com.my/ www.msc.com.my] | ||
}} | }} | ||
==Child navboxes== | |||
It is possible to place multiple navboxes within a single border with the use of the ''border'' parameter, or by specifying the first parameter to be "child". The basic code for doing this is as follows (which adds a subgroup for the first group/list area): | |||
<pre style="overflow:scroll;"> | |||
{{Navbox | |||
|name = {{subst:PAGENAME}} | |||
|title = Title | |||
|group1 = [optional] | |||
|list1 = {{Navbox|child | |||
...child navbox parameters... | |||
}} | |||
... | |||
}} | |||
</pre> | |||
===Subgroups example=== | |||
{{main|Template:Navbox subgroup}} | |||
This example shows how subgroups can be used. It is recommended that one uses {{t1|Navbox subgroups}}, but the same result can be reached by using {{t1|Navbox}} with <code>border = child</code> or the first unnamed parameter set to <code>child</code>. Note that the ''evenodd'' parameter is used to reverse striping in some of the subgroups in order to get all of the stripes to line up properly. If you wish to remove the striping altogether, you can set <code>liststyle = background:transparent;</code> in each of the navboxes. | |||
{{User:CapitalR/Navbox | |||
|name = User:CapitalR/Test2 | |||
|image = [[Image:Flag of the United States.svg|100px]] | |||
|state = uncollapsed | |||
|title = Multiple Subgroup Example | |||
|above = Above | |||
|below = Below | |||
|group1 = Group1 | |||
|list1 = List1 | |||
|group2 = Group2 | |||
|list2 = | |||
{{User:CapitalR/Navbox|child | |||
|evenodd = swap | |||
|group1 = Group2.1 | |||
|list1 = List1 | |||
|group2 = Group2.2 | |||
|list2 = List2 | |||
|group3 = Group2.3 | |||
|list3 = List3 | |||
}} | |||
|group3 = Group3 | |||
|list3 = List3 | |||
|group4 = Group4 | |||
|list4 = | |||
{{User:CapitalR/Navbox|child | |||
|evenodd = swap | |||
|group1 = Group4.1 | |||
|list1 = List1 | |||
|group2 = Group4.2 | |||
|list2 = List2 | |||
|group3 = Group4.3 | |||
|list3 = List3 | |||
}} | |||
}} | |||
===Multiple show/hides in a single container=== | |||
{{main|Template:Navbox with collapsible sections}} | |||
The example below is generated using a regular navbox for the main container, then its list1, list2, and list3 parameters each contain another navbox, with <code>border = child</code> set. Note that each of the child navboxes has its own VDE navbar; these could be hidden using <code>navbar = plain</code> for each of them, or by just leaving out the ''name'' parameter (child navboxes do not require the name parameter to be set, unlike regular navoxes). | |||
{{User:CapitalR/Navbox | |||
|name = Navbox/doc | |||
|title = [[Image:Blason France moderne.svg|15px]] {{flagicon|FRA}} [[French colonial empires|Former French overseas empire]] | |||
|state = uncollapsed | |||
|list1 = {{User:CapitalR/Navbox|child | |||
|name = Former French colonies in Africa and the Indian Ocean | |||
|title = [[French colonial empires|Former French colonies]] in [[Africa]] and the [[Indian Ocean]] | |||
|groupstyle = background:lavender; | |||
|group1 = [[Mahgreb]] | |||
|list1 = [[French rule in Algeria|Algeria]]{{·}} [[French Morocco|Morocco]] <small>([[Arguin|Arguin Island]])</small>{{·}} [[History of Tunisia|Tunisia]] | |||
|group2 = [[French West Africa]] | |||
|list2 = [[History of Côte d'Ivoire#French Period|Côte d'Ivoire]]{{·}} [[French Dahomey|Dahomey]]{{·}} [[French Sudan]]{{·}} [[French Guinea|Guinea]]{{·}} [[History of Mauritania#French colonization and post-colonial history|Mauritania]]{{·}} [[History of Niger#Colonization|Niger]]{{·}} [[History of Senegal|Senegal]]{{·}} [[French Upper Volta|Upper Volta]] | |||
|group3 = | |||
|list3 = [[French Togoland]]{{·}} [[James Island (The Gambia)|James Island]] | |||
|group4 = [[French Equatorial Africa]] | |||
|list4 = [[Colonial Chad|Chad]]{{·}} [[History of Gabon|Gabon]]{{·}} [[History of the Republic of the Congo|Middle Congo]]{{·}} [[Oubangui-Chari]] | |||
|group5 = [[Comoros]] | |||
|list5 = [[Anjouan]]{{·}} [[Grande Comore]]{{·}} [[Mohéli]] | |||
|group6 = | |||
|list6 = [[History of Djibouti#French Interest|French Somaliland (Djibouti)]]{{·}} [[History of Madagascar#French Control|Madagascar]]{{·}} [[Mauritius|Ile de France]]{{·}} [[Seychelles]] | |||
}} | |||
|list2 = {{User:CapitalR/Navbox|child | |||
|name = Former French colonies in the Americas | |||
|titlestyle = | |||
|title = [[French colonial empires|Former French colonies]] in the [[Americas]] | |||
|groupstyle = | |||
|list1 = [[New France]]{{spaces|2}}<small>([[Acadia]] • [[Louisiana (New France)|Louisiana]] • [[Canada, New France|Canada]] • [[Newfoundland (island)|Terre Neuve]]) 1655 – 1763 </small> | |||
|list2 = [[Inini]]{{·}} [[Berbice]]{{·}} [[Saint-Domingue]] <small>([[Haiti]])</small>{{·}} [[Tobago]]{{·}} [[History of the British Virgin Islands|Virgin Islands]]{{·}} {{nowrap|[[France Antarctique]]}}{{·}} {{nowrap|[[France Équinoxiale]]}} | |||
|belowstyle = | |||
|below = [[French West India Company]] | |||
}} | |||
|list3 = {{User:CapitalR/Navbox|child | |||
|name = Former French colonies in Asia and Oceania | |||
|title = [[French colonial empires|Former French colonies]] in [[Asia]] and [[Oceania]] | |||
|groupstyle = | |||
|group1 = [[French India]] | |||
|list1 = [[Chandernagor]]{{·}} [[Coromandel Coast]]{{·}} [[History of Chennai|Madras]]{{·}} [[Malabar]]{{·}} [[Mahé, India|Mahé]]{{·}} [[History of Puducherry|Pondichéry]]{{·}} [[Karaikal]]{{·}} [[Yanam (India)|Yanaon]] | |||
|group2 = [[French Indochina]] | |||
|list2 = [[Colonial Cambodia|Cambodia]]{{·}} [[History_of_Laos_to_1945#French_Laos|Laos]]{{·}} [[French Indochina|Vietnam]] <small>([[Annam (French colony)|Annam]] • [[Cochinchina]] • [[Tonkin]])</small> | |||
|group3 = Other Asian | |||
|list3 = [[Alawite State|Alaouites]]{{·}} [[Republic of Hatay|Alexandretta-Hatay]]{{·}} [[Sri Lanka|Ceylon]]{{·}} [[Kwangchowan]] | |||
|group4 = [[Oceania]] | |||
|list4 = [[New Hebrides|New Hebrides]] [[History of Vanuatu|(Vanuatu)]] | |||
|belowstyle = | |||
|below = [[French East India Company]] | |||
}} | |||
}} | |||
===Additional examples=== | |||
You may find additional examples of complex subgroups and child navboxes at the [[Template:Navbox/doc/Advanced examples|advanced navbox examples page]] and the [[Navbox code test page]]. | |||
==Relationship with other Navbox templates== | |||
This navbox template is specifically designed to work in conjunction two other sister templates: {{t1|Navbox with columns}} and {{t1|Navbox with collapsible sections}}. All three of these templates share common parameters for consistency and ease of use (such parameters are marked with a <sup>'''†'''</sup> in the complete parameter list above). Most importantly, all three of these templates can each be used as children of one another (by using the <code>border = child</code> parameter, or by specifying the first unnamed parameter to be <code>child</code> (i.e. use <code><nowiki>{{Navbox|child</nowiki></code>, <code><nowiki>{{Navbox with columns|child</nowiki></code>, or <code><nowiki>{{Navbox with collapsible sections|child</nowiki></code>). For examples on how this is done, see the page on [[Template:Navbox/doc/Advanced examples|advanced navbox examples]]. | |||
== Technical details == | == Technical details == | ||
This template uses CSS classes for most of its looks, thus it is fully skinnable. | |||
This template uses CSS classes for most of its looks, thus it is fully skinnable. | |||
Internally this meta template uses HTML markup instead of wiki markup for the table code. That is the usual way we make meta templates since wiki markup has several drawbacks. For instance it makes it harder to use [[m:Help:ParserFunctions|parser functions]] and special characters in parameters. | Internally this meta template uses HTML markup instead of wiki markup for the table code. That is the usual way we make meta templates since wiki markup has several drawbacks. For instance it makes it harder to use [[m:Help:ParserFunctions|parser functions]] and special characters in parameters. | ||
[[ | For more technical details see the [[{{TALKPAGENAME}}|talk page]], the CSS classes in [[MediaWiki:common.css]] and the collapsible table used to hide the box in [[MediaWiki:common.js]]. | ||
== See also == | == See also == | ||
* {{t1|Navbox with columns}} – Allows columns instead of groups/lists | |||
* {{ | * {{t1|Navbox with collapsible sections}} – Another variation. | ||
* | |||
* [[Wikipedia:Line break handling]] – The how-to guide about how to handle word wraps (line breaks) on Wikipedia, such as the wrapping of the link lists used in navboxes. | * [[Wikipedia:Line break handling]] – The how-to guide about how to handle word wraps (line breaks) on Wikipedia, such as the wrapping of the link lists used in navboxes. | ||
* {{t1|Nowrap begin}} – The recommended format for adding bullets, pipes, or dashes between list items. The page describes how to go about using them with proper wrapping. | |||
* {{t1|Nobold}} – To display text at normal font-weight within a context where the default font-weight is bold, e.g. header cells in tables. | * {{t1|Nobold}} – To display text at normal font-weight within a context where the default font-weight is bold, e.g. header cells in tables. | ||
Line 474: | Line 568: | ||
[[ko:틀:Navbox]] | [[ko:틀:Navbox]] | ||
[[no:Mal:Navbox]] | [[no:Mal:Navbox]] | ||
[[pt:Predefinição:Navbox]] | [[pt:Predefinição:Navbox]] | ||
[[sl:Predloga:Navpolje]] | [[sl:Predloga:Navpolje]] |
Revision as of 07:56, 2 May 2008
Template:Documentation subpage
NOTE:This template is currently undergoing a major revision. If navbox's look strange to you, you may need to clear your cache in order to reload the proper CSS. If they still look strange, wait a few hours, as certain pages will have known side effects to the recent changes, which should be corrected quickly. If problems persist, post a note on the talk page.
This template allows a navigational template to be set up relatively quickly by supplying it one or more lists of links. It comes equipped with default styles that should work for most navigational templates. It is not recommended that one modifies the default styles but it is possible if one wishes to do so.
Usage
Please remove the parameters that are left blank.
{{Navbox |name = {{subst:PAGENAME}} |title = |image = |above = |group1 = |list1 = |group2 = |list2 = ... |group20 = |list20 = |below = }}
Parameter list
Navbox/doc | |
{{{group1}}} | {{{list1}}} |
---|---|
{{{group2}}} | {{{list2}}} |
{{{group4}}} | {{{list4}}} |
The navbox uses lowercase parameter names, as shown in the box (at right). The mandatory name and title will create a one-line box if other parameters are omitted.
Notice "group1" (etc.) is optional, as are sections named "above/below". Template:- The basic and most common parameters are as follows (see below for the full list):
name -
the name of the template.title -
text in the title bar, such as: [[Widget stuff]].state - autocollapse, uncollapsed, collapsed
: the status of box expansion, where "autocollapse" hides stacked navboxes automatically.
titlestyle -
a CSS style for the title-bar, such as:background:gray;
groupstyle -
a CSS style for the group-cells, such as:background:#eee;
image -
an optional right-side image (coded as the whole image tag: [[Image:XX.jpg|90px]] ).imageleft -
an optional left-side image (code the same was as the "image" parameter).
above -
text to appear above the group/list section (could be a list of overall wikilinks).
groupn -
the left-side text before list-n (if group-n omitted, list-n starts at left of box).listn -
text listing wikilinks, often separated by middot templates, such as: [[A]]{{·}}
[[B]]below -
optional text to appear below the group/list section.
Further details, and complex restrictions, are explained below under section Parameter descriptions. See some alternate navbox formats under: Layout of table.
Parameter descriptions
The following is a complete list of parameters for using Template:T1. In most cases, the only required parameters are name
, title
, and list1
, though child navboxes do not even require those to be set.
Template:T1 shares numerous common parameter names as its sister templates Template:T1 and Template:T1 for consistency and ease of use. Parameters marked with a cross† are common to all three master templates.
Mandatory parameters
- name†
- The name of the template, which is needed for the "vTemplate:· dTemplate:· e" ("viewTemplate:· discussTemplate:· edit") links to work properly on all pages where the template is used. You can enter
{{subst:PAGENAME}}
for this value as a shortcut. The name parameter is only mandatory if atitle
is specified, and theborder
parameter is not set.
- title†
- Text that appears centered in the top row of the table. It is usually the template's topic, i.e. a succinct description of the body contents. This should be a single line, but if a second line is needed, use
{{-}}
to ensure proper centering. This parameter is technically not mandatory, but using Template:T1 is rather pointless without a title.
- listn
- (i.e. list1, list2, etc.) The body of the template, usually a list of links. Format is inline, although the text can be entered on separate lines if the entire list is enclosed within
<div> </div>
. At least one list parameter is required; each additional list is displayed in a separate row of the table. Each listn may be preceded by a corresponding groupn parameter, if provided (see below).
- (i.e. list1, list2, etc.) The body of the template, usually a list of links. Format is inline, although the text can be entered on separate lines if the entire list is enclosed within
Optional parameters
Cells
- groupn
- (i.e. group1, group2, etc.) If specified, text appears in a header cell displayed to the left of listn. If omitted, listn uses the full width of the table.
- image†
- An image to be displayed in a cell below the title and to the right of the body (the groups/lists). For the image to display properly, the list1 parameter must be specified. The image parameter accepts standard wikicode for displaying an image, i.e.
image = [[Image:Example.jpg|100px]]
- imageleft†
- An image to be displayed in a cell below the title and to the left of the body (lists). For the image to display properly, the list1 parameter must be specified and no groups can be specified. The imageleft parameter accepts standard wikicode for displaying an image, i.e.
imageleft = [[Image:Example.jpg|100px]]
- above†
- A full-width cell displayed between the titlebar and first group/list, i.e. above the template's body (groups, lists and image). In a template without an image, above behaves in the same way as the list1 parameter without the group1 parameter.
- below†
- A full-width cell displayed below the template's body (groups, lists and image). In a template without an image, below behaves in the same way as the template's final listn parameter without a groupn parameter. For an example of the below parameter in use, see Template:Tl.
Style parameters
Styles are generally not recommended as to maintain consistency among templates and pages in Wikipedia. However, the option to modify styles is given.
- style†
- Specifies CSS styles to apply to the template body. The parameter bodystyle also does the example same thing and can be used in place of this style parameter. This option should be used sparingly as it can lead to visual inconsistencies. Examples:
style = background:#nnnnnn;
style = width:N [em/%/px or width:auto];
style = float:[left/right/none];
style = clear:[right/left/both/none];
- titlestyle†
- CSS styles to apply to title, most often the titlebar's background color:
titlestyle = background:#nnnnnn;
titlestyle = background:name;
- groupstyle
- CSS styles to apply to the groupN cells. This option overrides any styles that are applied to the entire table. Examples:
groupstyle = background:#nnnnnn;
groupstyle = text-align:[left/center/right];
groupstyle = vertical-align:[top/middle/bottom];
- groupnstyle
- CSS styles to apply to a specific group, in addition to any styles specified by the groupstyle parameter. This parameter should only be used when absolutely necessary in order to maintain standardization and simplicity. Examples:
group3style = background:red;color:white;
- liststyle
- CSS styles to apply to all lists. Overruled by the oddstyle and evenstyle parameters (if specified) below.
- listnstyle
- CSS styles to apply to a specific group, in addition to any styles specified by the groupstyle parameter. This parameter should only be used when absolutely necessary in order to maintain standardization and simplicity. Examples:
list5style = background:#ddddff;
- listpadding
- A number and unit specifying the padding in each list cell. The list cells come equipped with a default padding of 0.25em on the left and right, and 0em on the top and bottom. Due to complex technical reasons, simply setting "liststyle=padding:0.5em;" (or any other padding setting) will not work. Examples:
listpadding = 0.5em 0em;
(sets 0.5em padding for the left/right, and 0em padding for the top/bottom.)listpadding = 0em;
(removes all list padding.)
- oddstyle
- evenstyle
- Applies to odd/even list numbers. Overrules styles defined by liststyle. The default behavior is to add striped colors (white and gray) to odd/even rows, respectively, in order to improve readability. These should not be changed except in extraordinary circumstances.
- abovestyle†
- belowstyle†
- CSS styles to apply to the top cell (specified via the above parameter) and bottom cell (specified via the below parameter). Typically used to set background color or text alignment:
abovestyle = background:#nnnnnn;
abovestyle = text-align:[left/center/right];
- basestyle†
- CSS styles to apply to the title, above, below, and group cells all at once. The style are not applied to list cells. This is convenient for easily changing the basic color of the navbox without having to repeat the style specifications for the different parts of the navbox. Examples:
basestyle = background:lightskyblue;
- imagestyle†
- imageleftstyle†
- CSS styles to apply to the cells where the image/imageleft sits. These styles should only be used in exceptional circumstances, usually to fix width problems if the width of groups is set and the width of the image cell grows too large. Examples:
imagestyle = width:5em;
Default styles
The style settings listed here are those that editors using the navbox change most often. The other more complex style settings were left out of this list to keep it simple. Most styles are set in MediaWiki:Common.css.
bodystyle = background:#fdfdfd; width:100%; vertical-align:middle;
titlestyle = background:#ccccff; padding-left:1em; padding-right:1em; text-align:center;
abovestyle = background:#ddddff; padding-left:1em; padding-right:1em; text-align:center;
belowstyle = background:#ddddff; padding-left:1em; padding-right:1em; text-align:center;
groupstyle = background:#ddddff; padding-left:1em; padding-right:1em; text-align:right;
liststyle = background:transparent; text-align:left/center;
oddstyle = background:transparent;
evenstyle = background:#f7f7f7;
Since liststyle and oddstyle are transparent odd lists have the color of the bodystyle, which defaults to #fdfdfd (white with a hint of gray). A list has text-align:left;
if it has a group, if not it has text-align:center;
. Since only bodystyle has a vertical-align all the others inherit its vertical-align:middle;
.
Setup parameters
- state† [
autocollapse, uncollapsed, collapsed, plain, off
]- Defaults to
autocollapse
. A navbox withautocollapse
will start out collapsed if there are two or more tables on the same page that use other collapsible tables. Otherwise, the navbox will be expanded. For the technically minded, see MediaWiki:Common.js. - If set to
collapsed
, the navbox will always start out in a collapsed state. - If set to
plain
, the navbox will always be expanded with no [hide] link on the right, and the title will remain centered (by using padding to offset the v • d • e links). - If set to
off
, the navbox will always be expanded with no [hide] link on the right, but no padding will be used to keep the title centered. This is for advanced use only; the "plain" option should suffice for most applications where the [show]/[hide] button needs to be hidden. - If set to blank or anything other than
autocollapse
,collapsed
,plain
, oroff
(such as "uncollapsed"), the navbox will always start out in an expanded state, but have the "hide" button.
- Defaults to
- To show the box when standalone (non-included) but then auto-hide contents when in an article, put "uncollapsed" inside <noinclude> tags:
state =
<noinclude>uncollapsed</noinclude>- That setting will force the box visible when standalone (even when followed by other boxes), displaying "[hide]" but then auto-collapse the box when stacked inside an article.
- Often times, editors will want a default initial state for a navbox, which may be overridden in an article. Here is the trick to do this:
- In your intermediate template, create a parameter also named "state" as a pass-through like this:
- | state = {{{state<includeonly>|your_desired_initial_state</includeonly>}}}
- The <includeonly>| will make the template expanded when viewing the template page by itself.
- Example: Template:Tl with autocollapse as the default initial state. Bolivian peso transcludes it and has only one navbox. So the peso navbox shows. Chilean peso has two navboxes. So the peso navbox collapses.
- Example: Template:Tl with expanded as the default initial state. All transcluding articles shows the content by default, unless there were an hypothetical article that specifies state = collapsed when transcluding.
- navbar†
- Defaults to
Tnavbar
. If set toplain
, the v • d • e links on the left side of the titlebar will not be displayed, and padding will be automatically used to keep the title centered. Useoff
to remove the v • d • e links, but not apply padding (this is for advanced use only; the "plain" option should suffice for most applications where a navbar is not desired). Note that it is highly recommended that one does not hide the navbar, in order to make it easier for users to edit the template, and to keep a standard style across pages.
- border†
- See section below on using navboxes within one another for examples and a more complete description. If set to
child
orsubgroup
, then the navbox can be used as a borderless child that fits snuggly in another navbox. The border is hidden and there is no padding on the sides of the table, so it fits into the list area of its parent navbox. If set tonone
, then the border is hidden and padding is removed, and the navbox may be used as a child of another container (do not use thenone
option inside of another navbox; similarly, only use thechild
/subgroup
option inside of another navbox). If set to anything else (default), then a regular navbox is displayed with a 1px border. An alternate way to specify the border to be a subgroup style is like this (i.e. use the first unnamed parameter instead of the named border parameter):{{Navbox|child
...
}}
- evenodd
- If set to
swap
, then the automatic striping of even and odd rows is reversed. Normally, even rows get a light gray background for striping; when this parameter is used, the odd rows receive the gray striping instead of the even rows. This advanced parameter should only be used to fix problems when the navbox is being used as a child of another navbox and the stripes do not match up. Examples and a further description can be found in the section on child navboxes below.
Advanced parameters
- titlegroup
- This puts a group in the title area, with the same default styles as groupn. It should be used only in exceptional circumstances (usually advanced meta-templates) and its use requires some knowledge of the internal code of Template:T1; you should be ready to manually set up CSS styles to get everything to work properly if you wish to use it. If you think you have an application for this parameter, it might be best to change your mind, or consult the talk page first.
- titlegroupstyle
- The styles for the titlegroup cell.
- innerstyle
- A very advanced parameter to be used only for advanced meta-templates employing the navbox. Internally, the navbox uses an outer table to draw the border, and then an inner table for everything else (title/above/groups/lists/below/images, etc.). The style/bodystyle parameter sets the style for the outer table, which the inner table inherits, but in advanced cases (meta-templates) it may be necessary to directly set the style for the inner table. This parameter provides access to that inner table so styles can be applied. Use at your own risk.
Layout of table
Table generated by Template:Tl without image, above and below parameters (gray list background color added for illustration only):
User:CapitalR/Navbox
Table generated by Template:Tl with image, above and below parameters (gray list background color added for illustration only):
User:CapitalR/Navbox
Table generated by Template:Tl with image, imageleft, lists, and without groups, above, below (gray list background color added for illustration only):
User:CapitalR/Navbox
Examples
No image
{{Navbox
|name = Navbox/doc
|title = [[Multimedia Super Corridor|MSC (Multimedia Super Corridor) Malaysia]]{{-}}''without image''
|group1 = Centre
|list1 = [[Cyberjaya]]
|group2 = Area
|list2 = [[Klang Valley]]
|group3 = Major landmarks
|list3 = [[Petronas Twin Towers]]{{·}} [[Kuala Lumpur Tower]]{{·}} [[Kuala Lumpur Sentral]]{{·}} [[Technology Park Malaysia]]{{·}} [[Putrajaya]]{{·}} [[Cyberjaya]]{{·}}
[[Kuala Lumpur International Airport]]
|group4 = Infrastructure
|list4 = [[Express Rail Link]]{{·}} [[KL-KLIA Dedicated Expressway]]
|group5 = Prime applications
|list5 = [[EGovernment]]{{·}} [[MyKad]]
}}
With image, without groups
{{Navbox
|name = Navbox/doc
|title = [[Multimedia Super Corridor|MSC (Multimedia Super Corridor) Malaysia]]
|image = [[Image:Flag of Malaysia.svg|80px]]
|list1 = [[Petronas Twin Towers]]{{·}} [[Kuala Lumpur Tower]]{{·}} [[Kuala Lumpur Sentral]]{{·}} [[Technology Park Malaysia]]{{·}} [[Putrajaya]]{{·}} [[Cyberjaya]]{{·}} [[Kuala Lumpur International Airport]]
}}
With two images, without groups, multiple lists
{{Navbox
|name = Navbox/doc
|title = [[Multimedia Super Corridor|MSC (Multimedia Super Corridor) Malaysia]]
|image = [[Image:Flag of Malaysia.svg|80px]]
|imageleft = [[Image:Flag of Malaysia.svg|80px]]
|list1 = [[Petronas Twin Towers]]{{·}} [[Kuala Lumpur Tower]]{{·}} [[Kuala Lumpur Sentral]]
|list2 = [[Express Rail Link]]{{·}} [[KL-KLIA Dedicated Expressway]]
|list3 = [[EGovernment]]{{·}} [[MyKad]]
|list4 = [[Klang Valley]]
}}
With image, groups, above, below
{{Navbox
|name = Navbox/doc
|title = [[Multimedia Super Corridor|MSC (Multimedia Super Corridor) Malaysia]]
|image = [[Image:Flag of Malaysia.svg|80px]]
|above = Above text goes here
|group1 = Centre
|list1 = [[Cyberjaya]]
|group2 = Area
|list2 = [[Klang Valley]]
|group3 = Major landmarks
|list3 = [[Petronas Twin Towers]]{{·}} [[Kuala Lumpur Tower]]{{·}} [[Kuala Lumpur Sentral]]{{·}} [[Technology Park Malaysia]]{{·}} [[Putrajaya]]{{·}} [[Cyberjaya]]{{·}} [[Kuala Lumpur International Airport]]
|group4 = Infrastructure
|list4 = [[Express Rail Link]]{{·}} [[KL-KLIA Dedicated Expressway]]
|group5 = Prime applications
|list5 = [[EGovernment]]{{·}} [[MyKad]]
|below = Website: [http://www.msc.com.my/ www.msc.com.my]
}}
It is possible to place multiple navboxes within a single border with the use of the border parameter, or by specifying the first parameter to be "child". The basic code for doing this is as follows (which adds a subgroup for the first group/list area):
{{Navbox
|name = {{subst:PAGENAME}}
|title = Title
|group1 = [optional]
|list1 = {{Navbox|child
...child navbox parameters...
}}
...
}}
Subgroups example
Template:Main
This example shows how subgroups can be used. It is recommended that one uses Template:T1, but the same result can be reached by using Template:T1 with border = child
or the first unnamed parameter set to child
. Note that the evenodd parameter is used to reverse striping in some of the subgroups in order to get all of the stripes to line up properly. If you wish to remove the striping altogether, you can set liststyle = background:transparent;
in each of the navboxes.
Multiple show/hides in a single container
Template:Main
The example below is generated using a regular navbox for the main container, then its list1, list2, and list3 parameters each contain another navbox, with border = child
set. Note that each of the child navboxes has its own VDE navbar; these could be hidden using navbar = plain
for each of them, or by just leaving out the name parameter (child navboxes do not require the name parameter to be set, unlike regular navoxes).
Additional examples
You may find additional examples of complex subgroups and child navboxes at the advanced navbox examples page and the Navbox code test page.
This navbox template is specifically designed to work in conjunction two other sister templates: Template:T1 and Template:T1. All three of these templates share common parameters for consistency and ease of use (such parameters are marked with a † in the complete parameter list above). Most importantly, all three of these templates can each be used as children of one another (by using the border = child
parameter, or by specifying the first unnamed parameter to be child
(i.e. use {{Navbox|child
, {{Navbox with columns|child
, or {{Navbox with collapsible sections|child
). For examples on how this is done, see the page on advanced navbox examples.
Technical details
This template uses CSS classes for most of its looks, thus it is fully skinnable.
Internally this meta template uses HTML markup instead of wiki markup for the table code. That is the usual way we make meta templates since wiki markup has several drawbacks. For instance it makes it harder to use parser functions and special characters in parameters.
For more technical details see the talk page, the CSS classes in MediaWiki:common.css and the collapsible table used to hide the box in MediaWiki:common.js.
See also
- Template:T1 – Allows columns instead of groups/lists
- Template:T1 – Another variation.
- Wikipedia:Line break handling – The how-to guide about how to handle word wraps (line breaks) on Wikipedia, such as the wrapping of the link lists used in navboxes.
- Template:T1 – The recommended format for adding bullets, pipes, or dashes between list items. The page describes how to go about using them with proper wrapping.
- Template:T1 – To display text at normal font-weight within a context where the default font-weight is bold, e.g. header cells in tables.
Template:Navigational templates