tldraw 4.1.0-canary.e4499a57ef5b → 4.1.0-next.0df13eab91e1

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.
Files changed (75) hide show
  1. package/dist-cjs/index.js +1 -1
  2. package/dist-cjs/lib/canvas/TldrawCropHandles.js +1 -1
  3. package/dist-cjs/lib/canvas/TldrawScribble.js +1 -1
  4. package/dist-cjs/lib/canvas/TldrawSelectionForeground.js +1 -1
  5. package/dist-cjs/lib/defaultExternalContentHandlers.js +1 -1
  6. package/dist-cjs/lib/defaultExternalContentHandlers.js.map +2 -2
  7. package/dist-cjs/lib/shapes/arrow/curved-arrow.js +8 -2
  8. package/dist-cjs/lib/shapes/arrow/curved-arrow.js.map +2 -2
  9. package/dist-cjs/lib/shapes/arrow/straight-arrow.js +4 -1
  10. package/dist-cjs/lib/shapes/arrow/straight-arrow.js.map +2 -2
  11. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js +1 -1
  12. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +1 -1
  13. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +1 -1
  14. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js +1 -1
  15. package/dist-cjs/lib/shapes/shared/PlainTextLabel.js +1 -1
  16. package/dist-cjs/lib/shapes/shared/RichTextLabel.js +2 -2
  17. package/dist-cjs/lib/shapes/shared/RichTextLabel.js.map +2 -2
  18. package/dist-cjs/lib/shapes/shared/ShapeFill.js +1 -1
  19. package/dist-cjs/lib/shapes/text/PlainTextArea.js +1 -1
  20. package/dist-cjs/lib/shapes/text/RichTextArea.js +1 -1
  21. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js +1 -1
  22. package/dist-cjs/lib/ui/TldrawUi.js +2 -2
  23. package/dist-cjs/lib/ui/components/DebugMenu/DefaultDebugMenuContent.js +1 -1
  24. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialog.js +1 -1
  25. package/dist-cjs/lib/ui/components/Minimap/DefaultMinimap.js +1 -1
  26. package/dist-cjs/lib/ui/components/OfflineIndicator/OfflineIndicator.js +1 -1
  27. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js +1 -1
  28. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js +1 -1
  29. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js +1 -1
  30. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.js +1 -1
  31. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDropdownPicker.js +1 -1
  32. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js +1 -1
  33. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js +1 -1
  34. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js +1 -1
  35. package/dist-cjs/lib/ui/components/primitives/Button/TldrawUiButton.js +2 -2
  36. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js +1 -1
  37. package/dist-cjs/lib/ui/components/primitives/TldrawUiDialog.js +1 -1
  38. package/dist-cjs/lib/ui/components/primitives/TldrawUiDropdownMenu.js +1 -1
  39. package/dist-cjs/lib/ui/components/primitives/TldrawUiIcon.js +1 -1
  40. package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js +2 -2
  41. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js +2 -2
  42. package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js +1 -1
  43. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js +2 -2
  44. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js +1 -1
  45. package/dist-cjs/lib/ui/components/primitives/layout.js +1 -1
  46. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js +1 -1
  47. package/dist-cjs/lib/ui/context/actions.js +1 -1
  48. package/dist-cjs/lib/ui/context/breakpoints.js +1 -1
  49. package/dist-cjs/lib/ui/context/events.js +1 -1
  50. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js +1 -1
  51. package/dist-cjs/lib/ui/hooks/useKeyboardShortcuts.js +1 -1
  52. package/dist-cjs/lib/ui/hooks/useLocalStorageState.js +1 -1
  53. package/dist-cjs/lib/ui/hooks/useTools.js +1 -1
  54. package/dist-cjs/lib/ui/hooks/useTranslation/useTranslation.js +1 -1
  55. package/dist-cjs/lib/ui/version.js +3 -3
  56. package/dist-cjs/lib/ui/version.js.map +1 -1
  57. package/dist-cjs/lib/utils/text/richText.js +4 -4
  58. package/dist-esm/index.mjs +1 -1
  59. package/dist-esm/lib/defaultExternalContentHandlers.mjs +1 -1
  60. package/dist-esm/lib/defaultExternalContentHandlers.mjs.map +2 -2
  61. package/dist-esm/lib/shapes/arrow/curved-arrow.mjs +8 -2
  62. package/dist-esm/lib/shapes/arrow/curved-arrow.mjs.map +2 -2
  63. package/dist-esm/lib/shapes/arrow/straight-arrow.mjs +4 -1
  64. package/dist-esm/lib/shapes/arrow/straight-arrow.mjs.map +2 -2
  65. package/dist-esm/lib/shapes/shared/RichTextLabel.mjs +1 -1
  66. package/dist-esm/lib/shapes/shared/RichTextLabel.mjs.map +2 -2
  67. package/dist-esm/lib/ui/version.mjs +3 -3
  68. package/dist-esm/lib/ui/version.mjs.map +1 -1
  69. package/package.json +11 -11
  70. package/src/lib/defaultExternalContentHandlers.ts +1 -1
  71. package/src/lib/shapes/arrow/ArrowShapeUtil.test.ts +211 -1
  72. package/src/lib/shapes/arrow/curved-arrow.ts +8 -2
  73. package/src/lib/shapes/arrow/straight-arrow.ts +5 -1
  74. package/src/lib/shapes/shared/RichTextLabel.tsx +1 -1
  75. package/src/lib/ui/version.ts +3 -3
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/lib/shapes/shared/RichTextLabel.tsx"],
4
- "sourcesContent": ["import {\n\tBox,\n\tDefaultFontFamilies,\n\tTLDefaultFillStyle,\n\tTLDefaultFontStyle,\n\tTLDefaultHorizontalAlignStyle,\n\tTLDefaultVerticalAlignStyle,\n\tTLEventInfo,\n\tTLRichText,\n\tTLShapeId,\n\tpreventDefault,\n\tuseEditor,\n\tuseReactor,\n\tuseValue,\n} from '@tldraw/editor'\nimport React, { useMemo } from 'react'\nimport { renderHtmlFromRichText } from '../../utils/text/richText'\nimport { RichTextArea } from '../text/RichTextArea'\nimport { TEXT_PROPS } from './default-shape-constants'\nimport { isLegacyAlign } from './legacyProps'\nimport { useEditableRichText } from './useEditableRichText'\n\n/** @public */\nexport interface RichTextLabelProps {\n\tshapeId: TLShapeId\n\ttype: string\n\tfont: TLDefaultFontStyle\n\tfontSize: number\n\tlineHeight: number\n\tfill?: TLDefaultFillStyle\n\talign: TLDefaultHorizontalAlignStyle\n\tverticalAlign: TLDefaultVerticalAlignStyle\n\twrap?: boolean\n\trichText?: TLRichText\n\tlabelColor: string\n\tbounds?: Box\n\tisSelected: boolean\n\tonKeyDown?(e: KeyboardEvent): void\n\tclassNamePrefix?: string\n\tstyle?: React.CSSProperties\n\ttextWidth?: number\n\ttextHeight?: number\n\tpadding?: number\n\thasCustomTabBehavior?: boolean\n}\n\n/**\n * Renders a text label that can be used inside of shapes.\n * The component has the ability to be edited in place and furthermore\n * supports rich text editing.\n *\n * @public @react\n */\nexport const RichTextLabel = React.memo(function RichTextLabel({\n\tshapeId,\n\ttype,\n\trichText,\n\tlabelColor,\n\tfont,\n\tfontSize,\n\tlineHeight,\n\talign,\n\tverticalAlign,\n\twrap,\n\tisSelected,\n\tpadding = 0,\n\tonKeyDown: handleKeyDownCustom,\n\tclassNamePrefix,\n\tstyle,\n\ttextWidth,\n\ttextHeight,\n\thasCustomTabBehavior,\n}: RichTextLabelProps) {\n\tconst editor = useEditor()\n\tconst isDragging = React.useRef(false)\n\tconst { rInput, isEmpty, isEditing, isReadyForEditing, ...editableTextRest } =\n\t\tuseEditableRichText(shapeId, type, richText)\n\n\tconst html = useMemo(() => {\n\t\tif (richText) {\n\t\t\treturn renderHtmlFromRichText(editor, richText)\n\t\t}\n\t}, [editor, richText])\n\n\tconst selectToolActive = useValue(\n\t\t'isSelectToolActive',\n\t\t() => editor.getCurrentToolId() === 'select',\n\t\t[editor]\n\t)\n\n\tuseReactor(\n\t\t'isDragging',\n\t\t() => {\n\t\t\teditor.getInstanceState()\n\t\t\tisDragging.current = editor.inputs.isDragging\n\t\t},\n\t\t[editor]\n\t)\n\n\tconst legacyAlign = isLegacyAlign(align)\n\n\tconst handlePointerDown = (e: React.MouseEvent<HTMLDivElement>) => {\n\t\tif (e.target instanceof HTMLElement && (e.target.tagName === 'A' || e.target.closest('a'))) {\n\t\t\t// This mousedown prevent default is to let dragging when over a link work.\n\t\t\tpreventDefault(e)\n\n\t\t\tif (!selectToolActive) return\n\t\t\tconst link = e.target.closest('a')?.getAttribute('href') ?? ''\n\t\t\t// We don't get the mouseup event later because we preventDefault\n\t\t\t// so we have to do it manually.\n\t\t\tconst handlePointerUp = (e: TLEventInfo) => {\n\t\t\t\tif (e.name !== 'pointer_up') return\n\n\t\t\t\tif (!isDragging.current) {\n\t\t\t\t\twindow.open(link, '_blank', 'noopener, noreferrer')\n\t\t\t\t}\n\t\t\t\teditor.off('event', handlePointerUp)\n\t\t\t}\n\t\t\teditor.on('event', handlePointerUp)\n\t\t}\n\t}\n\n\t// Should be guarded higher up so that this doesn't render... but repeated here. This should never be true.\n\tif (!isEditing && isEmpty) return null\n\n\t// TODO: probably combine tl-text and tl-arrow eventually\n\tconst cssPrefix = classNamePrefix || 'tl-text'\n\treturn (\n\t\t<div\n\t\t\tclassName={`${cssPrefix}-label tl-text-wrapper tl-rich-text-wrapper`}\n\t\t\taria-hidden={!isEditing}\n\t\t\tdata-font={font}\n\t\t\tdata-align={align}\n\t\t\tdata-hastext={!isEmpty}\n\t\t\tdata-isediting={isEditing}\n\t\t\tdata-textwrap={!!wrap}\n\t\t\tdata-isselected={isSelected}\n\t\t\tstyle={{\n\t\t\t\tjustifyContent: align === 'middle' || legacyAlign ? 'center' : align,\n\t\t\t\talignItems: verticalAlign === 'middle' ? 'center' : verticalAlign,\n\t\t\t\tpadding,\n\t\t\t\t...style,\n\t\t\t}}\n\t\t>\n\t\t\t<div\n\t\t\t\tclassName={`${cssPrefix}-label__inner tl-text-content__wrapper`}\n\t\t\t\tstyle={{\n\t\t\t\t\tfontSize,\n\t\t\t\t\tlineHeight: lineHeight.toString(),\n\t\t\t\t\tminHeight: Math.floor(fontSize * lineHeight) + 'px',\n\t\t\t\t\tminWidth: Math.ceil(textWidth || 0),\n\t\t\t\t\tcolor: labelColor,\n\t\t\t\t\twidth: textWidth ? Math.ceil(textWidth) : undefined,\n\t\t\t\t\theight: textHeight ? Math.ceil(textHeight) : undefined,\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t<div className={`${cssPrefix} tl-text tl-text-content`} dir=\"auto\">\n\t\t\t\t\t{richText && (\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName=\"tl-rich-text\"\n\t\t\t\t\t\t\tdata-is-select-tool-active={selectToolActive}\n\t\t\t\t\t\t\t// todo: see if I can abuse this\n\t\t\t\t\t\t\tdangerouslySetInnerHTML={{ __html: html || '' }}\n\t\t\t\t\t\t\tonPointerDown={handlePointerDown}\n\t\t\t\t\t\t\tdata-is-ready-for-editing={isReadyForEditing}\n\t\t\t\t\t\t/>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t\t{(isReadyForEditing || isSelected) && (\n\t\t\t\t\t<RichTextArea\n\t\t\t\t\t\t// Fudge the ref type because we're using forwardRef and it's not typed correctly.\n\t\t\t\t\t\tref={rInput as any}\n\t\t\t\t\t\trichText={richText}\n\t\t\t\t\t\tisEditing={isEditing}\n\t\t\t\t\t\tshapeId={shapeId}\n\t\t\t\t\t\t{...editableTextRest}\n\t\t\t\t\t\thasCustomTabBehavior={hasCustomTabBehavior}\n\t\t\t\t\t\thandleKeyDown={handleKeyDownCustom ?? editableTextRest.handleKeyDown}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t</div>\n\t\t</div>\n\t)\n})\n\n/** @public */\nexport interface RichTextSVGProps {\n\tbounds: Box\n\trichText: TLRichText\n\tfontSize: number\n\tfont: TLDefaultFontStyle\n\talign: TLDefaultHorizontalAlignStyle\n\tverticalAlign: TLDefaultVerticalAlignStyle\n\twrap?: boolean\n\tlabelColor: string\n\tpadding: number\n\tshowTextOutline?: boolean\n}\n\n/**\n * Renders a rich text string as SVG given bounds and text properties.\n *\n * @public @react\n */\nexport function RichTextSVG({\n\tbounds,\n\trichText,\n\tfontSize,\n\tfont,\n\talign,\n\tverticalAlign,\n\twrap,\n\tlabelColor,\n\tpadding,\n\tshowTextOutline = true,\n}: RichTextSVGProps) {\n\tconst editor = useEditor()\n\tconst html = renderHtmlFromRichText(editor, richText)\n\tconst textAlign =\n\t\talign === 'middle'\n\t\t\t? ('center' as const)\n\t\t\t: align === 'start'\n\t\t\t\t? ('start' as const)\n\t\t\t\t: ('end' as const)\n\tconst justifyContent =\n\t\talign === 'middle'\n\t\t\t? ('center' as const)\n\t\t\t: align === 'start'\n\t\t\t\t? ('flex-start' as const)\n\t\t\t\t: ('flex-end' as const)\n\tconst alignItems =\n\t\tverticalAlign === 'middle' ? 'center' : verticalAlign === 'start' ? 'flex-start' : 'flex-end'\n\tconst wrapperStyle = {\n\t\tdisplay: 'flex',\n\t\tfontFamily: DefaultFontFamilies[font],\n\t\theight: `100%`,\n\t\tjustifyContent,\n\t\talignItems,\n\t\tpadding: `${padding}px`,\n\t}\n\tconst style = {\n\t\tfontSize: `${fontSize}px`,\n\t\twrap: wrap ? 'wrap' : 'nowrap',\n\t\tcolor: labelColor,\n\t\tlineHeight: TEXT_PROPS.lineHeight,\n\t\ttextAlign,\n\t\twidth: '100%',\n\t\twordWrap: 'break-word' as const,\n\t\toverflowWrap: 'break-word' as const,\n\t\twhiteSpace: 'pre-wrap',\n\t\ttextShadow: showTextOutline ? 'var(--tl-text-outline)' : 'none',\n\t}\n\n\treturn (\n\t\t<foreignObject\n\t\t\tx={bounds.minX}\n\t\t\ty={bounds.minY}\n\t\t\twidth={bounds.w}\n\t\t\theight={bounds.h}\n\t\t\tclassName=\"tl-export-embed-styles tl-rich-text tl-rich-text-svg\"\n\t\t>\n\t\t\t<div style={wrapperStyle}>\n\t\t\t\t<div dangerouslySetInnerHTML={{ __html: html }} style={style} />\n\t\t\t</div>\n\t\t</foreignObject>\n\t)\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import {\n\tBox,\n\tDefaultFontFamilies,\n\tTLDefaultFillStyle,\n\tTLDefaultFontStyle,\n\tTLDefaultHorizontalAlignStyle,\n\tTLDefaultVerticalAlignStyle,\n\tTLEventInfo,\n\tTLRichText,\n\tTLShapeId,\n\tpreventDefault,\n\tuseEditor,\n\tuseReactor,\n\tuseValue,\n} from '@tldraw/editor'\nimport React, { useMemo } from 'react'\nimport { renderHtmlFromRichText } from '../../utils/text/richText'\nimport { RichTextArea } from '../text/RichTextArea'\nimport { TEXT_PROPS } from './default-shape-constants'\nimport { isLegacyAlign } from './legacyProps'\nimport { useEditableRichText } from './useEditableRichText'\n\n/** @public */\nexport interface RichTextLabelProps {\n\tshapeId: TLShapeId\n\ttype: string\n\tfont: TLDefaultFontStyle\n\tfontSize: number\n\tlineHeight: number\n\tfill?: TLDefaultFillStyle\n\talign: TLDefaultHorizontalAlignStyle\n\tverticalAlign: TLDefaultVerticalAlignStyle\n\twrap?: boolean\n\trichText?: TLRichText\n\tlabelColor: string\n\tbounds?: Box\n\tisSelected: boolean\n\tonKeyDown?(e: KeyboardEvent): void\n\tclassNamePrefix?: string\n\tstyle?: React.CSSProperties\n\ttextWidth?: number\n\ttextHeight?: number\n\tpadding?: number\n\thasCustomTabBehavior?: boolean\n}\n\n/**\n * Renders a text label that can be used inside of shapes.\n * The component has the ability to be edited in place and furthermore\n * supports rich text editing.\n *\n * @public @react\n */\nexport const RichTextLabel = React.memo(function RichTextLabel({\n\tshapeId,\n\ttype,\n\trichText,\n\tlabelColor,\n\tfont,\n\tfontSize,\n\tlineHeight,\n\talign,\n\tverticalAlign,\n\twrap,\n\tisSelected,\n\tpadding = 0,\n\tonKeyDown: handleKeyDownCustom,\n\tclassNamePrefix,\n\tstyle,\n\ttextWidth,\n\ttextHeight,\n\thasCustomTabBehavior,\n}: RichTextLabelProps) {\n\tconst editor = useEditor()\n\tconst isDragging = React.useRef(false)\n\tconst { rInput, isEmpty, isEditing, isReadyForEditing, ...editableTextRest } =\n\t\tuseEditableRichText(shapeId, type, richText)\n\n\tconst html = useMemo(() => {\n\t\tif (richText) {\n\t\t\treturn renderHtmlFromRichText(editor, richText)\n\t\t}\n\t}, [editor, richText])\n\n\tconst selectToolActive = useValue(\n\t\t'isSelectToolActive',\n\t\t() => editor.getCurrentToolId() === 'select',\n\t\t[editor]\n\t)\n\n\tuseReactor(\n\t\t'isDragging',\n\t\t() => {\n\t\t\teditor.getInstanceState()\n\t\t\tisDragging.current = editor.inputs.isDragging\n\t\t},\n\t\t[editor]\n\t)\n\n\tconst legacyAlign = isLegacyAlign(align)\n\n\tconst handlePointerDown = (e: React.MouseEvent<HTMLDivElement>) => {\n\t\tif (e.target instanceof HTMLElement && (e.target.tagName === 'A' || e.target.closest('a'))) {\n\t\t\t// This mousedown prevent default is to let dragging when over a link work.\n\t\t\tpreventDefault(e)\n\n\t\t\tif (!selectToolActive) return\n\t\t\tconst link = e.target.closest('a')?.getAttribute('href') ?? ''\n\t\t\t// We don't get the mouseup event later because we preventDefault\n\t\t\t// so we have to do it manually.\n\t\t\tconst handlePointerUp = (e: TLEventInfo) => {\n\t\t\t\tif (e.name !== 'pointer_up' || !link) return\n\n\t\t\t\tif (!isDragging.current) {\n\t\t\t\t\twindow.open(link, '_blank', 'noopener, noreferrer')\n\t\t\t\t}\n\t\t\t\teditor.off('event', handlePointerUp)\n\t\t\t}\n\t\t\teditor.on('event', handlePointerUp)\n\t\t}\n\t}\n\n\t// Should be guarded higher up so that this doesn't render... but repeated here. This should never be true.\n\tif (!isEditing && isEmpty) return null\n\n\t// TODO: probably combine tl-text and tl-arrow eventually\n\tconst cssPrefix = classNamePrefix || 'tl-text'\n\treturn (\n\t\t<div\n\t\t\tclassName={`${cssPrefix}-label tl-text-wrapper tl-rich-text-wrapper`}\n\t\t\taria-hidden={!isEditing}\n\t\t\tdata-font={font}\n\t\t\tdata-align={align}\n\t\t\tdata-hastext={!isEmpty}\n\t\t\tdata-isediting={isEditing}\n\t\t\tdata-textwrap={!!wrap}\n\t\t\tdata-isselected={isSelected}\n\t\t\tstyle={{\n\t\t\t\tjustifyContent: align === 'middle' || legacyAlign ? 'center' : align,\n\t\t\t\talignItems: verticalAlign === 'middle' ? 'center' : verticalAlign,\n\t\t\t\tpadding,\n\t\t\t\t...style,\n\t\t\t}}\n\t\t>\n\t\t\t<div\n\t\t\t\tclassName={`${cssPrefix}-label__inner tl-text-content__wrapper`}\n\t\t\t\tstyle={{\n\t\t\t\t\tfontSize,\n\t\t\t\t\tlineHeight: lineHeight.toString(),\n\t\t\t\t\tminHeight: Math.floor(fontSize * lineHeight) + 'px',\n\t\t\t\t\tminWidth: Math.ceil(textWidth || 0),\n\t\t\t\t\tcolor: labelColor,\n\t\t\t\t\twidth: textWidth ? Math.ceil(textWidth) : undefined,\n\t\t\t\t\theight: textHeight ? Math.ceil(textHeight) : undefined,\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t<div className={`${cssPrefix} tl-text tl-text-content`} dir=\"auto\">\n\t\t\t\t\t{richText && (\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName=\"tl-rich-text\"\n\t\t\t\t\t\t\tdata-is-select-tool-active={selectToolActive}\n\t\t\t\t\t\t\t// todo: see if I can abuse this\n\t\t\t\t\t\t\tdangerouslySetInnerHTML={{ __html: html || '' }}\n\t\t\t\t\t\t\tonPointerDown={handlePointerDown}\n\t\t\t\t\t\t\tdata-is-ready-for-editing={isReadyForEditing}\n\t\t\t\t\t\t/>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t\t{(isReadyForEditing || isSelected) && (\n\t\t\t\t\t<RichTextArea\n\t\t\t\t\t\t// Fudge the ref type because we're using forwardRef and it's not typed correctly.\n\t\t\t\t\t\tref={rInput as any}\n\t\t\t\t\t\trichText={richText}\n\t\t\t\t\t\tisEditing={isEditing}\n\t\t\t\t\t\tshapeId={shapeId}\n\t\t\t\t\t\t{...editableTextRest}\n\t\t\t\t\t\thasCustomTabBehavior={hasCustomTabBehavior}\n\t\t\t\t\t\thandleKeyDown={handleKeyDownCustom ?? editableTextRest.handleKeyDown}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t</div>\n\t\t</div>\n\t)\n})\n\n/** @public */\nexport interface RichTextSVGProps {\n\tbounds: Box\n\trichText: TLRichText\n\tfontSize: number\n\tfont: TLDefaultFontStyle\n\talign: TLDefaultHorizontalAlignStyle\n\tverticalAlign: TLDefaultVerticalAlignStyle\n\twrap?: boolean\n\tlabelColor: string\n\tpadding: number\n\tshowTextOutline?: boolean\n}\n\n/**\n * Renders a rich text string as SVG given bounds and text properties.\n *\n * @public @react\n */\nexport function RichTextSVG({\n\tbounds,\n\trichText,\n\tfontSize,\n\tfont,\n\talign,\n\tverticalAlign,\n\twrap,\n\tlabelColor,\n\tpadding,\n\tshowTextOutline = true,\n}: RichTextSVGProps) {\n\tconst editor = useEditor()\n\tconst html = renderHtmlFromRichText(editor, richText)\n\tconst textAlign =\n\t\talign === 'middle'\n\t\t\t? ('center' as const)\n\t\t\t: align === 'start'\n\t\t\t\t? ('start' as const)\n\t\t\t\t: ('end' as const)\n\tconst justifyContent =\n\t\talign === 'middle'\n\t\t\t? ('center' as const)\n\t\t\t: align === 'start'\n\t\t\t\t? ('flex-start' as const)\n\t\t\t\t: ('flex-end' as const)\n\tconst alignItems =\n\t\tverticalAlign === 'middle' ? 'center' : verticalAlign === 'start' ? 'flex-start' : 'flex-end'\n\tconst wrapperStyle = {\n\t\tdisplay: 'flex',\n\t\tfontFamily: DefaultFontFamilies[font],\n\t\theight: `100%`,\n\t\tjustifyContent,\n\t\talignItems,\n\t\tpadding: `${padding}px`,\n\t}\n\tconst style = {\n\t\tfontSize: `${fontSize}px`,\n\t\twrap: wrap ? 'wrap' : 'nowrap',\n\t\tcolor: labelColor,\n\t\tlineHeight: TEXT_PROPS.lineHeight,\n\t\ttextAlign,\n\t\twidth: '100%',\n\t\twordWrap: 'break-word' as const,\n\t\toverflowWrap: 'break-word' as const,\n\t\twhiteSpace: 'pre-wrap',\n\t\ttextShadow: showTextOutline ? 'var(--tl-text-outline)' : 'none',\n\t}\n\n\treturn (\n\t\t<foreignObject\n\t\t\tx={bounds.minX}\n\t\t\ty={bounds.minY}\n\t\t\twidth={bounds.w}\n\t\t\theight={bounds.h}\n\t\t\tclassName=\"tl-export-embed-styles tl-rich-text tl-rich-text-svg\"\n\t\t>\n\t\t\t<div style={wrapperStyle}>\n\t\t\t\t<div dangerouslySetInnerHTML={{ __html: html }} style={style} />\n\t\t\t</div>\n\t\t</foreignObject>\n\t)\n}\n"],
5
+ "mappings": "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",
6
6
  "names": ["React", "RichTextLabel", "e"]
7
7
  }
@@ -34,7 +34,7 @@ __export(ShapeFill_exports, {
34
34
  module.exports = __toCommonJS(ShapeFill_exports);
35
35
  var import_jsx_runtime = require("react/jsx-runtime");
36
36
  var import_editor = require("@tldraw/editor");
37
- var import_react = __toESM(require("react"));
37
+ var import_react = __toESM(require("react"), 1);
38
38
  var import_defaultStyleDefs = require("./defaultStyleDefs");
39
39
  const ShapeFill = import_react.default.memo(function ShapeFill2({
40
40
  theme,
@@ -33,7 +33,7 @@ __export(PlainTextArea_exports, {
33
33
  module.exports = __toCommonJS(PlainTextArea_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_editor = require("@tldraw/editor");
36
- var import_react = __toESM(require("react"));
36
+ var import_react = __toESM(require("react"), 1);
37
37
  const PlainTextArea = import_react.default.forwardRef(function TextArea({
38
38
  isEditing,
39
39
  text,
@@ -34,7 +34,7 @@ module.exports = __toCommonJS(RichTextArea_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_react = require("@tiptap/react");
36
36
  var import_editor = require("@tldraw/editor");
37
- var import_react2 = __toESM(require("react"));
37
+ var import_react2 = __toESM(require("react"), 1);
38
38
  const RichTextArea = import_react2.default.forwardRef(function RichTextArea2({
39
39
  shapeId,
40
40
  isEditing,
@@ -33,7 +33,7 @@ __export(VideoShapeUtil_exports, {
33
33
  module.exports = __toCommonJS(VideoShapeUtil_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_editor = require("@tldraw/editor");
36
- var import_classnames = __toESM(require("classnames"));
36
+ var import_classnames = __toESM(require("classnames"), 1);
37
37
  var import_react = require("react");
38
38
  var import_BrokenAssetIcon = require("../shared/BrokenAssetIcon");
39
39
  var import_HyperlinkButton = require("../shared/HyperlinkButton");
@@ -34,8 +34,8 @@ __export(TldrawUi_exports, {
34
34
  module.exports = __toCommonJS(TldrawUi_exports);
35
35
  var import_jsx_runtime = require("react/jsx-runtime");
36
36
  var import_editor = require("@tldraw/editor");
37
- var import_classnames = __toESM(require("classnames"));
38
- var import_react = __toESM(require("react"));
37
+ var import_classnames = __toESM(require("classnames"), 1);
38
+ var import_react = __toESM(require("react"), 1);
39
39
  var import_A11y = require("./components/A11y");
40
40
  var import_TldrawUiButton = require("./components/primitives/Button/TldrawUiButton");
41
41
  var import_TldrawUiButtonIcon = require("./components/primitives/Button/TldrawUiButtonIcon");
@@ -36,7 +36,7 @@ __export(DefaultDebugMenuContent_exports, {
36
36
  module.exports = __toCommonJS(DefaultDebugMenuContent_exports);
37
37
  var import_jsx_runtime = require("react/jsx-runtime");
38
38
  var import_editor = require("@tldraw/editor");
39
- var import_react = __toESM(require("react"));
39
+ var import_react = __toESM(require("react"), 1);
40
40
  var import_dialogs = require("../../context/dialogs");
41
41
  var import_toasts = require("../../context/toasts");
42
42
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
@@ -32,7 +32,7 @@ __export(DefaultKeyboardShortcutsDialog_exports, {
32
32
  });
33
33
  module.exports = __toCommonJS(DefaultKeyboardShortcutsDialog_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
- var import_classnames = __toESM(require("classnames"));
35
+ var import_classnames = __toESM(require("classnames"), 1);
36
36
  var import_react = require("react");
37
37
  var import_constants = require("../../constants");
38
38
  var import_breakpoints = require("../../context/breakpoints");
@@ -33,7 +33,7 @@ __export(DefaultMinimap_exports, {
33
33
  module.exports = __toCommonJS(DefaultMinimap_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_editor = require("@tldraw/editor");
36
- var React = __toESM(require("react"));
36
+ var React = __toESM(require("react"), 1);
37
37
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
38
38
  var import_MinimapManager = require("./MinimapManager");
39
39
  function DefaultMinimap() {
@@ -32,7 +32,7 @@ __export(OfflineIndicator_exports, {
32
32
  });
33
33
  module.exports = __toCommonJS(OfflineIndicator_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
- var import_classnames = __toESM(require("classnames"));
35
+ var import_classnames = __toESM(require("classnames"), 1);
36
36
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
37
37
  var import_TldrawUiIcon = require("../primitives/TldrawUiIcon");
38
38
  function OfflineIndicator() {
@@ -34,7 +34,7 @@ module.exports = __toCommonJS(UserPresenceColorPicker_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_editor = require("@tldraw/editor");
36
36
  var import_radix_ui = require("radix-ui");
37
- var import_react = __toESM(require("react"));
37
+ var import_react = __toESM(require("react"), 1);
38
38
  var import_events = require("../../context/events");
39
39
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
40
40
  var import_TldrawUiButton = require("../primitives/Button/TldrawUiButton");
@@ -33,7 +33,7 @@ __export(DefaultStylePanel_exports, {
33
33
  module.exports = __toCommonJS(DefaultStylePanel_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_editor = require("@tldraw/editor");
36
- var import_classnames = __toESM(require("classnames"));
36
+ var import_classnames = __toESM(require("classnames"), 1);
37
37
  var import_react = require("react");
38
38
  var import_useRelevantStyles = require("../../hooks/useRelevantStyles");
39
39
  var import_DefaultStylePanelContent = require("./DefaultStylePanelContent");
@@ -46,7 +46,7 @@ __export(DefaultStylePanelContent_exports, {
46
46
  module.exports = __toCommonJS(DefaultStylePanelContent_exports);
47
47
  var import_jsx_runtime = require("react/jsx-runtime");
48
48
  var import_editor = require("@tldraw/editor");
49
- var import_react = __toESM(require("react"));
49
+ var import_react = __toESM(require("react"), 1);
50
50
  var import_styles = require("../../../styles");
51
51
  var import_events = require("../../context/events");
52
52
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
@@ -33,7 +33,7 @@ __export(StylePanelDoubleDropdownPicker_exports, {
33
33
  module.exports = __toCommonJS(StylePanelDoubleDropdownPicker_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_editor = require("@tldraw/editor");
36
- var React = __toESM(require("react"));
36
+ var React = __toESM(require("react"), 1);
37
37
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
38
38
  var import_TldrawUiButtonIcon = require("../primitives/Button/TldrawUiButtonIcon");
39
39
  var import_TldrawUiPopover = require("../primitives/TldrawUiPopover");
@@ -33,7 +33,7 @@ __export(StylePanelDropdownPicker_exports, {
33
33
  module.exports = __toCommonJS(StylePanelDropdownPicker_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_editor = require("@tldraw/editor");
36
- var React = __toESM(require("react"));
36
+ var React = __toESM(require("react"), 1);
37
37
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
38
38
  var import_TldrawUiButtonIcon = require("../primitives/Button/TldrawUiButtonIcon");
39
39
  var import_TldrawUiButtonLabel = require("../primitives/Button/TldrawUiButtonLabel");
@@ -33,7 +33,7 @@ __export(DefaultToolbar_exports, {
33
33
  module.exports = __toCommonJS(DefaultToolbar_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_editor = require("@tldraw/editor");
36
- var import_classnames = __toESM(require("classnames"));
36
+ var import_classnames = __toESM(require("classnames"), 1);
37
37
  var import_react = require("react");
38
38
  var import_constants = require("../../constants");
39
39
  var import_breakpoints = require("../../context/breakpoints");
@@ -35,7 +35,7 @@ __export(OverflowingToolbar_exports, {
35
35
  module.exports = __toCommonJS(OverflowingToolbar_exports);
36
36
  var import_jsx_runtime = require("react/jsx-runtime");
37
37
  var import_editor = require("@tldraw/editor");
38
- var import_classnames = __toESM(require("classnames"));
38
+ var import_classnames = __toESM(require("classnames"), 1);
39
39
  var import_react = require("react");
40
40
  var import_constants = require("../../constants");
41
41
  var import_breakpoints = require("../../context/breakpoints");
@@ -33,7 +33,7 @@ __export(ToggleToolLockedButton_exports, {
33
33
  module.exports = __toCommonJS(ToggleToolLockedButton_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_editor = require("@tldraw/editor");
36
- var import_classnames = __toESM(require("classnames"));
36
+ var import_classnames = __toESM(require("classnames"), 1);
37
37
  var import_constants = require("../../constants");
38
38
  var import_actions = require("../../context/actions");
39
39
  var import_breakpoints = require("../../context/breakpoints");
@@ -32,8 +32,8 @@ __export(TldrawUiButton_exports, {
32
32
  });
33
33
  module.exports = __toCommonJS(TldrawUiButton_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
- var import_classnames = __toESM(require("classnames"));
36
- var React = __toESM(require("react"));
35
+ var import_classnames = __toESM(require("classnames"), 1);
36
+ var React = __toESM(require("react"), 1);
37
37
  const namedClassNamesSoThatICanGrepForThis = {
38
38
  normal: "tlui-button__normal",
39
39
  primary: "tlui-button__primary",
@@ -36,7 +36,7 @@ __export(TldrawUiContextualToolbar_exports, {
36
36
  module.exports = __toCommonJS(TldrawUiContextualToolbar_exports);
37
37
  var import_jsx_runtime = require("react/jsx-runtime");
38
38
  var import_editor = require("@tldraw/editor");
39
- var import_classnames = __toESM(require("classnames"));
39
+ var import_classnames = __toESM(require("classnames"), 1);
40
40
  var import_react = require("react");
41
41
  var import_react_dom = require("react-dom");
42
42
  var import_TldrawUiToolbar = require("./TldrawUiToolbar");
@@ -36,7 +36,7 @@ __export(TldrawUiDialog_exports, {
36
36
  });
37
37
  module.exports = __toCommonJS(TldrawUiDialog_exports);
38
38
  var import_jsx_runtime = require("react/jsx-runtime");
39
- var import_classnames = __toESM(require("classnames"));
39
+ var import_classnames = __toESM(require("classnames"), 1);
40
40
  var import_radix_ui = require("radix-ui");
41
41
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
42
42
  var import_TldrawUiButton = require("./Button/TldrawUiButton");
@@ -42,7 +42,7 @@ __export(TldrawUiDropdownMenu_exports, {
42
42
  module.exports = __toCommonJS(TldrawUiDropdownMenu_exports);
43
43
  var import_jsx_runtime = require("react/jsx-runtime");
44
44
  var import_editor = require("@tldraw/editor");
45
- var import_classnames = __toESM(require("classnames"));
45
+ var import_classnames = __toESM(require("classnames"), 1);
46
46
  var import_radix_ui = require("radix-ui");
47
47
  var import_useMenuIsOpen = require("../../hooks/useMenuIsOpen");
48
48
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
@@ -32,7 +32,7 @@ __export(TldrawUiIcon_exports, {
32
32
  });
33
33
  module.exports = __toCommonJS(TldrawUiIcon_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
- var import_classnames = __toESM(require("classnames"));
35
+ var import_classnames = __toESM(require("classnames"), 1);
36
36
  var import_react = require("react");
37
37
  var import_asset_urls = require("../../context/asset-urls");
38
38
  const TldrawUiIcon = (0, import_react.memo)(function TldrawUiIcon2({
@@ -33,8 +33,8 @@ __export(TldrawUiInput_exports, {
33
33
  module.exports = __toCommonJS(TldrawUiInput_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_editor = require("@tldraw/editor");
36
- var import_classnames = __toESM(require("classnames"));
37
- var React = __toESM(require("react"));
36
+ var import_classnames = __toESM(require("classnames"), 1);
37
+ var React = __toESM(require("react"), 1);
38
38
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
39
39
  var import_TldrawUiIcon = require("./TldrawUiIcon");
40
40
  const TldrawUiInput = React.forwardRef(
@@ -35,9 +35,9 @@ __export(TldrawUiPopover_exports, {
35
35
  module.exports = __toCommonJS(TldrawUiPopover_exports);
36
36
  var import_jsx_runtime = require("react/jsx-runtime");
37
37
  var import_editor = require("@tldraw/editor");
38
- var import_classnames = __toESM(require("classnames"));
38
+ var import_classnames = __toESM(require("classnames"), 1);
39
39
  var import_radix_ui = require("radix-ui");
40
- var import_react = __toESM(require("react"));
40
+ var import_react = __toESM(require("react"), 1);
41
41
  var import_useMenuIsOpen = require("../../hooks/useMenuIsOpen");
42
42
  function TldrawUiPopover({ id, children, onOpenChange, open, className }) {
43
43
  const [isOpen, handleOpenChange] = (0, import_useMenuIsOpen.useMenuIsOpen)(id, onOpenChange);
@@ -34,7 +34,7 @@ module.exports = __toCommonJS(TldrawUiSlider_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
35
  var import_editor = require("@tldraw/editor");
36
36
  var import_radix_ui = require("radix-ui");
37
- var import_react = __toESM(require("react"));
37
+ var import_react = __toESM(require("react"), 1);
38
38
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
39
39
  var import_TldrawUiTooltip = require("./TldrawUiTooltip");
40
40
  const TldrawUiSlider = import_react.default.forwardRef(function Slider({
@@ -35,9 +35,9 @@ __export(TldrawUiToolbar_exports, {
35
35
  });
36
36
  module.exports = __toCommonJS(TldrawUiToolbar_exports);
37
37
  var import_jsx_runtime = require("react/jsx-runtime");
38
- var import_classnames = __toESM(require("classnames"));
38
+ var import_classnames = __toESM(require("classnames"), 1);
39
39
  var import_radix_ui = require("radix-ui");
40
- var import_react = __toESM(require("react"));
40
+ var import_react = __toESM(require("react"), 1);
41
41
  var import_layout = require("./layout");
42
42
  var import_TldrawUiTooltip = require("./TldrawUiTooltip");
43
43
  const LayoutByOrientation = {
@@ -36,7 +36,7 @@ module.exports = __toCommonJS(TldrawUiTooltip_exports);
36
36
  var import_jsx_runtime = require("react/jsx-runtime");
37
37
  var import_editor = require("@tldraw/editor");
38
38
  var import_radix_ui = require("radix-ui");
39
- var import_react = __toESM(require("react"));
39
+ var import_react = __toESM(require("react"), 1);
40
40
  var import_layout = require("./layout");
41
41
  const DEFAULT_TOOLTIP_DELAY_MS = 700;
42
42
  class TooltipManager {
@@ -36,7 +36,7 @@ __export(layout_exports, {
36
36
  });
37
37
  module.exports = __toCommonJS(layout_exports);
38
38
  var import_jsx_runtime = require("react/jsx-runtime");
39
- var import_classnames = __toESM(require("classnames"));
39
+ var import_classnames = __toESM(require("classnames"), 1);
40
40
  var import_radix_ui = require("radix-ui");
41
41
  var import_react = require("react");
42
42
  const TldrawUiOrientationContext = (0, import_react.createContext)({
@@ -32,7 +32,7 @@ __export(TldrawUiMenuGroup_exports, {
32
32
  });
33
33
  module.exports = __toCommonJS(TldrawUiMenuGroup_exports);
34
34
  var import_jsx_runtime = require("react/jsx-runtime");
35
- var import_classnames = __toESM(require("classnames"));
35
+ var import_classnames = __toESM(require("classnames"), 1);
36
36
  var import_actions = require("../../../context/actions");
37
37
  var import_useTranslation = require("../../../hooks/useTranslation/useTranslation");
38
38
  var import_layout = require("../layout");
@@ -37,7 +37,7 @@ __export(actions_exports, {
37
37
  module.exports = __toCommonJS(actions_exports);
38
38
  var import_jsx_runtime = require("react/jsx-runtime");
39
39
  var import_editor = require("@tldraw/editor");
40
- var React = __toESM(require("react"));
40
+ var React = __toESM(require("react"), 1);
41
41
  var import_frames = require("../../utils/frames/frames");
42
42
  var import_A11y = require("../components/A11y");
43
43
  var import_EditLinkDialog = require("../components/EditLinkDialog");
@@ -34,7 +34,7 @@ __export(breakpoints_exports, {
34
34
  module.exports = __toCommonJS(breakpoints_exports);
35
35
  var import_jsx_runtime = require("react/jsx-runtime");
36
36
  var import_editor = require("@tldraw/editor");
37
- var import_react = __toESM(require("react"));
37
+ var import_react = __toESM(require("react"), 1);
38
38
  var import_constants = require("../constants");
39
39
  const BreakpointContext = import_react.default.createContext(null);
40
40
  function BreakPointProvider({ forceMobile = false, children }) {
@@ -34,7 +34,7 @@ __export(events_exports, {
34
34
  });
35
35
  module.exports = __toCommonJS(events_exports);
36
36
  var import_jsx_runtime = require("react/jsx-runtime");
37
- var React = __toESM(require("react"));
37
+ var React = __toESM(require("react"), 1);
38
38
  const defaultEventHandler = () => void 0;
39
39
  const EventsContext = React.createContext(null);
40
40
  function TldrawUiEventsProvider({ onEvent, children }) {
@@ -34,7 +34,7 @@ __export(useClipboardEvents_exports, {
34
34
  });
35
35
  module.exports = __toCommonJS(useClipboardEvents_exports);
36
36
  var import_editor = require("@tldraw/editor");
37
- var import_lz_string = __toESM(require("lz-string"));
37
+ var import_lz_string = __toESM(require("lz-string"), 1);
38
38
  var import_react = require("react");
39
39
  var import_clipboard = require("../../utils/clipboard");
40
40
  var import_events = require("../context/events");
@@ -33,7 +33,7 @@ __export(useKeyboardShortcuts_exports, {
33
33
  });
34
34
  module.exports = __toCommonJS(useKeyboardShortcuts_exports);
35
35
  var import_editor = require("@tldraw/editor");
36
- var import_hotkeys_js = __toESM(require("hotkeys-js"));
36
+ var import_hotkeys_js = __toESM(require("hotkeys-js"), 1);
37
37
  var import_react = require("react");
38
38
  var import_actions = require("../context/actions");
39
39
  var import_useReadonly = require("./useReadonly");
@@ -32,7 +32,7 @@ __export(useLocalStorageState_exports, {
32
32
  });
33
33
  module.exports = __toCommonJS(useLocalStorageState_exports);
34
34
  var import_editor = require("@tldraw/editor");
35
- var import_react = __toESM(require("react"));
35
+ var import_react = __toESM(require("react"), 1);
36
36
  function useLocalStorageState(key, defaultValue) {
37
37
  const [state, setState] = import_react.default.useState(defaultValue);
38
38
  import_react.default.useLayoutEffect(() => {
@@ -36,7 +36,7 @@ __export(useTools_exports, {
36
36
  module.exports = __toCommonJS(useTools_exports);
37
37
  var import_jsx_runtime = require("react/jsx-runtime");
38
38
  var import_editor = require("@tldraw/editor");
39
- var React = __toESM(require("react"));
39
+ var React = __toESM(require("react"), 1);
40
40
  var import_EmbedDialog = require("../components/EmbedDialog");
41
41
  var import_a11y = require("../context/a11y");
42
42
  var import_events = require("../context/events");
@@ -35,7 +35,7 @@ __export(useTranslation_exports, {
35
35
  });
36
36
  module.exports = __toCommonJS(useTranslation_exports);
37
37
  var import_jsx_runtime = require("react/jsx-runtime");
38
- var React = __toESM(require("react"));
38
+ var React = __toESM(require("react"), 1);
39
39
  var import_asset_urls = require("../../context/asset-urls");
40
40
  var import_defaultTranslation = require("./defaultTranslation");
41
41
  var import_translations = require("./translations");
@@ -22,10 +22,10 @@ __export(version_exports, {
22
22
  version: () => version
23
23
  });
24
24
  module.exports = __toCommonJS(version_exports);
25
- const version = "4.1.0-canary.e4499a57ef5b";
25
+ const version = "4.1.0-next.0df13eab91e1";
26
26
  const publishDates = {
27
27
  major: "2025-09-18T14:39:22.803Z",
28
- minor: "2025-09-19T11:41:15.460Z",
29
- patch: "2025-09-19T11:41:15.460Z"
28
+ minor: "2025-10-01T09:28:43.241Z",
29
+ patch: "2025-10-01T09:28:43.241Z"
30
30
  };
31
31
  //# sourceMappingURL=version.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/lib/ui/version.ts"],
4
- "sourcesContent": ["// This file is automatically generated by internal/scripts/refresh-assets.ts.\n// Do not edit manually. Or do, I'm a comment, not a cop.\n\nexport const version = '4.1.0-canary.e4499a57ef5b'\nexport const publishDates = {\n\tmajor: '2025-09-18T14:39:22.803Z',\n\tminor: '2025-09-19T11:41:15.460Z',\n\tpatch: '2025-09-19T11:41:15.460Z',\n}\n"],
4
+ "sourcesContent": ["// This file is automatically generated by internal/scripts/refresh-assets.ts.\n// Do not edit manually. Or do, I'm a comment, not a cop.\n\nexport const version = '4.1.0-next.0df13eab91e1'\nexport const publishDates = {\n\tmajor: '2025-09-18T14:39:22.803Z',\n\tminor: '2025-10-01T09:28:43.241Z',\n\tpatch: '2025-10-01T09:28:43.241Z',\n}\n"],
5
5
  "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAGO,MAAM,UAAU;AAChB,MAAM,eAAe;AAAA,EAC3B,OAAO;AAAA,EACP,OAAO;AAAA,EACP,OAAO;AACR;",
6
6
  "names": []
7
7
  }
@@ -39,10 +39,10 @@ __export(richText_exports, {
39
39
  });
40
40
  module.exports = __toCommonJS(richText_exports);
41
41
  var import_core = require("@tiptap/core");
42
- var import_extension_code = __toESM(require("@tiptap/extension-code"));
43
- var import_extension_highlight = __toESM(require("@tiptap/extension-highlight"));
44
- var import_extension_link = __toESM(require("@tiptap/extension-link"));
45
- var import_starter_kit = __toESM(require("@tiptap/starter-kit"));
42
+ var import_extension_code = __toESM(require("@tiptap/extension-code"), 1);
43
+ var import_extension_highlight = __toESM(require("@tiptap/extension-highlight"), 1);
44
+ var import_extension_link = __toESM(require("@tiptap/extension-link"), 1);
45
+ var import_starter_kit = __toESM(require("@tiptap/starter-kit"), 1);
46
46
  var import_editor = require("@tldraw/editor");
47
47
  var import_defaultFonts = require("../../shapes/shared/defaultFonts");
48
48
  var import_textDirection = require("./textDirection");
@@ -529,7 +529,7 @@ import {
529
529
  } from "./lib/utils/tldr/file.mjs";
530
530
  registerTldrawLibraryVersion(
531
531
  "tldraw",
532
- "4.1.0-canary.e4499a57ef5b",
532
+ "4.1.0-next.0df13eab91e1",
533
533
  "esm"
534
534
  );
535
535
  export {
@@ -223,7 +223,7 @@ function defaultHandleExternalEmbedContent(editor, { point, url, embed }) {
223
223
  async function defaultHandleExternalFileContent(editor, { point, files }, options) {
224
224
  const { acceptedImageMimeTypes = DEFAULT_SUPPORTED_IMAGE_TYPES, toasts, msg } = options;
225
225
  if (files.length > editor.options.maxFilesAtOnce) {
226
- toasts.addToast({ title: msg("assets.files.amount-too-big"), severity: "error" });
226
+ toasts.addToast({ title: msg("assets.files.amount-too-many"), severity: "error" });
227
227
  return;
228
228
  }
229
229
  const position = point ?? (editor.inputs.shiftKey ? editor.inputs.currentPagePoint : editor.getViewportPageBounds().center);