You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
115 lines
3.8 KiB
115 lines
3.8 KiB
@tool
|
|
class_name DialogicLabelEvent
|
|
extends DialogicEvent
|
|
|
|
## Event that is used as an anchor. You can use the DialogicJumpEvent to jump to this point.
|
|
|
|
|
|
### Settings
|
|
|
|
## Used to identify the label. Duplicate names in a timeline will mean it always chooses the first.
|
|
var name: String = ""
|
|
var display_name: String = ""
|
|
|
|
|
|
|
|
################################################################################
|
|
## EXECUTE
|
|
################################################################################
|
|
|
|
func _execute() -> void:
|
|
# This event is mainly implemented in the Jump subsystem.
|
|
dialogic.Jump.passed_label.emit(
|
|
{
|
|
"identifier": name,
|
|
"display_name": get_property_translated("display_name"),
|
|
"display_name_orig": display_name,
|
|
"timeline": DialogicResourceUtil.get_unique_identifier(dialogic.current_timeline.resource_path)
|
|
})
|
|
finish()
|
|
|
|
|
|
################################################################################
|
|
## INITIALIZE
|
|
################################################################################
|
|
|
|
func _init() -> void:
|
|
event_name = "Label"
|
|
set_default_color('Color4')
|
|
event_category = "Flow"
|
|
event_sorting_index = 3
|
|
|
|
|
|
func _get_icon() -> Resource:
|
|
return load(self.get_script().get_path().get_base_dir().path_join('icon_label.png'))
|
|
|
|
|
|
################################################################################
|
|
## SAVING/LOADING
|
|
################################################################################
|
|
func to_text() -> String:
|
|
if display_name.is_empty():
|
|
return "label "+name
|
|
else:
|
|
return "label "+name+ " ("+display_name+")"
|
|
|
|
|
|
|
|
func from_text(string:String) -> void:
|
|
var regex = RegEx.create_from_string(r'label +(?<name>[^(]+)(\((?<display_name>.+)\))?')
|
|
var result := regex.search(string.strip_edges())
|
|
if result:
|
|
name = result.get_string('name').strip_edges()
|
|
display_name = result.get_string('display_name').strip_edges()
|
|
|
|
|
|
func is_valid_event(string:String) -> bool:
|
|
if string.strip_edges().begins_with("label"):
|
|
return true
|
|
return false
|
|
|
|
|
|
# this is only here to provide a list of default values
|
|
# this way the module manager can add custom default overrides to this event.
|
|
func get_shortcode_parameters() -> Dictionary:
|
|
return {
|
|
#param_name : property_info
|
|
"name" : {"property": "name", "default": ""},
|
|
"display" : {"property": "display_name", "default": ""},
|
|
}
|
|
|
|
|
|
func _get_translatable_properties() -> Array:
|
|
return ["display_name"]
|
|
|
|
|
|
func _get_property_original_translation(property_name:String) -> String:
|
|
match property_name:
|
|
'display_name':
|
|
return display_name
|
|
return ''
|
|
|
|
################################################################################
|
|
## EDITOR REPRESENTATION
|
|
################################################################################
|
|
|
|
func build_event_editor():
|
|
add_header_edit('name', ValueType.SINGLELINE_TEXT, {'left_text':'Label', 'autofocus':true})
|
|
add_body_edit('display_name', ValueType.SINGLELINE_TEXT, {'left_text':'Display Name:'})
|
|
|
|
|
|
####################### CODE COMPLETION ########################################
|
|
################################################################################
|
|
|
|
func _get_start_code_completion(CodeCompletionHelper:Node, TextNode:TextEdit) -> void:
|
|
TextNode.add_code_completion_option(CodeEdit.KIND_PLAIN_TEXT, 'label', 'label ', event_color.lerp(TextNode.syntax_highlighter.normal_color, 0.3))
|
|
|
|
|
|
#################### SYNTAX HIGHLIGHTING #######################################
|
|
################################################################################
|
|
|
|
func _get_syntax_highlighting(Highlighter:SyntaxHighlighter, dict:Dictionary, line:String) -> Dictionary:
|
|
dict[line.find('label')] = {"color":event_color.lerp(Highlighter.normal_color, 0.3)}
|
|
dict[line.find('label')+5] = {"color":event_color.lerp(Highlighter.normal_color, 0.5)}
|
|
return dict
|