##// END OF EJS Templates
Discard an added event remove it now.
perrinel -
r1314:575bb1a5728f
parent child
Show More
@@ -1,84 +1,84
1 1 #ifndef SCIQLOP_CATALOGUECONTROLLER_H
2 2 #define SCIQLOP_CATALOGUECONTROLLER_H
3 3
4 4 #include "CoreGlobal.h"
5 5
6 6 #include <Data/SqpRange.h>
7 7
8 8 #include <QLoggingCategory>
9 9 #include <QObject>
10 10 #include <QUuid>
11 11
12 12 #include <Common/spimpl.h>
13 13
14 14 #include <memory>
15 15
16 16 class DBCatalogue;
17 17 class DBEvent;
18 18 class DBEventProduct;
19 19
20 20 Q_DECLARE_LOGGING_CATEGORY(LOG_CatalogueController)
21 21
22 22 class DataSourceItem;
23 23 class Variable;
24 24
25 25 /**
26 26 * @brief The CatalogueController class aims to handle catalogues and event using the CatalogueAPI
27 27 * library.
28 28 */
29 29 class SCIQLOP_CORE_EXPORT CatalogueController : public QObject {
30 30 Q_OBJECT
31 31 public:
32 32 explicit CatalogueController(QObject *parent = 0);
33 33 virtual ~CatalogueController();
34 34
35 35 // DB
36 36 QStringList getRepositories() const;
37 37 void addDB(const QString &dbPath);
38 38 void saveDB(const QString &destinationPath, const QString &repository);
39 39
40 40 // Event
41 41 /// retrieveEvents with empty repository retrieve them from the default repository
42 42 std::list<std::shared_ptr<DBEvent> > retrieveEvents(const QString &repository) const;
43 43 std::list<std::shared_ptr<DBEvent> > retrieveAllEvents() const;
44 44
45 45 void addEvent(std::shared_ptr<DBEvent> event);
46 46 void updateEvent(std::shared_ptr<DBEvent> event);
47 47 void updateEventProduct(std::shared_ptr<DBEventProduct> eventProduct);
48 48 void removeEvent(std::shared_ptr<DBEvent> event);
49 49 // void trashEvent(std::shared_ptr<DBEvent> event);
50 50 // void restore(std::shared_ptr<DBEvent> event);
51 51 void saveEvent(std::shared_ptr<DBEvent> event);
52 void discardEvent(std::shared_ptr<DBEvent> event);
52 void discardEvent(std::shared_ptr<DBEvent> event, bool &removed);
53 53 bool eventHasChanges(std::shared_ptr<DBEvent> event) const;
54 54
55 55 // Catalogue
56 56 std::list<std::shared_ptr<DBEvent> >
57 57 retrieveEventsFromCatalogue(std::shared_ptr<DBCatalogue> catalogue) const;
58 58 // bool createCatalogue(const QString &name, QVector<QUuid> eventList);
59 59 /// retrieveEvents with empty repository retrieve them from the default repository
60 60 std::list<std::shared_ptr<DBCatalogue> > retrieveCatalogues(const QString &repository
61 61 = QString()) const;
62 62 void updateCatalogue(std::shared_ptr<DBCatalogue> catalogue);
63 63 void removeCatalogue(std::shared_ptr<DBCatalogue> catalogue);
64 64 void saveCatalogue(std::shared_ptr<DBCatalogue> catalogue);
65 65
66 66 void saveAll();
67 67 bool hasChanges() const;
68 68
69 69 /// Returns the MIME data associated to a list of variables
70 70 QByteArray mimeDataForEvents(const QVector<std::shared_ptr<DBEvent> > &events) const;
71 71
72 72 /// Returns the list of variables contained in a MIME data
73 73 QVector<std::shared_ptr<DBEvent> > eventsForMimeData(const QByteArray &mimeData) const;
74 74
75 75 public slots:
76 76 /// Manage init/end of the controller
77 77 void initialize();
78 78
79 79 private:
80 80 class CatalogueControllerPrivate;
81 81 spimpl::unique_impl_ptr<CatalogueControllerPrivate> impl;
82 82 };
83 83
84 84 #endif // SCIQLOP_CATALOGUECONTROLLER_H
@@ -1,434 +1,461
1 1 #include <Catalogue/CatalogueController.h>
2 2
3 3 #include <Variable/Variable.h>
4 4
5 5 #include <CatalogueDao.h>
6 6
7 7 #include <ComparaisonPredicate.h>
8 8 #include <CompoundPredicate.h>
9 9 #include <DBCatalogue.h>
10 10 #include <DBEvent.h>
11 11 #include <DBEventProduct.h>
12 12 #include <DBTag.h>
13 13 #include <IRequestPredicate.h>
14 14
15 15 #include <QDataStream>
16 16 #include <QMutex>
17 17 #include <QThread>
18 18
19 19 #include <QDir>
20 20 #include <QStandardPaths>
21 21
22 22 Q_LOGGING_CATEGORY(LOG_CatalogueController, "CatalogueController")
23 23
24 24 namespace {
25 25
26 26 static QString REPOSITORY_WORK_SUFFIX = QString{"_work"};
27 27 static QString REPOSITORY_TRASH_SUFFIX = QString{"_trash"};
28 28 }
29 29
30 30 class CatalogueController::CatalogueControllerPrivate {
31 31
32 32 public:
33 33 explicit CatalogueControllerPrivate(CatalogueController *parent) : m_Q{parent} {}
34 34
35 35 CatalogueDao m_CatalogueDao;
36 36
37 37 QStringList m_RepositoryList;
38 38 CatalogueController *m_Q;
39 39
40 40 QSet<QString> m_EventKeysWithChanges;
41 41
42 42 QString eventUniqueKey(const std::shared_ptr<DBEvent> &event) const;
43 43
44 44 void copyDBtoDB(const QString &dbFrom, const QString &dbTo);
45 45 QString toWorkRepository(QString repository);
46 46 QString toSyncRepository(QString repository);
47 47 void savAllDB();
48 48
49 49 void saveEvent(std::shared_ptr<DBEvent> event, bool persist = true);
50 50 void saveCatalogue(std::shared_ptr<DBCatalogue> catalogue, bool persist = true);
51 51 };
52 52
53 53 CatalogueController::CatalogueController(QObject *parent)
54 54 : impl{spimpl::make_unique_impl<CatalogueControllerPrivate>(this)}
55 55 {
56 56 qCDebug(LOG_CatalogueController()) << tr("CatalogueController construction")
57 57 << QThread::currentThread();
58 58 }
59 59
60 60 CatalogueController::~CatalogueController()
61 61 {
62 62 qCDebug(LOG_CatalogueController()) << tr("CatalogueController destruction")
63 63 << QThread::currentThread();
64 64 }
65 65
66 66 QStringList CatalogueController::getRepositories() const
67 67 {
68 68 return impl->m_RepositoryList;
69 69 }
70 70
71 71 void CatalogueController::addDB(const QString &dbPath)
72 72 {
73 73 QDir dbDir(dbPath);
74 74 if (dbDir.exists()) {
75 75 auto dirName = dbDir.dirName();
76 76
77 77 if (std::find(impl->m_RepositoryList.cbegin(), impl->m_RepositoryList.cend(), dirName)
78 78 != impl->m_RepositoryList.cend()) {
79 79 qCCritical(LOG_CatalogueController())
80 80 << tr("Impossible to addDB that is already loaded");
81 81 }
82 82
83 83 if (!impl->m_CatalogueDao.addDB(dbPath, dirName)) {
84 84 qCCritical(LOG_CatalogueController())
85 85 << tr("Impossible to addDB %1 from %2 ").arg(dirName, dbPath);
86 86 }
87 87 else {
88 88 impl->m_RepositoryList << dirName;
89 89 impl->copyDBtoDB(dirName, impl->toWorkRepository(dirName));
90 90 }
91 91 }
92 92 else {
93 93 qCCritical(LOG_CatalogueController()) << tr("Impossible to addDB that not exists: ")
94 94 << dbPath;
95 95 }
96 96 }
97 97
98 98 void CatalogueController::saveDB(const QString &destinationPath, const QString &repository)
99 99 {
100 100 if (!impl->m_CatalogueDao.saveDB(destinationPath, repository)) {
101 101 qCCritical(LOG_CatalogueController())
102 102 << tr("Impossible to saveDB %1 from %2 ").arg(repository, destinationPath);
103 103 }
104 104 }
105 105
106 106 std::list<std::shared_ptr<DBEvent> >
107 107 CatalogueController::retrieveEvents(const QString &repository) const
108 108 {
109 109 QString dbDireName = repository.isEmpty() ? REPOSITORY_DEFAULT : repository;
110 110
111 111 auto eventsShared = std::list<std::shared_ptr<DBEvent> >{};
112 112 auto events = impl->m_CatalogueDao.getEvents(impl->toWorkRepository(dbDireName));
113 113 for (auto event : events) {
114 114 eventsShared.push_back(std::make_shared<DBEvent>(event));
115 115 }
116 116 return eventsShared;
117 117 }
118 118
119 119 std::list<std::shared_ptr<DBEvent> > CatalogueController::retrieveAllEvents() const
120 120 {
121 121 auto eventsShared = std::list<std::shared_ptr<DBEvent> >{};
122 122 for (auto repository : impl->m_RepositoryList) {
123 123 eventsShared.splice(eventsShared.end(), retrieveEvents(repository));
124 124 }
125 125
126 126 return eventsShared;
127 127 }
128 128
129 129 std::list<std::shared_ptr<DBEvent> >
130 130 CatalogueController::retrieveEventsFromCatalogue(std::shared_ptr<DBCatalogue> catalogue) const
131 131 {
132 132 auto eventsShared = std::list<std::shared_ptr<DBEvent> >{};
133 133 auto events = impl->m_CatalogueDao.getCatalogueEvents(*catalogue);
134 134 for (auto event : events) {
135 135 eventsShared.push_back(std::make_shared<DBEvent>(event));
136 136 }
137 137 return eventsShared;
138 138 }
139 139
140 140 void CatalogueController::updateEvent(std::shared_ptr<DBEvent> event)
141 141 {
142 142 event->setRepository(impl->toWorkRepository(event->getRepository()));
143 143
144 144 auto uniqueId = impl->eventUniqueKey(event);
145 145 impl->m_EventKeysWithChanges.insert(uniqueId);
146 146
147 147 impl->m_CatalogueDao.updateEvent(*event);
148 148 }
149 149
150 150 void CatalogueController::updateEventProduct(std::shared_ptr<DBEventProduct> eventProduct)
151 151 {
152 152 impl->m_CatalogueDao.updateEventProduct(*eventProduct);
153 153 }
154 154
155 155 void CatalogueController::removeEvent(std::shared_ptr<DBEvent> event)
156 156 {
157 157 // Remove it from both repository and repository_work
158 158 event->setRepository(impl->toWorkRepository(event->getRepository()));
159 159 impl->m_CatalogueDao.removeEvent(*event);
160 160 event->setRepository(impl->toSyncRepository(event->getRepository()));
161 161 impl->m_CatalogueDao.removeEvent(*event);
162 162 impl->savAllDB();
163 163 }
164 164
165 165 void CatalogueController::addEvent(std::shared_ptr<DBEvent> event)
166 166 {
167 167 event->setRepository(impl->toWorkRepository(event->getRepository()));
168 168
169 169 auto eventTemp = *event;
170 170 impl->m_CatalogueDao.addEvent(eventTemp);
171 171
172 172 // Call update is necessary at the creation of add Event if it has some tags or some event
173 173 // products
174 174 if (!event->getEventProducts().empty() || !event->getTags().empty()) {
175 175
176 176 auto eventProductsTemp = eventTemp.getEventProducts();
177 177 auto eventProductTempUpdated = std::list<DBEventProduct>{};
178 178 for (auto eventProductTemp : eventProductsTemp) {
179 179 eventProductTemp.setEvent(eventTemp);
180 180 eventProductTempUpdated.push_back(eventProductTemp);
181 181 }
182 182 eventTemp.setEventProducts(eventProductTempUpdated);
183 183
184 184 impl->m_CatalogueDao.updateEvent(eventTemp);
185 185 }
186
187
188 // update event parameter
189 auto uniqIdPredicate = std::make_shared<ComparaisonPredicate>(
190 QString{"uniqId"}, event->getUniqId(), ComparaisonOperation::EQUALEQUAL);
191
192 auto workRepositoryPredicate = std::make_shared<ComparaisonPredicate>(
193 QString{"repository"}, impl->toWorkRepository(event->getRepository()),
194 ComparaisonOperation::EQUALEQUAL);
195
196 auto workPred = std::make_shared<CompoundPredicate>(CompoundOperation::AND);
197 workPred->AddRequestPredicate(uniqIdPredicate);
198 workPred->AddRequestPredicate(workRepositoryPredicate);
199
200
201 auto workEvent = impl->m_CatalogueDao.getEvent(workPred);
202 *event = workEvent;
186 203 }
187 204
188 205 void CatalogueController::saveEvent(std::shared_ptr<DBEvent> event)
189 206 {
190 207 impl->saveEvent(event, true);
191 208 impl->m_EventKeysWithChanges.remove(impl->eventUniqueKey(event));
192 209 }
193 210
194 void CatalogueController::discardEvent(std::shared_ptr<DBEvent> event)
211 void CatalogueController::discardEvent(std::shared_ptr<DBEvent> event, bool &removed)
195 212 {
196 213 auto uniqIdPredicate = std::make_shared<ComparaisonPredicate>(
197 214 QString{"uniqId"}, event->getUniqId(), ComparaisonOperation::EQUALEQUAL);
198 215
199 216 auto syncRepositoryPredicate = std::make_shared<ComparaisonPredicate>(
200 217 QString{"repository"}, impl->toSyncRepository(event->getRepository()),
201 218 ComparaisonOperation::EQUALEQUAL);
202 219
203 220 auto syncPred = std::make_shared<CompoundPredicate>(CompoundOperation::AND);
204 221 syncPred->AddRequestPredicate(uniqIdPredicate);
205 222 syncPred->AddRequestPredicate(syncRepositoryPredicate);
206 223
207 224
208 225 auto workRepositoryPredicate = std::make_shared<ComparaisonPredicate>(
209 226 QString{"repository"}, impl->toWorkRepository(event->getRepository()),
210 227 ComparaisonOperation::EQUALEQUAL);
211 228
212 229 auto workPred = std::make_shared<CompoundPredicate>(CompoundOperation::AND);
213 230 workPred->AddRequestPredicate(uniqIdPredicate);
214 231 workPred->AddRequestPredicate(workRepositoryPredicate);
215 232
216 233
217 234 auto syncEvent = impl->m_CatalogueDao.getEvent(syncPred);
218 impl->m_CatalogueDao.copyEvent(syncEvent, impl->toWorkRepository(event->getRepository()), true);
235 if (!syncEvent.getUniqId().isNull()) {
236 removed = false;
237 impl->m_CatalogueDao.copyEvent(syncEvent, impl->toWorkRepository(event->getRepository()),
238 true);
219 239
220 240 auto workEvent = impl->m_CatalogueDao.getEvent(workPred);
221 241 *event = workEvent;
222 242 impl->m_EventKeysWithChanges.remove(impl->eventUniqueKey(event));
223 243 }
244 else {
245 removed = true;
246 // Since the element wasn't in sync repository. Discard it means remove it
247 event->setRepository(impl->toWorkRepository(event->getRepository()));
248 impl->m_CatalogueDao.removeEvent(*event);
249 }
250 }
224 251
225 252 bool CatalogueController::eventHasChanges(std::shared_ptr<DBEvent> event) const
226 253 {
227 254 return impl->m_EventKeysWithChanges.contains(impl->eventUniqueKey(event));
228 255 }
229 256
230 257 std::list<std::shared_ptr<DBCatalogue> >
231 258 CatalogueController::retrieveCatalogues(const QString &repository) const
232 259 {
233 260 QString dbDireName = repository.isEmpty() ? REPOSITORY_DEFAULT : repository;
234 261
235 262 auto cataloguesShared = std::list<std::shared_ptr<DBCatalogue> >{};
236 263 auto catalogues = impl->m_CatalogueDao.getCatalogues(impl->toWorkRepository(dbDireName));
237 264 for (auto catalogue : catalogues) {
238 265 cataloguesShared.push_back(std::make_shared<DBCatalogue>(catalogue));
239 266 }
240 267 return cataloguesShared;
241 268 }
242 269
243 270 void CatalogueController::updateCatalogue(std::shared_ptr<DBCatalogue> catalogue)
244 271 {
245 272 catalogue->setRepository(impl->toWorkRepository(catalogue->getRepository()));
246 273
247 274 impl->m_CatalogueDao.updateCatalogue(*catalogue);
248 275 }
249 276
250 277 void CatalogueController::removeCatalogue(std::shared_ptr<DBCatalogue> catalogue)
251 278 {
252 279 // Remove it from both repository and repository_work
253 280 catalogue->setRepository(impl->toWorkRepository(catalogue->getRepository()));
254 281 impl->m_CatalogueDao.removeCatalogue(*catalogue);
255 282 catalogue->setRepository(impl->toSyncRepository(catalogue->getRepository()));
256 283 impl->m_CatalogueDao.removeCatalogue(*catalogue);
257 284 }
258 285
259 286 void CatalogueController::saveCatalogue(std::shared_ptr<DBCatalogue> catalogue)
260 287 {
261 288 impl->saveCatalogue(catalogue, true);
262 289 }
263 290
264 291 void CatalogueController::saveAll()
265 292 {
266 293 for (auto repository : impl->m_RepositoryList) {
267 294 // Save Event
268 295 auto events = this->retrieveEvents(repository);
269 296 for (auto event : events) {
270 297 impl->saveEvent(event, false);
271 298 }
272 299
273 300 // Save Catalogue
274 301 auto catalogues = this->retrieveCatalogues(repository);
275 302 for (auto catalogue : catalogues) {
276 303 impl->saveCatalogue(catalogue, false);
277 304 }
278 305 }
279 306
280 307 impl->savAllDB();
281 308 impl->m_EventKeysWithChanges.clear();
282 309 }
283 310
284 311 bool CatalogueController::hasChanges() const
285 312 {
286 313 return !impl->m_EventKeysWithChanges.isEmpty(); // TODO: catalogues
287 314 }
288 315
289 316 QByteArray
290 317 CatalogueController::mimeDataForEvents(const QVector<std::shared_ptr<DBEvent> > &events) const
291 318 {
292 319 auto encodedData = QByteArray{};
293 320
294 321 QMap<QString, QVariantList> idsPerRepository;
295 322 for (auto event : events) {
296 323 idsPerRepository[event->getRepository()] << event->getUniqId();
297 324 }
298 325
299 326 QDataStream stream{&encodedData, QIODevice::WriteOnly};
300 327 stream << idsPerRepository;
301 328
302 329 return encodedData;
303 330 }
304 331
305 332 QVector<std::shared_ptr<DBEvent> >
306 333 CatalogueController::eventsForMimeData(const QByteArray &mimeData) const
307 334 {
308 335 auto events = QVector<std::shared_ptr<DBEvent> >{};
309 336 QDataStream stream{mimeData};
310 337
311 338 QMap<QString, QVariantList> idsPerRepository;
312 339 stream >> idsPerRepository;
313 340
314 341 for (auto it = idsPerRepository.cbegin(); it != idsPerRepository.cend(); ++it) {
315 342 auto repository = it.key();
316 343 auto allRepositoryEvent = retrieveEvents(repository);
317 344 for (auto uuid : it.value()) {
318 345 for (auto repositoryEvent : allRepositoryEvent) {
319 346 if (uuid.toUuid() == repositoryEvent->getUniqId()) {
320 347 events << repositoryEvent;
321 348 }
322 349 }
323 350 }
324 351 }
325 352
326 353 return events;
327 354 }
328 355
329 356 void CatalogueController::initialize()
330 357 {
331 358 qCDebug(LOG_CatalogueController()) << tr("CatalogueController init")
332 359 << QThread::currentThread();
333 360
334 361 impl->m_CatalogueDao.initialize();
335 362 auto defaultRepositoryLocation
336 363 = QStandardPaths::writableLocation(QStandardPaths::AppDataLocation);
337 364
338 365 QDir defaultRepositoryLocationDir;
339 366 if (defaultRepositoryLocationDir.mkpath(defaultRepositoryLocation)) {
340 367 defaultRepositoryLocationDir.cd(defaultRepositoryLocation);
341 368 auto defaultRepository = defaultRepositoryLocationDir.absoluteFilePath(REPOSITORY_DEFAULT);
342 369
343 370 qCInfo(LOG_CatalogueController()) << tr("Persistant data loading from: ")
344 371 << defaultRepository;
345 372
346 373 QDir dbDir(defaultRepository);
347 374 impl->m_RepositoryList << REPOSITORY_DEFAULT;
348 375 if (dbDir.exists()) {
349 376 auto dirName = dbDir.dirName();
350 377
351 378 if (impl->m_CatalogueDao.addDB(defaultRepository, dirName)) {
352 379 impl->copyDBtoDB(dirName, impl->toWorkRepository(dirName));
353 380 }
354 381 }
355 382 else {
356 383 qCInfo(LOG_CatalogueController()) << tr("Initialisation of Default repository detected")
357 384 << defaultRepository;
358 385 }
359 386 }
360 387 else {
361 388 qCWarning(LOG_CatalogueController())
362 389 << tr("Cannot load the persistent default repository from ")
363 390 << defaultRepositoryLocation;
364 391 }
365 392
366 393 qCDebug(LOG_CatalogueController()) << tr("CatalogueController init END");
367 394 }
368 395
369 396 QString CatalogueController::CatalogueControllerPrivate::eventUniqueKey(
370 397 const std::shared_ptr<DBEvent> &event) const
371 398 {
372 399 return event->getUniqId().toString().append(event->getRepository());
373 400 }
374 401
375 402 void CatalogueController::CatalogueControllerPrivate::copyDBtoDB(const QString &dbFrom,
376 403 const QString &dbTo)
377 404 {
378 405 // auto cataloguesShared = std::list<std::shared_ptr<DBCatalogue> >{};
379 406 auto catalogues = m_CatalogueDao.getCatalogues(dbFrom);
380 407 auto events = m_CatalogueDao.getEvents(dbFrom);
381 408 for (auto catalogue : catalogues) {
382 409 m_CatalogueDao.copyCatalogue(catalogue, dbTo, true);
383 410 }
384 411
385 412 for (auto event : events) {
386 413 m_CatalogueDao.copyEvent(event, dbTo, true);
387 414 }
388 415 }
389 416
390 417 QString CatalogueController::CatalogueControllerPrivate::toWorkRepository(QString repository)
391 418 {
392 419 auto syncRepository = toSyncRepository(repository);
393 420
394 421 return QString("%1%2").arg(syncRepository, REPOSITORY_WORK_SUFFIX);
395 422 }
396 423
397 424 QString CatalogueController::CatalogueControllerPrivate::toSyncRepository(QString repository)
398 425 {
399 426 auto syncRepository = repository;
400 427 if (repository.endsWith(REPOSITORY_WORK_SUFFIX)) {
401 428 syncRepository.remove(REPOSITORY_WORK_SUFFIX);
402 429 }
403 430 else if (repository.endsWith(REPOSITORY_TRASH_SUFFIX)) {
404 431 syncRepository.remove(REPOSITORY_TRASH_SUFFIX);
405 432 }
406 433 return syncRepository;
407 434 }
408 435
409 436 void CatalogueController::CatalogueControllerPrivate::savAllDB()
410 437 {
411 438 for (auto repository : m_RepositoryList) {
412 439 auto defaultRepositoryLocation
413 440 = QStandardPaths::writableLocation(QStandardPaths::AppDataLocation);
414 441 m_CatalogueDao.saveDB(defaultRepositoryLocation, repository);
415 442 }
416 443 }
417 444
418 445 void CatalogueController::CatalogueControllerPrivate::saveEvent(std::shared_ptr<DBEvent> event,
419 446 bool persist)
420 447 {
421 448 m_CatalogueDao.copyEvent(*event, toSyncRepository(event->getRepository()), true);
422 449 if (persist) {
423 450 savAllDB();
424 451 }
425 452 }
426 453
427 454 void CatalogueController::CatalogueControllerPrivate::saveCatalogue(
428 455 std::shared_ptr<DBCatalogue> catalogue, bool persist)
429 456 {
430 457 m_CatalogueDao.copyCatalogue(*catalogue, toSyncRepository(catalogue->getRepository()), true);
431 458 if (persist) {
432 459 savAllDB();
433 460 }
434 461 }
@@ -1,460 +1,466
1 1 #include "Catalogue/CatalogueEventsWidget.h"
2 2 #include "ui_CatalogueEventsWidget.h"
3 3
4 4 #include <Catalogue/CatalogueController.h>
5 5 #include <Catalogue/CatalogueEventsModel.h>
6 6 #include <Catalogue/CatalogueExplorerHelper.h>
7 7 #include <CatalogueDao.h>
8 8 #include <DBCatalogue.h>
9 9 #include <SqpApplication.h>
10 10 #include <Visualization/VisualizationTabWidget.h>
11 11 #include <Visualization/VisualizationWidget.h>
12 12 #include <Visualization/VisualizationZoneWidget.h>
13 13
14 14 #include <QDialog>
15 15 #include <QDialogButtonBox>
16 16 #include <QListWidget>
17 17 #include <QMessageBox>
18 18
19 19 Q_LOGGING_CATEGORY(LOG_CatalogueEventsWidget, "CatalogueEventsWidget")
20 20
21 21 /// Fixed size of the validation column
22 22 const auto VALIDATION_COLUMN_SIZE = 35;
23 23
24 24 struct CatalogueEventsWidget::CatalogueEventsWidgetPrivate {
25 25
26 26 CatalogueEventsModel *m_Model = nullptr;
27 27 QStringList m_ZonesForTimeMode;
28 28 QString m_ZoneForGraphMode;
29 29 QVector<std::shared_ptr<DBCatalogue> > m_DisplayedCatalogues;
30 30
31 31 VisualizationWidget *m_VisualizationWidget = nullptr;
32 32
33 33 void setEvents(const QVector<std::shared_ptr<DBEvent> > &events, CatalogueEventsWidget *widget)
34 34 {
35 35 widget->ui->treeView->setSortingEnabled(false);
36 36 m_Model->setEvents(events);
37 37 widget->ui->treeView->setSortingEnabled(true);
38 38
39 39 for (auto event : events) {
40 40 if (sqpApp->catalogueController().eventHasChanges(event)) {
41 41 auto index = m_Model->indexOf(event);
42 42 widget->setEventChanges(event, true);
43 43 }
44 44 }
45 45 }
46 46
47 47 void addEvent(const std::shared_ptr<DBEvent> &event, QTreeView *treeView)
48 48 {
49 49 treeView->setSortingEnabled(false);
50 50 m_Model->addEvent(event);
51 51 treeView->setSortingEnabled(true);
52 52 }
53 53
54 54 void removeEvent(const std::shared_ptr<DBEvent> &event, QTreeView *treeView)
55 55 {
56 56 treeView->setSortingEnabled(false);
57 57 m_Model->removeEvent(event);
58 58 treeView->setSortingEnabled(true);
59 59 }
60 60
61 61 QStringList getAvailableVisualizationZoneList() const
62 62 {
63 63 if (m_VisualizationWidget) {
64 64 if (auto tab = m_VisualizationWidget->currentTabWidget()) {
65 65 return tab->availableZoneWidgets();
66 66 }
67 67 }
68 68
69 69 return QStringList{};
70 70 }
71 71
72 72 QStringList selectZone(QWidget *parent, const QStringList &selectedZones,
73 73 bool allowMultiSelection, const QPoint &location)
74 74 {
75 75 auto availableZones = getAvailableVisualizationZoneList();
76 76 if (availableZones.isEmpty()) {
77 77 return QStringList{};
78 78 }
79 79
80 80 QDialog d(parent, Qt::Tool);
81 81 d.setWindowTitle("Choose a zone");
82 82 auto layout = new QVBoxLayout{&d};
83 83 layout->setContentsMargins(0, 0, 0, 0);
84 84 auto listWidget = new QListWidget{&d};
85 85 layout->addWidget(listWidget);
86 86
87 87 QSet<QListWidgetItem *> checkedItems;
88 88 for (auto zone : availableZones) {
89 89 auto item = new QListWidgetItem{zone};
90 90 item->setFlags(Qt::ItemIsEnabled | Qt::ItemIsUserCheckable);
91 91 if (selectedZones.contains(zone)) {
92 92 item->setCheckState(Qt::Checked);
93 93 checkedItems << item;
94 94 }
95 95 else {
96 96 item->setCheckState(Qt::Unchecked);
97 97 }
98 98
99 99 listWidget->addItem(item);
100 100 }
101 101
102 102 auto buttonBox = new QDialogButtonBox{QDialogButtonBox::Ok, &d};
103 103 layout->addWidget(buttonBox);
104 104
105 105 QObject::connect(buttonBox, &QDialogButtonBox::accepted, &d, &QDialog::accept);
106 106 QObject::connect(buttonBox, &QDialogButtonBox::rejected, &d, &QDialog::reject);
107 107
108 108 QObject::connect(listWidget, &QListWidget::itemChanged,
109 109 [&checkedItems, allowMultiSelection, listWidget](auto item) {
110 110 if (item->checkState() == Qt::Checked) {
111 111 if (!allowMultiSelection) {
112 112 for (auto checkedItem : checkedItems) {
113 113 listWidget->blockSignals(true);
114 114 checkedItem->setCheckState(Qt::Unchecked);
115 115 listWidget->blockSignals(false);
116 116 }
117 117
118 118 checkedItems.clear();
119 119 }
120 120 checkedItems << item;
121 121 }
122 122 else {
123 123 checkedItems.remove(item);
124 124 }
125 125 });
126 126
127 127 QStringList result;
128 128
129 129 d.setMinimumWidth(120);
130 130 d.resize(d.minimumSizeHint());
131 131 d.move(location);
132 132 if (d.exec() == QDialog::Accepted) {
133 133 for (auto item : checkedItems) {
134 134 result += item->text();
135 135 }
136 136 }
137 137 else {
138 138 result = selectedZones;
139 139 }
140 140
141 141 return result;
142 142 }
143 143
144 144 void updateForTimeMode(QTreeView *treeView)
145 145 {
146 146 auto selectedRows = treeView->selectionModel()->selectedRows();
147 147
148 148 if (selectedRows.count() == 1) {
149 149 auto event = m_Model->getEvent(selectedRows.first());
150 150 if (event) {
151 151 if (m_VisualizationWidget) {
152 152 if (auto tab = m_VisualizationWidget->currentTabWidget()) {
153 153
154 154 for (auto zoneName : m_ZonesForTimeMode) {
155 155 if (auto zone = tab->getZoneWithName(zoneName)) {
156 156 SqpRange eventRange;
157 157 eventRange.m_TStart = event->getTStart();
158 158 eventRange.m_TEnd = event->getTEnd();
159 159 zone->setZoneRange(eventRange);
160 160 }
161 161 }
162 162 }
163 163 else {
164 164 qCWarning(LOG_CatalogueEventsWidget())
165 165 << "updateTimeZone: no tab found in the visualization";
166 166 }
167 167 }
168 168 else {
169 169 qCWarning(LOG_CatalogueEventsWidget())
170 170 << "updateTimeZone: visualization widget not found";
171 171 }
172 172 }
173 173 }
174 174 else {
175 175 qCWarning(LOG_CatalogueEventsWidget())
176 176 << "updateTimeZone: not compatible with multiple events selected";
177 177 }
178 178 }
179 179
180 180 void updateForGraphMode(QTreeView *treeView)
181 181 {
182 182 auto selectedRows = treeView->selectionModel()->selectedRows();
183 183
184 184 if (selectedRows.count() == 1) {
185 185 auto event = m_Model->getEvent(selectedRows.first());
186 186 if (m_VisualizationWidget) {
187 187 if (auto tab = m_VisualizationWidget->currentTabWidget()) {
188 188 if (auto zone = tab->getZoneWithName(m_ZoneForGraphMode)) {
189 189 // TODO
190 190 }
191 191 }
192 192 else {
193 193 qCWarning(LOG_CatalogueEventsWidget())
194 194 << "updateGraphMode: no tab found in the visualization";
195 195 }
196 196 }
197 197 else {
198 198 qCWarning(LOG_CatalogueEventsWidget())
199 199 << "updateGraphMode: visualization widget not found";
200 200 }
201 201 }
202 202 else {
203 203 qCWarning(LOG_CatalogueEventsWidget())
204 204 << "updateGraphMode: not compatible with multiple events selected";
205 205 }
206 206 }
207 207
208 208 void getSelectedItems(
209 209 QTreeView *treeView, QVector<std::shared_ptr<DBEvent> > &events,
210 210 QVector<QPair<std::shared_ptr<DBEvent>, std::shared_ptr<DBEventProduct> > > &eventProducts)
211 211 {
212 212 for (auto rowIndex : treeView->selectionModel()->selectedRows()) {
213 213 auto itemType = m_Model->itemTypeOf(rowIndex);
214 214 if (itemType == CatalogueEventsModel::ItemType::Event) {
215 215 events << m_Model->getEvent(rowIndex);
216 216 }
217 217 else if (itemType == CatalogueEventsModel::ItemType::EventProduct) {
218 218 eventProducts << qMakePair(m_Model->getParentEvent(rowIndex),
219 219 m_Model->getEventProduct(rowIndex));
220 220 }
221 221 }
222 222 }
223 223 };
224 224
225 225 CatalogueEventsWidget::CatalogueEventsWidget(QWidget *parent)
226 226 : QWidget(parent),
227 227 ui(new Ui::CatalogueEventsWidget),
228 228 impl{spimpl::make_unique_impl<CatalogueEventsWidgetPrivate>()}
229 229 {
230 230 ui->setupUi(this);
231 231
232 232 impl->m_Model = new CatalogueEventsModel{this};
233 233 ui->treeView->setModel(impl->m_Model);
234 234
235 235 ui->treeView->setSortingEnabled(true);
236 236 ui->treeView->setDragDropMode(QAbstractItemView::DragDrop);
237 237 ui->treeView->setDragEnabled(true);
238 238
239 239 connect(ui->btnTime, &QToolButton::clicked, [this](auto checked) {
240 240 if (checked) {
241 241 ui->btnChart->setChecked(false);
242 242 impl->m_ZonesForTimeMode
243 243 = impl->selectZone(this, impl->m_ZonesForTimeMode, true,
244 244 this->mapToGlobal(ui->btnTime->frameGeometry().center()));
245 245
246 246 impl->updateForTimeMode(ui->treeView);
247 247 }
248 248 });
249 249
250 250 connect(ui->btnChart, &QToolButton::clicked, [this](auto checked) {
251 251 if (checked) {
252 252 ui->btnTime->setChecked(false);
253 253 impl->m_ZoneForGraphMode
254 254 = impl->selectZone(this, {impl->m_ZoneForGraphMode}, false,
255 255 this->mapToGlobal(ui->btnChart->frameGeometry().center()))
256 256 .value(0);
257 257
258 258 impl->updateForGraphMode(ui->treeView);
259 259 }
260 260 });
261 261
262 262 connect(ui->btnRemove, &QToolButton::clicked, [this]() {
263 263 QVector<std::shared_ptr<DBEvent> > events;
264 264 QVector<QPair<std::shared_ptr<DBEvent>, std::shared_ptr<DBEventProduct> > > eventProducts;
265 265 impl->getSelectedItems(ui->treeView, events, eventProducts);
266 266
267 267 if (!events.isEmpty() && eventProducts.isEmpty()) {
268 268
269 269 if (QMessageBox::warning(this, tr("Remove Event(s)"),
270 270 tr("The selected event(s) will be completly removed "
271 271 "from the repository!\nAre you sure you want to continue?"),
272 272 QMessageBox::Yes | QMessageBox::No, QMessageBox::No)
273 273 == QMessageBox::Yes) {
274 274
275 275 for (auto event : events) {
276 276 sqpApp->catalogueController().removeEvent(event);
277 277 impl->removeEvent(event, ui->treeView);
278 278 }
279 279 }
280 280 }
281 281 });
282 282
283 283 connect(ui->treeView, &QTreeView::clicked, this, &CatalogueEventsWidget::emitSelection);
284 284 connect(ui->treeView->selectionModel(), &QItemSelectionModel::selectionChanged, this,
285 285 &CatalogueEventsWidget::emitSelection);
286 286
287 287 ui->btnRemove->setEnabled(false); // Disabled by default when nothing is selected
288 288 connect(ui->treeView->selectionModel(), &QItemSelectionModel::selectionChanged, [this]() {
289 289 auto isNotMultiSelection = ui->treeView->selectionModel()->selectedRows().count() <= 1;
290 290 ui->btnChart->setEnabled(isNotMultiSelection);
291 291 ui->btnTime->setEnabled(isNotMultiSelection);
292 292
293 293 if (isNotMultiSelection && ui->btnTime->isChecked()) {
294 294 impl->updateForTimeMode(ui->treeView);
295 295 }
296 296 else if (isNotMultiSelection && ui->btnChart->isChecked()) {
297 297 impl->updateForGraphMode(ui->treeView);
298 298 }
299 299
300 300 QVector<std::shared_ptr<DBEvent> > events;
301 301 QVector<QPair<std::shared_ptr<DBEvent>, std::shared_ptr<DBEventProduct> > > eventProducts;
302 302 impl->getSelectedItems(ui->treeView, events, eventProducts);
303 303 ui->btnRemove->setEnabled(!events.isEmpty() && eventProducts.isEmpty());
304 304 });
305 305
306 306 ui->treeView->header()->setSectionResizeMode(QHeaderView::ResizeToContents);
307 307 ui->treeView->header()->setSectionResizeMode((int)CatalogueEventsModel::Column::Tags,
308 308 QHeaderView::Stretch);
309 309 ui->treeView->header()->setSectionResizeMode((int)CatalogueEventsModel::Column::Validation,
310 310 QHeaderView::Fixed);
311 311 ui->treeView->header()->setSectionResizeMode((int)CatalogueEventsModel::Column::Name,
312 312 QHeaderView::Interactive);
313 313 ui->treeView->header()->resizeSection((int)CatalogueEventsModel::Column::Validation,
314 314 VALIDATION_COLUMN_SIZE);
315 315 ui->treeView->header()->setSortIndicatorShown(true);
316 316
317 317 connect(impl->m_Model, &CatalogueEventsModel::modelSorted, [this]() {
318 318 auto allEvents = impl->m_Model->events();
319 319 for (auto event : allEvents) {
320 320 setEventChanges(event, sqpApp->catalogueController().eventHasChanges(event));
321 321 }
322 322 });
323 323
324 324 populateWithAllEvents();
325 325 }
326 326
327 327 CatalogueEventsWidget::~CatalogueEventsWidget()
328 328 {
329 329 delete ui;
330 330 }
331 331
332 332 void CatalogueEventsWidget::setVisualizationWidget(VisualizationWidget *visualization)
333 333 {
334 334 impl->m_VisualizationWidget = visualization;
335 335 }
336 336
337 337 void CatalogueEventsWidget::addEvent(const std::shared_ptr<DBEvent> &event)
338 338 {
339 339 impl->addEvent(event, ui->treeView);
340 340 }
341 341
342 342 void CatalogueEventsWidget::setEventChanges(const std::shared_ptr<DBEvent> &event, bool hasChanges)
343 343 {
344 344 impl->m_Model->refreshEvent(event);
345 345
346 346 auto eventIndex = impl->m_Model->indexOf(event);
347 347 auto validationIndex
348 348 = eventIndex.sibling(eventIndex.row(), (int)CatalogueEventsModel::Column::Validation);
349 349
350 350 if (validationIndex.isValid()) {
351 351 if (hasChanges) {
352 352 if (ui->treeView->indexWidget(validationIndex) == nullptr) {
353 353 auto widget = CatalogueExplorerHelper::buildValidationWidget(
354 354 ui->treeView,
355 355 [this, event]() {
356 356 sqpApp->catalogueController().saveEvent(event);
357 357 setEventChanges(event, false);
358 358 },
359 359 [this, event]() {
360 sqpApp->catalogueController().discardEvent(event);
360 bool removed = false;
361 sqpApp->catalogueController().discardEvent(event, removed);
362 if (removed) {
363 impl->m_Model->removeEvent(event);
364 }
365 else {
361 366 setEventChanges(event, false);
362 367 impl->m_Model->refreshEvent(event, true);
368 }
363 369 emitSelection();
364 370 });
365 371 ui->treeView->setIndexWidget(validationIndex, widget);
366 372 }
367 373 }
368 374 else {
369 375 // Note: the widget is destroyed
370 376 ui->treeView->setIndexWidget(validationIndex, nullptr);
371 377 }
372 378 }
373 379 else {
374 380 qCWarning(LOG_CatalogueEventsWidget())
375 381 << "setEventChanges: the event is not displayed in the model.";
376 382 }
377 383 }
378 384
379 385 QVector<std::shared_ptr<DBCatalogue> > CatalogueEventsWidget::displayedCatalogues() const
380 386 {
381 387 return impl->m_DisplayedCatalogues;
382 388 }
383 389
384 390 bool CatalogueEventsWidget::isAllEventsDisplayed() const
385 391 {
386 392 return impl->m_DisplayedCatalogues.isEmpty() && !impl->m_Model->events().isEmpty();
387 393 }
388 394
389 395 bool CatalogueEventsWidget::isEventDisplayed(const std::shared_ptr<DBEvent> &event) const
390 396 {
391 397 return impl->m_Model->indexOf(event).isValid();
392 398 }
393 399
394 400 void CatalogueEventsWidget::populateWithCatalogues(
395 401 const QVector<std::shared_ptr<DBCatalogue> > &catalogues)
396 402 {
397 403 impl->m_DisplayedCatalogues = catalogues;
398 404
399 405 QSet<QUuid> eventIds;
400 406 QVector<std::shared_ptr<DBEvent> > events;
401 407
402 408 for (auto catalogue : catalogues) {
403 409 auto catalogueEvents = sqpApp->catalogueController().retrieveEventsFromCatalogue(catalogue);
404 410 for (auto event : catalogueEvents) {
405 411 if (!eventIds.contains(event->getUniqId())) {
406 412 events << event;
407 413 eventIds.insert(event->getUniqId());
408 414 }
409 415 }
410 416 }
411 417
412 418 impl->setEvents(events, this);
413 419 }
414 420
415 421 void CatalogueEventsWidget::populateWithAllEvents()
416 422 {
417 423 impl->m_DisplayedCatalogues.clear();
418 424
419 425 auto allEvents = sqpApp->catalogueController().retrieveAllEvents();
420 426
421 427 QVector<std::shared_ptr<DBEvent> > events;
422 428 for (auto event : allEvents) {
423 429 events << event;
424 430 }
425 431
426 432 impl->setEvents(events, this);
427 433 }
428 434
429 435 void CatalogueEventsWidget::clear()
430 436 {
431 437 impl->m_DisplayedCatalogues.clear();
432 438 impl->setEvents({}, this);
433 439 }
434 440
435 441 void CatalogueEventsWidget::refresh()
436 442 {
437 443 if (impl->m_DisplayedCatalogues.isEmpty()) {
438 444 populateWithAllEvents();
439 445 }
440 446 else {
441 447 populateWithCatalogues(impl->m_DisplayedCatalogues);
442 448 }
443 449 }
444 450
445 451 void CatalogueEventsWidget::emitSelection()
446 452 {
447 453 QVector<std::shared_ptr<DBEvent> > events;
448 454 QVector<QPair<std::shared_ptr<DBEvent>, std::shared_ptr<DBEventProduct> > > eventProducts;
449 455 impl->getSelectedItems(ui->treeView, events, eventProducts);
450 456
451 457 if (!events.isEmpty() && eventProducts.isEmpty()) {
452 458 emit eventsSelected(events);
453 459 }
454 460 else if (events.isEmpty() && !eventProducts.isEmpty()) {
455 461 emit eventProductsSelected(eventProducts);
456 462 }
457 463 else {
458 464 emit selectionCleared();
459 465 }
460 466 }
@@ -1,211 +1,211
1 1 #include "Catalogue/CatalogueInspectorWidget.h"
2 2 #include "ui_CatalogueInspectorWidget.h"
3 3
4 4 #include <Common/DateUtils.h>
5 5 #include <DBCatalogue.h>
6 6 #include <DBEvent.h>
7 7 #include <DBEventProduct.h>
8 8 #include <DBTag.h>
9 9
10 10 struct CatalogueInspectorWidget::CatalogueInspectorWidgetPrivate {
11 11 std::shared_ptr<DBCatalogue> m_DisplayedCatalogue = nullptr;
12 12 std::shared_ptr<DBEvent> m_DisplayedEvent = nullptr;
13 13 std::shared_ptr<DBEventProduct> m_DisplayedEventProduct = nullptr;
14 14
15 15 void connectCatalogueUpdateSignals(CatalogueInspectorWidget *inspector,
16 16 Ui::CatalogueInspectorWidget *ui);
17 17 void connectEventUpdateSignals(CatalogueInspectorWidget *inspector,
18 18 Ui::CatalogueInspectorWidget *ui);
19 19 };
20 20
21 21 CatalogueInspectorWidget::CatalogueInspectorWidget(QWidget *parent)
22 22 : QWidget(parent),
23 23 ui(new Ui::CatalogueInspectorWidget),
24 24 impl{spimpl::make_unique_impl<CatalogueInspectorWidgetPrivate>()}
25 25 {
26 26 ui->setupUi(this);
27 27 showPage(Page::Empty);
28 28
29 29 impl->connectCatalogueUpdateSignals(this, ui);
30 30 impl->connectEventUpdateSignals(this, ui);
31 31 }
32 32
33 33 CatalogueInspectorWidget::~CatalogueInspectorWidget()
34 34 {
35 35 delete ui;
36 36 }
37 37
38 38 void CatalogueInspectorWidget::CatalogueInspectorWidgetPrivate::connectCatalogueUpdateSignals(
39 39 CatalogueInspectorWidget *inspector, Ui::CatalogueInspectorWidget *ui)
40 40 {
41 41 connect(ui->leCatalogueName, &QLineEdit::editingFinished, [ui, inspector, this]() {
42 42 if (ui->leCatalogueName->text() != m_DisplayedCatalogue->getName()) {
43 43 m_DisplayedCatalogue->setName(ui->leCatalogueName->text());
44 44 emit inspector->catalogueUpdated(m_DisplayedCatalogue);
45 45 }
46 46 });
47 47
48 48 connect(ui->leCatalogueAuthor, &QLineEdit::editingFinished, [ui, inspector, this]() {
49 49 if (ui->leCatalogueAuthor->text() != m_DisplayedCatalogue->getAuthor()) {
50 50 m_DisplayedCatalogue->setAuthor(ui->leCatalogueAuthor->text());
51 51 emit inspector->catalogueUpdated(m_DisplayedCatalogue);
52 52 }
53 53 });
54 54 }
55 55
56 56 void CatalogueInspectorWidget::CatalogueInspectorWidgetPrivate::connectEventUpdateSignals(
57 57 CatalogueInspectorWidget *inspector, Ui::CatalogueInspectorWidget *ui)
58 58 {
59 59 connect(ui->leEventName, &QLineEdit::editingFinished, [ui, inspector, this]() {
60 60 if (ui->leEventName->text() != m_DisplayedEvent->getName()) {
61 61 m_DisplayedEvent->setName(ui->leEventName->text());
62 62 emit inspector->eventUpdated(m_DisplayedEvent);
63 63 }
64 64 });
65 65
66 66 connect(ui->leEventTags, &QLineEdit::editingFinished, [ui, inspector, this]() {
67 auto tags = ui->leEventTags->text().split(QRegExp("\\s+"));
67 auto tags = ui->leEventTags->text().split(QRegExp("\\s+"), QString::SkipEmptyParts);
68 68 std::list<QString> tagNames;
69 69 for (auto tag : tags) {
70 70 tagNames.push_back(tag);
71 71 }
72 72
73 73 if (m_DisplayedEvent->getTagsNames() != tagNames) {
74 74 m_DisplayedEvent->setTagsNames(tagNames);
75 75 emit inspector->eventUpdated(m_DisplayedEvent);
76 76 }
77 77 });
78 78
79 79 connect(ui->leEventProduct, &QLineEdit::editingFinished, [ui, inspector, this]() {
80 80 if (ui->leEventProduct->text() != m_DisplayedEventProduct->getProductId()) {
81 81 auto oldProductId = m_DisplayedEventProduct->getProductId();
82 82 m_DisplayedEventProduct->setProductId(ui->leEventProduct->text());
83 83
84 84 auto eventProducts = m_DisplayedEvent->getEventProducts();
85 85 for (auto &eventProduct : eventProducts) {
86 86 if (eventProduct.getProductId() == oldProductId) {
87 87 eventProduct.setProductId(m_DisplayedEventProduct->getProductId());
88 88 }
89 89 }
90 90 m_DisplayedEvent->setEventProducts(eventProducts);
91 91
92 92 emit inspector->eventUpdated(m_DisplayedEvent);
93 93 }
94 94 });
95 95
96 96 connect(ui->dateTimeEventTStart, &QDateTimeEdit::editingFinished, [ui, inspector, this]() {
97 97 auto time = DateUtils::secondsSinceEpoch(ui->dateTimeEventTStart->dateTime());
98 98 if (time != m_DisplayedEventProduct->getTStart()) {
99 99 m_DisplayedEventProduct->setTStart(time);
100 100
101 101 auto eventProducts = m_DisplayedEvent->getEventProducts();
102 102 for (auto &eventProduct : eventProducts) {
103 103 if (eventProduct.getProductId() == m_DisplayedEventProduct->getProductId()) {
104 104 eventProduct.setTStart(m_DisplayedEventProduct->getTStart());
105 105 }
106 106 }
107 107 m_DisplayedEvent->setEventProducts(eventProducts);
108 108
109 109 emit inspector->eventUpdated(m_DisplayedEvent);
110 110 }
111 111 });
112 112
113 113 connect(ui->dateTimeEventTEnd, &QDateTimeEdit::editingFinished, [ui, inspector, this]() {
114 114 auto time = DateUtils::secondsSinceEpoch(ui->dateTimeEventTEnd->dateTime());
115 115 if (time != m_DisplayedEventProduct->getTEnd()) {
116 116 m_DisplayedEventProduct->setTEnd(time);
117 117
118 118 auto eventProducts = m_DisplayedEvent->getEventProducts();
119 119 for (auto &eventProduct : eventProducts) {
120 120 if (eventProduct.getProductId() == m_DisplayedEventProduct->getProductId()) {
121 121 eventProduct.setTEnd(m_DisplayedEventProduct->getTEnd());
122 122 }
123 123 }
124 124 m_DisplayedEvent->setEventProducts(eventProducts);
125 125
126 126 emit inspector->eventUpdated(m_DisplayedEvent);
127 127 }
128 128 });
129 129 }
130 130
131 131 void CatalogueInspectorWidget::showPage(CatalogueInspectorWidget::Page page)
132 132 {
133 133 ui->stackedWidget->setCurrentIndex(static_cast<int>(page));
134 134 }
135 135
136 136 CatalogueInspectorWidget::Page CatalogueInspectorWidget::currentPage() const
137 137 {
138 138 return static_cast<Page>(ui->stackedWidget->currentIndex());
139 139 }
140 140
141 141 void CatalogueInspectorWidget::setEvent(const std::shared_ptr<DBEvent> &event)
142 142 {
143 143 impl->m_DisplayedEvent = event;
144 144
145 145 blockSignals(true);
146 146
147 147 showPage(Page::EventProperties);
148 148 ui->leEventName->setEnabled(true);
149 149 ui->leEventName->setText(event->getName());
150 150 ui->leEventProduct->setEnabled(false);
151 151 ui->leEventProduct->setText(
152 152 QString::number(event->getEventProducts().size()).append(" product(s)"));
153 153
154 154 QString tagList;
155 155 auto tags = event->getTagsNames();
156 156 for (auto tag : tags) {
157 157 tagList += tag;
158 158 tagList += ' ';
159 159 }
160 160
161 161 ui->leEventTags->setEnabled(true);
162 162 ui->leEventTags->setText(tagList);
163 163
164 164 ui->dateTimeEventTStart->setEnabled(false);
165 165 ui->dateTimeEventTEnd->setEnabled(false);
166 166
167 167 ui->dateTimeEventTStart->setDateTime(DateUtils::dateTime(event->getTStart()));
168 168 ui->dateTimeEventTEnd->setDateTime(DateUtils::dateTime(event->getTEnd()));
169 169
170 170 blockSignals(false);
171 171 }
172 172
173 173 void CatalogueInspectorWidget::setEventProduct(const std::shared_ptr<DBEvent> &event,
174 174 const std::shared_ptr<DBEventProduct> &eventProduct)
175 175 {
176 176
177 177 impl->m_DisplayedEvent = event;
178 178 impl->m_DisplayedEventProduct = eventProduct;
179 179
180 180 blockSignals(true);
181 181
182 182 showPage(Page::EventProperties);
183 183 ui->leEventName->setEnabled(false);
184 184 ui->leEventName->setText(event->getName());
185 185 ui->leEventProduct->setEnabled(false);
186 186 ui->leEventProduct->setText(eventProduct->getProductId());
187 187
188 188 ui->leEventTags->setEnabled(false);
189 189 ui->leEventTags->clear();
190 190
191 191 ui->dateTimeEventTStart->setEnabled(true);
192 192 ui->dateTimeEventTEnd->setEnabled(true);
193 193
194 194 ui->dateTimeEventTStart->setDateTime(DateUtils::dateTime(eventProduct->getTStart()));
195 195 ui->dateTimeEventTEnd->setDateTime(DateUtils::dateTime(eventProduct->getTEnd()));
196 196
197 197 blockSignals(false);
198 198 }
199 199
200 200 void CatalogueInspectorWidget::setCatalogue(const std::shared_ptr<DBCatalogue> &catalogue)
201 201 {
202 202 impl->m_DisplayedCatalogue = catalogue;
203 203
204 204 blockSignals(true);
205 205
206 206 showPage(Page::CatalogueProperties);
207 207 ui->leCatalogueName->setText(catalogue->getName());
208 208 ui->leCatalogueAuthor->setText(catalogue->getAuthor());
209 209
210 210 blockSignals(false);
211 211 }
General Comments 0
You need to be logged in to leave comments. Login now