oh-my-git/scenes/card.gd

136 lines
3.3 KiB
GDScript3
Raw Normal View History

2020-10-13 13:04:12 +02:00
extends Node2D
var hovered = false
2020-10-13 13:04:12 +02:00
var dragged = false
var drag_offset
2020-10-14 00:27:37 +02:00
2020-10-27 13:14:07 +01:00
export var id = "" setget set_id
2020-10-13 17:08:37 +02:00
export var command = "" setget set_command
2020-10-14 00:27:37 +02:00
export var description = "" setget set_description
2020-10-15 15:22:38 +02:00
export var energy = 0 setget set_energy
2020-10-14 00:27:37 +02:00
2020-10-13 17:08:37 +02:00
var _first_argument = null
var _home_position = null
var _home_rotation = null
2020-10-13 17:08:37 +02:00
2020-10-15 15:22:38 +02:00
onready var energy_label = $Sprite/Energy
2020-10-13 13:04:12 +02:00
func _ready():
set_process_unhandled_input(true)
2020-10-15 15:22:38 +02:00
set_energy(energy)
2020-10-13 13:04:12 +02:00
func _process(delta):
2020-10-15 15:22:38 +02:00
if game.energy >= energy:
energy_label.modulate = Color(0.5, 1, 0.5)
else:
energy_label.modulate = Color(1, 1, 1)
modulate = Color(1, 0.5, 0.5)
2020-10-13 13:04:12 +02:00
if dragged:
var mousepos = get_viewport().get_mouse_position()
2020-10-14 14:48:38 +02:00
global_position = mousepos - drag_offset
var target_scale = 1
if hovered and not dragged:
target_scale = 1.5
scale = lerp(scale, Vector2(target_scale, target_scale), 10*delta)
2020-10-13 13:04:12 +02:00
func _unhandled_input(event):
if event is InputEventMouseButton:
if event.button_index == BUTTON_LEFT and event.pressed and hovered:
2020-10-13 13:04:12 +02:00
dragged = true
game.dragged_object = self
_turn_on_highlights()
2020-10-22 16:19:22 +02:00
$PickupSound.play()
2020-10-13 13:04:12 +02:00
drag_offset = get_viewport().get_mouse_position() - global_position
get_tree().set_input_as_handled()
modulate.a = 0.5
2020-10-13 17:08:37 +02:00
elif event.button_index == BUTTON_LEFT and !event.pressed and dragged:
2020-10-13 13:04:12 +02:00
dragged = false
game.dragged_object = null
_turn_off_highlights()
modulate.a = 1
2020-10-13 17:29:24 +02:00
if "[" in command:
2020-10-14 00:04:47 +02:00
move_back()
else:
try_play(command)
func _turn_on_highlights():
var arg_regex = RegEx.new()
arg_regex.compile("\\[(.*)\\]")
var m = arg_regex.search(command)
if m:
var types = Array(m.get_string(1).split(","))
for type in types:
for area in get_tree().get_nodes_in_group("drop_areas"):
area.highlight(type.strip_edges())
func _turn_off_highlights():
for area in get_tree().get_nodes_in_group("drop_areas"):
area.highlighted = false
func _mouse_entered():
hovered = true
z_index = 1
func _mouse_exited():
hovered = false
z_index = 0
2020-10-13 17:08:37 +02:00
func set_command(new_command):
command = new_command
2020-10-14 00:27:37 +02:00
$Label.text = command
func set_description(new_description):
description = new_description
$Description.text = description
2020-10-13 17:08:37 +02:00
2020-10-15 15:22:38 +02:00
func set_energy(new_energy):
energy = new_energy
if energy_label:
energy_label.text = str(energy)
2020-10-27 13:14:07 +01:00
func set_id(new_id):
id = new_id
var texture = load("res://cards/%s.svg" % new_id)
if texture:
$Image.texture = texture
2020-10-15 15:22:38 +02:00
2020-10-13 17:08:37 +02:00
func move_back():
position = _home_position
rotation_degrees = _home_rotation
2020-10-22 16:19:22 +02:00
$ReturnSound.play()
func dropped_on(other):
if "[" in command:
var argument
if other.type == "file":
argument = other.label
else:
argument = other.id
if (command.begins_with("git checkout") or command.begins_with("git rebase")) and argument.begins_with("refs/heads"):
argument = Array(argument.split("/")).pop_back()
var arg_regex = RegEx.new()
arg_regex.compile("\\[(.*)\\]")
var full_command = arg_regex.sub(command, argument)
try_play(full_command)
2020-10-26 19:56:52 +01:00
func try_play(full_command):
if game.energy >= energy:
var terminal = $"../../../..".terminal
terminal.send_command(full_command)
#yield(terminal, "command_done")
2020-10-22 16:19:22 +02:00
$PlaySound.play()
var particles = preload("res://scenes/card_particles.tscn").instance()
2020-10-22 16:19:22 +02:00
particles.position = position
get_parent().add_child(particles)
move_back()
game.energy -= energy
else:
move_back()