User:Gorgon/Sandbox/Sandbox Alpha: Difference between revisions

From Avlis Wiki
Jump to navigation Jump to search
m (→‎Extensions that would make this work better [My wish list]: Added note: The original DPL extension is also a viable option.)
m (More documentation ideas.)
Line 11: Line 11:
== Test version of [[Template:Spell]] ==
== Test version of [[Template:Spell]] ==
<!-- Add any revision notes or other ideas here. -->
<!-- Add any revision notes or other ideas here. -->


=== Extensions that would make this work better [My wish list] ===
=== Extensions that would make this work better [My wish list] ===
* [//www.mediawiki.org/wiki/Extension:Labeled_Section_Transclusion Extension:Labeled Section Transclusion] - Allows '''selective''' transclusion of marked-off sections of text.
* [http://www.mediawiki.org/wiki/Extension:Labeled_Section_Transclusion Extension:Labeled Section Transclusion] - Allows '''selective''' transclusion of marked-off sections of text.
* [//www.mediawiki.org/wiki/Extension:DynamicPageList_(third-party) Extension:DynamicPageList (third-party)] - Enhanced version of [//www.mediawiki.org/wiki/Extension:DynamicPageList_(Wikimedia) Extension:DynamicPageList (Wikimedia)]
* [http://www.mediawiki.org/wiki/Extension:DynamicPageList_(third-party) Extension:DynamicPageList (third-party)] - Enhanced version of [http://www.mediawiki.org/wiki/Extension:DynamicPageList_(Wikimedia) Extension:DynamicPageList (Wikimedia)]
** [//semeb.com/dpldemo/index.php?title=DPL:Overview DPL:Overview] - Generate dynamic reports based on category members and selective included info from each (Extension:Labeled Section Transclusion above would really help there).
** [http://semeb.com/dpldemo/index.php?title=DPL:Overview DPL:Overview] - Generate dynamic reports based on category members and selective included info from each (Extension:Labeled Section Transclusion above would really help there).
** [//semeb.com/dpldemo/index.php?title=Template:Catlist DPL:Template:Catlist] - Picture this totally reformatted as filter/sort options up top of the [[Magic:Spell_List | Spell List]] page, as a dynamic table. It starts showing all spells, but sortable with one click by level, school, class, or any other useful [[Template:Spell]] parameter/category used by them. Then add in the ability to filter results to only certain kinds/combinations (e.g, Show only cleric evocation spells, sorted by level, with the option of showing specific domain ones as well).  
** [http://semeb.com/dpldemo/index.php?title=Template:Catlist DPL:Template:Catlist] - Picture this totally reformatted as filter/sort options up top of the [[Magic:Spell_List | Spell List]] page, as a dynamic table. It starts showing all spells, but sortable with one click by level, school, class, or any other useful [[Template:Spell]] parameter/category used by them. Then add in the ability to filter results to only certain kinds/combinations (e.g, Show only cleric evocation spells, sorted by level, with the option of showing specific domain ones as well).  
** I doubt anyone else besides me would use this (except maybe the occasional dabbler), but it would really be useful for spells, and maybe a few other things eventually. Revamping all spells via this template is a huge undertaking (and my main goal for wiki updating, now that I can verify/test spells again), so adding this extension for that work alone would make a huge difference.
** I doubt anyone else besides me would use this (except maybe the occasional dabbler), but it would really be useful for spells, and maybe a few other things eventually. Revamping all spells via this template is a huge undertaking (and my main goal for wiki updating, now that I can verify/test spells again), so adding this extension for that work alone would make a huge difference.
** After looking into the more recent version of [//www.mediawiki.org/wiki/Extension:DynamicPageList_(Wikimedia) Extension:DynamicPageList (Wikimedia)] (the one used by most Wikimedia projects, not the "enhanced - 3rd party one"), it may be just as useful (or better), since it allows more sort options. Need to see both in practical use before deciding anything.
** After looking into the more recent version of [http://www.mediawiki.org/wiki/Extension:DynamicPageList_(Wikimedia) Extension:DynamicPageList (Wikimedia)] (the one used by most Wikimedia projects, not the "enhanced - 3rd party one"), it may be just as useful (or better), since it allows more sort options. Need to see both in practical use before deciding anything.
* [http://www.mediawiki.org/wiki/Extension:TemplateData Extension:TemplateData] - See the [[#Non-transcluded_template_documentation_.5Beventually_an_included_doc_subpage_or_.3Ctemplatedata.3E.5D | documentation section]] below.
 


=== Revision notes ===
=== Revision notes ===
* Still in pre-work thought mode here, and wanting extensions to make life easier. Made a few changes to automate very basic parameter stuff, but more can be done. [[NWN:Template:Spell | Template:Spell on the NWN Wiki]] has some ideas, but not quite what I had in mind either.
* Still in pre-work thought mode here, and wanting extensions to make life easier. Made a few changes to automate very basic parameter stuff, but more can be done. [[NWN:Template:Spell | Template:Spell on the NWN Wiki]] has some ideas, but not quite what I had in mind either.
* I think [[User:Buddha|Buddha]] had the right idea with his discussion on the [[Avlis_Wiki_talk:Categories#Categorizing_Spells | Categories page]] about reformatting how we categorize spells. The current [[Magic:Spell_List | Spell List]] page (and its various subversions) all rely on manual updating when any new changes happen to it, like a new spell being added. Revisions to this template will improve how each spell is displayed, and categorized (even without new extensions), so moving to category listings that update dynamically makes a lot of sense.
* I think [[User:Buddha|Buddha]] had the right idea with his discussion on the [[Avlis_Wiki_talk:Categories#Categorizing_Spells | Categories page]] about reformatting how we categorize spells. The current [[Magic:Spell_List | Spell List]] page (and its various subversions) all rely on manual updating when any new changes happen to it, like a new spell being added. Revisions to this template will improve how each spell is displayed, and categorized (even without new extensions), so moving to category listings that update dynamically makes a lot of sense.
** If the suggested [//www.mediawiki.org/wiki/Extension:Labeled_Section_Transclusion Labeled Section Transclusion] extension is added, then short spell descriptions and other info can be dynamically added/updated to manually updated lists, like [[Magic:Cleric_Spells:Level-1 | Cleric Spells:Level-1]], even without moving to categories.
** If the suggested [http://www.mediawiki.org/wiki/Extension:Labeled_Section_Transclusion Labeled Section Transclusion] extension is added, then short spell descriptions and other info can be dynamically added/updated to manually updated lists, like [[Magic:Cleric_Spells:Level-1 | Cleric Spells:Level-1]], even without moving to categories.
** The [//www.mediawiki.org/wiki/Extension:DynamicPageList_(third-party) Dynamic Page List (third-party)] extension would allow one page to display all variations in any sort of table, sortable and filterable by any useful criteria. Spells would be automatically categorized by this template, but one page would use those categories and/or the template parameters, to display whatever output is requested by the user. Combine this with Labeled Section Transclusion, and any results are updated as each spell gets edited.
** The [http://www.mediawiki.org/wiki/Extension:DynamicPageList_(third-party) Dynamic Page List (third-party)] extension would allow one page to display all variations in any sort of table, sortable and filterable by any useful criteria. Spells would be automatically categorized by this template, but one page would use those categories and/or the template parameters, to display whatever output is requested by the user. Combine this with Labeled Section Transclusion, and any results are updated as each spell gets edited.
 
 
----
 
 
Can the "Name" template parameter be taken from the page name automatically?
* Maybe as a default if not given as a parameter?
* Might need some page renaming, but should work.
* Keeping the template from categorizing itself as a spell might be annoying, unless namespace checking or other validation is done.
 
 
----
 


More to come...
More to come...


== Template start ==
== Template start ==
Line 124: Line 141:
[[Magic:Sorcerer Wizard Spells:Level-8|8]]
[[Magic:Sorcerer Wizard Spells:Level-8|8]]
[[Magic:Sorcerer Wizard Spells:Level-9|9]] )
[[Magic:Sorcerer Wizard Spells:Level-9|9]] )
</small> -->
</small> --><!-- <includeonly>
<!--  
 
[[Category:Magic|{{{Name}}}]]
[[Category:Magic|{{{Name}}}]]
<includeonly>[[Category:{{{School}}} Spells|{{{Name}}}]]</includeonly>
[[Category:{{{School}}} Spells|{{{Name}}}]]</includeonly><noinclude>
--><noinclude>
 
<!-- Add template documentation here, or include a doc subpage (see: https://en.wikipedia.org/wiki/Wikipedia:Template_documentation#How_to_create_a_documentation_subpage). -->
[[Category:Templates|{{PAGENAME}}]]</noinclude> --><noinclude>
== Non-transcluded template documentation [eventually an included doc subpage with transcluded categories] ==
 
<!-- Add template documentation here, or include a doc subpage (see: http://wikipedia.org/wiki/Wikipedia:Template_documentation#How_to_create_a_documentation_subpage). The <templatedata></templatedata> tags would be simpler. -->
 
== Non-transcluded template documentation [eventually an included doc subpage or <templatedata>] ==
 
[[Magic:Spell_Format]] should be here as documentation, instead of that hard to find page.
 
Add template documentation here, or include a doc subpage (see: [[Wikipedia:Wikipedia:Template_documentation#How_to_create_a_documentation_subpage | How to create a documentation subpage]]).
* A <nowiki>{{</nowiki>[[Wikipedia:Template:Documentation |Documentation]]<nowiki>}}</nowiki> sub-template would be useful for all templates on this wiki, since they need usage documentation (stripped down version, without the dozens of other templates).
* [http://www.mediawiki.org/wiki/Extension:TemplateData Extension:TemplateData] would work better on its own, keeping things simple.
** It should install a "Manage TemplateData" button for the edit gui, but I am not sure what else that needs (probably [http://www.mediawiki.org/wiki/VisualEditor VisualEditor], which is a slow pig, so pass on that). See: [http://www.mediawiki.org/wiki/Help:TemplateData#TemplateData_editor TemplateData editor].
** Below is what might be the beginning of the spell template documentation as an example (using <nowiki><templatedata></templatedata></nowiki> tags), if it is done manually. ''I have the "Name" as'' '''"required": false''' ''because I may try grabbing it from the page title, if it isn't given.''
<pre style="white-space: pre-wrap"><nowiki><noinclude>
 
==Usage==
 
<templatedata>
{
    "description": "Spells Template",
    "params": {
        "Name": {
            "label": "Spell Name",
            "description": "Name of the Spell (Uses the page title if not defined)",
            "required": false,
            "suggested": true,
            "default": {{SUBPAGENAME}},
            "type": "string",
            "example": "Name = Freedom of Movement"
        },
        "School": {
            "label": "Spell School",
            "description": "School of magic the spell belongs to. Must be one of: Abjuration, Conjuration, Divination, Enchantment, Evocation, Illusion, Necromancy, Transmutation or Universal.",
            "required": true,
            "type": "string",
            "example": "School = Abjuration"
        },
        "Subschool": {
            "label": "Spell Subschool",
            "description": "Subschool of the spell.",
            "required": false,
            "type": "string",
            "example": "Subschool = "
        },
        "Descriptors": {
            "label": "Spell Descriptors",
            "description": "Descriptors of the spell.",
            "required": false,
            "type": "string",
            "example": "Descriptors = "
        },
        "Bard_Level": {
            "label": "Bard Level",
            "description": "Level of spell for Bards (if it is a Bard spell).",
            "required": false,
            "type": "number",
            "example": "Bard_Level = "
        },
        "Cleric_Level": {
            "label": "Cleric Level",
            "description": "Level of spell for Clerics (if it is a Cleric spell).",
            "example": "Cleric_Level = 4",
            "inherits": "Bard_Level"
        },
        "Druid_Level": {
            "label": "Druid Level",
            "description": "Level of spell for Druids (if it is a Druid spell).",
            "example": "Druid_Level = 4",
            "inherits": "Bard_Level"
        },
        "Paladin_Level": {
            "label": "Paladin Level",
            "description": "Level of spell for Paladins (if it is a Paladin spell).",
            "example": "Paladin_Level = 4",
            "inherits": "Bard_Level"
        },
        "Ranger_Level": {
            "label": "Ranger Level",
            "description": "Level of spell for Rangers (if it is a Ranger spell).",
            "example": "Ranger_Level = 4",
            "inherits": "Bard_Level"
        },
        "Arcane_Level": {
            "label": "Sorcerer/Wizard Level",
            "description": "Level of spell for Sorcerers/Wizards (if it is an Arcane spell).",
            "example": "Arcane_Level = 4",
            "inherits": "Bard_Level"
        },
        "Domain": {
            "label": "Domain (1) Name",
            "description": "1st Domain name of spell for Clerics (if it is a Domain spell).",
            "required": false,
            "type": "string",
            "example": "Domain = Travel"
        },
        "Domain_Level": {
            "label": "Domain (1) Level",
            "description": "1st Domain Level of spell for Clerics (if it is a Domain spell).",
            "required": false,
            "type": "number",
            "example": "Domain_Level = 3"
        },
        "Domain_2": {
            "label": "Domain (2) Name",
            "description": "2nd Domain name of spell for Clerics (if it is a Domain spell).",
            "example": "Domain_2 = ",
            "inherits": "Domain"
        },
        "Domain_2_Level": {
            "label": "Domain (2) Level",
            "description": "2nd Domain Level of spell for Clerics (if it is a Domain spell).",
            "example": "Domain_2_Level = ",
            "inherits": "Domain_Level"
        }
    },           
    "paramOrder": [
        "Name",
        "School",
        "Subschool",
        "Descriptors",
        "Bard_Level",
        "Cleric_Level",
        "Druid_Level",
        "Paladin_Level",
        "Ranger_Level",
        "Arcane_Level",
        "Domain",
        "Domain_Level",
        "Domain_2",
        "Domain_2_Level"
    ]
}
</templatedata>
</noinclude></nowiki></pre>
 
Obviously I've added more parameters for class and domain spells, similar to the NWN Wiki version of [[NWN:Template:Spell | Template:Spell]]. Their full parameter list is below (they don't use Subschool, and I used proper case with underscores for all parameters):
 
 
:'''Spell levels:'''
:*''bardlevel'' &mdash; The level of this spell when cast by a [[bard]]. ''Optional''
:*''clericlevel'' &mdash; The level of this spell when cast by a [[cleric]]. ''Optional''
:*''druidlevel'' &mdash; The level of this spell when cast by a [[druid]]. ''Optional''
:*''paladinlevel'' &mdash; The level of this spell when cast by a [[paladin]]. ''Optional''
:*''rangerlevel'' &mdash; The level of this spell when cast by a [[ranger]]. ''Optional''
:*''magelevel'' &mdash; The level of this spell when cast by a [[sorcerer]] or [[wizard]]. ''Optional''
:*''domain'' &mdash; The clerical [[domain]] that grants access to this spell. ''Optional''
:*''domainlevel'' &mdash; The level of this spell when granted by this domain. ''Required if domain is specified''
:*''domain2'' &mdash; A second clerical domain that grants access to this spell. ''Optional''
:*''domain2level'' &mdash; The level of this spell when granted by the second domain. ''Required if domain2 is specified''
:*''domain3'' &mdash; A third clerical domain that grants access to this spell. ''Optional''
:*''domain3level'' &mdash; The level of this spell when granted by the third domain. ''Required if domain3 is specified''
:*''domain4'' &mdash; A fourth clerical domain that grants access to this spell. ''Optional''
:*''domain4level'' &mdash; The level of this spell when granted by the fourth domain. ''Required if domain4 is specified''
:*''innatelevel'' &mdash; The innate level of this spell.
 
 
:'''Lines of spells:'''
:* ''line'' &mdash; a name for the spell line this spell belongs to. ''Optional, but if not set then ''line0'' through ''line9'' are ignored''
:* ''line0'' through ''line9'' &mdash; names of spells (not linked) that are considered in the same "line" of spells as the current spell. Use the parameter corresponding to the spell's innate level. Include the current spell. ''Optional, but some should be used if "line" is set''
:* ''linebreach'' &mdash; set this (to "yes") to get a table for the breach line of spells. (This is a hack to accommodate ''disjunction'' having two spell lines.) ''Optional''
 
 
:'''Other:'''
:*''area'' &mdash; The area affected by this spell. The values "small", "medium", "large", "huge", "gargantuan", "colossal", and "spellcone" should be used when appropriate.
:**''areanote'' &mdash; Additional information about the area of effect (e.g. a limit on the number of targets in a colossal area). ''Optional''
:**''conesize'' &mdash; This can override the default length of "10" for spell cones.
:*''components'' &mdash; "V", "S", or "VS" indicating the components this spell utilizes. ''Optional''
:*''counters'' &mdash; Additional counterspells, preferably linked. ''Optional''
:*''duration'' &mdash; The duration of the spell.
:*''immunity'' &mdash; The [[Magic:Descriptors | descriptor]] (immunity type) of this spell. ''Optional''
:*''range'' &mdash; "p", "t", "s", "m", or "l" indicating the range of the spell.
:*''save'' &mdash; The save allowed for this spell, preferably linked. ''Optional''
:*''school'' &mdash; The [[Magic:School | spell school]] of this spell, preferably linked.
:*''spellcraft'' &mdash; The spellcraft requirement (for epic spells). ''Optional, epic only''
:*''spellresistance'' &mdash; Should be "yes" if spell resistance can bock this spell. Should be "yes*" if the BioWare description says spell resistance can block this spell, but it does not actually do so. ''Optional''
 
:*''desc'' &mdash; The spell's in-game description.
:*''icon'' &mdash; The name of the image (icon) for this spell. ''Optional''


Add template documentation here, or include a doc subpage (see: [//en.wikipedia.org/wiki/Wikipedia:Template_documentation#How_to_create_a_documentation_subpage How to create a documentation subpage]).
* A document sub-template would be useful for all templates on this wiki, since they need usage documentation.


<!-- End of documentation. -->
<!-- End of documentation. -->
</noinclude>
</noinclude>

Revision as of 10:56, 24 January 2017

Anything up to/including the Template start heading will not be included in transclusion of this template (or any part of the trailing documentation section either, though that will eventually be formalized template documentation, with transcluded categories at the end).

I love to over-comment my code, so why change things here...




Test version of Template:Spell

Extensions that would make this work better [My wish list]

  • Extension:Labeled Section Transclusion - Allows selective transclusion of marked-off sections of text.
  • Extension:DynamicPageList (third-party) - Enhanced version of Extension:DynamicPageList (Wikimedia)
    • DPL:Overview - Generate dynamic reports based on category members and selective included info from each (Extension:Labeled Section Transclusion above would really help there).
    • DPL:Template:Catlist - Picture this totally reformatted as filter/sort options up top of the Spell List page, as a dynamic table. It starts showing all spells, but sortable with one click by level, school, class, or any other useful Template:Spell parameter/category used by them. Then add in the ability to filter results to only certain kinds/combinations (e.g, Show only cleric evocation spells, sorted by level, with the option of showing specific domain ones as well).
    • I doubt anyone else besides me would use this (except maybe the occasional dabbler), but it would really be useful for spells, and maybe a few other things eventually. Revamping all spells via this template is a huge undertaking (and my main goal for wiki updating, now that I can verify/test spells again), so adding this extension for that work alone would make a huge difference.
    • After looking into the more recent version of Extension:DynamicPageList (Wikimedia) (the one used by most Wikimedia projects, not the "enhanced - 3rd party one"), it may be just as useful (or better), since it allows more sort options. Need to see both in practical use before deciding anything.
  • Extension:TemplateData - See the documentation section below.


Revision notes

  • Still in pre-work thought mode here, and wanting extensions to make life easier. Made a few changes to automate very basic parameter stuff, but more can be done. Template:Spell on the NWN Wiki has some ideas, but not quite what I had in mind either.
  • I think Buddha had the right idea with his discussion on the Categories page about reformatting how we categorize spells. The current Spell List page (and its various subversions) all rely on manual updating when any new changes happen to it, like a new spell being added. Revisions to this template will improve how each spell is displayed, and categorized (even without new extensions), so moving to category listings that update dynamically makes a lot of sense.
    • If the suggested Labeled Section Transclusion extension is added, then short spell descriptions and other info can be dynamically added/updated to manually updated lists, like Cleric Spells:Level-1, even without moving to categories.
    • The Dynamic Page List (third-party) extension would allow one page to display all variations in any sort of table, sortable and filterable by any useful criteria. Spells would be automatically categorized by this template, but one page would use those categories and/or the template parameters, to display whatever output is requested by the user. Combine this with Labeled Section Transclusion, and any results are updated as each spell gets edited.




Can the "Name" template parameter be taken from the page name automatically?

  • Maybe as a default if not given as a parameter?
  • Might need some page renaming, but should work.
  • Keeping the template from categorizing itself as a spell might be annoying, unless namespace checking or other validation is done.




More to come...


Template start

School: [[Magic:{{{School}}}|{{{School}}}]]
Level: {{{Level}}}
Innate Level: {{{Innate Level}}}
Component(s): {{{Components}}}
Casting Time: {{{Casting Time}}}
Range: {{{Range}}}
Target: {{{Target}}}
Duration: {{{Duration}}}
Counter(s): {{{Counters}}}
Saving Throw: {{{Saving Throw}}}
Spell Resistance: {{{Spell Resistance}}}
Metamagic: {{{Metamagic}}}
Energy Substitution: {{{Energy Substitution}}}

{{{Description}}}


Non-transcluded template documentation [eventually an included doc subpage or <templatedata>]

Magic:Spell_Format should be here as documentation, instead of that hard to find page.

Add template documentation here, or include a doc subpage (see: How to create a documentation subpage).

  • A {{Documentation}} sub-template would be useful for all templates on this wiki, since they need usage documentation (stripped down version, without the dozens of other templates).
  • Extension:TemplateData would work better on its own, keeping things simple.
    • It should install a "Manage TemplateData" button for the edit gui, but I am not sure what else that needs (probably VisualEditor, which is a slow pig, so pass on that). See: TemplateData editor.
    • Below is what might be the beginning of the spell template documentation as an example (using <templatedata></templatedata> tags), if it is done manually. I have the "Name" as "required": false because I may try grabbing it from the page title, if it isn't given.
<noinclude>

==Usage==

<templatedata>
{
    "description": "Spells Template",
    "params": {
        "Name": {
            "label": "Spell Name",
            "description": "Name of the Spell (Uses the page title if not defined)",
            "required": false,
            "suggested": true,
            "default": {{SUBPAGENAME}},
            "type": "string",
            "example": "Name = Freedom of Movement"
        },
        "School": {
            "label": "Spell School",
            "description": "School of magic the spell belongs to. Must be one of: Abjuration, Conjuration, Divination, Enchantment, Evocation, Illusion, Necromancy, Transmutation or Universal.",
            "required": true,
            "type": "string",
            "example": "School = Abjuration"
        },
        "Subschool": {
            "label": "Spell Subschool",
            "description": "Subschool of the spell.",
            "required": false,
            "type": "string",
            "example": "Subschool = "
        },
        "Descriptors": {
            "label": "Spell Descriptors",
            "description": "Descriptors of the spell.",
            "required": false,
            "type": "string",
            "example": "Descriptors = "
        },
        "Bard_Level": {
            "label": "Bard Level",
            "description": "Level of spell for Bards (if it is a Bard spell).",
            "required": false,
            "type": "number",
            "example": "Bard_Level = "
        },
        "Cleric_Level": {
            "label": "Cleric Level",
            "description": "Level of spell for Clerics (if it is a Cleric spell).",
            "example": "Cleric_Level = 4",
            "inherits": "Bard_Level"
        },
        "Druid_Level": {
            "label": "Druid Level",
            "description": "Level of spell for Druids (if it is a Druid spell).",
            "example": "Druid_Level = 4",
            "inherits": "Bard_Level"
        },
        "Paladin_Level": {
            "label": "Paladin Level",
            "description": "Level of spell for Paladins (if it is a Paladin spell).",
            "example": "Paladin_Level = 4",
            "inherits": "Bard_Level"
        },
        "Ranger_Level": {
            "label": "Ranger Level",
            "description": "Level of spell for Rangers (if it is a Ranger spell).",
            "example": "Ranger_Level = 4",
            "inherits": "Bard_Level"
        },
        "Arcane_Level": {
            "label": "Sorcerer/Wizard Level",
            "description": "Level of spell for Sorcerers/Wizards (if it is an Arcane spell).",
            "example": "Arcane_Level = 4",
            "inherits": "Bard_Level"
        },
        "Domain": {
            "label": "Domain (1) Name",
            "description": "1st Domain name of spell for Clerics (if it is a Domain spell).",
            "required": false,
            "type": "string",
            "example": "Domain = Travel"
        },
        "Domain_Level": {
            "label": "Domain (1) Level",
            "description": "1st Domain Level of spell for Clerics (if it is a Domain spell).",
            "required": false,
            "type": "number",
            "example": "Domain_Level = 3"
        },
        "Domain_2": {
            "label": "Domain (2) Name",
            "description": "2nd Domain name of spell for Clerics (if it is a Domain spell).",
            "example": "Domain_2 = ",
            "inherits": "Domain"
        },
        "Domain_2_Level": {
            "label": "Domain (2) Level",
            "description": "2nd Domain Level of spell for Clerics (if it is a Domain spell).",
            "example": "Domain_2_Level = ",
            "inherits": "Domain_Level"
        }
    },            
    "paramOrder": [
        "Name",
        "School",
        "Subschool",
        "Descriptors",
        "Bard_Level",
        "Cleric_Level",
        "Druid_Level",
        "Paladin_Level",
        "Ranger_Level",
        "Arcane_Level",
        "Domain",
        "Domain_Level",
        "Domain_2",
        "Domain_2_Level"
    ]
}
</templatedata>
</noinclude>

Obviously I've added more parameters for class and domain spells, similar to the NWN Wiki version of Template:Spell. Their full parameter list is below (they don't use Subschool, and I used proper case with underscores for all parameters):


Spell levels:
  • bardlevel — The level of this spell when cast by a bard. Optional
  • clericlevel — The level of this spell when cast by a cleric. Optional
  • druidlevel — The level of this spell when cast by a druid. Optional
  • paladinlevel — The level of this spell when cast by a paladin. Optional
  • rangerlevel — The level of this spell when cast by a ranger. Optional
  • magelevel — The level of this spell when cast by a sorcerer or wizard. Optional
  • domain — The clerical domain that grants access to this spell. Optional
  • domainlevel — The level of this spell when granted by this domain. Required if domain is specified
  • domain2 — A second clerical domain that grants access to this spell. Optional
  • domain2level — The level of this spell when granted by the second domain. Required if domain2 is specified
  • domain3 — A third clerical domain that grants access to this spell. Optional
  • domain3level — The level of this spell when granted by the third domain. Required if domain3 is specified
  • domain4 — A fourth clerical domain that grants access to this spell. Optional
  • domain4level — The level of this spell when granted by the fourth domain. Required if domain4 is specified
  • innatelevel — The innate level of this spell.


Lines of spells:
  • line — a name for the spell line this spell belongs to. Optional, but if not set then line0 through line9 are ignored
  • line0 through line9 — names of spells (not linked) that are considered in the same "line" of spells as the current spell. Use the parameter corresponding to the spell's innate level. Include the current spell. Optional, but some should be used if "line" is set
  • linebreach — set this (to "yes") to get a table for the breach line of spells. (This is a hack to accommodate disjunction having two spell lines.) Optional


Other:
  • area — The area affected by this spell. The values "small", "medium", "large", "huge", "gargantuan", "colossal", and "spellcone" should be used when appropriate.
    • areanote — Additional information about the area of effect (e.g. a limit on the number of targets in a colossal area). Optional
    • conesize — This can override the default length of "10" for spell cones.
  • components — "V", "S", or "VS" indicating the components this spell utilizes. Optional
  • counters — Additional counterspells, preferably linked. Optional
  • duration — The duration of the spell.
  • immunity — The descriptor (immunity type) of this spell. Optional
  • range — "p", "t", "s", "m", or "l" indicating the range of the spell.
  • save — The save allowed for this spell, preferably linked. Optional
  • school — The spell school of this spell, preferably linked.
  • spellcraft — The spellcraft requirement (for epic spells). Optional, epic only
  • spellresistance — Should be "yes" if spell resistance can bock this spell. Should be "yes*" if the BioWare description says spell resistance can block this spell, but it does not actually do so. Optional
  • desc — The spell's in-game description.
  • icon — The name of the image (icon) for this spell. Optional