Template:Navbox: Difference between revisions
m (1 revision imported) |
Tag: Rollback |
(4 intermediate revisions by 2 users not shown) | |
(No difference)
|
Latest revision as of 15:06, 14 November 2023
Template loop detected: Template:Documentation
Usage
This template can be used to make a standard navigation box. It is intended for use within another template that standardises the title and contents of the box (see Template:Rune equipment). This template should not be used directly within articles, as it creates a maintenance burden to do so whenever the contents of the box have to be updated.
The purpose of this template is to standardise the attributes of all navigation boxes, for example, their colours and other CSS attributes. The template is fairly simple, and could be extended to add other features in the future. Using this template allows changes to be implemented much quicker and easier than editing each template separately.
Syntax
{{Navbox |state = uncollapsed, collapsed, plain, autocollapse (default) |name = mandatory - name of the template |style = optional - style for the whole table |title = mandatory - navbox header |gtitleN = optional - title of N-th group of items |gNcatP = optional - categories to add to each item in the group |styleN = optional - style for groupN; i.e. text-align |groupN = mandatory - list of groups of items |fstyle = optional - style for footer ; i.e. text-align |footer = optional - navbox footer }}
- Groups: Currently there is no technical limit to the maximum number of groups.
- Groups of items can be added as parameters: group1, group2, group3, ... up to groupN.
- Group title: Each group has its own title parameter: gtitle1, gtitle2, gtitle3, ... up to gtitleN. Note that the default width for the first column is 15%.
- Group category: Each group can have a category parameter: g1cat1, g1cat2, g1cat3, ... up to g1catP. Each parameter can have multiple category names delimited by comma.
- Group style: Style may also be customised to each group in: style1, style2, style3, ... up to styleN.
- Note that neither the title nor the items have any wiki-links built into the template. As a result, users of the template are free to use wiki-links as they wish.
- Line breaks: Line-breaks (
<br>
) are unnecessary, as text wrapping is done automatically by the template. This also includes links and text in gtitleN and groupN. - Bullets: Create unordered lists with lines beginning with *. The use of Template:* is deprecated
States
- Autocollapse: By default, the state of a navbox is "autocollapsed". This means that if the number of navboxes in a page exceeds the maximum allocation of the collapsible navboxes, then the remaining navboxes are collapsed automatically. For more information (or to change the setting), see MediaWiki:Gadget-autocollapse.js.
- Currently, the autocollapse allocation is 2. This means that if there are 3 navboxes in a page, the third and subsequent navboxes will be collapsed automatically.
- Uncollapsed: Forces the navbox to be displayed.
- All of the navboxes in this documentation are in the uncollapsed state.
- Collapsed: The reverse of uncollapsed. Forces the navbox to be hidden instead.
- Navboxes with a height of more than 300 pixels will also be collapsed automatically. For more information (or to change the setting), see MediaWiki:Gadget-autocollapse.js.
- Plain: Removes the "show/hide" link.
Sub-groups
- For larger navboxes, it may be necessary to include sub-groups within a particular group of items. It is also possible to collapsible navboxes within the parent navbox, see Collapsible sub-groups.
- To create sub-groups within
{{Navbox}}
, certain parameters are to be included:- The parent navbox group (i.e. group2 in the example below) requires the type parameter (gtype2 = subgroup).
- The nested navbox (sub-group) requires the inclusion of the sub-group parameter (subgroup = yes). This enables the template to differentiate between the sub-group and the parent navbox.
{{Navbox |name = |title = |gtitle1 = |group1 = |gtitle2 = |gtype2 = subgroup (mandatory) |group2 = {{Navbox |subgroup = yes (mandatory) |gtitle1 = |group1 = |gtitle2 = |group2 = }} }}
Collapsible sub-groups
- For extremely long navboxes, it is recommended to use collapsible navboxes within the parent navbox. Further sub-groups can then be added to these collapsible navboxes.
- To create collapsible sub-groups within
{{Navbox}}
, these parameters need to be included:- The parent navbox is almost always uncollapsed (state=uncollapsed).
- The parent navbox group (i.e. group1 in the example below) requires the type parameter (gtype1 = subgroup).
- The nested collapsible navbox requires the inclusion of the collapsible parameter (collapsible = yes). This enables the template to differentiate between the collapsible navbox and the parent navbox.
- The nested collapsible navbox is forcefully collapsed (state=collapsed).
{{Navbox |state = uncollapsed |name = |gtype1 = subgroup |group1 = {{Navbox |collapsible = yes |state = collapsed |title = |gtitle1 = |group1 = |gtitle2 = |group2 = }} }}
Use of images
- The use of images in navboxes is permitted, but please resize the images to keep them small. Inventory-sized images (25-30 pixels) are recommended.
- Please use {{plink}} to create links with images. Use {{plinkp}} for any case where text is not desired after the link. It functions the same as {{plink}}, but it does not produce a wikilink in text. Use {{chatl}} to link chatheads. These templates create links for both the image and text (except for {{plinkp}}) using far less wikicode than the standard syntax. Use {{Emote link}} to link emote icons.
Link and file share the same name
{{plink|Item}}
File name differs from the link
{{plink|Item|pic=File}}
Link and file share the same name, but different text is desired to display
{{plink|Item|txt=Text}}
File name differs from the link and different text is desired to display
{{plink|Item|pic=File|txt=Text}}
Code | Standard syntax |
---|---|
{{plink|Abyssal whip}}
|
[[File:Abyssal whip.png|link=Abyssal whip]] [[Abyssal whip]]
|
{{plink|Granite maul|pic=Abyssal whip}}
|
[[File:Abyssal whip.png|link=Granite maul]] [[Granite maul]]
|
{{plink|Abyssal whip|txt=Whip}}
|
[[File:Abyssal whip.png|link=Abyssal whip]] [[Abyssal whip|Whip]]
|
{{plink|Granite maul|pic=Abyssal whip|txt=Whip}}
|
[[File:Abyssal whip.png|link=Granite maul]] [[Granite maul|Whip]]
|
{{plinkp|Abyssal whip}}
|
[[File:Abyssal whip.png|link=Abyssal whip]]
|
{{plinkp|Granite maul|pic=Abyssal whip}}
|
[[File:Abyssal whip.png|link=Granite maul]]
|
Categorising
Navboxes are very useful for transcluding categories onto a large number of pages that share both a trait and the navigation box. For example: Template:Rune equipment transcludes Category:Rune onto every page that uses it.
There are 3 methods of categorising pages with navboxes:
The first way is with {{Ctg}}. This is the preferred method, and can be used in most cases. The rules and operations for the Category handler template are very simple; however, they are enough to produce the desired results on most pages.
The second method is using the gNcatP parameter, where N is the number of the group and P is the number of the category. It takes a category name and adds that category to the items found within the group it's used on, including its subgroups. For example, |g1cat1=Rune|g1cat2=Daggers
would add Category:Rune and Category:Daggers to the pages found on group1
and its subgroups.
The third method is using {{Mainonly}} and providing more complex rules with parser functions. Template:Potions is an example of this:
{{mainonly|{{#ifeq:{{lc:{{#sub:{{PAGENAME}}|-3}}}}|mix|[[Category:Barbarian mixes]]}}}}
This code tells the template to add Category:Barbarian mixes to pages only if their title ends with the string "mix". {{ctg|Barbarian mixes::ifmatches[mix]}}
would not work here, because several pages include the substring "mix" in other locations, and they would be improperly categorised.
Categorisation should only be used on a template for large-scale addition. It is unhelpful, for example, to use a rule that only applies to 1 page.
Examples
|
{{Navbox |name = |title = |style1 = text-align:center |group1 = }}
| |
Centered footer |
{{Navbox |name = |title = |gtitle1 = |group1 = |footer = Centered footer }}
| |
Right-aligned footer |
{{Navbox |name = |title = |gtitle1 = |group1 = |fstyle = text-align:right |footer = Right-aligned footer }}
Group title 1 | Lorem ipsum dolor sit amet... |
Group title 2 | Consectetur adipisicing elit... |
Group title 3 | Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. |
{{Navbox |name = |title = |gtitle1 = Group title 1 |group1 = |gtitle2 = Group title 2 |group2 = |gtitle3 = Group title 3 |group3 = }}
Lorem? |
{{Navbox |state = collapsed |name = |title = |style1 = text-align:center |group1 = }}
[show]/[hide] links hidden (see Top-right corner). |
{{Navbox |state = plain |name = |title = |style1 = text-align:center |group1 = }}
[show]/[hide] links hidden (see Top-right corner). v • d • e links also hidden (see Top-left corner). This is done by removing the name parameter. |
{{Navbox |state = plain |title = |style1 = text-align:center |group1 = }}
Level 1 Title 1 | Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla eu sem eget nisi bibendum viverra a eget leo. Integer velit arcu, accumsan vel rhoncus eget, auctor a tellus. Nullam mollis turpis sollicitudin justo hendrerit ac volutpat nibh placerat. | ||||||||||||
Level 1 Title 2 | Curabitur posuere vestibulum dolor, quis faucibus justo tristique in. Nulla facilisi. Nunc iaculis erat nec ligula rutrum vel porta dolor posuere. Maecenas venenatis sapien id sapien pellentesque mollis. | ||||||||||||
Level 1 Title 3 | Sed ac sapien risus, in pharetra purus. | ||||||||||||
Level 1 Title 4 | Curabitur eu metus elit, a eleifend est. Aliquam vestibulum mollis metus, ut facilisis justo tincidunt non. Donec vel felis ut purus molestie facilisis consectetur a est. Nulla velit nisi, aliquet at condimentum non, varius ac nibh. Praesent fringilla nisi nibh. Morbi quis dapibus nulla. | ||||||||||||
Level 1 Title 5 |
| ||||||||||||
Level 1 Title 6 | Duis vel ligula tellus, sed rutrum augue. Cras varius consectetur ligula, vitae accumsan nisl vehicula vitae. Integer mi nunc, cursus sit amet mattis vitae, porta nec ligula. | ||||||||||||
Level 1 Title 7 | Etiam vulputate nisl eget sapien mattis ultrices. Vestibulum et eros vitae arcu condimentum porta. Cras fringilla, erat quis consequat sollicitudin, est tortor tempor massa, quis euismod risus nisi vel massa. Phasellus in risus ac metus pharetra sodales vel at velit. Nulla ullamcorper, orci ac ultrices sollicitudin, ante erat scelerisque eros, auctor pretium felis nibh bibendum purus. | ||||||||||||
Quisque ut nisl arcu. Integer tincidunt, turpis pharetra consectetur consectetur, felis ipsum sagittis turpis, vel interdum eros mauris sed odio. Aenean scelerisque rhoncus leo, a cursus neque vehicula sed. |
{{Navbox |state = uncollapsed |name = |title = |gtitle1 = Level 1 Title 1 |group1 = |gtitle2 = Level 1 Title 2 |group2 = |gtitle3 = Level 1 Title 3 |group3 = |gtitle4 = Level 1 Title 4 |group4 = |gtitle5 = Level 1 Title 5 |gtype5 = subgroup |group5 = {{Navbox |subgroup = yes |gtitle1 = Level 2 Title 1 |group1 = |gtitle2 = Level 2 Title 2 |group2 = |gtitle3 = Level 2 Title 3 |gtype3 = subgroup |group3 = {{Navbox |subgroup = yes |gtitle1 = Level 3 Title 1 |group1 = |gtitle2 = Level 3 Title 2 |group2 = }} |gtitle4 = Level 2 Title 4 |group4 = }} |gtitle6 = Level 1 Title 6 |group6 = |gtitle7 = Level 1 Title 7 |group7 = |fstyle = |footer = }}
Preventing unwanted documentation
The Navbox template's documentation is automatically transcluded under the navbox on any Template namespace page. It is not transcluded when used as a sub-group or collapsible sub-group template (subgroup= yes or collapsible=yes).
Should the documentation appear when it is unwanted, it can be hidden by setting the doc parameter doc=no on the template. In most cases, the doc parameter is not used and the parameter is removed completely.
On a similar note, the automatically-added category Category:Navigational templates can be suppressed by adding hidecat=yes.