Editing Template:Navbox/doc

Jump to: navigation, search

Warning: You are not logged in. Your IP address will be publicly visible if you make any edits. If you log in or create an account, your edits will be attributed to your username, along with other benefits.

The edit can be undone. Please check the comparison below to verify that this is what you want to do, and then save the changes below to finish undoing the edit.

This page is not enabled for semantic in-text annotations due to namespace restrictions. Details about how to enable the namespace can be found on the configuration help page.

Latest revision Your text
Line 1: Line 1:
 +
{{documentation subpage}}
 +
<!-- Categories go where indicated at the bottom of this page, please; interwikis go to Wikidata (see also: [[Wikipedia:Wikidata]]). -->
 
{{for|vertically-aligned navigation|Template:Sidebar}}
 
{{for|vertically-aligned navigation|Template:Sidebar}}
{{documentation subpage}}
+
{{#ifeq:{{FULLPAGENAME}}|Template:Navbox|{{high-risk| approximately 2600000 }}}}<includeonly>
{{high-use|all-pages=y}}
+
{{lua|Module:Navbox}}{{Template display|nomobile}}</includeonly>
{{Template display|nomobile}}
 
{{Lua|Module:Navbox}}
 
 
{{Navbox suite}}
 
{{Navbox suite}}
{{Lua sidebar}}
 
  
This template allows a [[Wikipedia:Navigation template|navigational template]] to be set up relatively quickly by supplying it with one or more lists of links. It comes equipped with default styles that should work for most navigational templates. Changing the default styles is possible, but not recommended. Using this template, or one of its "Navbox suite" sister templates, is highly recommended for standardization of navigational templates, and for ease of use.
+
This template allows a [[Wikipedia:Navigation template|navigational template]] to be set up relatively quickly by supplying it with one or more lists of links. It comes equipped with default styles that should work for most navigational templates. Changing the default styles is possible, but not recommended. Using this template, or one of its "Navbox suite" sister templates, is highly recommended for standardization of navigational templates, and for ease of use.
  
 
{{Navbox visibility}}
 
{{Navbox visibility}}
Line 61: Line 60:
 
The basic and most common parameters are as follows (see [[#Parameter descriptions|below]] for the full list):
 
The basic and most common parameters are as follows (see [[#Parameter descriptions|below]] for the full list):
  
: <code>name</code> – the name (Wikipedia location) 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>listclass</code> – a CSS class for the list cells, usually <code>hlist</code> for horizontal lists. Alternatively, use bodyclass for the whole box.
 
: <code>listclass</code> – a CSS class for the list cells, usually <code>hlist</code> for horizontal lists. Alternatively, use bodyclass for the whole box.
Line 68: Line 67:
 
: <code>groupstyle</code> – a CSS style for the group-cells, such as: <code>background: #eee;</code>
 
: <code>groupstyle</code> – a CSS style for the group-cells, such as: <code>background: #eee;</code>
 
: <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).
: <code>image</code> – an optional right-side image, coded as the whole image, such as: <code><nowiki>[[File:</nowiki><var>XX</var><nowiki>.jpg|80px|link=|alt=]]</nowiki></code>
+
: <code>image</code> – an optional right-side image, coded as the whole image. Typically it is purely decorative, so it should be coded as <code><nowiki>[[File:</nowiki><var>XX</var><nowiki>.jpg|80px|link=|alt=]]</nowiki></code>.
:: Note that most of such images don't comply with [[MOS:DECOR]] and should be removed at sight.
 
 
: <code>imageleft</code> – an optional left-side image (code the same as the "image" parameter).
 
: <code>imageleft</code> – an optional left-side image (code the same as the "image" parameter).
: <code>group<sub>n</sub></code> – the left-side text before list-n (if group-n omitted, list-n extends to the left edge of the box, and defaults to <code>text-align:center</code> styling).
+
: <code>group<sub>n</sub></code> – the left-side text before list-n (if group-n omitted, list-n starts at left of box).
: <code>list<sub>n</sub></code> – text listing wikilinks using a [[Help:List|wikilist]] format.
+
: <code>list<sub>n</sub></code> – text listing wikilinks using a [[Help:Lists|wikilist]] format.
 
: <code>below</code> – optional text to appear below the group/list section.
 
: <code>below</code> – optional text to appear below the group/list section.
  
 
== Parameter descriptions ==
 
== Parameter descriptions ==
The following is a complete list of parameters for using {{tl|Navbox}}. In most cases, the only required parameters are <code>name</code>, <code>title</code>, and <code>list1</code>, though [[Template:Navbox/doc#Child navboxes|child navboxes]] do not even require those to be set.
+
The following is a complete list of parameters for using {{tl|Navbox}}. In most cases, the only required parameters are <code>name</code>, <code>title</code>, and <code>list1</code>, though [[Template:Navbox/doc#Child navboxes|child navboxes]] do not even require those to be set.
  
{{tl|Navbox}} shares numerous common parameter names with its sister templates, {{tl|Navbox with columns}} and {{tl|Navbox with collapsible groups}}, for consistency and ease of use. Parameters marked with an asterisk (*) are common to all three master templates.
+
{{tl|Navbox}} shares numerous common parameter names with its sister templates, {{tl|Navbox with columns}} and {{tl|Navbox with collapsible groups}}, for consistency and ease of use. Parameters marked with an asterisk (*) are common to all three master templates.
  
 
=== Setup parameters ===
 
=== Setup parameters ===
 
:; ''name''*
 
:; ''name''*
:: The name of the template, which is needed for the "V&nbsp;• T&nbsp;• E" ("View&nbsp;• Talk&nbsp;• 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, and the <code>navbar</code> parameter is not used to disable the navbar.
+
:: The name of the template, which is needed for the "V&nbsp;• T&nbsp;• E" ("View&nbsp;• Talk&nbsp;• 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, and the <code>navbar</code> parameter is not used to disable the navbar.
 
:; ''state''* <span style="font-weight:normal;">[<code>autocollapse, collapsed, expanded, plain, off</code>]</span>
 
:; ''state''* <span style="font-weight:normal;">[<code>autocollapse, collapsed, expanded, plain, off</code>]</span>
:* Defaults to <code>autocollapse</code>. A navbox with <code>autocollapse</code> will start out collapsed if there are two or more collapsible elements on the same page. Otherwise, the navbox will be expanded. For the technically minded, see [[MediaWiki:Common.js]] (search for "autocollapse").
+
:* 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>collapsed</code>, the navbox will always start out in a collapsed state.
 
:* If set to <code>expanded</code>, the navbox will always start out in an expanded state.
 
:* If set to <code>expanded</code>, the navbox will always start out in an expanded 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&nbsp;• T&nbsp;• E</small> links).
 
:* 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&nbsp;• T&nbsp;• 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 <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.
 
: To show the box when standalone (non-included) but then auto-hide contents when in an article, put "expanded" inside {{tag|noinclude|p}} tags. This setting will force the box visible when standalone (even when followed by other boxes), displaying "[hide]", but then it will auto-collapse the box when stacked inside an article:
 
: To show the box when standalone (non-included) but then auto-hide contents when in an article, put "expanded" inside {{tag|noinclude|p}} tags. This setting will force the box visible when standalone (even when followed by other boxes), displaying "[hide]", but then it will auto-collapse the box when stacked inside an article:
 
:: <code><nowiki>| state =&nbsp;</nowiki></code>{{tag|noinclude|content=expanded}}
 
:: <code><nowiki>| state =&nbsp;</nowiki></code>{{tag|noinclude|content=expanded}}
Line 105: Line 103:
 
:* The template {{tl|Collapsible option}} explains how to use the <code>state</code> parameter. It can be added to a {{tag|noinclude|p}} section after the template definition or to the instructions on the {{tl|documentation subpage}}.
 
:* The template {{tl|Collapsible option}} explains how to use the <code>state</code> parameter. It can be added to a {{tag|noinclude|p}} section after the template definition or to the instructions on the {{tl|documentation subpage}}.
 
:; ''navbar''*
 
:; ''navbar''*
:: If set to <code>plain</code>, the <span style="font-size: 88%;">V&nbsp;• T&nbsp;• E</span> 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 <span style="font-size: 88%;">V&nbsp;• T&nbsp;• E</span> 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). It is highly recommended that one not hide the navbar, in order to make it easier for users to edit the template, and to keep a standard style across pages.
+
:: If set to <code>plain</code>, the <span style="font-size: 88%;">V&nbsp;• T&nbsp;• E</span> 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 <span style="font-size: 88%;">V&nbsp;• T&nbsp;• E</span> 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). It is highly recommended that one 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''*
 
:; ''border''*
:: ''See later section on [[#Child navboxes|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 snugly 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):
+
:: ''See later section on [[#Child navboxes|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 snugly 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><nowiki>{{Navbox|child</nowiki></code>
 
:::: <code>...</code>
 
:::: <code>...</code>
Line 114: Line 112:
 
=== Cells ===
 
=== Cells ===
 
:; ''title''*
 
:; ''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 <code><nowiki>{{-}}</nowiki></code> to ensure proper centering. This parameter is technically not mandatory, but using {{tl|Navbox}} is rather pointless without a 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 <code><nowiki>{{-}}</nowiki></code> to ensure proper centering. This parameter is technically not mandatory, but using {{tl|Navbox}} is rather pointless without a title.
 
:; ''above''*
 
:; ''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.
 
:: 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.
Line 120: Line 118:
 
:: (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.
 
:; ''list<sub>n</sub>''*
 
:; ''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).
+
:: (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).
 
::Entries should be separated using a [[newline]] and an [[asterisk]] (*). If instead two asterisks are used, it provides [[Nesting (computing)|nesting]] within the previous entry by enclosing the entry with brackets. Increasing the number of asterisks used increases the number of brackets around entries.
 
::Entries should be separated using a [[newline]] and an [[asterisk]] (*). If instead two asterisks are used, it provides [[Nesting (computing)|nesting]] within the previous entry by enclosing the entry with brackets. Increasing the number of asterisks used increases the number of brackets around entries.
 
:; ''image''*
 
:; ''image''*
Line 126: Line 124:
 
::: <code><nowiki>[[File:</nowiki><var>XX</var><nowiki>.jpg|80px|link=|alt=]]</nowiki></code>
 
::: <code><nowiki>[[File:</nowiki><var>XX</var><nowiki>.jpg|80px|link=|alt=]]</nowiki></code>
 
::: nb: including "|right" will produce the usual left margin to provide separation from the list items and [[Zebra striping (computer graphics)|zebra striping]].
 
::: nb: including "|right" will produce the usual left margin to provide separation from the list items and [[Zebra striping (computer graphics)|zebra striping]].
::Note that most of such images don't comply with [[MOS:DECOR]] and should be removed at sight. A rare example of a correct usage would be [[special:permalink/995622594|this one]]: a map shows (in green) the location of a region within the state of Kazakhstan, and this is consistently implemented for [[:category:Kazakhstan region templates|all state's regions]].
 
 
:; ''imageleft''*
 
:; ''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. It accepts the same sort of parameter that ''image'' accepts.
 
:: 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. It accepts the same sort of parameter that ''image'' accepts.
 
:; ''below''*
 
:; ''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 ''list<sub>n</sub>'' parameter without a ''group<sub>n</sub>'' parameter. For an example of the ''below'' parameter in use, see {{oldid|Main Page|352612160|this}} version of {{tl|Lists of the provinces and territories of Canada}}. {{tl|icon}} is often used for non-article links, for example <code><nowiki>{{icon|category}} [[:Category:</nowiki>''name''<nowiki>|Category]]</nowiki></code>.
+
:: 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 {{oldid|Main Page|352612160|this}} version of {{tl|Lists of the provinces and territories of Canada}}.
  
 
=== Style parameters ===
 
=== Style parameters ===
Line 136: Line 133:
  
 
:; ''bodystyle''*
 
:; ''bodystyle''*
:: Specifies [[Cascading Style Sheets|CSS]] styles to apply to the template body. This option should be used sparingly as it can lead to visual inconsistencies. Examples:
+
:: Specifies [[Cascading Style Sheets|CSS]] styles to apply to the template body. This option should be used sparingly as it can lead to visual inconsistencies. Examples:
 
::: <code>bodystyle = background: #''nnnnnn'';</code>
 
::: <code>bodystyle = background: #''nnnnnn'';</code>
 
::: <code>bodystyle = width: ''N''&nbsp;[em/%/px or width: auto];</code>
 
::: <code>bodystyle = width: ''N''&nbsp;[em/%/px or width: auto];</code>
Line 142: Line 139:
 
::: <code>bodystyle = clear: [''right/left/both/none''];</code>
 
::: <code>bodystyle = clear: [''right/left/both/none''];</code>
 
:; ''basestyle''*
 
:; ''basestyle''*
:: CSS styles to apply to the ''title'', ''above'', ''below'', and ''group'' cells all at once. The styles 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:
+
:: CSS styles to apply to the ''title'', ''above'', ''below'', and ''group'' cells all at once. The styles 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>
 
::: <code>basestyle = background: lightskyblue;</code>
 
:; ''titlestyle''*
 
:; ''titlestyle''*
Line 155: Line 152:
 
::: <code>groupstyle = vertical-align: [''top/middle/bottom''];</code>
 
::: <code>groupstyle = vertical-align: [''top/middle/bottom''];</code>
 
:; ''group<sub>n</sub>style''*
 
:; ''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:
+
:: 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>
 
::: <code>group3style = background: red; color: white;</code>
 
:; ''groupwidth''
 
:; ''groupwidth''
Line 173: Line 170:
 
:: 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.
 
:; ''evenodd'' <span style="font-weight: normal;"><code>[swap, even, odd, off]</code></span>
 
:; ''evenodd'' <span style="font-weight: normal;"><code>[swap, even, odd, off]</code></span>
:: 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. Setting to <code>even</code> or <code>odd</code> sets all rows to have that striping color. Setting to <code>off</code> disables automatic row striping.
+
:: 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. Setting to <code>even</code> or <code>odd</code> sets all rows to have that striping color. Setting to <code>off</code> disables automatic row striping.
 
:; ''abovestyle''*
 
:; ''abovestyle''*
 
:; ''belowstyle''*
 
:; ''belowstyle''*
Line 189: Line 186:
 
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]].
 
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]].
  
<syntaxhighlight lang="css">
+
<source lang="css">
 
bodystyle = background: #fdfdfd; width: 100%; vertical-align: middle;
 
bodystyle = background: #fdfdfd; width: 100%; vertical-align: middle;
 
titlestyle = background: #ccccff; padding-left: 1em; padding-right: 1em; text-align: center;
 
titlestyle = background: #ccccff; padding-left: 1em; padding-right: 1em; text-align: center;
Line 198: Line 195:
 
oddstyle = background: transparent;
 
oddstyle = background: transparent;
 
evenstyle = background: #f7f7f7;
 
evenstyle = background: #f7f7f7;
</syntaxhighlight>
+
</source>
 
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 defaults to <code>text-align: left;</code> if it has a group, if not it defaults to <code>text-align: center;</code>. Since only ''bodystyle'' has a vertical-align all the others inherit its <code>vertical-align: middle;</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 defaults to <code>text-align: left;</code> if it has a group, if not it defaults to <code>text-align: center;</code>. Since only ''bodystyle'' has a vertical-align all the others inherit its <code>vertical-align: middle;</code>.
  
Line 213: Line 210:
 
:: The styles for the titlegroup cell.
 
:: The styles for the titlegroup cell.
 
:; ''innerstyle''
 
:; ''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.
+
:: 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.
 
:; ''nowrapitems''
 
:; ''nowrapitems''
 
:: Setting <code>|nowrapitems=yes</code> applies nowrap to each line in a list item, and to any <code>above</code> or <code>below</code> item.
 
:: Setting <code>|nowrapitems=yes</code> applies nowrap to each line in a list item, and to any <code>above</code> or <code>below</code> item.
Line 305: Line 302:
  
 
=== No image ===
 
=== No image ===
<syntaxhighlight lang="moin" style="overflow: auto;">
+
<source lang="moin" style="overflow: auto;">
 
  {{Navbox
 
  {{Navbox
 
  | name  = Navbox/doc
 
  | name  = Navbox/doc
Line 339: Line 336:
 
  * [[MyKad]]
 
  * [[MyKad]]
 
  }}
 
  }}
</syntaxhighlight>
+
</source>
  
 
{{{{PAGENAMETDOC}}
 
{{{{PAGENAMETDOC}}
Line 369: Line 366:
 
* [[E-Government]]
 
* [[E-Government]]
 
* [[MyKad]]
 
* [[MyKad]]
 +
}}
 +
 +
=== With image, without groups ===
 +
<source lang="moin" style="overflow: auto;">
 +
{{Navbox
 +
| name  = Navbox/doc
 +
| title = [[MSC Malaysia]]
 +
| listclass = hlist
 +
| image = [[File:Flag of Malaysia.svg|80px|link=|alt=]]
 +
 +
| list1 =
 +
* [[Petronas Twin Towers]]
 +
* [[Kuala Lumpur Tower]]
 +
* [[Kuala Lumpur Sentral]]
 +
* [[Technology Park Malaysia]]
 +
* [[Putrajaya]]
 +
* [[Cyberjaya]]
 +
* [[Kuala Lumpur International Airport]]
 +
}}
 +
</source>
 +
 +
{{{{PAGENAMETDOC}}
 +
| name  = Navbox/doc
 +
| title = [[MSC Malaysia]]
 +
| listclass = hlist
 +
| image = [[File:Flag of Malaysia.svg|80px|link=|alt=]]
 +
| 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 ===
 +
<source lang="moin" style="overflow: auto;">
 +
{{Navbox
 +
| name  = Navbox/doc
 +
| title = [[MSC Malaysia]]
 +
| listclass = hlist
 +
| image = [[File:Flag of Malaysia.svg|80px|link=|alt=]]
 +
| imageleft = [[File:Flag of Malaysia.svg|80px]]
 +
 +
| list1 =
 +
* [[Petronas Twin Towers]]
 +
* [[Kuala Lumpur Tower]]
 +
* [[Kuala Lumpur Sentral]]
 +
 +
| list2 =
 +
* [[Express Rail Link]]
 +
* [[KL-KLIA Dedicated Expressway]]
 +
 +
| list3 =
 +
* [[E-Government]]
 +
* [[MyKad]]
 +
 +
| list4 =
 +
* [[Klang Valley]]
 +
}}
 +
</source>
 +
 +
{{{{PAGENAMETDOC}}
 +
| name  = Navbox/doc
 +
| title = [[MSC Malaysia]]
 +
| listclass = hlist
 +
| image = [[File:Flag of Malaysia.svg|80px|link=|alt=]]
 +
| imageleft = [[File:Flag of Malaysia.svg|80px]]
 +
| list1 =
 +
* [[Petronas Twin Towers]]
 +
* [[Kuala Lumpur Tower]]
 +
* [[Kuala Lumpur Sentral]]
 +
| list2 =
 +
* [[Express Rail Link]]
 +
* [[KL-KLIA Dedicated Expressway]]
 +
| list3 =
 +
* [[E-Government]]
 +
* [[MyKad]]
 +
| list4 =
 +
* [[Klang Valley]]
 +
}}
 +
 +
=== With image, groups, above, below ===
 +
<source lang="moin" style="overflow: auto;">
 +
{{Navbox
 +
| name  = Navbox/doc
 +
| title = [[MSC Malaysia]]
 +
| listclass = hlist
 +
| above = Above text goes here
 +
| image = [[File:Flag of Malaysia.svg|80px|link=|alt=]]
 +
 +
| 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]]
 +
 +
| group4 = Infrastructure
 +
| list4  =
 +
* [[Express Rail Link]]
 +
* [[KL-KLIA Dedicated Expressway]]
 +
 +
| group5 = Prime applications
 +
| list5  =
 +
* [[E-Government]]
 +
* [[MyKad]]
 +
 +
| below  = Below text goes here
 +
}}
 +
</source>
 +
 +
{{{{PAGENAMETDOC}}
 +
| name  = Navbox/doc
 +
| title = [[MSC Malaysia]]
 +
| listclass = hlist
 +
| above = Above text goes here
 +
| image = [[File:Flag of Malaysia.svg|80px|link=|alt=]]
 +
| 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]]
 +
| group4 = Infrastructure
 +
| list4  =
 +
* [[Express Rail Link]]
 +
* [[KL-KLIA Dedicated Expressway]]
 +
| group5 = Prime applications
 +
| list5  =
 +
* [[E-Government]]
 +
* [[MyKad]]
 +
| below  = Below text goes here
 
}}
 
}}
  
Line 395: Line 544:
 
{{{{PAGENAMETDOC}}
 
{{{{PAGENAMETDOC}}
 
| name = Navbox/doc
 
| name = Navbox/doc
 +
| image = [[File:Flag of the United States.svg|100px|link=|alt=]]
 
| state = uncollapsed
 
| state = uncollapsed
 
| title = Multiple subgroup example
 
| title = Multiple subgroup example
Line 428: Line 578:
 
{{main|Template:Navbox with collapsible groups}}
 
{{main|Template:Navbox with collapsible groups}}
  
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>1 = child</code> set. The view (v), talk (t), edit (e) navbar links are hidden using <code>navbar = plain</code> for each of them, or could be suppressed by just leaving out the ''name'' parameter (child navboxes do not require the name parameter to be set, unlike regular navboxes).
+
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>1 = child</code> set. The view (v), discuss (d), edit (e) navbar links are hidden using <code>navbar = plain</code> for each of them, or could be suppressed by just leaving out the ''name'' parameter (child navboxes do not require the name parameter to be set, unlike regular navboxes).
  
 
{{{{PAGENAMETDOC}}
 
{{{{PAGENAMETDOC}}
 
| name = Navbox/doc
 
| name = Navbox/doc
| title = [[French colonial empire|Former French overseas empire]]
+
| title = [[File:Blason France moderne.svg|x17px|link=|alt=]] [[File:Flag of France.svg|x17px|link=|alt=]] [[French colonial empire|Former French overseas empire]]
 
| state = uncollapsed
 
| state = uncollapsed
 
| list1 = {{{{PAGENAMETDOC}}|child
 
| list1 = {{{{PAGENAMETDOC}}|child
Line 521: Line 671:
  
 
== Relationship with other Navbox templates ==
 
== Relationship with other Navbox templates ==
This navbox template works in conjunction with two other templates: {{tl|Navbox with columns}} and {{tl|Navbox with collapsible groups}}. All three of these templates share common parameters for consistency and ease of use (such parameters are marked with an asterisk (*) in the [[#Parameter descriptions|parameter descriptions]] list hereinbefore). Most importantly, each template can be used as a child of one another (by using the {{para|border|child}} parameter, or by specifying the first unnamed parameter to be <code>child</code>. For example: <code><nowiki>{{Navbox|child ...}}</nowiki></code>, <code><nowiki>{{Navbox with columns|child ...}}</nowiki></code> or <code><nowiki>{{Navbox with collapsible groups|child ...}}</nowiki></code>.)
+
This navbox template is specifically designed to work in conjunction with two other sister templates: {{tl|Navbox with columns}} and {{tl|Navbox with collapsible groups}}. All three of these templates share common parameters for consistency and ease of use (such parameters are marked with an asterisk (*) in the [[#Parameter descriptions|parameter descriptions]] list hereinbefore). Most importantly, each template can be used as a child of one another (by using the {{para|border|child}} parameter, or by specifying the first unnamed parameter to be <code>child</code>. For example: <code><nowiki>{{Navbox|child ...}}</nowiki></code>, <code><nowiki>{{Navbox with columns|child ...}}</nowiki></code> or <code><nowiki>{{Navbox with collapsible groups|child ...}}</nowiki></code>.)
  
 
== Technical details ==
 
== Technical details ==
* The {{navbar|1=:{{FULLPAGENAME}}|mini=on}} links are produced by [[Template:Navbar]]. If you have a question about them, it is probably best to ask at [[Template talk:Navbar]].
+
* 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.
 +
* 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]].
 +
 
 +
=== Intricacies ===
 
* The 2px wide border between groups and lists is drawn using the border-left property of the list cell. Thus, if you wish to change the background color of the template (for example <code>bodystyle = background:purple;</code>), then you'll need to make the border-left-color match the background color (i.e. <code>liststyle = border-left-color: purple;</code>). If you wish to have a border around each list cell, then the 2px border between the list cells and group cells will disappear; you'll have to come up with your own solution.
 
* The 2px wide border between groups and lists is drawn using the border-left property of the list cell. Thus, if you wish to change the background color of the template (for example <code>bodystyle = background:purple;</code>), then you'll need to make the border-left-color match the background color (i.e. <code>liststyle = border-left-color: purple;</code>). If you wish to have a border around each list cell, then the 2px border between the list cells and group cells will disappear; you'll have to come up with your own solution.
* Adjacent navboxes have only a 1 pixel border between them. If you set the top or bottom margin of <code>style/bodystyle</code>, then this will not work.
+
* The list cell width is initially set to 100%. Thus, if you wish to manually set the width of group cells, you'll need to also specify the liststyle to have width: auto. If you wish to set the group width and use images, it's up to you to figure out the CSS in the groupstyle, liststyle, imagestyle, and imageleftstyle parameters to get everything to work correctly. Example of setting group width:
 +
:: <code>groupstyle = width: 10em;</code>
 +
:: <code>liststyle = width: auto;</code>
 +
* Adjacent navboxes have only a 1 pixel border between them (except in IE 6, which doesn't support the necessary CSS). If you set the top or bottom margin of <code>style/bodystyle</code>, then this will not work.
 
* The default margin-left and margin-right of the outer navbox table are set to "auto;". If you wish to use navbox as a float, you need to manually set the margin-left and margin-right values, because the auto margins interfere with the float option. For example, add the following code to use the navbox as a float:
 
* The default margin-left and margin-right of the outer navbox table are set to "auto;". If you wish to use navbox as a float, you need to manually set the margin-left and margin-right values, because the auto margins interfere with the float option. For example, add the following code to use the navbox as a float:
** <code>bodystyle = width: 22em; float: right; margin-left: 1em; margin-right: 0;</code>
+
::<code>bodystyle = width: 22em; float: right; margin-left: 1em; margin-right: 0;</code>
  
=== Copying to other projects or wikis ===
+
=== Copying to other projects or wikis? ===
If you are trying to copy {{tlf|Navbox}} to your local wiki, there are several other things that must be installed or copied over as well:
+
More detailed information on copying {{tlf|Navbox}} to other wikis can be found on the [[Template talk:Navbox|talk page]].
* The [[mw:Extension:Scribunto|Scribunto]] and [[:mw:Extension:TemplateStyles|TemplateStyles]] extensions must be installed.
 
* [[Module:Navbox]] and its module and TemplateStyles dependencies, listed in the above two links
 
* Optionally, the <code>Add support to mw-collapsible for autocollapse, innercollapse and outercollapse</code> script from [[MediaWiki:Common.js]] may be copied, if autocollapsing is desired.
 
  
== TemplateData ==
+
=== Known issues ===
{{TemplateDataHeader}}
+
# If the heading of the navbox spans more than one line, the second line will be displayed to the right of center. This can be avoided by hard-coding linebreaks with {{tag|br|single|params=clear="all"}}.
<templatedata>
+
# In Internet Explorer 8 and 9, there is a bug when using <code>hlist</code>; navbox will fail to wrap the list to the next line if the list items start with an image, causing navbox to extend its width outside the screen. This can be fixed by adding <code>&amp;nbsp;</code> in front of the images.
{
+
# Excessive use of the '''unsubstituted''' {{tlx|•}} template as a delimiter, can in extreme cases cause the wiki page rendering to fail&nbsp;— there is a limit to the number of templates that can be used on a page (example [[Ketamine]] where the inclusion of eleven Navboxes with hundreds of bullets caused the page load not to complete, only the substitution of the bullets in those navboxes cured the problem). Use of the <code>hlist</code> class avoids the delimiter transclusion issue altogether, as the delimiters are rendered via CSS.
"params": {
 
"state": {
 
"label": "State",
 
"description": "Controls when a navbox is expanded or collapsed",
 
"example": "autocollapse",
 
"suggestedvalues": [
 
"autocollapse",
 
"collapsed",
 
"expanded",
 
"plain",
 
"off"
 
],
 
"default": "autocollapse",
 
"suggested": true
 
},
 
"title": {
 
"label": "Title",
 
"description": "Text in the title bar; centered in the top row of the table. Usually the template's topic.",
 
"example": "[[Widget stuff]]",
 
"suggested": true
 
},
 
"above": {
 
"label": "Above",
 
"description": "Full-width cell displayed between the titlebar and first group/list, i.e. above the template's body (groups, lists and image)",
 
"type": "string",
 
"suggested": true
 
},
 
"image": {
 
"label": "Image",
 
"description": "Image to be displayed in a cell below the title and to the right of the body",
 
"example": "[[File:XX.jpg | 80px | link= | alt= ]]",
 
"type": "wiki-file-name",
 
"suggested": true
 
},
 
"group1": {
 
"label": "Group 1",
 
"description": "If specified, text appears in a header cell displayed to the left of list 1. If omitted, list 1 uses the full width of the table.",
 
"suggested": true
 
},
 
"list1": {
 
"label": "List 1",
 
"description": "Body of the template; usually a list of links. Format is inline. 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.\nEntries should be separated using a newline and an asterisk. If two asterisks are used, it provides nesting within the previous entry with brackets.",
 
"required": true,
 
"suggested": true
 
},
 
"group2": {
 
"suggested": true
 
},
 
"list2": {
 
"suggested": true
 
},
 
"list3": {
 
"suggested": true
 
},
 
"group3": {
 
"suggested": true
 
},
 
"group4": {},
 
"list4": {},
 
"below": {
 
"label": "Below",
 
"description": "Full-width cell displayed below the template's body.",
 
"suggested": true
 
},
 
"imageleft": {
 
"label": "Image left",
 
"description": "Image to be displayed in a cell below the title and to the left of the body. For the image to display properly, list1 parameter must be specified and no groups can be specified.",
 
"example": "[[File:XX.jpg | 80px | link= | alt= ]]",
 
"type": "wiki-file-name"
 
},
 
"name": {
 
"label": "Name",
 
"description": "The name of the template. Needed for \"View • Talk • Edit\" links to work properly.",
 
"type": "string",
 
"default": "Navbox/doc",
 
"suggested": true
 
},
 
"listclass": {
 
"label": "List class",
 
"description": "CSS class for the list cells, usually hlist for horizontal lists. Alternatively, use bodyclass for the whole box.",
 
"example": "hlist",
 
"type": "string"
 
},
 
"navbar": {
 
"label": "Navbar status",
 
"example": "plain, off",
 
"type": "string"
 
},
 
"border": {
 
"label": "Border status",
 
"example": "child, subgroup, none",
 
"type": "string"
 
},
 
"bodystyle": {},
 
"basestyle": {},
 
"titlestyle": {},
 
"groupstyle": {},
 
"group1style": {},
 
"groupwidth": {},
 
"liststyle": {},
 
"list1style": {},
 
"listpadding": {},
 
"oddstyle": {},
 
"evenstyle": {},
 
"evenodd": {
 
"suggestedvalues": [
 
"swap",
 
"even",
 
"odd",
 
"off"
 
]
 
},
 
"abovestyle": {},
 
"belowstyle": {},
 
"imagestyle": {},
 
"imageleftstyle": {}
 
},
 
"description": "Creates a navigational box for links to other pages. \nDoes not display in mobile.",
 
"paramOrder": [
 
"name",
 
"title",
 
"group1",
 
"list1",
 
"listclass",
 
"state",
 
"above",
 
"below",
 
"image",
 
"group2",
 
"list2",
 
"group3",
 
"list3",
 
"group4",
 
"list4",
 
"imageleft",
 
"navbar",
 
"border",
 
"bodystyle",
 
"basestyle",
 
"titlestyle",
 
"groupstyle",
 
"liststyle",
 
"group1style",
 
"list1style",
 
"groupwidth",
 
"listpadding",
 
"oddstyle",
 
"evenstyle",
 
"evenodd",
 
"abovestyle",
 
"belowstyle",
 
"imagestyle",
 
"imageleftstyle"
 
]
 
}
 
</templatedata>
 
  
 
== See also ==
 
== See also ==
 
* {{tl|Navboxes}} — groups several navigation boxes together.
 
* {{tl|Navboxes}} — groups several navigation boxes together.
 +
* {{tl|Otherarticles}} — a small navbox based on an existing category
 +
* {{tl|Navbar}} — Used for the navigation links in navbox.
 
* {{tl|Nobold}} — To display text at normal font-weight within a context where the default font-weight is bold, e.g. header cells in tables.
 
* {{tl|Nobold}} — To display text at normal font-weight within a context where the default font-weight is bold, e.g. header cells in tables.
 
* {{tl|Sidebar}} — Vertically-aligned navigation templates.
 
* {{tl|Sidebar}} — Vertically-aligned navigation templates.
 
* [[Template:Navbox/testcases]] — For additional examples of template code.
 
* [[Template:Navbox/testcases]] — For additional examples of template code.
 
* [[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.
* [[Wikipedia:Template documentation]] — Guideline to creating the accompanying documentation
 
 
* {{tl|Nowrap begin}}, {{tl|·}} and {{tl|•}} are '''deprecated''' in favor of the <code>hlist</code> class for formatting lists. See [[Template:Flatlist#Technical details|Flatlist]] for a technical explanation of how <code>hlist</code> works.
 
* {{tl|Nowrap begin}}, {{tl|·}} and {{tl|•}} are '''deprecated''' in favor of the <code>hlist</code> class for formatting lists. See [[Template:Flatlist#Technical details|Flatlist]] for a technical explanation of how <code>hlist</code> works.
 
=== Tracking categories ===
 
* {{clc|Navbox orphans}}
 
* {{clc|Navigational boxes without horizontal lists}}
 
* {{clc|Navboxes using background colours}}
 
* {{clc|Potentially illegible navboxes}}
 
* {{clc|Navboxes using borders}}
 
  
 
{{Navigation templates}}
 
{{Navigation templates}}
  
<includeonly>{{sandbox other||
+
<includeonly>{{#ifeq:{{SUBPAGENAME}}|sandbox||
<!-- Add categories below this line, and interwikis at Wikidata -->
+
<!-- Categories go below this line, please; interwikis go to Wikidata, thank you! -->
 
[[Category:Navigational boxes| ]]
 
[[Category:Navigational boxes| ]]
 
[[Category:Templates generating microformats]]
 
[[Category:Templates generating microformats]]
[[Category:Templates that are not mobile friendly]]
 
 
[[Category:Wikipedia metatemplates]]
 
[[Category:Wikipedia metatemplates]]
[[Category:Collapse templates]]
+
[[Category:Exclude in print]]
 +
 
 
}}</includeonly>
 
}}</includeonly>

Please note that all contributions to Yugipedia are considered to be released under the Creative Commons Attribution-ShareAlike 4.0 International License (see Yugipedia:Licensing for more details). If you do not want your writing to be edited mercilessly and redistributed at will, then do not submit it here.
You are also promising us that you wrote this yourself, or copied it from a public domain or similar free resource. Do not submit copyrighted work without permission!

Cancel Editing help (opens in new window)
Preview page with this template
Below are some commonly used wiki markup codes. Simply click on what you want to use and it will appear in the edit box above.

View this template

Templates used on this page:

This page is a member of 1 hidden category: