ORE Studio 0.0.4
Loading...
Searching...
No Matches
ClientChangeReasonModel.hpp
1/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 *
3 * Copyright (C) 2025 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_CHANGE_REASON_MODEL_HPP
21#define ORES_QT_CLIENT_CHANGE_REASON_MODEL_HPP
22
23#include <vector>
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.dq/domain/change_reason.hpp"
31
32namespace ores::qt {
33
40class ClientChangeReasonModel final : public QAbstractTableModel {
41 Q_OBJECT
42
43private:
44 inline static std::string_view logger_name =
45 "ores.qt.client_change_reason_model";
46
47 [[nodiscard]] static auto& lg() {
48 using namespace ores::logging;
49 static auto instance = make_logger(logger_name);
50 return instance;
51 }
52
53public:
57 enum Column {
58 Code,
59 CategoryCode,
60 AppliesToAmend,
61 AppliesToDelete,
62 RequiresCommentary,
63 DisplayOrder,
64 Version,
65 RecordedBy,
66 RecordedAt,
67 ColumnCount
68 };
69
70 explicit ClientChangeReasonModel(ClientManager* clientManager,
71 QObject* parent = nullptr);
72 ~ClientChangeReasonModel() override = default;
73
74 // QAbstractTableModel interface
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;
80
84 void refresh();
85
92 const dq::domain::change_reason* getReason(int row) const;
93
94signals:
98 void dataLoaded();
99
103 void loadError(const QString& error_message, const QString& details = {});
104
105private slots:
106 void onReasonsLoaded();
107 void onPulseStateChanged(bool isOn);
108 void onPulsingComplete();
109
110private:
111 QVariant recency_foreground_color(const std::string& code) const;
112
113 struct FetchResult {
114 bool success;
115 std::vector<dq::domain::change_reason> reasons;
116 QString error_message;
117 QString error_details;
118 };
119
120 ClientManager* clientManager_;
121 std::vector<dq::domain::change_reason> reasons_;
122 QFutureWatcher<FetchResult>* watcher_;
123 bool is_fetching_{false};
124
125 // Recency highlighting
126 using ChangeReasonKeyExtractor = std::string(*)(const dq::domain::change_reason&);
127 RecencyTracker<dq::domain::change_reason, ChangeReasonKeyExtractor> recencyTracker_;
128 RecencyPulseManager* pulseManager_;
129};
130
131}
132
133#endif
Implements logging infrastructure for ORE Studio.
Definition boost_severity.hpp:28
Qt-based graphical user interface for ORE Studio.
Definition AboutDialog.hpp:35
Defines a specific reason for record changes.
Definition change_reason.hpp:47
Model for displaying change reasons fetched from the server.
Definition ClientChangeReasonModel.hpp:40
const dq::domain::change_reason * getReason(int row) const
Get reason at the specified row.
Definition ClientChangeReasonModel.cpp:248
void refresh()
Refresh reason data from server asynchronously.
Definition ClientChangeReasonModel.cpp:143
void dataLoaded()
Emitted when data has been successfully loaded.
void loadError(const QString &error_message, const QString &details={})
Emitted when an error occurs during data loading.
Column
Enumeration of table columns for type-safe column access.
Definition ClientChangeReasonModel.hpp:57
Manages the lifecycle of the network client and IO context.
Definition ClientManager.hpp:90