[studio] Make first tab not draw before selected tab when window opens
This commit is contained in:
parent
e758e03d2b
commit
e3f84c4e75
@ -66,7 +66,9 @@ StudioUI::StudioUI(turbine::Context &ctx, ox::StringParam projectDataDir) noexce
|
|||||||
auto openFileErr = openFileActiveTab(f, config.activeTabItemName == f);
|
auto openFileErr = openFileActiveTab(f, config.activeTabItemName == f);
|
||||||
if (openFileErr) {
|
if (openFileErr) {
|
||||||
oxErrorf("\nCould not open editor for file:\n\t{}\nReason:\n\t{}\n", f, toStr(openFileErr));
|
oxErrorf("\nCould not open editor for file:\n\t{}\nReason:\n\t{}\n", f, toStr(openFileErr));
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
m_activeEditor = m_editors.back().value->get();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -194,26 +196,27 @@ void StudioUI::drawTabBar() noexcept {
|
|||||||
|
|
||||||
void StudioUI::drawTabs() noexcept {
|
void StudioUI::drawTabs() noexcept {
|
||||||
for (auto it = m_editors.begin(); it != m_editors.end();) {
|
for (auto it = m_editors.begin(); it != m_editors.end();) {
|
||||||
auto const &e = *it;
|
auto const&e = *it;
|
||||||
auto open = true;
|
auto open = true;
|
||||||
auto const unsavedChanges = e->unsavedChanges() ? ImGuiTabItemFlags_UnsavedDocument : 0;
|
auto const unsavedChanges = e->unsavedChanges() ? ImGuiTabItemFlags_UnsavedDocument : 0;
|
||||||
auto const selected = m_activeEditorUpdatePending == e.get() ? ImGuiTabItemFlags_SetSelected : 0;
|
auto const selected = m_activeEditorUpdatePending == e.get() ? ImGuiTabItemFlags_SetSelected : 0;
|
||||||
auto const flags = unsavedChanges | selected;
|
auto const flags = unsavedChanges | selected;
|
||||||
if (ImGui::BeginTabItem(e->itemDisplayName().c_str(), &open, flags)) {
|
if (ImGui::BeginTabItem(e->itemDisplayName().c_str(), &open, flags)) {
|
||||||
if (m_activeEditor != e.get()) {
|
if (m_activeEditor != e.get()) [[unlikely]] {
|
||||||
m_activeEditor = e.get();
|
m_activeEditor = e.get();
|
||||||
studio::editConfig<StudioConfig>(keelCtx(m_ctx), [&](StudioConfig &config) {
|
studio::editConfig<StudioConfig>(keelCtx(m_ctx), [&](StudioConfig &config) {
|
||||||
config.activeTabItemName = m_activeEditor->itemPath();
|
config.activeTabItemName = m_activeEditor->itemPath();
|
||||||
});
|
});
|
||||||
|
} else [[likely]] {
|
||||||
|
if (m_activeEditorUpdatePending == e.get()) [[unlikely]] {
|
||||||
|
m_activeEditorUpdatePending = nullptr;
|
||||||
|
}
|
||||||
|
if (m_activeEditorOnLastDraw != e.get()) [[unlikely]] {
|
||||||
|
m_activeEditor->onActivated();
|
||||||
|
}
|
||||||
|
e->draw(m_sctx);
|
||||||
|
m_activeEditorOnLastDraw = e.get();
|
||||||
}
|
}
|
||||||
if (m_activeEditorUpdatePending == e.get()) {
|
|
||||||
m_activeEditorUpdatePending = nullptr;
|
|
||||||
}
|
|
||||||
if (m_activeEditorOnLastDraw != e.get()) [[unlikely]] {
|
|
||||||
m_activeEditor->onActivated();
|
|
||||||
}
|
|
||||||
e->draw(m_sctx);
|
|
||||||
m_activeEditorOnLastDraw = e.get();
|
|
||||||
ImGui::EndTabItem();
|
ImGui::EndTabItem();
|
||||||
}
|
}
|
||||||
if (!open) {
|
if (!open) {
|
||||||
|
Loading…
Reference in New Issue
Block a user