From 9fc9e4d008b4597b35548e55ae1b2e0783a075b9 Mon Sep 17 00:00:00 2001 From: Erin Date: Fri, 14 Jun 2024 09:35:57 -0500 Subject: [PATCH] Added loading gif when user selects yes after hitting Wifi/Ethernet toggle --- include/botui/Create3Widget.h | 1 + src/Create3Widget.cpp | 65 +++++++++++++++++++++++++++++++++-- 2 files changed, 63 insertions(+), 3 deletions(-) diff --git a/include/botui/Create3Widget.h b/include/botui/Create3Widget.h index 5dd693c4..3fbc34ec 100644 --- a/include/botui/Create3Widget.h +++ b/include/botui/Create3Widget.h @@ -27,6 +27,7 @@ private slots: void toggleChanged(); void indexChanged(int index); void run(); + void rebootBox(); private: Ui::Create3Widget *ui; diff --git a/src/Create3Widget.cpp b/src/Create3Widget.cpp index 31e214bb..1d1925f6 100644 --- a/src/Create3Widget.cpp +++ b/src/Create3Widget.cpp @@ -10,7 +10,6 @@ #include #include #include -#include #include #include #include @@ -18,6 +17,13 @@ #include #include "RootController.h" #include "kipr/create3/create3.capnp.h" +#include +#include +#include +#include +#include +#include +#include int exampleIndex; QStringList programList; @@ -110,6 +116,7 @@ void Create3Widget::toggleChanged() QString ipOutput = QString(output); qDebug() << "IP OUTPUT: " << ipOutput; // Get current IP output + if (ipOutput.contains("192.168.125.1")) { @@ -129,6 +136,7 @@ void Create3Widget::toggleChanged() } else { + rebootBox(); QProcess process; process.startDetached("/bin/sh", QStringList() << "/home/kipr/wombat-os/configFiles/create3_interface_swap.sh" << "eth"); @@ -151,6 +159,7 @@ void Create3Widget::toggleChanged() } else { + rebootBox(); QProcess process; process.startDetached("/bin/sh", QStringList() << "/home/kipr/wombat-os/configFiles/create3_interface_swap.sh" << "wifi"); @@ -158,6 +167,58 @@ void Create3Widget::toggleChanged() } } +void Create3Widget::rebootBox() +{ + + QMessageBox msgBox(this); + msgBox.setWindowTitle("Reboot"); + msgBox.setText("Rebooting now..."); + + // msgBox.setText("Rebooting..."); + msgBox.setMaximumSize(500, 480); + // msgBox.setStyleSheet("QLabel{min-width: 450px; min-height: 280px;}"); + msgBox.setStandardButtons(QMessageBox::NoButton); + + QLabel *gifLabel = new QLabel(); + QLabel *messageLabel = new QLabel(msgBox.text()); + + QGridLayout *msgBoxLayout = qobject_cast(msgBox.layout()); + + msgBoxLayout->setVerticalSpacing(0); + + QWidget *container = new QWidget(); + QVBoxLayout *vLayout = new QVBoxLayout(container); + + vLayout->addWidget(gifLabel); + + vLayout->addWidget(messageLabel); + vLayout->setAlignment(Qt::AlignCenter); + gifLabel->setAlignment(Qt::AlignCenter); + messageLabel->setAlignment(Qt::AlignCenter); + + msgBoxLayout->setSpacing(0); + vLayout->setSpacing(10); + + container->setLayout(vLayout); + + if (msgBoxLayout) + { + msgBoxLayout->addWidget(container, 0, 0, 1, msgBoxLayout->columnCount()); + } + + gifLabel->move(200, -50); + gifLabel->resize(400, 1100); + + QMovie *movie = new QMovie("://qml/botguy_noMargin.gif"); + movie->setScaledSize(QSize(200, 240)); + gifLabel->setMovie(movie); + movie->start(); + gifLabel->show(); + + msgBox.setText(""); + msgBox.exec(); +} + QString Create3Widget::getIP() { @@ -545,8 +606,6 @@ void Create3Widget::run() create3_wait(); printf("Done!\n"); - - } // catch (const std::exception &e) catch (const std::exception &e)