From 98ea9b43b35bbb2c6735c378ebd2f84536a940e7 Mon Sep 17 00:00:00 2001 From: Marko Lindqvist Date: Mon, 18 Jul 2022 18:10:01 +0300 Subject: [PATCH 27/27] Qt: Adjust UI depending if trading_gold is enabled See osdn #45149 Signed-off-by: Marko Lindqvist --- client/gui-qt/diplodlg.cpp | 50 +++++++++++++++++++++++--------------- client/gui-qt/diplodlg.h | 2 -- 2 files changed, 30 insertions(+), 22 deletions(-) diff --git a/client/gui-qt/diplodlg.cpp b/client/gui-qt/diplodlg.cpp index d07040fab0..8542aa1b2e 100644 --- a/client/gui-qt/diplodlg.cpp +++ b/client/gui-qt/diplodlg.cpp @@ -62,8 +62,6 @@ diplo_wdg::diplo_wdg(int counterpart, int initiated_from): QWidget() QLabel *label2; QLabel *label3; QLabel *label4; - QLabel *goldlab1; - QLabel *goldlab2; QPushButton *add_clause1; QPushButton *add_clause2; QPixmap *pix = NULL; @@ -76,6 +74,8 @@ diplo_wdg::diplo_wdg(int counterpart, int initiated_from): QWidget() get_color(tileset, COLOR_MAPVIEW_CITYTEXT), get_color(tileset, COLOR_MAPVIEW_CITYTEXT_DARK) }; + int clause_column; + if (counterpart == initiated_from) { initiated_from = client_player_number(); } @@ -162,22 +162,36 @@ diplo_wdg::diplo_wdg(int counterpart, int initiated_from): QWidget() layout->addWidget(plr2_label, 6, 0); layout->addWidget(label2, 6, 5); layout->addWidget(plr2_accept, 6, 10); - goldlab1 = new QLabel(_("Gold:")); - goldlab1->setAlignment(Qt::AlignRight); - goldlab2 = new QLabel(_("Gold:")); - goldlab2->setAlignment(Qt::AlignRight); - gold_edit1 = new QSpinBox; - gold_edit2 = new QSpinBox; - gold_edit1->setMinimum(0); - gold_edit2->setMinimum(0); - gold_edit1->setFocusPolicy(Qt::ClickFocus); - gold_edit2->setFocusPolicy(Qt::ClickFocus); + if (game.info.trading_gold) { + QLabel *goldlab1; + QLabel *goldlab2; + QSpinBox *gold_edit1; + QSpinBox *gold_edit2; + + goldlab1 = new QLabel(_("Gold:")); + goldlab1->setAlignment(Qt::AlignRight); + goldlab2 = new QLabel(_("Gold:")); + goldlab2->setAlignment(Qt::AlignRight); + gold_edit1 = new QSpinBox; + gold_edit2 = new QSpinBox; + gold_edit1->setMinimum(0); + gold_edit2->setMinimum(0); + gold_edit1->setFocusPolicy(Qt::ClickFocus); + gold_edit2->setFocusPolicy(Qt::ClickFocus); gold_edit2->setMaximum(player_by_number(player1)->economic.gold); gold_edit1->setMaximum(player_by_number(player2)->economic.gold); + connect(gold_edit1, SIGNAL(valueChanged(int)), SLOT(gold_changed1(int))); + connect(gold_edit2, SIGNAL(valueChanged(int)), SLOT(gold_changed2(int))); + layout->addWidget(goldlab1, 7, 4); + layout->addWidget(goldlab2, 3, 4); + layout->addWidget(gold_edit1, 7, 5); + layout->addWidget(gold_edit2, 3, 5); + clause_column = 6; + } else { + clause_column = 5; } - connect(gold_edit1, SIGNAL(valueChanged(int)), SLOT(gold_changed1(int))); - connect(gold_edit2, SIGNAL(valueChanged(int)), SLOT(gold_changed2(int))); + add_clause1 = new QPushButton(style()->standardIcon(QStyle::SP_ArrowRight), _("Add Clause...")); add_clause2 = new QPushButton(style()->standardIcon(QStyle::SP_ArrowRight), @@ -186,12 +200,8 @@ diplo_wdg::diplo_wdg(int counterpart, int initiated_from): QWidget() add_clause2->setFocusPolicy(Qt::ClickFocus); connect(add_clause1, &QAbstractButton::clicked, this, &diplo_wdg::show_menu_p2); connect(add_clause2, &QAbstractButton::clicked, this, &diplo_wdg::show_menu_p1); - layout->addWidget(goldlab1, 7, 4); - layout->addWidget(goldlab2, 3, 4); - layout->addWidget(gold_edit1, 7, 5); - layout->addWidget(gold_edit2, 3, 5); - layout->addWidget(add_clause1, 7, 6); - layout->addWidget(add_clause2, 3, 6); + layout->addWidget(add_clause1, 7, clause_column); + layout->addWidget(add_clause2, 3, clause_column); text_edit = new QTableWidget(); text_edit->setColumnCount(1); diff --git a/client/gui-qt/diplodlg.h b/client/gui-qt/diplodlg.h index e8a99a1acb..c47880a300 100644 --- a/client/gui-qt/diplodlg.h +++ b/client/gui-qt/diplodlg.h @@ -54,8 +54,6 @@ class diplo_wdg: public QWidget QLabel *plr2_accept; QPushButton *accept_treaty; QPushButton *cancel_treaty; - QSpinBox *gold_edit1; - QSpinBox *gold_edit2; QTableWidget *text_edit; public: -- 2.35.1