ORE Studio 0.0.4
Loading...
Searching...
No Matches
ClientBatchModel.hpp
1/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 *
3 * Copyright (C) 2026 Marco Craveiro <marco.craveiro@gmail.com>
4 *
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU General Public License as published by the Free Software
7 * Foundation; either version 3 of the License, or (at your option) any later
8 * version.
9 *
10 * This program is distributed in the hope that it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
13 * details.
14 *
15 * You should have received a copy of the GNU General Public License along with
16 * this program; if not, write to the Free Software Foundation, Inc., 51
17 * Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 *
19 */
20#ifndef ORES_QT_CLIENT_BATCH_MODEL_HPP
21#define ORES_QT_CLIENT_BATCH_MODEL_HPP
22
23#include <vector>
24#include <QFutureWatcher>
25#include <QAbstractTableModel>
26#include "ores.qt/AbstractClientModel.hpp"
27#include "ores.qt/ClientManager.hpp"
28#include "ores.qt/RecencyPulseManager.hpp"
29#include "ores.qt/RecencyTracker.hpp"
30#include "ores.logging/make_logger.hpp"
31#include "ores.compute.api/domain/batch.hpp"
32
33namespace ores::qt {
34
42 Q_OBJECT
43
44private:
45 inline static std::string_view logger_name =
46 "ores.qt.client_batch_model";
47
48 [[nodiscard]] static auto& lg() {
49 using namespace ores::logging;
50 static auto instance = make_logger(logger_name);
51 return instance;
52 }
53
54public:
58 enum Column {
59 ExternalRef,
60 Status,
61 Version,
62 ModifiedBy,
63 ColumnCount
64 };
65
66 explicit ClientBatchModel(ClientManager* clientManager,
67 QObject* parent = nullptr);
68 ~ClientBatchModel() override = default;
69
70 // QAbstractTableModel interface
71 int rowCount(const QModelIndex& parent = QModelIndex()) const override;
72 int columnCount(const QModelIndex& parent = QModelIndex()) const override;
73 QVariant data(const QModelIndex& index, int role = Qt::DisplayRole) const override;
74 QVariant headerData(int section, Qt::Orientation orientation,
75 int role = Qt::DisplayRole) const override;
76
80 void refresh();
81
88 const compute::domain::batch* getBatch(int row) const;
89
93 void load_page(std::uint32_t offset, std::uint32_t limit);
94
98 std::uint32_t page_size() const { return page_size_; }
99
103 void set_page_size(std::uint32_t size);
104
108 std::uint32_t total_available_count() const { return total_available_count_; }
109
110signals:
119private slots:
120 void onBatchsLoaded();
121 void onPulseStateChanged(bool isOn);
122 void onPulsingComplete();
123
124private:
125 QVariant recency_foreground_color(const std::string& code) const;
126
127 struct FetchResult {
128 bool success;
129 std::vector<compute::domain::batch> batches;
130 std::uint32_t total_available_count;
131 QString error_message;
132 QString error_details;
133 };
134
135 void fetch_batches(std::uint32_t offset, std::uint32_t limit);
136
137 ClientManager* clientManager_;
138 std::vector<compute::domain::batch> batches_;
139 QFutureWatcher<FetchResult>* watcher_;
140 std::uint32_t page_size_{100};
141 std::uint32_t total_available_count_{0};
142 bool is_fetching_{false};
143
144 using BatchKeyExtractor = std::string(*)(const compute::domain::batch&);
145 RecencyTracker<compute::domain::batch, BatchKeyExtractor> recencyTracker_;
146 RecencyPulseManager* pulseManager_;
147};
148
149}
150
151#endif
Implements logging infrastructure for ORE Studio.
Definition boost_severity.hpp:28
Qt-based graphical user interface for ORE Studio.
Definition AboutDialog.hpp:29
A logical grouping of workunits forming a financial computation batch.
Definition batch.hpp:35
Base class for all client-side entity models.
Definition AbstractClientModel.hpp:36
Model for displaying compute batches fetched from the server.
Definition ClientBatchModel.hpp:41
void set_page_size(std::uint32_t size)
Set the page size for pagination.
Definition ClientBatchModel.cpp:253
void refresh()
Refresh compute batch data from server asynchronously.
Definition ClientBatchModel.cpp:120
std::uint32_t total_available_count() const
Get the total number of records available on the server.
Definition ClientBatchModel.hpp:108
const compute::domain::batch * getBatch(int row) const
Get compute batch at the specified row.
Definition ClientBatchModel.cpp:265
void load_page(std::uint32_t offset, std::uint32_t limit)
Load a specific page of data.
Definition ClientBatchModel.cpp:146
std::uint32_t page_size() const
Get the page size used for pagination.
Definition ClientBatchModel.hpp:98
Column
Enumeration of table columns for type-safe column access.
Definition ClientBatchModel.hpp:58
Manages the lifecycle of the NATS client and login state.
Definition ClientManager.hpp:109