#11171 closed Bug (fixed)
No checkWidgets after editor#insertHtml and #insertText
Reported by: | Alfonso Martínez de Lizarrondo | Owned by: | Piotrek Koszuliński |
---|---|---|---|
Priority: | Must have (possibly next milestone) | Milestone: | CKEditor 4.3.1 |
Component: | General | Version: | 4.3 |
Keywords: | Cc: |
Description (last modified by )
TC1
Use the API sample and add the image2 plugin, now insert an image with the textarea to test the API and that image can't be edited because it isn't a widget.
TC2
Go to placeholder sample and execute:
CKEDITOR.instances.editor1.insertText( '[[foo]]' )
Text will be upcasted to widget, but widget won't be initialized on it.
Workaround
After inserting HTML/text call:
editor1.widgets.fire( 'checkWidgets' )
Change History (19)
comment:1 Changed 11 years ago by
Description: | modified (diff) |
---|---|
Milestone: | → CKEditor 4.3.1 |
Status: | new → confirmed |
Summary: | Images inserted with the API can't be edited if image2 is used → No checkWidgets after editor#insertHtml |
comment:2 Changed 11 years ago by
Owner: | set to Piotrek Koszuliński |
---|---|
Status: | confirmed → assigned |
comment:4 Changed 11 years ago by
Description: | modified (diff) |
---|
comment:5 Changed 11 years ago by
Description: | modified (diff) |
---|
comment:6 Changed 11 years ago by
Priority: | Normal → High |
---|
comment:7 Changed 11 years ago by
Summary: | No checkWidgets after editor#insertHtml → No checkWidgets after editor#insertHtml and #insertText |
---|
comment:8 Changed 11 years ago by
Besides inserting content with insertHtml, another way to add content to the editor is by directly creating the DOM elements and inserting them.
In that case the images don't get the wrapping span and all those properties and the call to widgets.checkWidgets()
doesn't do anything.
Is there a way to fully initialize a widget on a specific DOM element? (ie: I call something like editor.widgets.initialize(element)
and the editor takes care to check if that element must be converted to a widget)
comment:9 Changed 11 years ago by
There are two ways to wrap element into a widget (we call this upcasting).
- First is by using data processor if upcast method was defined - this happens on insertHtml and insertText, but that means operating on HTML string.
- Second way is by using editor.widgets.wrapElement - this method can be called on detached or wired element, both on dom.element and htmlParser.element. After wrapping, widget still has to be initialised.
- And there's a third way which reuses the second way - editor.widgets.initOn. This method will wrap element and then initialise widget on it.
Regarding checkWidgets - it has only two jobs - destroying vanished widgets and initialising widgets on wrapped (upcasted) elements which don't have instances yet.
comment:10 Changed 11 years ago by
Thanks, but the problem with editor.widgets.wrapElement (or editor.widgets.initOn) is that besides the element, it requires to know the widget that I want to use and my request is to say to CKEditor:
Hello, I've inserted this element, I've finished. Can you check now if some widget wants to do something about it?
I don't want to reimplement any logic to find out which widgets are active, which elements they want to work on and which elements they avoid, I want an API call that will detect what to do with that element.
comment:11 Changed 11 years ago by
To reuse widgets' upcast methods you have to use insertHtml()
rather than insertElement()
. I understand your point, but this is a limitation which couldn't be overcome without a code duplication in widgets definitions. Widgets' upcast methods work only with htmlParser.element
, so they cannot be used in insertElement()
.
comment:13 Changed 11 years ago by
Description: | modified (diff) |
---|
comment:14 Changed 11 years ago by
Status: | assigned → review |
---|
Pushed t/11171 on dev and tests.
I extended checkWidgets capabilities with two new options and reused it in insertText and insertHtml events listeners. I was also able to remove the afterPaste listener in favor of insertHtml - now all insertions are handled the same way.
Additionally - I removed checkWidgets on keyup, because it will be enough when widgets will be cleaned up during insertions.
Regarding review - I strongly recommend checking commit after commit, because I did a code reorganisation which makes combined diff unreadable.
comment:16 Changed 11 years ago by
Status: | review_failed → review |
---|
Two tests were broken and one test is ok, but is failing because of #11055 which I accidentally partially fixed on other browsers.
comment:17 Changed 11 years ago by
Status: | review → review_passed |
---|
comment:18 Changed 11 years ago by
Resolution: | → fixed |
---|---|
Status: | review_passed → closed |
Fixed on master with git:918bcc4 on dev and 918bcc4 on tests.
Another case - insert template with image - image won't be a widget (actually, it will be gone, but due to: #11170).