Template:Country showdata: Difference between revisions
| Richardpruen (talk | contribs) m 1 revision imported | imported>Paine Ellsworth  include hatnote parameter | ||
| (2 intermediate revisions by 2 users not shown) | |||
| Line 1: | Line 1: | ||
| <includeonly>__NOEDITSECTION__ | <includeonly>__NOEDITSECTION__ | ||
| {{documentation|content=<code>Template:{{{demopagename|{{PAGENAME}}}}}</code> is an internal data container not intended to be transcluded directly. It is used indirectly by templates such as <code>[[Template:flag|flag]]</code>, <code>[[Template:flagicon|flagicon]]</code>, and others. | {{documentation|content= | ||
| {{#if:{{{hatnote|}}}|{{{hatnote}}}}} | |||
| {{#ifeq:{{#invoke:High-use|num|x|demo={{ROOTPAGENAME}}}}|many||{{High-use|demo={{ROOTPAGENAME}}}}}} | |||
| {{notice|image=Exclamationdiamond.svg|<code>Template:{{{demopagename|{{PAGENAME}}}}}</code> is an internal data container not intended to be transcluded directly. It is used indirectly by templates such as <code>[[Template:flag|flag]]</code>, <code>[[Template:flagicon|flagicon]]</code>, and others.}} | |||
| {{ombox|text=This template is within the scope of '''[[Wikipedia:WikiProject Flag Template|WikiProject Flag Template]]''', a collaborative effort to maintain flag templates on Wikipedia.  A more thorough discussion of the flag template system, including parameters not described here, can be found on the project page.}} | {{ombox|text=This template is within the scope of '''[[Wikipedia:WikiProject Flag Template|WikiProject Flag Template]]''', a collaborative effort to maintain flag templates on Wikipedia.  A more thorough discussion of the flag template system, including parameters not described here, can be found on the project page.}} | ||
| Line 120: | Line 123: | ||
| ===Military ensigns=== | ===Military ensigns=== | ||
| {{#if: {{{flag alias-naval|}}} | | {{#if: {{{flag alias-naval|}}} | | ||
| This template includes a naval  | This template includes a naval flag variant that can be used with [[Template:Naval]]: | ||
| * <code><nowiki>{{ | * <code><nowiki>{{naval|</nowiki>{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}<nowiki>}}</nowiki></code> → {{naval|{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}|naval}} | ||
| * <code><nowiki>{{flagicon|</nowiki>{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}<nowiki>|naval}}</nowiki></code> → {{flagicon|{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}|naval}} | * <code><nowiki>{{flagicon|</nowiki>{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}<nowiki>|naval}}</nowiki></code> → {{flagicon|{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}|naval}} | ||
| | {{#if: {{{link alias-naval|}}} | | | {{#if: {{{link alias-naval|}}} | | ||
| This nation's naval  | This nation's naval flag is the same as its national flag, so [[Template:Naval]] produces the following: | ||
| * <code><nowiki>{{ | * <code><nowiki>{{naval|</nowiki>{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}<nowiki>}}</nowiki></code> → {{naval|{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}}} | ||
| }}}}<!-- | }}}}<!-- | ||
| -->{{#if: {{{flag alias-air force|}}} |{{break}} | -->{{#if: {{{flag alias-air force|}}} |{{break}} | ||
| Line 160: | Line 163: | ||
| }}}}<!-- | }}}}<!-- | ||
| -->{{#if: {{{flag alias-navy|}}} |{{break}} | -->{{#if: {{{flag alias-navy|}}} |{{break}} | ||
| This template includes  | This template includes an ensign flag variant that can be used with [[Template:Navy]]: | ||
| * <code><nowiki>{{ | * <code><nowiki>{{navy|</nowiki>{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}<nowiki>}}</nowiki></code> → {{navy|{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}|navy}} | ||
| * <code><nowiki>{{flagicon|</nowiki>{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}<nowiki>|navy}}</nowiki></code> → {{flagicon|{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}|navy}} | * <code><nowiki>{{flagicon|</nowiki>{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}<nowiki>|navy}}</nowiki></code> → {{flagicon|{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}|navy}} | ||
| | {{#if: {{{link alias-navy|}}} |{{break}} | | {{#if: {{{link alias-navy|}}} |{{break}} | ||
| This nation's navy flag is the same as its national flag, so [[Template: | This nation's navy flag is the same as its national flag, so [[Template:Navy]] produces the following: | ||
| * <code><nowiki>{{ | * <code><nowiki>{{navy|</nowiki>{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}<nowiki>}}</nowiki></code> → {{navy|{{#invoke:String|replace|{{{demopagename|{{PAGENAME}}}}}|^%w+ data |||false}}}} | ||
| }}}}<!-- | }}}}<!-- | ||
| -->{{#if: {{{flag alias-coast guard|}}} |{{break}} | -->{{#if: {{{flag alias-coast guard|}}} |{{break}} | ||
Latest revision as of 16:13, 23 November 2022
| This template is used on approximately 6,400 pages and changes may be widely noticed. Test changes in the template's /sandbox or /testcases subpages, or in your own user subpage. Consider discussing changes on the talk page before implementing them. | 
| This template uses Lua: | 
This template is used for documenting country data meta-templates used by the flag template system. The output of this template can be seen by directly viewing any of the templates in Category:Country data templates.
See Wikipedia:WikiProject Flag Template for the main documentation and discussion page for the flag template system.
Usage
This template is automatically invoked by the standard syntax of a country data template:
{{ {{{1<noinclude>|country showdata</noinclude>}}}
| alias = Countryname
| shortname alias = Shortcountryname  <!-- only necessary if Shortcountryname ≠ Countryname, otherwise omit -->
| flag alias = Flag of Countryname.svg
| size = {{{size|}}}
| name = {{{name|}}}
| variant = {{{variant|}}}  <!-- only necessary if there is one or more flag alias-variant parameters, otherwise omit -->
}}
The first parameter to a country data template is usually the name of a formatting meta-template. For example, Template:Flag uses Template:Flag/core to actually render the flag icon and wikilink. If the first parameter is missing, which is the case when a country data template is viewed directly, the template code fragment {{{1<noinclude>|country showdata</noinclude>}}} ensures that this template will be used as the default first parameter. This technique ensures that country data templates are "self-documenting" if they use the standard syntax.
Additional parameters
Many country data templates require additional documentation beyond the standard mandatory alias and flag alias parameters. This template will automatically document standard optional parameters (such as shortname alias) if present, and can document unique optional parameters (such as flag variants) if instructed to. This latter method uses documentation-specific parameters in the country data template to activate the additional output from this template. These documentation parameters are set off from the rest of the parameters in the country data template by a <noinclude> section:
<noinclude> | var1 = ... | redir1 = ... | related1 = ... </noinclude>
Hatnote
If a brief hatnote is needed, then it can be added to the top of the documentation page by including the |hatnote= parameter with any of the existing hatnote templates. Example:
- |hatnote={{Hatnote|This template contains data that applies to the [[Republic of Ireland|sovereign state]]. For the [[Ireland|entire island]], see [[Template:Country data Ireland]].}}
results in:
Flag variants
Flag variants are added to a country data template by the inclusion of one or more flag alias-label parameters, where each label is a unique identifier that is subsequently used as an input parameter to {{flag|...}}, {{flagicon|...}}, etc. To document these flag variants, use the varN documentation parameters to identify each label.
For example, Template:Country data Seychelles identifies three flag variants (in addition to the current flag) with the following code:
| flag alias-1976 = Flag of the Seychelles 1976.svg | flag alias-1977 = Flag of the Seychelles 1977.svg | flag alias-colonial = Government Ensign of the United Kingdom.svg
These three variants are documented by the following code segment later in the template:
<noinclude> | var1 = 1976 | var2 = 1977 | var3 = colonial ... </noinclude>
Up to forty flag variants can be documented by this method (using var1 to var40).  If more are present, these can be listed on a separate documentation subpage as described below.
Note that you do not have to use a varN parameter for the standard optional variant labels naval, air force and army (used for the country's naval, air force and army ensigns, respectively). If present, they will automatically be documented.
Redirect aliases
Many country data templates have alias names that can be used instead of the usual country name with all of the main flag templates. These are usually, but not exclusively, standard country code abbreviations such as those specified in ISO 3166-1 alpha-3 or by the IOC or FIFA. These are implemented as redirects, and are listed in Category:Country data redirects.
For example, Template:Country data DEU and Template:Country data GER both redirect to Template:Country data Germany, because DEU is the ISO code and GER is the IOC and FIFA code for Germany. Therefore, {{flagicon|DEU}}, {{flagicon|GER}}, and {{flagicon|Germany}} all have the same result. These redirect aliases are documented by the following template code fragment:
<noinclude> ... | redir1 = DEU | redir2 = GER ... </noinclude>
Up to five flag redirects can be documented by this method (using redir1 to redir5).
Related templates
Several country data templates are used for alternative forms to the common country data template for the nation, usually but not exclusively for historic nations. Pointers to these alternative templates are useful additions to the template documentation so that editors can use the correct template for their specific purposes.
For example, Template:Country data Serbia and Montenegro includes the following code to document three other related country data templates:
<noinclude> ... | related1 = Serbia | related2 = Montenegro | related3 = FR Yugoslavia ... </noinclude>
Up to six related flags can be documented by this method (using related1 to related6).
Flag article link
This template shows a large flag image on the right of the documentation box, with a link to an article about the flag in the caption if it exists. The page that it evaluates is "Flag of {{{alias}}}", with the value of |alias= in the template code replacing {{{alias}}}. If there is an article about the flag even though "Flag of {{{alias}}}" does not exist, either create the latter as a redirect to the correct page or add the following parameter:
<noinclude> ... | flag link = ''Article name'' ... </noinclude>
This can also be used to override the automatic link if "Flag of {{{alias}}}" does exist but leads to the wrong article.
Additional documentation
For situations where the automatic documentation method is not completely adequate, additional documentation can be displayed by country showdata. Simply create a documentation subpage (named as Template:Country data Countryname/doc) with the additional material, and it will be transcluded to a section called "Other information" at or near the end of the automatic documentation. This "extra" documentation page can usually be edited even if the country data template is edit-protected.
For example:
- Template:Country data Ireland/doc is used to explain why that template is distinct from Template:Country data Republic of Ireland
- Template:Country data France/doc is used to document the list of country data templates available for each of the regions of France
- Template:Country data United States/doc is used to document the full set of flag variants (for each number of stars), and to list all of the country data templates available for state and territory flags
- Template:Country data Empire of Japan/doc sorts its template into individualized categories.
Categorization
This template automatically categorizes pages it is transcluded on in Category:All country data templates and in the tracking categories in Category:Country data tracking categories. Content categories, such as those by country or by type/status, should be added manually by putting them inside <includeonly>...</includeonly> tags on a template's documentation subpage. If a template does not have a documentation page yet, click on the "/doc" link at the bottom of the automatic documentation, add categories between the preloaded <includeonly> tags and save the page.
The default sort key used for the automatic categories is the part after Template:Country data in the page title. The parameter |cat= can be used to specify a custom ASCII sorting key for these categories. For example, Template:Country data Åland Islands and Template:Country data Republic of Ireland use this parameter to sort them under "A" and "I" respectively.
Automatically added by this template:
- Category:All country data templates (912)
- Category:Country data template sandboxes (0)
- Category:Country data templates with distinct default size (13)
- Category:Country data templates with distinct shortname (277)
- Category:Country data templates with distinct template name (56)
- Category:Country data templates with documentation subpage (387)
- Category:Country data templates without flag alias (1)
- Category:Uncategorized country data templates (525)
Manually added to templates or documentation pages:
- Category:Country data templates of countries (100)
- Category:Subnational country data templates (0)
- Category:Country data templates of cities (1)
- Category:Country data templates of continents (0)
- Category:Country data templates of dependent territories (0)
- Category:Country data templates of geographical regions (2)
- Category:Country data templates of governments (1)
- Category:Country data templates of historical entities (3)
- Category:Country data templates of international organizations (2)
- Category:Country data templates of micronations (0)