1
0
Fork 0
mirror of https://github.com/HenkKalkwater/harbour-sailfin.git synced 2024-11-26 10:55:17 +00:00
harbour-sailfin/core/include/JellyfinQt/DTO/sendcommand.h

111 lines
3.6 KiB
C++

/*
* Sailfin: a Jellyfin client written using Qt
* Copyright (C) 2021 Chris Josten and the Sailfin Contributors.
*
* This 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
*/
/*
* WARNING: THIS IS AN AUTOMATICALLY GENERATED FILE! PLEASE DO NOT EDIT THIS, AS YOUR EDITS WILL GET
* OVERWRITTEN AT SOME POINT!
*
* If there is a bug in this file, please fix the code generator used to generate this file found in
* core/openapigenerator.d.
*
* This file is generated based on Jellyfin's OpenAPI description, "openapi.json". Please update that
* file with a newer file if needed instead of manually updating the files.
*/
#ifndef JELLYFIN_DTO_SENDCOMMAND_H
#define JELLYFIN_DTO_SENDCOMMAND_H
#include <QDateTime>
#include <QJsonObject>
#include <QObject>
#include <QString>
#include "JellyfinQt/DTO/sendcommandtype.h"
namespace Jellyfin {
namespace DTO {
class SendCommand : public QObject {
Q_OBJECT
public:
explicit SendCommand(QObject *parent = nullptr);
static SendCommand *fromJSON(QJsonObject source, QObject *parent = nullptr);
void updateFromJSON(QJsonObject source);
QJsonObject toJSON();
/**
* @brief Gets the group identifier.
*/
Q_PROPERTY(QString groupId READ groupId WRITE setGroupId NOTIFY groupIdChanged)
/**
* @brief Gets the playlist identifier of the playing item.
*/
Q_PROPERTY(QString playlistItemId READ playlistItemId WRITE setPlaylistItemId NOTIFY playlistItemIdChanged)
/**
* @brief Gets or sets the UTC time when to execute the command.
*/
Q_PROPERTY(QDateTime when READ when WRITE setWhen NOTIFY whenChanged)
/**
* @brief Gets the position ticks.
*/
Q_PROPERTY(qint64 positionTicks READ positionTicks WRITE setPositionTicks NOTIFY positionTicksChanged)
Q_PROPERTY(SendCommandType command READ command WRITE setCommand NOTIFY commandChanged)
/**
* @brief Gets the UTC time when this command has been emitted.
*/
Q_PROPERTY(QDateTime emittedAt READ emittedAt WRITE setEmittedAt NOTIFY emittedAtChanged)
QString groupId() const;
void setGroupId(QString newGroupId);
QString playlistItemId() const;
void setPlaylistItemId(QString newPlaylistItemId);
QDateTime when() const;
void setWhen(QDateTime newWhen);
qint64 positionTicks() const;
void setPositionTicks(qint64 newPositionTicks);
SendCommandType command() const;
void setCommand(SendCommandType newCommand);
QDateTime emittedAt() const;
void setEmittedAt(QDateTime newEmittedAt);
signals:
void groupIdChanged(QString newGroupId);
void playlistItemIdChanged(QString newPlaylistItemId);
void whenChanged(QDateTime newWhen);
void positionTicksChanged(qint64 newPositionTicks);
void commandChanged(SendCommandType newCommand);
void emittedAtChanged(QDateTime newEmittedAt);
protected:
QString m_groupId;
QString m_playlistItemId;
QDateTime m_when;
qint64 m_positionTicks;
SendCommandType m_command;
QDateTime m_emittedAt;
};
} // NS Jellyfin
} // NS DTO
#endif // JELLYFIN_DTO_SENDCOMMAND_H