Skip to content

Commit

Permalink
feat: initial image path state to allow for the path to be different … (
Browse files Browse the repository at this point in the history
#242)

* Added initial image path state to allow for the path to be different than the image source, for example the path might be a file path and the image source may be base64 encoded file

* Update image preview hook example with base64

---------

Co-authored-by: Finlay Sawyer <finlay.sawyer@bp.com>
  • Loading branch information
colemorgan-bp and FinlayBP authored Dec 20, 2023
1 parent aa684b7 commit a1104bf
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 4 deletions.
8 changes: 5 additions & 3 deletions src/examples/images.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -54,11 +54,13 @@ export function ImageWithPreviewHook() {
return (
<>
<MDXEditor
markdown={markdownWithHtmlImages}
markdown="Preview hook that returns static base64: ![alt text](/attachments/my_image.png)"
plugins={[
imagePlugin({
disableImageResize: true,
imagePreviewHandler: async (imageSource) => Promise.resolve(`${imageSource}?grayscale`)
imagePreviewHandler: async () =>
Promise.resolve(
''
)
}),
diffSourcePlugin(),
jsxPlugin(),
Expand Down
4 changes: 3 additions & 1 deletion src/plugins/image/ImageEditor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,7 @@ export function ImageEditor({ src, title, alt, nodeKey, width, height }: ImageEd
const [disableImageResize] = imagePluginHooks.useEmitterValues('disableImageResize')
const [imagePreviewHandler] = imagePluginHooks.useEmitterValues('imagePreviewHandler')
const [imageSource, setImageSource] = React.useState<string | null>(null)
const [initialImagePath, setInitialImagePath] = React.useState<string | null>(null)
const openEditImageDialog = imagePluginHooks.usePublisher('openEditImageDialog')
const [iconComponentFor] = corePluginHooks.useEmitterValues('iconComponentFor')

Expand Down Expand Up @@ -148,6 +149,7 @@ export function ImageEditor({ src, title, alt, nodeKey, width, height }: ImageEd
React.useEffect(() => {
if (imagePreviewHandler) {
const callPreviewHandler = async () => {
if (!initialImagePath) setInitialImagePath(src)
const updatedSrc = await imagePreviewHandler(src)
setImageSource(updatedSrc)
}
Expand Down Expand Up @@ -267,7 +269,7 @@ export function ImageEditor({ src, title, alt, nodeKey, width, height }: ImageEd
openEditImageDialog({
nodeKey: nodeKey,
initialValues: {
src: imageSource,
src: !initialImagePath ? imageSource : initialImagePath,
title: title || '',
altText: alt || ''
}
Expand Down

0 comments on commit a1104bf

Please sign in to comment.