Difference between revisions of "Template:Recipe define"

From Captain of Industry Wiki
Jump to: navigation, search
(1st draft at migrating from inline styles to TemplateStyles)
(Attempt #1 at a full refactor to include mining/dumping)
Line 2: Line 2:
--><div class="recipe-wrapper"><!--
--><div class="recipe-wrapper"><!--


   -->{{#if:{{{Building|}}}|<!--
  *** v THIS IS A TEMPORARY DEBUG SECTION. REMOVE AFTER SUCCESSFUL CONVERSION. v ***
     --><div class="building-container inline-block"><!--
  -->{{#switch: {{lc:{{{Building}}}}}
      -->{{#ifeq: {{lc:{{{Building}}}}} | dumping |
      | mining
        [[File:{{{Output1Name}}}.png{{!}}link={{{Output1Name}}}{{!}}64x64px]] |
      | dumping = [[Category:Recipe template usage requiring special param]]
        [[File:{{{Building}}}.png{{!}}link={{{Building}}}{{!}}64x64px]]<!--
    }}<!--
      -->}}<!--
  *** ^ THIS IS A TEMPORARY DEBUG SECTION. REMOVE AFTER SUCCESSFUL CONVERSION. ^ ***
    --></div><!--
 
     -->{{#switch: {{lc:{{{Building}}}}}
   -->{{#if: {{{mining|}}} |<!-- Only executes if the `mining` param is set (to any value)
        | mining
     --><div class="building-container inline-block">[[File:Mining.png{{!}}64x64px{{!}}link=Mining]]</div><!--
        | dumping = <div class="arrow inline-block"><div class="arrow2 inline-block"><div>[[File:Icon arrow right.svg|30x45px]]</div></div></div>
     --><div class="arrow inline-block"><div class="arrow2">[[File:Icon arrow right.svg|30x45px]]</div></div><!--
        | #default = <div class="colon inline-block">:</div><!--
    --><div class="building-container inline-block">[[File:{{{Output1Name}}}{{!}}64x64px{{!}}link={{{Output1Name}}}]]</div><!--
    -->}}<!--
  -->}}<!--
  -->}}<!--


   -->{{#if:{{{Input1Name|}}}|<!--
   -->{{#if: {{{dumping|}}} |<!-- Only executes if the `dumping` param is set (to any value)
     --><div class="material-container inline-block"><!--
     --><div class="building-container inline-block">[[File:{{{Input1Name}}}{{!}}64x64px{{!}}link={{{Input1Name}}}]]</div><!--
      -->[[File:{{{Input1Name}}}.png|link={{{Input1Name}}}|45x45px]]<div class="quantity-container inline-block">{{{Input1Qty}}}</div><!--
     --><div class="arrow inline-block"><div class="arrow2">[[File:Icon arrow right.svg|30x45px]]</div></div><!--
    --></div><!--
     --><div class="building-container inline-block">[[File:Mining.png{{!}}64x64px{{!}}link=Mining]]</div><!--
  -->}}<!--
  -->}}<!--
  -->{{#if:{{{Input2Name|}}}|<!--
    --><div class="plus inline-block">+</div><!--
    --><div class="material-container inline-block"><!--
      -->[[File:{{{Input2Name}}}.png|link={{{Input2Name}}}|45x45px]]<div class="quantity-container inline-block">{{{Input2Qty}}}</div><!--
    --></div><!--
  -->}}<!--
  -->{{#if:{{{Input3Name|}}}|<!--
     --><div class="plus inline-block">+</div><!--
    --><div class="material-container inline-block"><!--
      -->[[File:{{{Input3Name}}}.png|link={{{Input3Name}}}|45x45px]]<div class="quantity-container inline-block">{{{Input3Qty}}}</div><!--
    --></div><!--
  -->}}<!--
  -->{{#if:{{{Input4Name|}}}|<!--
     --><div class="plus inline-block">+</div><!--
    --><div class="material-container inline-block"><!--
      -->[[File:{{{Input4Name}}}.png|link={{{Input4Name}}}|45x45px]]<div class="quantity-container inline-block">{{{Input4Qty}}}</div><!--
    --></div><!--
  -->}}<!--
  -->{{#if:{{{Input5Name|}}}|<!--
    --><div class="plus inline-block">+</div><!--
    --><div class="material-container inline-block"><!--
      -->[[File:{{{Input5Name}}}.png|link={{{Input5Name}}}|45x45px]]<div class="quantity-container inline-block">{{{Input5Qty}}}</div><!--
    --></div><!--
  -->}}<!--
  -->{{#if:{{{Input6Name|}}}|<!--
    --><div class="plus inline-block">+</div><!--
    --><div class="material-container inline-block"><!--
      -->[[File:{{{Input6Name}}}.png|link={{{Input6Name}}}|45x45px]]<div class="quantity-container inline-block">{{{Input6Qty}}}</div><!--
    --></div><!--
  -->}}<!--


   -->{{#if:{{{Time|}}}|<div class="arrow inline-block"><div class="arrow2 inline-block"><div>{{{Time}}}&nbsp;[[File:Clock.png|link=|16x16px]]</div><div>[[File:Icon arrow right.svg|30x45px]]</div></div></div>}}<!--
   -->{{#if: {{{mining|}}}{{{dumping|}}} ||<!-- Only executes if neither `mining` nor `dumping` param is set (to any value)
   
    -->{{#if: {{{Building|}}} |<!--
      --><div class="building-container inline-block">[[File:{{{Building}}}.png{{!}}64x64px{{!}}link={{{Building}}}]]</div><!--
      --><div class="colon inline-block">:</div><!--
    -->}}<!--


  -->{{#if:{{{Output1Name|}}}|<!--
    -->{{#if: {{{Input1Name|}}} |<!--
     -->{{#ifeq: {{lc:{{{Building}}}}} | dumping <!--
      --><div class="material-container inline-block">[[File:{{{Input1Name}}}.png{{!}}45x45px{{!}}link={{{Input1Name}}}]]<!--
       -->|<div class="material-container inline-block"><!--
        --><div class="quantity-container inline-block">{{{Input1Qty}}}</div><!--
        -->[[File:{{{Building}}}.png{{!}}link={{{Building}}}{{!}}64x64px]]<!--
      --></div><!--
    -->}}<!--
     -->{{#if: {{{Input2Name|}}} |<!--
      --><div class="plus inline-block">+</div><!--
      --><div class="material-container inline-block">[[File:{{{Input2Name}}}.png{{!}}45x45px{{!}}link={{{Input2Name}}}]]<!--
      --><div class="quantity-container inline-block">{{{Input2Qty}}}</div><!--
      --></div><!--
    -->}}<!--
    -->{{#if: {{{Input3Name|}}} |<!--
       --><div class="plus inline-block">+</div><!--
      --><div class="material-container inline-block">[[File:{{{Input3Name}}}.png{{!}}45x45px{{!}}link={{{Input3Name}}}]]<!--
      --><div class="quantity-container inline-block">{{{Input2Qty}}}</div><!--
      --></div><!--
    -->}}<!--
    -->{{#if: {{{Input4Name|}}} |<!--
      --><div class="plus inline-block">+</div><!--
      --><div class="material-container inline-block">[[File:{{{Input4Name}}}.png{{!}}45x45px{{!}}link={{{Input4Name}}}]]<!--
      --><div class="quantity-container inline-block">{{{Input2Qty}}}</div><!--
      --></div><!--
    -->}}<!--
    -->{{#if: {{{Input5Name|}}} |<!--
      --><div class="plus inline-block">+</div><!--
      --><div class="material-container inline-block">[[File:{{{Input5Name}}}.png{{!}}45x45px{{!}}link={{{Input5Name}}}]]<!--
      --><div class="quantity-container inline-block">{{{Input2Qty}}}</div><!--
       --></div><!--
       --></div><!--
       -->|<div class="material-container inline-block"><!--
    -->}}<!--
        -->[[File:{{{Output1Name}}}.png{{!}}link={{{Output1Name}}}{{!}}45x45px]]<div class="quantity-container inline-block">{{{Output1Qty|}}}</div><!--
    -->{{#if: {{{Input6Name|}}} |<!--
       --><div class="plus inline-block">+</div><!--
      --><div class="material-container inline-block">[[File:{{{Input6Name}}}.png{{!}}45x45px{{!}}link={{{Input6Name}}}]]<!--
      --><div class="quantity-container inline-block">{{{Input2Qty}}}</div><!--
       --></div><!--
       --></div><!--
     -->}}<!--
     -->}}<!--
  -->}}<!--
 
  -->{{#if:{{{Output2Name|}}}|<!--
    -->{{#if: {{{Time|}}} |<!--
    --><div class="plus inline-block">+</div><!--
      --><div class="arrow inline-block"><!--
     --><div class="material-container inline-block"><!--
        --><div class="arrow2 inline-block"><!--
       -->[[File:{{{Output2Name}}}.png|link={{{Output2Name}}}|45x45px]]<div class="quantity-container inline-block">{{{Output2Qty}}}</div><!--
          --><div>{{{Time}}}&nbsp;[[File:Clock.png|link=|16x16px]]</div><!--
          --><div>[[File:Icon arrow right.svg|30x45px]]</div><!--
        --></div><!--
      --></div><!--
    -->}}<!--
 
    -->{{#if: {{{Output1Name|}}} |<!--
      --><div class="material-container inline-block">[[File:{{{Output1Name}}}.png{{!}}link={{{Output1Name}}}{{!}}45x45px]]<!--
        --><div class="quantity-container inline-block">{{{Output1Qty|}}}</div><!--
     --></div><!--
    -->}}<!--
    -->{{#if: {{{Output2Name|}}} |<!--
      --><div class="plus inline-block">+</div><!--
       --><div class="material-container inline-block">[[File:{{{Output2Name}}}.png{{!}}link={{{Output2Name}}}{{!}}45x45px]]<!--
        --><div class="quantity-container inline-block">{{{Output2Qty|}}}</div><!--
     --></div><!--
     --></div><!--
  -->}}<!--
    -->}}<!--
  -->{{#if:{{{Output3Name|}}}|<!--
    -->{{#if: {{{Output3Name|}}} |<!--
    --><div class="plus inline-block">+</div><!--
      --><div class="plus inline-block">+</div><!--
    --><div class="material-container inline-block"><!--
      --><div class="material-container inline-block">[[File:{{{Output3Name}}}.png{{!}}link={{{Output3Name}}}{{!}}45x45px]]<!--
      -->[[File:{{{Output3Name}}}.png|link={{{Output3Name}}}|45x45px]]<div class="quantity-container inline-block">{{{Output3Qty}}}</div><!--
        --><div class="quantity-container inline-block">{{{Output3Qty|}}}</div><!--
     --></div><!--
     --></div><!--
  -->}}<!--
    -->}}<!--
  -->{{#if:{{{Output4Name|}}}|<!--
    -->{{#if: {{{Output4Name|}}} |<!--
    --><div class="plus inline-block">+</div><!--
      --><div class="plus inline-block">+</div><!--
    --><div class="material-container inline-block"><!--
      --><div class="material-container inline-block">[[File:{{{Output4Name}}}.png{{!}}link={{{Output4Name}}}{{!}}45x45px]]<!--
      -->[[File:{{{Output4Name}}}.png|link={{{Output4Name}}}|45x45px]]<div class="quantity-container inline-block">{{{Output4Qty}}}</div><!--
        --><div class="quantity-container inline-block">{{{Output4Qty|}}}</div><!--
     --></div><!--
     --></div><!--
  -->}}<!--
    -->}}<!--
  -->{{#if:{{{Output5Name|}}}|<!--
    -->{{#if: {{{Output5Name|}}} |<!--
    --><div class="plus inline-block">+</div><!--
      --><div class="plus inline-block">+</div><!--
    --><div class="material-container inline-block"><!--
      --><div class="material-container inline-block">[[File:{{{Output5Name}}}.png{{!}}link={{{Output5Name}}}{{!}}45x45px]]<!--
      -->[[File:{{{Output5Name}}}.png|link={{{Output5Name}}}|45x45px]]<div class="quantity-container inline-block">{{{Output5Qty}}}</div><!--
        --><div class="quantity-container inline-block">{{{Output5Qty|}}}</div><!--
     --></div><!--
     --></div><!--
  -->}}<!--
    -->}}<!--
  -->{{#if:{{{Output6Name|}}}|<!--
    -->{{#if: {{{Output6Name|}}} |<!--
    --><div class="plus inline-block">+</div><!--
      --><div class="plus inline-block">+</div><!--
    --><div class="material-container inline-block"><!--
      --><div class="material-container inline-block">[[File:{{{Output6Name}}}.png{{!}}link={{{Output6Name}}}{{!}}45x45px]]<!--
      -->[[File:{{{Output6Name}}}.png|link={{{Output6Name}}}|45x45px]]<div class="quantity-container inline-block">{{{Output6Qty}}}</div><!--
        --><div class="quantity-container inline-block">{{{Output6Qty|}}}</div><!--
     --></div><!--
     --></div><!--
    -->}}<!--
   -->}}<!--
   -->}}<!--
--></div></includeonly><!--
--></div></includeonly><!--
--><noinclude>{{documentation}}</noinclude>
--><noinclude>{{documentation}}</noinclude>

Revision as of 09:50, 13 January 2022

Template documentation (for the above template, sometimes hidden or invisible) [view] [edit] [history] [refresh]
Purpose
This template provides a method to rapidly illustrate crafting recipes without in-depth knowledge of wiki syntax or manual repetition/copy-pasting.
Basic usage
The following 2 templates are provided for making a recipe.
Both templates can be used with the format written in #Examples in this document.
Parameters
The template accepts the following parameters:
  • Building: Name of buildings (example: Blast Furnace). No need to specify on pages using Template:Infobox machine because the building is automatically detected.
  • Input1Name, Input2Name, ..., Input6Name: Name of materials (example: Iron Ore)
    • Input1Name = Mining (optional): Applies special format for mining.
  • Output1Name, Output2Name, ... Output6Name: Name of products (example: Molten Iron)
    • Output1Name = Dumping (optional): Applies special format for dumping.
  • Input1Qty, ..., Input6Qty, Output1Qty, ..., Output6Qty: Amount of materials or products per 1 cycle of recipe.
  • Time: Cycle time of recipe.
  • Input1Unit, ..., Input6Unit, Output1Unit, ..., Output6Unit (optional): Adds unit (for Electricity and Mechanical Power)
  • HideBldg (optional, rare): Hides building in recipe. No need to specify on pages using Template:Infobox machine (the building is automatically hidden).
  • Unreleased = yes (optional, rare): Applies special format for unreleased recipe
Limitations
This template can accept up to 6 inputs, 6 outputs, and 1 time value per recipe. The output can include only 1 pollution.

Examples

Example usage for mining
Markup Renders as
  {{Recipe
    | Input1Name  = Mining
    | Output1Name = Copper Ore
  }}
Mining.png
Transform.png
Copper Ore.png
Example usage for dumping loose materials
Markup Renders as
  {{Recipe
    | Output1Name = Dumping
    | Input1Name  = Rock
  }}
Rock.png
Transform.png
Dumping.png
Example usage for a machine with both inputs and outputs without pollution (most recipes)
Markup Renders as
  {{Recipe
    | Building    = Rotary Kiln
    | Input1Name  = Limestone
    | Input1Qty   = 12
    | Input2Name  = Coal
    | Input2Qty   = 2
    | Time        = 10
    | Output1Name = Cement
    | Output1Qty  = 4
    | Output2Name = Exhaust
    | Output2Qty  = 8
  }}
Rotary Kiln.pngCoal
:
12
Limestone.png
72
Plus.png
2
Coal.png
12
10 Clock.png
Transform.png
60 Clock 60s.png
4
Cement.png
24
Plus.png
8
Exhaust.png
48
Example for buildings that "provide" materials (Groundwater Pump, Air Separator, etc.)
Markup Renders as
  {{Recipe
    | Building    = Groundwater Pump
    | Time        = 10
    | Output1Name = Water
    | Output1Qty  = 8
  }}
Groundwater Pump.png
:
PROVIDES
8
Water.png
48
/ 10 Clock.png

/ 60 Clock 60s.png
Example usage for dumping/flaring/venting non-polluting liquids/gasses
Markup Renders as
  {{Recipe
    | Building    = Smoke Stack
    | Input1Name  = Oxygen
    | Input1Qty   = 200
    | Time        = 20
  }}
Smoke Stack.pngSmall
:
ACCEPTS
200
Oxygen.png
600
/ 20 Clock.png

/ 60 Clock 60s.png
Example usage for recipe with pollution
Markup Renders as
  {{Recipe
    | Building    = Liquid Dump
    | Input1Name  = Waste Water
    | Input1Qty   = 2
    | Time        = 2
    | Output1Name = Water Pollution
    | Output1Qty  = 2
  }}
Liquid Dump.png
:
ACCEPTS
2
Waste Water.png
60
/ 2 Clock.png

/ 60 Clock 60s.png
2
Water Pollution.png
60
  {{Recipe
    | Building    = Exhaust Scrubber
    | Input1Name  = Exhaust
    | Input1Qty   = 30
    | Input2Name  = Water
    | Input2Qty   = 4
    | Time        = 10
    | Output1Name = Sulfur
    | Output1Qty  = 1
    | Output2Name = Carbon Dioxide
    | Output2Qty  = 12
    | Output3Name = Steam Lo
    | Output3Qty  = 4
    | Output4Name = Air Pollution
    | Output4Qty  = 4
  }}
Exhaust Scrubber.png
:
30
Exhaust.png
180
Plus.png
4
Water.png
24
10 Clock.png
Transform.png
60 Clock 60s.png
1
Sulfur.png
6
Plus.png
12
Carbon Dioxide.png
72
Plus.png
4
Steam Lo.png
24
4
Air Pollution.png
24
Example usage for Mechanical Power and Electricity recipes with units
Markup Renders as
  {{Recipe
    | Building    = Low-pressure Turbine
    | Input1Name  = Steam Lo
    | Input1Qty   = 4
    | Time        = 5
    | Output1Name = Mechanical Power
    | Output1Qty  = 1
    | Output1Unit = MW
    | Output2Name = Steam Depleted
    | Output2Qty  = 4
  }}
Low-pressure Turbine.pngTier I
:
4
Steam Lo.png
48
Clock.png
Transform.png
60 Clock 60s.png
 
Mechanical Power.png
1 MW
Plus.png
4
Steam Depleted.png
48
Example usage for instantaneous recipes
Markup Renders as
  {{Recipe
    | Building    = Power Generator
    | Input1Name  = Mechanical Power
    | Input1Qty   = 500
    | Input1Unit  = KW
    | Time        = 0
    | Output1Name = Electricity
    | Output1Qty  = 250
    | Output1Unit = KW
  }}
Power Generator.png
:
 
Mechanical Power.png
500 KW
Transform.png
 
Electricity.png
250 KW
Example usage for recipes with variable quantity
Markup Renders as
  {{Recipe
    | Building    = Waste Collection
    | Time        = 60
    | Output1Name = Waste
    | Output1Unit = ?
  }}
Waste Collection.png
:
PROVIDES
?
Waste.png
?
/ 60 Clock.png

/ 60 Clock 60s.png
Example usage for hiding the building (automatically happens on pages using Template:Infobox machine)
Markup Renders as
  {{Recipe
    | Building    = Mixer
    | HideBldg    = yes
    | Input1Name  = Sand
    | Input1Qty   = 18
    | Input2Name  = Limestone
    | Input2Qty   = 4
    | Input3Name  = Salt
    | Input3Qty   = 4
    | Time        = 20
    | Output1Name = Glass Mix
    | Output1Qty  = 14
  }}
18
Sand.png
54
Plus.png
4
Limestone.png
12
Plus.png
4
Salt.png
12
20 Clock.png
Transform.png
60 Clock 60s.png
14
Glass Mix.png
42
Example usage for unreleased recipe
Markup Renders as
  {{Recipe
    | Building    = Crusher
    | Input1Name  = Gravel
    | Input1Qty   = 18
    | Time        = 20
    | Output1Name = Gold
    | Output1Qty  = 14
    | Unreleased  = yes
  }}
Crusher.png
:
20
Gravel.png
60
20 Clock.png
Transform.png
60 Clock 60s.png
1
Gold.png
3
UNRELEASED
The above text is transcluded from Template:Recipe draw/doc; you can change it or view its history. (How does this work?)
If you're done making changes, please refresh the text. (Why?)
You can experiment in this template's sandbox (create | mirror ) and testcases (create) pages.
Please add categories and interwikis to Template:Recipe draw/doc. (View all subpages of this page.)