Skip to content

Commit

Permalink
fix(component): fix lit portal not re-rendering in inline links case
Browse files Browse the repository at this point in the history
  • Loading branch information
fundon committed Dec 26, 2024
1 parent cadb921 commit 14cc3a5
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 16 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,9 @@ type PortalEvent = {
type PortalListener = (event: PortalEvent) => void;

export function createLitPortalAnchor(callback: (event: PortalEvent) => void) {
const id = nanoid();
return html`<lit-react-portal
.notify=${callback}
portalId=${id}
portalId=${nanoid()}
></lit-react-portal>`;
}

Expand Down Expand Up @@ -119,24 +118,26 @@ export const useLitPortalFactory = () => {
}

const prevId = event.previousPortalId;
// Ignore first `willUpdate`
if (!prevId) {
return;
}

// No re-rendering allowed
// Used in `pdf embed view` scenario
if (!rerendering) {
// Ignores first `willUpdate`
if (!prevId) {
return;
}

setPortals(portals => {
const portal = portals.find(p => p.id === prevId);
if (!portal) return portals;
if (!portal) return [...portals];

// Updates `ID`
portal.id = id;
portal.portal.key = id;
portal.portal.children = element;

// Re-rendering
// true: `inline link`
// false: `pdf embed view`
if (rerendering) {
portal.portal = ReactDOM.createPortal(element, target, id);
}

return [...portals];
});
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -357,7 +357,7 @@ export const BiDirectionalLinkPanel = () => {
{
<>
{portals.map(p => (
<Fragment key={p.id}>{p.portal}</Fragment>
<Fragment key={p.portal.key}>{p.portal}</Fragment>
))}
</>
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -194,7 +194,7 @@ const usePatchSpecs = (shared: boolean, mode: DocMode) => {
() => (
<>
{portals.map(p => (
<Fragment key={p.id}>{p.portal}</Fragment>
<Fragment key={p.portal.key}>{p.portal}</Fragment>
))}
</>
),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -604,7 +604,10 @@ export function patchForMobile() {
}

export function patchForAttachmentEmbedViews(
reactToLit: (element: ElementOrFactory) => TemplateResult
reactToLit: (
element: ElementOrFactory,
rerendering?: boolean
) => TemplateResult
): ExtensionType {
return {
setup: di => {
Expand All @@ -626,7 +629,8 @@ export function patchForAttachmentEmbedViews(
reactToLit(
<AttachmentPreviewErrorBoundary key={model.id}>
<PDFViewerEmbedded {...buildAttachmentProps(model)} />
</AttachmentPreviewErrorBoundary>
</AttachmentPreviewErrorBoundary>,
false
),
}));
},
Expand Down

0 comments on commit 14cc3a5

Please sign in to comment.