2017-05-19 03:28:15 +03:00
|
|
|
/*
|
|
|
|
* nheko Copyright (C) 2017 Konstantinos Sideris <siderisk@auth.gr>
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2018-06-29 14:28:48 +03:00
|
|
|
#include <QSettings>
|
2017-05-19 03:28:15 +03:00
|
|
|
|
2020-01-31 08:12:02 +03:00
|
|
|
#include "Logging.h"
|
2017-05-19 03:28:15 +03:00
|
|
|
#include "Splitter.h"
|
|
|
|
|
2018-07-04 00:05:05 +03:00
|
|
|
constexpr auto MaxWidth = (1 << 24) - 1;
|
|
|
|
|
2017-05-19 19:55:38 +03:00
|
|
|
Splitter::Splitter(QWidget *parent)
|
2017-08-20 13:47:22 +03:00
|
|
|
: QSplitter(parent)
|
2020-01-31 08:12:02 +03:00
|
|
|
, sz_{splitter::calculateSidebarSizes(QFont{})}
|
2017-05-19 03:28:15 +03:00
|
|
|
{
|
2017-09-10 12:59:21 +03:00
|
|
|
connect(this, &QSplitter::splitterMoved, this, &Splitter::onSplitterMoved);
|
|
|
|
setChildrenCollapsible(false);
|
2017-05-19 03:28:15 +03:00
|
|
|
}
|
|
|
|
|
2018-06-29 14:28:48 +03:00
|
|
|
void
|
|
|
|
Splitter::restoreSizes(int fallback)
|
|
|
|
{
|
|
|
|
QSettings settings;
|
|
|
|
int savedWidth = settings.value("sidebar/width").toInt();
|
|
|
|
|
|
|
|
auto left = widget(0);
|
2021-01-21 15:45:50 +03:00
|
|
|
if (savedWidth <= 0) {
|
2018-07-04 00:05:05 +03:00
|
|
|
hideSidebar();
|
|
|
|
return;
|
2021-01-21 15:45:50 +03:00
|
|
|
} else if (savedWidth <= sz_.small) {
|
2018-06-29 14:28:48 +03:00
|
|
|
if (left) {
|
2018-10-07 14:09:47 +03:00
|
|
|
left->setMinimumWidth(sz_.small);
|
|
|
|
left->setMaximumWidth(sz_.small);
|
2018-06-29 14:28:48 +03:00
|
|
|
return;
|
|
|
|
}
|
2021-01-21 15:45:50 +03:00
|
|
|
} else if (savedWidth < sz_.normal) {
|
|
|
|
savedWidth = sz_.normal;
|
2018-06-29 14:28:48 +03:00
|
|
|
}
|
|
|
|
|
2018-10-07 14:09:47 +03:00
|
|
|
left->setMinimumWidth(sz_.normal);
|
|
|
|
left->setMaximumWidth(2 * sz_.normal);
|
2021-01-21 15:45:50 +03:00
|
|
|
setSizes({savedWidth, fallback - savedWidth});
|
2018-07-04 00:05:05 +03:00
|
|
|
|
|
|
|
setStretchFactor(0, 0);
|
|
|
|
setStretchFactor(1, 1);
|
2018-06-29 14:28:48 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
Splitter::~Splitter()
|
|
|
|
{
|
|
|
|
auto left = widget(0);
|
|
|
|
|
|
|
|
if (left) {
|
|
|
|
QSettings settings;
|
2018-07-04 00:05:05 +03:00
|
|
|
settings.setValue("sidebar/width", left->width());
|
2018-06-29 14:28:48 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-20 13:47:22 +03:00
|
|
|
void
|
|
|
|
Splitter::onSplitterMoved(int pos, int index)
|
2017-05-19 03:28:15 +03:00
|
|
|
{
|
2017-09-10 12:59:21 +03:00
|
|
|
Q_UNUSED(pos);
|
|
|
|
Q_UNUSED(index);
|
2017-05-19 03:28:15 +03:00
|
|
|
|
2017-09-10 12:59:21 +03:00
|
|
|
auto s = sizes();
|
2017-05-19 03:28:15 +03:00
|
|
|
|
2017-09-10 12:59:21 +03:00
|
|
|
if (s.count() < 2) {
|
2020-01-31 08:12:02 +03:00
|
|
|
nhlog::ui()->warn("Splitter needs at least two children");
|
2017-09-10 12:59:21 +03:00
|
|
|
return;
|
|
|
|
}
|
2017-05-19 03:28:15 +03:00
|
|
|
|
2018-10-07 14:09:47 +03:00
|
|
|
if (s[0] == sz_.normal) {
|
2017-09-10 12:59:21 +03:00
|
|
|
rightMoveCount_ += 1;
|
2017-05-19 03:28:15 +03:00
|
|
|
|
2017-09-10 12:59:21 +03:00
|
|
|
if (rightMoveCount_ > moveEventLimit_) {
|
2018-07-08 22:10:40 +03:00
|
|
|
auto left = widget(0);
|
|
|
|
auto cursorPosition = left->mapFromGlobal(QCursor::pos());
|
2017-05-19 03:28:15 +03:00
|
|
|
|
2017-09-10 12:59:21 +03:00
|
|
|
// if we are coming from the right, the cursor should
|
|
|
|
// end up on the first widget.
|
2018-07-08 22:10:40 +03:00
|
|
|
if (left->rect().contains(cursorPosition)) {
|
2018-10-07 14:09:47 +03:00
|
|
|
left->setMinimumWidth(sz_.small);
|
|
|
|
left->setMaximumWidth(sz_.small);
|
2017-05-19 03:28:15 +03:00
|
|
|
|
2017-09-10 12:59:21 +03:00
|
|
|
rightMoveCount_ = 0;
|
|
|
|
}
|
|
|
|
}
|
2018-10-07 14:09:47 +03:00
|
|
|
} else if (s[0] == sz_.small) {
|
2017-09-10 12:59:21 +03:00
|
|
|
leftMoveCount_ += 1;
|
2017-05-19 03:28:15 +03:00
|
|
|
|
2017-09-10 12:59:21 +03:00
|
|
|
if (leftMoveCount_ > moveEventLimit_) {
|
2018-07-08 22:10:40 +03:00
|
|
|
auto left = widget(0);
|
|
|
|
auto right = widget(1);
|
|
|
|
auto cursorPosition = right->mapFromGlobal(QCursor::pos());
|
2017-05-19 03:28:15 +03:00
|
|
|
|
2017-09-10 12:59:21 +03:00
|
|
|
// We move the start a little further so the transition isn't so abrupt.
|
|
|
|
auto extended = right->rect();
|
|
|
|
extended.translate(100, 0);
|
2017-05-19 03:28:15 +03:00
|
|
|
|
2017-09-10 12:59:21 +03:00
|
|
|
// if we are coming from the left, the cursor should
|
|
|
|
// end up on the second widget.
|
2018-07-08 22:10:40 +03:00
|
|
|
if (extended.contains(cursorPosition) &&
|
2018-10-07 14:09:47 +03:00
|
|
|
right->size().width() >= sz_.collapsePoint + sz_.normal) {
|
|
|
|
left->setMinimumWidth(sz_.normal);
|
|
|
|
left->setMaximumWidth(2 * sz_.normal);
|
2017-05-19 03:28:15 +03:00
|
|
|
|
2017-09-10 12:59:21 +03:00
|
|
|
leftMoveCount_ = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2017-05-19 03:28:15 +03:00
|
|
|
}
|
2018-07-04 00:05:05 +03:00
|
|
|
|
2018-07-01 22:57:14 +03:00
|
|
|
void
|
2018-07-04 00:05:05 +03:00
|
|
|
Splitter::hideSidebar()
|
2018-07-01 22:57:14 +03:00
|
|
|
{
|
2018-07-04 00:05:05 +03:00
|
|
|
auto left = widget(0);
|
|
|
|
if (left)
|
|
|
|
left->hide();
|
|
|
|
}
|
2018-07-01 22:57:14 +03:00
|
|
|
|
2018-07-04 00:05:05 +03:00
|
|
|
void
|
|
|
|
Splitter::showChatView()
|
|
|
|
{
|
|
|
|
auto left = widget(0);
|
2018-07-01 22:57:14 +03:00
|
|
|
auto right = widget(1);
|
|
|
|
|
2018-07-04 00:05:05 +03:00
|
|
|
if (right->isHidden()) {
|
|
|
|
left->hide();
|
2018-07-01 22:57:14 +03:00
|
|
|
right->show();
|
|
|
|
|
2018-07-04 00:05:05 +03:00
|
|
|
// Restore previous size.
|
2018-10-07 14:09:47 +03:00
|
|
|
if (left->minimumWidth() == sz_.small) {
|
|
|
|
left->setMinimumWidth(sz_.small);
|
|
|
|
left->setMaximumWidth(sz_.small);
|
2018-07-04 00:05:05 +03:00
|
|
|
} else {
|
2018-10-07 14:09:47 +03:00
|
|
|
left->setMinimumWidth(sz_.normal);
|
|
|
|
left->setMaximumWidth(2 * sz_.normal);
|
2018-07-04 00:05:05 +03:00
|
|
|
}
|
2018-07-01 22:57:14 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2018-07-04 00:05:05 +03:00
|
|
|
Splitter::showFullRoomList()
|
2018-07-01 22:57:14 +03:00
|
|
|
{
|
2018-07-04 00:05:05 +03:00
|
|
|
auto left = widget(0);
|
|
|
|
auto right = widget(1);
|
|
|
|
|
|
|
|
right->hide();
|
|
|
|
|
|
|
|
left->show();
|
|
|
|
left->setMaximumWidth(MaxWidth);
|
2018-07-01 22:57:14 +03:00
|
|
|
}
|
2020-01-31 08:12:02 +03:00
|
|
|
|
|
|
|
splitter::SideBarSizes
|
|
|
|
splitter::calculateSidebarSizes(const QFont &f)
|
|
|
|
{
|
|
|
|
const auto height = static_cast<double>(QFontMetrics{f}.lineSpacing());
|
|
|
|
|
|
|
|
SideBarSizes sz;
|
2020-02-28 21:56:08 +03:00
|
|
|
sz.small = std::ceil(3.8 * height);
|
2020-01-31 08:12:02 +03:00
|
|
|
sz.normal = std::ceil(16 * height);
|
|
|
|
sz.groups = std::ceil(3 * height);
|
|
|
|
sz.collapsePoint = 2 * sz.normal;
|
|
|
|
|
|
|
|
return sz;
|
|
|
|
}
|