Difference between revisions of "Template:Honor index"

From Pathfinder Wiki
 
(143 intermediate revisions by 4 users not shown)
Line 1: Line 1:
<!--- ¦ --->
+
<!--- ¦ ---><includeonly>
 
+
<!-- assemble the tablerow argument of DPL so it is customizeable -->
{{#dpl
+
<!-- initialize the variables -->
|format=,\n[[%PAGE%]],,
+
{{#vardefine:selectedcolumns|{{{columnselection|:honorname:insignia:category:authority:skill:year}}}}}
|include={Honor desc{{{1|}}}}: category:authority:skill:     year:stage
+
{{#vardefine:tablerow|}}{{#vardefine:tableheader|}}{{#vardefine:i|1}}{{#while: <!-- we need to start at word 1 because of the leading : -->|{{#if:{{#explode:{{#var:selectedcolumns}}|:|{{#var:i}}}}|true}}|{{#vardefine:tablerow|{{#var: tablerow}}{{#switch:{{#explode:{{#var: selectedcolumns }}|:|{{#var:i}}}}|honorname=data-sort-value=²{GetHonorName¦page=%PAGE%}²¦[[%PAGE%¦²{GetHonorName¦page=%PAGE%}²]],|insignia=²{GetInsigniaThumb¦insignia=%%¦usePilotNoPatch={{{usePilotNoPatch¦}}}}²,|category=align="left"¦²{Localize¦%%}²,|authority=align="center"¦²{division honor¦²{division abbrev¦%%}²}²,|skill=align="center"¦²{YearOrUnknown¦%%}²,|year=align="center"¦²{YearOrUnknown¦%%}²,}}}}
|table  =class=sortable,Honor,Category,Approval, Skill Level,Year,Stage
+
{{#vardefine: tableheader|{{#var:tableheader}}{{#switch:{{#explode:{{#var:selectedcolumns}}|:|{{#var:i}}}}|honorname=,{{Localize|Honor}}|insignia=,{{Localize|Patch}}|category=,{{Localize|Category}}|authority=,{{Localize|Approval}}|skill=,{{Localize|Skill Level}}|year=,{{Localize|Year}}}}}}{{#vardefine:i|{{#expr:{{#var:i}}+1}}}}}}<nowiki />
|category=Adventist Youth Honors Answer Book/Primary
+
<!-- that loops through all arguments with the prefix cat and saves it into a variable -->
|category=Adventist Youth Honors Answer Book/Honor Desc{{{1|}}}
+
{{#vardefine:argIncCat|AY Honors/HonorLanding{{GetLangSuffix}}&AY Honors/Primary}}{{#forargs: cat | key | category |<nowiki />{{#vardefine:argIncCat|{{#var:argIncCat}}{{#if:{{#var:category}}|&{{#var:category}}{{GetLangSuffix}} }} }} }}
|order=ascending
+
{{#dpl:
|namespace=0
+
|debug={{{debug|0}}}
|suppresserrors = true
+
|include={HonorLanding}{{#var:selectedcolumns}}
 +
|table=class="wikitable sortable",-{{#var:tableheader}}
 +
|tablerow={{#var:tablerow}}
 +
|category={{#var:argIncCat}}
 +
|notcategory={{#if:{{{excat1|}}}|{{{excat1}}}{{GetLangSuffix}}}}
 +
|notcategory={{#if:{{{excat2|}}}|{{{excat2}}}{{GetLangSuffix}}}}
 +
|notcategory={{#if:{{{excat3|}}}|{{{excat3}}}{{GetLangSuffix}}}}
 +
|notcategory={{#if:{{{excat4|}}}|{{{excat4}}}{{GetLangSuffix}}}}
 +
|notcategory={{#if:{{{excat5|}}}|{{{excat5}}}{{GetLangSuffix}}}}
 +
|notcategory={{#if:{{{showPiloting|}}}||AY Honors/Piloting{{GetLangSuffix}}}}
 +
|nottitleregexp=.*/en$
 +
|ordermethod=sortkey
 +
|namespace=
 
}}
 
}}
 +
{{#if:{{{debug|}}}|
 +
*argIncCat = {{#var:argIncCat}}
 +
*key = {{#var:key}}
 +
*category = {{#var:category}}
 +
*tablerow = {{#var:tablerow}}
 +
*tableheader = {{#var:tableheader}}
 +
*selectedcolumns = {{#var:selectedcolumns}}
 +
}}
 +
</includeonly>
 +
<noinclude><nowiki />{{Honor index
 +
|cat1=AY Honors/Arts, Crafts and Hobbies
 +
|cat2=AY Honors/Skill Level 1
 +
|excat1=AY Honors/Approved by General Conference
 +
|excat2=AY Honors/Approved by North American Division
 +
|columnselection=:honorname:insignia:authority:skill:year
 +
}}<nowiki />{{Honor index
 +
|cat1=AY Honors/Arts, Crafts and Hobbies
 +
|cat2=AY Honors/Skill Level 1
 +
|excat1=AY Honors/Approved by General Conference
 +
|excat2=AY Honors/Approved by North American Division
 +
}}
 +
<templatedata>
 +
{
 +
"params": {
 +
"columnselection": {
 +
"label": "Shown columns (and order)",
 +
"description": "This defines the shown columns and the order of those. Each column needs to be separated by a \":\" and it needs to be started with a \":\". Possible columns are: honorname, insignia, category, authority, skill, year",
 +
"example": ":honorname:insignia:category:authority:skill:year",
 +
"default": ":honorname:insignia:category:authority:skill:year",
 +
"autovalue": ":honorname:insignia:category:authority:skill:year"
 +
},
 +
"excat1": {
 +
"label": "First excluded Category",
 +
"description": "The honor isn't allowed to be in that category.",
 +
"example": "AY Honors/Approved by General Conference",
 +
"autovalue": ""
 +
},
 +
"excat2": {
 +
"label": "Second excluded Category",
 +
"description": "The honor isn't allowed to be in that category.",
 +
"example": "AY Honors/Approved by General Conference"
 +
},
 +
"excat3": {
 +
"label": "Third excluded Category",
 +
"description": "The honor isn't allowed to be in that category.",
 +
"example": "AY Honors/Approved by General Conference"
 +
},
 +
"excat4": {
 +
"label": "Fourth excluded Category",
 +
"description": "The honor isn't allowed to be in that category.",
 +
"example": "AY Honors/Approved by General Conference"
 +
},
 +
"excat5": {
 +
"label": "Fifth excluded Category",
 +
"description": "The honor isn't allowed to be in that category.",
 +
"example": "AY Honors/Approved by General Conference"
 +
},
 +
"catn": {
 +
"label": "Included Category",
 +
"description": "This category needs to be included. The n needs to be replaced with an upcounting number, that way it is possible to add multiple categories. An honor included in the list needs to have every added category. For example add those arguments: cat1=mycategory1|cat2=mycategory2 and so on.",
 +
"example": "AY Honors/Skill Level 1"
 +
}
 +
},
 +
"description": "This template creates a table view, containing the honors in this wiki. The columns shown can be modified also it can be defined which categories should be included and which excluded.\n\nIt is very complex so I try to explain what is going on. First in the template we create the needed variables for defining the table (text's of the header, wanted columns, row template). \nAfter we did that magic, we have the magic that enables the template to have a dynamic count of needed (included) categories.\n\nThat is the whole preparation. Now we only let DPL do it's magic and a nice table will be created... hopefully ;) ",
 +
"paramOrder": [
 +
"columnselection",
 +
"excat1",
 +
"excat2",
 +
"excat3",
 +
"excat4",
 +
"excat5",
 +
"catn"
 +
]
 +
}
 +
</templatedata>[[Category:UsesLoops]]</noinclude>

Latest revision as of 17:51, 1 April 2022

Honor Patch Approval Skill Level Year
Fabric Yo-Yo
Fuxico AY Honor.png
SAD tiny.png 1 2012
Music - Beginners
Music Honor AY Honor.png
SPD tiny.png 1 Unknown
Papercraft
Papercraft AY Honor.png
SAD tiny.png 1 2012


Honor Patch Category Approval Skill Level Year
Fabric Yo-Yo
Fuxico AY Honor.png
Arts, Crafts and Hobbies SAD tiny.png 1 2012
Music - Beginners
Music Honor AY Honor.png
Arts, Crafts and Hobbies SPD tiny.png 1 Unknown
Papercraft
Papercraft AY Honor.png
Arts, Crafts and Hobbies SAD tiny.png 1 2012


This template creates a table view, containing the honors in this wiki. The columns shown can be modified also it can be defined which categories should be included and which excluded.

It is very complex so I try to explain what is going on. First in the template we create the needed variables for defining the table (text's of the header, wanted columns, row template). After we did that magic, we have the magic that enables the template to have a dynamic count of needed (included) categories.

That is the whole preparation. Now we only let DPL do it's magic and a nice table will be created... hopefully ;)

Template parameters

ParameterDescriptionTypeStatus
Shown columns (and order)columnselection

This defines the shown columns and the order of those. Each column needs to be separated by a ":" and it needs to be started with a ":". Possible columns are: honorname, insignia, category, authority, skill, year

Default
:honorname:insignia:category:authority:skill:year
Example
:honorname:insignia:category:authority:skill:year
Auto value
:honorname:insignia:category:authority:skill:year
Unknownoptional
First excluded Categoryexcat1

The honor isn't allowed to be in that category.

Example
AY Honors/Approved by General Conference
Auto value
Unknownoptional
Second excluded Categoryexcat2

The honor isn't allowed to be in that category.

Example
AY Honors/Approved by General Conference
Unknownoptional
Third excluded Categoryexcat3

The honor isn't allowed to be in that category.

Example
AY Honors/Approved by General Conference
Unknownoptional
Fourth excluded Categoryexcat4

The honor isn't allowed to be in that category.

Example
AY Honors/Approved by General Conference
Unknownoptional
Fifth excluded Categoryexcat5

The honor isn't allowed to be in that category.

Example
AY Honors/Approved by General Conference
Unknownoptional
Included Categorycatn

This category needs to be included. The n needs to be replaced with an upcounting number, that way it is possible to add multiple categories. An honor included in the list needs to have every added category. For example add those arguments: cat1=mycategory1|cat2=mycategory2 and so on.

Example
AY Honors/Skill Level 1
Unknownoptional