Fix crash and improve info navigation.

This commit is contained in:
John Preston 2017-11-17 11:33:20 +04:00
parent 0811190527
commit 41873412e7
2 changed files with 38 additions and 11 deletions

View File

@ -93,8 +93,6 @@ void WrapWidget::restoreHistoryStack(
Expects(!stack.empty()); Expects(!stack.empty());
Expects(!hasStackHistory()); Expects(!hasStackHistory());
startInjectingActivePeerProfiles();
auto content = std::move(stack.back()); auto content = std::move(stack.back());
stack.pop_back(); stack.pop_back();
if (!stack.empty()) { if (!stack.empty()) {
@ -105,6 +103,9 @@ void WrapWidget::restoreHistoryStack(
_historyStack.push_back(std::move(item)); _historyStack.push_back(std::move(item));
} }
} }
startInjectingActivePeerProfiles();
showNewContent(content.get()); showNewContent(content.get());
} }
@ -136,15 +137,13 @@ void WrapWidget::injectActivePeerProfile(not_null<PeerData*> peer) {
_historyStack.insert( _historyStack.insert(
_historyStack.begin(), _historyStack.begin(),
std::move(injected)); std::move(injected));
afterStackHistoryInject(); if (_content) {
setupTop();
finishShowContent();
}
} }
} }
void WrapWidget::afterStackHistoryInject() {
setupTop();
finishShowContent();
}
std::unique_ptr<Controller> WrapWidget::createController( std::unique_ptr<Controller> WrapWidget::createController(
not_null<Window::Controller*> window, not_null<Window::Controller*> window,
not_null<ContentMemento*> memento) { not_null<ContentMemento*> memento) {
@ -685,8 +684,7 @@ bool WrapWidget::showInternal(
auto content = infoMemento->content(); auto content = infoMemento->content();
auto skipInternal = hasStackHistory() auto skipInternal = hasStackHistory()
&& (params.way == Window::SectionShow::Way::ClearStack); && (params.way == Window::SectionShow::Way::ClearStack);
if (_controller->validateMementoPeer(content) if (_controller->validateMementoPeer(content)) {
&& infoMemento->stackSize() == 1) {
if (!skipInternal && _content->showInternal(content)) { if (!skipInternal && _content->showInternal(content)) {
highlightTopBar(); highlightTopBar();
return true; 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( showNewContent(
content, content,
params); params);
@ -750,6 +756,25 @@ QRect WrapWidget::contentGeometry() const {
return rect().marginsRemoved({ 0, topWidget()->height(), 0, 0 }); return rect().marginsRemoved({ 0, topWidget()->height(), 0, 0 });
} }
bool WrapWidget::returnToFirstStackFrame(
not_null<ContentMemento*> memento,
const Window::SectionShow &params) {
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( void WrapWidget::showNewContent(
not_null<ContentMemento*> memento, not_null<ContentMemento*> memento,
const Window::SectionShow &params) { const Window::SectionShow &params) {

View File

@ -146,7 +146,6 @@ private:
struct StackItem; struct StackItem;
void startInjectingActivePeerProfiles(); void startInjectingActivePeerProfiles();
void afterStackHistoryInject();
void injectActivePeerProfile(not_null<PeerData*> peer); void injectActivePeerProfile(not_null<PeerData*> peer);
void restoreHistoryStack( void restoreHistoryStack(
std::vector<std::unique_ptr<ContentMemento>> stack); std::vector<std::unique_ptr<ContentMemento>> stack);
@ -158,6 +157,9 @@ private:
void showNewContent( void showNewContent(
not_null<ContentMemento*> memento, not_null<ContentMemento*> memento,
const Window::SectionShow &params); const Window::SectionShow &params);
bool returnToFirstStackFrame(
not_null<ContentMemento*> memento,
const Window::SectionShow &params);
void setupTop(); void setupTop();
//void setupTabbedTop(); //void setupTabbedTop();
//void setupTabs(Tab tab); //void setupTabs(Tab tab);