This repository has been archived on 2026-05-31. You can view files and clone it, but cannot push or open issues or pull requests.
powersync-app/libnymea-app/wifisetup/bluetoothdeviceinfos.h
2025-12-05 13:39:19 +01:00

124 lines
4.1 KiB
C++

// SPDX-License-Identifier: LGPL-3.0-or-later
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Copyright (C) 2013 - 2024, nymea GmbH
* Copyright (C) 2024 - 2025, chargebyte austria GmbH
*
* This file is part of libnymea-app.
*
* libnymea-app 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 3
* of the License, or (at your option) any later version.
*
* libnymea-app 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 libnymea-app. If not, see <https://www.gnu.org/licenses/>.
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#ifndef BLUETOOTHDEVICEINFOS_H
#define BLUETOOTHDEVICEINFOS_H
#include <QObject>
#include <QAbstractListModel>
#include <QSortFilterProxyModel>
#include <QUuid>
#include <QBluetoothUuid>
#include "bluetoothdeviceinfo.h"
class BluetoothDeviceInfos : public QAbstractListModel
{
Q_OBJECT
Q_PROPERTY(int count READ rowCount NOTIFY countChanged)
public:
enum BluetoothDeviceInfoRole {
BluetoothDeviceInfoRoleName = Qt::DisplayRole,
BluetoothDeviceInfoRoleAddress,
BluetoothDeviceInfoRoleLe,
BluetoothDeviceInfoRoleSignalStrength
};
Q_ENUM(BluetoothDeviceInfoRole)
explicit BluetoothDeviceInfos(QObject *parent = nullptr);
QList<BluetoothDeviceInfo *> deviceInfos();
int rowCount(const QModelIndex & parent = QModelIndex()) const;
QVariant data(const QModelIndex & index, int role = Qt::DisplayRole) const;
int count() const;
Q_INVOKABLE BluetoothDeviceInfo *get(int index) const;
void addBluetoothDeviceInfo(BluetoothDeviceInfo *deviceInfo);
Q_INVOKABLE void clearModel();
signals:
void countChanged();
protected:
QHash<int, QByteArray> roleNames() const;
private:
QList<BluetoothDeviceInfo *> m_deviceInfos;
};
class BluetoothDeviceInfosProxy: public QSortFilterProxyModel
{
Q_OBJECT
Q_PROPERTY(BluetoothDeviceInfos* model READ model WRITE setModel NOTIFY modelChanged)
Q_PROPERTY(int count READ rowCount NOTIFY countChanged)
// Workaround for allowing particular names, even if they'd fail the filters below (used for legacy compatibility)
Q_PROPERTY(QStringList nameWhitelist READ nameWhitelist WRITE setNameWhitelist NOTIFY nameWhitelistChanged)
Q_PROPERTY(bool filterForLowEnergy READ filterForLowEnergy WRITE setFilterForLowEnergy NOTIFY filterForLowEnergyChanged)
Q_PROPERTY(QString filterForServiceUUID READ filterForServiceUUID WRITE setFilterForServiceUUID NOTIFY filterForServiceUUIDChanged)
Q_PROPERTY(QString filterForName READ filterForName WRITE setFilterForName NOTIFY filterForNameChanged)
public:
BluetoothDeviceInfosProxy(QObject *parent = nullptr);
BluetoothDeviceInfos* model() const;
void setModel(BluetoothDeviceInfos *model);
QStringList nameWhitelist() const;
void setNameWhitelist(const QStringList &nameWhitelist);
bool filterForLowEnergy() const;
void setFilterForLowEnergy(bool filterForLowEnergy);
QString filterForServiceUUID() const;
void setFilterForServiceUUID(const QString &filterForServiceUUID);
QString filterForName() const;
void setFilterForName(const QString &name);
Q_INVOKABLE BluetoothDeviceInfo* get(int index) const;
signals:
void modelChanged();
void countChanged();
void nameWhitelistChanged();
void filterForLowEnergyChanged();
void filterForServiceUUIDChanged();
void filterForNameChanged();
protected:
bool filterAcceptsRow(int source_row, const QModelIndex &source_parent) const override;
private:
BluetoothDeviceInfos *m_model = nullptr;
QStringList m_nameWhitelist;
bool m_filterForLowEnergy = false;
QBluetoothUuid m_filterForServiceUUID;
QString m_filterForName;
};
#endif // BLUETOOTHDEVICEINFOS_H