ORE Studio 0.0.4
Loading...
Searching...
No Matches
RecencyPulseManager.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_RECENCY_PULSE_MANAGER_HPP
21#define ORES_QT_RECENCY_PULSE_MANAGER_HPP
22
23#include <QTimer>
24#include <QObject>
25#include "ores.qt/export.hpp"
26
27namespace ores::qt {
28
43class ORES_QT_API RecencyPulseManager final : public QObject {
44 Q_OBJECT
45
46public:
54 explicit RecencyPulseManager(QObject* parent = nullptr,
55 int pulse_interval_ms = 500,
56 int max_pulse_cycles = 6);
57
64 void start_pulsing();
65
74 [[nodiscard]] bool is_pulse_on() const { return pulse_state_; }
75
81 [[nodiscard]] bool is_pulsing() const;
82
86 void stop_pulsing();
87
88signals:
95 void pulse_state_changed(bool is_on);
96
104
105private slots:
106 void on_timer_timeout();
107
108private:
109 QTimer* timer_;
110 bool pulse_state_{false};
111 int pulse_count_{0};
112 int pulse_interval_ms_;
113 int max_pulse_cycles_;
114};
115
116}
117
118#endif
Qt-based graphical user interface for ORE Studio.
Definition AccountController.hpp:32
Manages the pulsing animation for recently-changed items in models.
Definition RecencyPulseManager.hpp:43
void pulsing_complete()
Emitted when the pulsing animation completes all cycles.
void pulse_state_changed(bool is_on)
Emitted whenever the pulse state changes.
bool is_pulse_on() const
Check if the pulse is currently in the "on" (highlighted) state.
Definition RecencyPulseManager.hpp:74