notificationarea.h 2.38 KB
Newer Older
1 2 3
/* BEGIN_COMMON_COPYRIGHT_HEADER
 * (c)LGPL2+
 *
4 5
 * LXQt - a lightweight, Qt based, desktop toolset
 * https://lxqt.org
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
 *
 * Copyright: 2012 Razor team
 * Authors:
 *   Petr Vanek <petr@scribus.info>
 *
 * This program or library is free software; you can redistribute it
 * and/or modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.

 * You should have received a copy of the GNU Lesser General
 * Public License along with this library; if not, write to the
 * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
 * Boston, MA 02110-1301 USA
 *
 * END_COMMON_COPYRIGHT_HEADER */

#ifndef NOTIFICATIONAREA_H
#define NOTIFICATIONAREA_H

#include <QScrollArea>
#include "notificationlayout.h"


/*! Top level widget. Scroll area is used to ensure access
 * of all \c Notification instances (scrollable with mouse).
 */
class NotificationArea : public QScrollArea
{
    Q_OBJECT
public:

43
    explicit NotificationArea(QWidget *parent = nullptr);
44 45 46 47 48 49 50 51 52 53

    /*! An access to \c NotificationLayout to connect signals and slots in \c Notifyd
     */
    NotificationLayout* layout() { return m_layout; }

    /*! Set new settings value from \c Notifyd. There are only one settings
     * used - in \c Notifyd.
     * \param placement a string name for notification location "top-level" etc.
     * \param width set with of notifications
     * \param spacing a spacing in the \NotificationLayout
54 55
     * \param unattendedMaxNum the max. number of unattended notifications to be saved
     * \param blackList the list of apps whose unattended notifications aren't saved
56
     */
57
    void setSettings(const QString &placement, int width, int spacing, int unattendedMaxNum, const QStringList &blackList);
58 59 60 61 62 63 64 65 66 67 68 69 70 71 72

private:
    NotificationLayout *m_layout;

    QString m_placement;
    int m_spacing;

private slots:
    /*! Recalculate widget size and visibility. Slot is called from \c Notificationlayout
     * on demand (notification appear or is closed).
     */
    void setHeight(int contentHeight = -1);
};

#endif // NOTIFICATIONAREA_H