Compare commits

...

2 Commits

Author SHA1 Message Date
d68e64931b [nostalgia/core/studio/tilesheeteditor] Add support for dragging palette to palette selector
All checks were successful
Build / build (push) Successful in 3m22s
2025-01-19 11:41:48 -06:00
1cbc576286 [studio] Complete drag/drop support for files 2025-01-19 11:41:08 -06:00
6 changed files with 44 additions and 9 deletions

View File

@ -443,6 +443,16 @@ void TileSheetEditorImGui::drawPaletteMenu() noexcept {
if (ig::ComboBox("Palette", files, m_selectedPaletteIdx)) { if (ig::ComboBox("Palette", files, m_selectedPaletteIdx)) {
oxLogError(m_model.setPalette(files[m_selectedPaletteIdx])); oxLogError(m_model.setPalette(files[m_selectedPaletteIdx]));
} }
if (ig::DragDropTarget const dragDropTarget; dragDropTarget) {
auto const [ref, err] = ig::getDragDropPayload<studio::FileRef>("FileRef");
if (!err) {
auto const oldVal = m_selectedPaletteIdx;
std::ignore = ox::findIdx(files.begin(), files.end(), ref.path).moveTo(m_selectedPaletteIdx);
if (oldVal != m_selectedPaletteIdx) {
oxLogError(m_model.setPalette(files[m_selectedPaletteIdx]));
}
}
}
auto const pages = m_model.pal().pages.size(); auto const pages = m_model.pal().pages.size();
if (pages > 1) { if (pages > 1) {
ig::IndentStackItem const indentStackItem{20}; ig::IndentStackItem const indentStackItem{20};

View File

@ -4,6 +4,7 @@
#include <imgui.h> #include <imgui.h>
#include <studio/dragdrop.hpp>
#include <studio/imguiutil.hpp> #include <studio/imguiutil.hpp>
#include "projectexplorer.hpp" #include "projectexplorer.hpp"
@ -54,8 +55,9 @@ void ProjectTreeModel::draw(turbine::Context &tctx) const noexcept {
ImGui::EndPopup(); ImGui::EndPopup();
} }
ImGui::TreePop(); ImGui::TreePop();
ig::dragDropSource([this] { std::ignore = ig::dragDropSource([this] {
ImGui::Text("%s", m_name.c_str()); ImGui::Text("%s", m_name.c_str());
return ig::setDragDropPayload("FileRef", FileRef{fullPath<ox::String>()});
}); });
} }
} }
@ -80,11 +82,4 @@ void ProjectTreeModel::drawDirContextMenu() const noexcept {
} }
} }
ox::BasicString<255> ProjectTreeModel::fullPath() const noexcept {
if (m_parent) {
return m_parent->fullPath() + "/" + m_name;
}
return {};
}
} }

View File

@ -32,8 +32,14 @@ class ProjectTreeModel {
private: private:
void drawDirContextMenu() const noexcept; void drawDirContextMenu() const noexcept;
template<typename Str = ox::BasicString<255>>
[[nodiscard]] [[nodiscard]]
ox::BasicString<255> fullPath() const noexcept; Str fullPath() const noexcept {
if (m_parent) {
return m_parent->fullPath<Str>() + "/" + m_name;
}
return {};
}
}; };

View File

@ -0,0 +1,22 @@
/*
* Copyright 2016 - 2025 Gary Talent (gary@drinkingtea.net). All rights reserved.
*/
#pragma once
#include <ox/std/string.hpp>
#include <ox/model/def.hpp>
namespace studio {
struct FileRef {
static constexpr auto TypeName = "net.drinkingtea.studio.FileRef";
static constexpr auto TypeVersion = 1;
ox::String path;
};
OX_MODEL_BEGIN(FileRef)
OX_MODEL_FIELD(path)
OX_MODEL_END()
}

View File

@ -63,6 +63,7 @@ auto dragDropSource(auto const&cb) noexcept {
if (ig::DragDropSource const tgt; tgt) [[unlikely]] { if (ig::DragDropSource const tgt; tgt) [[unlikely]] {
return cb(); return cb();
} }
return ox::Error{};
} else { } else {
if (ig::DragDropSource const tgt; tgt) [[unlikely]] { if (ig::DragDropSource const tgt; tgt) [[unlikely]] {
cb(); cb();

View File

@ -6,6 +6,7 @@
#include <studio/configio.hpp> #include <studio/configio.hpp>
#include <studio/context.hpp> #include <studio/context.hpp>
#include <studio/dragdrop.hpp>
#include <studio/editor.hpp> #include <studio/editor.hpp>
#include <studio/filedialog.hpp> #include <studio/filedialog.hpp>
#include <studio/imguiutil.hpp> #include <studio/imguiutil.hpp>