Skip to content

ENG-1373: Drag pages onto the canvas to create node shapes#1083

Open
sid597 wants to merge 6 commits into
mainfrom
eng-1373-drag-and-drop-pages-to-canvas
Open

ENG-1373: Drag pages onto the canvas to create node shapes#1083
sid597 wants to merge 6 commits into
mainfrom
eng-1373-drag-and-drop-pages-to-canvas

Conversation

@sid597

@sid597 sid597 commented May 25, 2026

Copy link
Copy Markdown
Collaborator

Page refs aren't draggable by default, so make them draggable via the
existing rm-page-ref observer and route the drag payload through the canvas
text-content handler that already turns [[name]] into a discourse-node shape.

- Always-on: only the draggable attribute is global; the drag payload and
  drop handling live in the canvas component, so drags are inert unless a
  canvas is open.
- Custom MIME (application/x-roam-page), not text/plain, so a drag can't leak
  [[title]] into other blocks or apps.
- Guard the existing block-dragstart so dragging a ref doesn't also attach its
  containing block's UID.
@linear-code

linear-code Bot commented May 25, 2026

Copy link
Copy Markdown

ENG-1373

@supabase

supabase Bot commented May 25, 2026

Copy link
Copy Markdown

This pull request has been ignored for the connected project zytfjzqyijgagqxrzbmz because there are no changes detected in packages/database/supabase directory. You can change this behaviour in Project Integrations Settings ↗︎.


Preview Branches by Supabase.
Learn more about Supabase Branching ↗︎.

@chatgpt-codex-connector chatgpt-codex-connector Bot left a comment

Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

💡 Codex Review

Here are some automated review suggestions for this pull request.

Reviewed commit: 014d57e942

ℹ️ About Codex in GitHub

Your team has set up Codex to review pull requests in this repo. Reviews are triggered when you

  • Open a pull request for review
  • Mark a draft as ready
  • Comment "@codex review".

If Codex has suggestions, it will comment; otherwise it will react with 👍.

Codex can also answer questions or update the PR. Try commenting "@codex address that feedback".

Comment thread apps/roam/src/utils/initializeObserversAndListeners.ts Outdated
sid597 added 3 commits May 25, 2026 15:08
The always-on registration had no matching teardown, so the singleton
rm-page-ref observer and the makePageRefDraggable callback survived extension
unload/reload. Add a cleanup that unregisters the handler; for users without
the overlay/preview/suggestive handlers this empties the set and disconnects
the observer.
The first commit only captured spans whose data-link-title lives on the
parent element. Query-builder result rows and the discourse-context overlay
render page links as <a class="rm-page-ref" data-link-title="..."> with the
title on the element itself, which the existing parent-only read missed.

Also resolve a dragged block whose text is exactly [[X]] to that discourse
node's shape (instead of a gray blck-node) when X is a discourse node. The
page-ref branch already does this, so factor out tryCreatePageNodeShape and
reuse it from the block-ref path; the heavy page-uid + discourse-node lookup
is gated behind a cheap PAGE_REF_REGEX match on the block text.

- Read data-link-title on the page-ref element itself, falling back to the
  parent for span page-refs.
- Extract tryCreatePageNodeShape; the boolean return lets callers decide
  the fallback (default text handler vs. blck-node).
- Hoist PAGE_REF_REGEX to module scope next to BLOCK_REF_REGEX usage.
Comment thread apps/roam/src/components/canvas/Tldraw.tsx
Comment thread apps/roam/src/components/canvas/Tldraw.tsx
@sid597 sid597 requested a review from mdroidian May 29, 2026 05:53
@mdroidian

Copy link
Copy Markdown
Member

@codex review

@chatgpt-codex-connector

Copy link
Copy Markdown

Codex Review: Didn't find any major issues. Keep them coming!

ℹ️ About Codex in GitHub

Your team has set up Codex to review pull requests in this repo. Reviews are triggered when you

  • Open a pull request for review
  • Mark a draft as ready
  • Comment "@codex review".

If Codex has suggestions, it will comment; otherwise it will react with 👍.

Codex can also answer questions or update the PR. Try commenting "@codex address that feedback".

@mdroidian mdroidian left a comment

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

https://www.loom.com/share/b7fa55afb36a48bd8fabe14391f8fe65

I think this needs one more pass before merging.

The goal is to drag a page reference from inside an outliner block onto the canvas. Right now, mixed-content blocks still open the page instead of allowing drag.

It also looks like this changes the behavior when a page reference is the only content in a block: dragging the block now creates a page node instead of a block node. I’m not sure we want to change that existing block-drag behavior.

Expected behavior: dragging the specific page reference should add that page to the canvas, similar to the discourse context behavior, without changing how the containing block itself drags.

Could you also test/show:

  • link/render/embed query views
  • multiple canvases, including sidebar canvases, to check useEffect behavior


// Handle Roam block drag and drop
useEffect(() => {
const temporaryDraggableAttribute = "data-roamjs-canvas-page-ref-draggable";

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

TEMP_DRAG_ATTR

const pageMatch = text.match(PAGE_REF_REGEX);
if (pageMatch?.[1]) {
if (await tryCreatePageNodeShape(pageMatch[1])) {
posthog.capture("Canvas: Node Added from External Content", {

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

"External Content" here can be misleading. Does this mean outside of Roam?


const refMatch = blockText.match(PAGE_REF_REGEX);
if (refMatch?.[1] && (await tryCreatePageNodeShape(refMatch[1]))) {
posthog.capture("Canvas: Node Added from External Content", {

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

"External Content" here can be misleading. Does this mean outside of Roam?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants