Quest system base
This commit is contained in:
parent
37cd28d611
commit
8a40de576e
20 changed files with 178 additions and 9 deletions
|
|
@ -8,10 +8,13 @@ const SELL_FETCH = "BASE_FETCH_SELL"
|
|||
const BUY_ITEM = "BASE_BUY_ITEM"
|
||||
## This message will trigger dialogue to get selected item data
|
||||
const SELL_ITEM = "BASE_SELL_ITEM"
|
||||
## This message will trigger quest node to make answer format
|
||||
const TAKE_QUEST = "BASE_TAKE_QUEST"
|
||||
|
||||
@onready var dialogue = $DialogueView
|
||||
@onready var buy_sell = $"../../BuySell"
|
||||
@onready var actions_menu = $"../Actions/ActionsMenu"
|
||||
@onready var quest = $"../../Quest"
|
||||
|
||||
func _ready():
|
||||
var tween = create_tween() \
|
||||
|
|
@ -40,6 +43,8 @@ func send_message(msg: Message):
|
|||
var item_name = list[id].name
|
||||
format["amount"] = actions_menu.buy_sell_amount
|
||||
format["item_name"] = item_name
|
||||
TAKE_QUEST:
|
||||
format["answer"] = quest.answer
|
||||
var new_msg = tr(msg.fact + "_RECEIVED").format(format)
|
||||
var old_len = len(dialogue.get_parsed_text())
|
||||
dialogue.append_text(new_msg)
|
||||
|
|
|
|||
|
|
@ -4,9 +4,44 @@ var base: Base
|
|||
|
||||
var quest: Quest
|
||||
|
||||
const NO_QUEST = "BASE_TAKE_QUEST_FAILED"
|
||||
const HAS_QUEST = "BASE_TAKE_QUEST_SUCCEED"
|
||||
const QUEST_TYPE = {
|
||||
Quest.Type.Elimination: "BASE_QUEST_ELIMINATION",
|
||||
Quest.Type.Delivery: "BASE_QUEST_DELIVERY"
|
||||
}
|
||||
const RESTRICTIONS = {
|
||||
Quest.Restriction.NoDeaths: "BASE_QUEST_RESTRICTION_NO_DEATHS",
|
||||
Quest.Restriction.NoWeapon: "BASE_QUEST_RESTRICTION_NO_WEAPON",
|
||||
Quest.Restriction.Timer: "BASE_QUEST_RESTRICTION_TIMER"
|
||||
}
|
||||
var has_quest: bool = false
|
||||
var answer: String = ""
|
||||
|
||||
func _ready():
|
||||
get_tree().create_timer(0.05).timeout.connect(fetch_quest)
|
||||
|
||||
func fetch_quest():
|
||||
base = get_parent().base
|
||||
quest = base.quest
|
||||
make_answer(quest)
|
||||
|
||||
func make_answer(quest: Quest):
|
||||
has_quest = quest != null
|
||||
if !has_quest:
|
||||
answer = tr(NO_QUEST)
|
||||
return
|
||||
var quest_format = {}
|
||||
match quest.type:
|
||||
Quest.Type.Elimination:
|
||||
quest_format["amount"] = quest.progress_max
|
||||
quest_format["target_class"] = tr(quest.data["target_class"])
|
||||
Quest.Type.Delivery:
|
||||
quest_format["base_name"] = tr(quest.data["base_name"])
|
||||
var restrictions = ""
|
||||
for restriction in quest.restrictions:
|
||||
restrictions += tr(RESTRICTIONS[restriction]) + "\n"
|
||||
quest_format["restrictions"] = restrictions
|
||||
var quest_info = tr(QUEST_TYPE[quest.type]).format(quest_format)
|
||||
var final_format = {"quest_info": quest_info}
|
||||
answer = tr(HAS_QUEST).format(final_format)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue