summaryrefslogtreecommitdiff
path: root/UI/players_list.gd
diff options
context:
space:
mode:
Diffstat (limited to 'UI/players_list.gd')
-rw-r--r--UI/players_list.gd24
1 files changed, 13 insertions, 11 deletions
diff --git a/UI/players_list.gd b/UI/players_list.gd
index 598d7ad..6bb7e14 100644
--- a/UI/players_list.gd
+++ b/UI/players_list.gd
@@ -1,35 +1,37 @@
extends PanelContainer
+@export var players: Array[Player]:
+ set(value):
+ players = value
+ update_players()
+
@onready var list: Control = %List
func _ready() -> void:
#players_list_container.visible = false
- Client.player.score_changed.connect(update_players)
Network.players_changed.connect(update_players)
- update_players()
multiplayer.peer_disconnected.connect(remove_player)
func update_players():
- for id in Network.get_ordered_player_ids():
- var player: Player = Network.get_player(id)
-
- var control: Control = list.get_node_or_null(str(id))
+ for player in players:
+ var control: Control = list.get_node_or_null(str(player.id))
if not control:
control = preload("res://UI/PlayersListItem.tscn").instantiate()
- control.name = str(id)
+ control.name = str(player.id)
control.modulate = player.get_color()
- control.get_node("%Indicator").visible = id == multiplayer.get_unique_id()
+ control.get_node("%Indicator").visible = player.id == multiplayer.get_unique_id()
list.add_child(control)
control.get_node("%ID").text = str(player.username)
- control.get_node("%ID").tooltip_text = str(id)
- control.get_node("%Score").text = str(player.score)
- list.move_child(control, Network.get_ordered_player_ids().find(id) + 1)
+ control.get_node("%ID").tooltip_text = str(player.id)
+ control.get_node("%Score").text = str(player.income)
+ list.move_child(control, Network.get_ordered_player_ids().find(player.id) + 1)
func remove_player(id):
list.remove_child(list.get_node(str(id)))
+ #players.remove_at(players.filter(func(item): return item.id == id)[0]) TODO