diff --git a/res.qrc b/res.qrc index 33995781f..793d63c22 100644 --- a/res.qrc +++ b/res.qrc @@ -108,5 +108,6 @@ ui/statusButton/dot_idle.png ui/statusButton/dot_online.png ui/statusButton/statusButton.css + ui/statusButton/menu_indicator.png diff --git a/ui/fileTransferWidget/fileTransferWidget.css b/ui/fileTransferWidget/fileTransferWidget.css index ce8f1759b..ab306fb9c 100644 --- a/ui/fileTransferWidget/fileTransferWidget.css +++ b/ui/fileTransferWidget/fileTransferWidget.css @@ -16,11 +16,11 @@ QProgressBar { background-color: transparent; - border: 1px solid black; + border: 1px solid rgb(150,150,150); height: 11px; } QProgressBar::chunk { - background-color: black; + background-color: rgb(150,150,150); width: 2px; } \ No newline at end of file diff --git a/ui/statusButton/menu_indicator.png b/ui/statusButton/menu_indicator.png new file mode 100644 index 000000000..0015b5d08 Binary files /dev/null and b/ui/statusButton/menu_indicator.png differ diff --git a/ui/statusButton/statusButton.css b/ui/statusButton/statusButton.css index e96750704..5ca59c357 100644 --- a/ui/statusButton/statusButton.css +++ b/ui/statusButton/statusButton.css @@ -1,17 +1,41 @@ QPushButton { - background: none; + background: none; background-color: rgb(65,65,65); border: none; border-radius: 6px; } -/*Disabled due to a bug preventing button status from - resetting to default after menu item pressed +QPushButton#online +{ + image: url(":ui/statusButton/dot_online.png") center center; +} + +QPushButton#away +{ + image: url(":ui/statusButton/dot_idle.png") center center; +} + +QPushButton#busy +{ + image: url(":ui/statusButton/dot_busy.png") center center; +} + +QPushButton#offline +{ + image: url(":ui/statusButton/dot_away.png") center center; +} + +QPushButton:default +{ + background-color: rgb(65,65,65); +} + +/*Bugged in Qt, but it's probably better to leave enabled so that users can tell it's clickable*/ QPushButton:hover { background-color: rgb(75,75,75); -}*/ +} QPushButton:pressed { @@ -21,3 +45,14 @@ QPushButton:pressed QPushButton:focus { outline: none; } + +QPushButton::menu-indicator {image: none;} + +QPushButton::menu-indicator:pressed, QPushButton::menu-indicator:open +{ + image: url(":ui/statusButton/menu_indicator.png"); + subcontrol-origin: padding; + subcontrol-position: bottom center; + position: relative; + bottom: 2px; +} diff --git a/widget.ui b/widget.ui index 34db6ed85..48f172468 100644 --- a/widget.ui +++ b/widget.ui @@ -2026,19 +2026,24 @@ QSplitter:handle{ + + + 0 + 0 + + 20 40 + + Qt::NoFocus + - - - :/ui/statusButton/dot_away.png:/ui/statusButton/dot_away.png - 10 diff --git a/widget/widget.cpp b/widget/widget.cpp index c480548b9..44352ad0d 100644 --- a/widget/widget.cpp +++ b/widget/widget.cpp @@ -156,6 +156,7 @@ Widget::Widget(QWidget *parent) : setStatusBusy->setIcon(QIcon(":ui/statusButton/dot_busy.png")); ui->statusButton->setMenu(statusButtonMenu); + this->setMouseTracking(true); QList widgets = this->findChildren(); @@ -315,14 +316,28 @@ void Widget::onFailedToStartCore() void Widget::onStatusSet(Status status) { + //We have to use stylesheets here, there's no way to + //prevent the button icon from moving when pressed otherwise if (status == Status::Online) - ui->statusButton->setIcon(QIcon(":ui/statusButton/dot_online.png")); + { + ui->statusButton->setObjectName("online"); + ui->statusButton->style()->polish(ui->statusButton); + } else if (status == Status::Away) - ui->statusButton->setIcon(QIcon(":ui/statusButton/dot_idle.png")); + { + ui->statusButton->setObjectName("away"); + ui->statusButton->style()->polish(ui->statusButton); + } else if (status == Status::Busy) - ui->statusButton->setIcon(QIcon(":ui/statusButton/dot_busy.png")); + { + ui->statusButton->setObjectName("busy"); + ui->statusButton->style()->polish(ui->statusButton); + } else if (status == Status::Offline) - ui->statusButton->setIcon(QIcon(":ui/statusButton/dot_away.png")); + { + ui->statusButton->setObjectName("offline"); + ui->statusButton->style()->polish(ui->statusButton); + } } void Widget::onAddClicked()