mirror of https://github.com/procxx/kepka.git
Fix crash and improve info navigation.
This commit is contained in:
parent
0811190527
commit
41873412e7
|
@ -93,8 +93,6 @@ void WrapWidget::restoreHistoryStack(
|
|||
Expects(!stack.empty());
|
||||
Expects(!hasStackHistory());
|
||||
|
||||
startInjectingActivePeerProfiles();
|
||||
|
||||
auto content = std::move(stack.back());
|
||||
stack.pop_back();
|
||||
if (!stack.empty()) {
|
||||
|
@ -105,6 +103,9 @@ void WrapWidget::restoreHistoryStack(
|
|||
_historyStack.push_back(std::move(item));
|
||||
}
|
||||
}
|
||||
|
||||
startInjectingActivePeerProfiles();
|
||||
|
||||
showNewContent(content.get());
|
||||
}
|
||||
|
||||
|
@ -136,15 +137,13 @@ void WrapWidget::injectActivePeerProfile(not_null<PeerData*> peer) {
|
|||
_historyStack.insert(
|
||||
_historyStack.begin(),
|
||||
std::move(injected));
|
||||
afterStackHistoryInject();
|
||||
if (_content) {
|
||||
setupTop();
|
||||
finishShowContent();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void WrapWidget::afterStackHistoryInject() {
|
||||
setupTop();
|
||||
finishShowContent();
|
||||
}
|
||||
|
||||
std::unique_ptr<Controller> WrapWidget::createController(
|
||||
not_null<Window::Controller*> window,
|
||||
not_null<ContentMemento*> memento) {
|
||||
|
@ -685,8 +684,7 @@ bool WrapWidget::showInternal(
|
|||
auto content = infoMemento->content();
|
||||
auto skipInternal = hasStackHistory()
|
||||
&& (params.way == Window::SectionShow::Way::ClearStack);
|
||||
if (_controller->validateMementoPeer(content)
|
||||
&& infoMemento->stackSize() == 1) {
|
||||
if (_controller->validateMementoPeer(content)) {
|
||||
if (!skipInternal && _content->showInternal(content)) {
|
||||
highlightTopBar();
|
||||
return true;
|
||||
|
@ -711,6 +709,14 @@ bool WrapWidget::showInternal(
|
|||
// }
|
||||
}
|
||||
}
|
||||
|
||||
// If we're in a nested section and we're asked to show
|
||||
// a chat profile that is at the bottom of the stack we'll
|
||||
// just go back in the stack all the way instead of pushing.
|
||||
if (returnToFirstStackFrame(content, params)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
showNewContent(
|
||||
content,
|
||||
params);
|
||||
|
@ -750,6 +756,25 @@ QRect WrapWidget::contentGeometry() const {
|
|||
return rect().marginsRemoved({ 0, topWidget()->height(), 0, 0 });
|
||||
}
|
||||
|
||||
|
||||
bool WrapWidget::returnToFirstStackFrame(
|
||||
not_null<ContentMemento*> memento,
|
||||
const Window::SectionShow ¶ms) {
|
||||
if (!hasStackHistory()) {
|
||||
return false;
|
||||
}
|
||||
auto firstPeerId = _historyStack.front().section->peerId();
|
||||
auto firstSection = _historyStack.front().section->section();
|
||||
if (firstPeerId == memento->peerId()
|
||||
&& firstSection.type() == memento->section().type()
|
||||
&& firstSection.type() == Section::Type::Profile) {
|
||||
_historyStack.resize(1);
|
||||
showBackFromStack();
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
void WrapWidget::showNewContent(
|
||||
not_null<ContentMemento*> memento,
|
||||
const Window::SectionShow ¶ms) {
|
||||
|
|
|
@ -146,7 +146,6 @@ private:
|
|||
struct StackItem;
|
||||
|
||||
void startInjectingActivePeerProfiles();
|
||||
void afterStackHistoryInject();
|
||||
void injectActivePeerProfile(not_null<PeerData*> peer);
|
||||
void restoreHistoryStack(
|
||||
std::vector<std::unique_ptr<ContentMemento>> stack);
|
||||
|
@ -158,6 +157,9 @@ private:
|
|||
void showNewContent(
|
||||
not_null<ContentMemento*> memento,
|
||||
const Window::SectionShow ¶ms);
|
||||
bool returnToFirstStackFrame(
|
||||
not_null<ContentMemento*> memento,
|
||||
const Window::SectionShow ¶ms);
|
||||
void setupTop();
|
||||
//void setupTabbedTop();
|
||||
//void setupTabs(Tab tab);
|
||||
|
|
Loading…
Reference in New Issue