Commit 5dd20181 authored by ctrlaltca's avatar ctrlaltca
Browse files

Merge pull request #1753 from ctrlaltca/pr_1544

Re-Dockified the game & replay review areas
parents 14e94f1f f57e0454
...@@ -57,3 +57,43 @@ void LayoutsSettings::setDeckEditorFilterSize(const QSize &value) ...@@ -57,3 +57,43 @@ void LayoutsSettings::setDeckEditorFilterSize(const QSize &value)
{ {
setValue(value,"layouts/deckEditor_FilterSize"); setValue(value,"layouts/deckEditor_FilterSize");
} }
void LayoutsSettings::setGamePlayAreaGeometry(const QByteArray &value)
{
setValue(value,"layouts/gameplayarea_geometry");
}
void LayoutsSettings::setGamePlayAreaState(const QByteArray &value)
{
setValue(value,"layouts/gameplayarea_state");
}
const QByteArray LayoutsSettings::getGamePlayAreaLayoutState()
{
return getValue("layouts/gameplayarea_state").toByteArray();
}
const QByteArray LayoutsSettings::getGamePlayAreaGeometry()
{
return getValue("layouts/gameplayarea_geometry").toByteArray();
}
void LayoutsSettings::setReplayPlayAreaGeometry(const QByteArray &value)
{
setValue(value,"layouts/replayplayarea_geometry");
}
void LayoutsSettings::setReplayPlayAreaState(const QByteArray &value)
{
setValue(value,"layouts/replayplayarea_state");
}
const QByteArray LayoutsSettings::getReplayPlayAreaLayoutState()
{
return getValue("layouts/replayplayarea_state").toByteArray();
}
const QByteArray LayoutsSettings::getReplayPlayAreaGeometry()
{
return getValue("layouts/replayplayarea_geometry").toByteArray();
}
...@@ -15,12 +15,20 @@ public: ...@@ -15,12 +15,20 @@ public:
void setDeckEditorCardSize(const QSize &value); void setDeckEditorCardSize(const QSize &value);
void setDeckEditorDeckSize(const QSize &value); void setDeckEditorDeckSize(const QSize &value);
void setDeckEditorFilterSize(const QSize &value); void setDeckEditorFilterSize(const QSize &value);
void setGamePlayAreaGeometry(const QByteArray &value);
void setGamePlayAreaState(const QByteArray &value);
void setReplayPlayAreaGeometry(const QByteArray &value);
void setReplayPlayAreaState(const QByteArray &value);
const QByteArray getDeckEditorLayoutState(); const QByteArray getDeckEditorLayoutState();
const QByteArray getDeckEditorGeometry(); const QByteArray getDeckEditorGeometry();
const QSize getDeckEditorCardSize(); const QSize getDeckEditorCardSize();
const QSize getDeckEditorDeckSize(); const QSize getDeckEditorDeckSize();
const QSize getDeckEditorFilterSize(); const QSize getDeckEditorFilterSize();
const QByteArray getGamePlayAreaLayoutState();
const QByteArray getGamePlayAreaGeometry();
const QByteArray getReplayPlayAreaLayoutState();
const QByteArray getReplayPlayAreaGeometry();
signals: signals:
public slots: public slots:
......
...@@ -243,4 +243,5 @@ void ShortcutsSettings::fillDefaultShorcuts() ...@@ -243,4 +243,5 @@ void ShortcutsSettings::fillDefaultShorcuts()
defaultShortCuts["Player/phase9"] = parseSequenceString("F9"); defaultShortCuts["Player/phase9"] = parseSequenceString("F9");
defaultShortCuts["tab_room/aClearChat"] = parseSequenceString("F12"); defaultShortCuts["tab_room/aClearChat"] = parseSequenceString("F12");
defaultShortCuts["DlgLoadDeckFromClipboard/refreshButton"] = parseSequenceString("F5"); defaultShortCuts["DlgLoadDeckFromClipboard/refreshButton"] = parseSequenceString("F5");
defaultShortCuts["Player/aResetLayout"] = parseSequenceString("");
} }
...@@ -4,8 +4,9 @@ ...@@ -4,8 +4,9 @@
#include <QApplication> #include <QApplication>
#include <QDebug> #include <QDebug>
Tab::Tab(TabSupervisor *_tabSupervisor, QWidget *parent) Tab::Tab(TabSupervisor *_tabSupervisor, QWidget *parent)
: QWidget(parent), tabSupervisor(_tabSupervisor), contentsChanged(false), infoPopup(0) : QMainWindow(parent), tabSupervisor(_tabSupervisor), contentsChanged(false), infoPopup(0)
{ {
setAttribute(Qt::WA_DeleteOnClose);
} }
void Tab::showCardInfoPopup(const QPoint &pos, const QString &cardName) void Tab::showCardInfoPopup(const QPoint &pos, const QString &cardName)
......
#ifndef TAB_H #ifndef TAB_H
#define TAB_H #define TAB_H
#include <QWidget> #include <QMainWindow>
class QMenu; class QMenu;
class TabSupervisor; class TabSupervisor;
class CardInfoWidget; class CardInfoWidget;
class Tab : public QWidget { class Tab : public QMainWindow {
Q_OBJECT Q_OBJECT
signals: signals:
void userEvent(bool globalEvent = true); void userEvent(bool globalEvent = true);
......
...@@ -83,7 +83,10 @@ TabAdmin::TabAdmin(TabSupervisor *_tabSupervisor, AbstractClient *_client, bool ...@@ -83,7 +83,10 @@ TabAdmin::TabAdmin(TabSupervisor *_tabSupervisor, AbstractClient *_client, bool
mainLayout->addWidget(lockButton); mainLayout->addWidget(lockButton);
retranslateUi(); retranslateUi();
setLayout(mainLayout);
QWidget * mainWidget = new QWidget(this);
mainWidget->setLayout(mainLayout);
setCentralWidget(mainWidget);
} }
void TabAdmin::retranslateUi() void TabAdmin::retranslateUi()
......
...@@ -52,30 +52,6 @@ void SearchLineEdit::keyPressEvent(QKeyEvent *event) ...@@ -52,30 +52,6 @@ void SearchLineEdit::keyPressEvent(QKeyEvent *event)
QLineEdit::keyPressEvent(event); QLineEdit::keyPressEvent(event);
} }
void TabDeckEditor::createShowHideDocksButtons()
{
btnFilter = new QPushButton(QPixmap("theme:icons/view"),QString());
btnFilter->setObjectName("btnFilter");
btnFilter->setCheckable(true);
btnFilter->setChecked(true);
btnFilter->setMaximumWidth(30);
searchLayout->addWidget(btnFilter);
btnDeck = new QPushButton(QPixmap("theme:hand"),QString());
btnDeck->setObjectName("btnDeck");
btnDeck->setCheckable(true);
btnDeck->setChecked(true);
btnDeck->setMaximumWidth(30);
searchLayout->addWidget(btnDeck);
btnCard = new QPushButton(QPixmap("theme:cardback"),QString());
btnCard->setObjectName("btnCard");
btnCard->setCheckable(true);
btnCard->setChecked(true);
btnCard->setMaximumWidth(30);
searchLayout->addWidget(btnCard);
}
void TabDeckEditor::createDeckDock() void TabDeckEditor::createDeckDock()
{ {
deckModel = new DeckListModel(this); deckModel = new DeckListModel(this);
...@@ -160,7 +136,7 @@ void TabDeckEditor::createDeckDock() ...@@ -160,7 +136,7 @@ void TabDeckEditor::createDeckDock()
rightFrame->addWidget(deckView, 10); rightFrame->addWidget(deckView, 10);
rightFrame->addLayout(deckToolbarLayout); rightFrame->addLayout(deckToolbarLayout);
deckDock = new QDockWidget(MainWindow); deckDock = new QDockWidget(this);
deckDock->setObjectName("deckDock"); deckDock->setObjectName("deckDock");
deckDock->setMinimumSize(QSize(200, 41)); deckDock->setMinimumSize(QSize(200, 41));
...@@ -171,8 +147,8 @@ void TabDeckEditor::createDeckDock() ...@@ -171,8 +147,8 @@ void TabDeckEditor::createDeckDock()
deckDockContents->setLayout(rightFrame); deckDockContents->setLayout(rightFrame);
deckDock->setWidget(deckDockContents); deckDock->setWidget(deckDockContents);
connect(btnDeck,SIGNAL(toggled(bool)),deckDock,SLOT(setVisible(bool)));
deckDock->installEventFilter(this); deckDock->installEventFilter(this);
connect(deckDock, SIGNAL(topLevelChanged(bool)), this, SLOT(dockTopLevelChanged(bool)));
} }
void TabDeckEditor::createCardInfoDock() void TabDeckEditor::createCardInfoDock()
...@@ -183,7 +159,7 @@ void TabDeckEditor::createCardInfoDock() ...@@ -183,7 +159,7 @@ void TabDeckEditor::createCardInfoDock()
cardInfoFrame->setObjectName("cardInfoFrame"); cardInfoFrame->setObjectName("cardInfoFrame");
cardInfoFrame->addWidget(cardInfo); cardInfoFrame->addWidget(cardInfo);
cardInfoDock = new QDockWidget(MainWindow); cardInfoDock = new QDockWidget(this);
cardInfoDock->setObjectName("cardInfoDock"); cardInfoDock->setObjectName("cardInfoDock");
cardInfoDock->setMinimumSize(QSize(200, 41)); cardInfoDock->setMinimumSize(QSize(200, 41));
...@@ -194,8 +170,8 @@ void TabDeckEditor::createCardInfoDock() ...@@ -194,8 +170,8 @@ void TabDeckEditor::createCardInfoDock()
cardInfoDockContents->setLayout(cardInfoFrame); cardInfoDockContents->setLayout(cardInfoFrame);
cardInfoDock->setWidget(cardInfoDockContents); cardInfoDock->setWidget(cardInfoDockContents);
connect(btnCard,SIGNAL(toggled(bool)),cardInfoDock,SLOT(setVisible(bool)));
cardInfoDock->installEventFilter(this); cardInfoDock->installEventFilter(this);
connect(cardInfoDock, SIGNAL(topLevelChanged(bool)), this, SLOT(dockTopLevelChanged(bool)));
} }
void TabDeckEditor::createFiltersDock() void TabDeckEditor::createFiltersDock()
...@@ -243,17 +219,17 @@ void TabDeckEditor::createFiltersDock() ...@@ -243,17 +219,17 @@ void TabDeckEditor::createFiltersDock()
filterFrame->setObjectName("filterFrame"); filterFrame->setObjectName("filterFrame");
filterFrame->addWidget(filterBox); filterFrame->addWidget(filterBox);
filterDock = new QDockWidget(MainWindow); filterDock = new QDockWidget(this);
filterDock->setObjectName("filterDock"); filterDock->setObjectName("filterDock");
filterDock->setFeatures(QDockWidget::DockWidgetClosable|QDockWidget::DockWidgetFloatable|QDockWidget::DockWidgetMovable); filterDock->setFeatures(QDockWidget::DockWidgetClosable|QDockWidget::DockWidgetFloatable|QDockWidget::DockWidgetMovable);
QWidget *filterDockContents = new QWidget(MainWindow); QWidget *filterDockContents = new QWidget(this);
filterDockContents->setObjectName("filterDockContents"); filterDockContents->setObjectName("filterDockContents");
filterDockContents->setLayout(filterFrame); filterDockContents->setLayout(filterFrame);
filterDock->setWidget(filterDockContents); filterDock->setWidget(filterDockContents);
connect(btnFilter,SIGNAL(toggled(bool)),filterDock,SLOT(setVisible(bool)));
filterDock->installEventFilter(this); filterDock->installEventFilter(this);
connect(filterDock, SIGNAL(topLevelChanged(bool)), this, SLOT(dockTopLevelChanged(bool)));
} }
void TabDeckEditor::createMenus() void TabDeckEditor::createMenus()
...@@ -297,9 +273,6 @@ void TabDeckEditor::createMenus() ...@@ -297,9 +273,6 @@ void TabDeckEditor::createMenus()
aEditTokens = new QAction(QString(), this); aEditTokens = new QAction(QString(), this);
connect(aEditTokens, SIGNAL(triggered()), this, SLOT(actEditTokens())); connect(aEditTokens, SIGNAL(triggered()), this, SLOT(actEditTokens()));
aResetLayout = new QAction(QString(), this);
connect(aResetLayout,SIGNAL(triggered()),this,SLOT(restartLayout()));
deckMenu = new QMenu(this); deckMenu = new QMenu(this);
deckMenu->addAction(aNewDeck); deckMenu->addAction(aNewDeck);
deckMenu->addAction(aLoadDeck); deckMenu->addAction(aLoadDeck);
...@@ -313,8 +286,6 @@ void TabDeckEditor::createMenus() ...@@ -313,8 +286,6 @@ void TabDeckEditor::createMenus()
deckMenu->addSeparator(); deckMenu->addSeparator();
deckMenu->addAction(aAnalyzeDeck); deckMenu->addAction(aAnalyzeDeck);
deckMenu->addSeparator(); deckMenu->addSeparator();
deckMenu->addAction(aResetLayout);
deckMenu->addSeparator();
deckMenu->addAction(aClose); deckMenu->addAction(aClose);
addTabMenu(deckMenu); addTabMenu(deckMenu);
...@@ -338,6 +309,41 @@ void TabDeckEditor::createMenus() ...@@ -338,6 +309,41 @@ void TabDeckEditor::createMenus()
dbMenu->addAction(aOpenCustomsetsFolder); dbMenu->addAction(aOpenCustomsetsFolder);
#endif #endif
addTabMenu(dbMenu); addTabMenu(dbMenu);
viewMenu = new QMenu(this);
cardInfoDockMenu = viewMenu->addMenu(QString());
deckDockMenu = viewMenu->addMenu(QString());
filterDockMenu = viewMenu->addMenu(QString());
aCardInfoDockVisible = cardInfoDockMenu->addAction(QString());
aCardInfoDockVisible->setCheckable(true);
connect(aCardInfoDockVisible,SIGNAL(triggered()),this,SLOT(dockVisibleTriggered()));
aCardInfoDockFloating = cardInfoDockMenu->addAction(QString());
aCardInfoDockFloating->setCheckable(true);
connect(aCardInfoDockFloating,SIGNAL(triggered()),this,SLOT(dockFloatingTriggered()));
aDeckDockVisible = deckDockMenu->addAction(QString());
aDeckDockVisible->setCheckable(true);
connect(aDeckDockVisible,SIGNAL(triggered()),this,SLOT(dockVisibleTriggered()));
aDeckDockFloating = deckDockMenu->addAction(QString());
aDeckDockFloating->setCheckable(true);
connect(aDeckDockFloating,SIGNAL(triggered()),this,SLOT(dockFloatingTriggered()));
aFilterDockVisible = filterDockMenu->addAction(QString());
aFilterDockVisible->setCheckable(true);
connect(aFilterDockVisible,SIGNAL(triggered()),this,SLOT(dockVisibleTriggered()));
aFilterDockFloating = filterDockMenu->addAction(QString());
aFilterDockFloating->setCheckable(true);
connect(aFilterDockFloating,SIGNAL(triggered()),this,SLOT(dockFloatingTriggered()));
viewMenu->addSeparator();
aResetLayout = viewMenu->addAction(QString());
connect(aResetLayout,SIGNAL(triggered()),this,SLOT(restartLayout()));
viewMenu->addAction(aResetLayout);
addTabMenu(viewMenu);
} }
void TabDeckEditor::createCentralFrame() void TabDeckEditor::createCentralFrame()
...@@ -414,41 +420,43 @@ void TabDeckEditor::createCentralFrame() ...@@ -414,41 +420,43 @@ void TabDeckEditor::createCentralFrame()
searchLayout->setObjectName("searchLayout"); searchLayout->setObjectName("searchLayout");
searchLayout->addWidget(deckEditToolBar); searchLayout->addWidget(deckEditToolBar);
searchLayout->addWidget(searchEdit); searchLayout->addWidget(searchEdit);
createShowHideDocksButtons();
centralFrame = new QVBoxLayout; centralFrame = new QVBoxLayout;
centralFrame->setObjectName("centralFrame"); centralFrame->setObjectName("centralFrame");
centralFrame->addLayout(searchLayout); centralFrame->addLayout(searchLayout);
centralFrame->addWidget(databaseView); centralFrame->addWidget(databaseView);
centralWidget = new QWidget(MainWindow); centralWidget = new QWidget(this);
centralWidget->setObjectName("centralWidget"); centralWidget->setObjectName("centralWidget");
centralWidget->setLayout(centralFrame); centralWidget->setLayout(centralFrame);
MainWindow->setCentralWidget(centralWidget); setCentralWidget(centralWidget);
MainWindow->setDockOptions(QMainWindow::AnimatedDocks|QMainWindow::AllowNestedDocks|QMainWindow::AllowTabbedDocks); setDockOptions(QMainWindow::AnimatedDocks|QMainWindow::AllowNestedDocks|QMainWindow::AllowTabbedDocks);
QHBoxLayout *mainLayout = new QHBoxLayout;
mainLayout->setObjectName("mainLayout");
mainLayout->addWidget(MainWindow);
setLayout(mainLayout);
} }
void TabDeckEditor::restartLayout() void TabDeckEditor::restartLayout()
{ {
btnDeck->setChecked(true); deckDock->setVisible(true);
btnFilter->setChecked(true); cardInfoDock->setVisible(true);
btnCard->setChecked(true); filterDock->setVisible(true);
deckDock->setFloating(false); deckDock->setFloating(false);
cardInfoDock->setFloating(false); cardInfoDock->setFloating(false);
filterDock->setFloating(false); filterDock->setFloating(false);
MainWindow->addDockWidget(static_cast<Qt::DockWidgetArea>(2), deckDock); aCardInfoDockVisible->setChecked(true);
MainWindow->addDockWidget(static_cast<Qt::DockWidgetArea>(2), cardInfoDock); aDeckDockVisible->setChecked(true);
MainWindow->addDockWidget(static_cast<Qt::DockWidgetArea>(2), filterDock); aFilterDockVisible->setChecked(true);
aCardInfoDockFloating->setChecked(false);
aDeckDockFloating->setChecked(false);
aFilterDockFloating->setChecked(false);
MainWindow->splitDockWidget(cardInfoDock, deckDock, Qt::Horizontal); addDockWidget(static_cast<Qt::DockWidgetArea>(2), deckDock);
MainWindow->splitDockWidget(cardInfoDock, filterDock, Qt::Vertical); addDockWidget(static_cast<Qt::DockWidgetArea>(2), cardInfoDock);
addDockWidget(static_cast<Qt::DockWidgetArea>(2), filterDock);
splitDockWidget(cardInfoDock, deckDock, Qt::Horizontal);
splitDockWidget(cardInfoDock, filterDock, Qt::Vertical);
deckDock->setMinimumWidth(360); deckDock->setMinimumWidth(360);
deckDock->setMaximumWidth(360); deckDock->setMaximumWidth(360);
...@@ -496,12 +504,20 @@ void TabDeckEditor::refreshShortcuts() ...@@ -496,12 +504,20 @@ void TabDeckEditor::refreshShortcuts()
void TabDeckEditor::loadLayout() void TabDeckEditor::loadLayout()
{ {
MainWindow->restoreState(settingsCache->layouts().getDeckEditorLayoutState()); restoreState(settingsCache->layouts().getDeckEditorLayoutState());
MainWindow->restoreGeometry(settingsCache->layouts().getDeckEditorGeometry()); restoreGeometry(settingsCache->layouts().getDeckEditorGeometry());
aCardInfoDockVisible->setChecked(cardInfoDock->isVisible());
aFilterDockVisible->setChecked(filterDock->isVisible());
aDeckDockVisible->setChecked(deckDock->isVisible());
aCardInfoDockFloating->setEnabled(aCardInfoDockVisible->isChecked());
aDeckDockFloating->setEnabled(aDeckDockVisible->isChecked());
aFilterDockFloating->setEnabled(aFilterDockVisible->isChecked());
btnCard->setChecked(!cardInfoDock->isHidden()); aCardInfoDockFloating->setChecked(cardInfoDock->isFloating());
btnFilter->setChecked(!filterDock->isHidden()); aFilterDockFloating->setChecked(filterDock->isFloating());
btnDeck->setChecked(!deckDock->isHidden()); aDeckDockFloating->setChecked(deckDock->isFloating());
cardInfoDock->setMinimumSize(settingsCache->layouts().getDeckEditorCardSize()); cardInfoDock->setMinimumSize(settingsCache->layouts().getDeckEditorCardSize());
cardInfoDock->setMaximumSize(settingsCache->layouts().getDeckEditorCardSize()); cardInfoDock->setMaximumSize(settingsCache->layouts().getDeckEditorCardSize());
...@@ -518,8 +534,7 @@ void TabDeckEditor::loadLayout() ...@@ -518,8 +534,7 @@ void TabDeckEditor::loadLayout()
TabDeckEditor::TabDeckEditor(TabSupervisor *_tabSupervisor, QWidget *parent) TabDeckEditor::TabDeckEditor(TabSupervisor *_tabSupervisor, QWidget *parent)
: Tab(_tabSupervisor, parent), modified(false) : Tab(_tabSupervisor, parent), modified(false)
{ {
MainWindow = new QMainWindow; setObjectName("TabDeckEditor");
MainWindow->setObjectName("MainWindow");
createMenus(); createMenus();
...@@ -587,13 +602,25 @@ void TabDeckEditor::retranslateUi() ...@@ -587,13 +602,25 @@ void TabDeckEditor::retranslateUi()
aEditSets->setText(tr("&Edit sets...")); aEditSets->setText(tr("&Edit sets..."));
aEditTokens->setText(tr("Edit &tokens...")); aEditTokens->setText(tr("Edit &tokens..."));
btnCard->setToolTip(tr("Show/Hide card information"));
btnDeck->setToolTip(tr("Show/Hide deck"));
btnFilter->setToolTip(tr("Show/Hide filters"));
aResetLayout->setText(tr("Reset layout"));
cardInfoDock->setWindowTitle(tr("Card Info")); cardInfoDock->setWindowTitle(tr("Card Info"));
deckDock->setWindowTitle(tr("Deck")); deckDock->setWindowTitle(tr("Deck"));
filterDock->setWindowTitle(tr("Filters")); filterDock->setWindowTitle(tr("Filters"));
viewMenu->setTitle(tr("&View"));
cardInfoDockMenu->setTitle(tr("Card Info"));
deckDockMenu->setTitle(tr("Deck"));
filterDockMenu->setTitle(tr("Filters"));
aCardInfoDockVisible->setText(tr("Visible"));
aCardInfoDockFloating->setText(tr("Floating"));
aDeckDockVisible->setText(tr("Visible"));
aDeckDockFloating->setText(tr("Floating"));
aFilterDockVisible->setText(tr("Visible"));
aFilterDockFloating->setText(tr("Floating"));
aResetLayout->setText(tr("Reset layout"));
} }
QString TabDeckEditor::getTabText() const QString TabDeckEditor::getTabText() const
...@@ -998,28 +1025,6 @@ void TabDeckEditor::setPriceTagFeatureEnabled(int /* enabled */) ...@@ -998,28 +1025,6 @@ void TabDeckEditor::setPriceTagFeatureEnabled(int /* enabled */)
deckModel->pricesUpdated(); deckModel->pricesUpdated();
} }
bool TabDeckEditor::eventFilter(QObject * o, QEvent * e)
{
if(e->type() == QEvent::Close)
{
if(o == cardInfoDock)
btnCard->setChecked(false);
else if(o == deckDock)
btnDeck->setChecked(false);
else if(o == filterDock)
btnFilter->setChecked(false);
}
if( o == this && e->type() == QEvent::Hide){
settingsCache->layouts().setDeckEditorLayoutState(MainWindow->saveState());
settingsCache->layouts().setDeckEditorGeometry(MainWindow->saveGeometry());
settingsCache->layouts().setDeckEditorCardSize(cardInfoDock->size());
settingsCache->layouts().setDeckEditorFilterSize(filterDock->size());
settingsCache->layouts().setDeckEditorDeckSize(deckDock->size());
}
return false;
}
/* /*
void TabDeckEditor::actUpdatePrices() void TabDeckEditor::actUpdatePrices()
{ {
...@@ -1105,3 +1110,99 @@ void TabDeckEditor::checkFirstRunDetected() ...@@ -1105,3 +1110,99 @@ void TabDeckEditor::checkFirstRunDetected()
actEditSets(); actEditSets();
} }
} }
// Method uses to sync docks state with menu items state
bool TabDeckEditor::eventFilter(QObject * o, QEvent * e)
{
if(e->type() == QEvent::Close)
{
if(o == cardInfoDock)
{
aCardInfoDockVisible->setChecked(false);
aCardInfoDockFloating->setEnabled(false);
} else if(o == deckDock) {
aDeckDockVisible->setChecked(false);
aDeckDockFloating->setEnabled(false);
} else if(o == filterDock) {
aFilterDockVisible->setChecked(false);
aFilterDockFloating->setEnabled(false);
}
}
if( o == this && e->type() == QEvent::Hide){
settingsCache->layouts().setDeckEditorLayoutState(saveState());
settingsCache->layouts().setDeckEditorGeometry(saveGeometry());
settingsCache->layouts().setDeckEditorCardSize(cardInfoDock->size());
settingsCache->layouts().setDeckEditorFilterSize(filterDock->size());
settingsCache->layouts().setDeckEditorDeckSize(deckDock->size());
}
return false;
}
void TabDeckEditor::dockVisibleTriggered()
{
QObject *o = sender();
if(o == aCardInfoDockVisible)
{
cardInfoDock->setVisible(aCardInfoDockVisible->isChecked());
aCardInfoDockFloating->setEnabled(aCardInfoDockVisible->isChecked());
return;
}
if(o == aDeckDockVisible)
{
deckDock->setVisible(aDeckDockVisible->isChecked());
aDeckDockFloating->setEnabled(aDeckDockVisible->isChecked());
return;
}
if(o == aFilterDockVisible)
{
filterDock->setVisible(aFilterDockVisible->isChecked());
aFilterDockFloating->setEnabled(aFilterDockVisible->isChecked());
return;
}
}
void TabDeckEditor::dockFloatingTriggered()
{
QObject *o = sender();
if(o == aCardInfoDockFloating)
{
cardInfoDock->setFloating(aCardInfoDockFloating->isChecked());
return;
}
if(o == aDeckDockFloating)
{
deckDock->setFloating(aDeckDockFloating->isChecked());
return;
}
if(o == aFilterDockFloating)
{
filterDock->setFloating(aFilterDockFloating->isChecked());
return;
}
}
void TabDeckEditor::dockTopLevelChanged(bool topLevel)
{
QObject *o = sender();
if(o == cardInfoDock)
{
aCardInfoDockFloating->setChecked(topLevel);
return;
}
if(o == deckDock)
{
aDeckDockFloating->setChecked(topLevel);
return;
}
if(o == filterDock)
{
aFilterDockFloating->setChecked(topLevel);
return;
}
}
...@@ -22,7 +22,6 @@ class CardInfo; ...@@ -22,7 +22,6 @@ class CardInfo;
class QGroupBox; class QGroupBox;
class QHBoxLayout; class QHBoxLayout;
class QPushButton; class QPushButton;
class QMainWindow;
class QDockWidget; class QDockWidget;
class SearchLineEdit : public QLineEdit { class SearchLineEdit : public QLineEdit {
...@@ -79,12 +78,15 @@ class TabDeckEditor : public Tab { ...@@ -79,12 +78,15 @@ class TabDeckEditor : public Tab {
void filterRemove(QAction *action); void filterRemove(QAction *action);
void setPriceTagFeatureEnabled(int enabled); void setPriceTagFeatureEnabled(int enabled);
bool eventFilter(QObject *o, QEvent *e);
void loadLayout(); void loadLayout();
void restartLayout(); void restartLayout();
void freeDocksSize(); void freeDocksSize();
void refreshShortcuts(); void refreshShortcuts();
bool eventFilter(QObject *o, QEvent *e);
void dockVisibleTriggered();
void dockFloatingTriggered();
void dockTopLevelChanged(bool topLevel);
private: private:
CardInfo *currentCardInfo() const; CardInfo *currentCardInfo() const;
void addCardHelper(QString zoneName); void addCardHelper(QString zoneName);
...@@ -113,19 +115,16 @@ private: ...@@ -113,19 +115,16 @@ private:
QTreeView *filterView; QTreeView *filterView;
QWidget *filterBox; QWidget *filterBox;
QMenu *deckMenu, *dbMenu; QMenu *deckMenu, *dbMenu, *viewMenu, *cardInfoDockMenu, *deckDockMenu, *filterDockMenu;
QAction *aNewDeck, *aLoadDeck, *aSaveDeck, *aSaveDeckAs, *aLoadDeckFromClipboard, *aSaveDeckToClipboard, *aPrintDeck, *aAnalyzeDeck, *aClose, *aOpenCustomFolder, *aOpenCustomsetsFolder; QAction *aNewDeck, *aLoadDeck, *aSaveDeck, *aSaveDeckAs, *aLoadDeckFromClipboard, *aSaveDeckToClipboard, *aPrintDeck, *aAnalyzeDeck, *aClose, *aOpenCustomFolder, *aOpenCustomsetsFolder;
QAction *aEditSets, *aEditTokens, *aClearFilterAll, *aClearFilterOne; QAction *aEditSets, *aEditTokens, *aClearFilterAll, *aClearFilterOne;
QAction *aAddCard, *aAddCardToSideboard, *aRemoveCard, *aIncrement, *aDecrement;// *aUpdatePrices; QAction *aAddCard, *aAddCardToSideboard, *aRemoveCard, *aIncrement, *aDecrement;// *aUpdatePrices;
QAction *aResetLayout; QAction *aResetLayout;
QAction *aCardInfoDockVisible, *aCardInfoDockFloating, *aDeckDockVisible, *aDeckDockFloating, *aFilterDockVisible, *aFilterDockFloating;
bool modified; bool modified;
QMainWindow *MainWindow;
QVBoxLayout *centralFrame; QVBoxLayout *centralFrame;
QHBoxLayout *searchLayout; QHBoxLayout *searchLayout;
QPushButton *btnFilter;
QPushButton *btnDeck;
QPushButton *btnCard;
QDockWidget *cardInfoDock; QDockWidget *cardInfoDock;
QDockWidget *deckDock; QDockWidget *deckDock;
QDockWidget *filterDock; QDockWidget *filterDock;
...@@ -138,7 +137,6 @@ public: ...@@ -138,7 +137,6 @@ public:
void setDeck(DeckLoader *_deckLoader); void setDeck(DeckLoader *_deckLoader);
void setModified(bool _windowModified); void setModified(bool _windowModified);
bool confirmClose(); bool confirmClose();
void createShowHideDocksButtons();
void createDeckDock(); void createDeckDock();
void createCardInfoDock(); void createCardInfoDock();
void createFiltersDock(); void createFiltersDock();
......
...@@ -110,7 +110,10 @@ TabDeckStorage::TabDeckStorage(TabSupervisor *_tabSupervisor, AbstractClient *_c ...@@ -110,7 +110,10 @@ TabDeckStorage::TabDeckStorage(TabSupervisor *_tabSupervisor, AbstractClient *_c
rightToolBar->addAction(aDeleteRemoteDeck); rightToolBar->addAction(aDeleteRemoteDeck);
retranslateUi(); retranslateUi();
setLayout(hbox);
QWidget * mainWidget = new QWidget(this);
mainWidget->setLayout(hbox);
setCentralWidget(mainWidget);
} }
void TabDeckStorage::retranslateUi() void TabDeckStorage::retranslateUi()
......
This diff is collapsed.
...@@ -56,6 +56,8 @@ class GameReplay; ...@@ -56,6 +56,8 @@ class GameReplay;
class ServerInfo_User; class ServerInfo_User;
class PendingCommand; class PendingCommand;
class LineEditCompleter; class LineEditCompleter;
class QDockWidget;
class QStackedWidget;
class ToggleButton : public QPushButton { class ToggleButton : public QPushButton {
Q_OBJECT Q_OBJECT
...@@ -77,6 +79,7 @@ private: ...@@ -77,6 +79,7 @@ private:
QPushButton *loadLocalButton, *loadRemoteButton; QPushButton *loadLocalButton, *loadRemoteButton;
ToggleButton *readyStartButton, *sideboardLockButton; ToggleButton *readyStartButton, *sideboardLockButton;
DeckView *deckView; DeckView *deckView;
TabGame *parentGame;
int playerId; int playerId;
private slots: private slots:
void loadLocalDeck(); void loadLocalDeck();
...@@ -90,7 +93,7 @@ private slots: ...@@ -90,7 +93,7 @@ private slots:
signals: signals:
void newCardAdded(AbstractCardItem *card); void newCardAdded(AbstractCardItem *card);
public: public:
DeckViewContainer(int _playerId, TabGame *parent = 0); DeckViewContainer(int _playerId, TabGame *parent);
void retranslateUi(); void retranslateUi();
void setButtonsVisible(bool _visible); void setButtonsVisible(bool _visible);
void setReadyStart(bool ready); void setReadyStart(bool ready);
...@@ -121,6 +124,7 @@ private: ...@@ -121,6 +124,7 @@ private:
QStringList gameTypes; QStringList gameTypes;
QCompleter *completer; QCompleter *completer;
QStringList autocompleteUserList; QStringList autocompleteUserList;
QStackedWidget * mainWidget;
// Replay related members // Replay related members
GameReplay *replay; GameReplay *replay;
...@@ -129,7 +133,6 @@ private: ...@@ -129,7 +133,6 @@ private:
ReplayTimelineWidget *timelineWidget; ReplayTimelineWidget *timelineWidget;
QToolButton *replayStartButton, *replayPauseButton, *replayFastForwardButton; QToolButton *replayStartButton, *replayPauseButton, *replayFastForwardButton;
QSplitter *splitter;
CardFrame *cardInfo; CardFrame *cardInfo;
PlayerListWidget *playerListWidget; PlayerListWidget *playerListWidget;
QLabel *timeElapsedLabel; QLabel *timeElapsedLabel;
...@@ -140,13 +143,14 @@ private: ...@@ -140,13 +143,14 @@ private:
GameScene *scene; GameScene *scene;
GameView *gameView; GameView *gameView;
QMap<int, DeckViewContainer *> deckViewContainers; QMap<int, DeckViewContainer *> deckViewContainers;
QVBoxLayout *deckViewContainerLayout; QVBoxLayout *cardVInfoLayout, *messageLogLayout, *gamePlayAreaVBox, *deckViewContainerLayout;
QHBoxLayout *mainLayout; QHBoxLayout *cardHInfoLayout, *sayHLayout, *mainHLayout, *replayControlLayout;
ZoneViewLayout *zoneLayout; QWidget *cardBoxLayoutWidget, *messageLogLayoutWidget, *gamePlayAreaWidget, *deckViewContainerWidget, *replayControlWidget;
QDockWidget *cardInfoDock, *messageLayoutDock, *playerListDock, *replayDock;
QAction *playersSeparator; QAction *playersSeparator;
QMenu *gameMenu; QMenu *gameMenu, *phasesMenu, *viewMenu, *cardInfoDockMenu, *messageLayoutDockMenu, *playerListDockMenu, *replayDockMenu;
QMenu *phasesMenu; QAction *aGameInfo, *aConcede, *aLeaveGame, *aCloseReplay, *aNextPhase, *aNextTurn, *aRemoveLocalArrows, *aRotateViewCW, *aRotateViewCCW, *aResetLayout, *aResetReplayLayout;
QAction *aGameInfo, *aConcede, *aLeaveGame, *aCloseReplay, *aNextPhase, *aNextTurn, *aRemoveLocalArrows, *aRotateViewCW, *aRotateViewCCW; QAction *aCardInfoDockVisible, *aCardInfoDockFloating, *aMessageLayoutDockVisible, *aMessageLayoutDockFloating, *aPlayerListDockVisible, *aPlayerListDockFloating, *aReplayDockVisible, *aReplayDockFloating;
QList<QAction *> phaseActions; QList<QAction *> phaseActions;
Player *addPlayer(int playerId, const ServerInfo_User &info); Player *addPlayer(int playerId, const ServerInfo_User &info);
...@@ -171,6 +175,15 @@ private: ...@@ -171,6 +175,15 @@ private:
void eventSetActivePhase(const Event_SetActivePhase &event, int eventPlayerId, const GameEventContext &context); void eventSetActivePhase(const Event_SetActivePhase &event, int eventPlayerId, const GameEventContext &context);
void eventPing(const Event_Ping &event, int eventPlayerId, const GameEventContext &context); void eventPing(const Event_Ping &event, int eventPlayerId, const GameEventContext &context);
void emitUserEvent(); void emitUserEvent();
void createMenuItems();
void createReplayMenuItems();
void createViewMenuItems();
void createCardInfoDock(bool bReplay=false);
void createPlayerListDock(bool bReplay=false);
void createMessageDock(bool bReplay=false);
void createPlayAreaWidget(bool bReplay=false);
void createDeckViewContainerWidget(bool bReplay=false);
void createReplayDock();
signals: signals:
void gameClosing(TabGame *tab); void gameClosing(TabGame *tab);
void playerAdded(Player *player); void playerAdded(Player *player);
...@@ -207,7 +220,14 @@ private slots: ...@@ -207,7 +220,14 @@ private slots:
void refreshShortcuts(); void refreshShortcuts();
void loadLayout();
void actCompleterChanged(); void actCompleterChanged();
void actResetLayout();
bool eventFilter(QObject *o, QEvent *e);
void dockVisibleTriggered();
void dockFloatingTriggered();
void dockTopLevelChanged(bool topLevel);
public: public:
TabGame(TabSupervisor *_tabSupervisor, QList<AbstractClient *> &_clients, const Event_GameJoined &event, const QMap<int, QString> &_roomGameTypes); TabGame(TabSupervisor *_tabSupervisor, QList<AbstractClient *> &_clients, const Event_GameJoined &event, const QMap<int, QString> &_roomGameTypes);
TabGame(TabSupervisor *_tabSupervisor, GameReplay *replay); TabGame(TabSupervisor *_tabSupervisor, GameReplay *replay);
......
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
#include <QLineEdit> #include <QLineEdit>
#include <QCheckBox> #include <QCheckBox>
#include <QRadioButton> #include <QRadioButton>
#include <QTabWidget>
#include "tab_logs.h" #include "tab_logs.h"
#include "abstractclient.h" #include "abstractclient.h"
#include "window_sets.h" #include "window_sets.h"
...@@ -23,7 +24,27 @@ ...@@ -23,7 +24,27 @@
TabLog::TabLog(TabSupervisor *_tabSupervisor, AbstractClient *_client, QWidget *parent) TabLog::TabLog(TabSupervisor *_tabSupervisor, AbstractClient *_client, QWidget *parent)
: Tab(_tabSupervisor, parent), client(_client) : Tab(_tabSupervisor, parent), client(_client)
{ {
MainWindow = new QMainWindow; roomTable = new QTableWidget();
roomTable->setColumnCount(6);
roomTable->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
roomTable->setHorizontalHeaderLabels(QString(tr("Time;SenderName;SenderIP;Message;TargetID;TargetName")).split(";"));
gameTable = new QTableWidget();
gameTable->setColumnCount(6);
gameTable->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
gameTable->setHorizontalHeaderLabels(QString(tr("Time;SenderName;SenderIP;Message;TargetID;TargetName")).split(";"));
chatTable = new QTableWidget();
chatTable->setColumnCount(6);
chatTable->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
chatTable->setHorizontalHeaderLabels(QString(tr("Time;SenderName;SenderIP;Message;TargetID;TargetName")).split(";"));
QTabWidget *tabManager = new QTabWidget();
tabManager->addTab(roomTable, tr("Room Logs"));
tabManager->addTab(gameTable, tr("Game Logs"));
tabManager->addTab(chatTable, tr("Chat Logs"));
setCentralWidget(tabManager);
createDock(); createDock();
restartLayout(); restartLayout();
clearClicked(); clearClicked();
...@@ -212,7 +233,7 @@ void TabLog::createDock() ...@@ -212,7 +233,7 @@ void TabLog::createDock()
buttonGroupBox = new QGroupBox(tr("")); buttonGroupBox = new QGroupBox(tr(""));
buttonGroupBox->setLayout(buttonGrid); buttonGroupBox->setLayout(buttonGrid);
mainLayout = new QVBoxLayout(MainWindow); mainLayout = new QVBoxLayout(this);
mainLayout->addWidget(criteriaGroupBox); mainLayout->addWidget(criteriaGroupBox);
mainLayout->addWidget(locationGroupBox); mainLayout->addWidget(locationGroupBox);
mainLayout->addWidget(rangeGroupBox); mainLayout->addWidget(rangeGroupBox);
...@@ -221,116 +242,94 @@ void TabLog::createDock() ...@@ -221,116 +242,94 @@ void TabLog::createDock()
mainLayout->addWidget(buttonGroupBox); mainLayout->addWidget(buttonGroupBox);
mainLayout->setAlignment(Qt::AlignCenter); mainLayout->setAlignment(Qt::AlignCenter);
searchDockContents = new QWidget(MainWindow); searchDockContents = new QWidget(this);
searchDockContents->setLayout(mainLayout); searchDockContents->setLayout(mainLayout);
searchDock = new QDockWidget(MainWindow); searchDock = new QDockWidget(this);
searchDock->setFeatures(QDockWidget::DockWidgetFloatable|QDockWidget::DockWidgetMovable); searchDock->setFeatures(QDockWidget::DockWidgetFloatable|QDockWidget::DockWidgetMovable);
searchDock->setWidget(searchDockContents); searchDock->setWidget(searchDockContents);
QVBoxLayout *mainVLayoutContent = new QVBoxLayout;
QHBoxLayout *mainHLayoutContent = new QHBoxLayout;
mainHLayoutContent->addWidget(MainWindow);
mainHLayoutContent->addLayout(mainVLayoutContent);
setLayout(mainHLayoutContent);
} }
void TabLog::viewLogHistory_processResponse(const Response &resp) void TabLog::viewLogHistory_processResponse(const Response &resp)
{ {
const Response_ViewLogHistory &response = resp.GetExtension(Response_ViewLogHistory::ext); const Response_ViewLogHistory &response = resp.GetExtension(Response_ViewLogHistory::ext);
if (resp.response_code() == Response::RespOk) { if (resp.response_code() != Response::RespOk) {
QMessageBox::critical(static_cast<QWidget *>(parent()), tr("Message History"), tr("Failed to collect message history information."));
if (response.log_message_size() > 0) { return;
}
int j = 0;
QTableWidget *roomTable = new QTableWidget();
roomTable->setWindowTitle(tr("Room Logs"));
roomTable->setRowCount(response.log_message_size());
roomTable->setColumnCount(6);
roomTable->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
roomTable->setHorizontalHeaderLabels(QString(tr("Time;SenderName;SenderIP;Message;TargetID;TargetName")).split(";"));
int k = 0; if (response.log_message_size() == 0) {
QTableWidget *gameTable = new QTableWidget(); QMessageBox::information(static_cast<QWidget *>(parent()), tr("Message History"), tr("There are no messages for the selected filters."));
gameTable->setWindowTitle(tr("Game Logs")); return;
gameTable->setRowCount(response.log_message_size()); }
gameTable->setColumnCount(6);
gameTable->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
gameTable->setHorizontalHeaderLabels(QString(tr("Time;SenderName;SenderIP;Message;TargetID;TargetName")).split(";"));
int l = 0; int roomCounter = 0, gameCounter = 0, chatCounter = 0;
QTableWidget *chatTable = new QTableWidget(); roomTable->setRowCount(roomCounter);
chatTable->setWindowTitle(tr("Chat Logs")); gameTable->setRowCount(gameCounter);
chatTable->setRowCount(response.log_message_size()); chatTable->setRowCount(chatCounter);
chatTable->setColumnCount(6);
chatTable->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
chatTable->setHorizontalHeaderLabels(QString(tr("Time;SenderName;SenderIP;Message;TargetID;TargetName")).split(";"));
ServerInfo_ChatMessage message; for (int i = 0; i < response.log_message_size(); ++i) { for (int i = 0; i < response.log_message_size(); ++i)
message = response.log_message(i); {
ServerInfo_ChatMessage message = response.log_message(i);
if (QString::fromStdString(message.target_type()) == "room") { if (QString::fromStdString(message.target_type()) == "room") {
roomTable->setItem(j, 0, new QTableWidgetItem(QString::fromStdString(message.time()))); roomTable->insertRow(roomCounter);
roomTable->setItem(j, 1, new QTableWidgetItem(QString::fromStdString(message.sender_name()))); roomTable->setItem(roomCounter, 0, new QTableWidgetItem(QString::fromStdString(message.time())));
roomTable->setItem(j, 2, new QTableWidgetItem(QString::fromStdString(message.sender_ip()))); roomTable->setItem(roomCounter, 1, new QTableWidgetItem(QString::fromStdString(message.sender_name())));
roomTable->setItem(j, 3, new QTableWidgetItem(QString::fromStdString(message.message()))); roomTable->setItem(roomCounter, 2, new QTableWidgetItem(QString::fromStdString(message.sender_ip())));
roomTable->setItem(j, 4, new QTableWidgetItem(QString::fromStdString(message.target_id()))); roomTable->setItem(roomCounter, 3, new QTableWidgetItem(QString::fromStdString(message.message())));
roomTable->setItem(j, 5, new QTableWidgetItem(QString::fromStdString(message.target_name()))); roomTable->setItem(roomCounter, 4, new QTableWidgetItem(QString::fromStdString(message.target_id())));
++j; roomTable->setItem(roomCounter, 5, new QTableWidgetItem(QString::fromStdString(message.target_name())));
++roomCounter;
} }
if (QString::fromStdString(message.target_type()) == "game") { if (QString::fromStdString(message.target_type()) == "game") {
gameTable->setItem(k, 0, new QTableWidgetItem(QString::fromStdString(message.time()))); gameTable->insertRow(gameCounter);
gameTable->setItem(k, 1, new QTableWidgetItem(QString::fromStdString(message.sender_name()))); gameTable->setItem(gameCounter, 0, new QTableWidgetItem(QString::fromStdString(message.time())));
gameTable->setItem(k, 2, new QTableWidgetItem(QString::fromStdString(message.sender_ip()))); gameTable->setItem(gameCounter, 1, new QTableWidgetItem(QString::fromStdString(message.sender_name())));
gameTable->setItem(k, 3, new QTableWidgetItem(QString::fromStdString(message.message()))); gameTable->setItem(gameCounter, 2, new QTableWidgetItem(QString::fromStdString(message.sender_ip())));
gameTable->setItem(k, 4, new QTableWidgetItem(QString::fromStdString(message.target_id()))); gameTable->setItem(gameCounter, 3, new QTableWidgetItem(QString::fromStdString(message.message())));
gameTable->setItem(k, 5, new QTableWidgetItem(QString::fromStdString(message.target_name()))); gameTable->setItem(gameCounter, 4, new QTableWidgetItem(QString::fromStdString(message.target_id())));
++k; gameTable->setItem(gameCounter, 5, new QTableWidgetItem(QString::fromStdString(message.target_name())));
++gameCounter;
} }
if (QString::fromStdString(message.target_type()) == "chat") { if (QString::fromStdString(message.target_type()) == "chat") {
chatTable->setItem(l, 0, new QTableWidgetItem(QString::fromStdString(message.time()))); chatTable->insertRow(chatCounter);
chatTable->setItem(l, 1, new QTableWidgetItem(QString::fromStdString(message.sender_name()))); chatTable->setItem(chatCounter, 0, new QTableWidgetItem(QString::fromStdString(message.time())));
chatTable->setItem(l, 2, new QTableWidgetItem(QString::fromStdString(message.sender_ip()))); chatTable->setItem(chatCounter, 1, new QTableWidgetItem(QString::fromStdString(message.sender_name())));
chatTable->setItem(l, 3, new QTableWidgetItem(QString::fromStdString(message.message()))); chatTable->setItem(chatCounter, 2, new QTableWidgetItem(QString::fromStdString(message.sender_ip())));
chatTable->setItem(l, 4, new QTableWidgetItem(QString::fromStdString(message.target_id()))); chatTable->setItem(chatCounter, 3, new QTableWidgetItem(QString::fromStdString(message.message())));
chatTable->setItem(l, 5, new QTableWidgetItem(QString::fromStdString(message.target_name()))); chatTable->setItem(chatCounter, 4, new QTableWidgetItem(QString::fromStdString(message.target_id())));
++l; chatTable->setItem(chatCounter, 5, new QTableWidgetItem(QString::fromStdString(message.target_name())));
++chatCounter;
} }
} }
roomTable->setRowCount(j); if (roomCounter) {
roomTable->resizeColumnsToContents();
gameTable->setRowCount(k);
gameTable->resizeColumnsToContents();
chatTable->setRowCount(l);
chatTable->resizeColumnsToContents();
if (mainRoom->isChecked()) {
roomTable->resize(600, 200);
roomTable->show(); roomTable->show();
roomTable->resizeColumnsToContents();
} else {
roomTable->hide();
} }
if (gameRoom->isChecked()) { if (gameCounter) {
gameTable->resize(600, 200); gameTable->resizeColumnsToContents();
gameTable->show(); gameTable->show();
} else {
gameTable->hide();
} }
if (privateChat->isChecked()) { if (chatCounter) {
chatTable->resize(600, 200); chatTable->resizeColumnsToContents();
chatTable->show(); chatTable->show();
} else {
chatTable->hide();
} }
} else
QMessageBox::information(static_cast<QWidget *>(parent()), tr("Message History"), tr("There are no messages for the selected filters."));
} else
QMessageBox::critical(static_cast<QWidget *>(parent()), tr("Message History"), tr("Failed to collect message history information."));
} }
void TabLog::restartLayout() void TabLog::restartLayout()
{ {
searchDock->setFloating(false); searchDock->setFloating(false);
MainWindow->addDockWidget(Qt::TopDockWidgetArea, searchDock); addDockWidget(Qt::LeftDockWidgetArea, searchDock);
searchDock->setVisible(true); searchDock->setVisible(true);
} }
\ No newline at end of file
...@@ -16,10 +16,10 @@ class QLabel; ...@@ -16,10 +16,10 @@ class QLabel;
class QDockWidget; class QDockWidget;
class QWidget; class QWidget;
class QGridLayout; class QGridLayout;
class QTableWidget;
class CommandContainer; class CommandContainer;
class Response; class Response;
class AbstractClient; class AbstractClient;
class QMainWindow;
class TabLog : public Tab { class TabLog : public Tab {
Q_OBJECT Q_OBJECT
...@@ -36,7 +36,7 @@ private: ...@@ -36,7 +36,7 @@ private:
QGridLayout *criteriaGrid, *locationGrid, *rangeGrid, *maxResultsGrid, *descriptionGrid, *buttonGrid; QGridLayout *criteriaGrid, *locationGrid, *rangeGrid, *maxResultsGrid, *descriptionGrid, *buttonGrid;
QGroupBox *criteriaGroupBox, *locationGroupBox, *rangeGroupBox, *maxResultsGroupBox, *descriptionGroupBox, *buttonGroupBox; QGroupBox *criteriaGroupBox, *locationGroupBox, *rangeGroupBox, *maxResultsGroupBox, *descriptionGroupBox, *buttonGroupBox;
QVBoxLayout *mainLayout; QVBoxLayout *mainLayout;
QMainWindow *MainWindow; QTableWidget *roomTable, *gameTable, *chatTable;
void createDock(); void createDock();
signals: signals:
......
...@@ -39,7 +39,10 @@ TabMessage::TabMessage(TabSupervisor *_tabSupervisor, AbstractClient *_client, c ...@@ -39,7 +39,10 @@ TabMessage::TabMessage(TabSupervisor *_tabSupervisor, AbstractClient *_client, c
addTabMenu(messageMenu); addTabMenu(messageMenu);
retranslateUi(); retranslateUi();
setLayout(vbox);
QWidget * mainWidget = new QWidget(this);
mainWidget->setLayout(vbox);
setCentralWidget(mainWidget);
} }
TabMessage::~TabMessage() TabMessage::~TabMessage()
......
...@@ -106,7 +106,10 @@ TabReplays::TabReplays(TabSupervisor *_tabSupervisor, AbstractClient *_client) ...@@ -106,7 +106,10 @@ TabReplays::TabReplays(TabSupervisor *_tabSupervisor, AbstractClient *_client)
rightToolBar->addAction(aDeleteRemoteReplay); rightToolBar->addAction(aDeleteRemoteReplay);
retranslateUi(); retranslateUi();
setLayout(hbox);
QWidget * mainWidget = new QWidget(this);
mainWidget->setLayout(hbox);
setCentralWidget(mainWidget);
connect(client, SIGNAL(replayAddedEventReceived(const Event_ReplayAdded &)), this, SLOT(replayAddedEventReceived(const Event_ReplayAdded &))); connect(client, SIGNAL(replayAddedEventReceived(const Event_ReplayAdded &)), this, SLOT(replayAddedEventReceived(const Event_ReplayAdded &)));
} }
......
...@@ -104,9 +104,6 @@ TabRoom::TabRoom(TabSupervisor *_tabSupervisor, AbstractClient *_client, ServerI ...@@ -104,9 +104,6 @@ TabRoom::TabRoom(TabSupervisor *_tabSupervisor, AbstractClient *_client, ServerI
roomMenu->addAction(aLeaveRoom); roomMenu->addAction(aLeaveRoom);
addTabMenu(roomMenu); addTabMenu(roomMenu);
retranslateUi();
setLayout(hbox);
const int userListSize = info.user_list_size(); const int userListSize = info.user_list_size();
for (int i = 0; i < userListSize; ++i){ for (int i = 0; i < userListSize; ++i){
userList->processUserInfo(info.user_list(i), true); userList->processUserInfo(info.user_list(i), true);
...@@ -130,6 +127,12 @@ TabRoom::TabRoom(TabSupervisor *_tabSupervisor, AbstractClient *_client, ServerI ...@@ -130,6 +127,12 @@ TabRoom::TabRoom(TabSupervisor *_tabSupervisor, AbstractClient *_client, ServerI
actCompleterChanged(); actCompleterChanged();
connect(&settingsCache->shortcuts(), SIGNAL(shortCutchanged()),this,SLOT(refreshShortcuts())); connect(&settingsCache->shortcuts(), SIGNAL(shortCutchanged()),this,SLOT(refreshShortcuts()));
refreshShortcuts(); refreshShortcuts();
retranslateUi();
QWidget * mainWidget = new QWidget(this);
mainWidget->setLayout(hbox);
setCentralWidget(mainWidget);
} }
TabRoom::~TabRoom() TabRoom::~TabRoom()
......
...@@ -141,7 +141,11 @@ TabServer::TabServer(TabSupervisor *_tabSupervisor, AbstractClient *_client, QWi ...@@ -141,7 +141,11 @@ TabServer::TabServer(TabSupervisor *_tabSupervisor, AbstractClient *_client, QWi
vbox->addWidget(roomSelector); vbox->addWidget(roomSelector);
vbox->addWidget(serverInfoBox); vbox->addWidget(serverInfoBox);
setLayout(vbox); retranslateUi();
QWidget * mainWidget = new QWidget(this);
mainWidget->setLayout(vbox);
setCentralWidget(mainWidget);
} }
void TabServer::retranslateUi() void TabServer::retranslateUi()
......
...@@ -75,7 +75,11 @@ TabUserLists::TabUserLists(TabSupervisor *_tabSupervisor, AbstractClient *_clien ...@@ -75,7 +75,11 @@ TabUserLists::TabUserLists(TabSupervisor *_tabSupervisor, AbstractClient *_clien
mainLayout->addLayout(ignorePanel); mainLayout->addLayout(ignorePanel);
mainLayout->addLayout(vbox); mainLayout->addLayout(vbox);
setLayout(mainLayout); retranslateUi();
QWidget * mainWidget = new QWidget(this);
mainWidget->setLayout(mainLayout);
setCentralWidget(mainWidget);
} }
void TabUserLists::addToBuddyList() void TabUserLists::addToBuddyList()
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment