react-quill
react-quill copied to clipboard
The quill-image-resizing -module is not working properly, the image stays highlighted with resize options even clicking outside the editor
When I integrated the quill-image-resize-module with react-quill, the resizer stays in the screen even clicking outside the editor. The resizer getting closed when we click inside the editor. This is causing some bugs like, sometimes the resizing window is positioned outside of the image.
@chrismcv @jdhuntington @daggmano @Sajam @jacktrades
Thanks!
@sarang-naico Any news for this issue ?
@M4gie I just edited the quill-image-resize library in-order to fix this issue
I can share the code if you want @M4gie
I found a solution here for my issue https://github.com/zenoamaro/react-quill/issues/224#issuecomment-311933020
@sarang-naico : Could you please share the code ? Facing the same issue. @M4gie : Not sure how registering the module could solve this problem ?
import React from 'react'
import ReactQuill, { Quill } from 'react-quill'
import 'react-quill/dist/quill.snow.css'
import ImageResize from 'quill-image-resize-module-react'
Quill.register('modules/imageResize', ImageResize)
function TextEditor(props) {
const modules = {
toolbar: [
[{'header': [1, 2, 3, 4, 5, 6, false]}],
['bold', 'italic', 'underline', 'strike'], // toggled buttons
['blockquote', 'code-block'],
[{'list': 'ordered'}, {'list': 'bullet'}, {'indent': '-1'}, {'indent': '+1'}, {'align': []}],
[{'script': 'sub'}, {'script': 'super'}], // superscript/subscript
[{'direction': 'rtl'}], // text direction,
[{'color': []}, {'background': []}], // dropdown with defaults from theme
['link', 'image'],
['clean'] // remove formatting button
],
imageResize: {
// parchment: Quill.import('parchment'),
modules: [ 'Resize', 'DisplaySize' ]
}
}
return (
<ReactQuill
value={props.content}
onChange={(value) => {
props.setContent(value)
}}
modules={modules}
/>
)
}
export default TextEditor;
This is my Editor component, I didn't edit my webpack config.
@M4gie Did it solve the actual problem ?
When I integrated the quill-image-resize-module with react-quill, the resizer stays in the screen even clicking outside the editor.
Did you all solve the problem? I use Nextjs and can't find any solutions.
Yes I did. But I had to make changes in the image resize module
You can refer to my repository : https://github.com/ashishBharadwaj/flawesome
Image-resize Component: https://github.com/ashishBharadwaj/flawesome/blob/master/src/components/imge-resize/ImageResize.js
I added a blur event listener like so:
this.quill.root.addEventListener('blur', this.handleFocusOut);
handleFocusOut = (evn) => {
if(this.img){
this.hideOverlay();
}
}
I decided to include the code in my repo because apart from this I had several other use cases that I needed to handle like resized image state retention in case the editor is reinitialized with some content. And I was not able to build after forking the original repository
@ashishBharadwaj It's not working with NextJS
Hi, any update regarding the same? Stuck with a similar problem. Using NextJS.
Same here, don't know how to implement it using Nextjs
@nitink66 @nithinkashyapn @Kamez
same Next.js problem.
use this next.config.js
work for me:
module.exports = {
webpack: (config, { buildId, dev, isServer, defaultLoaders, webpack }) => {
config.module.rules.push({
test: /\.js$/,
exclude: /node_modules(?!\/quill-image-drop-module|quill-image-resize-module)/,
loader: 'babel-loader',
})
config.plugins.push(new webpack.ProvidePlugin({
'window.Quill': 'quill'
}))
return config
}
};
register:
import ReactQuill, { Quill } from "react-quill";
import ImageResize from 'quill-image-resize-module';
Quill.register('modules/ImageResize', ImageResize);
Did anyone solve the problem in nextjs?
data:image/s3,"s3://crabby-images/66f6c/66f6cfbc092b3add1f992d808f20a2336d6aa396" alt="스크린샷 2020-12-11 오후 12 42 33"
image doesnt resize is there any solution?
import { Quill } from "react-quill";
import ImageResize from "quill-image-resize-module";
Quill.register("modules/ImageResize", ImageResize);
export const modules = {
syntax: true,
ImageResize: {
handleStyles: {
displaySize: true,
backgroundColor: "black",
border: "none",
color: "white",
},
modules: ["Resize", "DisplaySize", "Toolbar"],
},
toolbar: [
// [{ header: "1" }, { header: "2" }],
[{ font: [] }],
[{ size: ["small", false, "large", "huge"] }], // custom dropdown
["bold", "italic", "underline", "strike"],
["blockquote", "code-block"],
[{ color: [] }, { background: [] }], // dropdown with defaults from theme
[{ align: [] }],
[{ list: "ordered" }, { list: "bullet" }, { indent: "-1" }, { indent: "+1" }],
["link", "image", "video"],
],
};`
- [ ]
Did anyone solve the problem in nextjs?
I'm not aware of any resolution of this so far... looking at the files there is no "module/imageResize" class on quill folder.., maybe the author injected or somehow
This might be a possible solution:
document.addEventListener('click', e => {
const editorEl = document.querySelector(YOUR_EDITOR_ID/CLASS);
if (!editorEl?.contains?.(e?.target)) { // click outside editor
// do something such as cancel highlight
}
});
@M4gie I just edited the quill-image-resize library in-order to fix this issue
Can you provide me the code?
useEffect(() => { const quillEditorContext = textEditorRef.current; if (!quillEditorContext) return const quill = quillEditorContext.getEditor(); const imageResize = quill.getModule("imageResize") const quillRoot = quill.root const hideOverlay = async (event) => { if (!quillRoot.contains(event.target)) { imageResize.hide() } } document.getElementById("__next").addEventListener("click", hideOverlay) return () => { document.getElementById("__next").removeEventListener("click", hideOverlay) } }, [value])
Does anyone here know how to use this in next.js?