Narrative Trigger Templates
The narrative_triggers
table contains a list of narrative trigger templates that campaign scripts can use to create narrative triggers. See the page on narrative
for an overview of the narrative event framework. See also the narrative_trigger
documentation for detailed information about the narrative_trigger
object interface.
Loaded in Campaign | |
Loaded in Battle | |
Loaded in Frontend |
-
narrative_triggers.generic(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
event name
string
,
condition
[function
],
Immediate
[boolean
]
) -
Creates and starts a narrative trigger that attempts to trigger when a specified event is received. An optional condition function may also be supplied, which must be passed for the narrative trigger to fire its target events. If supplied, the condition function will be called when the specified event is received, and will be passed the event context and the narrative trigger object as separate arguments. It must return a value that evaluates to
true
for the condition to pass. If no condition function is supplied then the condition always passes.
If the immediate flag is set, or if it is a multiplayer game, then the narrative trigger will immediately trigger the target messages when the event is received and condition passes. If the flag is not set and it's a singleplayer game the narrative will instead create anintervention
which will fire the target messages when it gets to trigger.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Event name to listen for.
7
optional, default value=nil
Condition function to call when the event is received. The event context and narrative trigger objects are provided to the function as arguments. If no condition function is supplied then the condition always passes.
8
optional, default value=true
Trigger the target message(s) immediately when the event is received and the optional condition is met.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 77
-
narrative_triggers.message(
unique name
string
,
faction key
string
,
trigger message
string
,
target message
string
,
cancel message
[string
]
) -
Triggers a message when a different message is received for the specified faction. Instead of using this, it is encouraged to make the narrative entity triggering the incoming message to instead just trigger the target message as well/instead, making this intermediate narrative trigger redundant. However, there are circumstances which can make the creation of an intermediate trigger desirable.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
Message on which this narrative trigger should trigger. If multiple trigger messages are required then a
table
containing string message names can be supplied here instead.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel. If multiple messages are required then a
table
containing string message names can be supplied here instead.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 139
-
narrative_triggers.turn_start(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
condition
[function
],
faction starting turn
[string
],
Immediate
[boolean
]
) -
Creates and starts a narrative trigger that attempts to trigger on start of turn for the specified faction. An optional condition function may also be supplied, which must be passed for the narrative trigger to fire its target events. If supplied, the condition function will be called when the faction starts its turn and will be passed the context of the
FactionTurnStart
event and the narrative trigger object as separate arguments. It must return a value that evaluates totrue
for the condition to pass. If no condition function is supplied then the condition always passes.
If the immediate flag is set, or if it is a multiplayer game, then the narrative trigger will immediately trigger the target messages when the turn start event is received. If the flag is not set and it's a singleplayer game the narrative will instead create anintervention
which will fire the target messages when it gets to trigger.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=nil
Condition function which must be passed for the trigger to fire. This function will be passed the context object from the
FactionTurnStart
event and the narrative trigger as two separate arguments. It must return a value that evaluates totrue
for the condition to pass.If no condition function is supplied here then the condition always passes.
7
optional, default value=nil
Key of the faction whose turn start we should listen for. If
nil
is supplied here then the key of the faction to which this narrative trigger applies is used.8
optional, default value=true
Trigger the target message(s) immediately when the event is received and the optional condition is met.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 222
-
narrative_triggers.dilemma_choice_made(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
dilemma key
string
,
choice value
[number
]
) -
Creates and starts a narrative trigger that fires when a dilemma choice is made.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Key of dilemma to listen for, from the
dilemmas
database table.7
optional, default value=nil
Integer choice value.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 292
-
narrative_triggers.turn_countdown(
unique name
string
,
faction key
string
,
start message
string
,
target message
string
,
cancel message
[string
],
turns
number
,
Immediate
[boolean
]
) -
Creates and starts a narrative trigger that listens for a message from another narrative object, and then waits a specified number of turns (for the specified faction) before sending one or more target messages.
The target messages are always triggered immediately, with no intervention being created in singleplayer mode.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
Message on which this narrative trigger should start its turn countdown. If multiple messages are required then a
table
containing string message names can be supplied here instead.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead. This message/these messages will be associated with the specified target faction rather than the source faction.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Number of turns to wait.
7
optional, default value=true
Trigger the target message(s) immediately when the event is received and the optional condition is met.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 388
-
narrative_triggers.faction_switch(
unique name
string
,
faction key
string
,
start message
string
,
target message
string
,
cancel message
[string
],
target faction key
string
) -
Creates and starts a narrative trigger that listens for a start message from another narrative object associated with one faction, and then sends one or more target messages associated with another faction. This can be useful if a desired narrative sequence flows over the player changing faction.
The target messages are always triggered immediately, with no intervention being created in singleplayer mode.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table. This should be the originator faction.3
Message on which this narrative trigger should initiate the faction switch process. If multiple messages are required then a
table
containing string message names can be supplied here instead.4
Target message or messages to trigger when this narrative trigger fires. These target message(s) will be associated with the target faction. If multiple target messages are required then a
table
containing string message names can be supplied here instead. This message/these messages will be associated with the specified target faction rather than the source faction.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Key of the target faction, to which the outgoing target message(s) will be associated.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 483
-
narrative_triggers.growth_point_gained(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
upgrade available only
[boolean
],
province key
[string
]
) -
Creates and starts a narrative trigger that fires when the specified faction has gained a growth point in a specified province, or any controlled territory if no province is specified.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=false
The narrative trigger should only fire when a growth point is earned in a player-controlled region and an upgrade of the main settlement chain is available.
7
optional, default value=nil
Key of province in which the growth point must be earned. This can also be a
table
of string province keys. If left blank, then any growth point earned by the specified faction is counted.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 570
-
narrative_triggers.building_construction_issued(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
condition
[function
]
) -
Creates and starts a narrative trigger that fires when the specified faction starts construction on a building. An optional condition function may be specified which is passed the context object supplied by the underlying
BuildingConstructionIssuedByPlayer
script event.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=nil
Condition function which, if supplied, must be passed in order for the trigger to fire. The condition function is passed the context object supplied by the underlying
BuildingConstructionIssuedByPlayer
script event as well as the narrative trigger object as separate arguments, and should return a value that evaluates to aboolean
.The condition function may also return a second
boolean
return value, which suppresses downstream output. This can be set if the condition function handles output itself.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 653
-
narrative_triggers.technology_building_construction_issued(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
condition
[function
]
) -
Creates and starts a narrative trigger that fires when the specified faction starts construction on a building that unlocks a technology. An additional optional condition function may be specified which is passed the context object supplied by the underlying
BuildingConstructionIssuedByPlayer
script event.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=nil
Condition function which, if supplied, must be passed in order for the trigger to fire. The condition function is passed the context object supplied by the underlying
BuildingConstructionIssuedByPlayer
script event as well as the narrative trigger object as separate arguments, and should return a value that evaluates to aboolean
.The condition function may also return a second
boolean
return value, which suppresses downstream output. This can be set if the condition function handles output itself.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 671
-
narrative_triggers.general_created(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
condition
[function
]
) -
Creates and starts a narrative trigger that fires when a general/lord character is created for the specified faction. An optional condition function may also be specified which is passed the context object supplied by the underlying
CharacterCreated
script event.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=nil
Condition function which, if supplied, must be passed in order for the trigger to fire. The condition function is passed the context object supplied by the underlying
BuildingConstructionIssuedByPlayer
script event as well as the narrative trigger object as separate arguments, and should return a value that evaluates to aboolean
.The condition function may also return a second
boolean
return value, which suppresses downstream output. This can be set if the condition function handles output itself.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 795
-
narrative_triggers.agent_created(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
condition
[function
]
) -
Creates and starts a narrative trigger that fires when an agent/hero character is created for the specified faction. An optional condition function may also be specified which is passed the context object supplied by the underlying
CharacterCreated
script event.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=nil
Condition function which, if supplied, must be passed in order for the trigger to fire. The condition function is passed the context object supplied by the underlying
BuildingConstructionIssuedByPlayer
script event as well as the narrative trigger object as separate arguments, and should return a value that evaluates to aboolean
.The condition function may also return a second
boolean
return value, which suppresses downstream output. This can be set if the condition function handles output itself.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 813
-
narrative_triggers.hero_action_performed(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
condition
[function
]
) -
Creates and starts a narrative trigger that fires when a hero character performs a successful action for the specified faction. An optional condition function may also be specified which is passed the context object supplied by the underlying
CharacterCharacterTargetAction
script event.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=nil
Condition function which, if supplied, must be passed in order for the trigger to fire. The condition function is passed the context object supplied by the underlying
BuildingConstructionIssuedByPlayer
script event as well as the narrative trigger object as separate arguments, and should return a value that evaluates to aboolean
.The condition function may also return a second
boolean
return value, which suppresses downstream output. This can be set if the condition function handles output itself.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 899
-
narrative_triggers.any_general_won_x_battles(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
victories
[number
],
condition
[function
]
) -
Creates and starts a narrative trigger that fires when a lord in the specified faction has participated in a certain number of battle victories. An optional condition function may also be specified which is passed the context object supplied by the underlying
CharacterCompletedBattle
script event.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=1
Threshold number of victories.
7
optional, default value=nil
Condition function which, if supplied, must be passed in order for the trigger to fire. The condition function is passed the context object supplied by the underlying
BuildingConstructionIssuedByPlayer
script event as well as the narrative trigger object as separate arguments, and should return a value that evaluates to aboolean
.The condition function may also return a second
boolean
return value, which suppresses downstream output. This can be set if the condition function handles output itself.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 988
-
narrative_triggers.any_hero_won_x_battles(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
victories
[number
],
condition
[function
]
) -
Creates and starts a narrative trigger that fires when a hero character in the specified faction has participated in a certain number of battle victories. An optional condition function may also be specified which is passed the context object supplied by the underlying
CharacterCompletedBattle
script event.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=1
Threshold number of victories.
7
optional, default value=nil
Condition function which, if supplied, must be passed in order for the trigger to fire. The condition function is passed the context object supplied by the underlying
BuildingConstructionIssuedByPlayer
script event as well as the narrative trigger object as separate arguments, and should return a value that evaluates to aboolean
.The condition function may also return a second
boolean
return value, which suppresses downstream output. This can be set if the condition function handles output itself.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1007
-
narrative_triggers.pooled_resource_gained(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
pooled resource key
string
,
threshold value
number
,
less than
[boolean
]
) -
Creates and starts a narrative trigger that fires when the specified faction has an amount of a specified pooled resource equal to or greater than a specified threshold.
An optional flag makes the narrative trigger instead fire when the pooled resource is less than or equal to the threshold.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Key of the pooled resource to monitor, from the
pooled_resources
database table. this can also be atable
of multiple pooled resource keys.7
Threshold value that the pooled resoure must meet or exceed for subject faction for trigger to fire.
8
optional, default value=false
Trigger when the pooled resource is less than or equal to the threshold value, rather than greater than.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1130
-
narrative_triggers.faction_pooled_resource_gained(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
pooled resource faction key
string
,
pooled resource key
string
,
threshold value
number
,
less than
[boolean
]
) -
Creates and starts a narrative trigger that fires when the specified faction has an amount of a specified pooled resource equal to or greater than a specified threshold. This differs from
narrative_triggers.pooled_resource_gained
as it allows the faction which is being monitored to be different from the faction with which the triggered messages are associated with.
An optional flag makes the narrative trigger instead fire when the pooled resource is less than or equal to the threshold.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction with which the triggered messages are associated with, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Key of the faction whose pooled resources are being monitored, from the
factions
database table.7
Key of the pooled resource to monitor, from the
pooled_resources
database table. this can also be atable
of multiple pooled resource keys.8
Threshold value that the pooled resoure must meet or exceed for subject faction for trigger to fire.
9
optional, default value=false
Trigger when the pooled resource is less than or equal to the threshold value, rather than greater than.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1150
-
narrative_triggers.skulls_gained(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
threshold value
number
,
less than
[boolean
]
) -
Creates and starts a narrative trigger that fires when the specified faction has an amount of the skulls pooled resource equal to or greater than a specified threshold.
An optional flag makes the narrative trigger instead fire when the pooled resource is less than or equal to the threshold.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Threshold value that the pooled resoure must meet or exceed for subject faction for trigger to fire.
7
optional, default value=false
Trigger when the pooled resource is less than or equal to the threshold value, rather than greater than.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1171
-
narrative_triggers.devotion_gained(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
threshold value
number
,
less than
[boolean
]
) -
Creates and starts a narrative trigger that fires when the specified faction has an amount of the devotion pooled resource equal to or greater than a specified threshold.
An optional flag makes the narrative trigger instead fire when the pooled resource is less than or equal to the threshold.Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Threshold value that the pooled resoure must meet or exceed for subject faction for trigger to fire.
7
optional, default value=false
Trigger when the pooled resource is less than or equal to the threshold value, rather than greater than.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1190
-
narrative_triggers.can_reach_faction(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
target faction key
string
,
include armies
[boolean
]
) -
Creates and starts a narrative trigger that fires when the specified faction starts a turn and any of its military forces can reach any of the settlements of a specified target faction to attack this turn. An optional flag also includes the target faction's armies in this assessment.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Key of the target faction, from the
factions
database table.7
optional, default value=false
Includes the target faction's roving armies in the can-reach check, as well as their settlements.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1265
-
narrative_triggers.can_reach_settlement(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
target settlements
string
,
include agents
boolean
) -
Creates and starts a narrative trigger that fires when the specified faction starts a turn and any of its military forces can reach any of the specified settlements to attack this turn. An optional flag also includes the subject faction's agents in this assessment, as well as military forces.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Key of the region containing the target settlement, from the
campaign_map_regions
database table. If multiple target settlements are desired then atable
containing multiple string keys may be supplied here.7
Include the source faction's agents/heroes in the can-reach assessment.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1351
-
narrative_triggers.corruption_in_adjacent_region(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
corruption type
string
,
threshold value
number
,
culture key
[string
]
) -
Creates and starts a narrative trigger that fires when the amount of corruption in any adjacent region to the specified faction reaches a specified threshold.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Corruption type, from the
pooled_resources
database table.7
Threshold value which the corruption must meet or exceed in an adjacent region for the trigger condition to be met.
8
optional, default value=nil
Culture key of region owner to exclude. If an eligible region has a faction owner with this culture, the region will not be included.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1445
-
narrative_triggers.foreign_slot_established(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
should be allied
[boolean
]
) -
Creates and starts a narrative trigger that fires when the specified faction establishes a foreign slot. Whether the foreign slot should be allied to the region it's embedded in or not may optionally be specified.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=nil
Should the foreign slot be allied to the region its embedded in or not. If
nil
(or no value) is supplied here then the trigger fires in either case.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1511
-
narrative_triggers.ritual_performed(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
ritual keys
[string
],
ritual categories
[string
],
target faction keys
[string
]
) -
Creates and starts a narrative trigger that fires when the specified faction performs a ritual. One or more optional ritual keys, ritual categories and target faction keys may be specified which the ritual performed must satisfy. Where a list of ritual keys/ritual categories/target faction keys is given, the ritual performed must match one of those in the list to qualify.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=nil
Key(s) of ritual(s), from the
rituals
database table. This can be astring
ritual key or atable
of strings. If no ritual keys are specified then any rituals match.7
optional, default value=nil
Key(s) of ritual category/categories, from the
ritual_categories
database table. This can be astring
category key or atable
of strings. If no categories are specified then any rituals match.8
optional, default value=nil
Key(s) of any target factions, from the
factions
database table. This can be astring
faction key or atable
of strings. If no target factions are specified then any targets match.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1648
-
narrative_triggers.character_action(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
ability key(s)
[string
],
target faction keys
[string
],
char subtypes
[string
],
must be success
[boolean
]
) -
Creates and starts a narrative trigger that fires when a character in the specified faction performs a character action (hero action). One or more optional action keys, performing character subtypes and/or target faction keys may be specified which the action performed must satisfy. It may also be specified whether the action must have succeeded to qualify.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=nil
Key(s) of character ability/abilities, from the
abilities
database table. This can be astring
ability key or atable
of strings. If no ability keys are specified then any abilities match.7
optional, default value=nil
Key(s) of any target factions, from the
factions
database table. This can be astring
faction key or atable
of strings. If no target factions are specified then any targets match.8
optional, default value=nil
Key(s) of character subtypes of the performing character, from the
agent_subtypes
database table. This can be astring
subtype key or atable
of strings. If no subtypes are specified then any performing characters match.9
optional, default value=nil
Specifies whether only successful character actions qualify.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1794
-
narrative_triggers.technology_research_started(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
technology key
[string
],
condition
[function
]
) -
Creates and starts a narrative trigger that fires when the specified faction starts researching a technology. A list of zero or more technology keys can be supplied which the technology must be in. Additionally, a condition function may be supplied which must be passed if the trigger is to fire.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=nil
Technology key, from the
technologies
database table, which the subject technology must match for the trigger to fire. Atable
ofstring
technology keys may be supplied here, in which case the trigger will fire if the subject technology is in the list. Additionally,nil
may be specified, in which case any technology matches.7
optional, default value=nil
An additional condition function which, if supplied, must be passed for the trigger to fire. The condition function will be passed the context object from the
ResearchStarted
event and the narrative trigger as two separate arguments, and should returntrue
if the trigger is allowed to fire.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1889
-
narrative_triggers.technology_research_completed(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
technology key
[string
],
condition
[function
]
) -
Creates and starts a narrative trigger that fires when the specified faction completes the research of a technology. A list of zero or more technology keys can be supplied which the technology must be in. Additionally, a condition function may be supplied which must be passed if the trigger is to fire.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
optional, default value=nil
Technology key, from the
technologies
database table, which the subject technology must match for the trigger to fire. Atable
ofstring
technology keys may be supplied here, in which case the trigger will fire if the subject technology is in the list. Additionally,nil
may be specified, in which case any technology matches.7
optional, default value=nil
An additional condition function which, if supplied, must be passed for the trigger to fire. The condition function will be passed the context object from the
ResearchCompleted
event and the narrative trigger as two separate arguments, and should returntrue
if the trigger is allowed to fire.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1907
-
narrative_triggers.net_income(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
threshold
number
,
trigger when lower
[boolean
]
) -
Creates and starts a narrative trigger that fires when the specified faction starts a turn with a net income greater than or equal to, or less than or equal to, a specified value.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Net income threshold.
7
optional, default value=false
If set to
true
, the narrative trigger fires when the net income is less than or equal to the specified threshold instead of greater than or equal to.Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 1976
-
narrative_triggers.controls_provinces(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
threshold
number
) -
Creates and starts a narrative trigger that fires when the number of provinces the specified faction fully controls is greater than or equal to the supplied threshold.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Provinces threshold.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 2047
-
narrative_triggers.highest_level_settlement(
unique name
string
,
faction key
string
,
start message
[string
],
target message
string
,
cancel message
[string
],
threshold
number
) -
Creates and starts a narrative trigger that fires when the specified faction controls a settlement or camp where the level of the main settlement building is greater than or equal to a specified value.
Parameters:
1
Unique name amongst other declared narrative triggers.
2
Key of the faction to which this narrative trigger applies, from the
factions
database table.3
optional, default value=nil
Message on which this narrative trigger should start its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead. If no start messages are specified, then the trigger will start its main listeners when it is started.4
Target messages to trigger when this narrative trigger fires. If multiple target messages are required then a
table
containing string message names can be supplied here instead.5
optional, default value=nil
Message on which this narrative trigger should cancel its main listening process. If multiple messages are required then a
table
containing string message names can be supplied here instead.6
Settlement building level threshold.
Returns:
nil
defined in ../../Warhammer/working_data/script/campaign/_narrative/wh3_narrative_trigger_templates.lua, line 2124