diff options
author | Kae <80987908+Novaenia@users.noreply.github.com> | 2023-06-20 14:33:09 +1000 |
---|---|---|
committer | Kae <80987908+Novaenia@users.noreply.github.com> | 2023-06-20 14:33:09 +1000 |
commit | 6352e8e3196f78388b6c771073f9e03eaa612673 (patch) | |
tree | e23772f79a7fbc41bc9108951e9e136857484bf4 /source/frontend/StarQuestInterface.hpp | |
parent | 6741a057e5639280d85d0f88ba26f000baa58f61 (diff) |
everything everywhere
all at once
Diffstat (limited to 'source/frontend/StarQuestInterface.hpp')
-rw-r--r-- | source/frontend/StarQuestInterface.hpp | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/source/frontend/StarQuestInterface.hpp b/source/frontend/StarQuestInterface.hpp new file mode 100644 index 0000000..d7d68e8 --- /dev/null +++ b/source/frontend/StarQuestInterface.hpp @@ -0,0 +1,95 @@ +#ifndef STAR_QUEST_INTERFACE_HPP +#define STAR_QUEST_INTERFACE_HPP + +#include "StarQuests.hpp" +#include "StarPane.hpp" + +namespace Star { + +STAR_CLASS(QuestManager); +STAR_CLASS(Player); +STAR_CLASS(Cinematic); +STAR_CLASS(UniverseClient); +STAR_CLASS(PaneManager); +STAR_CLASS(ItemBag); + +class QuestLogInterface : public Pane { +public: + QuestLogInterface(QuestManagerPtr manager, PlayerPtr player, CinematicPtr cinematic, UniverseClientPtr client); + virtual ~QuestLogInterface() {} + + virtual void displayed() override; + virtual void tick() override; + virtual PanePtr createTooltip(Vec2I const& screenPosition) override; + + void fetchData(); + + void pollDialog(PaneManager* paneManager); + +private: + WidgetPtr getSelected(); + void setSelected(WidgetPtr selected); + void toggleTracking(); + void abandon(); + void showQuests(List<QuestPtr> quests); + + QuestManagerPtr m_manager; + PlayerPtr m_player; + CinematicPtr m_cinematic; + UniverseClientPtr m_client; + + String m_trackLabel; + String m_untrackLabel; + + ItemBagPtr m_rewardItems; + int m_refreshRate; + int m_refreshTimer; +}; + +class QuestPane : public Pane { +protected: + QuestPane(QuestPtr const& quest, PlayerPtr player); + + void commonSetup(Json config, String bodyText, String const& portraitName); + virtual void close(); + virtual void accept(); + virtual PanePtr createTooltip(Vec2I const& screenPosition) override; + + QuestPtr m_quest; + PlayerPtr m_player; +}; + +class NewQuestInterface : public QuestPane { +public: + NewQuestInterface(QuestManagerPtr const& manager, QuestPtr const& quest, PlayerPtr player); + +protected: + void close() override; + void accept() override; + void dismissed() override; + +private: + QuestManagerPtr m_manager; + bool m_declined; +}; + +class QuestCompleteInterface : public QuestPane { +public: + QuestCompleteInterface(QuestPtr const& quest, PlayerPtr player, CinematicPtr cinematic); + +protected: + void close() override; + +private: + PlayerPtr m_player; + CinematicPtr m_cinematic; +}; + +class QuestFailedInterface : public QuestPane { +public: + QuestFailedInterface(QuestPtr const& quest, PlayerPtr player); +}; + +} + +#endif |