Difference between revisions of "Template:Lead"

From Species-ID
Jump to: navigation, search
m (inline display as <div> for occurrence, remarks, description including last line break, <span> HTML containing complex stuff gets broken)
 
(24 intermediate revisions by 4 users not shown)
Line 1: Line 1:
<noinclude>Version 2.0: Creating a shell for [[Template:Lead/Inner]], passing calculated fields like the parsed lead-ID to be used multiple times.
+
<noinclude>{{Documentation}}
 
+
{{Documentation}}
+
 
+
 
[[Category:Single-access key templates]]
 
[[Category:Single-access key templates]]
 +
</noinclude><includeonly><!--
 +
// First parse leadID, see http://offene-naturfuehrer.de/web/Vorlage:Lead/SplitNumberV2 for development notices:
 +
-->{{
 +
#vardefine: leadIDParenthesisPos|{{#pos:{{{1}}}|(}}}}{{
 +
#vardefine: leadIDMain|{{#replace:{{#replace:{{#replace:{{{1|Couplet_ID_missing!}}}|-|–}}|'|’}}|*|&#42;}}}}{{
 +
#vardefine: backlink|}}{{
 +
#if: {{#var: leadIDParenthesisPos}}|{{
 +
  #vardefine: backlink|{{#if:alwaystrue-to-trim|{{#replace:{{#sub:{{#var: leadIDMain}}|{{#expr:{{#var: leadIDParenthesisPos}}+1 }}<!--end sub/repl/trim/vardef:-->}}|)|}} }}}}{{
 +
  #vardefine: leadIDMain|{{#if:alwaystrue-to-trim|{{#sub:{{#var: leadIDMain}} | 0 |{{#var: leadIDParenthesisPos}} }} }}}}
 +
}}<!-- // end if leadIDParenthesisPos.
  
</noinclude><includeonly>{{Lead/Inner|  
+
// Now split the leadIDMain into coupletID and withinCoupletID (=alternativeID). First determine splitting position:
keyID      ={{#var:SingleAccessKeyID}}|
+
-->{{#vardefine: leadIDSplitPos|{{#pos:{{#var: leadIDMain}}|&#42;}}}}{{#if: {{#var: leadIDSplitPos}}|<!--nothing,
leadID    ={{Lead/SplitNumber|{{{1|99999}}}|0|noformatting=1}}|
+
else:-->|{{#vardefine: leadIDSplitPos|{{#pos:{{#var: leadIDMain}}|–}}}}{{#if: {{#var: leadIDSplitPos}}|<!--nothing,
displayID  ={{Lead/SplitNumber|{{{1|Number missing!}}}|0}}|
+
else:-->|{{#vardefine: leadIDSplitPos|{{#pos:{{#var: leadIDMain}}|’}}}}{{#if: {{#var: leadIDSplitPos}}|<!--nothing,
leadpart2 ={{Lead/SplitNumber|{{{1}}}|1}}|
+
else:-->|{{#vardefine: leadIDSplitPos|{{#pos:{{#var: leadIDMain}}|<nowiki> </nowiki>}}}}{{#if: {{#var: leadIDSplitPos}}|<!--nothing,
statement  ={{{2|'''Lead statement missing!'''}}}|
+
else:-->|{{#vardefine: leadIDSplitPos|{{#len:{{#if: true|{{#var: leadIDMain}}}}}}}}}}<!--
nextlead  ={{{3|}}}|
+
close 3x if: -->}}}}}}<!--
commonnames={{{commonnames|}}}|
+
// Now use leadIDSplitPos to split part 1 and part 2:
result     ={{{result|}}}|
+
-->{{#vardefine: coupletID| {{#sub:{{#var: leadIDMain}}| 0 |{{#var: leadIDSplitPos}}<!--end sub+vardef:-->}}}}{{
errors    =<!--ERROR REPORTING: Any content in 4th and later unnamed parameters is an error.-->{{#if: {{{4|}}}{{{commonname|}}}{{{image|}}}{{{images|}}}<!--
+
    #vardefine: withinCoupletID| {{#sub:{{#var: leadIDMain}}|{{#var: leadIDSplitPos}}}}}}{{Lead/Inner
THEN:-->|Error: You may have an erroneous 4th unnamed parameter (vertical bar without a field name), or you may use "commonname/image/images" instead of "commonnames/image 1a" etc. The content is: {{{4|}}} {{{5|}}} {{{commonname|}}} {{{image|}}} {{{images|}}}. To add images or descriptions use <code><nowiki>|description=Your text|</nowiki></code> ''and'' <code><nowiki>|image 1a=Image:YourImage.jpg |caption 1a=Your Caption</nowiki></code>.<!--END ERROR REPORTING.-->}}|
+
| subheading = {{{subheading|}}}
synonyms   ={{{synonyms|}}}|
+
| subheadingstyle = {{{subheadingstyle|}}}
description={{{description|}}}|
+
| IDprefix  =L{{#var:decisiontreeID}}_{{#replace:{{#replace:{{#replace:{{{parentlead|}}}|-|–}}|'|’}}|*|&#42;}}
occurrence ={{{occurrence|}}}|
+
| leadIDbacklink ={{#var: backlink}}
remarks   ={{{remarks|}}}|
+
| coupletID      ={{#var: coupletID}}
images 1 width  ={{{images 1 width|100}}}|
+
| withinCoupletID ={{#var: withinCoupletID}}
images 1 height ={{{images 1 height|100}}}|
+
| parentlead ={{{parentlead|}}}
images 1 resize ={{{images 1 resize|1}}}|
+
| nested    ={{#if:alwaystrue-to-trim|{{{nested|}}}}}
image 1a       ={{{image 1a|}}}|
+
| statement  ={{{2|'''Lead statement missing!'''}}}
caption 1a     ={{{caption 1a|}}}|
+
| next      ={{#if:alwaystrue-to-trim|{{{3|}}}}}
image 1a width  ={{{image 1a width|}}}|
+
| commonnames={{#replace: {{{commonnames|}}}{{{common names|}}}|;|,}}
image 1a height ={{{image 1a height|}}}|
+
| scientificname={{{scientific name|}}}
image 1b       ={{{image 1b|}}}|
+
| synonyms  ={{{synonyms|}}}
caption 1b     ={{{caption 1b|}}}|
+
| resultqualifier ={{{result qualifier|}}}{{{resultqualifier|}}}<!-- always possible, e.g. "male", "L.", “2 species“ -->
image 1b width  ={{{image 1b width|}}}|
+
| resulttextoverride ={{{result text|}}}{{{resulttext|}}}
image 1b height ={{{image 1b height|}}}|
+
| resulttext ={{#if: {{{result text|}}}{{{resulttext|}}}<!--
image 1c       ={{{image 1c|}}}|
+
// then-->|{{{result text|}}}{{{resulttext|}}}<!--
caption 1c     ={{{caption 1c|}}}|
+
// else-->|{{#if: {{{scientific name|}}} |{{{scientific name|}}}|{{{result|}}}}}
image 1c width  ={{{image 1c width|}}}|
+
}}
image 1c height ={{{image 1c height|}}}|
+
| resultlink ={{StripFormatting|1={{#if: {{{result|}}} |{{{result|}}}|{{{scientific name|}}}}} }}
image 1d       ={{{image 1d|}}}|
+
| errors    =<!--ERROR REPORTING: Content in 4th and ff unnamed parameters is error.-->{{
caption 1d     ={{{caption 1d|}}}|
+
#if: {{{4|}}}{{{5|}}}{{{commonname|}}}{{{common name|}}}{{{image|}}}{{{images|}}}{{{synonym|}}}{{{remark|}}}{{{results|}}}<!--
image 1d width  ={{{image 1d width|}}}
+
THEN:-->|[[Category:Internal - Error in Lead template]]Error: You may have an erroneous 4th unnamed parameter (vertical bar without a field name), or you may use "commonname/common name/remark/results/synonym/image/images" instead of "common names/remarks/result/synonyms/image a" etc. The content is: '''{{{4|}}} {{{5|}}} {{{commonname|}}} {{{common name|}}} {{{synonym|}}} {{{remark|}}} {{{results|}}} {{{image|}}} {{{images|}}}'''. To add descriptions use <code><nowiki>|description=Your text|</nowiki></code>; to add one or several synonyms use <code><nowiki>|synonmys=Synonym 1; Synonym 2|</nowiki></code>; to add images use <code><nowiki>|image 1a=Image:YourImage.jpg |caption 1a=Your Caption</nowiki></code> (images a to e are in the sidebar, j following below lead text, with j/k always visible and, images m to r in the "more"-information area below the lead).<!--
image 1d height ={{{image 1d height|}}}|
+
END ERROR REPORTING.
gallerytype  ={{{gallerytype|wrap}}}|
+
START DETAIL TEXT:-->}}
imagesfooter ={{{imagesfooter|}}}|
+
| detailtext ={{
captionlines ={{{captionlines|2}}}|
+
#if: {{{synonyms|}}} |<span class="synonyms">(= {{{synonyms}}})</span><br />
images 2 width  ={{{images 2 width|180}}}|
+
}}{{
images 2 height ={{{images 2 height|180}}}|
+
#if: {{{description|}}} |<div class="description" style="display:inline">{{{description}}}
images 2 resize ={{{images 2 resize|1}}}|
+
</div>
image 2a       ={{{image 2a|}}}|
+
}}{{
caption 2a     ={{{caption 2a|}}}|
+
#if: {{{occurrence|}}} |<div class="occurrence" style="display:inline">{{{occurrence}}}
image 2a width  ={{{image 2a width|}}}|
+
</div>
image 2a height ={{{image 2a height|}}}|
+
}}{{
image 2b       ={{{image 2b|}}}|
+
#if: {{{remarks|}}} |<div class="remarks" style="display:inline">{{{remarks}}}
caption 2b     ={{{caption 2b|}}}|
+
</div>
image 2b width  ={{{image 2b width|}}}|
+
}}<!--END DETAIL TEXT. Next short version: detailtext or image m following present:-->
image 2b height ={{{image 2b height|}}}|
+
| detailspresent ={{#sub:{{{synonyms|}}}{{{description|}}}{{{occurrence|}}}{{{remarks|}}}{{{image m|}}}|0|1}}
image 2c       ={{{image 2c|}}}|
+
| primary images width  ={{{primary images width|100}}}
caption 2c     ={{{caption 2c|}}}|
+
| primary images height ={{{primary images height|100}}}
image 2c width  ={{{image 2c width|}}}|
+
| image a        ={{{image a|}}}
image 2c height ={{{image 2c height|}}}|
+
| label a       ={{{label a|}}}
image 2d       ={{{image 2d|}}}|
+
| caption a     ={{{caption a|}}}
caption 2d     ={{{caption 2d|}}}|
+
| image a width  ={{{image a width|{{{primary images width|100}}}}}}
image 2d width  ={{{image 2d width|}}}|
+
| image a height ={{{image a height|{{{primary images height|100}}}}}}
image 2d height ={{{image 2d height|}}}|
+
| image b       ={{{image b|}}}
image 2e       ={{{image 2e|}}}|
+
| label b        ={{{label b|}}}
caption 2e     ={{{caption 2e|}}}|
+
| caption b     ={{{caption b|}}}
image 2e width  ={{{image 2e width|}}}|
+
| image b width  ={{{image b width|{{{primary images width|100}}}}}}
image 2e height ={{{image 2e height|}}}|
+
| image b height ={{{image b height|{{{primary images height|100}}}}}}
image 2f       ={{{image 2f|}}}|
+
| image c       ={{{image c|}}}
caption 2f     ={{{caption 2f|}}}|
+
| label c        ={{{label c|}}}
image 2f width  ={{{image 2f width|}}}|
+
| caption c     ={{{caption c|}}}
image 2f height ={{{image 2f height|}}}|
+
| image c width  ={{{image c width|{{{primary images width|100}}}}}}
image 2g       ={{{image 2g|}}}|
+
| image c height ={{{image c height|{{{primary images height|100}}}}}}
caption 2g     ={{{caption 2g|}}}|
+
| image d       ={{{image d|}}}
image 2g width  ={{{image 2g width|}}}|
+
| label d        ={{{label d|}}}
image 2g height ={{{image 2g height|}}}|
+
| caption d     ={{{caption d|}}}
image 2h       ={{{image 2h|}}}|
+
| image d width  ={{{image d width|{{{primary images width|100}}}}}}
caption 2h     ={{{caption 2h|}}}|
+
| image d height ={{{image d height|{{{primary images height|100}}}}}}
image 2h width  ={{{image 2h width|}}}|
+
| image e        ={{{image e|}}}
image 2h height ={{{image 2h height|}}}|
+
| label e        ={{{label e|}}}
image 2i        ={{{image 2i|}}}|
+
| caption e      ={{{caption e|}}}
caption 2i      ={{{caption 2i|}}}|
+
| image e width  ={{{image e width|{{{primary images width|100}}}}}}
image 2i width  ={{{image 2i width|}}}|
+
| image e height ={{{image e height|{{{primary images height|100}}}}}}
image 2i height ={{{image 2i height|}}}
+
| extra images width  ={{{extra images width|200}}}
 +
| extra images height ={{{extra images height|200}}}
 +
| image j       ={{{image j|}}}
 +
| label j        ={{{label j|}}}
 +
| caption j     ={{{caption j|}}}
 +
| image j width  ={{{image j width|600}}}
 +
| image j height ={{{image j height|400}}}
 +
| image k       ={{{image k|}}}
 +
| label k        ={{{label k|}}}
 +
| caption k     ={{{caption k|}}}
 +
| image k width  ={{{image k width|600}}}
 +
| image k height ={{{image k height|400}}}
 +
| image m       ={{{image m|}}}
 +
| label m        ={{{label m|}}}
 +
| caption m     ={{{caption m|}}}
 +
| image m width  ={{{image m width|{{{extra images width|200}}}}}}
 +
| image m height ={{{image m height|{{{extra images height|200}}}}}}
 +
| image n       ={{{image n|}}}
 +
| label n        ={{{label n|}}}
 +
| caption n     ={{{caption n|}}}
 +
| image n width  ={{{image n width|{{{extra images width|200}}}}}}
 +
| image n height ={{{image n height|{{{extra images height|200}}}}}}
 +
| image o       ={{{image o|}}}
 +
| label o        ={{{label o|}}}
 +
| caption o     ={{{caption o|}}}
 +
| image o width  ={{{image o width|{{{extra images width|200}}}}}}
 +
| image o height ={{{image o height|{{{extra images height|200}}}}}}
 +
| image p       ={{{image p|}}}
 +
| label p        ={{{label p|}}}
 +
| caption p     ={{{caption p|}}}
 +
| image p width  ={{{image p width|{{{extra images width|200}}}}}}
 +
| image p height ={{{image p height|{{{extra images height|200}}}}}}
 +
| image q       ={{{image q|}}}
 +
| label q        ={{{label q|}}}
 +
| caption q     ={{{caption q|}}}
 +
| image q width  ={{{image q width|{{{extra images width|200}}}}}}
 +
| image q height ={{{image q height|{{{extra images height|200}}}}}}
 +
| image r       ={{{image r|}}}
 +
| label r        ={{{label r|}}}
 +
| caption r     ={{{caption r|}}}
 +
| image r width  ={{{image r width|{{{extra images width|200}}}}}}
 +
| image r height ={{{image r height|{{{extra images height|200}}}}}}
 +
| captionlines ={{{captionlines|3}}}
 +
| imagesfooter ={{{imagesfooter|}}}
 
}}</includeonly>
 
}}</includeonly>

Latest revision as of 21:53, 20 April 2017

[edit] [purge] Template-info.svg Template documentation

See Key Start for the main documentation.

Changes in recent versions

(The main documentation for all parts of the single-access key is under Template:Key Start/doc!)

Version 3.9.

  • comments changed, partly refactored
  • removed the br in front of the resultqualifier if sidebar image a etc. present
  • result layout variants better integrated to save memory
  • general minor optimizations
  • next-lead-pointer (number on right side) now always in same row as statement, even if results are also present

Version 3.8.

  • moved from own jKey-collapsible mechanism to MediaWiki’s mw-customcollapsible
  • introduced scientificname and new rules of the result-layout
  • saving properties for commonnames, scientificname, synonyms

Version 3.7.

Length estimate based on resulttext instead of resultlink (for empty result!!!)

Previous changes:

  • nested works now on parents with backlinks and alternatives (1 and 1*, 1 and 1'). 1 and 1- NEEDS TESTING!
  • result text+ empty result supported (non-linking result).
  • nowrap on result/qualifier reworked!
  • result=http:... now works.
  • Nested subkey ok. Resultqualifier no longer in ()
Version 3.3:
  • added scientific name and new layout for result
Version 3.2:
  • Added error category: Category:Internal - Error in Lead template
  • removed: resultlink
  • resulttext deprecated, "result text" is preferred!
  • resultqualifier deprecated, "result qualifier" is preferred!
  • common names allowed (and should perhaps be preferred over commonnames! -- TODO: also allow common names in Key Start

Older version changes:

Nested subkey. STATUS: Tested, result text and image j/k working.

New parameters: nested (the first lead number of a nested key that identifies the current lead as its parentlead. parentlead = identifying a lead as nested within the parentlead (the leads are indented, and the parentlead identifier become part of the nested lead id/next-lead values).

a) Simplified, no more image-no-resize-parameter (manually set size for very small images), no more link to next/result behind image, no more little metadata icons (which were necessary because of redirecting the main links. Javascript runs almost everywhere, former solution was very complicated and removed by javascript code! -- b) new image k, intended to be always displayed (no autohide) BELOW the statement text (for larger, wide in-key images). -- c) obsolete -- d) new parameter "result qualifier=" for male/female/white form, etc.; may also be used for scientific names, if result is desired to link to the common name. -- c) Image numbering adjusted to simplify creating a decision-based template (one template covering all leads, like the decision horizontal template. Called by outer template, Collapsible/collapsed added, lead images in right sidebar (up to five primary, "image a" to "image e", images side-by-side), non-hideable below statement (2 images, "image j"/"image k") and hidable below (secondary, "image m" to "image r" etc, max 6 images, wrapping gallery style).

PROCESS: a) Handle the subheading parameter directly (creating a visual separator (bold) above a couplet, usually summarizing identification progress and highlighting "sections" of a key). b) Error handling and combining detail text already occurs here. c) Call Template:Lead/Inner, passing calculated fields like the parsed lead-ID to be used multiple times.

Additional- and subtemplates

Lead
 ├ Lead/SplitNumberLead/InnerLead/docLead/GalleryItemLead/GalleryItemNoCaption
 + Template: StripFormatting to get just text
 + Template: Pixel2Number eg. 300px → 300


Technical Documentation

Lead/Inner produces a table row with 6 <td>

Legend:
tr#something → id="something"
td.something → class="something"
{something}  → {{{something}}}
[something]  → optional
‹1-2›        → colspan

┌ tr#L{keyID}_{leadID}_{decisiontreeAlternative}_row ───────────────────┐
│  [td] ┬ if {parentlead}                                               │
│  [td] ┘                                                               │
│  td.dt-nodeid                                                         │
└───────────────────────────────────────────────────────────────────────┘

┌ tr.dt-subheading ─────────────────────────────────────────────────────┐
└───────────────────────────────────────────────────────────────────────┘

┌  tr.dt-row#L{keyID}_{leadID}_row ─────────────────────────────────────┐
│   [td] ┬ if {parentlead}                                              │
│   [td] ┘                                                              │
│   td.dt-nodeid#L{keyID}_{leadID}                                      │
│   td.leadalt                                                          │
│ ┌ td.lead-row1 ─────────────────────────────────────────────────────┐ │
│ │  table.nested                                                     │ │
│ │  ├ tr                                                             │ │
│ │  │  td.leadtext span.leadspan                                     │ │   │   │ ► │
│ │  │  [td.leadresult span.leadon]                                   │ │   
│ │  ├ tr                                                             │ │
│ │  │  td.leadresult                                                 │ │   │       │
│ │  │     span.commonnames                                           │ │
│ │  │     span.leadresults                                           │ │
│ │  │       span.leadout                                             │ │
│ │  │       span.resultqualifier                                     │ │
│ │  │     span.leadon                                                │ │
│ │  ├ tr                                                             │ │
│ │  │  th.leaderror                                                  │ │   │       │
│ │  └ tr                                                             │ │
│ │     td.leadextras                                                 │ │   │       │
│ │       div.leadextras[.mw-collapsible]                             │ │
│ │         table                                                     │ │
│ │          tr                                                       │ │
│ │           table (containing image m,n,o,p,q,r) → Lead/GalleryItem │ │
│ │  table.nested                                                     │ │
│ │  └ tr                                                             │ │
│ │     td                                                            │ │
│ │       div (float:left) image j,k                                  │ │
│ └───────────────────────────────────────────────────────────────────┘ │
│   td                                                                  │
│    table                                                              │
│    tr                                                                 │
│      td (containing image a,b,c,d,e) → Lead/GalleryItemNoCaption      │
│        div.overlaywrapper                                             │
│          div.overlaylabel                                             │
└───────────────────────────────────────────────────────────────────────┘   

Notes:

1. The first column contains the lead number plus an anchor (id="") to which internal links may point. Here and further below, the first Lead parameter is split into two parts using the Lead/SplitNumber template.

2. Retrieving the id-parameter of the earlier "Key Start" template from a variable depends on the "Variables" extension being installed. On Wiki installations where this is not the case, remove the template code "{{#var: decisiontreeID}}" (here, in Lead itself and Lead/SplitNumber).

3. Temporarily, the template supports two versions for formatting results, depending on whether Scientific Name is present (new) or not (old). If most keys have a scientific name, then the old version may be dropped. Please attempt to create all new keys for the new format!

 ############### NEW OLD RESULT layout rules: ####################
 // ? scientificname
 // yes: (new layout format)
 //    ? resulttext
 //    yes: resulttext [, resultlink] [, next]
 //    no :
 //        ? commonnames
 //        yes: commonnames - scientificname [, next]
 //        no : scientificname [, next]
 // no : (old layout)
 //    ? commonnames
 //    yes: commonnames
 //        ? resulttext
 //        yes: commonnames - resulttext [, resultlink] [, next]
 //        no : commonnames [, next]
 // Note: [, next] can appear in all layout variants
 ############################################################