Clear designation tile-highlight when jobs complete

Each entity completion handler (wall/floor/door/bed/torch/workbench/crate
/tree/rock/big_rock/grave_slot) now calls World.clear_designation_at(tile)
so the orange/blue/etc. highlight overlay disappears with the job.
BigRock iterates its footprint to clear all four tiles.

World.designation_ctl is set during the scene boot wire-up; the helper
no-ops when the controller is absent (e.g. headless tests).
This commit is contained in:
megaproxy 2026-05-15 19:31:55 +01:00
parent 6abd53c6f5
commit f67c12c51f
13 changed files with 29 additions and 0 deletions

View file

@ -279,6 +279,7 @@ func _complete() -> void:
if sprite != null:
sprite.modulate.a = 1.0
queue_redraw()
World.clear_designation_at(tile)
Audit.log("bed", "%s built at %s" % [label_text, tile])
# Phase 13 — notify BeautySystem so nearby tile beauty scores update.
var bs = World.get("beauty_system")

View file

@ -149,6 +149,9 @@ func mined() -> void:
Audit.log("big_rock", "mined 2×2 at %s; %d stone drops" % [origin_tile, STONE_DROPS_ON_MINE])
if Audio != null:
Audio.play_sfx(&"mine_tick")
# BigRocks span 2×2 — clear the designation stamp from every footprint tile.
for ft in footprint_tiles():
World.clear_designation_at(ft)
queue_free()

View file

@ -181,4 +181,5 @@ func _complete() -> void:
if sprite != null:
sprite.modulate.a = 1.0
queue_redraw()
World.clear_designation_at(tile)
Audit.log("door", "door completed at %s" % tile)

View file

@ -172,4 +172,5 @@ func _complete() -> void:
# Floors do NOT block pathfinding — no pathfinder call here.
World.mark_floor_tile(tile, floor_material)
queue_redraw()
World.clear_designation_at(tile)
Audit.log("floor", "%s floor completed at %s" % [floor_material, tile])

View file

@ -224,4 +224,5 @@ func from_dict(d: Dictionary) -> void:
func _complete_dig() -> void:
_dug = true
queue_redraw()
World.clear_designation_at(tile)
Audit.log("grave_slot", "grave dug at %s (ready for burial)" % tile)

View file

@ -124,6 +124,7 @@ func mined() -> void:
Audit.log("rock", "mined at %s; %d stone drop" % [tile, STONE_DROPS_ON_MINE])
if Audio != null:
Audio.play_sfx(&"mine_tick")
World.clear_designation_at(tile)
queue_free()

View file

@ -245,6 +245,7 @@ func _complete() -> void:
if _light != null:
_light.enabled = _is_on
queue_redraw()
World.clear_designation_at(tile)
Audit.log("torch", "built at %s" % tile)
# Phase 13 — notify BeautySystem so nearby tile beauty scores update.
var bs = World.get("beauty_system")

View file

@ -119,6 +119,7 @@ func fell() -> void:
Audit.log("tree", "felled at %s; %d wood drops" % [tile, drops_count])
if Audio != null:
Audio.play_sfx(&"tree_fell")
World.clear_designation_at(tile)
queue_free()

View file

@ -241,4 +241,5 @@ func _complete() -> void:
queue_redraw()
queue_redraw()
World.clear_designation_at(tile)
Audit.log("wall", "%s wall completed at %s" % [wall_material, tile])

View file

@ -419,6 +419,7 @@ func _complete() -> void:
if _light != null:
_light.enabled = is_on()
queue_redraw()
World.clear_designation_at(tile)
Audit.log("workbench", "%s built at %s" % [label_text, tile])
# Phase 13 — notify BeautySystem so nearby tile beauty scores update.
# Hearth gets base beauty 4 (warm glow); other benches get 1.

View file

@ -143,6 +143,7 @@ func on_build_tick() -> void:
if build_progress >= BUILD_TICKS:
_completed = true
emit_signal("contents_changed")
World.clear_designation_at(tile)
Audit.log("crate", "built at %s (capacity %d)" % [tile, CAPACITY])
queue_redraw()

View file

@ -185,6 +185,9 @@ func _ready() -> void:
# Designation: bind the paint surface + the Selection guard.
designation_ctl.bind(designation_layer, selection)
# Expose on the autoload so entities can clear their ghost stamp on
# completion (Tree.fell, Wall._complete, etc.).
World.designation_ctl = designation_ctl
# Register all 10 providers — Decision iterates by .priority desc.
# doctor=9 > sleep=8 > eat=7 > construction=6 > chop=5 ≈ plant=5 > mine=4