127 lines
4.0 KiB
GDScript
127 lines
4.0 KiB
GDScript
|
@tool
|
||
|
extends Button
|
||
|
|
||
|
const DialogueConstants = preload("../constants.gd")
|
||
|
const DialogueSettings = preload("../settings.gd")
|
||
|
|
||
|
const REMOTE_RELEASES_URL = "https://api.github.com/repos/nathanhoad/godot_dialogue_manager/releases"
|
||
|
|
||
|
|
||
|
@onready var http_request: HTTPRequest = $HTTPRequest
|
||
|
@onready var download_dialog: AcceptDialog = $DownloadDialog
|
||
|
@onready var download_update_panel = $DownloadDialog/DownloadUpdatePanel
|
||
|
@onready var needs_reload_dialog: AcceptDialog = $NeedsReloadDialog
|
||
|
@onready var update_failed_dialog: AcceptDialog = $UpdateFailedDialog
|
||
|
@onready var timer: Timer = $Timer
|
||
|
|
||
|
# The main editor plugin
|
||
|
var editor_plugin: EditorPlugin
|
||
|
|
||
|
var needs_reload: bool = false
|
||
|
|
||
|
# A lambda that gets called just before refreshing the plugin. Return false to stop the reload.
|
||
|
var on_before_refresh: Callable = func(): return true
|
||
|
|
||
|
|
||
|
func _ready() -> void:
|
||
|
hide()
|
||
|
apply_theme()
|
||
|
|
||
|
# Check for updates on GitHub
|
||
|
check_for_update()
|
||
|
|
||
|
# Check again every few hours
|
||
|
timer.start(60 * 60 * 12)
|
||
|
|
||
|
|
||
|
# Convert a version number to an actually comparable number
|
||
|
func version_to_number(version: String) -> int:
|
||
|
var bits = version.split(".")
|
||
|
return bits[0].to_int() * 1000000 + bits[1].to_int() * 1000 + bits[2].to_int()
|
||
|
|
||
|
|
||
|
func apply_theme() -> void:
|
||
|
var color: Color = get_theme_color("success_color", "Editor")
|
||
|
|
||
|
if needs_reload:
|
||
|
color = get_theme_color("error_color", "Editor")
|
||
|
icon = get_theme_icon("Reload", "EditorIcons")
|
||
|
add_theme_color_override("icon_normal_color", color)
|
||
|
add_theme_color_override("icon_focus_color", color)
|
||
|
add_theme_color_override("icon_hover_color", color)
|
||
|
|
||
|
add_theme_color_override("font_color", color)
|
||
|
add_theme_color_override("font_focus_color", color)
|
||
|
add_theme_color_override("font_hover_color", color)
|
||
|
|
||
|
|
||
|
func check_for_update() -> void:
|
||
|
if DialogueSettings.get_user_value("check_for_updates", true):
|
||
|
http_request.request(REMOTE_RELEASES_URL)
|
||
|
|
||
|
|
||
|
### Signals
|
||
|
|
||
|
|
||
|
func _on_http_request_request_completed(result: int, response_code: int, headers: PackedStringArray, body: PackedByteArray) -> void:
|
||
|
if result != HTTPRequest.RESULT_SUCCESS: return
|
||
|
|
||
|
var current_version: String = editor_plugin.get_version()
|
||
|
|
||
|
# Work out the next version from the releases information on GitHub
|
||
|
var response = JSON.parse_string(body.get_string_from_utf8())
|
||
|
if typeof(response) != TYPE_ARRAY: return
|
||
|
|
||
|
# GitHub releases are in order of creation, not order of version
|
||
|
var versions = (response as Array).filter(func(release):
|
||
|
var version: String = release.tag_name.substr(1)
|
||
|
return version_to_number(version) > version_to_number(current_version)
|
||
|
)
|
||
|
if versions.size() > 0:
|
||
|
download_update_panel.next_version_release = versions[0]
|
||
|
text = DialogueConstants.translate(&"update.available").format({ version = versions[0].tag_name.substr(1) })
|
||
|
show()
|
||
|
|
||
|
|
||
|
func _on_update_button_pressed() -> void:
|
||
|
if needs_reload:
|
||
|
var will_refresh = on_before_refresh.call()
|
||
|
if will_refresh:
|
||
|
editor_plugin.get_editor_interface().restart_editor(true)
|
||
|
else:
|
||
|
var scale: float = editor_plugin.get_editor_interface().get_editor_scale()
|
||
|
download_dialog.min_size = Vector2(300, 250) * scale
|
||
|
download_dialog.popup_centered()
|
||
|
|
||
|
|
||
|
func _on_download_dialog_close_requested() -> void:
|
||
|
download_dialog.hide()
|
||
|
|
||
|
|
||
|
func _on_download_update_panel_updated(updated_to_version: String) -> void:
|
||
|
download_dialog.hide()
|
||
|
|
||
|
needs_reload_dialog.dialog_text = DialogueConstants.translate(&"update.needs_reload")
|
||
|
needs_reload_dialog.ok_button_text = DialogueConstants.translate(&"update.reload_ok_button")
|
||
|
needs_reload_dialog.cancel_button_text = DialogueConstants.translate(&"update.reload_cancel_button")
|
||
|
needs_reload_dialog.popup_centered()
|
||
|
|
||
|
needs_reload = true
|
||
|
text = DialogueConstants.translate(&"update.reload_project")
|
||
|
apply_theme()
|
||
|
|
||
|
|
||
|
func _on_download_update_panel_failed() -> void:
|
||
|
download_dialog.hide()
|
||
|
update_failed_dialog.dialog_text = DialogueConstants.translate(&"update.failed")
|
||
|
update_failed_dialog.popup_centered()
|
||
|
|
||
|
|
||
|
func _on_needs_reload_dialog_confirmed() -> void:
|
||
|
editor_plugin.get_editor_interface().restart_editor(true)
|
||
|
|
||
|
|
||
|
func _on_timer_timeout() -> void:
|
||
|
if not needs_reload:
|
||
|
check_for_update()
|