20#ifndef ORES_QT_CLIENT_INSTRUMENT_MODEL_HPP
21#define ORES_QT_CLIENT_INSTRUMENT_MODEL_HPP
24#include <QFutureWatcher>
25#include <QAbstractTableModel>
26#include "ores.qt/ClientManager.hpp"
27#include "ores.qt/RecencyPulseManager.hpp"
28#include "ores.qt/RecencyTracker.hpp"
29#include "ores.logging/make_logger.hpp"
30#include "ores.trading.api/domain/instrument.hpp"
44 inline static std::string_view logger_name =
45 "ores.qt.client_instrument_model";
47 [[nodiscard]]
static auto& lg() {
49 static auto instance = make_logger(logger_name);
71 QObject* parent =
nullptr);
75 int rowCount(
const QModelIndex& parent = QModelIndex())
const override;
76 int columnCount(
const QModelIndex& parent = QModelIndex())
const override;
77 QVariant data(
const QModelIndex& index,
int role = Qt::DisplayRole)
const override;
78 QVariant headerData(
int section, Qt::Orientation orientation,
79 int role = Qt::DisplayRole)
const override;
97 void load_page(std::uint32_t offset, std::uint32_t limit);
123 void loadError(
const QString& error_message,
const QString& details = {});
126 void onInstrumentsLoaded();
127 void onPulseStateChanged(
bool isOn);
128 void onPulsingComplete();
131 QVariant recency_foreground_color(
const std::string& key)
const;
135 std::vector<trading::domain::instrument> instruments;
136 std::uint32_t total_available_count;
137 QString error_message;
138 QString error_details;
141 void fetch_instruments(std::uint32_t offset, std::uint32_t limit);
143 ClientManager* clientManager_;
144 std::vector<trading::domain::instrument> instruments_;
145 QFutureWatcher<FetchResult>* watcher_;
146 std::uint32_t page_size_{100};
147 std::uint32_t total_available_count_{0};
148 bool is_fetching_{
false};
151 RecencyTracker<trading::domain::instrument, InstrumentKeyExtractor> recencyTracker_;
152 RecencyPulseManager* pulseManager_;
Implements logging infrastructure for ORE Studio.
Definition boost_severity.hpp:28
Qt-based graphical user interface for ORE Studio.
Definition AboutDialog.hpp:29
Model for displaying instruments fetched from the server.
Definition ClientInstrumentModel.hpp:40
void set_page_size(std::uint32_t size)
Set the page size for pagination.
Definition ClientInstrumentModel.cpp:276
void refresh()
Refresh instrument data from server asynchronously.
Definition ClientInstrumentModel.cpp:142
std::uint32_t total_available_count() const
Get the total number of records available on the server.
Definition ClientInstrumentModel.hpp:112
void dataLoaded()
Emitted when data has been successfully loaded.
void load_page(std::uint32_t offset, std::uint32_t limit)
Load a specific page of data.
Definition ClientInstrumentModel.cpp:168
void loadError(const QString &error_message, const QString &details={})
Emitted when an error occurs during data loading.
const trading::domain::instrument * getInstrument(int row) const
Get instrument at the specified row.
Definition ClientInstrumentModel.cpp:288
std::uint32_t page_size() const
Get the page size used for pagination.
Definition ClientInstrumentModel.hpp:102
Column
Enumeration of table columns for type-safe column access.
Definition ClientInstrumentModel.hpp:57
Manages the lifecycle of the NATS client and login state.
Definition ClientManager.hpp:109
Parent instrument record holding economic terms for a trade.
Definition instrument.hpp:40