123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- #include "serverstatuswidget.h"
- #include "ui_serverstatuswidget.h"
- #include <QDebug>
- #include "constants.h"
- #include "models/settings.h"
- ServerStatusWidget::ServerStatusWidget(QWidget *parent) :
- QWidget(parent),
- ui(new Ui::ServerStatusWidget)
- {
- servers_disabled = false;
- setMouseTracking(true);
- ui->setupUi(this);
- connect(&update_timer, &QTimer::timeout, &status_downloader, &Downloader::start);
- connect(&status_downloader, &Downloader::downloadFinished, this, &ServerStatusWidget::updateStatus);
- // updateStatus will start tech_work_message_downloader
- connect(&tech_work_message_downloader, &Downloader::downloadFinished, this, &ServerStatusWidget::updateTechWorksMessage);
- status_downloader.targetBytearray = &status_data;
- status_downloader.setUrl(Settings::getValue("Network/game_servers_status").toUrl());
- tech_work_message_downloader.targetBytearray = &tech_work_message_data;
- tech_work_message_downloader.setUrl(Settings::getValue("Network/game_servers_message").toUrl());
- update_timer.setInterval(1000 * 60); // 1 minute;
- update_timer.start();
- // Perform update on startup
- status_downloader.start();
- }
- ServerStatusWidget::~ServerStatusWidget()
- {
- delete ui;
- }
- void ServerStatusWidget::updateFontsSizes()
- {
- foreach (QString server_name, servers_list) {
- QLabel* label = ui->servers_list->findChild<QLabel*>(server_name.toLower());
- if (!label) {
- qDebug() << "Error! Cannot find server widget " << server_name;
- continue;
- }
- label->setFont(trajan_9pt);
- }
- }
- void ServerStatusWidget::resizeEvent(QResizeEvent*)
- {
- updateFontsSizes();
- }
- void ServerStatusWidget::leaveEvent(QEvent *event)
- {
- event->ignore();
- emit showNoTooltip();
- }
- void ServerStatusWidget::enterEvent(QEvent *event)
- {
- event->ignore();
- emit showServersTooltip(server_status_tooltip_);
- }
- void ServerStatusWidget::updateServerStatus()
- {
- status_downloader.start();
- }
- void ServerStatusWidget::updateStatus()
- {
- if (QString(status_data).contains("profilaktika")) {
- servers_disabled = true;
- qDebug() << "All servers are closed!";
- foreach (QString server_name, servers_list) {
- QLabel* label = ui->servers_list->findChild<QLabel*>(server_name.toLower());
- if (!label) {
- qDebug() << "Error! Cannot find server widget " << server_name;
- continue;
- }
- label->setStyleSheet(closed_color);
- }
- status_data = "";
- tech_work_message_downloader.start();
- return;
- }
- servers_disabled = false;
- QStringList servers = QString(status_data).split("|||");
- foreach (QString server, servers) {
- QStringList data = server.split(":::");
- QWidget* widget = findChild<QWidget*>(QString(data[0]).toLower());
- if (!widget)
- continue;
- if (data.size() > 1 && data[1] == "on")
- widget->setStyleSheet(open_color);
- else
- widget->setStyleSheet(closed_color);
- }
- status_data = "";
- tech_work_message_downloader.start();
- }
- void ServerStatusWidget::updateTechWorksMessage()
- {
- if (tech_work_message_data.isEmpty()) {
- if (!servers_disabled) {
- server_status_tooltip_ = "Серверы игры работают в штатном режиме.";
- } else {
- server_status_tooltip_ = "<p style =\"color:#ff0000\">Серверы игры отключены.</p>";
- }
- tech_work_message_data = "";
- return;
- }
- QStringList list = QString(tech_work_message_data).split(":::");
- if (list.size() < 4) {
- tech_work_message_data = "";
- return;
- }
- QString time_beginning = "<span style =\"font-family:Trajan Pro 3\">" + list[0] + "</span>";
- QString time_end = "<span style =\"font-family:Trajan Pro 3\">" + list[1] + "</span>";
- QString day = "<span style =\"font-family:Trajan Pro 3\">" + list[2] + "</span>";
- QString month = QString(" " + list[3]).toUpper();
- if (!servers_disabled) {
- server_status_tooltip_ = "<p style=\"color:#ffff7f\">Планируется отключение серверов игры " + day + month + " с " + time_beginning + " до " + time_end+ " (мск).</p>";
- } else {
- server_status_tooltip_ = "<p style=\"color:#ff0000\">Серверы игры отключены на профилактику<br>Время проф. работ: " + day + month + " с " + time_beginning + " до " + time_end + " (мск).</p>";
- }
- tech_work_message_data = "";
- }
|