Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allows jump to be a variable, making the jump event dynamic #2495

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

kirbynator
Copy link

@kirbynator kirbynator commented Dec 20, 2024

I noticed that the jump event could not be set to a variable. This pull request is to add that feature.

How to test:

  1. create a dialogic variable in the default VAR folder.
    image

  2. create a timeline with a jump event with the name of the variable and have it jump pass an end time line event to a label with the name of what the variable is set too.
    jump {jump_demo}
    Failed
    [end_timeline]
    label variable
    Success

  3. Run the timeline. You should see the dialog that it jumped too.

@kirbynator kirbynator changed the title Allows label to be a variable, making the jump event dynamic Allows jump to be a variable, making the jump event dynamic Dec 20, 2024
@Jowan-Spooner
Copy link
Member

Hi @kirbynator, sorry for not getting back to you sooner.

I like this change, however right now it isn't working when using the visual editor at all, because the label field won't accept entries that aren't in the label list. This means adjusting the get_label_suggestions().
Something like this should work. I can add these changes myself if you prefer.

func get_label_suggestions(_filter:String="") -> Dictionary:
	var suggestions := {}
	suggestions['at the beginning'] = {'value':'', 'editor_icon':['GuiRadioUnchecked', 'EditorIcons']}
	if timeline_identifier in DialogicResourceUtil.get_label_cache().keys():
		for label in DialogicResourceUtil.get_label_cache()[timeline_identifier]:
			suggestions[label] = {'value': label, 'tooltip':label, 'editor_icon': ["ArrowRight", "EditorIcons"]}
	if _filter.begins_with("{"):
		for var_path in DialogicUtil.list_variables(DialogicUtil.get_default_variables()):
			suggestions["{"+var_path+"}"] = {'value':"{"+var_path+"}", 'icon':load("res://addons/dialogic/Editor/Images/Pieces/variable.svg")}
	return suggestions


####################### CODE COMPLETION ########################################
################################################################################

func _get_code_completion(CodeCompletionHelper:Node, TextNode:TextEdit, line:String, _word:String, symbol:String) -> void:
	if symbol == ' ' and line.count(' ') == 1:
		CodeCompletionHelper.suggest_labels(TextNode, '', '\n', event_color.lerp(TextNode.syntax_highlighter.normal_color, 0.6))
		CodeCompletionHelper.suggest_timelines(TextNode, CodeEdit.KIND_MEMBER, event_color.lerp(TextNode.syntax_highlighter.normal_color, 0.6))
	if symbol == "{":
		CodeCompletionHelper.suggest_variables(TextNode)
	if symbol == '/':
		CodeCompletionHelper.suggest_labels(TextNode, line.strip_edges().trim_prefix('jump ').trim_suffix('/'+String.chr(0xFFFF)).strip_edges(), '\n', event_color.lerp(TextNode.syntax_highlighter.normal_color, 0.6))

Note that this also adds code completion suggestions for the text editor.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Development

Successfully merging this pull request may close these issues.

2 participants