Bug 190009

Summary: Need a way for JavaScript (or bundle) code to participate in undo
Product: WebKit Reporter: mitz
Component: HTML EditingAssignee: Wenson Hsieh <wenson_hsieh>
Status: RESOLVED FIXED    
Severity: Normal CC: aestes, bdakin, commit-queue, ews-watchlist, megan_gardner, rniwa, thorton, wenson_hsieh
Priority: P2 Keywords: InRadar
Version: Other   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Fix WPE/GTK/Win
rniwa: review+
Archive of layout-test-results from ews106 for mac-highsierra-wk2
none
Patch for EWS
none
Patch for EWS none

mitz
Reported 2018-09-26 14:01:12 PDT
There needs to be a way for code in the Web Content process—presumably JavaScript code on the page, but possibly bundle code—to participate in undo. Here is a concrete use case that should be supported: if an (undoable) editing operation triggers an event handler (such as an input event handler or DOM mutation event handler), then in the context of handling the event, there should be a way to register a handler to be run when the editing operation gets undone. There should probably also be a way to determine whether the event handler is running because of an undo/redo invocation.
Attachments
Patch (37.61 KB, patch)
2019-01-23 09:49 PST, Wenson Hsieh
no flags
Fix WPE/GTK/Win (37.23 KB, patch)
2019-01-23 10:56 PST, Wenson Hsieh
rniwa: review+
Archive of layout-test-results from ews106 for mac-highsierra-wk2 (2.73 MB, application/zip)
2019-01-23 12:04 PST, EWS Watchlist
no flags
Patch for EWS (42.09 KB, patch)
2019-01-25 07:31 PST, Wenson Hsieh
no flags
Patch for EWS (42.23 KB, patch)
2019-01-25 08:12 PST, Wenson Hsieh
no flags
mitz
Comment 1 2018-09-26 14:02:28 PDT
Ryosuke Niwa
Comment 2 2018-09-28 03:13:11 PDT
See https://bugs.webkit.org/show_bug.cgi?id=87189 for the previous attempt.
Wenson Hsieh
Comment 3 2019-01-23 08:25:56 PST
*** Bug 193720 has been marked as a duplicate of this bug. ***
Wenson Hsieh
Comment 4 2019-01-23 09:49:06 PST
Wenson Hsieh
Comment 5 2019-01-23 10:56:27 PST
Created attachment 359905 [details] Fix WPE/GTK/Win
EWS Watchlist
Comment 6 2019-01-23 12:04:39 PST Comment hidden (obsolete)
EWS Watchlist
Comment 7 2019-01-23 12:04:41 PST Comment hidden (obsolete)
Ryosuke Niwa
Comment 8 2019-01-24 20:25:37 PST
Comment on attachment 359905 [details] Fix WPE/GTK/Win View in context: https://bugs.webkit.org/attachment.cgi?id=359905&action=review > Source/WebCore/editing/CompositeEditCommand.h:92 > + void invalidate() final { } I don't like "invalidate". It doesn't tell us what it does, nor what we're invalidating, or what invalidating edit command means. I think we should say something more specific like didRemoveFromUndoManager. > Source/WebCore/page/UndoManager.cpp:48 > + // FIXME: Support adding the same UndoItem to an UndoManager multiple times. We probably want to throw in this case. > Tools/TestRunnerShared/UIScriptContext/Bindings/UIScriptController.idl:299 > + readonly attribute DOMString undoActionName; > + readonly attribute DOMString redoActionName; action name is Cocoa terminology. It's also somewhat surprising that there is only one name. We should probably call these something like lastUndoLabel and firstRedoLabel.
Wenson Hsieh
Comment 9 2019-01-24 21:25:56 PST
Comment on attachment 359905 [details] Fix WPE/GTK/Win View in context: https://bugs.webkit.org/attachment.cgi?id=359905&action=review >> Source/WebCore/editing/CompositeEditCommand.h:92 >> + void invalidate() final { } > > I don't like "invalidate". It doesn't tell us what it does, nor what we're invalidating, or what invalidating edit command means. > I think we should say something more specific like didRemoveFromUndoManager. Ok! Renamed this to didRemoveFromUndoManager(). >> Source/WebCore/page/UndoManager.cpp:48 >> + // FIXME: Support adding the same UndoItem to an UndoManager multiple times. > > We probably want to throw in this case. Good call. I made UndoManager.addItem() capable of throwing exceptions, and added exceptions in the case of this early return, and the !frame check below. This also made me realize that this first check for `m_items.contains(item.ptr())` isn't quite right — we really want to bail if the given UndoItem already has already been added an undoManager, not just this undo manager in particular! I added a new layout test as well, to verify that we throw an exception. >> Tools/TestRunnerShared/UIScriptContext/Bindings/UIScriptController.idl:299 >> + readonly attribute DOMString redoActionName; > > action name is Cocoa terminology. It's also somewhat surprising that there is only one name. > We should probably call these something like lastUndoLabel and firstRedoLabel. Sounds good! Renamed to lastUndoLabel and firstRedoLabel.
Wenson Hsieh
Comment 10 2019-01-25 07:31:18 PST
Created attachment 360113 [details] Patch for EWS
Wenson Hsieh
Comment 11 2019-01-25 08:12:59 PST
Created attachment 360117 [details] Patch for EWS
WebKit Commit Bot
Comment 12 2019-01-25 09:23:12 PST
Comment on attachment 360117 [details] Patch for EWS Clearing flags on attachment: 360117 Committed r240476: <https://trac.webkit.org/changeset/240476>
Note You need to log in before you can comment on or make changes to this bug.