diff options
| author | Rachel Powers <508861+Ryex@users.noreply.github.com> | 2023-07-07 21:25:14 -0700 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-07-07 21:25:14 -0700 | 
| commit | 3211b265d75dc7e28b1608935396bce2ac4648dd (patch) | |
| tree | b321cd2ac758b182c3f8b7b9d42e7ca98763a4af /launcher/ui | |
| parent | 1131038fdb0093ef9c732b18d699b6176fc6d82c (diff) | |
| parent | e5b9bfb2e78ca86917d91fd41de1e797e570cf83 (diff) | |
| download | PrismLauncher-3211b265d75dc7e28b1608935396bce2ac4648dd.tar.gz PrismLauncher-3211b265d75dc7e28b1608935396bce2ac4648dd.tar.bz2 PrismLauncher-3211b265d75dc7e28b1608935396bce2ac4648dd.zip | |
Merge pull request #1302 from Ryex/fix/progress-dialog-segfault
fix: segfault in progress dialog
Diffstat (limited to 'launcher/ui')
| -rw-r--r-- | launcher/ui/dialogs/ProgressDialog.cpp | 35 | 
1 files changed, 23 insertions, 12 deletions
| diff --git a/launcher/ui/dialogs/ProgressDialog.cpp b/launcher/ui/dialogs/ProgressDialog.cpp index 246a0fd4..3368a8c4 100644 --- a/launcher/ui/dialogs/ProgressDialog.cpp +++ b/launcher/ui/dialogs/ProgressDialog.cpp @@ -34,6 +34,7 @@   */  #include "ProgressDialog.h" +#include <QPoint>  #include "ui_ProgressDialog.h"  #include <limits> @@ -68,6 +69,7 @@ ProgressDialog::ProgressDialog(QWidget* parent) : QDialog(parent), ui(new Ui::Pr      setAttribute(Qt::WidgetAttribute::WA_QuitOnClose, true);      setSkipButton(false);      changeProgress(0, 100); +    updateSize();  }  void ProgressDialog::setSkipButton(bool present, QString label) @@ -96,22 +98,29 @@ ProgressDialog::~ProgressDialog()  void ProgressDialog::updateSize()  {         QSize lastSize = this->size(); -    QSize qSize = QSize(480, minimumSizeHint().height()); - +    QPoint lastPos = this->pos(); +    int minHeight = ui->globalStatusDetailsLabel->minimumSize().height() + (ui->verticalLayout->spacing() * 2); +    minHeight += ui->globalProgressBar->minimumSize().height() + ui->verticalLayout->spacing(); +    if (!ui->taskProgressScrollArea->isHidden()) +        minHeight += ui->taskProgressScrollArea->minimumSizeHint().height() + ui->verticalLayout->spacing(); +    if (ui->skipButton->isVisible()) +        minHeight += ui->skipButton->height() + ui->verticalLayout->spacing(); +    minHeight = std::max(minHeight, 60); +    QSize minSize = QSize(480, minHeight); + +    setMinimumSize(minSize); +    adjustSize(); + +    QSize newSize = this->size();      // if the current window is too small -    if ((lastSize != qSize) && (lastSize.height() < qSize.height())) +    if ((lastSize != newSize) && (lastSize.height() < newSize.height()))      { -        resize(qSize); -         -        // keep the dialog in the center after a resize -        this->move( -            this->parentWidget()->x() + (this->parentWidget()->width() - this->width()) / 2, -            this->parentWidget()->y() + (this->parentWidget()->height() - this->height()) / 2 -        ); +        QSize sizeDiff = lastSize - newSize; // last size was smaller, the results should be negative +        // center on old position after resize +        QPoint newPos(lastPos.x() + (sizeDiff.width() / 2), lastPos.y() + (sizeDiff.height() / 2)); +        this->move(newPos);      } -    setMinimumSize(qSize); -  }  int ProgressDialog::execWithTask(Task* task) @@ -201,7 +210,9 @@ void ProgressDialog::onTaskSucceeded()  void ProgressDialog::changeStatus(const QString& status)  {      ui->globalStatusLabel->setText(task->getStatus()); +    ui->globalStatusLabel->adjustSize();      ui->globalStatusDetailsLabel->setText(task->getDetails()); +    ui->globalStatusDetailsLabel->adjustSize();      updateSize();  } | 
