2013-01-27 12:01:37 -08:00
|
|
|
#ifndef MWGUI_JOURNALVIEWMODEL_HPP
|
|
|
|
#define MWGUI_JOURNALVIEWMODEL_HPP
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include <memory>
|
|
|
|
#include <functional>
|
2014-03-05 17:08:58 +01:00
|
|
|
#include <stdint.h>
|
2013-01-27 12:01:37 -08:00
|
|
|
|
2018-05-24 12:53:06 +04:00
|
|
|
#include <components/misc/utf8stream.hpp>
|
|
|
|
|
2013-01-27 12:01:37 -08:00
|
|
|
namespace MWGui
|
|
|
|
{
|
|
|
|
/// View-Model for the journal GUI
|
|
|
|
///
|
|
|
|
/// This interface defines an abstract data model suited
|
2013-05-01 10:28:59 +02:00
|
|
|
/// specifically to the needs of the journal GUI. It isolates
|
2013-01-27 12:01:37 -08:00
|
|
|
/// the journal GUI from the implementation details of the
|
|
|
|
/// game data store.
|
2013-03-06 20:02:00 -08:00
|
|
|
struct JournalViewModel
|
2013-01-27 12:01:37 -08:00
|
|
|
{
|
2017-05-05 21:21:11 +02:00
|
|
|
typedef std::shared_ptr <JournalViewModel> Ptr;
|
2013-01-27 12:01:37 -08:00
|
|
|
|
2013-05-01 10:28:59 +02:00
|
|
|
typedef intptr_t QuestId;
|
|
|
|
typedef intptr_t TopicId;
|
|
|
|
typedef uint8_t const * Utf8Point;
|
|
|
|
typedef std::pair <Utf8Point, Utf8Point> Utf8Span;
|
2013-01-27 12:01:37 -08:00
|
|
|
|
|
|
|
/// The base interface for both journal entries and topics.
|
2013-03-06 20:02:00 -08:00
|
|
|
struct Entry
|
2013-01-27 12:01:37 -08:00
|
|
|
{
|
|
|
|
/// returns the body text for the journal entry
|
|
|
|
///
|
|
|
|
/// This function returns a borrowed reference to the body of the
|
|
|
|
/// journal entry. The returned reference becomes invalid when the
|
|
|
|
/// entry is destroyed.
|
2013-05-01 10:28:59 +02:00
|
|
|
virtual Utf8Span body () const = 0;
|
2013-01-27 12:01:37 -08:00
|
|
|
|
|
|
|
/// Visits each subset of text in the body, delivering the beginning
|
|
|
|
/// and end of the span relative to the body, and a valid topic ID if
|
|
|
|
/// the span represents a keyword, or zero if not.
|
2017-05-07 00:04:46 +02:00
|
|
|
virtual void visitSpans (std::function <void (TopicId, size_t, size_t)> visitor) const = 0;
|
2020-03-26 12:07:32 +04:00
|
|
|
|
|
|
|
virtual ~Entry() = default;
|
2013-01-27 12:01:37 -08:00
|
|
|
};
|
|
|
|
|
|
|
|
/// An interface to topic data.
|
2013-03-06 20:02:00 -08:00
|
|
|
struct TopicEntry : Entry
|
2013-01-27 12:01:37 -08:00
|
|
|
{
|
|
|
|
/// Returns a pre-formatted span of UTF8 encoded text representing
|
|
|
|
/// the name of the NPC this portion of dialog was heard from.
|
2013-05-01 10:28:59 +02:00
|
|
|
virtual Utf8Span source () const = 0;
|
2020-03-26 12:07:32 +04:00
|
|
|
|
|
|
|
virtual ~TopicEntry() = default;
|
2013-01-27 12:01:37 -08:00
|
|
|
};
|
|
|
|
|
|
|
|
/// An interface to journal data.
|
2013-03-06 20:02:00 -08:00
|
|
|
struct JournalEntry : Entry
|
2013-01-27 12:01:37 -08:00
|
|
|
{
|
|
|
|
/// Returns a pre-formatted span of UTF8 encoded text representing
|
|
|
|
/// the in-game date this entry was added to the journal.
|
2013-05-01 10:28:59 +02:00
|
|
|
virtual Utf8Span timestamp () const = 0;
|
2013-01-27 12:01:37 -08:00
|
|
|
|
2020-03-26 12:07:32 +04:00
|
|
|
virtual ~JournalEntry() = default;
|
|
|
|
};
|
2013-01-27 12:01:37 -08:00
|
|
|
|
|
|
|
/// called prior to journal opening
|
|
|
|
virtual void load () = 0;
|
|
|
|
|
|
|
|
/// called prior to journal closing
|
|
|
|
virtual void unload () = 0;
|
|
|
|
|
|
|
|
/// returns true if their are no journal entries to display
|
2013-02-14 21:37:33 -08:00
|
|
|
virtual bool isEmpty () const = 0;
|
2013-01-27 12:01:37 -08:00
|
|
|
|
2015-02-13 16:51:34 +01:00
|
|
|
/// walks the active and optionally completed, quests providing the name and completed status
|
2017-05-07 00:04:46 +02:00
|
|
|
virtual void visitQuestNames (bool active_only, std::function <void (const std::string&, bool)> visitor) const = 0;
|
2013-01-27 12:01:37 -08:00
|
|
|
|
2014-06-03 00:16:32 +02:00
|
|
|
/// walks over the journal entries related to all quests with the given name
|
|
|
|
/// If \a questName is empty, simply visits all journal entries
|
2017-05-07 00:04:46 +02:00
|
|
|
virtual void visitJournalEntries (const std::string& questName, std::function <void (JournalEntry const &)> visitor) const = 0;
|
2013-01-27 12:01:37 -08:00
|
|
|
|
|
|
|
/// provides the name of the topic specified by its id
|
2017-05-07 00:04:46 +02:00
|
|
|
virtual void visitTopicName (TopicId topicId, std::function <void (Utf8Span)> visitor) const = 0;
|
2013-01-27 12:01:37 -08:00
|
|
|
|
2017-11-21 12:31:23 +04:00
|
|
|
/// walks over the topics whose names start with the character
|
2018-05-24 12:53:06 +04:00
|
|
|
virtual void visitTopicNamesStartingWith (Utf8Stream::UnicodeChar character, std::function < void (const std::string&) > visitor) const = 0;
|
2013-01-27 12:01:37 -08:00
|
|
|
|
|
|
|
/// walks over the topic entries for the topic specified by its identifier
|
2017-05-07 00:04:46 +02:00
|
|
|
virtual void visitTopicEntries (TopicId topicId, std::function <void (TopicEntry const &)> visitor) const = 0;
|
2013-01-27 12:01:37 -08:00
|
|
|
|
|
|
|
// create an instance of the default journal view model implementation
|
2013-05-01 10:28:59 +02:00
|
|
|
static Ptr create ();
|
2020-03-26 12:07:32 +04:00
|
|
|
|
|
|
|
virtual ~JournalViewModel() = default;
|
2013-01-27 12:01:37 -08:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // MWGUI_JOURNALVIEWMODEL_HPP
|