2018-01-19 07:42:21 -06:00
|
|
|
// Copyright 2017 Citra Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include <QDialog>
|
|
|
|
#include <QFutureWatcher>
|
|
|
|
#include <QSortFilterProxyModel>
|
|
|
|
#include <QStandardItemModel>
|
2018-04-18 11:29:03 -05:00
|
|
|
#include "citra_qt/multiplayer/validation.h"
|
2018-01-19 07:42:21 -06:00
|
|
|
#include "common/announce_multiplayer_room.h"
|
2020-08-20 14:54:01 -05:00
|
|
|
#include "network/announce_multiplayer_session.h"
|
2018-01-19 07:42:21 -06:00
|
|
|
#include "network/network.h"
|
2020-09-30 20:23:01 -05:00
|
|
|
|
|
|
|
namespace Ui {
|
|
|
|
class Lobby;
|
|
|
|
}
|
2018-01-19 07:42:21 -06:00
|
|
|
|
|
|
|
class LobbyModel;
|
|
|
|
class LobbyFilterProxyModel;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Listing of all public games pulled from services. The lobby should be simple enough for users to
|
|
|
|
* find the game they want to play, and join it.
|
|
|
|
*/
|
|
|
|
class Lobby : public QDialog {
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
|
|
|
explicit Lobby(QWidget* parent, QStandardItemModel* list,
|
2020-08-20 14:54:01 -05:00
|
|
|
std::shared_ptr<Network::AnnounceMultiplayerSession> session);
|
2020-09-30 20:23:01 -05:00
|
|
|
~Lobby() override;
|
2018-01-19 07:42:21 -06:00
|
|
|
|
2019-04-19 23:38:19 -05:00
|
|
|
/**
|
|
|
|
* Updates the lobby with a new game list model.
|
|
|
|
* This model should be the original model of the game list.
|
|
|
|
*/
|
|
|
|
void UpdateGameList(QStandardItemModel* list);
|
2018-10-09 10:08:33 -05:00
|
|
|
void RetranslateUi();
|
|
|
|
|
2018-01-19 07:42:21 -06:00
|
|
|
public slots:
|
|
|
|
/**
|
|
|
|
* Begin the process to pull the latest room list from web services. After the listing is
|
|
|
|
* returned from web services, `LobbyRefreshed` will be signalled
|
|
|
|
*/
|
|
|
|
void RefreshLobby();
|
|
|
|
|
|
|
|
private slots:
|
|
|
|
/**
|
|
|
|
* Pulls the list of rooms from network and fills out the lobby model with the results
|
|
|
|
*/
|
|
|
|
void OnRefreshLobby();
|
|
|
|
|
2018-04-05 13:07:11 -05:00
|
|
|
/**
|
|
|
|
* Handler for single clicking on a room in the list. Expands the treeitem to show player
|
|
|
|
* information for the people in the room
|
|
|
|
*
|
|
|
|
* index - The row of the proxy model that the user wants to join.
|
|
|
|
*/
|
|
|
|
void OnExpandRoom(const QModelIndex&);
|
|
|
|
|
2018-01-19 07:42:21 -06:00
|
|
|
/**
|
|
|
|
* Handler for double clicking on a room in the list. Gathers the host ip and port and attempts
|
|
|
|
* to connect. Will also prompt for a password in case one is required.
|
|
|
|
*
|
|
|
|
* index - The row of the proxy model that the user wants to join.
|
|
|
|
*/
|
|
|
|
void OnJoinRoom(const QModelIndex&);
|
|
|
|
|
|
|
|
signals:
|
|
|
|
void StateChanged(const Network::RoomMember::State&);
|
|
|
|
|
|
|
|
private:
|
|
|
|
/**
|
|
|
|
* Removes all entries in the Lobby before refreshing.
|
|
|
|
*/
|
|
|
|
void ResetModel();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Prompts for a password. Returns an empty QString if the user either did not provide a
|
|
|
|
* password or if the user closed the window.
|
|
|
|
*/
|
2018-04-18 00:06:02 -05:00
|
|
|
QString PasswordPrompt();
|
2018-01-19 07:42:21 -06:00
|
|
|
|
2019-07-14 10:04:52 -05:00
|
|
|
std::unique_ptr<Ui::Lobby> ui;
|
|
|
|
|
2019-04-19 23:38:19 -05:00
|
|
|
QStandardItemModel* model{};
|
|
|
|
QStandardItemModel* game_list{};
|
|
|
|
LobbyFilterProxyModel* proxy{};
|
2018-01-19 07:42:21 -06:00
|
|
|
|
2018-09-12 11:22:48 -05:00
|
|
|
QFutureWatcher<AnnounceMultiplayerRoom::RoomList> room_list_watcher;
|
2020-08-20 14:54:01 -05:00
|
|
|
std::weak_ptr<Network::AnnounceMultiplayerSession> announce_multiplayer_session;
|
2018-01-19 07:42:21 -06:00
|
|
|
QFutureWatcher<void>* watcher;
|
2018-04-18 11:29:03 -05:00
|
|
|
Validation validation;
|
2018-01-19 07:42:21 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Proxy Model for filtering the lobby
|
|
|
|
*/
|
|
|
|
class LobbyFilterProxyModel : public QSortFilterProxyModel {
|
|
|
|
Q_OBJECT;
|
|
|
|
|
|
|
|
public:
|
|
|
|
explicit LobbyFilterProxyModel(QWidget* parent, QStandardItemModel* list);
|
2019-04-19 23:38:19 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Updates the filter with a new game list model.
|
|
|
|
* This model should be the processed one created by the Lobby.
|
|
|
|
*/
|
|
|
|
void UpdateGameList(QStandardItemModel* list);
|
|
|
|
|
2018-01-19 07:42:21 -06:00
|
|
|
bool filterAcceptsRow(int sourceRow, const QModelIndex& sourceParent) const override;
|
|
|
|
void sort(int column, Qt::SortOrder order) override;
|
|
|
|
|
|
|
|
public slots:
|
|
|
|
void SetFilterOwned(bool);
|
2023-03-07 17:51:46 -06:00
|
|
|
void SetFilterEmpty(bool);
|
2018-01-19 07:42:21 -06:00
|
|
|
void SetFilterFull(bool);
|
2018-04-19 02:18:45 -05:00
|
|
|
void SetFilterSearch(const QString&);
|
2018-01-19 07:42:21 -06:00
|
|
|
|
|
|
|
private:
|
|
|
|
QStandardItemModel* game_list;
|
|
|
|
bool filter_owned = false;
|
2023-03-07 17:51:46 -06:00
|
|
|
bool filter_empty = false;
|
2018-01-19 07:42:21 -06:00
|
|
|
bool filter_full = false;
|
2018-04-19 02:18:45 -05:00
|
|
|
QString filter_search;
|
2018-01-19 07:42:21 -06:00
|
|
|
};
|