@marimo-team/islands 0.20.3-dev88 → 0.20.3-dev89

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/main.js CHANGED
@@ -68637,7 +68637,11 @@ Image URL: ${r.imageUrl}`)), contextToXml({
68637
68637
  if (isDataPart(d2)) return Logger.debug("Found data part", d2), null;
68638
68638
  switch (d2.type) {
68639
68639
  case "text":
68640
- return (0, import_jsx_runtime.jsx)(MarkdownRenderer, {
68640
+ return d2.text.includes("<marimo-") ? (0, import_jsx_runtime.jsx)(import_react.Fragment, {
68641
+ children: renderHTML({
68642
+ html: d2.text
68643
+ })
68644
+ }, f) : (0, import_jsx_runtime.jsx)(MarkdownRenderer, {
68641
68645
  content: d2.text
68642
68646
  }, f);
68643
68647
  case "reasoning":
@@ -70347,7 +70351,7 @@ Image URL: ${r.imageUrl}`)), contextToXml({
70347
70351
  return Logger.warn("Failed to get version from mount config"), null;
70348
70352
  }
70349
70353
  }
70350
- const marimoVersionAtom = atom(getVersionFromMountConfig() || "0.20.3-dev88"), showCodeInRunModeAtom = atom(true);
70354
+ const marimoVersionAtom = atom(getVersionFromMountConfig() || "0.20.3-dev89"), showCodeInRunModeAtom = atom(true);
70351
70355
  atom(null);
70352
70356
  var import_compiler_runtime$88 = require_compiler_runtime();
70353
70357
  function useKeydownOnElement(e, r) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@marimo-team/islands",
3
- "version": "0.20.3-dev88",
3
+ "version": "0.20.3-dev89",
4
4
  "main": "dist/main.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "type": "module",
@@ -1,6 +1,8 @@
1
1
  /* Copyright 2026 Marimo. All rights reserved. */
2
2
 
3
3
  import type { DataUIPart, ToolUIPart, UIMessage } from "ai";
4
+ import React from "react";
5
+ import { renderHTML } from "@/plugins/core/RenderHTML";
4
6
  import { logNever } from "@/utils/assertNever";
5
7
  import { Logger } from "@/utils/Logger";
6
8
  import { MarkdownRenderer } from "../markdown/markdown-renderer";
@@ -46,6 +48,17 @@ export const renderUIMessage = ({
46
48
 
47
49
  switch (part.type) {
48
50
  case "text":
51
+ // Streamdown sanitizes the HTML which strips out marimo elements
52
+ // So instead, we render the HTML with our custom renderer.
53
+ if (part.text.includes("<marimo-")) {
54
+ return (
55
+ <React.Fragment key={index}>
56
+ {renderHTML({
57
+ html: part.text,
58
+ })}
59
+ </React.Fragment>
60
+ );
61
+ }
49
62
  return <MarkdownRenderer key={index} content={part.text} />;
50
63
  case "reasoning":
51
64
  return (