#11753 closed Bug (fixed)
CheckDirty is true after clicking a widget, but getData() returns the same
Reported by: | Joel | Owned by: | Artur Delura |
---|---|---|---|
Priority: | Normal | Milestone: | CKEditor 4.4.2 |
Component: | General | Version: | 4.3 |
Keywords: | Cc: |
Description (last modified by )
In Chrome33 and IE9, the checkDirty() method returns true after a widget drag handle has appeared, even though nothing has changed.
- Open Developers console
- Go to http://ckeditor.com/demo#widgets
- Run CKEDITOR.instances.editor3.checkDirty(); in console
--> returns false
- Run var d1 = CKEDITOR.instances.editor3.getData(); in console
- Click on the apollo picture in the 3rd editor, but do not move it.
- Run CKEDITOR.instances.editor3.checkDirty(); in console
--> returns true
- Run var d2 = CKEDITOR.instances.editor3.getData(); in console
- run d1 === d2 in console
--> returns true
I know this is a battle between getData() vs getSnapshot() vs _.previousValue, but as far as I can see, it is unexpected behaviour. Shouldn't checkDirty() work with getData() especially when there are widgets involved?
Switching to source mode and back does not help.
Bonus: In Chrome CKEDITOR.instances.editor4.checkDirty(); is always true after page has loaded.
Change History (18)
comment:1 Changed 11 years ago by
Status: | new → confirmed |
---|---|
Version: | → 4.3 |
comment:2 Changed 11 years ago by
Owner: | set to Artur Delura |
---|---|
Status: | confirmed → assigned |
comment:3 Changed 11 years ago by
or every single time DOM we change something irrelevant in the DOM we need to reset checkDirty to correct state
What if some other part of code e.g. custom plugin changes dirty state at the same time (and relies on it)? If such thing happens then, not only it breaks custom plugin but also our onchange is becoming more and more useless.
comment:4 Changed 11 years ago by
Other plugins should not rely on the dirty flag. It is only for integration purposes. Other plugins should only take care of not changing it when it shouldn't be changed. Just like in this case - the flag should not be change to true when widget is focused or blurred.
comment:5 Changed 11 years ago by
Description: | modified (diff) |
---|
comment:6 Changed 11 years ago by
Description: | modified (diff) |
---|
comment:7 Changed 11 years ago by
To reproduce this issue simply open sample with image2 widget enabled with content:
<figure class="image" style="float:left"> <img alt="Saturn V" src="assets/image1.jpg" width="200" /> <figcaption>Roll out of Saturn V on launch pad</figcaption> </figure>
comment:11 Changed 11 years ago by
Status: | review_failed → review |
---|
Test were written on branch:t/11753.
comment:12 Changed 11 years ago by
Status: | review → assigned |
---|
comment:13 follow-up: 14 Changed 11 years ago by
- We use only lowercase letters in file names.
- Use strict mode and a closure.
- You should initialize editors in 'async:init', because more tests later may use it.
- You didn't test what happens if checkDirty was true before focusing widget.
- Don't use image2 widget in general widget tests. Use custom widget like other tests.
- You can keep these tests in
plugins/widget/
, because there's more cases to test than just the one from this ticket. - You don't need justify plugin.
- In 3rd line there's a missing space.
comment:14 Changed 11 years ago by
Status: | assigned → review |
---|
Replying to Reinmar:
- We use only lowercase letters in file names.
- Use strict mode and a closure.
Didn't know it's a standard :)
- You should initialize editors in 'async:init', because more tests later may use it.
Even until YAGNI? :)
comment:15 Changed 11 years ago by
Milestone: | → CKEditor 4.4.2 |
---|---|
Status: | review → review_passed |
Rebased branch and pushed additional commits (polished tests and added missing ones).
Even until YAGNI? :)
The thing about multiple editors is that you'll need them at some point. And if you used the single bot you'll need to alter all tests what's irritating and is a cause of bugs. Of course YAGNI in dev code is a different case.
comment:16 Changed 11 years ago by
Resolution: | → fixed |
---|---|
Status: | review_passed → closed |
Changes in git:a2facd8
comment:17 Changed 11 years ago by
I wrote that I pushed additional commits to this branch. You have not included there while merging to master!
There's no integration between widgets and checkDirty at all. Honestly speaking, we've got a problem with checkDirty, because whatever we do with DOM it yields. And with widgets we do a lot.
So either we'll reimplement it (only possible with undo manager...), or every single time DOM we change something irrelevant in the DOM we need to reset checkDirty to correct state.