From fe8893d69648774b286f77f990c9d44a37ba4bfd Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 27 Feb 2024 13:22:47 -0800 Subject: [PATCH 01/80] Create FindOnPage.md --- FindOnPage.md | 382 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 382 insertions(+) create mode 100644 FindOnPage.md diff --git a/FindOnPage.md b/FindOnPage.md new file mode 100644 index 000000000..d27f54274 --- /dev/null +++ b/FindOnPage.md @@ -0,0 +1,382 @@ +# WebView2Find API + +## Background + +The WebView2Find API provides methods and events to support text finding and navigation within a WebView2 control. +It allows developers to initiate find operations, navigate between find results, and customize various find configurations. + +## Examples + + +#### Description +To initiate a find operation within a WebView2 control, developers can utilize the `StartFindOnPage` method. +This method allows specifying the find term and configuring other find parameters using the `ICoreWebView2FindConfiguration` interface. + +#### Create/Specify a Find Configuration + + + +```cpp +ICoreWebView2FindConfiguration CreateFindConfiguration() +{ + ICoreWebView2Environment5 environment = webView2Control.GetEnvironment(); + ICoreWebView2FindConfiguration configuration; + environment.CreateFindConfiguration(out configuration); + configuration.FindTerm = "example"; + configuration.FindDirection = COREWEBVIEW2_FIND_DIRECTION.COREWEBVIEW2_FIND_DIRECTION_FORWARD; + configuration.IsCaseSensitive = false; + configuration.ShouldMatchWord = false; + return configuration; +} +``` + +### Start a Find Operation + + +```cpp +//! [StartFindOnPage] +void AppWindow::StartFindOnPage(const std::wstring& findTerm) +{ + // Get the find interface + auto find = webView2Control.GetFind(); + + // Create find configuration + auto configuration = CreateFindConfiguration(); + + // Start the find operation + find.StartFind(configuration, OnFindOperationCompleted); +} +//! [StartFindOnPage] +``` +### Stop an existing find operation +#### Description +To stop an ongoing find operation within a WebView2 control, developers can use the `StopFind` method of the `ICoreWebView2Find` interface. +```cpp +//! [StopFind] +void AppWindow::StopFind() +{ + // Get the find interface + auto find = webView2Control.GetFind(); + + // Stop the find operation + find.StopFind(); +} +//! [StopFind] +``` + +### Retrieve the Number of Matches + +#### Description +To retrieve the total number of matches found during a find operation within a WebView2 control, developers can utilize the `GetMatchCount` method. + + +```cpp +//! [GetMatchCount] +void AppWindow::GetMatchCount() +{ + // Get the find interface + auto find = webView2Control.GetFind(); + + // Get the match count + LONG matchCount; + find.GetMatchesCount(&matchCount); + + // Update UI or handle matchCount +} +//! [GetMatchCount] +``` + +### Retrieve the Index of the Active Match + +#### Description +Developers can retrieve the index of the currently active match within a WebView2 control using the `GetActiveMatchIndex` method. + + +```cpp +//! [GetActiveMatchIndex] +void AppWindow::GetActiveMatchIndex() +{ + // Get the find interface + auto find = webView2Control.GetFind(); + + // Get the active match index + LONG activeMatchIndex; + find.GetActiveMatchIndex(&activeMatchIndex); + + // Update UI or handle activeMatchIndex +} +//! [GetActiveMatchIndex] +``` + +### Navigate to the Next Match + +#### Description +To navigate to the next match found during a find operation within a WebView2 control, developers can use the `FindNext` method. + + +```cpp +//! [FindNext] +void AppWindow::FindNext() +{ + // Get the find interface + auto find = webView2Control.GetFind(); + + // Find the next occurrence + find.FindNext(); +} +//! [FindNext] +``` + +### Navigate to the Previous Match + +#### Description +To navigate to the previous match found during a find operation within a WebView2 control, developers can use the `FindPrevious` method. + + +```cpp +//! [FindPrevious] +void AppWindow::FindPrevious() +{ + // Get the find interface + auto find = webView2Control.GetFind(); + + // Find the previous occurrence + find.FindPrevious(); +} +//! [FindPrevious] +``` + +#### Handle Match Count Changes + +```cpp +void OnMatchCountChanged(LONG matchesCount) +{ + // Handle match count changes + // Update UI elements or perform actions based on the new match count +} +``` +#### Handle Active Match Index Changes +```cpp +void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2StagingFindActiveMatchIndexChangedEventArgs* args) +{ + // Handle active match index changes + // Update UI to reflect the change in the active match index +} +``` + +#### Handle Find Operation Completion + +```cpp +void OnFindOperationCompleted(HRESULT value, LONG activeMatchIndex, LONG matchesCount) +{ + // Handle find operation completion + // Update UI elements, display search results, or handle errors +} +``` +## API Details +```csharp +/// Specifies the direction of find Parameters. +[v1_enum] +typedef enum COREWEBVIEW2_FIND_DIRECTION { + /// Specifies a forward find in the document. + COREWEBVIEW2_FIND_DIRECTION_FORWARD, + /// Specifies a backwards find in the document. + COREWEBVIEW2_FIND_DIRECTION_BACKWARD +} COREWEBVIEW2_FIND_DIRECTION; +/// Interface defining the find configuration. +/// This interface provides the necessary methods and properties to configure a find operation. +[uuid(4A6ED732-DF08-4449-8949-3632A4DEBFCD), object, pointer_default(unique)] +interface ICoreWebView2FindConfiguration : IUnknown { + /// Gets the find term used for the find operation. + /// \return The find term. + [propget] HRESULT FindTerm([out, retval] LPWSTR* value); + /// Sets the find term to be used for the find operation. + /// \param[in] value The find term. + [propput] HRESULT FindTerm([in] LPCWSTR value); + /// Gets the direction of the find operation (forward or backward). + /// \return The find direction. + [propget] HRESULT FindDirection([out, retval] COREWEBVIEW2_FIND_DIRECTION* value); + /// Sets the direction for the find operation. + /// \param[in] value The find direction. + [propput] HRESULT FindDirection([in] COREWEBVIEW2_FIND_DIRECTION value); + /// Determines if the find operation is case sensitive. + /// \return TRUE if the find is case sensitive, FALSE otherwise. + [propget] HRESULT IsCaseSensitive([out, retval] BOOL* value); + /// Sets whether the find operation should be case sensitive. + /// \param[in] value TRUE to make the find case sensitive, FALSE otherwise. + [propput] HRESULT IsCaseSensitive([in] BOOL value); + /// Determines if only whole words should be matched during the find operation. + /// \return TRUE if only whole words should be matched, FALSE otherwise. + [propget] HRESULT ShouldMatchWord([out, retval] BOOL* value); + /// Sets whether to only match whole words during the find operation. + [propput] HRESULT ShouldMatchWord([in] BOOL value); + /// Gets the state of whether all matches are highlighted. + /// \return TRUE if all matches are highlighted, FALSE otherwise. + [propget] HRESULT ShouldHighlightAllMatches([out, retval] BOOL* value); + /// Sets the state to either highlight all matches or not. + [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); + /// Determines if the currently active match is highlighted. + /// \return TRUE if the active match is highlighted, FALSE otherwise. + [propget] HRESULT ShouldHighlightActiveMatch([out, retval] BOOL* value); + /// Sets whether to highlight the currently active match. + [propput] HRESULT ShouldHighlightActiveMatch([in] BOOL value); + /// Checks if a custom user interface is desired by end developer. + /// If TRUE, the default Find bar is not displayed. + /// \return TRUE if using a custom UI, FALSE if using the default. + [propget] HRESULT UseCustomUI([out, retval] BOOL* value); + /// Sets whether to use a custom UI for the Find operation. + [propput] HRESULT UseCustomUI([in] BOOL value); + /// Gets the index of the currently active match. + /// If there's no active find session but an attempt is made to change the active match index: + /// The function might crash if the global_match_id isn't found in the map. + /// It will clear any active match highlighting if there's a previously active frame. + /// It will either select a new active match or return an error through the callback if the frame associated with the match isn't valid. + /// \return The active match index. + [propget] HRESULT ActiveMatchIndex([out, retval] LONG* value); + /// Sets the index for the active match. + [propput] HRESULT ActiveMatchIndex([in] LONG value); + /// Gets the total count of matches found in the current document based on the last find criteria. + /// \return The total count of matches. + [propget] HRESULT MatchesCount([out, retval] LONG* value); + /** + * Passes the current highlighting settings to the underlying Mojo. + * + * This function retrieves the current text highlighting settings set by the user + * or the default system and ensures that they are used during any subsequent text + * find or highlight operations. This includes settings related to highlighting + * all matches, the active match, and any custom UI preferences. + * + * Users should call this function after changing any highlight settings to ensure + * that they are applied properly in the system. + */ + HRESULT PassHighlightSettings(); +} +/// Handles the event that's fired when the match count changes. +[uuid(623EFBFB-A19E-43C4-B309-D578511D24AB), object, pointer_default(unique)] +interface ICoreWebView2FindMatchCountChangedEventHandler : IUnknown { + /// Provides the event args when the match count changes. + HRESULT Invoke(LONG matchesCount); +} +/// Handles the event that's fired when the active match index changes. +[uuid(623EFBF9-A19E-43C4-B309-D578511D24A9), object, pointer_default(unique)] +interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { + /// Provides the event args when the active match index changes. + /// \param sender The sender of this event, representing the current instance of ICoreWebView2Find. + /// \param args The event args that contain the new active match index. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2FindActiveMatchIndexChangedEventArgs* args); +} +/// Handles the event that's fired when the find operation completes. +[uuid(2604789D-9553-4246-8E21-B9C74EFAD04F), object, pointer_default(unique)] +interface ICoreWebView2FindOperationCompletedHandler : IUnknown { + /// Provides the event args when the find operation completes. + HRESULT Invoke(HRESULT value, LONG activeMatchIndex, LONG matchesCount); +} +// Interface defining the find configuration. +[uuid(4A6ED732-DF08-4449-8949-3632A4DEBFCD), object, pointer_default(unique)] +interface ICoreWebView2FindConfiguration : IUnknown { + // Gets or sets the find term used for the find operation. + [propget] HRESULT FindTerm([out, retval] LPWSTR* value); + [propput] HRESULT FindTerm([in] LPCWSTR value); + // Gets or sets the direction of the find operation (forward or backward). + [propget] HRESULT FindDirection([out, retval] COREWEBVIEW2_FIND_DIRECTION* value); + [propput] HRESULT FindDirection([in] COREWEBVIEW2_FIND_DIRECTION value); + // Gets or sets whether the find operation is case sensitive. + [propget] HRESULT IsCaseSensitive([out, retval] BOOL* value); + [propput] HRESULT IsCaseSensitive([in] BOOL value); + // Gets or sets whether to only match whole words during the find operation. + [propget] HRESULT ShouldMatchWord([out, retval] BOOL* value); + [propput] HRESULT ShouldMatchWord([in] BOOL value); + // Gets the state of whether all matches are highlighted. + // \return TRUE if all matches are highlighted, FALSE otherwise. + [propget] HRESULT ShouldHighlightAllMatches([out, retval] BOOL* value); + // Sets the state to either highlight all matches or not. + [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); + // Determines if the currently active match is highlighted. + // \return TRUE if the active match is highlighted, FALSE otherwise. + [propget] HRESULT ShouldHighlightActiveMatch([out, retval] BOOL* value); + // Sets whether to highlight the currently active match. + [propput] HRESULT ShouldHighlightActiveMatch([in] BOOL value); + // Checks if a custom user interface is desired by end developer. + // If TRUE, the default Find bar is not displayed. + // \return TRUE if using a custom UI, FALSE if using the default. + [propget] HRESULT UseCustomUI([out, retval] BOOL* value); + // Sets whether to use a custom UI for the Find operation. + [propput] HRESULT UseCustomUI([in] BOOL value); + // Gets the index of the currently active match. + // If there's no active find session but an attempt is made to change the active match index: + // The function might crash if the global_match_id isn't found in the map. + // It will clear any active match highlighting if there's a previously active frame. + // It will either select a new active match or return an error through the callback if the frame associated with the match isn't valid. + // \return The active match index. + [propget] HRESULT ActiveMatchIndex([out, retval] LONG* value); + // Sets the index for the active match. + [propput] HRESULT ActiveMatchIndex([in] LONG value); + // Gets the total count of matches found in the current document based on the last find criteria. + // \return The total count of matches. + [propget] HRESULT MatchesCount([out, retval] LONG* value); + /** + * Passes the current highlighting settings to the underlying Mojo. + * + * This function retrieves the current text highlighting settings set by the user + * or the default system and ensures that they are used during any subsequent text + * find or highlight operations. This includes settings related to highlighting + * all matches, the active match, and any custom UI preferences. + * + * Users should call this function after changing any highlight settings to ensure + * that they are applied properly in the system. + */ + HRESULT PassHighlightSettings(); +} +// Interface providing methods and properties for finding and navigating through text in the web view. +[uuid(7C49A8AA-2A17-4846-8207-21D1520AABC0), object, pointer_default(unique)] +interface ICoreWebView2Find : IUnknown { + // Initiates a find using the specified configuration. + HRESULT StartFind([in] ICoreWebView2FindConfiguration* configuration, + ICoreWebView2FindOperationCompletedHandler* handler); + // Navigates to the next match in the document. + HRESULT FindNext(); + // Navigates to the previous match in the document. + HRESULT FindPrevious(); + // Stops the current 'Find' operation and hides the Find bar. + HRESULT StopFind(); + // Registers an event handler for the FindCompleted event. + // This event is raised when a find operation completes, either by finding all matches, navigating to a match, or by being stopped. + // \param eventHandler The event handler to be added. + // \return A token representing the added event handler. This token can be used to unregister the event handler. + HRESULT add_FindOperationCompleted( + [in] ICoreWebView2FindOperationCompletedHandler* eventHandler, + [out] EventRegistrationToken* token); + // Unregisters an event handler from the FindCompleted event. + // \param token The token of the event handler to be removed, obtained during the registration of the event handler. + HRESULT remove_FindOperationCompleted([in] EventRegistrationToken token); + // Registers an event handler for the MatchCountChanged event. + // This event is raised when the total count of matches in the document changes due to a new find operation or changes in the document. + // \param eventHandler The event handler to be added. + // \return A token representing the added event handler. This token can be used to unregister the event handler. + HRESULT add_MatchCountChanged( + [in] ICoreWebView2FindMatchCountChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + // Unregisters an event handler from the MatchCountChanged event. + // \param token The token of the event handler to be removed, obtained during the registration of the event handler. + HRESULT remove_MatchCountChanged([in] EventRegistrationToken token); + // Registers an event handler for the ActiveMatchIndexChanged event. + // This event is raised when the index of the currently active match changes. + // This can happen when the user navigates to a different match or when the active match is changed programmatically. + // \param eventHandler The event handler to be added. + // \return A token representing the added event handler. This token can be used to unregister the event handler. + HRESULT add_ActiveMatchIndexChanged( + [in] ICoreWebView2FindActiveMatchIndexChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + // Unregisters an event handler from the ActiveMatchIndexChanged event. + // \param token The token of the event handler to be removed, obtained during the registration of the event handler. + HRESULT remove_ActiveMatchIndexChanged([in] EventRegistrationToken token); +} +``` + +# Appendix + +This API specification focuses on providing developers with the necessary information to integrate text finding and navigation functionalities into WebView2 applications. +It emphasizes the usage of interfaces such as `ICoreWebView2Find` and `ICoreWebView2FindConfiguration` to perform find operations effectively. +For more detailed implementation notes and examples, developers can refer to the WebView2 documentation and sample code provided by Microsoft. From eae4c7e30917d6b75e0ef3832c834ade1a59f605 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 28 Feb 2024 11:55:59 -0800 Subject: [PATCH 02/80] Update FindOnPage.md removed event handler for find operation completed handler --- FindOnPage.md | 10 ---------- 1 file changed, 10 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index d27f54274..d2478cb6b 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -345,16 +345,6 @@ interface ICoreWebView2Find : IUnknown { // This event is raised when a find operation completes, either by finding all matches, navigating to a match, or by being stopped. // \param eventHandler The event handler to be added. // \return A token representing the added event handler. This token can be used to unregister the event handler. - HRESULT add_FindOperationCompleted( - [in] ICoreWebView2FindOperationCompletedHandler* eventHandler, - [out] EventRegistrationToken* token); - // Unregisters an event handler from the FindCompleted event. - // \param token The token of the event handler to be removed, obtained during the registration of the event handler. - HRESULT remove_FindOperationCompleted([in] EventRegistrationToken token); - // Registers an event handler for the MatchCountChanged event. - // This event is raised when the total count of matches in the document changes due to a new find operation or changes in the document. - // \param eventHandler The event handler to be added. - // \return A token representing the added event handler. This token can be used to unregister the event handler. HRESULT add_MatchCountChanged( [in] ICoreWebView2FindMatchCountChangedEventHandler* eventHandler, [out] EventRegistrationToken* token); From 6c2f522ea93ea3266898e1d4892dd2cfc1823829 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 28 Feb 2024 13:22:59 -0800 Subject: [PATCH 03/80] Update FindOnPage.md deleted duplicates --- FindOnPage.md | 116 +++++++++++--------------------------------------- 1 file changed, 26 insertions(+), 90 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index d2478cb6b..307161dd5 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -183,96 +183,7 @@ typedef enum COREWEBVIEW2_FIND_DIRECTION { /// Specifies a backwards find in the document. COREWEBVIEW2_FIND_DIRECTION_BACKWARD } COREWEBVIEW2_FIND_DIRECTION; -/// Interface defining the find configuration. -/// This interface provides the necessary methods and properties to configure a find operation. -[uuid(4A6ED732-DF08-4449-8949-3632A4DEBFCD), object, pointer_default(unique)] -interface ICoreWebView2FindConfiguration : IUnknown { - /// Gets the find term used for the find operation. - /// \return The find term. - [propget] HRESULT FindTerm([out, retval] LPWSTR* value); - /// Sets the find term to be used for the find operation. - /// \param[in] value The find term. - [propput] HRESULT FindTerm([in] LPCWSTR value); - /// Gets the direction of the find operation (forward or backward). - /// \return The find direction. - [propget] HRESULT FindDirection([out, retval] COREWEBVIEW2_FIND_DIRECTION* value); - /// Sets the direction for the find operation. - /// \param[in] value The find direction. - [propput] HRESULT FindDirection([in] COREWEBVIEW2_FIND_DIRECTION value); - /// Determines if the find operation is case sensitive. - /// \return TRUE if the find is case sensitive, FALSE otherwise. - [propget] HRESULT IsCaseSensitive([out, retval] BOOL* value); - /// Sets whether the find operation should be case sensitive. - /// \param[in] value TRUE to make the find case sensitive, FALSE otherwise. - [propput] HRESULT IsCaseSensitive([in] BOOL value); - /// Determines if only whole words should be matched during the find operation. - /// \return TRUE if only whole words should be matched, FALSE otherwise. - [propget] HRESULT ShouldMatchWord([out, retval] BOOL* value); - /// Sets whether to only match whole words during the find operation. - [propput] HRESULT ShouldMatchWord([in] BOOL value); - /// Gets the state of whether all matches are highlighted. - /// \return TRUE if all matches are highlighted, FALSE otherwise. - [propget] HRESULT ShouldHighlightAllMatches([out, retval] BOOL* value); - /// Sets the state to either highlight all matches or not. - [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); - /// Determines if the currently active match is highlighted. - /// \return TRUE if the active match is highlighted, FALSE otherwise. - [propget] HRESULT ShouldHighlightActiveMatch([out, retval] BOOL* value); - /// Sets whether to highlight the currently active match. - [propput] HRESULT ShouldHighlightActiveMatch([in] BOOL value); - /// Checks if a custom user interface is desired by end developer. - /// If TRUE, the default Find bar is not displayed. - /// \return TRUE if using a custom UI, FALSE if using the default. - [propget] HRESULT UseCustomUI([out, retval] BOOL* value); - /// Sets whether to use a custom UI for the Find operation. - [propput] HRESULT UseCustomUI([in] BOOL value); - /// Gets the index of the currently active match. - /// If there's no active find session but an attempt is made to change the active match index: - /// The function might crash if the global_match_id isn't found in the map. - /// It will clear any active match highlighting if there's a previously active frame. - /// It will either select a new active match or return an error through the callback if the frame associated with the match isn't valid. - /// \return The active match index. - [propget] HRESULT ActiveMatchIndex([out, retval] LONG* value); - /// Sets the index for the active match. - [propput] HRESULT ActiveMatchIndex([in] LONG value); - /// Gets the total count of matches found in the current document based on the last find criteria. - /// \return The total count of matches. - [propget] HRESULT MatchesCount([out, retval] LONG* value); - /** - * Passes the current highlighting settings to the underlying Mojo. - * - * This function retrieves the current text highlighting settings set by the user - * or the default system and ensures that they are used during any subsequent text - * find or highlight operations. This includes settings related to highlighting - * all matches, the active match, and any custom UI preferences. - * - * Users should call this function after changing any highlight settings to ensure - * that they are applied properly in the system. - */ - HRESULT PassHighlightSettings(); -} -/// Handles the event that's fired when the match count changes. -[uuid(623EFBFB-A19E-43C4-B309-D578511D24AB), object, pointer_default(unique)] -interface ICoreWebView2FindMatchCountChangedEventHandler : IUnknown { - /// Provides the event args when the match count changes. - HRESULT Invoke(LONG matchesCount); -} -/// Handles the event that's fired when the active match index changes. -[uuid(623EFBF9-A19E-43C4-B309-D578511D24A9), object, pointer_default(unique)] -interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { - /// Provides the event args when the active match index changes. - /// \param sender The sender of this event, representing the current instance of ICoreWebView2Find. - /// \param args The event args that contain the new active match index. - HRESULT Invoke( - [in] ICoreWebView2* sender, - [in] ICoreWebView2FindActiveMatchIndexChangedEventArgs* args); -} -/// Handles the event that's fired when the find operation completes. -[uuid(2604789D-9553-4246-8E21-B9C74EFAD04F), object, pointer_default(unique)] -interface ICoreWebView2FindOperationCompletedHandler : IUnknown { - /// Provides the event args when the find operation completes. - HRESULT Invoke(HRESULT value, LONG activeMatchIndex, LONG matchesCount); -} + // Interface defining the find configuration. [uuid(4A6ED732-DF08-4449-8949-3632A4DEBFCD), object, pointer_default(unique)] interface ICoreWebView2FindConfiguration : IUnknown { @@ -329,6 +240,31 @@ interface ICoreWebView2FindConfiguration : IUnknown { */ HRESULT PassHighlightSettings(); } + +/// Handles the event that's fired when the match count changes. +[uuid(623EFBFB-A19E-43C4-B309-D578511D24AB), object, pointer_default(unique)] +interface ICoreWebView2FindMatchCountChangedEventHandler : IUnknown { + /// Provides the event args when the match count changes. + HRESULT Invoke(LONG matchesCount); +} + +/// Handles the event that's fired when the active match index changes. +[uuid(623EFBF9-A19E-43C4-B309-D578511D24A9), object, pointer_default(unique)] +interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { + /// Provides the event args when the active match index changes. + /// \param sender The sender of this event, representing the current instance of ICoreWebView2Find. + /// \param args The event args that contain the new active match index. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2FindActiveMatchIndexChangedEventArgs* args); +} +/// Handles the event that's fired when the find operation completes. +[uuid(2604789D-9553-4246-8E21-B9C74EFAD04F), object, pointer_default(unique)] +interface ICoreWebView2FindOperationCompletedHandler : IUnknown { + /// Provides the event args when the find operation completes. + HRESULT Invoke(HRESULT value, LONG activeMatchIndex, LONG matchesCount); +} + // Interface providing methods and properties for finding and navigating through text in the web view. [uuid(7C49A8AA-2A17-4846-8207-21D1520AABC0), object, pointer_default(unique)] interface ICoreWebView2Find : IUnknown { From 18600e63555e36371b327fde6c1f03fb82f265c1 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 28 Feb 2024 15:12:33 -0800 Subject: [PATCH 04/80] Update FindOnPage.md Deleted 3 event handlers as they did not serve an explicit purpose. --- FindOnPage.md | 26 -------------------------- 1 file changed, 26 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 307161dd5..63a4db834 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -146,32 +146,6 @@ void AppWindow::FindPrevious() //! [FindPrevious] ``` -#### Handle Match Count Changes - -```cpp -void OnMatchCountChanged(LONG matchesCount) -{ - // Handle match count changes - // Update UI elements or perform actions based on the new match count -} -``` -#### Handle Active Match Index Changes -```cpp -void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2StagingFindActiveMatchIndexChangedEventArgs* args) -{ - // Handle active match index changes - // Update UI to reflect the change in the active match index -} -``` - -#### Handle Find Operation Completion - -```cpp -void OnFindOperationCompleted(HRESULT value, LONG activeMatchIndex, LONG matchesCount) -{ - // Handle find operation completion - // Update UI elements, display search results, or handle errors -} ``` ## API Details ```csharp From f2c8a40eea262cc7f4c07d2c0b4d64fb9c0b8388 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 1 Mar 2024 15:35:10 -0800 Subject: [PATCH 05/80] Update FindOnPage.md --- FindOnPage.md | 241 ++++++++++++++++++++++++++++++-------------------- 1 file changed, 144 insertions(+), 97 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 63a4db834..317165b24 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -13,39 +13,72 @@ To initiate a find operation within a WebView2 control, developers can utilize t This method allows specifying the find term and configuring other find parameters using the `ICoreWebView2FindConfiguration` interface. #### Create/Specify a Find Configuration - - - ```cpp -ICoreWebView2FindConfiguration CreateFindConfiguration() +bool AppWindow::ConfigureAndExecuteFind( + const std::wstring& searchTerm, + bool caseSensitive, + bool highlightAllMatches, + COREWEBVIEW2_FIND_DIRECTION direction) { - ICoreWebView2Environment5 environment = webView2Control.GetEnvironment(); - ICoreWebView2FindConfiguration configuration; - environment.CreateFindConfiguration(out configuration); - configuration.FindTerm = "example"; - configuration.FindDirection = COREWEBVIEW2_FIND_DIRECTION.COREWEBVIEW2_FIND_DIRECTION_FORWARD; - configuration.IsCaseSensitive = false; - configuration.ShouldMatchWord = false; - return configuration; + // Query for the ICoreWebView2StagingEnvironment5 interface. + auto webView2Environment5 = m_webViewEnvironment.try_query(); + CHECK_FEATURE_RETURN(webView2Environment5); + + // Create the find configuration. + wil::com_ptr findConfiguration; + CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); + + // Apply the find operation configurations. + CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); + CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(caseSensitive)); + CHECK_FAILURE(findConfiguration->put_ShouldHighlightAllMatches(highlightAllMatches)); + CHECK_FAILURE(findConfiguration->put_FindDirection(direction)); + + // Proceed to execute the find operation with the configured settings. + return ExecuteFindOperation(findConfiguration.get()); } ``` ### Start a Find Operation - ```cpp //! [StartFindOnPage] -void AppWindow::StartFindOnPage(const std::wstring& findTerm) +bool AppWindow::ExecuteFindOperation(ICoreWebView2StagingFindConfiguration* configuration) { - // Get the find interface - auto find = webView2Control.GetFind(); - - // Create find configuration - auto configuration = CreateFindConfiguration(); - - // Start the find operation - find.StartFind(configuration, OnFindOperationCompleted); + // Query for the ICoreWebView2Staging17 interface to access the Find feature. + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + + // Get the Find interface. + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + + // Apply custom UI settings and highlight configurations. + CHECK_FAILURE(webView2stagingfind->put_UseCustomUI(false)); // Assuming you want to use the default UI, adjust as necessary. + CHECK_FAILURE(webView2stagingfind->put_ShouldHighlightAllMatches(true)); // This should match the passed parameter if dynamic. + CHECK_FAILURE(webView2stagingfind->PassHighlightSettings()); + + // Start the find operation with the configured findConfiguration. + HRESULT result = webView2stagingfind->StartFind( + configuration, + Callback( + [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT + { + if (SUCCEEDED(result)) + { + // Handle successful find operation + // For example, updating UI elements to reflect the find results + } + else + { + // Handle errors appropriately + } + return S_OK; + }).Get()); + + return SUCCEEDED(result); } + //! [StartFindOnPage] ``` ### Stop an existing find operation @@ -53,13 +86,14 @@ void AppWindow::StartFindOnPage(const std::wstring& findTerm) To stop an ongoing find operation within a WebView2 control, developers can use the `StopFind` method of the `ICoreWebView2Find` interface. ```cpp //! [StopFind] -void AppWindow::StopFind() +bool AppWindow::StopFind() { - // Get the find interface - auto find = webView2Control.GetFind(); - - // Stop the find operation - find.StopFind(); + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + CHECK_FAILURE(webView2stagingfind->StopFind()); + return true; } //! [StopFind] ``` @@ -72,16 +106,21 @@ To retrieve the total number of matches found during a find operation within a W ```cpp //! [GetMatchCount] -void AppWindow::GetMatchCount() +bool AppWindow::GetMatchCount() { - // Get the find interface - auto find = webView2Control.GetFind(); - - // Get the match count + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); LONG matchCount; - find.GetMatchesCount(&matchCount); + CHECK_FAILURE(webView2stagingfind->get_MatchesCount(&matchCount)); + + // Update UI or handle matchCount as you wish + // For example, you could show a message box + std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); + MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); - // Update UI or handle matchCount + return true; } //! [GetMatchCount] ``` @@ -94,16 +133,22 @@ Developers can retrieve the index of the currently active match within a WebView ```cpp //! [GetActiveMatchIndex] -void AppWindow::GetActiveMatchIndex() +bool AppWindow::GetActiveMatchIndex() { - // Get the find interface - auto find = webView2Control.GetFind(); - - // Get the active match index + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); LONG activeMatchIndex; - find.GetActiveMatchIndex(&activeMatchIndex); + CHECK_FAILURE(webView2stagingfind->get_ActiveMatchIndex(&activeMatchIndex)); + + // Update UI or handle activeMatchIndex as you wish + // For example, you could show a message box + std::wstring activeMatchIndexStr = + L"Active Match Index: " + std::to_wstring(activeMatchIndex); + MessageBox(m_mainWindow, activeMatchIndexStr.c_str(), L"Find Operation", MB_OK); - // Update UI or handle activeMatchIndex + return true; } //! [GetActiveMatchIndex] ``` @@ -116,13 +161,18 @@ To navigate to the next match found during a find operation within a WebView2 co ```cpp //! [FindNext] -void AppWindow::FindNext() +bool AppWindow::FindNext() { - // Get the find interface - auto find = webView2Control.GetFind(); + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); - // Find the next occurrence - find.FindNext(); + CHECK_FAILURE(webView2stagingfind->FindNext()); + CHECK_FAILURE(webView2stagingfind->remove_ActiveMatchIndexChanged( + m_ActiveMatchIndexChangedEventToken)); + + return true; } //! [FindNext] ``` @@ -135,20 +185,23 @@ To navigate to the previous match found during a find operation within a WebView ```cpp //! [FindPrevious] -void AppWindow::FindPrevious() +bool AppWindow::FindPrevious() { - // Get the find interface - auto find = webView2Control.GetFind(); + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + + CHECK_FAILURE(webView2stagingfind->FindPrevious()); - // Find the previous occurrence - find.FindPrevious(); + return true; } //! [FindPrevious] ``` -``` ## API Details ```csharp + /// Specifies the direction of find Parameters. [v1_enum] typedef enum COREWEBVIEW2_FIND_DIRECTION { @@ -161,58 +214,46 @@ typedef enum COREWEBVIEW2_FIND_DIRECTION { // Interface defining the find configuration. [uuid(4A6ED732-DF08-4449-8949-3632A4DEBFCD), object, pointer_default(unique)] interface ICoreWebView2FindConfiguration : IUnknown { + // Gets or sets the find term used for the find operation. [propget] HRESULT FindTerm([out, retval] LPWSTR* value); - [propput] HRESULT FindTerm([in] LPCWSTR value); + [propput] HRESULT FindTerm([in] LPCWSTR value); + // Gets or sets the direction of the find operation (forward or backward). [propget] HRESULT FindDirection([out, retval] COREWEBVIEW2_FIND_DIRECTION* value); - [propput] HRESULT FindDirection([in] COREWEBVIEW2_FIND_DIRECTION value); + [propput] HRESULT FindDirection([in] COREWEBVIEW2_FIND_DIRECTION value); + // Gets or sets whether the find operation is case sensitive. [propget] HRESULT IsCaseSensitive([out, retval] BOOL* value); - [propput] HRESULT IsCaseSensitive([in] BOOL value); + [propput] HRESULT IsCaseSensitive([in] BOOL value); + // Gets or sets whether to only match whole words during the find operation. [propget] HRESULT ShouldMatchWord([out, retval] BOOL* value); - [propput] HRESULT ShouldMatchWord([in] BOOL value); + [propput] HRESULT ShouldMatchWord([in] BOOL value); + // Gets the state of whether all matches are highlighted. // \return TRUE if all matches are highlighted, FALSE otherwise. [propget] HRESULT ShouldHighlightAllMatches([out, retval] BOOL* value); // Sets the state to either highlight all matches or not. - [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); - // Determines if the currently active match is highlighted. - // \return TRUE if the active match is highlighted, FALSE otherwise. - [propget] HRESULT ShouldHighlightActiveMatch([out, retval] BOOL* value); - // Sets whether to highlight the currently active match. - [propput] HRESULT ShouldHighlightActiveMatch([in] BOOL value); + [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); + // Checks if a custom user interface is desired by end developer. // If TRUE, the default Find bar is not displayed. - // \return TRUE if using a custom UI, FALSE if using the default. - [propget] HRESULT UseCustomUI([out, retval] BOOL* value); + // Returns TRUE if using a custom UI, FALSE if using the default. + [propget] HRESULT SuppressDefaultDialog([out, retval] BOOL* value); // Sets whether to use a custom UI for the Find operation. - [propput] HRESULT UseCustomUI([in] BOOL value); + [propput] HRESULT SuppressDefaultDialog([in] BOOL value); + // Gets the index of the currently active match. - // If there's no active find session but an attempt is made to change the active match index: - // The function might crash if the global_match_id isn't found in the map. - // It will clear any active match highlighting if there's a previously active frame. - // It will either select a new active match or return an error through the callback if the frame associated with the match isn't valid. - // \return The active match index. + // If there's no active find session but an attempt is made to get the active match index: + // The function will return -1. + // Returns The active match index. [propget] HRESULT ActiveMatchIndex([out, retval] LONG* value); - // Sets the index for the active match. - [propput] HRESULT ActiveMatchIndex([in] LONG value); + // Gets the total count of matches found in the current document based on the last find criteria. // \return The total count of matches. [propget] HRESULT MatchesCount([out, retval] LONG* value); - /** - * Passes the current highlighting settings to the underlying Mojo. - * - * This function retrieves the current text highlighting settings set by the user - * or the default system and ensures that they are used during any subsequent text - * find or highlight operations. This includes settings related to highlighting - * all matches, the active match, and any custom UI preferences. - * - * Users should call this function after changing any highlight settings to ensure - * that they are applied properly in the system. - */ - HRESULT PassHighlightSettings(); + } /// Handles the event that's fired when the match count changes. @@ -226,8 +267,8 @@ interface ICoreWebView2FindMatchCountChangedEventHandler : IUnknown { [uuid(623EFBF9-A19E-43C4-B309-D578511D24A9), object, pointer_default(unique)] interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { /// Provides the event args when the active match index changes. - /// \param sender The sender of this event, representing the current instance of ICoreWebView2Find. - /// \param args The event args that contain the new active match index. + /// Parameter is a sender The sender of this event, representing the current instance of ICoreWebView2Find. + /// Parameter is a args The event args that contain the new active match index. HRESULT Invoke( [in] ICoreWebView2* sender, [in] ICoreWebView2FindActiveMatchIndexChangedEventArgs* args); @@ -241,36 +282,42 @@ interface ICoreWebView2FindOperationCompletedHandler : IUnknown { // Interface providing methods and properties for finding and navigating through text in the web view. [uuid(7C49A8AA-2A17-4846-8207-21D1520AABC0), object, pointer_default(unique)] -interface ICoreWebView2Find : IUnknown { +interface ICoreWebView2Find : IUnknown { + // Initiates a find using the specified configuration. HRESULT StartFind([in] ICoreWebView2FindConfiguration* configuration, ICoreWebView2FindOperationCompletedHandler* handler); + // Navigates to the next match in the document. - HRESULT FindNext(); + HRESULT FindNext(); + // Navigates to the previous match in the document. - HRESULT FindPrevious(); + HRESULT FindPrevious(); + // Stops the current 'Find' operation and hides the Find bar. - HRESULT StopFind(); + HRESULT StopFind(); + // Registers an event handler for the FindCompleted event. // This event is raised when a find operation completes, either by finding all matches, navigating to a match, or by being stopped. - // \param eventHandler The event handler to be added. - // \return A token representing the added event handler. This token can be used to unregister the event handler. + // Parameter is the event handler to be added. + // Returns a token representing the added event handler. This token can be used to unregister the event handler. HRESULT add_MatchCountChanged( [in] ICoreWebView2FindMatchCountChangedEventHandler* eventHandler, [out] EventRegistrationToken* token); // Unregisters an event handler from the MatchCountChanged event. - // \param token The token of the event handler to be removed, obtained during the registration of the event handler. + // Parameter is the token of the event handler to be removed, obtained during the registration of the event handler. HRESULT remove_MatchCountChanged([in] EventRegistrationToken token); + // Registers an event handler for the ActiveMatchIndexChanged event. // This event is raised when the index of the currently active match changes. // This can happen when the user navigates to a different match or when the active match is changed programmatically. - // \param eventHandler The event handler to be added. - // \return A token representing the added event handler. This token can be used to unregister the event handler. + // Parameter is the event handler to be added. + // Returns a token representing the added event handler. This token can be used to unregister the event handler. HRESULT add_ActiveMatchIndexChanged( [in] ICoreWebView2FindActiveMatchIndexChangedEventHandler* eventHandler, [out] EventRegistrationToken* token); // Unregisters an event handler from the ActiveMatchIndexChanged event. - // \param token The token of the event handler to be removed, obtained during the registration of the event handler. + // parameter is the token of the event handler to be removed, obtained during the registration of the event handler. HRESULT remove_ActiveMatchIndexChanged([in] EventRegistrationToken token); } ``` From 27cc5a1e50a2d5bd963430da434983fcf616e90a Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 4 Mar 2024 13:56:05 -0800 Subject: [PATCH 06/80] Update FindOnPage.md Added event handlers for match count and match index back --- FindOnPage.md | 29 +++++++++++++++++++++-------- 1 file changed, 21 insertions(+), 8 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 317165b24..18f330bd3 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -124,7 +124,15 @@ bool AppWindow::GetMatchCount() } //! [GetMatchCount] ``` +#### Handle Match Count Changes +```cpp +void OnMatchCountChanged(LONG matchesCount) +{ + // Handle match count changes + // Update UI elements or perform actions based on the new match count +} +``` ### Retrieve the Index of the Active Match #### Description @@ -153,6 +161,15 @@ bool AppWindow::GetActiveMatchIndex() //! [GetActiveMatchIndex] ``` +#### Handle Active Match Index Changes +```cpp +void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2StagingFindActiveMatchIndexChangedEventArgs* args) +{ + // Handle active match index changes + // Update UI to reflect the change in the active match index +} +``` + ### Navigate to the Next Match #### Description @@ -259,25 +276,21 @@ interface ICoreWebView2FindConfiguration : IUnknown { /// Handles the event that's fired when the match count changes. [uuid(623EFBFB-A19E-43C4-B309-D578511D24AB), object, pointer_default(unique)] interface ICoreWebView2FindMatchCountChangedEventHandler : IUnknown { - /// Provides the event args when the match count changes. + /// Parameter is the match count. HRESULT Invoke(LONG matchesCount); } /// Handles the event that's fired when the active match index changes. [uuid(623EFBF9-A19E-43C4-B309-D578511D24A9), object, pointer_default(unique)] interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { - /// Provides the event args when the active match index changes. - /// Parameter is a sender The sender of this event, representing the current instance of ICoreWebView2Find. - /// Parameter is a args The event args that contain the new active match index. - HRESULT Invoke( - [in] ICoreWebView2* sender, - [in] ICoreWebView2FindActiveMatchIndexChangedEventArgs* args); + /// Parameter is the active match index. + HRESULT Invoke(LONG activeMatchIndex); } /// Handles the event that's fired when the find operation completes. [uuid(2604789D-9553-4246-8E21-B9C74EFAD04F), object, pointer_default(unique)] interface ICoreWebView2FindOperationCompletedHandler : IUnknown { /// Provides the event args when the find operation completes. - HRESULT Invoke(HRESULT value, LONG activeMatchIndex, LONG matchesCount); + HRESULT Invoke(HRESULT errorCode, BOOL status); } // Interface providing methods and properties for finding and navigating through text in the web view. From 866f3fe6490999729378bafae7edb71168facfdc Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 4 Mar 2024 14:01:43 -0800 Subject: [PATCH 07/80] Update FindOnPage.md Added more to description --- FindOnPage.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 18f330bd3..bfe7459d7 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -3,7 +3,9 @@ ## Background The WebView2Find API provides methods and events to support text finding and navigation within a WebView2 control. -It allows developers to initiate find operations, navigate between find results, and customize various find configurations. +It allows developers to programmatically initiate find operations, navigate between find results, supress default UI, customize various find configurations +such as query, direction of search, match case, match word, etc. Also enables developers to track the status of ongoing operations such as whether a find session has +completed or not, whether the match count has changed, and whether the match index has changed. ## Examples From bdcfbb524a27373a1690686ac97e2518929f3b71 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 4 Mar 2024 17:12:16 -0800 Subject: [PATCH 08/80] Update FindOnPage.md Added C# defintion of API --- FindOnPage.md | 94 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 94 insertions(+) diff --git a/FindOnPage.md b/FindOnPage.md index bfe7459d7..736934ac0 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -337,6 +337,100 @@ interface ICoreWebView2Find : IUnknown { } ``` + +### Setting Up Find Configuration + +```csharp +public enum CoreWebView2FindDirection +{ + Forward, + Backward +} + +public class CoreWebView2FindConfiguration +{ + public string FindTerm { get; set; } + public CoreWebView2FindDirection FindDirection { get; set; } + public bool IsCaseSensitive { get; set; } + public bool ShouldMatchWord { get; set; } +} +``` + +### Starting a Find Operation + +```csharp +public interface ICoreWebView2StagingFind +{ + Task StartFindAsync(CoreWebView2FindConfiguration configuration); + void FindNext(); + void FindPrevious(); + void StopFind(); + bool ShouldHighlightAllMatches { get; set; } + bool ShouldHighlightActiveMatch { get; set; } + bool UseCustomUI { get; set; } + int ActiveMatchIndex { get; } + int MatchesCount { get; } + void PassHighlightSettings(); +} + +// Usage example: +public async Task PerformFindOperation(ICoreWebView2StagingFind webViewFind) +{ + var findConfig = new CoreWebView2FindConfiguration + { + FindTerm = "example", + FindDirection = CoreWebView2FindDirection.Forward, + IsCaseSensitive = false, + ShouldMatchWord = true + }; + + await webViewFind.StartFindAsync(findConfig); + webViewFind.FindNext(); + // Further operations... +} +``` + +### Handling Find Operation Events + +```csharp +public interface ICoreWebView2StagingFindMatchCountChangedEventHandler +{ + void OnMatchCountChanged(ICoreWebView2StagingFind sender); +} + +public interface ICoreWebView2StagingFindActiveMatchIndexChangedEventHandler +{ + void OnActiveMatchIndexChanged(ICoreWebView2StagingFind sender); +} + +public interface ICoreWebView2StagingFindOperationCompletedHandler +{ + void OnFindOperationCompleted(ICoreWebView2StagingFind sender); +} + +public void SubscribeToFindEvents(ICoreWebView2StagingFind webViewFind) +{ + webViewFind.MatchCountChanged += OnMatchCountChanged; + webViewFind.ActiveMatchIndexChanged += OnActiveMatchIndexChanged; + webViewFind.FindOperationCompleted += OnFindOperationCompleted; +} + +private void OnMatchCountChanged(ICoreWebView2StagingFind sender) +{ + Console.WriteLine($"Match count changed. New count: {sender.MatchesCount}"); +} + +private void OnActiveMatchIndexChanged(ICoreWebView2StagingFind sender) +{ + Console.WriteLine($"Active match index changed. New index: {sender.ActiveMatchIndex}"); +} + +private void OnFindOperationCompleted(ICoreWebView2StagingFind sender) +{ + Console.WriteLine("Find operation completed."); +} +``` + # Appendix This API specification focuses on providing developers with the necessary information to integrate text finding and navigation functionalities into WebView2 applications. From bcb312dd40dc49a4aa028683cf3dd38d597d1787 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 5 Mar 2024 16:04:56 -0800 Subject: [PATCH 09/80] Update FindOnPage.md --- FindOnPage.md | 169 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 169 insertions(+) diff --git a/FindOnPage.md b/FindOnPage.md index 736934ac0..4ae55d89b 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -40,7 +40,31 @@ bool AppWindow::ConfigureAndExecuteFind( return ExecuteFindOperation(findConfiguration.get()); } ``` +```csharp +bool AppWindow::ConfigureAndExecuteFind( + const std::wstring& searchTerm, + bool caseSensitive, + bool highlightAllMatches, + COREWEBVIEW2_FIND_DIRECTION direction) +{ + // Query for the ICoreWebView2StagingEnvironment5 interface. + auto webView2Environment5 = m_webViewEnvironment.try_query(); + CHECK_FEATURE_RETURN(webView2Environment5); + + // Create the find configuration. + wil::com_ptr findConfiguration; + CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); + // Apply the find operation configurations. + CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); + CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(caseSensitive)); + CHECK_FAILURE(findConfiguration->put_ShouldHighlightAllMatches(highlightAllMatches)); + CHECK_FAILURE(findConfiguration->put_FindDirection(direction)); + + // Proceed to execute the find operation with the configured settings. + return ExecuteFindOperation(findConfiguration.get()); +} +``` ### Start a Find Operation ```cpp @@ -81,6 +105,46 @@ bool AppWindow::ExecuteFindOperation(ICoreWebView2StagingFindConfiguration* conf return SUCCEEDED(result); } +//! [StartFindOnPage] +``` +```csharp +//! [StartFindOnPage] +bool AppWindow::ExecuteFindOperation(ICoreWebView2StagingFindConfiguration* configuration) +{ + // Query for the ICoreWebView2Staging17 interface to access the Find feature. + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + + // Get the Find interface. + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + + // Apply custom UI settings and highlight configurations. + CHECK_FAILURE(webView2stagingfind->put_UseCustomUI(false)); // Assuming you want to use the default UI, adjust as necessary. + CHECK_FAILURE(webView2stagingfind->put_ShouldHighlightAllMatches(true)); // This should match the passed parameter if dynamic. + CHECK_FAILURE(webView2stagingfind->PassHighlightSettings()); + + // Start the find operation with the configured findConfiguration. + HRESULT result = webView2stagingfind->StartFind( + configuration, + Callback( + [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT + { + if (SUCCEEDED(result)) + { + // Handle successful find operation + // For example, updating UI elements to reflect the find results + } + else + { + // Handle errors appropriately + } + return S_OK; + }).Get()); + + return SUCCEEDED(result); +} + //! [StartFindOnPage] ``` ### Stop an existing find operation @@ -99,6 +163,19 @@ bool AppWindow::StopFind() } //! [StopFind] ``` +```csharp +//! [StopFind] +bool AppWindow::StopFind() +{ + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + CHECK_FAILURE(webView2stagingfind->StopFind()); + return true; +} +//! [StopFind] +``` ### Retrieve the Number of Matches @@ -126,6 +203,26 @@ bool AppWindow::GetMatchCount() } //! [GetMatchCount] ``` +```csharp +//! [GetMatchCount] +bool AppWindow::GetMatchCount() +{ + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + LONG matchCount; + CHECK_FAILURE(webView2stagingfind->get_MatchesCount(&matchCount)); + + // Update UI or handle matchCount as you wish + // For example, you could show a message box + std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); + MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); + + return true; +} +//! [GetMatchCount] +``` #### Handle Match Count Changes ```cpp @@ -135,6 +232,14 @@ void OnMatchCountChanged(LONG matchesCount) // Update UI elements or perform actions based on the new match count } ``` + +```csharp +void OnMatchCountChanged(LONG matchesCount) +{ + // Handle match count changes + // Update UI elements or perform actions based on the new match count +} +``` ### Retrieve the Index of the Active Match #### Description @@ -163,6 +268,28 @@ bool AppWindow::GetActiveMatchIndex() //! [GetActiveMatchIndex] ``` +```csharp +//! [GetActiveMatchIndex] +bool AppWindow::GetActiveMatchIndex() +{ + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + LONG activeMatchIndex; + CHECK_FAILURE(webView2stagingfind->get_ActiveMatchIndex(&activeMatchIndex)); + + // Update UI or handle activeMatchIndex as you wish + // For example, you could show a message box + std::wstring activeMatchIndexStr = + L"Active Match Index: " + std::to_wstring(activeMatchIndex); + MessageBox(m_mainWindow, activeMatchIndexStr.c_str(), L"Find Operation", MB_OK); + + return true; +} +//! [GetActiveMatchIndex] +``` + #### Handle Active Match Index Changes ```cpp void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2StagingFindActiveMatchIndexChangedEventArgs* args) @@ -172,6 +299,14 @@ void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2StagingFindAc } ``` +```csharp +void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2StagingFindActiveMatchIndexChangedEventArgs* args) +{ + // Handle active match index changes + // Update UI to reflect the change in the active match index +} +``` + ### Navigate to the Next Match #### Description @@ -196,6 +331,24 @@ bool AppWindow::FindNext() //! [FindNext] ``` +```csharp +//! [FindNext] +bool AppWindow::FindNext() +{ + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + + CHECK_FAILURE(webView2stagingfind->FindNext()); + CHECK_FAILURE(webView2stagingfind->remove_ActiveMatchIndexChanged( + m_ActiveMatchIndexChangedEventToken)); + + return true; +} +//! [FindNext] +``` + ### Navigate to the Previous Match #### Description @@ -218,6 +371,22 @@ bool AppWindow::FindPrevious() //! [FindPrevious] ``` +```csharp +//! [FindPrevious] +bool AppWindow::FindPrevious() +{ + auto webView2staging17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging17); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + + CHECK_FAILURE(webView2stagingfind->FindPrevious()); + + return true; +} +//! [FindPrevious] +``` + ## API Details ```csharp From 0cbebb2ac6cdf7f9ed9ca160a053a760ad7fc818 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 5 Mar 2024 16:15:51 -0800 Subject: [PATCH 10/80] Update FindOnPage.md --- FindOnPage.md | 128 +++++++++++++++----------------------------------- 1 file changed, 38 insertions(+), 90 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 4ae55d89b..bf98d837b 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -41,28 +41,21 @@ bool AppWindow::ConfigureAndExecuteFind( } ``` ```csharp -bool AppWindow::ConfigureAndExecuteFind( - const std::wstring& searchTerm, +public async Task ConfigureAndExecuteFindAsync( + string searchTerm, bool caseSensitive, bool highlightAllMatches, - COREWEBVIEW2_FIND_DIRECTION direction) + CoreWebView2FindDirection direction) { - // Query for the ICoreWebView2StagingEnvironment5 interface. - auto webView2Environment5 = m_webViewEnvironment.try_query(); - CHECK_FEATURE_RETURN(webView2Environment5); - - // Create the find configuration. - wil::com_ptr findConfiguration; - CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); - - // Apply the find operation configurations. - CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); - CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(caseSensitive)); - CHECK_FAILURE(findConfiguration->put_ShouldHighlightAllMatches(highlightAllMatches)); - CHECK_FAILURE(findConfiguration->put_FindDirection(direction)); + var findConfiguration = new CoreWebView2FindConfiguration + { + FindTerm = searchTerm, + IsCaseSensitive = caseSensitive, + ShouldHighlightAllMatches = highlightAllMatches, + FindDirection = direction + }; - // Proceed to execute the find operation with the configured settings. - return ExecuteFindOperation(findConfiguration.get()); + return await ExecuteFindOperationAsync(findConfiguration); } ``` ### Start a Find Operation @@ -109,40 +102,16 @@ bool AppWindow::ExecuteFindOperation(ICoreWebView2StagingFindConfiguration* conf ``` ```csharp //! [StartFindOnPage] -bool AppWindow::ExecuteFindOperation(ICoreWebView2StagingFindConfiguration* configuration) +public async Task ExecuteFindOperationAsync(CoreWebView2FindConfiguration configuration) { - // Query for the ICoreWebView2Staging17 interface to access the Find feature. - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - // Get the Find interface. - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); - - // Apply custom UI settings and highlight configurations. - CHECK_FAILURE(webView2stagingfind->put_UseCustomUI(false)); // Assuming you want to use the default UI, adjust as necessary. - CHECK_FAILURE(webView2stagingfind->put_ShouldHighlightAllMatches(true)); // This should match the passed parameter if dynamic. - CHECK_FAILURE(webView2stagingfind->PassHighlightSettings()); - - // Start the find operation with the configured findConfiguration. - HRESULT result = webView2stagingfind->StartFind( - configuration, - Callback( - [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT - { - if (SUCCEEDED(result)) - { - // Handle successful find operation - // For example, updating UI elements to reflect the find results - } - else - { - // Handle errors appropriately - } - return S_OK; - }).Get()); + // Assume CoreWebView2.FindController has been appropriately implemented or wrapped to expose async tasks. + // This example assumes such an implementation for illustration. + await webViewFind.StartFindAsync(configuration); - return SUCCEEDED(result); + // Optionally, handle completion or results with events or further async operations. + return true; } //! [StartFindOnPage] @@ -165,14 +134,10 @@ bool AppWindow::StopFind() ``` ```csharp //! [StopFind] -bool AppWindow::StopFind() +public void StopFindOperation() { - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); - CHECK_FAILURE(webView2stagingfind->StopFind()); - return true; + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + webViewFind.StopFind(); } //! [StopFind] ``` @@ -206,20 +171,12 @@ bool AppWindow::GetMatchCount() ```csharp //! [GetMatchCount] bool AppWindow::GetMatchCount() +public async Task GetMatchCountAsync() { - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); - LONG matchCount; - CHECK_FAILURE(webView2stagingfind->get_MatchesCount(&matchCount)); - - // Update UI or handle matchCount as you wish - // For example, you could show a message box - std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); - MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); - - return true; + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + var matchCount = await webViewFind.GetMatchesCountAsync(); + MessageBox.Show($"Match Count: {matchCount}", "Find Operation", MessageBoxButton.OK); + return matchCount; } //! [GetMatchCount] ``` @@ -234,10 +191,10 @@ void OnMatchCountChanged(LONG matchesCount) ``` ```csharp -void OnMatchCountChanged(LONG matchesCount) +private void OnMatchCountChanged(object sender, EventArgs e) { - // Handle match count changes - // Update UI elements or perform actions based on the new match count + // Assuming EventArgs or a derived type carries the new match count + MessageBox.Show($"Match count changed. New count: {e.MatchCount}", "Find Operation"); } ``` ### Retrieve the Index of the Active Match @@ -270,23 +227,14 @@ bool AppWindow::GetActiveMatchIndex() ```csharp //! [GetActiveMatchIndex] -bool AppWindow::GetActiveMatchIndex() +public async Task GetActiveMatchIndexAsync() { - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); - LONG activeMatchIndex; - CHECK_FAILURE(webView2stagingfind->get_ActiveMatchIndex(&activeMatchIndex)); - - // Update UI or handle activeMatchIndex as you wish - // For example, you could show a message box - std::wstring activeMatchIndexStr = - L"Active Match Index: " + std::to_wstring(activeMatchIndex); - MessageBox(m_mainWindow, activeMatchIndexStr.c_str(), L"Find Operation", MB_OK); - - return true; + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + var activeMatchIndex = await webViewFind.GetActiveMatchIndexAsync(); + MessageBox.Show($"Active Match Index: {activeMatchIndex}", "Find Operation", MessageBoxButton.OK); + return activeMatchIndex; } + //! [GetActiveMatchIndex] ``` @@ -300,10 +248,10 @@ void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2StagingFindAc ``` ```csharp -void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2StagingFindActiveMatchIndexChangedEventArgs* args) +private void OnActiveMatchIndexChanged(object sender, EventArgs e) { - // Handle active match index changes - // Update UI to reflect the change in the active match index + // Assuming EventArgs or a derived type carries the new active match index + MessageBox.Show($"Active match index changed. New index: {e.ActiveMatchIndex}", "Find Operation"); } ``` From b88741d93ada9f5dcee838b11b9e9fcdea9d53b4 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 6 Mar 2024 18:01:49 -0800 Subject: [PATCH 11/80] Update FindOnPage.md --- FindOnPage.md | 673 +++++++++++++++++++++++++++----------------------- 1 file changed, 363 insertions(+), 310 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index bf98d837b..e190ec2c9 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -16,231 +16,230 @@ This method allows specifying the find term and configuring other find parameter #### Create/Specify a Find Configuration ```cpp -bool AppWindow::ConfigureAndExecuteFind( - const std::wstring& searchTerm, - bool caseSensitive, - bool highlightAllMatches, - COREWEBVIEW2_FIND_DIRECTION direction) -{ - // Query for the ICoreWebView2StagingEnvironment5 interface. - auto webView2Environment5 = m_webViewEnvironment.try_query(); - CHECK_FEATURE_RETURN(webView2Environment5); - - // Create the find configuration. - wil::com_ptr findConfiguration; - CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); - - // Apply the find operation configurations. - CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); - CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(caseSensitive)); - CHECK_FAILURE(findConfiguration->put_ShouldHighlightAllMatches(highlightAllMatches)); - CHECK_FAILURE(findConfiguration->put_FindDirection(direction)); - - // Proceed to execute the find operation with the configured settings. - return ExecuteFindOperation(findConfiguration.get()); -} -``` -```csharp -public async Task ConfigureAndExecuteFindAsync( - string searchTerm, - bool caseSensitive, - bool highlightAllMatches, - CoreWebView2FindDirection direction) -{ - var findConfiguration = new CoreWebView2FindConfiguration + bool AppWindow::ConfigureAndExecuteFind( + const std::wstring& searchTerm, + bool caseSensitive, + bool highlightAllMatches, + COREWEBVIEW2_FIND_DIRECTION direction) { - FindTerm = searchTerm, - IsCaseSensitive = caseSensitive, - ShouldHighlightAllMatches = highlightAllMatches, - FindDirection = direction - }; - - return await ExecuteFindOperationAsync(findConfiguration); -} -``` -### Start a Find Operation - -```cpp -//! [StartFindOnPage] -bool AppWindow::ExecuteFindOperation(ICoreWebView2StagingFindConfiguration* configuration) -{ - // Query for the ICoreWebView2Staging17 interface to access the Find feature. - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); - - // Get the Find interface. - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); - - // Apply custom UI settings and highlight configurations. - CHECK_FAILURE(webView2stagingfind->put_UseCustomUI(false)); // Assuming you want to use the default UI, adjust as necessary. - CHECK_FAILURE(webView2stagingfind->put_ShouldHighlightAllMatches(true)); // This should match the passed parameter if dynamic. - CHECK_FAILURE(webView2stagingfind->PassHighlightSettings()); - - // Start the find operation with the configured findConfiguration. - HRESULT result = webView2stagingfind->StartFind( - configuration, - Callback( - [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT - { - if (SUCCEEDED(result)) - { - // Handle successful find operation - // For example, updating UI elements to reflect the find results - } - else + // Query for the ICoreWebView2Environment5 interface. + auto webView2Environment5 = m_webViewEnvironment.try_query(); + CHECK_FEATURE_RETURN(webView2Environment5); + + // Create the find configuration. + wil::com_ptr findConfiguration; + CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); + + // Apply the find operation configurations. + CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); + CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(caseSensitive)); + CHECK_FAILURE(findConfiguration->put_ShouldHighlightAllMatches(highlightAllMatches)); + CHECK_FAILURE(findConfiguration->put_FindDirection(direction)); + + // Proceed to execute the find operation with the configured settings. + return ExecuteFindOperation(findConfiguration.get()); + } + ``` + ```csharp + public async Task ConfigureAndExecuteFindAsync( + string searchTerm, + bool caseSensitive, + bool highlightAllMatches, + CoreWebView2FindDirection direction) + { + var findConfiguration = new CoreWebView2FindConfiguration + { + FindTerm = searchTerm, + IsCaseSensitive = caseSensitive, + ShouldHighlightAllMatches = highlightAllMatches, + FindDirection = direction + }; + return await ExecuteFindOperationAsync(findConfiguration); + } + ``` + ### Start a Find Operation + + ```cpp + //! [StartFindOnPage] + bool AppWindow::ExecuteFindOperation(ICoreWebView2FindConfiguration* configuration) + { + // Query for the ICoreWebView217 interface to access the Find feature. + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + + // Get the Find interface. + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); + + // Apply custom UI settings and highlight configurations. + CHECK_FAILURE(webView2find->put_UseCustomUI(false)); // Assuming you want to use the default UI, adjust as necessary. + CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); // This should match the passed parameter if dynamic. + CHECK_FAILURE(webView2find->PassHighlightSettings()); + + // Start the find operation with the configured findConfiguration. + HRESULT result = webView2find->StartFind( + configuration, + Callback( + [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT { - // Handle errors appropriately - } - return S_OK; - }).Get()); - - return SUCCEEDED(result); -} - -//! [StartFindOnPage] -``` -```csharp -//! [StartFindOnPage] -public async Task ExecuteFindOperationAsync(CoreWebView2FindConfiguration configuration) -{ - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - - // Assume CoreWebView2.FindController has been appropriately implemented or wrapped to expose async tasks. - // This example assumes such an implementation for illustration. - await webViewFind.StartFindAsync(configuration); - - // Optionally, handle completion or results with events or further async operations. - return true; -} - -//! [StartFindOnPage] -``` -### Stop an existing find operation -#### Description -To stop an ongoing find operation within a WebView2 control, developers can use the `StopFind` method of the `ICoreWebView2Find` interface. -```cpp -//! [StopFind] -bool AppWindow::StopFind() -{ - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); - CHECK_FAILURE(webView2stagingfind->StopFind()); - return true; -} -//! [StopFind] -``` -```csharp -//! [StopFind] -public void StopFindOperation() -{ - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - webViewFind.StopFind(); -} -//! [StopFind] -``` - -### Retrieve the Number of Matches - -#### Description -To retrieve the total number of matches found during a find operation within a WebView2 control, developers can utilize the `GetMatchCount` method. - - -```cpp -//! [GetMatchCount] -bool AppWindow::GetMatchCount() -{ - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); - LONG matchCount; - CHECK_FAILURE(webView2stagingfind->get_MatchesCount(&matchCount)); - - // Update UI or handle matchCount as you wish - // For example, you could show a message box - std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); - MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); - - return true; -} -//! [GetMatchCount] -``` -```csharp -//! [GetMatchCount] -bool AppWindow::GetMatchCount() -public async Task GetMatchCountAsync() -{ - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - var matchCount = await webViewFind.GetMatchesCountAsync(); - MessageBox.Show($"Match Count: {matchCount}", "Find Operation", MessageBoxButton.OK); - return matchCount; -} -//! [GetMatchCount] -``` -#### Handle Match Count Changes - -```cpp -void OnMatchCountChanged(LONG matchesCount) -{ - // Handle match count changes - // Update UI elements or perform actions based on the new match count -} -``` - -```csharp -private void OnMatchCountChanged(object sender, EventArgs e) -{ - // Assuming EventArgs or a derived type carries the new match count - MessageBox.Show($"Match count changed. New count: {e.MatchCount}", "Find Operation"); -} -``` -### Retrieve the Index of the Active Match - -#### Description -Developers can retrieve the index of the currently active match within a WebView2 control using the `GetActiveMatchIndex` method. - - -```cpp -//! [GetActiveMatchIndex] -bool AppWindow::GetActiveMatchIndex() -{ - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); - LONG activeMatchIndex; - CHECK_FAILURE(webView2stagingfind->get_ActiveMatchIndex(&activeMatchIndex)); - - // Update UI or handle activeMatchIndex as you wish - // For example, you could show a message box - std::wstring activeMatchIndexStr = - L"Active Match Index: " + std::to_wstring(activeMatchIndex); - MessageBox(m_mainWindow, activeMatchIndexStr.c_str(), L"Find Operation", MB_OK); - - return true; -} -//! [GetActiveMatchIndex] -``` - -```csharp -//! [GetActiveMatchIndex] -public async Task GetActiveMatchIndexAsync() -{ - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - var activeMatchIndex = await webViewFind.GetActiveMatchIndexAsync(); - MessageBox.Show($"Active Match Index: {activeMatchIndex}", "Find Operation", MessageBoxButton.OK); - return activeMatchIndex; -} - -//! [GetActiveMatchIndex] -``` - -#### Handle Active Match Index Changes -```cpp -void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2StagingFindActiveMatchIndexChangedEventArgs* args) + if (SUCCEEDED(result)) + { + // Handle successful find operation + // For example, updating UI elements to reflect the find results + } + else + { + // Handle errors appropriately + } + return S_OK; + }).Get()); + + return SUCCEEDED(result); + } + + //! [StartFindOnPage] + ``` + ```csharp + //! [StartFindOnPage] + public async Task ExecuteFindOperationAsync(CoreWebView2FindConfiguration configuration) + { + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + + // Assume CoreWebView2.FindController has been appropriately implemented or wrapped to expose async tasks. + // This example assumes such an implementation for illustration. + await webViewFind.StartFindAsync(configuration); + + // Optionally, handle completion or results with events or further async operations. + return true; + } + + //! [StartFindOnPage] + ``` + ### Stop an existing find operation + #### Description + To stop an ongoing find operation within a WebView2 control, developers can use the `StopFind` method of the `ICoreWebView2Find` interface. + ```cpp + //! [StopFind] + bool AppWindow::StopFind() + { + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); + CHECK_FAILURE(webView2find->StopFind()); + return true; + } + //! [StopFind] + ``` + ```csharp + //! [StopFind] + public void StopFindOperation() + { + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + webViewFind.StopFind(); + } + //! [StopFind] + ``` + + ### Retrieve the Number of Matches + + #### Description + To retrieve the total number of matches found during a find operation within a WebView2 control, developers can utilize the `GetMatchCount` method. + + + ```cpp + //! [GetMatchCount] + bool AppWindow::GetMatchCount() + { + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); + LONG matchCount; + CHECK_FAILURE(webView2find->get_MatchesCount(&matchCount)); + + // Update UI or handle matchCount as you wish + // For example, you could show a message box + std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); + MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); + + return true; + } + //! [GetMatchCount] + ``` + ```csharp + //! [GetMatchCount] + bool AppWindow::GetMatchCount() + public async Task GetMatchCountAsync() + { + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + var matchCount = await webViewFind.GetMatchesCountAsync(); + MessageBox.Show($"Match Count: {matchCount}", "Find Operation", MessageBoxButton.OK); + return matchCount; + } + //! [GetMatchCount] + ``` + #### Handle Match Count Changes + + ```cpp + void OnMatchCountChanged(LONG matchesCount) + { + // Handle match count changes + // Update UI elements or perform actions based on the new match count + } + ``` + + ```csharp + private void OnMatchCountChanged(object sender, EventArgs e) + { + // Assuming EventArgs or a derived type carries the new match count + MessageBox.Show($"Match count changed. New count: {e.MatchCount}", "Find Operation"); + } + ``` + ### Retrieve the Index of the Active Match + + #### Description + Developers can retrieve the index of the currently active match within a WebView2 control using the `GetActiveMatchIndex` method. + + + ```cpp + //! [GetActiveMatchIndex] + bool AppWindow::GetActiveMatchIndex() + { + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); + LONG activeMatchIndex; + CHECK_FAILURE(webView2find->get_ActiveMatchIndex(&activeMatchIndex)); + + // Update UI or handle activeMatchIndex as you wish + // For example, you could show a message box + std::wstring activeMatchIndexStr = + L"Active Match Index: " + std::to_wstring(activeMatchIndex); + MessageBox(m_mainWindow, activeMatchIndexStr.c_str(), L"Find Operation", MB_OK); + + return true; + } + //! [GetActiveMatchIndex] + ``` + + ```csharp + //! [GetActiveMatchIndex] + public async Task GetActiveMatchIndexAsync() + { + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + var activeMatchIndex = await webViewFind.GetActiveMatchIndexAsync(); + MessageBox.Show($"Active Match Index: {activeMatchIndex}", "Find Operation", MessageBoxButton.OK); + return activeMatchIndex; + } + + //! [GetActiveMatchIndex] + ``` + + #### Handle Active Match Index Changes + ```cpp + void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2FindActiveMatchIndexChangedEventArgs* args) { // Handle active match index changes // Update UI to reflect the change in the active match index @@ -265,13 +264,13 @@ To navigate to the next match found during a find operation within a WebView2 co //! [FindNext] bool AppWindow::FindNext() { - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); - CHECK_FAILURE(webView2stagingfind->FindNext()); - CHECK_FAILURE(webView2stagingfind->remove_ActiveMatchIndexChanged( + CHECK_FAILURE(webView2find->FindNext()); + CHECK_FAILURE(webView2find->remove_ActiveMatchIndexChanged( m_ActiveMatchIndexChangedEventToken)); return true; @@ -283,13 +282,13 @@ bool AppWindow::FindNext() //! [FindNext] bool AppWindow::FindNext() { - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); - CHECK_FAILURE(webView2stagingfind->FindNext()); - CHECK_FAILURE(webView2stagingfind->remove_ActiveMatchIndexChanged( + CHECK_FAILURE(webView2find->FindNext()); + CHECK_FAILURE(webView2find->remove_ActiveMatchIndexChanged( m_ActiveMatchIndexChangedEventToken)); return true; @@ -307,12 +306,12 @@ To navigate to the previous match found during a find operation within a WebView //! [FindPrevious] bool AppWindow::FindPrevious() { - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); - CHECK_FAILURE(webView2stagingfind->FindPrevious()); + CHECK_FAILURE(webView2find->FindPrevious()); return true; } @@ -323,12 +322,12 @@ bool AppWindow::FindPrevious() //! [FindPrevious] bool AppWindow::FindPrevious() { - auto webView2staging17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging17); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging17->get_Find(&webView2stagingfind)); + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); - CHECK_FAILURE(webView2stagingfind->FindPrevious()); + CHECK_FAILURE(webView2find->FindPrevious()); return true; } @@ -455,99 +454,153 @@ interface ICoreWebView2Find : IUnknown { ``` -### Setting Up Find Configuration +### Setting Up Find Configuration with MIDL3 + +To represent the given C# examples in a manner consistent with the behavior demonstrated earlier in the chat and align them with an API design that could be described using MIDL3 (noted as C# for formatting), let's formalize the design for a hypothetical WebView2 Find operation API. This design will incorporate setting up a find configuration, starting a find operation, handling find operation events, and navigating through find matches. + +### CoreWebView2 Find Configuration and Direction ```csharp -public enum CoreWebView2FindDirection +namespace Microsoft.Web.WebView2.Core { - Forward, - Backward -} + public enum CoreWebView2FindDirection + { + Forward, + Backward + } -public class CoreWebView2FindConfiguration -{ - public string FindTerm { get; set; } - public CoreWebView2FindDirection FindDirection { get; set; } - public bool IsCaseSensitive { get; set; } - public bool ShouldMatchWord { get; set; } + public class CoreWebView2FindConfiguration + { + public string FindTerm { get; set; } + public CoreWebView2FindDirection FindDirection { get; set; } + public bool IsCaseSensitive { get; set; } + public bool ShouldMatchWord { get; set; } + } } ``` -### Starting a Find Operation +### CoreWebView2 Find Interface and Usage ```csharp -public interface ICoreWebView2StagingFind +namespace Microsoft.Web.WebView2.Core { - Task StartFindAsync(CoreWebView2FindConfiguration configuration); - void FindNext(); - void FindPrevious(); - void StopFind(); - bool ShouldHighlightAllMatches { get; set; } - bool ShouldHighlightActiveMatch { get; set; } - bool UseCustomUI { get; set; } - int ActiveMatchIndex { get; } - int MatchesCount { get; } - void PassHighlightSettings(); -} -// Usage example: -public async Task PerformFindOperation(ICoreWebView2StagingFind webViewFind) -{ - var findConfig = new CoreWebView2FindConfiguration + enum CoreWebView2FindDirection { - FindTerm = "example", - FindDirection = CoreWebView2FindDirection.Forward, - IsCaseSensitive = false, - ShouldMatchWord = true + Forward, + Backward, }; + + runtime CoreWebView2Find + { + [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2Find")] + { + void StartFindAsync(CoreWebView2FindConfiguration configuration); + void FindNextAsync(); + void FindPreviousAsync(); + void StopFindAsync(); + bool ShouldHighlightAllMatches { get; set; } + bool ShouldHighlightActiveMatch { get; set; } + bool UseCustomUI { get; set; } + int GetActiveMatchIndexAsync(); + int GetMatchesCountAsync(); + } + } + + runtimeclass CoreWebView2FindConfiguration { + [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2StagingFindConfiguration")] + { + String FindTerm { get; set; }; + CoreWebView2FindDirection FindDirection { get; set; }; + Boolean IsCaseSensitive { get; set; }; + Boolean ShouldMatchWord { get; set; }; + }; + } + - await webViewFind.StartFindAsync(findConfig); - webViewFind.FindNext(); - // Further operations... + + [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2Environment14")] + + { + CoreWebView2FindConfiguration CreateFindConfiguration(); + }; + + interface ICoreWebView2Environment14 + { + CoreWebView2FindConfiguration CreateFindConfiguration(); + }; + + + // Example usage: + public async Task PerformFindOperationAsync(ICoreWebView2Find webViewFind) + { + var findConfig = new CoreWebView2FindConfiguration + { + FindTerm = "example", + FindDirection = CoreWebView2FindDirection.Forward, + IsCaseSensitive = false, + ShouldMatchWord = true + }; + + await webViewFind.StartFindAsync(findConfig); + await webViewFind.FindNextAsync(); + // Additional operations... + } } ``` ### Handling Find Operation Events ```csharp -public interface ICoreWebView2StagingFindMatchCountChangedEventHandler +namespace Microsoft.Web.WebView2.Core { - void OnMatchCountChanged(ICoreWebView2StagingFind sender); -} - -public interface ICoreWebView2StagingFindActiveMatchIndexChangedEventHandler -{ - void OnActiveMatchIndexChanged(ICoreWebView2StagingFind sender); -} - -public interface ICoreWebView2StagingFindOperationCompletedHandler -{ - void OnFindOperationCompleted(ICoreWebView2StagingFind sender); -} -public void SubscribeToFindEvents(ICoreWebView2StagingFind webViewFind) -{ - webViewFind.MatchCountChanged += OnMatchCountChanged; - webViewFind.ActiveMatchIndexChanged += OnActiveMatchIndexChanged; - webViewFind.FindOperationCompleted += OnFindOperationCompleted; -} + public interface ICoreWebView2FindMatchCountChangedEventHandler + { + void OnMatchCountChanged(ICoreWebView2Find sender, int newCount); + } -private void OnMatchCountChanged(ICoreWebView2StagingFind sender) -{ - Console.WriteLine($"Match count changed. New count: {sender.MatchesCount}"); -} + public interface ICoreWebView2FindActiveMatchIndexChangedEventHandler + { + void OnActiveMatchIndexChanged(ICoreWebView2Find sender, int newIndex); + } -private void OnActiveMatchIndexChanged(ICoreWebView2StagingFind sender) -{ - Console.WriteLine($"Active match index changed. New index: {sender.ActiveMatchIndex}"); -} + public interface ICoreWebView2FindOperationCompletedHandler + { + void OnFindOperationCompleted(ICoreWebView2Find sender, bool isSuccess); + } -private void OnFindOperationCompleted(ICoreWebView2StagingFind sender) -{ - Console.WriteLine("Find operation completed."); + // Subscribing to events: + public class FindEventSubscriber + { + public void SubscribeToFindEvents(ICoreWebView2Find webViewFind) + { + webViewFind.MatchCountChanged += OnMatchCountChanged; + webViewFind.ActiveMatchIndexChanged += OnActiveMatchIndexChanged; + webViewFind.FindOperationCompleted += OnFindOperationCompleted; + } + + private void OnMatchCountChanged(ICoreWebView2Find sender, int newCount) + { + Console.WriteLine($"Match count changed. New count: {newCount}"); + } + + private void OnActiveMatchIndexChanged(ICoreWebView2Find sender, int newIndex) + { + Console.WriteLine($"Active match index changed. New index: {newIndex}"); + } + + private void OnFindOperationCompleted(ICoreWebView2Find sender, bool isSuccess) + { + var status = isSuccess ? "completed successfully" : "failed"; + Console.WriteLine($"Find operation {status}."); + } + } } ``` +These examples demonstrate how you might conceptualize and implement a Find API within the Microsoft WebView2 environment, focusing on async patterns for responsive UI interactions and event handling for dynamic UI updates based on the results of find operations. This design emphasizes asynchronous task-based APIs, event handling for UI updates, and modular API design for clear separation of concerns. + # Appendix This API specification focuses on providing developers with the necessary information to integrate text finding and navigation functionalities into WebView2 applications. From 9d9ef6d60acb766ab040c3ad315d31c04c185807 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 6 Mar 2024 20:22:52 -0800 Subject: [PATCH 12/80] Update FindOnPage.md consolidate examples --- FindOnPage.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index e190ec2c9..2d4da3beb 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -13,6 +13,8 @@ completed or not, whether the match count has changed, and whether the match ind #### Description To initiate a find operation within a WebView2 control, developers can utilize the `StartFindOnPage` method. This method allows specifying the find term and configuring other find parameters using the `ICoreWebView2FindConfiguration` interface. +When StartFind is called while a find session is currently active, it will navigate the active match index forwards or backwards depending +on the direction specified within the find configuration. #### Create/Specify a Find Configuration ```cpp @@ -301,7 +303,6 @@ bool AppWindow::FindNext() #### Description To navigate to the previous match found during a find operation within a WebView2 control, developers can use the `FindPrevious` method. - ```cpp //! [FindPrevious] bool AppWindow::FindPrevious() From 09c3bd8e9bb89502823852df13714c25928124d3 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 7 Mar 2024 10:32:52 -0800 Subject: [PATCH 13/80] Update FindOnPage.md --- FindOnPage.md | 130 ++++++++++++++++++++++++++++++++++++++++---------- 1 file changed, 106 insertions(+), 24 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 2d4da3beb..f54cd7136 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -13,33 +13,114 @@ completed or not, whether the match count has changed, and whether the match ind #### Description To initiate a find operation within a WebView2 control, developers can utilize the `StartFindOnPage` method. This method allows specifying the find term and configuring other find parameters using the `ICoreWebView2FindConfiguration` interface. -When StartFind is called while a find session is currently active, it will navigate the active match index forwards or backwards depending -on the direction specified within the find configuration. #### Create/Specify a Find Configuration ```cpp - bool AppWindow::ConfigureAndExecuteFind( - const std::wstring& searchTerm, - bool caseSensitive, - bool highlightAllMatches, - COREWEBVIEW2_FIND_DIRECTION direction) - { - // Query for the ICoreWebView2Environment5 interface. - auto webView2Environment5 = m_webViewEnvironment.try_query(); - CHECK_FEATURE_RETURN(webView2Environment5); - - // Create the find configuration. - wil::com_ptr findConfiguration; - CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); - - // Apply the find operation configurations. - CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); - CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(caseSensitive)); - CHECK_FAILURE(findConfiguration->put_ShouldHighlightAllMatches(highlightAllMatches)); - CHECK_FAILURE(findConfiguration->put_FindDirection(direction)); - - // Proceed to execute the find operation with the configured settings. - return ExecuteFindOperation(findConfiguration.get()); + //! [StartFindOnPage] +bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) +{ + // Query for the ICoreWebView2Environment5 interface. + auto webView2Environment5 = m_webViewEnvironment.try_query(); + CHECK_FEATURE_RETURN(webView2Environment5); + + // Initialize find configuration/settings + wil::com_ptr findConfiguration; + CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); + CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); + CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(false)); + CHECK_FAILURE(findConfiguration->put_ShouldMatchWord(false)); + CHECK_FAILURE(findConfiguration->put_FindDirection(COREWEBVIEW2_FIND_DIRECTION_FORWARD)); + + // Query for the ICoreWebView217 interface to access the Find feature. + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + + // Get the Find interface. + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); + + // Apply custom UI settings and highlight configurations. + CHECK_FAILURE(webView2find->put_UseCustomUI(false)); // Assuming you want to use the default UI, adjust as necessary. + CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); // This should match the passed parameter if dynamic. + + + + // Start the find operation + CHECK_FAILURE(webView2find->StartFind( + findConfiguration.get(), + Callback( + [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT + { + if (SUCCEEDED(result)) + { + // Handle successful find operation + // For example, you could update UI elements here + } + else + { + // Handle errors + } + return S_OK; + }) + .Get())); + CHECK_FAILURE(webView2find->FindNext()); + CHECK_FAILURE(webView2find->FindNext()); + CHECK_FAILURE(webView2find->FindPrevious()); + + return true; +} +//! [StartFindOnPage] + +//! [StopFind] +bool AppWindow::StopFind() +{ + auto webView2staging11 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging11); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); + + return true; +} +//! [StopFind] + +//! [GetMatchCount] +bool AppWindow::GetMatchCount() +{ + auto webView2staging11 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging11); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); + LONG matchCount; + CHECK_FAILURE(webView2stagingfind->get_MatchesCount(&matchCount)); + + // Update UI or handle matchCount as you wish + // For example, you could show a message box + std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); + MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); + + return true; +} +//! [GetMatchCount] + +//! [GetActiveMatchIndex] +bool AppWindow::GetActiveMatchIndex() +{ + auto webView2staging11 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging11); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); + LONG activeMatchIndex; + CHECK_FAILURE(webView2stagingfind->get_ActiveMatchIndex(&activeMatchIndex)); + + // Update UI or handle activeMatchIndex as you wish + // For example, you could show a message box + std::wstring activeMatchIndexStr = L"Active Match Index: " + std::to_wstring(activeMatchIndex); + MessageBox(m_mainWindow, activeMatchIndexStr.c_str(), L"Find Operation", MB_OK); + + return true; +} +//! [GetActiveMatchIndex] +#endif } ``` ```csharp @@ -303,6 +384,7 @@ bool AppWindow::FindNext() #### Description To navigate to the previous match found during a find operation within a WebView2 control, developers can use the `FindPrevious` method. + ```cpp //! [FindPrevious] bool AppWindow::FindPrevious() From 15050e24d7417f5224a41b210ea92598232549c5 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 7 Mar 2024 11:04:55 -0800 Subject: [PATCH 14/80] Update FindOnPage.md --- FindOnPage.md | 683 +++++++------------------------------------------- 1 file changed, 97 insertions(+), 586 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index f54cd7136..c96ed2c8a 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -1,29 +1,26 @@ +To improve the Markdown formatting of your document and ensure the C++ to C# conversion requests are clear, here's the reformatted version: + +--- + # WebView2Find API ## Background -The WebView2Find API provides methods and events to support text finding and navigation within a WebView2 control. -It allows developers to programmatically initiate find operations, navigate between find results, supress default UI, customize various find configurations -such as query, direction of search, match case, match word, etc. Also enables developers to track the status of ongoing operations such as whether a find session has -completed or not, whether the match count has changed, and whether the match index has changed. +The WebView2Find API enables developers to support text finding and navigation within a WebView2 control programmatically. This API allows for initiating find operations, navigating between find results, suppressing the default UI, and customizing various find configurations such as query, direction of search, match case, and match word. It also provides functionality to track the status of ongoing operations, including whether a find session has completed, whether the match count has changed, and whether the match index has changed. ## Examples +### Create/Specify a Find Configuration -#### Description -To initiate a find operation within a WebView2 control, developers can utilize the `StartFindOnPage` method. -This method allows specifying the find term and configuring other find parameters using the `ICoreWebView2FindConfiguration` interface. +#### C++ -#### Create/Specify a Find Configuration ```cpp - //! [StartFindOnPage] -bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) -{ +bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) { // Query for the ICoreWebView2Environment5 interface. auto webView2Environment5 = m_webViewEnvironment.try_query(); CHECK_FEATURE_RETURN(webView2Environment5); - // Initialize find configuration/settings + // Initialize find configuration/settings. wil::com_ptr findConfiguration; CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); @@ -40,652 +37,166 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) CHECK_FAILURE(webView217->get_Find(&webView2find)); // Apply custom UI settings and highlight configurations. - CHECK_FAILURE(webView2find->put_UseCustomUI(false)); // Assuming you want to use the default UI, adjust as necessary. - CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); // This should match the passed parameter if dynamic. - + CHECK_FAILURE(webView2find->put_UseCustomUI(false)); + CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); - - // Start the find operation - CHECK_FAILURE(webView2find->StartFind( + // Start the find operation. + HRESULT result = webView2find->StartFind( findConfiguration.get(), - Callback( - [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT - { - if (SUCCEEDED(result)) - { - // Handle successful find operation - // For example, you could update UI elements here - } - else - { - // Handle errors + Callback( + [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT { + if (SUCCEEDED(result)) { + // For example, update UI elements here. + } else { + // Handle errors. } return S_OK; - }) - .Get())); - CHECK_FAILURE(webView2find->FindNext()); + }).Get()); + + CHECK_FAILURE(result); CHECK_FAILURE(webView2find->FindNext()); CHECK_FAILURE(webView2find->FindPrevious()); return true; } -//! [StartFindOnPage] - -//! [StopFind] -bool AppWindow::StopFind() -{ - auto webView2staging11 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging11); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); +``` - return true; -} -//! [StopFind] - -//! [GetMatchCount] -bool AppWindow::GetMatchCount() -{ - auto webView2staging11 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging11); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); - LONG matchCount; - CHECK_FAILURE(webView2stagingfind->get_MatchesCount(&matchCount)); +#### C# - // Update UI or handle matchCount as you wish - // For example, you could show a message box - std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); - MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); +```csharp +public async Task ConfigureAndExecuteFindAsync(string searchTerm) { + var findConfiguration = new CoreWebView2FindConfiguration() { + FindTerm = searchTerm, + IsCaseSensitive = false, + ShouldMatchWord = false, + FindDirection = CoreWebView2FindDirection.Forward + }; - return true; -} -//! [GetMatchCount] - -//! [GetActiveMatchIndex] -bool AppWindow::GetActiveMatchIndex() -{ - auto webView2staging11 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging11); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); - LONG activeMatchIndex; - CHECK_FAILURE(webView2stagingfind->get_ActiveMatchIndex(&activeMatchIndex)); - - // Update UI or handle activeMatchIndex as you wish - // For example, you could show a message box - std::wstring activeMatchIndexStr = L"Active Match Index: " + std::to_wstring(activeMatchIndex); - MessageBox(m_mainWindow, activeMatchIndexStr.c_str(), L"Find Operation", MB_OK); + // Assume CoreWebView2 and CoreWebView2FindController have been appropriately implemented or wrapped. + var webViewFind = webView.CoreWebView2.FindController; + await webViewFind.StartFindAsync(findConfiguration); + await webViewFind.FindNextAsync(); + await webViewFind.FindPreviousAsync(); return true; } -//! [GetActiveMatchIndex] -#endif - } - ``` - ```csharp - public async Task ConfigureAndExecuteFindAsync( - string searchTerm, - bool caseSensitive, - bool highlightAllMatches, - CoreWebView2FindDirection direction) - { - var findConfiguration = new CoreWebView2FindConfiguration - { - FindTerm = searchTerm, - IsCaseSensitive = caseSensitive, - ShouldHighlightAllMatches = highlightAllMatches, - FindDirection = direction - }; - return await ExecuteFindOperationAsync(findConfiguration); - } - ``` - ### Start a Find Operation - - ```cpp - //! [StartFindOnPage] - bool AppWindow::ExecuteFindOperation(ICoreWebView2FindConfiguration* configuration) - { - // Query for the ICoreWebView217 interface to access the Find feature. - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - - // Get the Find interface. - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); - - // Apply custom UI settings and highlight configurations. - CHECK_FAILURE(webView2find->put_UseCustomUI(false)); // Assuming you want to use the default UI, adjust as necessary. - CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); // This should match the passed parameter if dynamic. - CHECK_FAILURE(webView2find->PassHighlightSettings()); - - // Start the find operation with the configured findConfiguration. - HRESULT result = webView2find->StartFind( - configuration, - Callback( - [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT - { - if (SUCCEEDED(result)) - { - // Handle successful find operation - // For example, updating UI elements to reflect the find results - } - else - { - // Handle errors appropriately - } - return S_OK; - }).Get()); - - return SUCCEEDED(result); - } - - //! [StartFindOnPage] - ``` - ```csharp - //! [StartFindOnPage] - public async Task ExecuteFindOperationAsync(CoreWebView2FindConfiguration configuration) - { - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - - // Assume CoreWebView2.FindController has been appropriately implemented or wrapped to expose async tasks. - // This example assumes such an implementation for illustration. - await webViewFind.StartFindAsync(configuration); - - // Optionally, handle completion or results with events or further async operations. - return true; - } - - //! [StartFindOnPage] - ``` - ### Stop an existing find operation - #### Description - To stop an ongoing find operation within a WebView2 control, developers can use the `StopFind` method of the `ICoreWebView2Find` interface. - ```cpp - //! [StopFind] - bool AppWindow::StopFind() - { - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); - CHECK_FAILURE(webView2find->StopFind()); - return true; - } - //! [StopFind] - ``` - ```csharp - //! [StopFind] - public void StopFindOperation() - { - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - webViewFind.StopFind(); - } - //! [StopFind] - ``` - - ### Retrieve the Number of Matches - - #### Description - To retrieve the total number of matches found during a find operation within a WebView2 control, developers can utilize the `GetMatchCount` method. - - - ```cpp - //! [GetMatchCount] - bool AppWindow::GetMatchCount() - { - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); - LONG matchCount; - CHECK_FAILURE(webView2find->get_MatchesCount(&matchCount)); - - // Update UI or handle matchCount as you wish - // For example, you could show a message box - std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); - MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); - - return true; - } - //! [GetMatchCount] - ``` - ```csharp - //! [GetMatchCount] - bool AppWindow::GetMatchCount() - public async Task GetMatchCountAsync() - { - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - var matchCount = await webViewFind.GetMatchesCountAsync(); - MessageBox.Show($"Match Count: {matchCount}", "Find Operation", MessageBoxButton.OK); - return matchCount; - } - //! [GetMatchCount] - ``` - #### Handle Match Count Changes - - ```cpp - void OnMatchCountChanged(LONG matchesCount) - { - // Handle match count changes - // Update UI elements or perform actions based on the new match count - } - ``` - - ```csharp - private void OnMatchCountChanged(object sender, EventArgs e) - { - // Assuming EventArgs or a derived type carries the new match count - MessageBox.Show($"Match count changed. New count: {e.MatchCount}", "Find Operation"); - } - ``` - ### Retrieve the Index of the Active Match - - #### Description - Developers can retrieve the index of the currently active match within a WebView2 control using the `GetActiveMatchIndex` method. - - - ```cpp - //! [GetActiveMatchIndex] - bool AppWindow::GetActiveMatchIndex() - { - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); - LONG activeMatchIndex; - CHECK_FAILURE(webView2find->get_ActiveMatchIndex(&activeMatchIndex)); - - // Update UI or handle activeMatchIndex as you wish - // For example, you could show a message box - std::wstring activeMatchIndexStr = - L"Active Match Index: " + std::to_wstring(activeMatchIndex); - MessageBox(m_mainWindow, activeMatchIndexStr.c_str(), L"Find Operation", MB_OK); - - return true; - } - //! [GetActiveMatchIndex] - ``` - - ```csharp - //! [GetActiveMatchIndex] - public async Task GetActiveMatchIndexAsync() - { - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - var activeMatchIndex = await webViewFind.GetActiveMatchIndexAsync(); - MessageBox.Show($"Active Match Index: {activeMatchIndex}", "Find Operation", MessageBoxButton.OK); - return activeMatchIndex; - } - - //! [GetActiveMatchIndex] - ``` - - #### Handle Active Match Index Changes - ```cpp - void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2FindActiveMatchIndexChangedEventArgs* args) -{ - // Handle active match index changes - // Update UI to reflect the change in the active match index -} -``` - -```csharp -private void OnActiveMatchIndexChanged(object sender, EventArgs e) -{ - // Assuming EventArgs or a derived type carries the new active match index - MessageBox.Show($"Active match index changed. New index: {e.ActiveMatchIndex}", "Find Operation"); -} ``` -### Navigate to the Next Match - -#### Description -To navigate to the next match found during a find operation within a WebView2 control, developers can use the `FindNext` method. +### Stop an Existing Find Operation +#### C++ ```cpp -//! [FindNext] -bool AppWindow::FindNext() -{ +bool AppWindow::StopFind() { auto webView217 = m_webView.try_query(); CHECK_FEATURE_RETURN(webView217); wil::com_ptr webView2find; CHECK_FAILURE(webView217->get_Find(&webView2find)); - CHECK_FAILURE(webView2find->FindNext()); - CHECK_FAILURE(webView2find->remove_ActiveMatchIndexChanged( - m_ActiveMatchIndexChangedEventToken)); - + CHECK_FAILURE(webView2find->StopFind()); return true; } -//! [FindNext] ``` -```csharp -//! [FindNext] -bool AppWindow::FindNext() -{ - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); - - CHECK_FAILURE(webView2find->FindNext()); - CHECK_FAILURE(webView2find->remove_ActiveMatchIndexChanged( - m_ActiveMatchIndexChangedEventToken)); +#### C# - return true; +```csharp +public void StopFindOperation() { + var webViewFind = webView.CoreWebView2.FindController; + webViewFind.StopFind(); } -//! [FindNext] ``` -### Navigate to the Previous Match - -#### Description -To navigate to the previous match found during a find operation within a WebView2 control, developers can use the `FindPrevious` method. +### Retrieve the Number of Matches +#### C++ ```cpp -//! [FindPrevious] -bool AppWindow::FindPrevious() -{ +bool AppWindow::GetMatchCount() { auto webView217 = m_webView.try_query(); CHECK_FEATURE_RETURN(webView217); wil::com_ptr webView2find; CHECK_FAILURE(webView217->get_Find(&webView2find)); + LONG matchCount; + CHECK_FAILURE(webView2find->get_MatchesCount(&matchCount)); - CHECK_FAILURE(webView2find->FindPrevious()); + // Update UI or handle matchCount as you wish. + std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); + MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); return true; } -//! [FindPrevious] ``` -```csharp -//! [FindPrevious] -bool AppWindow::FindPrevious() -{ - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); +#### C# - CHECK_FAILURE(webView2find->FindPrevious()); +```csharp +public async Task GetMatchCountAsync() { + var webViewFind = webView.CoreWebView2.FindController; + var matchCount = await webViewFind.GetMatchesCountAsync(); + MessageBox.Show($"Match Count: {matchCount - return true; +}", "Find Operation", MessageBoxButton.OK); + return matchCount; } -//! [FindPrevious] ``` -## API Details -```csharp - -/// Specifies the direction of find Parameters. -[v1_enum] -typedef enum COREWEBVIEW2_FIND_DIRECTION { - /// Specifies a forward find in the document. - COREWEBVIEW2_FIND_DIRECTION_FORWARD, - /// Specifies a backwards find in the document. - COREWEBVIEW2_FIND_DIRECTION_BACKWARD -} COREWEBVIEW2_FIND_DIRECTION; - -// Interface defining the find configuration. -[uuid(4A6ED732-DF08-4449-8949-3632A4DEBFCD), object, pointer_default(unique)] -interface ICoreWebView2FindConfiguration : IUnknown { - - // Gets or sets the find term used for the find operation. - [propget] HRESULT FindTerm([out, retval] LPWSTR* value); - [propput] HRESULT FindTerm([in] LPCWSTR value); - - // Gets or sets the direction of the find operation (forward or backward). - [propget] HRESULT FindDirection([out, retval] COREWEBVIEW2_FIND_DIRECTION* value); - [propput] HRESULT FindDirection([in] COREWEBVIEW2_FIND_DIRECTION value); - - // Gets or sets whether the find operation is case sensitive. - [propget] HRESULT IsCaseSensitive([out, retval] BOOL* value); - [propput] HRESULT IsCaseSensitive([in] BOOL value); - - // Gets or sets whether to only match whole words during the find operation. - [propget] HRESULT ShouldMatchWord([out, retval] BOOL* value); - [propput] HRESULT ShouldMatchWord([in] BOOL value); - - // Gets the state of whether all matches are highlighted. - // \return TRUE if all matches are highlighted, FALSE otherwise. - [propget] HRESULT ShouldHighlightAllMatches([out, retval] BOOL* value); - // Sets the state to either highlight all matches or not. - [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); - - // Checks if a custom user interface is desired by end developer. - // If TRUE, the default Find bar is not displayed. - // Returns TRUE if using a custom UI, FALSE if using the default. - [propget] HRESULT SuppressDefaultDialog([out, retval] BOOL* value); - // Sets whether to use a custom UI for the Find operation. - [propput] HRESULT SuppressDefaultDialog([in] BOOL value); - - // Gets the index of the currently active match. - // If there's no active find session but an attempt is made to get the active match index: - // The function will return -1. - // Returns The active match index. - [propget] HRESULT ActiveMatchIndex([out, retval] LONG* value); - - // Gets the total count of matches found in the current document based on the last find criteria. - // \return The total count of matches. - [propget] HRESULT MatchesCount([out, retval] LONG* value); - -} +### Navigate to the Next Match -/// Handles the event that's fired when the match count changes. -[uuid(623EFBFB-A19E-43C4-B309-D578511D24AB), object, pointer_default(unique)] -interface ICoreWebView2FindMatchCountChangedEventHandler : IUnknown { - /// Parameter is the match count. - HRESULT Invoke(LONG matchesCount); -} +#### C++ -/// Handles the event that's fired when the active match index changes. -[uuid(623EFBF9-A19E-43C4-B309-D578511D24A9), object, pointer_default(unique)] -interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { - /// Parameter is the active match index. - HRESULT Invoke(LONG activeMatchIndex); -} -/// Handles the event that's fired when the find operation completes. -[uuid(2604789D-9553-4246-8E21-B9C74EFAD04F), object, pointer_default(unique)] -interface ICoreWebView2FindOperationCompletedHandler : IUnknown { - /// Provides the event args when the find operation completes. - HRESULT Invoke(HRESULT errorCode, BOOL status); -} +```cpp +bool AppWindow::FindNext() { + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); -// Interface providing methods and properties for finding and navigating through text in the web view. -[uuid(7C49A8AA-2A17-4846-8207-21D1520AABC0), object, pointer_default(unique)] -interface ICoreWebView2Find : IUnknown { - - // Initiates a find using the specified configuration. - HRESULT StartFind([in] ICoreWebView2FindConfiguration* configuration, - ICoreWebView2FindOperationCompletedHandler* handler); - - // Navigates to the next match in the document. - HRESULT FindNext(); - - // Navigates to the previous match in the document. - HRESULT FindPrevious(); - - // Stops the current 'Find' operation and hides the Find bar. - HRESULT StopFind(); - - // Registers an event handler for the FindCompleted event. - // This event is raised when a find operation completes, either by finding all matches, navigating to a match, or by being stopped. - // Parameter is the event handler to be added. - // Returns a token representing the added event handler. This token can be used to unregister the event handler. - HRESULT add_MatchCountChanged( - [in] ICoreWebView2FindMatchCountChangedEventHandler* eventHandler, - [out] EventRegistrationToken* token); - // Unregisters an event handler from the MatchCountChanged event. - // Parameter is the token of the event handler to be removed, obtained during the registration of the event handler. - HRESULT remove_MatchCountChanged([in] EventRegistrationToken token); - - // Registers an event handler for the ActiveMatchIndexChanged event. - // This event is raised when the index of the currently active match changes. - // This can happen when the user navigates to a different match or when the active match is changed programmatically. - // Parameter is the event handler to be added. - // Returns a token representing the added event handler. This token can be used to unregister the event handler. - HRESULT add_ActiveMatchIndexChanged( - [in] ICoreWebView2FindActiveMatchIndexChangedEventHandler* eventHandler, - [out] EventRegistrationToken* token); - // Unregisters an event handler from the ActiveMatchIndexChanged event. - // parameter is the token of the event handler to be removed, obtained during the registration of the event handler. - HRESULT remove_ActiveMatchIndexChanged([in] EventRegistrationToken token); + CHECK_FAILURE(webView2find->FindNext()); + return true; } ``` - -### Setting Up Find Configuration with MIDL3 - -To represent the given C# examples in a manner consistent with the behavior demonstrated earlier in the chat and align them with an API design that could be described using MIDL3 (noted as C# for formatting), let's formalize the design for a hypothetical WebView2 Find operation API. This design will incorporate setting up a find configuration, starting a find operation, handling find operation events, and navigating through find matches. - -### CoreWebView2 Find Configuration and Direction +#### C# ```csharp -namespace Microsoft.Web.WebView2.Core -{ - public enum CoreWebView2FindDirection - { - Forward, - Backward - } - - public class CoreWebView2FindConfiguration - { - public string FindTerm { get; set; } - public CoreWebView2FindDirection FindDirection { get; set; } - public bool IsCaseSensitive { get; set; } - public bool ShouldMatchWord { get; set; } - } +public async Task FindNextAsync() { + var webViewFind = webView.CoreWebView2.FindController; + await webViewFind.FindNextAsync(); + return true; } ``` -### CoreWebView2 Find Interface and Usage - -```csharp -namespace Microsoft.Web.WebView2.Core -{ - - enum CoreWebView2FindDirection - { - Forward, - Backward, - }; - - runtime CoreWebView2Find - { - [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2Find")] - { - void StartFindAsync(CoreWebView2FindConfiguration configuration); - void FindNextAsync(); - void FindPreviousAsync(); - void StopFindAsync(); - bool ShouldHighlightAllMatches { get; set; } - bool ShouldHighlightActiveMatch { get; set; } - bool UseCustomUI { get; set; } - int GetActiveMatchIndexAsync(); - int GetMatchesCountAsync(); - } - } - - runtimeclass CoreWebView2FindConfiguration { - [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2StagingFindConfiguration")] - { - String FindTerm { get; set; }; - CoreWebView2FindDirection FindDirection { get; set; }; - Boolean IsCaseSensitive { get; set; }; - Boolean ShouldMatchWord { get; set; }; - }; - } - - - - [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2Environment14")] - - { - CoreWebView2FindConfiguration CreateFindConfiguration(); - }; +### Navigate to the Previous Match - interface ICoreWebView2Environment14 - { - CoreWebView2FindConfiguration CreateFindConfiguration(); - }; +#### C++ +```cpp +bool AppWindow::FindPrevious() { + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); - // Example usage: - public async Task PerformFindOperationAsync(ICoreWebView2Find webViewFind) - { - var findConfig = new CoreWebView2FindConfiguration - { - FindTerm = "example", - FindDirection = CoreWebView2FindDirection.Forward, - IsCaseSensitive = false, - ShouldMatchWord = true - }; - - await webViewFind.StartFindAsync(findConfig); - await webViewFind.FindNextAsync(); - // Additional operations... - } + CHECK_FAILURE(webView2find->FindPrevious()); + return true; } ``` -### Handling Find Operation Events +#### C# ```csharp -namespace Microsoft.Web.WebView2.Core -{ - - public interface ICoreWebView2FindMatchCountChangedEventHandler - { - void OnMatchCountChanged(ICoreWebView2Find sender, int newCount); - } - - public interface ICoreWebView2FindActiveMatchIndexChangedEventHandler - { - void OnActiveMatchIndexChanged(ICoreWebView2Find sender, int newIndex); - } - - public interface ICoreWebView2FindOperationCompletedHandler - { - void OnFindOperationCompleted(ICoreWebView2Find sender, bool isSuccess); - } - - // Subscribing to events: - public class FindEventSubscriber - { - public void SubscribeToFindEvents(ICoreWebView2Find webViewFind) - { - webViewFind.MatchCountChanged += OnMatchCountChanged; - webViewFind.ActiveMatchIndexChanged += OnActiveMatchIndexChanged; - webViewFind.FindOperationCompleted += OnFindOperationCompleted; - } - - private void OnMatchCountChanged(ICoreWebView2Find sender, int newCount) - { - Console.WriteLine($"Match count changed. New count: {newCount}"); - } - - private void OnActiveMatchIndexChanged(ICoreWebView2Find sender, int newIndex) - { - Console.WriteLine($"Active match index changed. New index: {newIndex}"); - } - - private void OnFindOperationCompleted(ICoreWebView2Find sender, bool isSuccess) - { - var status = isSuccess ? "completed successfully" : "failed"; - Console.WriteLine($"Find operation {status}."); - } - } +public async Task FindPreviousAsync() { + var webViewFind = webView.CoreWebView2.FindController; + await webViewFind.FindPreviousAsync(); + return true; } ``` -These examples demonstrate how you might conceptualize and implement a Find API within the Microsoft WebView2 environment, focusing on async patterns for responsive UI interactions and event handling for dynamic UI updates based on the results of find operations. This design emphasizes asynchronous task-based APIs, event handling for UI updates, and modular API design for clear separation of concerns. +## API Details + +The API details and event handling examples demonstrate how developers might interact with the WebView2Find API, managing find operations, configurations, and UI updates programmatically. The C# examples are designed to provide a basic understanding of how to implement these functionalities within a WebView2 control in a .NET environment, using asynchronous patterns for responsiveness and event subscription for dynamic updates. -# Appendix +## Appendix -This API specification focuses on providing developers with the necessary information to integrate text finding and navigation functionalities into WebView2 applications. -It emphasizes the usage of interfaces such as `ICoreWebView2Find` and `ICoreWebView2FindConfiguration` to perform find operations effectively. -For more detailed implementation notes and examples, developers can refer to the WebView2 documentation and sample code provided by Microsoft. +This API specification aims to equip developers with the tools needed to integrate text finding and navigation functionalities into WebView2 applications effectively. Developers are encouraged to refer to the official WebView2 documentation and sample code for detailed implementation notes and examples. From 121afee821c393d4922fe3e1bf60d7c4e5def41a Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 7 Mar 2024 14:47:30 -0800 Subject: [PATCH 15/80] Update FindOnPage.md --- FindOnPage.md | 656 ++++++++++++++++++++++++++++++++++++++++---------- 1 file changed, 532 insertions(+), 124 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index c96ed2c8a..75519ad8e 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -1,202 +1,610 @@ -To improve the Markdown formatting of your document and ensure the C++ to C# conversion requests are clear, here's the reformatted version: - ---- - # WebView2Find API ## Background -The WebView2Find API enables developers to support text finding and navigation within a WebView2 control programmatically. This API allows for initiating find operations, navigating between find results, suppressing the default UI, and customizing various find configurations such as query, direction of search, match case, and match word. It also provides functionality to track the status of ongoing operations, including whether a find session has completed, whether the match count has changed, and whether the match index has changed. +The WebView2Find API provides methods and events to support text finding and navigation within a WebView2 control. +It allows developers to programmatically initiate find operations, navigate between find results, supress default UI, customize various find configurations +such as query, direction of search, match case, match word, etc. Also enables developers to track the status of ongoing operations such as whether a find session has +completed or not, whether the match count has changed, and whether the match index has changed. ## Examples -### Create/Specify a Find Configuration -#### C++ +#### Description +To initiate a find operation within a WebView2 control, developers can utilize the `StartFindOnPage` method. +This method allows specifying the find term and configuring other find parameters using the `ICoreWebView2FindConfiguration` interface. +#### Create/Specify a Find Configuration ```cpp -bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) { - // Query for the ICoreWebView2Environment5 interface. - auto webView2Environment5 = m_webViewEnvironment.try_query(); - CHECK_FEATURE_RETURN(webView2Environment5); - - // Initialize find configuration/settings. - wil::com_ptr findConfiguration; - CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); - CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); - CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(false)); - CHECK_FAILURE(findConfiguration->put_ShouldMatchWord(false)); - CHECK_FAILURE(findConfiguration->put_FindDirection(COREWEBVIEW2_FIND_DIRECTION_FORWARD)); - - // Query for the ICoreWebView217 interface to access the Find feature. + bool AppWindow::ConfigureAndExecuteFind( + const std::wstring& searchTerm, + bool caseSensitive, + bool highlightAllMatches, + COREWEBVIEW2_FIND_DIRECTION direction) + { + // Query for the ICoreWebView2Environment5 interface. + auto webView2Environment5 = m_webViewEnvironment.try_query(); + CHECK_FEATURE_RETURN(webView2Environment5); + + // Create the find configuration. + wil::com_ptr findConfiguration; + CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); + + // Apply the find operation configurations. + CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); + CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(caseSensitive)); + CHECK_FAILURE(findConfiguration->put_ShouldHighlightAllMatches(highlightAllMatches)); + CHECK_FAILURE(findConfiguration->put_FindDirection(direction)); + + // Proceed to execute the find operation with the configured settings. + return ExecuteFindOperation(findConfiguration.get()); + } + ``` + ```csharp + public async Task ConfigureAndExecuteFindAsync( + string searchTerm, + bool caseSensitive, + bool highlightAllMatches, + CoreWebView2FindDirection direction) + { + var findConfiguration = new CoreWebView2FindConfiguration + { + FindTerm = searchTerm, + IsCaseSensitive = caseSensitive, + ShouldHighlightAllMatches = highlightAllMatches, + FindDirection = direction + }; + return await ExecuteFindOperationAsync(findConfiguration); + } + ``` + ### Start a Find Operation + + ```cpp + //! [StartFindOnPage] + bool AppWindow::ExecuteFindOperation(ICoreWebView2FindConfiguration* configuration) + { + // Query for the ICoreWebView217 interface to access the Find feature. + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + + // Get the Find interface. + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); + + // Apply custom UI settings and highlight configurations. + CHECK_FAILURE(webView2find->put_UseCustomUI(false)); // Assuming you want to use the default UI, adjust as necessary. + CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); // This should match the passed parameter if dynamic. + CHECK_FAILURE(webView2find->PassHighlightSettings()); + + // Start the find operation with the configured findConfiguration. + HRESULT result = webView2find->StartFind( + configuration, + Callback( + [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT + { + if (SUCCEEDED(result)) + { + // Handle successful find operation + // For example, updating UI elements to reflect the find results + } + else + { + // Handle errors appropriately + } + return S_OK; + }).Get()); + + return SUCCEEDED(result); + } + + //! [StartFindOnPage] + ``` + ```csharp + //! [StartFindOnPage] + public async Task ExecuteFindOperationAsync(CoreWebView2FindConfiguration configuration) + { + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + + // Assume CoreWebView2.FindController has been appropriately implemented or wrapped to expose async tasks. + // This example assumes such an implementation for illustration. + await webViewFind.StartFindAsync(configuration); + + // Optionally, handle completion or results with events or further async operations. + return true; + } + + //! [StartFindOnPage] + ``` + ### Stop an existing find operation + #### Description + To stop an ongoing find operation within a WebView2 control, developers can use the `StopFind` method of the `ICoreWebView2Find` interface. + ```cpp + //! [StopFind] + bool AppWindow::StopFind() + { + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); + CHECK_FAILURE(webView2find->StopFind()); + return true; + } + //! [StopFind] + ``` + ```csharp + //! [StopFind] + public void StopFindOperation() + { + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + webViewFind.StopFind(); + } + //! [StopFind] + ``` + + ### Retrieve the Number of Matches + + #### Description + To retrieve the total number of matches found during a find operation within a WebView2 control, developers can utilize the `GetMatchCount` method. + + + ```cpp + //! [GetMatchCount] + bool AppWindow::GetMatchCount() + { + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); + LONG matchCount; + CHECK_FAILURE(webView2find->get_MatchesCount(&matchCount)); + + // Update UI or handle matchCount as you wish + // For example, you could show a message box + std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); + MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); + + return true; + } + //! [GetMatchCount] + ``` + ```csharp + //! [GetMatchCount] + bool AppWindow::GetMatchCount() + public async Task GetMatchCountAsync() + { + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + var matchCount = await webViewFind.GetMatchesCountAsync(); + MessageBox.Show($"Match Count: {matchCount}", "Find Operation", MessageBoxButton.OK); + return matchCount; + } + //! [GetMatchCount] + ``` + #### Handle Match Count Changes + + ```cpp + void OnMatchCountChanged(LONG matchesCount) + { + // Handle match count changes + // Update UI elements or perform actions based on the new match count + } + ``` + + ```csharp + private void OnMatchCountChanged(object sender, EventArgs e) + { + // Assuming EventArgs or a derived type carries the new match count + MessageBox.Show($"Match count changed. New count: {e.MatchCount}", "Find Operation"); + } + ``` + ### Retrieve the Index of the Active Match + + #### Description + Developers can retrieve the index of the currently active match within a WebView2 control using the `GetActiveMatchIndex` method. + + + ```cpp + //! [GetActiveMatchIndex] + bool AppWindow::GetActiveMatchIndex() + { + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); + LONG activeMatchIndex; + CHECK_FAILURE(webView2find->get_ActiveMatchIndex(&activeMatchIndex)); + + // Update UI or handle activeMatchIndex as you wish + // For example, you could show a message box + std::wstring activeMatchIndexStr = + L"Active Match Index: " + std::to_wstring(activeMatchIndex); + MessageBox(m_mainWindow, activeMatchIndexStr.c_str(), L"Find Operation", MB_OK); + + return true; + } + //! [GetActiveMatchIndex] + ``` + + ```csharp + //! [GetActiveMatchIndex] + public async Task GetActiveMatchIndexAsync() + { + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + var activeMatchIndex = await webViewFind.GetActiveMatchIndexAsync(); + MessageBox.Show($"Active Match Index: {activeMatchIndex}", "Find Operation", MessageBoxButton.OK); + return activeMatchIndex; + } + + //! [GetActiveMatchIndex] + ``` + + #### Handle Active Match Index Changes + ```cpp + void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2FindActiveMatchIndexChangedEventArgs* args) +{ + // Handle active match index changes + // Update UI to reflect the change in the active match index +} +``` + +```csharp +private void OnActiveMatchIndexChanged(object sender, EventArgs e) +{ + // Assuming EventArgs or a derived type carries the new active match index + MessageBox.Show($"Active match index changed. New index: {e.ActiveMatchIndex}", "Find Operation"); +} +``` + +### Navigate to the Next Match + +#### Description +To navigate to the next match found during a find operation within a WebView2 control, developers can use the `FindNext` method. + + +```cpp +//! [FindNext] +bool AppWindow::FindNext() +{ auto webView217 = m_webView.try_query(); CHECK_FEATURE_RETURN(webView217); - - // Get the Find interface. wil::com_ptr webView2find; CHECK_FAILURE(webView217->get_Find(&webView2find)); - // Apply custom UI settings and highlight configurations. - CHECK_FAILURE(webView2find->put_UseCustomUI(false)); - CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); - - // Start the find operation. - HRESULT result = webView2find->StartFind( - findConfiguration.get(), - Callback( - [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT { - if (SUCCEEDED(result)) { - // For example, update UI elements here. - } else { - // Handle errors. - } - return S_OK; - }).Get()); - - CHECK_FAILURE(result); CHECK_FAILURE(webView2find->FindNext()); - CHECK_FAILURE(webView2find->FindPrevious()); + CHECK_FAILURE(webView2find->remove_ActiveMatchIndexChanged( + m_ActiveMatchIndexChangedEventToken)); return true; } +//! [FindNext] ``` -#### C# - ```csharp -public async Task ConfigureAndExecuteFindAsync(string searchTerm) { - var findConfiguration = new CoreWebView2FindConfiguration() { - FindTerm = searchTerm, - IsCaseSensitive = false, - ShouldMatchWord = false, - FindDirection = CoreWebView2FindDirection.Forward - }; +//! [FindNext] +bool AppWindow::FindNext() +{ + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); - // Assume CoreWebView2 and CoreWebView2FindController have been appropriately implemented or wrapped. - var webViewFind = webView.CoreWebView2.FindController; - await webViewFind.StartFindAsync(findConfiguration); - await webViewFind.FindNextAsync(); - await webViewFind.FindPreviousAsync(); + CHECK_FAILURE(webView2find->FindNext()); + CHECK_FAILURE(webView2find->remove_ActiveMatchIndexChanged( + m_ActiveMatchIndexChangedEventToken)); return true; } +//! [FindNext] ``` -### Stop an Existing Find Operation +### Navigate to the Previous Match + +#### Description +To navigate to the previous match found during a find operation within a WebView2 control, developers can use the `FindPrevious` method. -#### C++ ```cpp -bool AppWindow::StopFind() { +//! [FindPrevious] +bool AppWindow::FindPrevious() +{ auto webView217 = m_webView.try_query(); CHECK_FEATURE_RETURN(webView217); wil::com_ptr webView2find; CHECK_FAILURE(webView217->get_Find(&webView2find)); - CHECK_FAILURE(webView2find->StopFind()); + CHECK_FAILURE(webView2find->FindPrevious()); + return true; } +//! [FindPrevious] ``` -#### C# - ```csharp -public void StopFindOperation() { - var webViewFind = webView.CoreWebView2.FindController; - webViewFind.StopFind(); -} -``` - -### Retrieve the Number of Matches - -#### C++ - -```cpp -bool AppWindow::GetMatchCount() { +//! [FindPrevious] +bool AppWindow::FindPrevious() +{ auto webView217 = m_webView.try_query(); CHECK_FEATURE_RETURN(webView217); wil::com_ptr webView2find; CHECK_FAILURE(webView217->get_Find(&webView2find)); - LONG matchCount; - CHECK_FAILURE(webView2find->get_MatchesCount(&matchCount)); - // Update UI or handle matchCount as you wish. - std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); - MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); + CHECK_FAILURE(webView2find->FindPrevious()); return true; } +//! [FindPrevious] ``` -#### C# - +## API Details ```csharp -public async Task GetMatchCountAsync() { - var webViewFind = webView.CoreWebView2.FindController; - var matchCount = await webViewFind.GetMatchesCountAsync(); - MessageBox.Show($"Match Count: {matchCount -}", "Find Operation", MessageBoxButton.OK); - return matchCount; -} -``` +/// Specifies the direction of find Parameters. +[v1_enum] +typedef enum COREWEBVIEW2_FIND_DIRECTION { + /// Specifies a forward find in the document. + COREWEBVIEW2_FIND_DIRECTION_FORWARD, + /// Specifies a backwards find in the document. + COREWEBVIEW2_FIND_DIRECTION_BACKWARD +} COREWEBVIEW2_FIND_DIRECTION; + +// Interface defining the find configuration. +[uuid(4A6ED732-DF08-4449-8949-3632A4DEBFCD), object, pointer_default(unique)] +interface ICoreWebView2FindConfiguration : IUnknown { + + // Gets or sets the find term used for the find operation. + [propget] HRESULT FindTerm([out, retval] LPWSTR* value); + [propput] HRESULT FindTerm([in] LPCWSTR value); + + // Gets or sets the direction of the find operation (forward or backward). + [propget] HRESULT FindDirection([out, retval] COREWEBVIEW2_FIND_DIRECTION* value); + [propput] HRESULT FindDirection([in] COREWEBVIEW2_FIND_DIRECTION value); + + // Gets or sets whether the find operation is case sensitive. + [propget] HRESULT IsCaseSensitive([out, retval] BOOL* value); + [propput] HRESULT IsCaseSensitive([in] BOOL value); + + // Gets or sets whether to only match whole words during the find operation. + [propget] HRESULT ShouldMatchWord([out, retval] BOOL* value); + [propput] HRESULT ShouldMatchWord([in] BOOL value); + + // Gets the state of whether all matches are highlighted. + // \return TRUE if all matches are highlighted, FALSE otherwise. + [propget] HRESULT ShouldHighlightAllMatches([out, retval] BOOL* value); + // Sets the state to either highlight all matches or not. + [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); + + // Checks if a custom user interface is desired by end developer. + // If TRUE, the default Find bar is not displayed. + // Returns TRUE if using a custom UI, FALSE if using the default. + [propget] HRESULT SuppressDefaultDialog([out, retval] BOOL* value); + // Sets whether to use a custom UI for the Find operation. + [propput] HRESULT SuppressDefaultDialog([in] BOOL value); + + // Gets the index of the currently active match. + // If there's no active find session but an attempt is made to get the active match index: + // The function will return -1. + // Returns The active match index. + [propget] HRESULT ActiveMatchIndex([out, retval] LONG* value); + + // Gets the total count of matches found in the current document based on the last find criteria. + // \return The total count of matches. + [propget] HRESULT MatchesCount([out, retval] LONG* value); -### Navigate to the Next Match +} -#### C++ +/// Handles the event that's fired when the match count changes. +[uuid(623EFBFB-A19E-43C4-B309-D578511D24AB), object, pointer_default(unique)] +interface ICoreWebView2FindMatchCountChangedEventHandler : IUnknown { + /// Parameter is the match count. + HRESULT Invoke(LONG matchesCount); +} -```cpp -bool AppWindow::FindNext() { - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); +/// Handles the event that's fired when the active match index changes. +[uuid(623EFBF9-A19E-43C4-B309-D578511D24A9), object, pointer_default(unique)] +interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { + /// Parameter is the active match index. + HRESULT Invoke(LONG activeMatchIndex); +} +/// Handles the event that's fired when the find operation completes. +[uuid(2604789D-9553-4246-8E21-B9C74EFAD04F), object, pointer_default(unique)] +interface ICoreWebView2FindOperationCompletedHandler : IUnknown { + /// Provides the event args when the find operation completes. + HRESULT Invoke(HRESULT errorCode, BOOL status); +} - CHECK_FAILURE(webView2find->FindNext()); - return true; +// Interface providing methods and properties for finding and navigating through text in the web view. +[uuid(7C49A8AA-2A17-4846-8207-21D1520AABC0), object, pointer_default(unique)] +interface ICoreWebView2Find : IUnknown { + + // Initiates a find using the specified configuration. + HRESULT StartFind([in] ICoreWebView2FindConfiguration* configuration, + ICoreWebView2FindOperationCompletedHandler* handler); + + // Navigates to the next match in the document. + HRESULT FindNext(); + + // Navigates to the previous match in the document. + HRESULT FindPrevious(); + + // Stops the current 'Find' operation and hides the Find bar. + HRESULT StopFind(); + + // Registers an event handler for the FindCompleted event. + // This event is raised when a find operation completes, either by finding all matches, navigating to a match, or by being stopped. + // Parameter is the event handler to be added. + // Returns a token representing the added event handler. This token can be used to unregister the event handler. + HRESULT add_MatchCountChanged( + [in] ICoreWebView2FindMatchCountChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + // Unregisters an event handler from the MatchCountChanged event. + // Parameter is the token of the event handler to be removed, obtained during the registration of the event handler. + HRESULT remove_MatchCountChanged([in] EventRegistrationToken token); + + // Registers an event handler for the ActiveMatchIndexChanged event. + // This event is raised when the index of the currently active match changes. + // This can happen when the user navigates to a different match or when the active match is changed programmatically. + // Parameter is the event handler to be added. + // Returns a token representing the added event handler. This token can be used to unregister the event handler. + HRESULT add_ActiveMatchIndexChanged( + [in] ICoreWebView2FindActiveMatchIndexChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + // Unregisters an event handler from the ActiveMatchIndexChanged event. + // parameter is the token of the event handler to be removed, obtained during the registration of the event handler. + HRESULT remove_ActiveMatchIndexChanged([in] EventRegistrationToken token); } ``` -#### C# + +### Setting Up Find Configuration with MIDL3 + +To represent the given C# examples in a manner consistent with the behavior demonstrated earlier in the chat and align them with an API design that could be described using MIDL3 (noted as C# for formatting), let's formalize the design for a hypothetical WebView2 Find operation API. This design will incorporate setting up a find configuration, starting a find operation, handling find operation events, and navigating through find matches. + +### CoreWebView2 Find Configuration and Direction ```csharp -public async Task FindNextAsync() { - var webViewFind = webView.CoreWebView2.FindController; - await webViewFind.FindNextAsync(); - return true; +namespace Microsoft.Web.WebView2.Core +{ + public enum CoreWebView2FindDirection + { + Forward, + Backward + } + + public class CoreWebView2FindConfiguration + { + public string FindTerm { get; set; } + public CoreWebView2FindDirection FindDirection { get; set; } + public bool IsCaseSensitive { get; set; } + public bool ShouldMatchWord { get; set; } + } } ``` -### Navigate to the Previous Match +### CoreWebView2 Find Interface and Usage -#### C++ +```csharp +namespace Microsoft.Web.WebView2.Core +{ -```cpp -bool AppWindow::FindPrevious() { - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); + enum CoreWebView2FindDirection + { + Forward, + Backward, + }; - CHECK_FAILURE(webView2find->FindPrevious()); - return true; + runtime CoreWebView2Find + { + [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2Find")] + { + void StartFindAsync(CoreWebView2FindConfiguration configuration); + void FindNextAsync(); + void FindPreviousAsync(); + void StopFindAsync(); + bool ShouldHighlightAllMatches { get; set; } + bool ShouldHighlightActiveMatch { get; set; } + bool UseCustomUI { get; set; } + int GetActiveMatchIndexAsync(); + int GetMatchesCountAsync(); + } + } + + runtimeclass CoreWebView2FindConfiguration { + [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2StagingFindConfiguration")] + { + String FindTerm { get; set; }; + CoreWebView2FindDirection FindDirection { get; set; }; + Boolean IsCaseSensitive { get; set; }; + Boolean ShouldMatchWord { get; set; }; + }; + } + + + + [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2Environment14")] + + { + CoreWebView2FindConfiguration CreateFindConfiguration(); + }; + + interface ICoreWebView2Environment14 + { + CoreWebView2FindConfiguration CreateFindConfiguration(); + }; + + + // Example usage: + public async Task PerformFindOperationAsync(ICoreWebView2Find webViewFind) + { + var findConfig = new CoreWebView2FindConfiguration + { + FindTerm = "example", + FindDirection = CoreWebView2FindDirection.Forward, + IsCaseSensitive = false, + ShouldMatchWord = true + }; + + await webViewFind.StartFindAsync(findConfig); + await webViewFind.FindNextAsync(); + // Additional operations... + } } ``` -#### C# +### Handling Find Operation Events ```csharp -public async Task FindPreviousAsync() { - var webViewFind = webView.CoreWebView2.FindController; - await webViewFind.FindPreviousAsync(); - return true; +namespace Microsoft.Web.WebView2.Core +{ + + public interface ICoreWebView2FindMatchCountChangedEventHandler + { + void OnMatchCountChanged(ICoreWebView2Find sender, int newCount); + } + + public interface ICoreWebView2FindActiveMatchIndexChangedEventHandler + { + void OnActiveMatchIndexChanged(ICoreWebView2Find sender, int newIndex); + } + + public interface ICoreWebView2FindOperationCompletedHandler + { + void OnFindOperationCompleted(ICoreWebView2Find sender, bool isSuccess); + } + + // Subscribing to events: + public class FindEventSubscriber + { + public void SubscribeToFindEvents(ICoreWebView2Find webViewFind) + { + webViewFind.MatchCountChanged += OnMatchCountChanged; + webViewFind.ActiveMatchIndexChanged += OnActiveMatchIndexChanged; + webViewFind.FindOperationCompleted += OnFindOperationCompleted; + } + + private void OnMatchCountChanged(ICoreWebView2Find sender, int newCount) + { + Console.WriteLine($"Match count changed. New count: {newCount}"); + } + + private void OnActiveMatchIndexChanged(ICoreWebView2Find sender, int newIndex) + { + Console.WriteLine($"Active match index changed. New index: {newIndex}"); + } + + private void OnFindOperationCompleted(ICoreWebView2Find sender, bool isSuccess) + { + var status = isSuccess ? "completed successfully" : "failed"; + Console.WriteLine($"Find operation {status}."); + } + } } ``` -## API Details - -The API details and event handling examples demonstrate how developers might interact with the WebView2Find API, managing find operations, configurations, and UI updates programmatically. The C# examples are designed to provide a basic understanding of how to implement these functionalities within a WebView2 control in a .NET environment, using asynchronous patterns for responsiveness and event subscription for dynamic updates. +These examples demonstrate how you might conceptualize and implement a Find API within the Microsoft WebView2 environment, focusing on async patterns for responsive UI interactions and event handling for dynamic UI updates based on the results of find operations. This design emphasizes asynchronous task-based APIs, event handling for UI updates, and modular API design for clear separation of concerns. -## Appendix +# Appendix -This API specification aims to equip developers with the tools needed to integrate text finding and navigation functionalities into WebView2 applications effectively. Developers are encouraged to refer to the official WebView2 documentation and sample code for detailed implementation notes and examples. +This API specification focuses on providing developers with the necessary information to integrate text finding and navigation functionalities into WebView2 applications. +It emphasizes the usage of interfaces such as `ICoreWebView2Find` and `ICoreWebView2FindConfiguration` to perform find operations effectively. +Additional Info: +Starting a find session when one is in progress will result in the active match index being moved forward or backwards depending on what find configuration has been used +(forward,backward). From 83a0f0ce20ee377a4e7e9520b3d39fe6a7f858ff Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 7 Mar 2024 14:48:03 -0800 Subject: [PATCH 16/80] Update FindOnPage.md --- FindOnPage.md | 50 -------------------------------------------------- 1 file changed, 50 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 75519ad8e..6e5fb1943 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -549,56 +549,6 @@ namespace Microsoft.Web.WebView2.Core } ``` -### Handling Find Operation Events - -```csharp -namespace Microsoft.Web.WebView2.Core -{ - - public interface ICoreWebView2FindMatchCountChangedEventHandler - { - void OnMatchCountChanged(ICoreWebView2Find sender, int newCount); - } - - public interface ICoreWebView2FindActiveMatchIndexChangedEventHandler - { - void OnActiveMatchIndexChanged(ICoreWebView2Find sender, int newIndex); - } - - public interface ICoreWebView2FindOperationCompletedHandler - { - void OnFindOperationCompleted(ICoreWebView2Find sender, bool isSuccess); - } - - // Subscribing to events: - public class FindEventSubscriber - { - public void SubscribeToFindEvents(ICoreWebView2Find webViewFind) - { - webViewFind.MatchCountChanged += OnMatchCountChanged; - webViewFind.ActiveMatchIndexChanged += OnActiveMatchIndexChanged; - webViewFind.FindOperationCompleted += OnFindOperationCompleted; - } - - private void OnMatchCountChanged(ICoreWebView2Find sender, int newCount) - { - Console.WriteLine($"Match count changed. New count: {newCount}"); - } - - private void OnActiveMatchIndexChanged(ICoreWebView2Find sender, int newIndex) - { - Console.WriteLine($"Active match index changed. New index: {newIndex}"); - } - - private void OnFindOperationCompleted(ICoreWebView2Find sender, bool isSuccess) - { - var status = isSuccess ? "completed successfully" : "failed"; - Console.WriteLine($"Find operation {status}."); - } - } -} -``` - These examples demonstrate how you might conceptualize and implement a Find API within the Microsoft WebView2 environment, focusing on async patterns for responsive UI interactions and event handling for dynamic UI updates based on the results of find operations. This design emphasizes asynchronous task-based APIs, event handling for UI updates, and modular API design for clear separation of concerns. # Appendix From b1a63fb2b299ccfabe3afacc4f3c8f26298467d2 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 7 Mar 2024 19:37:42 -0800 Subject: [PATCH 17/80] Update FindOnPage.md --- FindOnPage.md | 149 +++++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 130 insertions(+), 19 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 6e5fb1943..90726f76b 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -16,6 +16,113 @@ This method allows specifying the find term and configuring other find parameter #### Create/Specify a Find Configuration ```cpp + + //! [ConfigureAndExecuteFind] +bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) +{ + // Query for the ICoreWebView2Environment5 interface. + auto webView2Environment5 = m_webViewEnvironment.try_query(); + CHECK_FEATURE_RETURN(webView2Environment5); + + // Initialize find configuration/settings + wil::com_ptr findConfiguration; + CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); + CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); + CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(false)); + CHECK_FAILURE(findConfiguration->put_ShouldMatchWord(false)); + CHECK_FAILURE(findConfiguration->put_FindDirection(COREWEBVIEW2_FIND_DIRECTION_FORWARD)); + + // Query for the ICoreWebView217 interface to access the Find feature. + auto webView217 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView217); + + // Get the Find interface. + wil::com_ptr webView2find; + CHECK_FAILURE(webView217->get_Find(&webView2find)); + + // Determine if custom UI will be usedsettings and highlight configurations. + + // Assuming you want to use the default UI, adjust as necessary. + CHECK_FAILURE(webView2find->put_UseCustomUI(false)); + CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); + + // Start the find operation + CHECK_FAILURE(webView2find->StartFind( + findConfiguration.get(), + Callback( + [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT + { + if (SUCCEEDED(result)) + { + // For example, you could update UI elements here + } + else + { + // Handle errors + } + return S_OK; + }) + .Get())); + CHECK_FAILURE(webView2find->FindNext()); + CHECK_FAILURE(webView2find->FindNext()); + CHECK_FAILURE(webView2find->FindPrevious()); + CHECK_FAILURE(webView2find->StopFind()); + + return true; +} +//! [ConfigureAndExecuteFind] + +//! [StopFind] +bool AppWindow::StopFind() +{ + auto webView2staging11 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging11); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); + + return true; +} +//! [StopFind] + +//! [GetMatchCount] +bool AppWindow::GetMatchCount() +{ + auto webView2staging11 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging11); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); + LONG matchCount; + CHECK_FAILURE(webView2stagingfind->get_MatchesCount(&matchCount)); + + // Update UI or handle matchCount as you wish + // For example, you could show a message box + std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); + MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); + + return true; +} +//! [GetMatchCount] + +//! [GetActiveMatchIndex] +bool AppWindow::GetActiveMatchIndex() +{ + auto webView2staging11 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2staging11); + wil::com_ptr webView2stagingfind; + CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); + LONG activeMatchIndex; + CHECK_FAILURE(webView2stagingfind->get_ActiveMatchIndex(&activeMatchIndex)); + + // Update UI or handle activeMatchIndex as you wish + // For example, you could show a message box + std::wstring activeMatchIndexStr = L"Active Match Index: " + std::to_wstring(activeMatchIndex); + MessageBox(m_mainWindow, activeMatchIndexStr.c_str(), L"Find Operation", MB_OK); + + return true; +} +//! [GetActiveMatchIndex] +#endif + bool AppWindow::ConfigureAndExecuteFind( const std::wstring& searchTerm, bool caseSensitive, @@ -39,8 +146,9 @@ This method allows specifying the find term and configuring other find parameter // Proceed to execute the find operation with the configured settings. return ExecuteFindOperation(findConfiguration.get()); } - ``` - ```csharp +``` + +```csharp public async Task ConfigureAndExecuteFindAsync( string searchTerm, bool caseSensitive, @@ -56,10 +164,10 @@ This method allows specifying the find term and configuring other find parameter }; return await ExecuteFindOperationAsync(findConfiguration); } - ``` - ### Start a Find Operation +``` +### Start a Find Operation - ```cpp +```cpp //! [StartFindOnPage] bool AppWindow::ExecuteFindOperation(ICoreWebView2FindConfiguration* configuration) { @@ -98,8 +206,9 @@ This method allows specifying the find term and configuring other find parameter } //! [StartFindOnPage] - ``` - ```csharp +``` + +```csharp //! [StartFindOnPage] public async Task ExecuteFindOperationAsync(CoreWebView2FindConfiguration configuration) { @@ -114,11 +223,11 @@ This method allows specifying the find term and configuring other find parameter } //! [StartFindOnPage] - ``` - ### Stop an existing find operation - #### Description - To stop an ongoing find operation within a WebView2 control, developers can use the `StopFind` method of the `ICoreWebView2Find` interface. - ```cpp +``` +### Stop an existing find operation +#### Description +To stop an ongoing find operation within a WebView2 control, developers can use the `StopFind` method of the `ICoreWebView2Find` interface. +```cpp //! [StopFind] bool AppWindow::StopFind() { @@ -130,8 +239,9 @@ This method allows specifying the find term and configuring other find parameter return true; } //! [StopFind] - ``` - ```csharp +``` + +```csharp //! [StopFind] public void StopFindOperation() { @@ -139,7 +249,7 @@ This method allows specifying the find term and configuring other find parameter webViewFind.StopFind(); } //! [StopFind] - ``` +``` ### Retrieve the Number of Matches @@ -147,7 +257,7 @@ This method allows specifying the find term and configuring other find parameter To retrieve the total number of matches found during a find operation within a WebView2 control, developers can utilize the `GetMatchCount` method. - ```cpp +```cpp //! [GetMatchCount] bool AppWindow::GetMatchCount() { @@ -166,8 +276,9 @@ This method allows specifying the find term and configuring other find parameter return true; } //! [GetMatchCount] - ``` - ```csharp +``` + +```csharp //! [GetMatchCount] bool AppWindow::GetMatchCount() public async Task GetMatchCountAsync() @@ -178,7 +289,7 @@ This method allows specifying the find term and configuring other find parameter return matchCount; } //! [GetMatchCount] - ``` +``` #### Handle Match Count Changes ```cpp From af525b66a0e049e37e4f4592f5d85c7acde2bd5f Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 7 Mar 2024 19:42:19 -0800 Subject: [PATCH 18/80] Update FindOnPage.md --- FindOnPage.md | 48 +++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 47 insertions(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 90726f76b..82ece66aa 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -17,7 +17,7 @@ This method allows specifying the find term and configuring other find parameter #### Create/Specify a Find Configuration ```cpp - //! [ConfigureAndExecuteFind] +//! [ConfigureAndExecuteFind] bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) { // Query for the ICoreWebView2Environment5 interface. @@ -71,6 +71,52 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) return true; } //! [ConfigureAndExecuteFind] +``` +```csharp +//! [ConfigureAndExecuteFind] +public async Task ConfigureAndExecuteFindAsync(string searchTerm) + { + try + { + // Assuming 'webView' is already initialized and is an instance of CoreWebView2 + + // Initialize find configuration/settings + var findConfiguration = new CoreWebView2FindConfiguration + { + FindTerm = searchTerm, + IsCaseSensitive = false, + ShouldMatchWord = false, + FindDirection = CoreWebView2FindDirection.Forward + }; + + // Use the FindController to start the find operation + var findController = webView.FindController; + + // Assuming you want to use the default UI, adjust as necessary + findController.UseCustomUI = false; + findController.ShouldHighlightAllMatches = true; + + // Start the find operation + await findController.StartFindAsync(findConfiguration); + + // Perform FindNext operations + await findController.FindNextAsync(); + await findController.FindNextAsync(); + await findController.FindPreviousAsync(); + findController.StopFind(); + + return true; + } + catch (Exception ex) + { + // Handle errors + Console.WriteLine($"An error occurred: {ex.Message}"); + return false; + } + } +} +//! [ConfigureAndExecuteFind] +``` //! [StopFind] bool AppWindow::StopFind() From 52ba7d4f2bec4afe75c021f7223b200e7419dc55 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 7 Mar 2024 20:32:31 -0800 Subject: [PATCH 19/80] Update FindOnPage.md --- FindOnPage.md | 245 +++----------------------------------------------- 1 file changed, 13 insertions(+), 232 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 82ece66aa..a43b8327e 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -74,14 +74,13 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) ``` ```csharp //! [ConfigureAndExecuteFind] -public async Task ConfigureAndExecuteFindAsync(string searchTerm) - { +async void ConfigureAndExecuteFindAsync(string searchTerm){ try { // Assuming 'webView' is already initialized and is an instance of CoreWebView2 // Initialize find configuration/settings - var findConfiguration = new CoreWebView2FindConfiguration + CoreWebView2FindConfinguration findConfiguration = new CoreWebView2FindConfiguration { FindTerm = searchTerm, IsCaseSensitive = false, @@ -90,20 +89,20 @@ public async Task ConfigureAndExecuteFindAsync(string searchTerm) }; // Use the FindController to start the find operation - var findController = webView.FindController; + CoreWebView2Find find = new CoreWebView2Find(findConfiguration); // Assuming you want to use the default UI, adjust as necessary - findController.UseCustomUI = false; - findController.ShouldHighlightAllMatches = true; + find.UseCustomUI = false; + find.ShouldHighlightAllMatches = true; // Start the find operation - await findController.StartFindAsync(findConfiguration); + await find.StartFindAsync(findConfiguration); // Perform FindNext operations - await findController.FindNextAsync(); - await findController.FindNextAsync(); - await findController.FindPreviousAsync(); - findController.StopFind(); + await find.FindNextAsync(); + await find.FindNextAsync(); + await find.FindPreviousAsync(); + find.StopFind(); return true; } @@ -113,22 +112,10 @@ public async Task ConfigureAndExecuteFindAsync(string searchTerm) Console.WriteLine($"An error occurred: {ex.Message}"); return false; } - } } //! [ConfigureAndExecuteFind] ``` -//! [StopFind] -bool AppWindow::StopFind() -{ - auto webView2staging11 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging11); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); - - return true; -} -//! [StopFind] //! [GetMatchCount] bool AppWindow::GetMatchCount() @@ -167,140 +154,12 @@ bool AppWindow::GetActiveMatchIndex() return true; } //! [GetActiveMatchIndex] -#endif - - bool AppWindow::ConfigureAndExecuteFind( - const std::wstring& searchTerm, - bool caseSensitive, - bool highlightAllMatches, - COREWEBVIEW2_FIND_DIRECTION direction) - { - // Query for the ICoreWebView2Environment5 interface. - auto webView2Environment5 = m_webViewEnvironment.try_query(); - CHECK_FEATURE_RETURN(webView2Environment5); - - // Create the find configuration. - wil::com_ptr findConfiguration; - CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); - - // Apply the find operation configurations. - CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); - CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(caseSensitive)); - CHECK_FAILURE(findConfiguration->put_ShouldHighlightAllMatches(highlightAllMatches)); - CHECK_FAILURE(findConfiguration->put_FindDirection(direction)); - - // Proceed to execute the find operation with the configured settings. - return ExecuteFindOperation(findConfiguration.get()); - } -``` - -```csharp - public async Task ConfigureAndExecuteFindAsync( - string searchTerm, - bool caseSensitive, - bool highlightAllMatches, - CoreWebView2FindDirection direction) - { - var findConfiguration = new CoreWebView2FindConfiguration - { - FindTerm = searchTerm, - IsCaseSensitive = caseSensitive, - ShouldHighlightAllMatches = highlightAllMatches, - FindDirection = direction - }; - return await ExecuteFindOperationAsync(findConfiguration); - } -``` -### Start a Find Operation - -```cpp - //! [StartFindOnPage] - bool AppWindow::ExecuteFindOperation(ICoreWebView2FindConfiguration* configuration) - { - // Query for the ICoreWebView217 interface to access the Find feature. - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - - // Get the Find interface. - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); - - // Apply custom UI settings and highlight configurations. - CHECK_FAILURE(webView2find->put_UseCustomUI(false)); // Assuming you want to use the default UI, adjust as necessary. - CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); // This should match the passed parameter if dynamic. - CHECK_FAILURE(webView2find->PassHighlightSettings()); - - // Start the find operation with the configured findConfiguration. - HRESULT result = webView2find->StartFind( - configuration, - Callback( - [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT - { - if (SUCCEEDED(result)) - { - // Handle successful find operation - // For example, updating UI elements to reflect the find results - } - else - { - // Handle errors appropriately - } - return S_OK; - }).Get()); - - return SUCCEEDED(result); - } - - //! [StartFindOnPage] ``` - -```csharp - //! [StartFindOnPage] - public async Task ExecuteFindOperationAsync(CoreWebView2FindConfiguration configuration) - { - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - - // Assume CoreWebView2.FindController has been appropriately implemented or wrapped to expose async tasks. - // This example assumes such an implementation for illustration. - await webViewFind.StartFindAsync(configuration); + +### Retrieve the Number of Matches - // Optionally, handle completion or results with events or further async operations. - return true; - } - - //! [StartFindOnPage] -``` -### Stop an existing find operation #### Description -To stop an ongoing find operation within a WebView2 control, developers can use the `StopFind` method of the `ICoreWebView2Find` interface. -```cpp - //! [StopFind] - bool AppWindow::StopFind() - { - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); - CHECK_FAILURE(webView2find->StopFind()); - return true; - } - //! [StopFind] -``` - -```csharp - //! [StopFind] - public void StopFindOperation() - { - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - webViewFind.StopFind(); - } - //! [StopFind] -``` - - ### Retrieve the Number of Matches - - #### Description - To retrieve the total number of matches found during a find operation within a WebView2 control, developers can utilize the `GetMatchCount` method. +To retrieve the total number of matches found during a find operation within a WebView2 control, developers can utilize the `GetMatchCount` method. ```cpp @@ -411,85 +270,7 @@ private void OnActiveMatchIndexChanged(object sender, EventArgs e) } ``` -### Navigate to the Next Match - -#### Description -To navigate to the next match found during a find operation within a WebView2 control, developers can use the `FindNext` method. - - -```cpp -//! [FindNext] -bool AppWindow::FindNext() -{ - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); - - CHECK_FAILURE(webView2find->FindNext()); - CHECK_FAILURE(webView2find->remove_ActiveMatchIndexChanged( - m_ActiveMatchIndexChangedEventToken)); - return true; -} -//! [FindNext] -``` - -```csharp -//! [FindNext] -bool AppWindow::FindNext() -{ - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); - - CHECK_FAILURE(webView2find->FindNext()); - CHECK_FAILURE(webView2find->remove_ActiveMatchIndexChanged( - m_ActiveMatchIndexChangedEventToken)); - - return true; -} -//! [FindNext] -``` - -### Navigate to the Previous Match - -#### Description -To navigate to the previous match found during a find operation within a WebView2 control, developers can use the `FindPrevious` method. - - -```cpp -//! [FindPrevious] -bool AppWindow::FindPrevious() -{ - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); - - CHECK_FAILURE(webView2find->FindPrevious()); - - return true; -} -//! [FindPrevious] -``` - -```csharp -//! [FindPrevious] -bool AppWindow::FindPrevious() -{ - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); - wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); - - CHECK_FAILURE(webView2find->FindPrevious()); - - return true; -} -//! [FindPrevious] -``` ## API Details ```csharp From e6c89057dd0adbfabd751bef6d9fa77a2814e8bc Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 7 Mar 2024 21:18:27 -0800 Subject: [PATCH 20/80] Update FindOnPage.md --- FindOnPage.md | 143 ++++++++++++++++++++------------------------------ 1 file changed, 58 insertions(+), 85 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index a43b8327e..bf317b23f 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -115,46 +115,6 @@ async void ConfigureAndExecuteFindAsync(string searchTerm){ } //! [ConfigureAndExecuteFind] ``` - - -//! [GetMatchCount] -bool AppWindow::GetMatchCount() -{ - auto webView2staging11 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging11); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); - LONG matchCount; - CHECK_FAILURE(webView2stagingfind->get_MatchesCount(&matchCount)); - - // Update UI or handle matchCount as you wish - // For example, you could show a message box - std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); - MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); - - return true; -} -//! [GetMatchCount] - -//! [GetActiveMatchIndex] -bool AppWindow::GetActiveMatchIndex() -{ - auto webView2staging11 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2staging11); - wil::com_ptr webView2stagingfind; - CHECK_FAILURE(webView2staging11->get_Find(&webView2stagingfind)); - LONG activeMatchIndex; - CHECK_FAILURE(webView2stagingfind->get_ActiveMatchIndex(&activeMatchIndex)); - - // Update UI or handle activeMatchIndex as you wish - // For example, you could show a message box - std::wstring activeMatchIndexStr = L"Active Match Index: " + std::to_wstring(activeMatchIndex); - MessageBox(m_mainWindow, activeMatchIndexStr.c_str(), L"Find Operation", MB_OK); - - return true; -} -//! [GetActiveMatchIndex] -``` ### Retrieve the Number of Matches @@ -185,7 +145,6 @@ To retrieve the total number of matches found during a find operation within a W ```csharp //! [GetMatchCount] - bool AppWindow::GetMatchCount() public async Task GetMatchCountAsync() { var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control @@ -195,30 +154,61 @@ To retrieve the total number of matches found during a find operation within a W } //! [GetMatchCount] ``` - #### Handle Match Count Changes +#### Handle Match Count Changes - ```cpp - void OnMatchCountChanged(LONG matchesCount) +```cpp +// Register MatchCountChanged event handler + m_webView->add_MatchCountChanged( + Callback( + [this](LONG matchCount) -> HRESULT + { + // Update custom UI + wprintf(L"Match Count Changed: %ld\n", matchCount); + return S_OK; + }).Get(), + &m_matchCountChangedToken); +``` + +```csharp +void MatchCountChangedSample() +{ + _webview.MatchCountChanged += (object sender, CoreWebView2MatchCountChangedEventArgs args) => { - // Handle match count changes - // Update UI elements or perform actions based on the new match count - } - ``` - - ```csharp - private void OnMatchCountChanged(object sender, EventArgs e) + // Update Custom UI + }; +} +``` +#### Handle Match Index Changes + +```cpp +// Register ActiveMatchIndexChanged event handler +m_webView->add_ActiveMatchIndexChanged( + Callback( + [this](LONG activeMatchIndex) -> HRESULT + { + // Update custom UI + wprintf(L"Active Match Index Changed: %ld\n", activeMatchIndex); + return S_OK; + }).Get(), + &m_activeMatchIndexChangedToken); +``` + +```csharp +void ActiveMatchIndexChangedSample() +{ + _webview.MatchCountChanged += (object sender, CoreWebView2ActiveMatchIndexChangedEventArgs args) => { - // Assuming EventArgs or a derived type carries the new match count - MessageBox.Show($"Match count changed. New count: {e.MatchCount}", "Find Operation"); - } - ``` - ### Retrieve the Index of the Active Match + // Update Custom UI + }; +} +``` +### Retrieve the Index of the Active Match - #### Description - Developers can retrieve the index of the currently active match within a WebView2 control using the `GetActiveMatchIndex` method. +#### Description +Developers can retrieve the index of the currently active match within a WebView2 control using the `GetActiveMatchIndex` method. - ```cpp +```cpp //! [GetActiveMatchIndex] bool AppWindow::GetActiveMatchIndex() { @@ -238,36 +228,19 @@ To retrieve the total number of matches found during a find operation within a W return true; } //! [GetActiveMatchIndex] - ``` - - ```csharp - //! [GetActiveMatchIndex] - public async Task GetActiveMatchIndexAsync() - { - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - var activeMatchIndex = await webViewFind.GetActiveMatchIndexAsync(); - MessageBox.Show($"Active Match Index: {activeMatchIndex}", "Find Operation", MessageBoxButton.OK); - return activeMatchIndex; - } - - //! [GetActiveMatchIndex] - ``` - - #### Handle Active Match Index Changes - ```cpp - void OnActiveMatchIndexChanged(ICoreWebView2* sender, ICoreWebView2FindActiveMatchIndexChangedEventArgs* args) -{ - // Handle active match index changes - // Update UI to reflect the change in the active match index -} ``` - + ```csharp -private void OnActiveMatchIndexChanged(object sender, EventArgs e) +//! [GetActiveMatchIndex] +public async Task GetActiveMatchIndexAsync() { - // Assuming EventArgs or a derived type carries the new active match index - MessageBox.Show($"Active match index changed. New index: {e.ActiveMatchIndex}", "Find Operation"); + var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + var activeMatchIndex = await webViewFind.GetActiveMatchIndexAsync(); + MessageBox.Show($"Active Match Index: {activeMatchIndex}", "Find Operation", MessageBoxButton.OK); + return activeMatchIndex; } + +//! [GetActiveMatchIndex] ``` From 42b3cdd89e4bc220761b8374a813b28eb45e5810 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 8 Mar 2024 09:50:54 -0800 Subject: [PATCH 21/80] Update FindOnPage.md --- FindOnPage.md | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index bf317b23f..666270b6c 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -154,8 +154,7 @@ To retrieve the total number of matches found during a find operation within a W } //! [GetMatchCount] ``` -#### Handle Match Count Changes - +#### WIN32 C++ ```cpp // Register MatchCountChanged event handler m_webView->add_MatchCountChanged( @@ -168,7 +167,7 @@ To retrieve the total number of matches found during a find operation within a W }).Get(), &m_matchCountChangedToken); ``` - +#### .NET C# ```csharp void MatchCountChangedSample() { @@ -179,6 +178,7 @@ void MatchCountChangedSample() } ``` #### Handle Match Index Changes +#### WIN32 C++ ```cpp // Register ActiveMatchIndexChanged event handler @@ -192,7 +192,7 @@ m_webView->add_ActiveMatchIndexChanged( }).Get(), &m_activeMatchIndexChangedToken); ``` - +#### .NET C# ```csharp void ActiveMatchIndexChangedSample() { @@ -229,7 +229,7 @@ Developers can retrieve the index of the currently active match within a WebView } //! [GetActiveMatchIndex] ``` - +#### .NET C# ```csharp //! [GetActiveMatchIndex] public async Task GetActiveMatchIndexAsync() @@ -460,7 +460,8 @@ namespace Microsoft.Web.WebView2.Core } ``` -These examples demonstrate how you might conceptualize and implement a Find API within the Microsoft WebView2 environment, focusing on async patterns for responsive UI interactions and event handling for dynamic UI updates based on the results of find operations. This design emphasizes asynchronous task-based APIs, event handling for UI updates, and modular API design for clear separation of concerns. +These examples demonstrate how you would conceptualize and implement the Find API within the Microsoft WebView2 environment, focusing on async patterns for responsive UI interactions and event handling for dynamic UI updates based on the results of find operations. +This design emphasizes asynchronous task-based APIs, event handling for UI updates, and modular API design for clear separation of concerns. # Appendix From f0b9e322eb40af68eb53cf64e1d3aa50588afd17 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 8 Mar 2024 09:52:25 -0800 Subject: [PATCH 22/80] Update FindOnPage.md --- FindOnPage.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 666270b6c..b338a74e2 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -455,7 +455,8 @@ namespace Microsoft.Web.WebView2.Core await webViewFind.StartFindAsync(findConfig); await webViewFind.FindNextAsync(); - // Additional operations... + await webViewFind.FindNextAsync(); + await webViewFind.StopFindAsync(); } } ``` From 2320ee1d20b064de1ec3e3ba45284d5be352238a Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 8 Mar 2024 09:59:33 -0800 Subject: [PATCH 23/80] Update FindOnPage.md --- FindOnPage.md | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index b338a74e2..ee0866d2f 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -88,7 +88,6 @@ async void ConfigureAndExecuteFindAsync(string searchTerm){ FindDirection = CoreWebView2FindDirection.Forward }; - // Use the FindController to start the find operation CoreWebView2Find find = new CoreWebView2Find(findConfiguration); // Assuming you want to use the default UI, adjust as necessary @@ -102,7 +101,9 @@ async void ConfigureAndExecuteFindAsync(string searchTerm){ await find.FindNextAsync(); await find.FindNextAsync(); await find.FindPreviousAsync(); - find.StopFind(); + + // Stop the active find session + await find.StopFindAsync(); return true; } From 5e54814aa3461b9fc161ab044d82ade093fb0bf8 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 8 Mar 2024 10:12:28 -0800 Subject: [PATCH 24/80] Update FindOnPage.md --- FindOnPage.md | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index ee0866d2f..672b0d6b5 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -11,8 +11,12 @@ completed or not, whether the match count has changed, and whether the match ind #### Description -To initiate a find operation within a WebView2 control, developers can utilize the `StartFindOnPage` method. +To initiate a find operation within a WebView2 control, developers can utilize the `StartFind` method. This method allows specifying the find term and configuring other find parameters using the `ICoreWebView2FindConfiguration` interface. +Additionally there can only be one find session active per webview environment. +If an attempt is made to call start find more than once with the same findconfugration, +it will result in the active match index either being increased or decreased depending on what +Find Direction parameter was chosen for the Find Configuration. #### Create/Specify a Find Configuration ```cpp From 151f501b706ed9e941c35e4adfb6af65280a84b6 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 20 Mar 2024 12:12:33 -0700 Subject: [PATCH 25/80] Update FindOnPage.md Removed \return syntax --- FindOnPage.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 672b0d6b5..8bfe6e58f 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -283,7 +283,7 @@ interface ICoreWebView2FindConfiguration : IUnknown { [propput] HRESULT ShouldMatchWord([in] BOOL value); // Gets the state of whether all matches are highlighted. - // \return TRUE if all matches are highlighted, FALSE otherwise. + // Returns TRUE if all matches are highlighted, FALSE otherwise. [propget] HRESULT ShouldHighlightAllMatches([out, retval] BOOL* value); // Sets the state to either highlight all matches or not. [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); @@ -302,7 +302,7 @@ interface ICoreWebView2FindConfiguration : IUnknown { [propget] HRESULT ActiveMatchIndex([out, retval] LONG* value); // Gets the total count of matches found in the current document based on the last find criteria. - // \return The total count of matches. + // Returns the total count of matches. [propget] HRESULT MatchesCount([out, retval] LONG* value); } From 87f7dbad66ade97336003dc63c27415245b31d2f Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 28 Mar 2024 13:27:03 -0700 Subject: [PATCH 26/80] deleted 438-443 --- FindOnPage.md | 8 -------- 1 file changed, 8 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 8bfe6e58f..3a2d14d79 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -433,14 +433,6 @@ namespace Microsoft.Web.WebView2.Core }; } - - - [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2Environment14")] - - { - CoreWebView2FindConfiguration CreateFindConfiguration(); - }; - interface ICoreWebView2Environment14 { CoreWebView2FindConfiguration CreateFindConfiguration(); From e66ba7a7b66a24a594b04a9763a4b08257cd9cb5 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 28 Mar 2024 13:28:06 -0700 Subject: [PATCH 27/80] deleted usage example from the api def --- FindOnPage.md | 20 +------------------- 1 file changed, 1 insertion(+), 19 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 3a2d14d79..84c5b0d9f 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -395,7 +395,7 @@ namespace Microsoft.Web.WebView2.Core } ``` -### CoreWebView2 Find Interface and Usage +### CoreWebView2 Find Interface ```csharp namespace Microsoft.Web.WebView2.Core @@ -437,24 +437,6 @@ namespace Microsoft.Web.WebView2.Core { CoreWebView2FindConfiguration CreateFindConfiguration(); }; - - - // Example usage: - public async Task PerformFindOperationAsync(ICoreWebView2Find webViewFind) - { - var findConfig = new CoreWebView2FindConfiguration - { - FindTerm = "example", - FindDirection = CoreWebView2FindDirection.Forward, - IsCaseSensitive = false, - ShouldMatchWord = true - }; - - await webViewFind.StartFindAsync(findConfig); - await webViewFind.FindNextAsync(); - await webViewFind.FindNextAsync(); - await webViewFind.StopFindAsync(); - } } ``` From 0a6971e5a70962e86574e15b0ea45cbec36d7d49 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 28 Mar 2024 15:29:16 -0700 Subject: [PATCH 28/80] line length corrected --- FindOnPage.md | 52 ++++++++++++++++++++++++++++++++------------------- 1 file changed, 33 insertions(+), 19 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 84c5b0d9f..67a6a27d4 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -2,22 +2,22 @@ ## Background -The WebView2Find API provides methods and events to support text finding and navigation within a WebView2 control. -It allows developers to programmatically initiate find operations, navigate between find results, supress default UI, customize various find configurations -such as query, direction of search, match case, match word, etc. Also enables developers to track the status of ongoing operations such as whether a find session has -completed or not, whether the match count has changed, and whether the match index has changed. +The WebView2Find API offers methods and events for text finding and navigation +within a WebView2 control. It enables developers to programmatically initiate find +operations, navigate find results, suppress default UI, and customize find configurations +like query and search direction. It also tracks the status of operations, indicating +completion, match count changes, and match index changes. ## Examples #### Description -To initiate a find operation within a WebView2 control, developers can utilize the `StartFind` method. -This method allows specifying the find term and configuring other find parameters using the `ICoreWebView2FindConfiguration` interface. -Additionally there can only be one find session active per webview environment. -If an attempt is made to call start find more than once with the same findconfugration, -it will result in the active match index either being increased or decreased depending on what -Find Direction parameter was chosen for the Find Configuration. +To initiate a find operation in a WebView2 control, use the `StartFind` method. +This method allows setting the search term and find parameters via the +`ICoreWebView2FindConfiguration` interface. Only one find session can be active per +webview environment. Starting another with the same configuration will adjust +the active match index based on the selected Find Direction. #### Create/Specify a Find Configuration ```cpp @@ -124,7 +124,8 @@ async void ConfigureAndExecuteFindAsync(string searchTerm){ ### Retrieve the Number of Matches #### Description -To retrieve the total number of matches found during a find operation within a WebView2 control, developers can utilize the `GetMatchCount` method. +To retrieve the total number of matches found during a find operation +within a WebView2 control, developers can utilize the `GetMatchCount` method. ```cpp @@ -152,7 +153,8 @@ To retrieve the total number of matches found during a find operation within a W //! [GetMatchCount] public async Task GetMatchCountAsync() { - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + // Assuming webView is your WebView2 control + var webViewFind = webView.CoreWebView2.FindController; var matchCount = await webViewFind.GetMatchesCountAsync(); MessageBox.Show($"Match Count: {matchCount}", "Find Operation", MessageBoxButton.OK); return matchCount; @@ -210,7 +212,8 @@ void ActiveMatchIndexChangedSample() ### Retrieve the Index of the Active Match #### Description -Developers can retrieve the index of the currently active match within a WebView2 control using the `GetActiveMatchIndex` method. +Developers can retrieve the index of the currently active match +within a WebView2 control using the `GetActiveMatchIndex` method. ```cpp @@ -372,7 +375,11 @@ interface ICoreWebView2Find : IUnknown { ### Setting Up Find Configuration with MIDL3 -To represent the given C# examples in a manner consistent with the behavior demonstrated earlier in the chat and align them with an API design that could be described using MIDL3 (noted as C# for formatting), let's formalize the design for a hypothetical WebView2 Find operation API. This design will incorporate setting up a find configuration, starting a find operation, handling find operation events, and navigating through find matches. +To represent the given C# examples in a manner consistent with the behavior demonstrated +earlier in the chat and align them with an API design that could be described using +MIDL3 (noted as C# for formatting), let's formalize the design for a hypothetical +WebView2 Find operation API. This design will incorporate setting up a find configuration, + starting a find operation, handling find operation events, and navigating through find matches. ### CoreWebView2 Find Configuration and Direction @@ -440,13 +447,20 @@ namespace Microsoft.Web.WebView2.Core } ``` -These examples demonstrate how you would conceptualize and implement the Find API within the Microsoft WebView2 environment, focusing on async patterns for responsive UI interactions and event handling for dynamic UI updates based on the results of find operations. -This design emphasizes asynchronous task-based APIs, event handling for UI updates, and modular API design for clear separation of concerns. +These examples demonstrate how you would conceptualize and implement the Find API +within the Microsoft WebView2 environment, focusing on async patterns for +responsive UI interactions and event handling for dynamic UI updates based on the +results of find operations. This design emphasizes asynchronous task-based APIs, +event handling for UI updates, and modular API design for clear separation of concerns. # Appendix -This API specification focuses on providing developers with the necessary information to integrate text finding and navigation functionalities into WebView2 applications. -It emphasizes the usage of interfaces such as `ICoreWebView2Find` and `ICoreWebView2FindConfiguration` to perform find operations effectively. +This API specification focuses on providing developers with the necessary information +to integrate text finding and navigation functionalities into WebView2 applications. +It emphasizes the usage of interfaces such as `ICoreWebView2Find` and +`ICoreWebView2FindConfiguration` to perform find operations effectively. + Additional Info: -Starting a find session when one is in progress will result in the active match index being moved forward or backwards depending on what find configuration has been used +Starting a find session when one is in progress will result in the active match index +being moved forward or backwards depending on what find configuration has been used (forward,backward). From 4c876048ff9562b7a7eb293625b7166c8e11bc7f Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 28 Mar 2024 15:30:44 -0700 Subject: [PATCH 29/80] 217 to 2_17 --- FindOnPage.md | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 67a6a27d4..8ca5e3872 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -36,13 +36,13 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) CHECK_FAILURE(findConfiguration->put_ShouldMatchWord(false)); CHECK_FAILURE(findConfiguration->put_FindDirection(COREWEBVIEW2_FIND_DIRECTION_FORWARD)); - // Query for the ICoreWebView217 interface to access the Find feature. - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); + // Query for the ICoreWebView2_17 interface to access the Find feature. + auto webView2_17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2_17); // Get the Find interface. wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); + CHECK_FAILURE(webView2_17->get_Find(&webView2find)); // Determine if custom UI will be usedsettings and highlight configurations. @@ -132,10 +132,10 @@ within a WebView2 control, developers can utilize the `GetMatchCount` method. //! [GetMatchCount] bool AppWindow::GetMatchCount() { - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); + auto webView2_17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2_17); wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); + CHECK_FAILURE(webView2_17->get_Find(&webView2find)); LONG matchCount; CHECK_FAILURE(webView2find->get_MatchesCount(&matchCount)); @@ -220,10 +220,10 @@ within a WebView2 control using the `GetActiveMatchIndex` method. //! [GetActiveMatchIndex] bool AppWindow::GetActiveMatchIndex() { - auto webView217 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView217); + auto webView2_17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2_17); wil::com_ptr webView2find; - CHECK_FAILURE(webView217->get_Find(&webView2find)); + CHECK_FAILURE(webView2_17->get_Find(&webView2find)); LONG activeMatchIndex; CHECK_FAILURE(webView2find->get_ActiveMatchIndex(&activeMatchIndex)); From d28354a3f81d94babf1cdb0e2bee73c731a5f750 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 28 Mar 2024 15:31:08 -0700 Subject: [PATCH 30/80] Update FindOnPage.md Co-authored-by: David Risney --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 8ca5e3872..52a5795b0 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -41,7 +41,7 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) CHECK_FEATURE_RETURN(webView2_17); // Get the Find interface. - wil::com_ptr webView2find; + wil::com_ptr webView2Find; CHECK_FAILURE(webView2_17->get_Find(&webView2find)); // Determine if custom UI will be usedsettings and highlight configurations. From 4de44afee00b6f69b5f5cbfd4b52dd3b7fb6fd0c Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 28 Mar 2024 15:35:02 -0700 Subject: [PATCH 31/80] Updated Callback in StartFind and the description of the find op completed handler --- FindOnPage.md | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 52a5795b0..57397370c 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -54,7 +54,7 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) CHECK_FAILURE(webView2find->StartFind( findConfiguration.get(), Callback( - [this](HRESULT result, LONG ActiveIdx, LONG MatchesCount) -> HRESULT + [this](HRESULT result, BOOL status) -> HRESULT { if (SUCCEEDED(result)) { @@ -326,7 +326,8 @@ interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { /// Handles the event that's fired when the find operation completes. [uuid(2604789D-9553-4246-8E21-B9C74EFAD04F), object, pointer_default(unique)] interface ICoreWebView2FindOperationCompletedHandler : IUnknown { - /// Provides the event args when the find operation completes. + /// Param1 refers to the returned code when the find operation completes. + /// Param2 refers whether the find session successfully finished executing or not. HRESULT Invoke(HRESULT errorCode, BOOL status); } From b3b07aefc584a80f256d48c39a8dbd3a810f42e2 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 28 Mar 2024 15:44:03 -0700 Subject: [PATCH 32/80] Updated the Configure/Execute Find --- FindOnPage.md | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 57397370c..18c232171 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -67,11 +67,9 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) return S_OK; }) .Get())); - CHECK_FAILURE(webView2find->FindNext()); - CHECK_FAILURE(webView2find->FindNext()); - CHECK_FAILURE(webView2find->FindPrevious()); - CHECK_FAILURE(webView2find->StopFind()); - + // End user will now be able to interact with default Find UX + // using the built in navigation buttons and Find filters to + // customize their search. return true; } //! [ConfigureAndExecuteFind] From a74ffa93b9c6a0d00244045e9a16fe2bd286565a Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 28 Mar 2024 15:59:49 -0700 Subject: [PATCH 33/80] Created a flow for using custom dialog and default dialog within startfind --- FindOnPage.md | 96 +++++++++++++++++++++++++++++++++++++++++++-------- 1 file changed, 82 insertions(+), 14 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 18c232171..fd0db8b10 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -19,10 +19,11 @@ This method allows setting the search term and find parameters via the webview environment. Starting another with the same configuration will adjust the active match index based on the selected Find Direction. #### Create/Specify a Find Configuration + ```cpp -//! [ConfigureAndExecuteFind] -bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) +//! [InitializeFindConfiguration] +wil::com_ptr AppWindow::InitializeFindConfiguration(const std::wstring& searchTerm) { // Query for the ICoreWebView2Environment5 interface. auto webView2Environment5 = m_webViewEnvironment.try_query(); @@ -44,35 +45,102 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) wil::com_ptr webView2Find; CHECK_FAILURE(webView2_17->get_Find(&webView2find)); - // Determine if custom UI will be usedsettings and highlight configurations. + return findConfiguration; +} +//! [InitializeFindConfiguration] +``` + +```cpp +//! [ExecuteFindWithDefaultUI] +bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) +{ + auto findConfiguration = InitializeFindConfiguration(searchTerm); + if (!findConfiguration) + { + return false; + } + // Query for the ICoreWebView2_17 interface to access the Find feature. + auto webView2_17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2_17); + + // Get the Find interface. + wil::com_ptr webView2Find; + CHECK_FAILURE(webView2_17->get_Find(&webView2Find)); // Assuming you want to use the default UI, adjust as necessary. - CHECK_FAILURE(webView2find->put_UseCustomUI(false)); + CHECK_FAILURE(webView2Find->put_UseCustomUI(false)); + CHECK_FAILURE(webView2Find->put_ShouldHighlightAllMatches(true)); + + // Start the find operation with a callback for completion. + CHECK_FAILURE(webView2Find->StartFind( + findConfiguration.get(), + Callback( + [this](HRESULT result, BOOL status) -> HRESULT + { + if (SUCCEEDED(result)) + { + // Optionally update UI elements here upon successful find operation. + } + else + { + // Handle errors. + } + return S_OK; + }).Get())); + + // End user interaction is handled via UI. + return true; +} +//! [ExecuteFindWithDefaultUI] +``` + +```cpp +//! [ExecuteFindWithCustomUI] +bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& searchTerm) +{ + auto findConfiguration = InitializeFindConfiguration(searchTerm); + if (!findConfiguration) + { + return false; + } + // Query for the ICoreWebView2_17 interface to access the Find feature. + auto webView2_17 = m_webView.try_query(); + CHECK_FEATURE_RETURN(webView2_17); + + // Get the Find interface. + wil::com_ptr webView2Find; + CHECK_FAILURE(webView2_17->get_Find(&webView2Find)); + + // Opt for using a custom UI for the find operation. + CHECK_FAILURE(webView2find->put_UseCustomUI(true)); CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); - // Start the find operation + // Start the find operation with callback for completion. CHECK_FAILURE(webView2find->StartFind( findConfiguration.get(), Callback( [this](HRESULT result, BOOL status) -> HRESULT { - if (SUCCEEDED(result)) + if (SUCCEEDED(result) && status) { - // For example, you could update UI elements here + // Optionally update UI elements here upon successful find operation. } else { - // Handle errors + // Handle errors or unsuccessful search. } return S_OK; - }) - .Get())); - // End user will now be able to interact with default Find UX - // using the built in navigation buttons and Find filters to - // customize their search. + }).Get())); + + // Note: In this example, navigation through find results (FindNext/FindPrevious) + // and stopping the find operation (StopFind) are assumed to be handled by + // custom UI elements and user interaction, not directly in code here. + // User could then connect functions such as FindNext, FindPrevious, and StopFind + // to corresponding custom UI elements. + return true; } -//! [ConfigureAndExecuteFind] +//! [ExecuteFindWithCustomUI] ``` ```csharp //! [ConfigureAndExecuteFind] From a33d8c084c6896eb54d2e61a87e0d9efcfe6acc9 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 28 Mar 2024 16:25:11 -0700 Subject: [PATCH 34/80] Update FindOnPage.md --- FindOnPage.md | 99 ++++++++++++++++++++++++++++++++++----------------- 1 file changed, 66 insertions(+), 33 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index fd0db8b10..5e0c2cc32 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -143,48 +143,81 @@ bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& searchTerm) //! [ExecuteFindWithCustomUI] ``` ```csharp -//! [ConfigureAndExecuteFind] -async void ConfigureAndExecuteFindAsync(string searchTerm){ - try +//! [ConfigureAndExecuteFindWithDefaultUI] +async Task ConfigureAndExecuteFindWithDefaultUIAsync(string searchTerm) +{ + try + { + // Check if the webView is already initialized and is an instance of CoreWebView2. + if (webView.CoreWebView2 == null) { - // Assuming 'webView' is already initialized and is an instance of CoreWebView2 - - // Initialize find configuration/settings - CoreWebView2FindConfinguration findConfiguration = new CoreWebView2FindConfiguration - { - FindTerm = searchTerm, - IsCaseSensitive = false, - ShouldMatchWord = false, - FindDirection = CoreWebView2FindDirection.Forward - }; - - CoreWebView2Find find = new CoreWebView2Find(findConfiguration); + throw new InvalidOperationException("WebView2 is not initialized."); + } - // Assuming you want to use the default UI, adjust as necessary - find.UseCustomUI = false; - find.ShouldHighlightAllMatches = true; + // Initialize the find configuration with specified settings. + var findConfiguration = new CoreWebView2FindConfiguration + { + FindTerm = searchTerm, + IsCaseSensitive = false, + ShouldMatchWord = false, + FindDirection = CoreWebView2FindDirection.Forward + }; - // Start the find operation - await find.StartFindAsync(findConfiguration); + // Use the default UI provided by WebView2 for the find operation. + webView.CoreWebView2.FindController.UseCustomUI = false; + webView.CoreWebView2.FindController.ShouldHighlightAllMatches = true; - // Perform FindNext operations - await find.FindNextAsync(); - await find.FindNextAsync(); - await find.FindPreviousAsync(); + // Start the find operation with the specified configuration. + await webView.CoreWebView2.FindController.StartFindAsync(findConfiguration); - // Stop the active find session - await find.StopFindAsync(); + // End user interaction is handled via UI. + } + catch (Exception ex) + { + // Handle any errors that may occur during the find operation. + Console.WriteLine($"An error occurred: {ex.Message}"); + } +} +//! [ConfigureAndExecuteFindWithDefaultUI] +``` - return true; - } - catch (Exception ex) +```csharp +//! [ConfigureAndExecuteFindWithCustomUI] +async Task ConfigureAndExecuteFindWithCustomUIAsync(string searchTerm) +{ + try + { + // Check if the webView is already initialized and is an instance of CoreWebView2. + if (webView.CoreWebView2 == null) { - // Handle errors - Console.WriteLine($"An error occurred: {ex.Message}"); - return false; + throw new InvalidOperationException("WebView2 is not initialized."); } + + // Initialize the find configuration with specified settings. + var findConfiguration = new CoreWebView2FindConfiguration + { + FindTerm = searchTerm, + IsCaseSensitive = false, + ShouldMatchWord = false, + FindDirection = CoreWebView2FindDirection.Forward + }; + + // Specify that a custom UI will be used for the find operation. + webView.CoreWebView2.FindController.UseCustomUI = true; + webView.CoreWebView2.FindController.ShouldHighlightAllMatches = true; + + // Start the find operation with the specified configuration. + await webView.CoreWebView2.FindController.StartFindAsync(findConfiguration); + // It's expected that the custom UI for navigating between matches (next, previous) + // and stopping the find operation will be managed by the developer's custom code. + } + catch (Exception ex) + { + // Handle any errors that may occur during the find operation. + Console.WriteLine($"An error occurred: {ex.Message}"); + } } -//! [ConfigureAndExecuteFind] +//! [ConfigureAndExecuteFindWithCustomUI] ``` ### Retrieve the Number of Matches From cb1913d2140f75c664c4ef9edb2f0b4b05ace89f Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 28 Mar 2024 16:26:46 -0700 Subject: [PATCH 35/80] Update FindOnPage.md --- FindOnPage.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 5e0c2cc32..88a721a6e 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -18,7 +18,8 @@ This method allows setting the search term and find parameters via the `ICoreWebView2FindConfiguration` interface. Only one find session can be active per webview environment. Starting another with the same configuration will adjust the active match index based on the selected Find Direction. -#### Create/Specify a Find Configuration +### Create/Specify a Find Configuration +#### WIN32 C++ ```cpp @@ -142,6 +143,7 @@ bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& searchTerm) } //! [ExecuteFindWithCustomUI] ``` +#### .NET C# ```csharp //! [ConfigureAndExecuteFindWithDefaultUI] async Task ConfigureAndExecuteFindWithDefaultUIAsync(string searchTerm) From fcf1ebbfc9dda3d90a50a7671d6b8da0fe862630 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 28 Mar 2024 16:32:22 -0700 Subject: [PATCH 36/80] Update FindOnPage.md --- FindOnPage.md | 122 +++++++++++++++++++++++--------------------------- 1 file changed, 55 insertions(+), 67 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 88a721a6e..e4bd147a8 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -226,90 +226,62 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string searchTerm) #### Description To retrieve the total number of matches found during a find operation -within a WebView2 control, developers can utilize the `GetMatchCount` method. +within a WebView2 control, developers can utilize the `GetmatchCount ` method. ```cpp - //! [GetMatchCount] - bool AppWindow::GetMatchCount() + //! [GetmatchCount ] + bool AppWindow::GetmatchCount () { auto webView2_17 = m_webView.try_query(); CHECK_FEATURE_RETURN(webView2_17); wil::com_ptr webView2find; CHECK_FAILURE(webView2_17->get_Find(&webView2find)); - LONG matchCount; - CHECK_FAILURE(webView2find->get_MatchesCount(&matchCount)); + LONG matchCount ; + CHECK_FAILURE(webView2find->get_MatchesCount(&matchCount )); - // Update UI or handle matchCount as you wish + // Update UI or handle matchCount as you wish // For example, you could show a message box - std::wstring matchCountStr = L"Match Count: " + std::to_wstring(matchCount); - MessageBox(m_mainWindow, matchCountStr.c_str(), L"Find Operation", MB_OK); + std::wstring matchCount Str = L"Match Count: " + std::to_wstring(matchCount ); + MessageBox(m_mainWindow, matchCount Str.c_str(), L"Find Operation", MB_OK); return true; } - //! [GetMatchCount] -``` + //! [GetmatchCount ] -```csharp - //! [GetMatchCount] - public async Task GetMatchCountAsync() - { - // Assuming webView is your WebView2 control - var webViewFind = webView.CoreWebView2.FindController; - var matchCount = await webViewFind.GetMatchesCountAsync(); - MessageBox.Show($"Match Count: {matchCount}", "Find Operation", MessageBoxButton.OK); - return matchCount; - } - //! [GetMatchCount] -``` -#### WIN32 C++ -```cpp -// Register MatchCountChanged event handler - m_webView->add_MatchCountChanged( - Callback( - [this](LONG matchCount) -> HRESULT +// Register matchCount Changed event handler + m_webView->add_matchCount Changed( + Callback( + [this](LONG matchCount ) -> HRESULT { // Update custom UI - wprintf(L"Match Count Changed: %ld\n", matchCount); + wprintf(L"Match Count Changed: %ld\n", matchCount ); return S_OK; }).Get(), - &m_matchCountChangedToken); + &m_matchCount ChangedToken); ``` -#### .NET C# + ```csharp -void MatchCountChangedSample() -{ - _webview.MatchCountChanged += (object sender, CoreWebView2MatchCountChangedEventArgs args) => + //! [GetmatchCount ] + public async Task GetmatchCount Async() { - // Update Custom UI - }; -} -``` -#### Handle Match Index Changes -#### WIN32 C++ + // Assuming webView is your WebView2 control + var webViewFind = webView.CoreWebView2.FindController; + var matchCount = await webViewFind.GetMatchesCountAsync(); + MessageBox.Show($"Match Count: {matchCount }", "Find Operation", MessageBoxButton.OK); + return matchCount ; + } + //! [GetmatchCount ] -```cpp -// Register ActiveMatchIndexChanged event handler -m_webView->add_ActiveMatchIndexChanged( - Callback( - [this](LONG activeMatchIndex) -> HRESULT - { - // Update custom UI - wprintf(L"Active Match Index Changed: %ld\n", activeMatchIndex); - return S_OK; - }).Get(), - &m_activeMatchIndexChangedToken); -``` -#### .NET C# -```csharp -void ActiveMatchIndexChangedSample() -{ - _webview.MatchCountChanged += (object sender, CoreWebView2ActiveMatchIndexChangedEventArgs args) => + void matchCount ChangedSample() { - // Update Custom UI - }; -} + _webview.matchCount Changed += (object sender, CoreWebView2matchCount ChangedEventArgs args) => + { + // Update Custom UI + }; + } ``` + ### Retrieve the Index of the Active Match #### Description @@ -337,6 +309,17 @@ within a WebView2 control using the `GetActiveMatchIndex` method. return true; } //! [GetActiveMatchIndex] + + // Register ActiveMatchIndexChanged event handler + m_webView->add_ActiveMatchIndexChanged( + Callback( + [this](LONG activeMatchIndex) -> HRESULT + { + // Update custom UI + wprintf(L"Active Match Index Changed: %ld\n", activeMatchIndex); + return S_OK; + }).Get(), + &m_activeMatchIndexChangedToken); ``` #### .NET C# ```csharp @@ -349,11 +332,16 @@ public async Task GetActiveMatchIndexAsync() return activeMatchIndex; } +void ActiveMatchIndexChangedSample() +{ + _webview.matchCount Changed += (object sender, CoreWebView2ActiveMatchIndexChangedEventArgs args) => + { + // Update Custom UI + }; +} //! [GetActiveMatchIndex] ``` - - ## API Details ```csharp @@ -413,7 +401,7 @@ interface ICoreWebView2FindConfiguration : IUnknown { /// Handles the event that's fired when the match count changes. [uuid(623EFBFB-A19E-43C4-B309-D578511D24AB), object, pointer_default(unique)] -interface ICoreWebView2FindMatchCountChangedEventHandler : IUnknown { +interface ICoreWebView2FindmatchCount ChangedEventHandler : IUnknown { /// Parameter is the match count. HRESULT Invoke(LONG matchesCount); } @@ -453,12 +441,12 @@ interface ICoreWebView2Find : IUnknown { // This event is raised when a find operation completes, either by finding all matches, navigating to a match, or by being stopped. // Parameter is the event handler to be added. // Returns a token representing the added event handler. This token can be used to unregister the event handler. - HRESULT add_MatchCountChanged( - [in] ICoreWebView2FindMatchCountChangedEventHandler* eventHandler, + HRESULT add_matchCount Changed( + [in] ICoreWebView2FindmatchCount ChangedEventHandler* eventHandler, [out] EventRegistrationToken* token); - // Unregisters an event handler from the MatchCountChanged event. + // Unregisters an event handler from the matchCount Changed event. // Parameter is the token of the event handler to be removed, obtained during the registration of the event handler. - HRESULT remove_MatchCountChanged([in] EventRegistrationToken token); + HRESULT remove_matchCount Changed([in] EventRegistrationToken token); // Registers an event handler for the ActiveMatchIndexChanged event. // This event is raised when the index of the currently active match changes. From 990ed886c9d005660a5d439f6598d41f5388fd60 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 1 Apr 2024 11:25:26 -0700 Subject: [PATCH 37/80] Update FindOnPage.md Co-authored-by: David Risney --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index e4bd147a8..f2f330d95 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -403,7 +403,7 @@ interface ICoreWebView2FindConfiguration : IUnknown { [uuid(623EFBFB-A19E-43C4-B309-D578511D24AB), object, pointer_default(unique)] interface ICoreWebView2FindmatchCount ChangedEventHandler : IUnknown { /// Parameter is the match count. - HRESULT Invoke(LONG matchesCount); + HRESULT Invoke(ICoreWebView2Find* source, IUnknown* eventArgs); } /// Handles the event that's fired when the active match index changes. From 2f7177010e06363c15ecd2f553ae2bfebb1fa2bd Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 1 Apr 2024 11:36:02 -0700 Subject: [PATCH 38/80] Update FindOnPage.md --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index f2f330d95..930dee4d3 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -414,7 +414,7 @@ interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { } /// Handles the event that's fired when the find operation completes. [uuid(2604789D-9553-4246-8E21-B9C74EFAD04F), object, pointer_default(unique)] -interface ICoreWebView2FindOperationCompletedHandler : IUnknown { +interface ICoreWebView2FindStartFindOperationCompletedHandler: IUnknown { /// Param1 refers to the returned code when the find operation completes. /// Param2 refers whether the find session successfully finished executing or not. HRESULT Invoke(HRESULT errorCode, BOOL status); From eeceaf02bfbbfcd62ea9ec9583cab5093e0078c7 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 1 Apr 2024 11:55:49 -0700 Subject: [PATCH 39/80] Update FindOnPage.md Changed Match Index and Count to async operations --- FindOnPage.md | 35 +++++++++++++++++++---------------- 1 file changed, 19 insertions(+), 16 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 930dee4d3..c4b845ae4 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -327,16 +327,18 @@ within a WebView2 control using the `GetActiveMatchIndex` method. public async Task GetActiveMatchIndexAsync() { var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control - var activeMatchIndex = await webViewFind.GetActiveMatchIndexAsync(); + var activeMatchIndex = webViewFind.ActiveMatchIndex(); MessageBox.Show($"Active Match Index: {activeMatchIndex}", "Find Operation", MessageBoxButton.OK); return activeMatchIndex; } void ActiveMatchIndexChangedSample() { - _webview.matchCount Changed += (object sender, CoreWebView2ActiveMatchIndexChangedEventArgs args) => + webView.CoreWebView2.FindController.ActiveMatchIndexChanged += (object sender, EventArgs args) => { - // Update Custom UI + // Access the active match index synchronously in the event handler. + int activeMatchIndex = webView.CoreWebView2.FindController.ActiveMatchIndex; + // Update Custom UI based on the new active match index. }; } //! [GetActiveMatchIndex] @@ -504,21 +506,22 @@ namespace Microsoft.Web.WebView2.Core Backward, }; - runtime CoreWebView2Find +runtime CoreWebView2Find +{ + [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2Find")] { - [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2Find")] - { - void StartFindAsync(CoreWebView2FindConfiguration configuration); - void FindNextAsync(); - void FindPreviousAsync(); - void StopFindAsync(); - bool ShouldHighlightAllMatches { get; set; } - bool ShouldHighlightActiveMatch { get; set; } - bool UseCustomUI { get; set; } - int GetActiveMatchIndexAsync(); - int GetMatchesCountAsync(); - } + void StartFind(CoreWebView2FindConfiguration configuration); + void FindNext(); + void FindPrevious(); + void StopFind(); + bool ShouldHighlightAllMatches { get; set; } + bool ShouldHighlightActiveMatch { get; set; } + bool UseCustomUI { get; set; } + int ActiveMatchIndex { get; }; // Synchronously gets the active match index. + int MatchesCount { get; }; // Synchronously gets the matches count. } +} + runtimeclass CoreWebView2FindConfiguration { [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2StagingFindConfiguration")] From e0a860c2f3bfd8dec94493c65801fe62c013a101 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 1 Apr 2024 13:28:40 -0700 Subject: [PATCH 40/80] Update FindOnPage.md --- FindOnPage.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index c4b845ae4..b28c65f13 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -238,7 +238,7 @@ within a WebView2 control, developers can utilize the `GetmatchCount ` method. wil::com_ptr webView2find; CHECK_FAILURE(webView2_17->get_Find(&webView2find)); LONG matchCount ; - CHECK_FAILURE(webView2find->get_MatchesCount(&matchCount )); + CHECK_FAILURE(webView2find->get_MatchCount(&matchCount )); // Update UI or handle matchCount as you wish // For example, you could show a message box @@ -267,7 +267,7 @@ within a WebView2 control, developers can utilize the `GetmatchCount ` method. { // Assuming webView is your WebView2 control var webViewFind = webView.CoreWebView2.FindController; - var matchCount = await webViewFind.GetMatchesCountAsync(); + var matchCount = await webViewFind.GetMatchCountAsync(); MessageBox.Show($"Match Count: {matchCount }", "Find Operation", MessageBoxButton.OK); return matchCount ; } @@ -397,7 +397,7 @@ interface ICoreWebView2FindConfiguration : IUnknown { // Gets the total count of matches found in the current document based on the last find criteria. // Returns the total count of matches. - [propget] HRESULT MatchesCount([out, retval] LONG* value); + [propget] HRESULT MatchCount([out, retval] LONG* value); } @@ -517,8 +517,8 @@ runtime CoreWebView2Find bool ShouldHighlightAllMatches { get; set; } bool ShouldHighlightActiveMatch { get; set; } bool UseCustomUI { get; set; } - int ActiveMatchIndex { get; }; // Synchronously gets the active match index. - int MatchesCount { get; }; // Synchronously gets the matches count. + int ActiveMatchIndex { get; }; + int MatchCount { get; }; } } From 5f4f6c7a21663267f41046c0818b414ea4c4a97d Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 1 Apr 2024 13:32:29 -0700 Subject: [PATCH 41/80] Update FindOnPage.md --- FindOnPage.md | 60 --------------------------------------------------- 1 file changed, 60 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index b28c65f13..19eac985c 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -221,66 +221,6 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string searchTerm) } //! [ConfigureAndExecuteFindWithCustomUI] ``` - -### Retrieve the Number of Matches - -#### Description -To retrieve the total number of matches found during a find operation -within a WebView2 control, developers can utilize the `GetmatchCount ` method. - - -```cpp - //! [GetmatchCount ] - bool AppWindow::GetmatchCount () - { - auto webView2_17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2_17); - wil::com_ptr webView2find; - CHECK_FAILURE(webView2_17->get_Find(&webView2find)); - LONG matchCount ; - CHECK_FAILURE(webView2find->get_MatchCount(&matchCount )); - - // Update UI or handle matchCount as you wish - // For example, you could show a message box - std::wstring matchCount Str = L"Match Count: " + std::to_wstring(matchCount ); - MessageBox(m_mainWindow, matchCount Str.c_str(), L"Find Operation", MB_OK); - - return true; - } - //! [GetmatchCount ] - -// Register matchCount Changed event handler - m_webView->add_matchCount Changed( - Callback( - [this](LONG matchCount ) -> HRESULT - { - // Update custom UI - wprintf(L"Match Count Changed: %ld\n", matchCount ); - return S_OK; - }).Get(), - &m_matchCount ChangedToken); -``` - -```csharp - //! [GetmatchCount ] - public async Task GetmatchCount Async() - { - // Assuming webView is your WebView2 control - var webViewFind = webView.CoreWebView2.FindController; - var matchCount = await webViewFind.GetMatchCountAsync(); - MessageBox.Show($"Match Count: {matchCount }", "Find Operation", MessageBoxButton.OK); - return matchCount ; - } - //! [GetmatchCount ] - - void matchCount ChangedSample() - { - _webview.matchCount Changed += (object sender, CoreWebView2matchCount ChangedEventArgs args) => - { - // Update Custom UI - }; - } -``` ### Retrieve the Index of the Active Match From 7d1db179df5ef5d3129d1231ddddfb79e702e3f2 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 1 Apr 2024 13:33:18 -0700 Subject: [PATCH 42/80] Update FindOnPage.md --- FindOnPage.md | 1 - 1 file changed, 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 19eac985c..4e352cacd 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -276,7 +276,6 @@ void ActiveMatchIndexChangedSample() { webView.CoreWebView2.FindController.ActiveMatchIndexChanged += (object sender, EventArgs args) => { - // Access the active match index synchronously in the event handler. int activeMatchIndex = webView.CoreWebView2.FindController.ActiveMatchIndex; // Update Custom UI based on the new active match index. }; From b4e4f7deb9b57a1edcae4a7984ff7d2e3cfeb4fd Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 17 Apr 2024 16:12:26 -0700 Subject: [PATCH 43/80] Update FindOnPage.md Addressed feedback, Updated API descriptions locally and rebuilt then pasted resulting ones into spec. --- FindOnPage.md | 405 ++++++++++++++++++++++++++++++++------------------ 1 file changed, 263 insertions(+), 142 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 4e352cacd..4d6cb316f 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -284,134 +284,223 @@ void ActiveMatchIndexChangedSample() ``` ## API Details -```csharp +```cpp -/// Specifies the direction of find Parameters. +/// Specifies the direction of Search Parameters. +// MSOWNERS: core (maxwellmyers@microsoft.com) [v1_enum] -typedef enum COREWEBVIEW2_FIND_DIRECTION { - /// Specifies a forward find in the document. - COREWEBVIEW2_FIND_DIRECTION_FORWARD, - /// Specifies a backwards find in the document. - COREWEBVIEW2_FIND_DIRECTION_BACKWARD -} COREWEBVIEW2_FIND_DIRECTION; - -// Interface defining the find configuration. -[uuid(4A6ED732-DF08-4449-8949-3632A4DEBFCD), object, pointer_default(unique)] -interface ICoreWebView2FindConfiguration : IUnknown { - - // Gets or sets the find term used for the find operation. - [propget] HRESULT FindTerm([out, retval] LPWSTR* value); - [propput] HRESULT FindTerm([in] LPCWSTR value); - - // Gets or sets the direction of the find operation (forward or backward). - [propget] HRESULT FindDirection([out, retval] COREWEBVIEW2_FIND_DIRECTION* value); - [propput] HRESULT FindDirection([in] COREWEBVIEW2_FIND_DIRECTION value); - - // Gets or sets whether the find operation is case sensitive. - [propget] HRESULT IsCaseSensitive([out, retval] BOOL* value); - [propput] HRESULT IsCaseSensitive([in] BOOL value); - - // Gets or sets whether to only match whole words during the find operation. - [propget] HRESULT ShouldMatchWord([out, retval] BOOL* value); - [propput] HRESULT ShouldMatchWord([in] BOOL value); - - // Gets the state of whether all matches are highlighted. - // Returns TRUE if all matches are highlighted, FALSE otherwise. - [propget] HRESULT ShouldHighlightAllMatches([out, retval] BOOL* value); - // Sets the state to either highlight all matches or not. - [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); - - // Checks if a custom user interface is desired by end developer. - // If TRUE, the default Find bar is not displayed. - // Returns TRUE if using a custom UI, FALSE if using the default. - [propget] HRESULT SuppressDefaultDialog([out, retval] BOOL* value); - // Sets whether to use a custom UI for the Find operation. - [propput] HRESULT SuppressDefaultDialog([in] BOOL value); - - // Gets the index of the currently active match. - // If there's no active find session but an attempt is made to get the active match index: - // The function will return -1. - // Returns The active match index. - [propget] HRESULT ActiveMatchIndex([out, retval] LONG* value); - - // Gets the total count of matches found in the current document based on the last find criteria. - // Returns the total count of matches. - [propget] HRESULT MatchCount([out, retval] LONG* value); +typedef enum COREWEBVIEW2_FIND_DIRECTION { + /// Specifies a forward search in the document. + COREWEBVIEW2_FIND_DIRECTION_FORWARD, + /// Specifies a backwards search in the document. + COREWEBVIEW2_FIND_DIRECTION_BACKWARD, +} COREWEBVIEW2_FIND_DIRECTION; + + +/// Interface that provides methods related to the environment settings of CoreWebView2. +/// This interface allows for the creation of new find configuration objects. +// MSOWNERS: core (maxwellmyers@microsoft.com) +[uuid(f10bddd3-bb59-5d5b-8748-8a1a53f65d0c), object, pointer_default(unique)] +interface ICoreWebView2StagingEnvironment5 : IUnknown { + /// Creates a new instance of a FindConfiguration object. + /// This configuration object can be used to define parameters for a search operation. + /// Returns the newly created FindConfiguration object. + // MSOWNERS: core (maxwellmyers@microsoft.com) + HRESULT CreateFindConfiguration( + [out, retval] ICoreWebView2StagingFindConfiguration** value + ); + } -/// Handles the event that's fired when the match count changes. -[uuid(623EFBFB-A19E-43C4-B309-D578511D24AB), object, pointer_default(unique)] -interface ICoreWebView2FindmatchCount ChangedEventHandler : IUnknown { - /// Parameter is the match count. - HRESULT Invoke(ICoreWebView2Find* source, IUnknown* eventArgs); + +/// Receives the result of the `StartFind` method. +[uuid(7c20f8b0-c14e-5135-a099-6c9d11d59dd1), object, pointer_default(unique)] +interface ICoreWebView2StagingFindStartFindCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode); } -/// Handles the event that's fired when the active match index changes. -[uuid(623EFBF9-A19E-43C4-B309-D578511D24A9), object, pointer_default(unique)] -interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { - /// Parameter is the active match index. - HRESULT Invoke(LONG activeMatchIndex); +/// Receives `FindActiveMatchIndexChanged` events. +[uuid(8d3422bf-66df-5bae-9916-71fd23d5bef6), object, pointer_default(unique)] +interface ICoreWebView2StagingFindActiveMatchIndexChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2StagingFind* sender, + [in] IUnknown* args); } -/// Handles the event that's fired when the find operation completes. -[uuid(2604789D-9553-4246-8E21-B9C74EFAD04F), object, pointer_default(unique)] -interface ICoreWebView2FindStartFindOperationCompletedHandler: IUnknown { - /// Param1 refers to the returned code when the find operation completes. - /// Param2 refers whether the find session successfully finished executing or not. - HRESULT Invoke(HRESULT errorCode, BOOL status); +/// Receives `FindMatchCountChanged` events. +[uuid(cecb8e8f-b6c8-55c3-98b1-68fd1e2b9eea), object, pointer_default(unique)] +interface ICoreWebView2StagingFindMatchCountChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2StagingFind* sender, + [in] IUnknown* args); +} + + +/// Interface providing methods and properties for finding and navigating through text in the web view. +/// This interface allows for text searches, navigation between matches, and customization of the find UI. +// MSOWNERS: core (maxwellmyers@microsoft.com) +[uuid(b21617e6-34a1-516d-846c-5615516afa90), object, pointer_default(unique)] +interface ICoreWebView2StagingFind : IUnknown { + /// Retrieves the index of the currently active match in the find session. Returns the index of the currently active match, or -1 if there is no active match. + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propget] HRESULT ActiveMatchIndex([out, retval] UINT32* value); + + + /// Gets the total count of matches found in the current document based on the last search criteria. Returns the total count of matches. + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propget] HRESULT MatchCount([out, retval] UINT32* value); + + + /// Gets the `ShouldHighlightAllMatches` property. + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propget] HRESULT ShouldHighlightAllMatches([out, retval] BOOL* value); + + + /// Gets or sets the state of whether all matches are highlighted. Returns TRUE if all matches are highlighted, FALSE otherwise. + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); + + + /// Gets the `SuppressDefaultDialog` property. + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propget] HRESULT SuppressDefaultDialog([out, retval] BOOL* value); + + + /// Checks if a custom user interface is desired by the end developer. Returns TRUE if using a custom UI, FALSE if using the default. + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propput] HRESULT SuppressDefaultDialog([in] BOOL value); + + + + /// Adds an event handler for the `FindActiveMatchIndexChanged` event. + /// Registers an event handler for the ActiveMatchIndexChanged event. This event is raised when the index of the currently active match changes. This can happen when the user navigates to a different match or when the active match is changed programmatically. The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. + // MSOWNERS: core (maxwellmyers@microsoft.com) + HRESULT add_FindActiveMatchIndexChanged( + [in] ICoreWebView2StagingFindActiveMatchIndexChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_FindActiveMatchIndexChanged`. + // MSOWNERS: core (maxwellmyers@microsoft.com) + HRESULT remove_FindActiveMatchIndexChanged( + [in] EventRegistrationToken token); + + /// Adds an event handler for the `FindMatchCountChanged` event. + /// Registers an event handler for the MatchCountChanged event. This event is raised when the total count of matches in the document changes due to a new search operation or changes in the document. The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. + // MSOWNERS: core (maxwellmyers@microsoft.com) + HRESULT add_FindMatchCountChanged( + [in] ICoreWebView2StagingFindMatchCountChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_FindMatchCountChanged`. + // MSOWNERS: core (maxwellmyers@microsoft.com) + HRESULT remove_FindMatchCountChanged( + [in] EventRegistrationToken token); + + + /// Initiates a search using the specified configuration. + /// Displays the Find bar and starts the search operation. If a search was already ongoing, it will be stopped and replaced with this new instance. + /// If called with an empty string, the Find bar is displayed but no search occurs. Changing the configuration object after initiation won't affect the ongoing search. + /// To change the ongoing search, StartFind must be called again with a new or modified configuration object. + /// This method is primarily designed for HTML document searches. + // MSOWNERS: core (maxwellmyers@microsoft.com) + HRESULT StartFind( + [in] ICoreWebView2StagingFindConfiguration* configuration + , [in] ICoreWebView2StagingFindStartFindCompletedHandler* handler + ); + + /// Navigates to the next match in the document. + // MSOWNERS: core (maxwellmyers@microsoft.com) + HRESULT FindNext( + ); + + /// Navigates to the previous match in the document. + // MSOWNERS: core (maxwellmyers@microsoft.com) + HRESULT FindPrevious( + ); + + /// Stops the current 'Find' operation and hides the Find bar. + // MSOWNERS: core (maxwellmyers@microsoft.com) + HRESULT StopFind( + ); + + +} + + + +/// Interface defining the find configuration. +/// This interface provides the necessary methods and properties to configure a search operation. +// MSOWNERS: core (maxwellmyers@microsoft.com) +[uuid(52a04b23-acc8-5659-aa2f-26dbe9faafde), object, pointer_default(unique)] +interface ICoreWebView2StagingFindConfiguration : IUnknown { + /// Gets the `FindDirection` property. + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propget] HRESULT FindDirection([out, retval] COREWEBVIEW2_FIND_DIRECTION* value); + + + /// + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propput] HRESULT FindDirection([in] COREWEBVIEW2_FIND_DIRECTION value); + + + /// Gets the `FindTerm` property. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propget] HRESULT FindTerm([out, retval] LPWSTR* value); + + + /// + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propput] HRESULT FindTerm([in] LPCWSTR value); + + + /// Gets the `IsCaseSensitive` property. + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propget] HRESULT IsCaseSensitive([out, retval] BOOL* value); + + + /// + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propput] HRESULT IsCaseSensitive([in] BOOL value); + + + /// Gets the `ShouldMatchWord` property. + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propget] HRESULT ShouldMatchWord([out, retval] BOOL* value); + + + /// + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propput] HRESULT ShouldMatchWord([in] BOOL value); + + + } -// Interface providing methods and properties for finding and navigating through text in the web view. -[uuid(7C49A8AA-2A17-4846-8207-21D1520AABC0), object, pointer_default(unique)] -interface ICoreWebView2Find : IUnknown { - - // Initiates a find using the specified configuration. - HRESULT StartFind([in] ICoreWebView2FindConfiguration* configuration, - ICoreWebView2FindOperationCompletedHandler* handler); - - // Navigates to the next match in the document. - HRESULT FindNext(); - - // Navigates to the previous match in the document. - HRESULT FindPrevious(); - - // Stops the current 'Find' operation and hides the Find bar. - HRESULT StopFind(); - - // Registers an event handler for the FindCompleted event. - // This event is raised when a find operation completes, either by finding all matches, navigating to a match, or by being stopped. - // Parameter is the event handler to be added. - // Returns a token representing the added event handler. This token can be used to unregister the event handler. - HRESULT add_matchCount Changed( - [in] ICoreWebView2FindmatchCount ChangedEventHandler* eventHandler, - [out] EventRegistrationToken* token); - // Unregisters an event handler from the matchCount Changed event. - // Parameter is the token of the event handler to be removed, obtained during the registration of the event handler. - HRESULT remove_matchCount Changed([in] EventRegistrationToken token); - - // Registers an event handler for the ActiveMatchIndexChanged event. - // This event is raised when the index of the currently active match changes. - // This can happen when the user navigates to a different match or when the active match is changed programmatically. - // Parameter is the event handler to be added. - // Returns a token representing the added event handler. This token can be used to unregister the event handler. - HRESULT add_ActiveMatchIndexChanged( - [in] ICoreWebView2FindActiveMatchIndexChangedEventHandler* eventHandler, - [out] EventRegistrationToken* token); - // Unregisters an event handler from the ActiveMatchIndexChanged event. - // parameter is the token of the event handler to be removed, obtained during the registration of the event handler. - HRESULT remove_ActiveMatchIndexChanged([in] EventRegistrationToken token); +/// +/// Interface providing methods to access the find operation functionalities in the CoreWebView2. +/// +// MSOWNERS: core (maxwellmyers@microsoft.com) +[uuid(c9a130ca-a807-549c-9d76-8e09ccee3973), object, pointer_default(unique)] +interface ICoreWebView2Staging17 : IUnknown { + /// Retrieves the find operation interface for the current web view. + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propget] HRESULT Find([out, retval] ICoreWebView2StagingFind** value); + + + } ``` ### Setting Up Find Configuration with MIDL3 -To represent the given C# examples in a manner consistent with the behavior demonstrated -earlier in the chat and align them with an API design that could be described using -MIDL3 (noted as C# for formatting), let's formalize the design for a hypothetical -WebView2 Find operation API. This design will incorporate setting up a find configuration, - starting a find operation, handling find operation events, and navigating through find matches. - ### CoreWebView2 Find Configuration and Direction ```csharp @@ -438,53 +527,85 @@ namespace Microsoft.Web.WebView2.Core ```csharp namespace Microsoft.Web.WebView2.Core { - + /// Specifies the direction of Search Parameters. + [ms_owner("core", "maxwellmyers@microsoft.com")] + [availability("staging")] enum CoreWebView2FindDirection { + /// Specifies a forward search in the document. Forward, + /// Specifies a backwards search in the document. Backward, }; -runtime CoreWebView2Find -{ - [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2Find")] + runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfiguration {} + + /// Interface defining the find configuration. + /// This interface provides the necessary methods and properties to configure a search operation. + [com_interface("staging=ICoreWebView2StagingFindConfiguration")] + [ms_owner("core", "maxwellmyers@microsoft.com")] + [availability("staging")] + interface ICoreWebView2FindConfiguration { - void StartFind(CoreWebView2FindConfiguration configuration); + // Gets or sets the search term used for the find operation. Returns the search term. + String FindTerm { get; set; }; + // Gets or sets the direction of the search operation (forward or backward). Returns the search direction. + CoreWebView2FindDirection FindDirection { get; set; }; + // Determines if the search operation is case sensitive. Returns TRUE if the search is case sensitive, FALSE otherwise. + Boolean IsCaseSensitive { get; set; }; + // Determines if only whole words should be matched during the find operation. Returns TRUE if only whole words should be matched, FALSE otherwise. + Boolean ShouldMatchWord { get; set; }; + }; + + runtimeclass CoreWebView2Find : [default]ICoreWebView2Find {} + + /// Interface providing methods and properties for finding and navigating through text in the web view. + /// This interface allows for text searches, navigation between matches, and customization of the find UI. + [com_interface("staging=ICoreWebView2StagingFind")] + [ms_owner("core", "maxwellmyers@microsoft.com")] + [availability("staging")] + interface ICoreWebView2Find + { + [completed_handler("")] + /// Initiates a search using the specified configuration. + /// Displays the Find bar and starts the search operation. If a search was already ongoing, it will be stopped and replaced with this new instance. + /// If called with an empty string, the Find bar is displayed but no search occurs. Changing the configuration object after initiation won't affect the ongoing search. + /// To change the ongoing search, StartFind must be called again with a new or modified configuration object. + /// This method is primarily designed for HTML document searches. + Windows.Foundation.IAsyncAction StartFindAsync(CoreWebView2FindConfiguration configuration); + + /// Navigates to the next match in the document. void FindNext(); + + /// Navigates to the previous match in the document. void FindPrevious(); + + /// Stops the current 'Find' operation and hides the Find bar. void StopFind(); - bool ShouldHighlightAllMatches { get; set; } - bool ShouldHighlightActiveMatch { get; set; } - bool UseCustomUI { get; set; } - int ActiveMatchIndex { get; }; - int MatchCount { get; }; - } -} + /// Gets or sets the state of whether all matches are highlighted. Returns TRUE if all matches are highlighted, FALSE otherwise. + Boolean ShouldHighlightAllMatches { get; set; }; - runtimeclass CoreWebView2FindConfiguration { - [interface_name("Microsoft.Web.WebView2.Core.ICoreWebView2StagingFindConfiguration")] - { - String FindTerm { get; set; }; - CoreWebView2FindDirection FindDirection { get; set; }; - Boolean IsCaseSensitive { get; set; }; - Boolean ShouldMatchWord { get; set; }; - }; - } + /// Checks if a custom user interface is desired by the end developer. Returns TRUE if using a custom UI, FALSE if using the default. + Boolean SuppressDefaultDialog { get; set; }; - interface ICoreWebView2Environment14 - { - CoreWebView2FindConfiguration CreateFindConfiguration(); + /// Retrieves the index of the currently active match in the find session. Returns the index of the currently active match, or -1 if there is no active match. + UInt32 ActiveMatchIndex { get; }; + + /// Gets the total count of matches found in the current document based on the last search criteria. Returns the total count of matches. + UInt32 MatchCount { get; }; + + /// Registers an event handler for the MatchCountChanged event. This event is raised when the total count of matches in the document changes due to a new search operation or changes in the document. The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. + [event_handler("", "", "")] + event Windows.Foundation.TypedEventHandler FindMatchCountChanged; + + /// Registers an event handler for the ActiveMatchIndexChanged event. This event is raised when the index of the currently active match changes. This can happen when the user navigates to a different match or when the active match is changed programmatically. The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. + [event_handler("", "", "")] + event Windows.Foundation.TypedEventHandler FindActiveMatchIndexChanged; }; } ``` -These examples demonstrate how you would conceptualize and implement the Find API -within the Microsoft WebView2 environment, focusing on async patterns for -responsive UI interactions and event handling for dynamic UI updates based on the -results of find operations. This design emphasizes asynchronous task-based APIs, -event handling for UI updates, and modular API design for clear separation of concerns. - # Appendix This API specification focuses on providing developers with the necessary information From 9c6460b454b6a1e617a699b7deaa1086d396b7ad Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 24 Apr 2024 07:35:13 -0700 Subject: [PATCH 44/80] Update FindOnPage.md Updated "webview2find" var names --- FindOnPage.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 4d6cb316f..dea943748 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -44,7 +44,7 @@ wil::com_ptr AppWindow::InitializeFindConfigurat // Get the Find interface. wil::com_ptr webView2Find; - CHECK_FAILURE(webView2_17->get_Find(&webView2find)); + CHECK_FAILURE(webView2_17->get_Find(&webView2Find)); return findConfiguration; } @@ -113,11 +113,11 @@ bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& searchTerm) CHECK_FAILURE(webView2_17->get_Find(&webView2Find)); // Opt for using a custom UI for the find operation. - CHECK_FAILURE(webView2find->put_UseCustomUI(true)); + CHECK_FAILURE(webView2Find->put_UseCustomUI(true)); CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); // Start the find operation with callback for completion. - CHECK_FAILURE(webView2find->StartFind( + CHECK_FAILURE(webView2Find->StartFind( findConfiguration.get(), Callback( [this](HRESULT result, BOOL status) -> HRESULT @@ -236,9 +236,9 @@ within a WebView2 control using the `GetActiveMatchIndex` method. auto webView2_17 = m_webView.try_query(); CHECK_FEATURE_RETURN(webView2_17); wil::com_ptr webView2find; - CHECK_FAILURE(webView2_17->get_Find(&webView2find)); + CHECK_FAILURE(webView2_17->get_Find(&webView2Find)); LONG activeMatchIndex; - CHECK_FAILURE(webView2find->get_ActiveMatchIndex(&activeMatchIndex)); + CHECK_FAILURE(webView2Find->get_ActiveMatchIndex(&activeMatchIndex)); // Update UI or handle activeMatchIndex as you wish // For example, you could show a message box From f68c12c6883aa651489a69c6b735b16d05a0ce60 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 2 May 2024 13:19:51 -0700 Subject: [PATCH 45/80] Update FindOnPage.md --- FindOnPage.md | 14 +++++--------- 1 file changed, 5 insertions(+), 9 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index dea943748..54cf9c575 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -42,10 +42,6 @@ wil::com_ptr AppWindow::InitializeFindConfigurat auto webView2_17 = m_webView.try_query(); CHECK_FEATURE_RETURN(webView2_17); - // Get the Find interface. - wil::com_ptr webView2Find; - CHECK_FAILURE(webView2_17->get_Find(&webView2Find)); - return findConfiguration; } //! [InitializeFindConfiguration] @@ -53,7 +49,7 @@ wil::com_ptr AppWindow::InitializeFindConfigurat ```cpp //! [ExecuteFindWithDefaultUI] -bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) +bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) { auto findConfiguration = InitializeFindConfiguration(searchTerm); if (!findConfiguration) @@ -69,7 +65,7 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) CHECK_FAILURE(webView2_17->get_Find(&webView2Find)); // Assuming you want to use the default UI, adjust as necessary. - CHECK_FAILURE(webView2Find->put_UseCustomUI(false)); + CHECK_FAILURE(webView2Find->put_SuppressDefaultDialog(false)); CHECK_FAILURE(webView2Find->put_ShouldHighlightAllMatches(true)); // Start the find operation with a callback for completion. @@ -113,7 +109,7 @@ bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& searchTerm) CHECK_FAILURE(webView2_17->get_Find(&webView2Find)); // Opt for using a custom UI for the find operation. - CHECK_FAILURE(webView2Find->put_UseCustomUI(true)); + CHECK_FAILURE(webView2Find->put_SuppressDefaultDialog(true)); CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); // Start the find operation with callback for completion. @@ -166,7 +162,7 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string searchTerm) }; // Use the default UI provided by WebView2 for the find operation. - webView.CoreWebView2.FindController.UseCustomUI = false; + webView.CoreWebView2.FindController.SuppressDefaultDialog = false; webView.CoreWebView2.FindController.ShouldHighlightAllMatches = true; // Start the find operation with the specified configuration. @@ -205,7 +201,7 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string searchTerm) }; // Specify that a custom UI will be used for the find operation. - webView.CoreWebView2.FindController.UseCustomUI = true; + webView.CoreWebView2.FindController.SuppressDefaultDialog = true; webView.CoreWebView2.FindController.ShouldHighlightAllMatches = true; // Start the find operation with the specified configuration. From 7528998a8101db3a178d31731e91906e433da4c8 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Thu, 2 May 2024 13:28:06 -0700 Subject: [PATCH 46/80] Update FindOnPage.md --- FindOnPage.md | 77 +++++++++++++++++++++++++++------------------------ 1 file changed, 41 insertions(+), 36 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 54cf9c575..c9547aac9 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -337,16 +337,16 @@ interface ICoreWebView2StagingFindMatchCountChangedEventHandler : IUnknown { /// Interface providing methods and properties for finding and navigating through text in the web view. -/// This interface allows for text searches, navigation between matches, and customization of the find UI. +/// This interface allows for finding text, navigation between matches, and customization of the find UI. // MSOWNERS: core (maxwellmyers@microsoft.com) -[uuid(b21617e6-34a1-516d-846c-5615516afa90), object, pointer_default(unique)] +[uuid(9c494a0a-c5d8-5fee-b7e6-4926d8d7b391), object, pointer_default(unique)] interface ICoreWebView2StagingFind : IUnknown { /// Retrieves the index of the currently active match in the find session. Returns the index of the currently active match, or -1 if there is no active match. // MSOWNERS: core (maxwellmyers@microsoft.com) [propget] HRESULT ActiveMatchIndex([out, retval] UINT32* value); - /// Gets the total count of matches found in the current document based on the last search criteria. Returns the total count of matches. + /// Gets the total count of matches found in the current document based on the last find sessions criteria. Returns the total count of matches. // MSOWNERS: core (maxwellmyers@microsoft.com) [propget] HRESULT MatchCount([out, retval] UINT32* value); @@ -361,47 +361,47 @@ interface ICoreWebView2StagingFind : IUnknown { [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); - /// Gets the `SuppressDefaultDialog` property. + /// Gets the `SuppressDefaultFindDialog` property. // MSOWNERS: core (maxwellmyers@microsoft.com) - [propget] HRESULT SuppressDefaultDialog([out, retval] BOOL* value); + [propget] HRESULT SuppressDefaultFindDialog([out, retval] BOOL* value); /// Checks if a custom user interface is desired by the end developer. Returns TRUE if using a custom UI, FALSE if using the default. // MSOWNERS: core (maxwellmyers@microsoft.com) - [propput] HRESULT SuppressDefaultDialog([in] BOOL value); + [propput] HRESULT SuppressDefaultFindDialog([in] BOOL value); - /// Adds an event handler for the `FindActiveMatchIndexChanged` event. + /// Adds an event handler for the `ActiveMatchIndexChanged` event. /// Registers an event handler for the ActiveMatchIndexChanged event. This event is raised when the index of the currently active match changes. This can happen when the user navigates to a different match or when the active match is changed programmatically. The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. // MSOWNERS: core (maxwellmyers@microsoft.com) - HRESULT add_FindActiveMatchIndexChanged( - [in] ICoreWebView2StagingFindActiveMatchIndexChangedEventHandler* eventHandler, + HRESULT add_ActiveMatchIndexChanged( + [in] ICoreWebView2StagingActiveMatchIndexChangedEventHandler* eventHandler, [out] EventRegistrationToken* token); - /// Removes an event handler previously added with `add_FindActiveMatchIndexChanged`. + /// Removes an event handler previously added with `add_ActiveMatchIndexChanged`. // MSOWNERS: core (maxwellmyers@microsoft.com) - HRESULT remove_FindActiveMatchIndexChanged( + HRESULT remove_ActiveMatchIndexChanged( [in] EventRegistrationToken token); - /// Adds an event handler for the `FindMatchCountChanged` event. - /// Registers an event handler for the MatchCountChanged event. This event is raised when the total count of matches in the document changes due to a new search operation or changes in the document. The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. + /// Adds an event handler for the `MatchCountChanged` event. + /// Registers an event handler for the MatchCountChanged event. This event is raised when the total count of matches in the document changes due to a new find operation or changes in the document. The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. // MSOWNERS: core (maxwellmyers@microsoft.com) - HRESULT add_FindMatchCountChanged( - [in] ICoreWebView2StagingFindMatchCountChangedEventHandler* eventHandler, + HRESULT add_MatchCountChanged( + [in] ICoreWebView2StagingMatchCountChangedEventHandler* eventHandler, [out] EventRegistrationToken* token); - /// Removes an event handler previously added with `add_FindMatchCountChanged`. + /// Removes an event handler previously added with `add_MatchCountChanged`. // MSOWNERS: core (maxwellmyers@microsoft.com) - HRESULT remove_FindMatchCountChanged( + HRESULT remove_MatchCountChanged( [in] EventRegistrationToken token); - /// Initiates a search using the specified configuration. - /// Displays the Find bar and starts the search operation. If a search was already ongoing, it will be stopped and replaced with this new instance. - /// If called with an empty string, the Find bar is displayed but no search occurs. Changing the configuration object after initiation won't affect the ongoing search. - /// To change the ongoing search, StartFind must be called again with a new or modified configuration object. - /// This method is primarily designed for HTML document searches. + /// Initiates a find using the specified configuration. + /// Displays the Find bar and starts the find operation. If a find session was already ongoing, it will be stopped and replaced with this new instance. + /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the configuration object after initiation won't affect the ongoing find session. + /// To change the ongoing find session, StartFind must be called again with a new or modified configuration object. + /// This method is primarily designed for HTML document queries. // MSOWNERS: core (maxwellmyers@microsoft.com) HRESULT StartFind( [in] ICoreWebView2StagingFindConfiguration* configuration @@ -556,18 +556,18 @@ namespace Microsoft.Web.WebView2.Core runtimeclass CoreWebView2Find : [default]ICoreWebView2Find {} /// Interface providing methods and properties for finding and navigating through text in the web view. - /// This interface allows for text searches, navigation between matches, and customization of the find UI. + /// This interface allows for finding text, navigation between matches, and customization of the find UI. [com_interface("staging=ICoreWebView2StagingFind")] [ms_owner("core", "maxwellmyers@microsoft.com")] [availability("staging")] interface ICoreWebView2Find { [completed_handler("")] - /// Initiates a search using the specified configuration. - /// Displays the Find bar and starts the search operation. If a search was already ongoing, it will be stopped and replaced with this new instance. - /// If called with an empty string, the Find bar is displayed but no search occurs. Changing the configuration object after initiation won't affect the ongoing search. - /// To change the ongoing search, StartFind must be called again with a new or modified configuration object. - /// This method is primarily designed for HTML document searches. + /// Initiates a find using the specified configuration. + /// Displays the Find bar and starts the find operation. If a find session was already ongoing, it will be stopped and replaced with this new instance. + /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the configuration object after initiation won't affect the ongoing find session. + /// To change the ongoing find session, StartFind must be called again with a new or modified configuration object. + /// This method is primarily designed for HTML document queries. Windows.Foundation.IAsyncAction StartFindAsync(CoreWebView2FindConfiguration configuration); /// Navigates to the next match in the document. @@ -583,21 +583,26 @@ namespace Microsoft.Web.WebView2.Core Boolean ShouldHighlightAllMatches { get; set; }; /// Checks if a custom user interface is desired by the end developer. Returns TRUE if using a custom UI, FALSE if using the default. - Boolean SuppressDefaultDialog { get; set; }; + Boolean SuppressDefaultFindDialog { get; set; }; /// Retrieves the index of the currently active match in the find session. Returns the index of the currently active match, or -1 if there is no active match. - UInt32 ActiveMatchIndex { get; }; + Int32 ActiveMatchIndex { get; }; - /// Gets the total count of matches found in the current document based on the last search criteria. Returns the total count of matches. - UInt32 MatchCount { get; }; + /// Gets the total count of matches found in the current document based on the last find sessions criteria. Returns the total count of matches. + Int32 MatchCount { get; }; - /// Registers an event handler for the MatchCountChanged event. This event is raised when the total count of matches in the document changes due to a new search operation or changes in the document. The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. + /// Registers an event handler for the MatchCountChanged event. + This event is raised when the total count of matches in the document changes due to a new find operation or changes in the document. + The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. [event_handler("", "", "")] - event Windows.Foundation.TypedEventHandler FindMatchCountChanged; + event Windows.Foundation.TypedEventHandler MatchCountChanged; - /// Registers an event handler for the ActiveMatchIndexChanged event. This event is raised when the index of the currently active match changes. This can happen when the user navigates to a different match or when the active match is changed programmatically. The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. + /// Registers an event handler for the ActiveMatchIndexChanged event. This event is raised when the index of the currently active match changes. + This can happen when the user navigates to a different match or when the active match is changed programmatically. + The parameter is the event handler to be added. Returns a token representing the added event handler. + This token can be used to unregister the event handler. [event_handler("", "", "")] - event Windows.Foundation.TypedEventHandler FindActiveMatchIndexChanged; + event Windows.Foundation.TypedEventHandler ActiveMatchIndexChanged; }; } ``` From 374292a424f862c7321a087804b0edf182caeb1f Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 3 May 2024 08:42:15 -0700 Subject: [PATCH 47/80] Update FindOnPage.md Co-authored-by: David Risney --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index c9547aac9..b7ba9c58c 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -582,7 +582,7 @@ namespace Microsoft.Web.WebView2.Core /// Gets or sets the state of whether all matches are highlighted. Returns TRUE if all matches are highlighted, FALSE otherwise. Boolean ShouldHighlightAllMatches { get; set; }; - /// Checks if a custom user interface is desired by the end developer. Returns TRUE if using a custom UI, FALSE if using the default. + /// Set this property to hide the default Find UI. You can use this to hide the default UI so that you can show your own custom UI or programmatically interact with the Find API while showing no Find UI. Returns TRUE if hiding the default Find UI and FALSE if using showing the default Find UI. Boolean SuppressDefaultFindDialog { get; set; }; /// Retrieves the index of the currently active match in the find session. Returns the index of the currently active match, or -1 if there is no active match. From e5cde967226f7e206da8d9ae62db86998326ceb5 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 3 May 2024 12:17:17 -0700 Subject: [PATCH 48/80] Changed search to find --- FindOnPage.md | 50 +++++++++++++++++++++++++------------------------- 1 file changed, 25 insertions(+), 25 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index b7ba9c58c..0e88ae85c 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -5,7 +5,7 @@ The WebView2Find API offers methods and events for text finding and navigation within a WebView2 control. It enables developers to programmatically initiate find operations, navigate find results, suppress default UI, and customize find configurations -like query and search direction. It also tracks the status of operations, indicating +like query and find direction. It also tracks the status of operations, indicating completion, match count changes, and match index changes. ## Examples @@ -14,7 +14,7 @@ completion, match count changes, and match index changes. #### Description To initiate a find operation in a WebView2 control, use the `StartFind` method. -This method allows setting the search term and find parameters via the +This method allows setting the find term and find parameters via the `ICoreWebView2FindConfiguration` interface. Only one find session can be active per webview environment. Starting another with the same configuration will adjust the active match index based on the selected Find Direction. @@ -24,7 +24,7 @@ the active match index based on the selected Find Direction. ```cpp //! [InitializeFindConfiguration] -wil::com_ptr AppWindow::InitializeFindConfiguration(const std::wstring& searchTerm) +wil::com_ptr AppWindow::InitializeFindConfiguration(const std::wstring& findTerm) { // Query for the ICoreWebView2Environment5 interface. auto webView2Environment5 = m_webViewEnvironment.try_query(); @@ -33,7 +33,7 @@ wil::com_ptr AppWindow::InitializeFindConfigurat // Initialize find configuration/settings wil::com_ptr findConfiguration; CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); - CHECK_FAILURE(findConfiguration->put_FindTerm(searchTerm.c_str())); + CHECK_FAILURE(findConfiguration->put_FindTerm(findTerm.c_str())); CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(false)); CHECK_FAILURE(findConfiguration->put_ShouldMatchWord(false)); CHECK_FAILURE(findConfiguration->put_FindDirection(COREWEBVIEW2_FIND_DIRECTION_FORWARD)); @@ -49,9 +49,9 @@ wil::com_ptr AppWindow::InitializeFindConfigurat ```cpp //! [ExecuteFindWithDefaultUI] -bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) +bool AppWindow::ConfigureAndExecuteFind(const std::wstring& findTerm) { - auto findConfiguration = InitializeFindConfiguration(searchTerm); + auto findConfiguration = InitializeFindConfiguration(findTerm); if (!findConfiguration) { return false; @@ -93,9 +93,9 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& searchTerm) ```cpp //! [ExecuteFindWithCustomUI] -bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& searchTerm) +bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& findTerm) { - auto findConfiguration = InitializeFindConfiguration(searchTerm); + auto findConfiguration = InitializeFindConfiguration(findTerm); if (!findConfiguration) { return false; @@ -124,7 +124,7 @@ bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& searchTerm) } else { - // Handle errors or unsuccessful search. + // Handle errors or unsuccessful find. } return S_OK; }).Get())); @@ -142,7 +142,7 @@ bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& searchTerm) #### .NET C# ```csharp //! [ConfigureAndExecuteFindWithDefaultUI] -async Task ConfigureAndExecuteFindWithDefaultUIAsync(string searchTerm) +async Task ConfigureAndExecuteFindWithDefaultUIAsync(string findTerm) { try { @@ -155,7 +155,7 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string searchTerm) // Initialize the find configuration with specified settings. var findConfiguration = new CoreWebView2FindConfiguration { - FindTerm = searchTerm, + FindTerm = findTerm, IsCaseSensitive = false, ShouldMatchWord = false, FindDirection = CoreWebView2FindDirection.Forward @@ -181,7 +181,7 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string searchTerm) ```csharp //! [ConfigureAndExecuteFindWithCustomUI] -async Task ConfigureAndExecuteFindWithCustomUIAsync(string searchTerm) +async Task ConfigureAndExecuteFindWithCustomUIAsync(string findTerm) { try { @@ -194,7 +194,7 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string searchTerm) // Initialize the find configuration with specified settings. var findConfiguration = new CoreWebView2FindConfiguration { - FindTerm = searchTerm, + FindTerm = findTerm, IsCaseSensitive = false, ShouldMatchWord = false, FindDirection = CoreWebView2FindDirection.Forward @@ -282,13 +282,13 @@ void ActiveMatchIndexChangedSample() ## API Details ```cpp -/// Specifies the direction of Search Parameters. +/// Specifies the direction of find Parameters. // MSOWNERS: core (maxwellmyers@microsoft.com) [v1_enum] typedef enum COREWEBVIEW2_FIND_DIRECTION { - /// Specifies a forward search in the document. + /// Specifies a forward find in the document. COREWEBVIEW2_FIND_DIRECTION_FORWARD, - /// Specifies a backwards search in the document. + /// Specifies a backwards find in the document. COREWEBVIEW2_FIND_DIRECTION_BACKWARD, } COREWEBVIEW2_FIND_DIRECTION; @@ -299,7 +299,7 @@ typedef enum COREWEBVIEW2_FIND_DIRECTION { [uuid(f10bddd3-bb59-5d5b-8748-8a1a53f65d0c), object, pointer_default(unique)] interface ICoreWebView2StagingEnvironment5 : IUnknown { /// Creates a new instance of a FindConfiguration object. - /// This configuration object can be used to define parameters for a search operation. + /// This configuration object can be used to define parameters for a find operation. /// Returns the newly created FindConfiguration object. // MSOWNERS: core (maxwellmyers@microsoft.com) HRESULT CreateFindConfiguration( @@ -429,7 +429,7 @@ interface ICoreWebView2StagingFind : IUnknown { /// Interface defining the find configuration. -/// This interface provides the necessary methods and properties to configure a search operation. +/// This interface provides the necessary methods and properties to configure a find operation. // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(52a04b23-acc8-5659-aa2f-26dbe9faafde), object, pointer_default(unique)] interface ICoreWebView2StagingFindConfiguration : IUnknown { @@ -523,31 +523,31 @@ namespace Microsoft.Web.WebView2.Core ```csharp namespace Microsoft.Web.WebView2.Core { - /// Specifies the direction of Search Parameters. + /// Specifies the direction of find Parameters. [ms_owner("core", "maxwellmyers@microsoft.com")] [availability("staging")] enum CoreWebView2FindDirection { - /// Specifies a forward search in the document. + /// Specifies a forward find in the document. Forward, - /// Specifies a backwards search in the document. + /// Specifies a backwards find in the document. Backward, }; runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfiguration {} /// Interface defining the find configuration. - /// This interface provides the necessary methods and properties to configure a search operation. + /// This interface provides the necessary methods and properties to configure a find operation. [com_interface("staging=ICoreWebView2StagingFindConfiguration")] [ms_owner("core", "maxwellmyers@microsoft.com")] [availability("staging")] interface ICoreWebView2FindConfiguration { - // Gets or sets the search term used for the find operation. Returns the search term. + // Gets or sets the find term used for the find operation. Returns the find term. String FindTerm { get; set; }; - // Gets or sets the direction of the search operation (forward or backward). Returns the search direction. + // Gets or sets the direction of the find operation (forward or backward). Returns the find direction. CoreWebView2FindDirection FindDirection { get; set; }; - // Determines if the search operation is case sensitive. Returns TRUE if the search is case sensitive, FALSE otherwise. + // Determines if the find operation is case sensitive. Returns TRUE if the find is case sensitive, FALSE otherwise. Boolean IsCaseSensitive { get; set; }; // Determines if only whole words should be matched during the find operation. Returns TRUE if only whole words should be matched, FALSE otherwise. Boolean ShouldMatchWord { get; set; }; From 1315049c3f72b904b83fd2bb9140657ec4572bbf Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 3 May 2024 12:32:18 -0700 Subject: [PATCH 49/80] Update FindOnPage.md Updated additional info --- FindOnPage.md | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 0e88ae85c..67543c37b 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -615,6 +615,12 @@ It emphasizes the usage of interfaces such as `ICoreWebView2Find` and `ICoreWebView2FindConfiguration` to perform find operations effectively. Additional Info: -Starting a find session when one is in progress will result in the active match index -being moved forward or backwards depending on what find configuration has been used -(forward,backward). +When initiating a find session while another session is in progress, the behavior of +the active match index depends on the direction set for the find operation (forward or backward). +However, calling StartFind again during an ongoing find operation does not resume from the point +of the current active match. For example, given the text "1 1 A 1 1" and initiating a find session for "A", + then starting another find session for "1", it will start searching from the beginning of the document, +regardless of the previous active match. This behavior indicates that changing the find query initiates a +completely new find session, rather than continuing from the previous match index. This distinction is essential +to understand when utilizing the StartFind method for navigating through text matches. + From 0f40d23b13285c70138a19eeef7e9ed23ddd72bf Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 3 May 2024 12:34:36 -0700 Subject: [PATCH 50/80] Update FindOnPage.md Updated supress def dialog and should highlight --- FindOnPage.md | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 67543c37b..3d5cccca7 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -579,12 +579,22 @@ namespace Microsoft.Web.WebView2.Core /// Stops the current 'Find' operation and hides the Find bar. void StopFind(); - /// Gets or sets the state of whether all matches are highlighted. Returns TRUE if all matches are highlighted, FALSE otherwise. + /// Gets or sets the state of whether all matches are highlighted. + /// Returns TRUE if all matches are highlighted, FALSE otherwise. + /// Note: Changes to this property take effect only when StartFind, FindNext, or FindPrevious is called. + /// Preferences for the session cannot be updated unless another call to the StartFind function on the server-side is made. + /// Therefore, changes will not take effect until one of these functions is called. Boolean ShouldHighlightAllMatches { get; set; }; - - /// Set this property to hide the default Find UI. You can use this to hide the default UI so that you can show your own custom UI or programmatically interact with the Find API while showing no Find UI. Returns TRUE if hiding the default Find UI and FALSE if using showing the default Find UI. + + /// Sets this property to hide the default Find UI. + /// You can use this to hide the default UI so that you can show your own custom UI or programmatically interact with the Find API while showing no Find UI. + /// Returns TRUE if hiding the default Find UI and FALSE if using showing the default Find UI. + /// Note: Changes to this property take effect only when StartFind, FindNext, or FindPrevious is called. + /// Preferences for the session cannot be updated unless another call to the StartFind function on the server-side is made. + /// Therefore, changes will not take effect until one of these functions is called. Boolean SuppressDefaultFindDialog { get; set; }; + /// Retrieves the index of the currently active match in the find session. Returns the index of the currently active match, or -1 if there is no active match. Int32 ActiveMatchIndex { get; }; From 9e9f9958c50f595b7bad5d3d3f591fa04ddf4634 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 3 May 2024 12:35:39 -0700 Subject: [PATCH 51/80] Update FindOnPage.md Updated stopfind description/documentation --- FindOnPage.md | 1 + 1 file changed, 1 insertion(+) diff --git a/FindOnPage.md b/FindOnPage.md index 3d5cccca7..e1abc02a9 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -577,6 +577,7 @@ namespace Microsoft.Web.WebView2.Core void FindPrevious(); /// Stops the current 'Find' operation and hides the Find bar. + /// If called with no Find session active, it will silently do nothing. void StopFind(); /// Gets or sets the state of whether all matches are highlighted. From 6dd9024db0eece2777a68f82ec2674354623d348 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 3 May 2024 12:37:14 -0700 Subject: [PATCH 52/80] Update FindOnPage.md updated find next and previous --- FindOnPage.md | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index e1abc02a9..cf89c1408 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -571,11 +571,18 @@ namespace Microsoft.Web.WebView2.Core Windows.Foundation.IAsyncAction StartFindAsync(CoreWebView2FindConfiguration configuration); /// Navigates to the next match in the document. + /// Note: If called when there is no find operation in progress, FindNext will start a new find session. + /// If there are no matches to find, FindNext will wrap around to the first match if the search direction is forward, + /// or to the last match if the search direction is backward. void FindNext(); - + /// Navigates to the previous match in the document. + /// Note: If called when there is no find operation in progress, FindPrevious will start a new find session. + /// If there are no matches to find, FindPrevious will wrap around to the last match if the search direction is forward, + /// or to the first match if the search direction is backward. void FindPrevious(); + /// Stops the current 'Find' operation and hides the Find bar. /// If called with no Find session active, it will silently do nothing. void StopFind(); From 24c70afc2f438940869a8f57939f039aa5cdc5b8 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 3 May 2024 12:38:33 -0700 Subject: [PATCH 53/80] Update FindOnPage.md start find async --- FindOnPage.md | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index cf89c1408..9c3d3af32 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -563,13 +563,17 @@ namespace Microsoft.Web.WebView2.Core interface ICoreWebView2Find { [completed_handler("")] - /// Initiates a find using the specified configuration. + /// Initiates a find using the specified configuration asynchronously. /// Displays the Find bar and starts the find operation. If a find session was already ongoing, it will be stopped and replaced with this new instance. /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the configuration object after initiation won't affect the ongoing find session. - /// To change the ongoing find session, StartFind must be called again with a new or modified configuration object. + /// To change the ongoing find session, StartFindAsync must be called again with a new or modified configuration object. /// This method is primarily designed for HTML document queries. + /// Note: The asynchronous action completes when the UI has been displayed with the find term in the UI bar, and the matches have populated on the counter on the find bar. + /// There may be a slight latency between the UI display and the matches populating in the counter. + /// The MatchCountChanged and ActiveMatchIndexChanged events are only raised after StartFindAsync has completed, otherwise they will have their default values (-1 for both). Windows.Foundation.IAsyncAction StartFindAsync(CoreWebView2FindConfiguration configuration); + /// Navigates to the next match in the document. /// Note: If called when there is no find operation in progress, FindNext will start a new find session. /// If there are no matches to find, FindNext will wrap around to the first match if the search direction is forward, From db2d318563bf7a07b276e4dac21c4b13696dc43f Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 6 May 2024 12:10:55 -0700 Subject: [PATCH 54/80] Update FindOnPage.md Added info to startfind, added /// for documentation of matchcountchanged events, addressed case sensitivity question --- FindOnPage.md | 39 +++++++++++++++++++++------------------ 1 file changed, 21 insertions(+), 18 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 9c3d3af32..bdf60b94d 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -543,11 +543,14 @@ namespace Microsoft.Web.WebView2.Core [availability("staging")] interface ICoreWebView2FindConfiguration { - // Gets or sets the find term used for the find operation. Returns the find term. + /// Gets or sets the find term used for the find operation. Returns the find term. String FindTerm { get; set; }; - // Gets or sets the direction of the find operation (forward or backward). Returns the find direction. + /// Gets or sets the direction of the find operation (forward or backward). Returns the find direction. CoreWebView2FindDirection FindDirection { get; set; }; - // Determines if the find operation is case sensitive. Returns TRUE if the find is case sensitive, FALSE otherwise. + /// Determines if the find operation is case sensitive. Returns TRUE if the find is case sensitive, FALSE otherwise. + /// In text operations such as case sensitivity and word breaking, the behavior can vary by locale, which may be influenced by both the browser's UI locale and the document's language settings. The browser's UI locale + /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration + /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content Boolean IsCaseSensitive { get; set; }; // Determines if only whole words should be matched during the find operation. Returns TRUE if only whole words should be matched, FALSE otherwise. Boolean ShouldMatchWord { get; set; }; @@ -567,10 +570,19 @@ namespace Microsoft.Web.WebView2.Core /// Displays the Find bar and starts the find operation. If a find session was already ongoing, it will be stopped and replaced with this new instance. /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the configuration object after initiation won't affect the ongoing find session. /// To change the ongoing find session, StartFindAsync must be called again with a new or modified configuration object. - /// This method is primarily designed for HTML document queries. + /// StartFind supports, HTML, PDF, and TXT document queries. In general this api is designed for text based find sessions. + //// If you start a find session programmatically on another file format that doesnt have text fields, the find session will try to execute but will fail to find any matches. (It will silently fail) /// Note: The asynchronous action completes when the UI has been displayed with the find term in the UI bar, and the matches have populated on the counter on the find bar. /// There may be a slight latency between the UI display and the matches populating in the counter. /// The MatchCountChanged and ActiveMatchIndexChanged events are only raised after StartFindAsync has completed, otherwise they will have their default values (-1 for both). + /// When initiating a find session while another session is in progress, the behavior of + /// the active match index depends on the direction set for the find operation (forward or backward). + /// However, calling StartFind again during an ongoing find operation does not resume from the point + /// of the current active match. For example, given the text "1 1 A 1 1" and initiating a find session for "A", + /// then starting another find session for "1", it will start searching from the beginning of the document, + /// regardless of the previous active match. This behavior indicates that changing the find query initiates a + /// completely new find session, rather than continuing from the previous match index. This distinction is essential + /// to understand when utilizing the StartFind method for navigating through text matches. Windows.Foundation.IAsyncAction StartFindAsync(CoreWebView2FindConfiguration configuration); @@ -614,15 +626,15 @@ namespace Microsoft.Web.WebView2.Core Int32 MatchCount { get; }; /// Registers an event handler for the MatchCountChanged event. - This event is raised when the total count of matches in the document changes due to a new find operation or changes in the document. - The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. + /// This event is raised when the total count of matches in the document changes due to a new find operation or changes in the document. + /// The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. [event_handler("", "", "")] event Windows.Foundation.TypedEventHandler MatchCountChanged; /// Registers an event handler for the ActiveMatchIndexChanged event. This event is raised when the index of the currently active match changes. - This can happen when the user navigates to a different match or when the active match is changed programmatically. - The parameter is the event handler to be added. Returns a token representing the added event handler. - This token can be used to unregister the event handler. + /// This can happen when the user navigates to a different match or when the active match is changed programmatically. + /// The parameter is the event handler to be added. Returns a token representing the added event handler. + /// This token can be used to unregister the event handler. [event_handler("", "", "")] event Windows.Foundation.TypedEventHandler ActiveMatchIndexChanged; }; @@ -636,13 +648,4 @@ to integrate text finding and navigation functionalities into WebView2 applicati It emphasizes the usage of interfaces such as `ICoreWebView2Find` and `ICoreWebView2FindConfiguration` to perform find operations effectively. -Additional Info: -When initiating a find session while another session is in progress, the behavior of -the active match index depends on the direction set for the find operation (forward or backward). -However, calling StartFind again during an ongoing find operation does not resume from the point -of the current active match. For example, given the text "1 1 A 1 1" and initiating a find session for "A", - then starting another find session for "1", it will start searching from the beginning of the document, -regardless of the previous active match. This behavior indicates that changing the find query initiates a -completely new find session, rather than continuing from the previous match index. This distinction is essential -to understand when utilizing the StartFind method for navigating through text matches. From 57389cf0395e267df549aeec5ddb4352eac7eae1 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 13 May 2024 11:28:38 -0700 Subject: [PATCH 55/80] Update FindOnPage.md --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index bdf60b94d..1e1fa3664 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -385,7 +385,7 @@ interface ICoreWebView2StagingFind : IUnknown { [in] EventRegistrationToken token); /// Adds an event handler for the `MatchCountChanged` event. - /// Registers an event handler for the MatchCountChanged event. This event is raised when the total count of matches in the document changes due to a new find operation or changes in the document. The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. + /// Registers an event handler for the MatchCountChanged event. This event is raised when the total count of matches in the document changes due to a new find operation or changes in the document. /// The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. // MSOWNERS: core (maxwellmyers@microsoft.com) HRESULT add_MatchCountChanged( [in] ICoreWebView2StagingMatchCountChangedEventHandler* eventHandler, From b9a14b62d1469af09dc3b367a305cb9b35278b92 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 13 May 2024 14:09:31 -0700 Subject: [PATCH 56/80] changed shouldhighlight and supress dialiog --- FindOnPage.md | 47 ++++++++++++++++++++++++++--------------------- 1 file changed, 26 insertions(+), 21 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 1e1fa3664..958334a98 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -534,7 +534,7 @@ namespace Microsoft.Web.WebView2.Core Backward, }; - runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfiguration {} +runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfiguration {} /// Interface defining the find configuration. /// This interface provides the necessary methods and properties to configure a find operation. @@ -545,18 +545,39 @@ namespace Microsoft.Web.WebView2.Core { /// Gets or sets the find term used for the find operation. Returns the find term. String FindTerm { get; set; }; + /// Gets or sets the direction of the find operation (forward or backward). Returns the find direction. CoreWebView2FindDirection FindDirection { get; set; }; + /// Determines if the find operation is case sensitive. Returns TRUE if the find is case sensitive, FALSE otherwise. - /// In text operations such as case sensitivity and word breaking, the behavior can vary by locale, which may be influenced by both the browser's UI locale and the document's language settings. The browser's UI locale + /// When toggling case sensitivity, the behavior can vary by locale, which may be influenced by both the browser's UI locale and the document's language settings. The browser's UI locale /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration - /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content + /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content. Boolean IsCaseSensitive { get; set; }; - // Determines if only whole words should be matched during the find operation. Returns TRUE if only whole words should be matched, FALSE otherwise. + + /// Similar to case sensitivity, word matching also can vary by locale, which may be influenced by both the browser's UI locale and the document's language settings. The browser's UI locale + /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration + /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content. + /// ShouldMatchWord determines if only whole words should be matched during the find operation. Returns TRUE if only whole words should be matched, FALSE otherwise. Boolean ShouldMatchWord { get; set; }; + + /// Gets or sets the state of whether all matches are highlighted. + /// Returns TRUE if all matches are highlighted, FALSE otherwise. + /// Note: Changes to this property take effect only when StartFind, FindNext, or FindPrevious is called. + /// Preferences for the session cannot be updated unless another call to the StartFind function on the server-side is made. + /// Therefore, changes will not take effect until one of these functions is called. + Boolean ShouldHighlightAllMatches { get; set; }; + + /// Sets this property to hide the default Find UI. + /// You can use this to hide the default UI so that you can show your own custom UI or programmatically interact with the Find API while showing no Find UI. + /// Returns TRUE if hiding the default Find UI and FALSE if using showing the default Find UI. + /// Note: Changes to this property take effect only when StartFind, FindNext, or FindPrevious is called. + /// Preferences for the session cannot be updated unless another call to the StartFind function on the server-side is made. + /// Therefore, changes will not take effect until one of these functions is called. + Boolean SuppressDefaultFindDialog { get; set; }; }; - runtimeclass CoreWebView2Find : [default]ICoreWebView2Find {} + runtimeclass CoreWebView2Find : [default]ICoreWebView2Find {} /// Interface providing methods and properties for finding and navigating through text in the web view. /// This interface allows for finding text, navigation between matches, and customization of the find UI. @@ -603,22 +624,6 @@ namespace Microsoft.Web.WebView2.Core /// If called with no Find session active, it will silently do nothing. void StopFind(); - /// Gets or sets the state of whether all matches are highlighted. - /// Returns TRUE if all matches are highlighted, FALSE otherwise. - /// Note: Changes to this property take effect only when StartFind, FindNext, or FindPrevious is called. - /// Preferences for the session cannot be updated unless another call to the StartFind function on the server-side is made. - /// Therefore, changes will not take effect until one of these functions is called. - Boolean ShouldHighlightAllMatches { get; set; }; - - /// Sets this property to hide the default Find UI. - /// You can use this to hide the default UI so that you can show your own custom UI or programmatically interact with the Find API while showing no Find UI. - /// Returns TRUE if hiding the default Find UI and FALSE if using showing the default Find UI. - /// Note: Changes to this property take effect only when StartFind, FindNext, or FindPrevious is called. - /// Preferences for the session cannot be updated unless another call to the StartFind function on the server-side is made. - /// Therefore, changes will not take effect until one of these functions is called. - Boolean SuppressDefaultFindDialog { get; set; }; - - /// Retrieves the index of the currently active match in the find session. Returns the index of the currently active match, or -1 if there is no active match. Int32 ActiveMatchIndex { get; }; From 0d2f601f2c129964e1ca1dfc47ddf534e0977db1 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 13 May 2024 14:14:05 -0700 Subject: [PATCH 57/80] Update FindOnPage.md updated behavior for find previous and find next --- FindOnPage.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 958334a98..a6c789b16 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -608,15 +608,15 @@ runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfigura /// Navigates to the next match in the document. - /// Note: If called when there is no find operation in progress, FindNext will start a new find session. /// If there are no matches to find, FindNext will wrap around to the first match if the search direction is forward, /// or to the last match if the search direction is backward. + /// If called when there is no find session active, FindPrevious will silently fail. void FindNext(); /// Navigates to the previous match in the document. - /// Note: If called when there is no find operation in progress, FindPrevious will start a new find session. /// If there are no matches to find, FindPrevious will wrap around to the last match if the search direction is forward, /// or to the first match if the search direction is backward. + /// If called when there is no find session active, FindPrevious will silently fail. void FindPrevious(); From 99a713fb09792645d3e68e599298e5dcbb3a9061 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 13 May 2024 14:17:58 -0700 Subject: [PATCH 58/80] Update FindOnPage.md --- FindOnPage.md | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index a6c789b16..4b661f7c7 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -64,9 +64,8 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& findTerm) wil::com_ptr webView2Find; CHECK_FAILURE(webView2_17->get_Find(&webView2Find)); - // Assuming you want to use the default UI, adjust as necessary. - CHECK_FAILURE(webView2Find->put_SuppressDefaultDialog(false)); - CHECK_FAILURE(webView2Find->put_ShouldHighlightAllMatches(true)); + // By default Find will use the default UI and highlight all matches. If you want different behavior + // you can change the SuppressDefaultDialog and ShouldHighlightAllMatches properties here. // Start the find operation with a callback for completion. CHECK_FAILURE(webView2Find->StartFind( @@ -110,7 +109,6 @@ bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& findTerm) // Opt for using a custom UI for the find operation. CHECK_FAILURE(webView2Find->put_SuppressDefaultDialog(true)); - CHECK_FAILURE(webView2find->put_ShouldHighlightAllMatches(true)); // Start the find operation with callback for completion. CHECK_FAILURE(webView2Find->StartFind( @@ -161,9 +159,8 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string findTerm) FindDirection = CoreWebView2FindDirection.Forward }; - // Use the default UI provided by WebView2 for the find operation. - webView.CoreWebView2.FindController.SuppressDefaultDialog = false; - webView.CoreWebView2.FindController.ShouldHighlightAllMatches = true; + // By default Find will use the default UI and highlight all matches. If you want different behavior + // you can change the SuppressDefaultDialog and ShouldHighlightAllMatches properties here. // Start the find operation with the specified configuration. await webView.CoreWebView2.FindController.StartFindAsync(findConfiguration); From 6ccdf1790d80d324adac59c007b40130ea7fc39d Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 13 May 2024 14:20:33 -0700 Subject: [PATCH 59/80] Update FindOnPage.md Changed Find Controller --- FindOnPage.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 4b661f7c7..8b0f6eb5a 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -163,7 +163,7 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string findTerm) // you can change the SuppressDefaultDialog and ShouldHighlightAllMatches properties here. // Start the find operation with the specified configuration. - await webView.CoreWebView2.FindController.StartFindAsync(findConfiguration); + await webView.CoreWebView2.Find.StartFindAsync(findConfiguration); // End user interaction is handled via UI. } @@ -198,11 +198,11 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string findTerm) }; // Specify that a custom UI will be used for the find operation. - webView.CoreWebView2.FindController.SuppressDefaultDialog = true; - webView.CoreWebView2.FindController.ShouldHighlightAllMatches = true; + webView.CoreWebView2.Find.SuppressDefaultDialog = true; + webView.CoreWebView2.Find.ShouldHighlightAllMatches = true; // Start the find operation with the specified configuration. - await webView.CoreWebView2.FindController.StartFindAsync(findConfiguration); + await webView.CoreWebView2.Find.StartFindAsync(findConfiguration); // It's expected that the custom UI for navigating between matches (next, previous) // and stopping the find operation will be managed by the developer's custom code. } @@ -259,7 +259,7 @@ within a WebView2 control using the `GetActiveMatchIndex` method. //! [GetActiveMatchIndex] public async Task GetActiveMatchIndexAsync() { - var webViewFind = webView.CoreWebView2.FindController; // Assuming webView is your WebView2 control + var webViewFind = webView.CoreWebView2.Find; // Assuming webView is your WebView2 control var activeMatchIndex = webViewFind.ActiveMatchIndex(); MessageBox.Show($"Active Match Index: {activeMatchIndex}", "Find Operation", MessageBoxButton.OK); return activeMatchIndex; @@ -267,9 +267,9 @@ public async Task GetActiveMatchIndexAsync() void ActiveMatchIndexChangedSample() { - webView.CoreWebView2.FindController.ActiveMatchIndexChanged += (object sender, EventArgs args) => + webView.CoreWebView2.Find.ActiveMatchIndexChanged += (object sender, EventArgs args) => { - int activeMatchIndex = webView.CoreWebView2.FindController.ActiveMatchIndex; + int activeMatchIndex = webView.CoreWebView2.Find.ActiveMatchIndex; // Update Custom UI based on the new active match index. }; } From b20d9a656d4ddbb1d02c5e9172d8d3e5baba01fd Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 13 May 2024 16:39:53 -0700 Subject: [PATCH 60/80] Update FindOnPage.md Co-authored-by: David Risney --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 8b0f6eb5a..943531b38 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -607,7 +607,7 @@ runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfigura /// Navigates to the next match in the document. /// If there are no matches to find, FindNext will wrap around to the first match if the search direction is forward, /// or to the last match if the search direction is backward. - /// If called when there is no find session active, FindPrevious will silently fail. + /// If called when there is no find session active, FindNext will silently fail. void FindNext(); /// Navigates to the previous match in the document. From 4788c42b0bc9e9327b11fd2bb02a5a3c3d34c443 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 13 May 2024 16:40:04 -0700 Subject: [PATCH 61/80] Update FindOnPage.md Co-authored-by: David Risney --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 943531b38..a78904fbe 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -547,7 +547,7 @@ runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfigura CoreWebView2FindDirection FindDirection { get; set; }; /// Determines if the find operation is case sensitive. Returns TRUE if the find is case sensitive, FALSE otherwise. - /// When toggling case sensitivity, the behavior can vary by locale, which may be influenced by both the browser's UI locale and the document's language settings. The browser's UI locale + /// The locale used to determine case sensitivity is the document's language specified by the HTML lang attribute, or if unspecified then the WebView2's UI locale. /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content. Boolean IsCaseSensitive { get; set; }; From d4be4a634c56659a1b89630439fcae37d25621e6 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 13 May 2024 16:41:06 -0700 Subject: [PATCH 62/80] Update FindOnPage.md removed c# section --- FindOnPage.md | 17 ----------------- 1 file changed, 17 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index a78904fbe..4cc05aad1 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -496,24 +496,7 @@ interface ICoreWebView2Staging17 : IUnknown { ### CoreWebView2 Find Configuration and Direction -```csharp -namespace Microsoft.Web.WebView2.Core -{ - public enum CoreWebView2FindDirection - { - Forward, - Backward - } - public class CoreWebView2FindConfiguration - { - public string FindTerm { get; set; } - public CoreWebView2FindDirection FindDirection { get; set; } - public bool IsCaseSensitive { get; set; } - public bool ShouldMatchWord { get; set; } - } -} -``` ### CoreWebView2 Find Interface From aa1a1e5f46228e50c19dff67fb75a52068eee9ef Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 13 May 2024 16:52:28 -0700 Subject: [PATCH 63/80] Update FindOnPage.md --- FindOnPage.md | 30 +++++++++++++++++++++++++++++- 1 file changed, 29 insertions(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 4cc05aad1..870d1643e 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -514,6 +514,29 @@ namespace Microsoft.Web.WebView2.Core Backward, }; + /// + /// Interface responsible for providing access the find operation functionalities in the CoreWebView2. + /// + // MSOWNERS: core (maxwellmyers@microsoft.com) + [uuid(c9a130ca-a807-549c-9d76-8e09ccee3973), object, pointer_default(unique)] + interface ICoreWebView2Staging17 : IUnknown { + /// Retrieves the find operation interface for the current web view. + // MSOWNERS: core (maxwellmyers@microsoft.com) + [propget] HRESULT Find([out, retval] ICoreWebView2StagingFind** value); + } + + /// Interface that provides methods related to the environment settings of CoreWebView2. + /// This interface allows for the creation of new find configuration objects. + [com_interface("staging=ICoreWebView2StagingEnvironment5")] + [ms_owner("core", "maxwellmyers@microsoft.com")] + interface ICoreWebView2Environment15 + { + /// Creates a new instance of a CoreWebView2FindConfiguration object. + /// This configuration object can be used to define parameters for a find operation. + /// Returns the newly created FindConfiguration object. + CoreWebView2FindConfiguration CreateFindConfiguration(); + }; + runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfiguration {} /// Interface defining the find configuration. @@ -623,7 +646,12 @@ runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfigura [event_handler("", "", "")] event Windows.Foundation.TypedEventHandler ActiveMatchIndexChanged; }; -} + + + + + } + } ``` # Appendix From d2b65a2a6acc905ecacebbf1c107d915c3b77393 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 14 May 2024 10:36:18 -0700 Subject: [PATCH 64/80] Update FindOnPage.md updated midl3 definition --- FindOnPage.md | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 870d1643e..f877feb38 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -514,15 +514,15 @@ namespace Microsoft.Web.WebView2.Core Backward, }; - /// - /// Interface responsible for providing access the find operation functionalities in the CoreWebView2. - /// - // MSOWNERS: core (maxwellmyers@microsoft.com) - [uuid(c9a130ca-a807-549c-9d76-8e09ccee3973), object, pointer_default(unique)] - interface ICoreWebView2Staging17 : IUnknown { - /// Retrieves the find operation interface for the current web view. - // MSOWNERS: core (maxwellmyers@microsoft.com) - [propget] HRESULT Find([out, retval] ICoreWebView2StagingFind** value); + /// + /// Interface providing methods to access the find operation functionalities in the CoreWebView2. + /// + [com_interface("staging=ICoreWebView2Staging17")] + [ms_owner("core", "maxwellmyers@microsoft.com")] + interface ICoreWebView2_25 + { + /// Retrieves the find operation interface for the current web view. + CoreWebView2Find Find { get; }; } /// Interface that provides methods related to the environment settings of CoreWebView2. From c40a79bb036398b1b88fd6362a3ba47335dbb74c Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 24 Jul 2024 13:44:18 -0700 Subject: [PATCH 65/80] added 2 default UI screenshots (One with and One without the filtering options) --- FindOnPage.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/FindOnPage.md b/FindOnPage.md index f877feb38..2b6ef1d96 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -10,6 +10,17 @@ completion, match count changes, and match index changes. ## Examples +### Default UI: + +#### Without filter options +![image](https://github.com/user-attachments/assets/a71ba66b-8402-4e9d-a2fa-9437fce4a118) + + + +#### With filter options +![image](https://github.com/user-attachments/assets/9817353b-e758-4b55-8c13-81fd036ec22a) + + #### Description From c0626112d03bf49df59e5ef81d575c2b64548ed3 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 30 Jul 2024 13:19:54 -0700 Subject: [PATCH 66/80] Update FindOnPage.md Co-authored-by: MikeHillberg <18429489+MikeHillberg@users.noreply.github.com> --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 2b6ef1d96..46343c8aa 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -24,7 +24,7 @@ completion, match count changes, and match index changes. #### Description -To initiate a find operation in a WebView2 control, use the `StartFind` method. +To initiate a find operation in a WebView2 control, use the `StartFindAsync` method. This method allows setting the find term and find parameters via the `ICoreWebView2FindConfiguration` interface. Only one find session can be active per webview environment. Starting another with the same configuration will adjust From 18ea6f55ded8c952ffd73d36481fab48f1ab0169 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 30 Jul 2024 13:31:37 -0700 Subject: [PATCH 67/80] Update FindOnPage.md --- FindOnPage.md | 13 ++----------- 1 file changed, 2 insertions(+), 11 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 46343c8aa..34539de66 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -45,9 +45,6 @@ wil::com_ptr AppWindow::InitializeFindConfigurat wil::com_ptr findConfiguration; CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); CHECK_FAILURE(findConfiguration->put_FindTerm(findTerm.c_str())); - CHECK_FAILURE(findConfiguration->put_IsCaseSensitive(false)); - CHECK_FAILURE(findConfiguration->put_ShouldMatchWord(false)); - CHECK_FAILURE(findConfiguration->put_FindDirection(COREWEBVIEW2_FIND_DIRECTION_FORWARD)); // Query for the ICoreWebView2_17 interface to access the Find feature. auto webView2_17 = m_webView.try_query(); @@ -164,10 +161,7 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string findTerm) // Initialize the find configuration with specified settings. var findConfiguration = new CoreWebView2FindConfiguration { - FindTerm = findTerm, - IsCaseSensitive = false, - ShouldMatchWord = false, - FindDirection = CoreWebView2FindDirection.Forward + FindTerm = findTerm }; // By default Find will use the default UI and highlight all matches. If you want different behavior @@ -202,10 +196,7 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string findTerm) // Initialize the find configuration with specified settings. var findConfiguration = new CoreWebView2FindConfiguration { - FindTerm = findTerm, - IsCaseSensitive = false, - ShouldMatchWord = false, - FindDirection = CoreWebView2FindDirection.Forward + FindTerm = findTerm }; // Specify that a custom UI will be used for the find operation. From c4988da6e5750a43c0363cdab039caad781cb721 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 30 Jul 2024 13:38:02 -0700 Subject: [PATCH 68/80] Update FindOnPage.md --- FindOnPage.md | 14 -------------- 1 file changed, 14 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 34539de66..be9b3f87d 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -34,7 +34,6 @@ the active match index based on the selected Find Direction. ```cpp -//! [InitializeFindConfiguration] wil::com_ptr AppWindow::InitializeFindConfiguration(const std::wstring& findTerm) { // Query for the ICoreWebView2Environment5 interface. @@ -52,11 +51,9 @@ wil::com_ptr AppWindow::InitializeFindConfigurat return findConfiguration; } -//! [InitializeFindConfiguration] ``` ```cpp -//! [ExecuteFindWithDefaultUI] bool AppWindow::ConfigureAndExecuteFind(const std::wstring& findTerm) { auto findConfiguration = InitializeFindConfiguration(findTerm); @@ -95,11 +92,9 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& findTerm) // End user interaction is handled via UI. return true; } -//! [ExecuteFindWithDefaultUI] ``` ```cpp -//! [ExecuteFindWithCustomUI] bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& findTerm) { auto findConfiguration = InitializeFindConfiguration(findTerm); @@ -143,11 +138,9 @@ bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& findTerm) return true; } -//! [ExecuteFindWithCustomUI] ``` #### .NET C# ```csharp -//! [ConfigureAndExecuteFindWithDefaultUI] async Task ConfigureAndExecuteFindWithDefaultUIAsync(string findTerm) { try @@ -178,11 +171,9 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string findTerm) Console.WriteLine($"An error occurred: {ex.Message}"); } } -//! [ConfigureAndExecuteFindWithDefaultUI] ``` ```csharp -//! [ConfigureAndExecuteFindWithCustomUI] async Task ConfigureAndExecuteFindWithCustomUIAsync(string findTerm) { try @@ -214,7 +205,6 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string findTerm) Console.WriteLine($"An error occurred: {ex.Message}"); } } -//! [ConfigureAndExecuteFindWithCustomUI] ``` ### Retrieve the Index of the Active Match @@ -225,7 +215,6 @@ within a WebView2 control using the `GetActiveMatchIndex` method. ```cpp - //! [GetActiveMatchIndex] bool AppWindow::GetActiveMatchIndex() { auto webView2_17 = m_webView.try_query(); @@ -243,7 +232,6 @@ within a WebView2 control using the `GetActiveMatchIndex` method. return true; } - //! [GetActiveMatchIndex] // Register ActiveMatchIndexChanged event handler m_webView->add_ActiveMatchIndexChanged( @@ -258,7 +246,6 @@ within a WebView2 control using the `GetActiveMatchIndex` method. ``` #### .NET C# ```csharp -//! [GetActiveMatchIndex] public async Task GetActiveMatchIndexAsync() { var webViewFind = webView.CoreWebView2.Find; // Assuming webView is your WebView2 control @@ -275,7 +262,6 @@ void ActiveMatchIndexChangedSample() // Update Custom UI based on the new active match index. }; } -//! [GetActiveMatchIndex] ``` ## API Details From 99bfd11943f7a5af2e602f1889986b1cbd9444f2 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 30 Jul 2024 13:44:00 -0700 Subject: [PATCH 69/80] Update FindOnPage.md --- FindOnPage.md | 4 ---- 1 file changed, 4 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index be9b3f87d..39a56c606 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -45,10 +45,6 @@ wil::com_ptr AppWindow::InitializeFindConfigurat CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); CHECK_FAILURE(findConfiguration->put_FindTerm(findTerm.c_str())); - // Query for the ICoreWebView2_17 interface to access the Find feature. - auto webView2_17 = m_webView.try_query(); - CHECK_FEATURE_RETURN(webView2_17); - return findConfiguration; } ``` From 6eeaf1e1865eecf0f70cf8a01dc3c02e66693fdd Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 30 Jul 2024 14:40:16 -0700 Subject: [PATCH 70/80] Changed FindConfig -> FindOptions --- FindOnPage.md | 102 +++++++++++++++++++++++++------------------------- 1 file changed, 51 insertions(+), 51 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 39a56c606..e37ca9319 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -4,7 +4,7 @@ The WebView2Find API offers methods and events for text finding and navigation within a WebView2 control. It enables developers to programmatically initiate find -operations, navigate find results, suppress default UI, and customize find configurations +operations, navigate find results, suppress default UI, and customize find options like query and find direction. It also tracks the status of operations, indicating completion, match count changes, and match index changes. @@ -26,34 +26,34 @@ completion, match count changes, and match index changes. To initiate a find operation in a WebView2 control, use the `StartFindAsync` method. This method allows setting the find term and find parameters via the -`ICoreWebView2FindConfiguration` interface. Only one find session can be active per -webview environment. Starting another with the same configuration will adjust +`ICoreWebView2FindOptions` interface. Only one find session can be active per +webview environment. Starting another with the same option will adjust the active match index based on the selected Find Direction. -### Create/Specify a Find Configuration +### Create/Specify a Find Option #### WIN32 C++ ```cpp -wil::com_ptr AppWindow::InitializeFindConfiguration(const std::wstring& findTerm) +wil::com_ptr AppWindow::InitializeFindOptions(const std::wstring& findTerm) { // Query for the ICoreWebView2Environment5 interface. auto webView2Environment5 = m_webViewEnvironment.try_query(); CHECK_FEATURE_RETURN(webView2Environment5); - // Initialize find configuration/settings - wil::com_ptr findConfiguration; - CHECK_FAILURE(webView2Environment5->CreateFindConfiguration(&findConfiguration)); - CHECK_FAILURE(findConfiguration->put_FindTerm(findTerm.c_str())); + // Initialize find options + wil::com_ptr find_options; + CHECK_FAILURE(webView2Environment5->CreateFindOptions(&find_options)); + CHECK_FAILURE(find_options->put_FindTerm(findTerm.c_str())); - return findConfiguration; + return find_options; } ``` ```cpp bool AppWindow::ConfigureAndExecuteFind(const std::wstring& findTerm) { - auto findConfiguration = InitializeFindConfiguration(findTerm); - if (!findConfiguration) + auto find_options = InitializeFindOptions(findTerm); + if (!find_options) { return false; } @@ -70,7 +70,7 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& findTerm) // Start the find operation with a callback for completion. CHECK_FAILURE(webView2Find->StartFind( - findConfiguration.get(), + find_options.get(), Callback( [this](HRESULT result, BOOL status) -> HRESULT { @@ -93,8 +93,8 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& findTerm) ```cpp bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& findTerm) { - auto findConfiguration = InitializeFindConfiguration(findTerm); - if (!findConfiguration) + auto find_options = InitializeFindOptions(findTerm); + if (!find_options) { return false; } @@ -111,7 +111,7 @@ bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& findTerm) // Start the find operation with callback for completion. CHECK_FAILURE(webView2Find->StartFind( - findConfiguration.get(), + find_options.get(), Callback( [this](HRESULT result, BOOL status) -> HRESULT { @@ -147,8 +147,8 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string findTerm) throw new InvalidOperationException("WebView2 is not initialized."); } - // Initialize the find configuration with specified settings. - var findConfiguration = new CoreWebView2FindConfiguration + // Initialize the find options with specified settings. + var find_options = new CoreWebView2FindOptions { FindTerm = findTerm }; @@ -156,8 +156,8 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string findTerm) // By default Find will use the default UI and highlight all matches. If you want different behavior // you can change the SuppressDefaultDialog and ShouldHighlightAllMatches properties here. - // Start the find operation with the specified configuration. - await webView.CoreWebView2.Find.StartFindAsync(findConfiguration); + // Start the find operation with the specified options. + await webView.CoreWebView2.Find.StartFindAsync(find_options); // End user interaction is handled via UI. } @@ -180,8 +180,8 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string findTerm) throw new InvalidOperationException("WebView2 is not initialized."); } - // Initialize the find configuration with specified settings. - var findConfiguration = new CoreWebView2FindConfiguration + // Initialize the find options. + var find_options = new CoreWebView2FindOptions { FindTerm = findTerm }; @@ -190,8 +190,8 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string findTerm) webView.CoreWebView2.Find.SuppressDefaultDialog = true; webView.CoreWebView2.Find.ShouldHighlightAllMatches = true; - // Start the find operation with the specified configuration. - await webView.CoreWebView2.Find.StartFindAsync(findConfiguration); + // Start the find operation with the specified options. + await webView.CoreWebView2.Find.StartFindAsync(find_options); // It's expected that the custom UI for navigating between matches (next, previous) // and stopping the find operation will be managed by the developer's custom code. } @@ -275,16 +275,16 @@ typedef enum COREWEBVIEW2_FIND_DIRECTION { /// Interface that provides methods related to the environment settings of CoreWebView2. -/// This interface allows for the creation of new find configuration objects. +/// This interface allows for the creation of new find options objects. // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(f10bddd3-bb59-5d5b-8748-8a1a53f65d0c), object, pointer_default(unique)] interface ICoreWebView2StagingEnvironment5 : IUnknown { - /// Creates a new instance of a FindConfiguration object. - /// This configuration object can be used to define parameters for a find operation. - /// Returns the newly created FindConfiguration object. + /// Creates a new instance of a FindOptions object. + /// This options object can be used to define parameters for a find operation. + /// Returns the newly created FindOptions object. // MSOWNERS: core (maxwellmyers@microsoft.com) - HRESULT CreateFindConfiguration( - [out, retval] ICoreWebView2StagingFindConfiguration** value + HRESULT CreateFindOptions( + [out, retval] ICoreWebView2StagingFindOptions** value ); @@ -378,14 +378,14 @@ interface ICoreWebView2StagingFind : IUnknown { [in] EventRegistrationToken token); - /// Initiates a find using the specified configuration. + /// Initiates a find using the specified find option. /// Displays the Find bar and starts the find operation. If a find session was already ongoing, it will be stopped and replaced with this new instance. - /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the configuration object after initiation won't affect the ongoing find session. - /// To change the ongoing find session, StartFind must be called again with a new or modified configuration object. + /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the find options object after initiation won't affect the ongoing find session. + /// To change the ongoing find session, Start must be called again with a new or modified find options object. /// This method is primarily designed for HTML document queries. // MSOWNERS: core (maxwellmyers@microsoft.com) HRESULT StartFind( - [in] ICoreWebView2StagingFindConfiguration* configuration + [in] ICoreWebView2StagingFindOptions* options , [in] ICoreWebView2StagingFindStartFindCompletedHandler* handler ); @@ -409,11 +409,11 @@ interface ICoreWebView2StagingFind : IUnknown { -/// Interface defining the find configuration. +/// Interface defining the find options. /// This interface provides the necessary methods and properties to configure a find operation. // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(52a04b23-acc8-5659-aa2f-26dbe9faafde), object, pointer_default(unique)] -interface ICoreWebView2StagingFindConfiguration : IUnknown { +interface ICoreWebView2StagingFindOptions : IUnknown { /// Gets the `FindDirection` property. // MSOWNERS: core (maxwellmyers@microsoft.com) [propget] HRESULT FindDirection([out, retval] COREWEBVIEW2_FIND_DIRECTION* value); @@ -476,7 +476,7 @@ interface ICoreWebView2Staging17 : IUnknown { ``` -### Setting Up Find Configuration with MIDL3 +### Setting Up Find Options with MIDL3 ### CoreWebView2 Find Configuration and Direction @@ -510,25 +510,25 @@ namespace Microsoft.Web.WebView2.Core } /// Interface that provides methods related to the environment settings of CoreWebView2. - /// This interface allows for the creation of new find configuration objects. + /// This interface allows for the creation of new find options objects. [com_interface("staging=ICoreWebView2StagingEnvironment5")] [ms_owner("core", "maxwellmyers@microsoft.com")] interface ICoreWebView2Environment15 { - /// Creates a new instance of a CoreWebView2FindConfiguration object. - /// This configuration object can be used to define parameters for a find operation. - /// Returns the newly created FindConfiguration object. - CoreWebView2FindConfiguration CreateFindConfiguration(); + /// Creates a new instance of a CoreWebView2FindOptions object. + /// This find options object can be used to define parameters for a find operation. + /// Returns the newly created FindOptions object. + CoreWebView2FindOptions CreateFindOptions(); }; -runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfiguration {} +runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} - /// Interface defining the find configuration. + /// Interface defining the find options. /// This interface provides the necessary methods and properties to configure a find operation. - [com_interface("staging=ICoreWebView2StagingFindConfiguration")] + [com_interface("staging=ICoreWebView2StagingFindOptions")] [ms_owner("core", "maxwellmyers@microsoft.com")] [availability("staging")] - interface ICoreWebView2FindConfiguration + interface ICoreWebView2FindOptions { /// Gets or sets the find term used for the find operation. Returns the find term. String FindTerm { get; set; }; @@ -574,10 +574,10 @@ runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfigura interface ICoreWebView2Find { [completed_handler("")] - /// Initiates a find using the specified configuration asynchronously. + /// Initiates a find using the specified options asynchronously. /// Displays the Find bar and starts the find operation. If a find session was already ongoing, it will be stopped and replaced with this new instance. - /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the configuration object after initiation won't affect the ongoing find session. - /// To change the ongoing find session, StartFindAsync must be called again with a new or modified configuration object. + /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the find options object after initiation won't affect the ongoing find session. + /// To change the ongoing find session, StartFindAsync must be called again with a new or modified find options object. /// StartFind supports, HTML, PDF, and TXT document queries. In general this api is designed for text based find sessions. //// If you start a find session programmatically on another file format that doesnt have text fields, the find session will try to execute but will fail to find any matches. (It will silently fail) /// Note: The asynchronous action completes when the UI has been displayed with the find term in the UI bar, and the matches have populated on the counter on the find bar. @@ -591,7 +591,7 @@ runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfigura /// regardless of the previous active match. This behavior indicates that changing the find query initiates a /// completely new find session, rather than continuing from the previous match index. This distinction is essential /// to understand when utilizing the StartFind method for navigating through text matches. - Windows.Foundation.IAsyncAction StartFindAsync(CoreWebView2FindConfiguration configuration); + Windows.Foundation.IAsyncAction StartFindAsync(CoreWebView2FindOptions options); /// Navigates to the next match in the document. @@ -643,6 +643,6 @@ runtimeclass CoreWebView2FindConfiguration : [default]ICoreWebView2FindConfigura This API specification focuses on providing developers with the necessary information to integrate text finding and navigation functionalities into WebView2 applications. It emphasizes the usage of interfaces such as `ICoreWebView2Find` and -`ICoreWebView2FindConfiguration` to perform find operations effectively. +`ICoreWebView2FindOptions` to perform find operations effectively. From 05838bf7d00b1f22ac4830ec74d6238f9a04adef Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 6 Aug 2024 10:51:25 -0700 Subject: [PATCH 71/80] Update FindOnPage.md Co-authored-by: MikeHillberg <18429489+MikeHillberg@users.noreply.github.com> --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index e37ca9319..243b06e39 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -207,7 +207,7 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string findTerm) #### Description Developers can retrieve the index of the currently active match -within a WebView2 control using the `GetActiveMatchIndex` method. +within a WebView2 control using the `ActiveMatchIndex` property. ```cpp From 7e99d7d363c7b504b190d1ab7fe045ba2abeff30 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 6 Aug 2024 11:00:06 -0700 Subject: [PATCH 72/80] Update FindOnPage.md Co-authored-by: FrankC-msft <99926235+FrankC-msft@users.noreply.github.com> --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 243b06e39..cfb3ff201 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -537,7 +537,7 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} CoreWebView2FindDirection FindDirection { get; set; }; /// Determines if the find operation is case sensitive. Returns TRUE if the find is case sensitive, FALSE otherwise. - /// The locale used to determine case sensitivity is the document's language specified by the HTML lang attribute, or if unspecified then the WebView2's UI locale. + /// The locale used to determine case sensitivity is the document's language specified by the HTML lang attribute. If unspecified then the WebView2's UI locale /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content. Boolean IsCaseSensitive { get; set; }; From 3e608aa9809f07b1ad400481de6373d67a125f1a Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 21 Aug 2024 13:15:47 -0700 Subject: [PATCH 73/80] Update FindOnPage.md --- FindOnPage.md | 156 +++++++++++++++++++++++++------------------------- 1 file changed, 78 insertions(+), 78 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index cfb3ff201..efeec17df 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -3,9 +3,9 @@ ## Background The WebView2Find API offers methods and events for text finding and navigation -within a WebView2 control. It enables developers to programmatically initiate find -operations, navigate find results, suppress default UI, and customize find options -like query and find direction. It also tracks the status of operations, indicating +within a WebView2 control. It enables developers to programmatically initiate Find +operations, navigate Find results, suppress default UI, and customize Find options +like query and Find direction. It also tracks the status of operations, indicating completion, match count changes, and match index changes. ## Examples @@ -24,10 +24,10 @@ completion, match count changes, and match index changes. #### Description -To initiate a find operation in a WebView2 control, use the `StartFindAsync` method. -This method allows setting the find term and find parameters via the -`ICoreWebView2FindOptions` interface. Only one find session can be active per -webview environment. Starting another with the same option will adjust +To initiate a Find operation in a WebView2 control, use the `StartFindAsync` method. +This method allows setting the Find term and Find parameters via the +`ICoreWebView2FindOptions` interface. Only one Find session can be active per +WebView2 environment. Starting another with the same option will adjust the active match index based on the selected Find Direction. ### Create/Specify a Find Option #### WIN32 C++ @@ -40,7 +40,7 @@ wil::com_ptr AppWindow::InitializeFindOptions(const st auto webView2Environment5 = m_webViewEnvironment.try_query(); CHECK_FEATURE_RETURN(webView2Environment5); - // Initialize find options + // Initialize Find options wil::com_ptr find_options; CHECK_FAILURE(webView2Environment5->CreateFindOptions(&find_options)); CHECK_FAILURE(find_options->put_FindTerm(findTerm.c_str())); @@ -68,7 +68,7 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& findTerm) // By default Find will use the default UI and highlight all matches. If you want different behavior // you can change the SuppressDefaultDialog and ShouldHighlightAllMatches properties here. - // Start the find operation with a callback for completion. + // Start the Find operation with a callback for completion. CHECK_FAILURE(webView2Find->StartFind( find_options.get(), Callback( @@ -76,7 +76,7 @@ bool AppWindow::ConfigureAndExecuteFind(const std::wstring& findTerm) { if (SUCCEEDED(result)) { - // Optionally update UI elements here upon successful find operation. + // Optionally update UI elements here upon successful Find operation. } else { @@ -106,10 +106,10 @@ bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& findTerm) wil::com_ptr webView2Find; CHECK_FAILURE(webView2_17->get_Find(&webView2Find)); - // Opt for using a custom UI for the find operation. + // Opt for using a custom UI for the Find operation. CHECK_FAILURE(webView2Find->put_SuppressDefaultDialog(true)); - // Start the find operation with callback for completion. + // Start the Find operation with callback for completion. CHECK_FAILURE(webView2Find->StartFind( find_options.get(), Callback( @@ -117,17 +117,17 @@ bool AppWindow::ExecuteFindWithCustomUI(const std::wstring& findTerm) { if (SUCCEEDED(result) && status) { - // Optionally update UI elements here upon successful find operation. + // Optionally update UI elements here upon successful Find operation. } else { - // Handle errors or unsuccessful find. + // Handle errors or unsuccessful Find. } return S_OK; }).Get())); - // Note: In this example, navigation through find results (FindNext/FindPrevious) - // and stopping the find operation (StopFind) are assumed to be handled by + // Note: In this example, navigation through Find results (FindNext/FindPrevious) + // and stopping the Find operation (StopFind) are assumed to be handled by // custom UI elements and user interaction, not directly in code here. // User could then connect functions such as FindNext, FindPrevious, and StopFind // to corresponding custom UI elements. @@ -147,7 +147,7 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string findTerm) throw new InvalidOperationException("WebView2 is not initialized."); } - // Initialize the find options with specified settings. + // Initialize the Find options with specified settings. var find_options = new CoreWebView2FindOptions { FindTerm = findTerm @@ -156,14 +156,14 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string findTerm) // By default Find will use the default UI and highlight all matches. If you want different behavior // you can change the SuppressDefaultDialog and ShouldHighlightAllMatches properties here. - // Start the find operation with the specified options. + // Start the Find operation with the specified options. await webView.CoreWebView2.Find.StartFindAsync(find_options); // End user interaction is handled via UI. } catch (Exception ex) { - // Handle any errors that may occur during the find operation. + // Handle any errors that may occur during the Find operation. Console.WriteLine($"An error occurred: {ex.Message}"); } } @@ -180,24 +180,24 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string findTerm) throw new InvalidOperationException("WebView2 is not initialized."); } - // Initialize the find options. + // Initialize the Find options. var find_options = new CoreWebView2FindOptions { FindTerm = findTerm }; - // Specify that a custom UI will be used for the find operation. + // Specify that a custom UI will be used for the Find operation. webView.CoreWebView2.Find.SuppressDefaultDialog = true; webView.CoreWebView2.Find.ShouldHighlightAllMatches = true; - // Start the find operation with the specified options. + // Start the Find operation with the specified options. await webView.CoreWebView2.Find.StartFindAsync(find_options); // It's expected that the custom UI for navigating between matches (next, previous) - // and stopping the find operation will be managed by the developer's custom code. + // and stopping the Find operation will be managed by the developer's custom code. } catch (Exception ex) { - // Handle any errors that may occur during the find operation. + // Handle any errors that may occur during the Find operation. Console.WriteLine($"An error occurred: {ex.Message}"); } } @@ -215,7 +215,7 @@ within a WebView2 control using the `ActiveMatchIndex` property. { auto webView2_17 = m_webView.try_query(); CHECK_FEATURE_RETURN(webView2_17); - wil::com_ptr webView2find; + wil::com_ptr webView2Find; CHECK_FAILURE(webView2_17->get_Find(&webView2Find)); LONG activeMatchIndex; CHECK_FAILURE(webView2Find->get_ActiveMatchIndex(&activeMatchIndex)); @@ -263,24 +263,24 @@ void ActiveMatchIndexChangedSample() ## API Details ```cpp -/// Specifies the direction of find Parameters. +/// Specifies the direction of Find Parameters. // MSOWNERS: core (maxwellmyers@microsoft.com) [v1_enum] typedef enum COREWEBVIEW2_FIND_DIRECTION { - /// Specifies a forward find in the document. + /// Specifies a forward Find in the document. COREWEBVIEW2_FIND_DIRECTION_FORWARD, - /// Specifies a backwards find in the document. + /// Specifies a backwards Find in the document. COREWEBVIEW2_FIND_DIRECTION_BACKWARD, } COREWEBVIEW2_FIND_DIRECTION; /// Interface that provides methods related to the environment settings of CoreWebView2. -/// This interface allows for the creation of new find options objects. +/// This interface allows for the creation of new Find options objects. // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(f10bddd3-bb59-5d5b-8748-8a1a53f65d0c), object, pointer_default(unique)] interface ICoreWebView2StagingEnvironment5 : IUnknown { /// Creates a new instance of a FindOptions object. - /// This options object can be used to define parameters for a find operation. + /// This options object can be used to define parameters for a Find operation. /// Returns the newly created FindOptions object. // MSOWNERS: core (maxwellmyers@microsoft.com) HRESULT CreateFindOptions( @@ -318,16 +318,16 @@ interface ICoreWebView2StagingFindMatchCountChangedEventHandler : IUnknown { /// Interface providing methods and properties for finding and navigating through text in the web view. -/// This interface allows for finding text, navigation between matches, and customization of the find UI. +/// This interface allows for finding text, navigation between matches, and customization of the Find UI. // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(9c494a0a-c5d8-5fee-b7e6-4926d8d7b391), object, pointer_default(unique)] interface ICoreWebView2StagingFind : IUnknown { - /// Retrieves the index of the currently active match in the find session. Returns the index of the currently active match, or -1 if there is no active match. + /// Retrieves the index of the currently active match in the Find session. Returns the index of the currently active match, or -1 if there is no active match. // MSOWNERS: core (maxwellmyers@microsoft.com) [propget] HRESULT ActiveMatchIndex([out, retval] UINT32* value); - /// Gets the total count of matches found in the current document based on the last find sessions criteria. Returns the total count of matches. + /// Gets the total count of matches found in the current document based on the last Find sessions criteria. Returns the total count of matches. // MSOWNERS: core (maxwellmyers@microsoft.com) [propget] HRESULT MatchCount([out, retval] UINT32* value); @@ -366,7 +366,7 @@ interface ICoreWebView2StagingFind : IUnknown { [in] EventRegistrationToken token); /// Adds an event handler for the `MatchCountChanged` event. - /// Registers an event handler for the MatchCountChanged event. This event is raised when the total count of matches in the document changes due to a new find operation or changes in the document. /// The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. + /// Registers an event handler for the MatchCountChanged event. This event is raised when the total count of matches in the document changes due to a new Find operation or changes in the document. /// The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. // MSOWNERS: core (maxwellmyers@microsoft.com) HRESULT add_MatchCountChanged( [in] ICoreWebView2StagingMatchCountChangedEventHandler* eventHandler, @@ -378,10 +378,10 @@ interface ICoreWebView2StagingFind : IUnknown { [in] EventRegistrationToken token); - /// Initiates a find using the specified find option. - /// Displays the Find bar and starts the find operation. If a find session was already ongoing, it will be stopped and replaced with this new instance. - /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the find options object after initiation won't affect the ongoing find session. - /// To change the ongoing find session, Start must be called again with a new or modified find options object. + /// Initiates a Find using the specified Find option. + /// Displays the Find bar and starts the Find operation. If a Find session was already ongoing, it will be stopped and replaced with this new instance. + /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the Find options object after initiation won't affect the ongoing Find session. + /// To change the ongoing Find session, Start must be called again with a new or modified Find options object. /// This method is primarily designed for HTML document queries. // MSOWNERS: core (maxwellmyers@microsoft.com) HRESULT StartFind( @@ -409,8 +409,8 @@ interface ICoreWebView2StagingFind : IUnknown { -/// Interface defining the find options. -/// This interface provides the necessary methods and properties to configure a find operation. +/// Interface defining the Find options. +/// This interface provides the necessary methods and properties to configure a Find operation. // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(52a04b23-acc8-5659-aa2f-26dbe9faafde), object, pointer_default(unique)] interface ICoreWebView2StagingFindOptions : IUnknown { @@ -461,12 +461,12 @@ interface ICoreWebView2StagingFindOptions : IUnknown { } /// -/// Interface providing methods to access the find operation functionalities in the CoreWebView2. +/// Interface providing methods to access the Find operation functionalities in the CoreWebView2. /// // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(c9a130ca-a807-549c-9d76-8e09ccee3973), object, pointer_default(unique)] interface ICoreWebView2Staging17 : IUnknown { - /// Retrieves the find operation interface for the current web view. + /// Retrieves the Find operation interface for the current web view. // MSOWNERS: core (maxwellmyers@microsoft.com) [propget] HRESULT Find([out, retval] ICoreWebView2StagingFind** value); @@ -487,56 +487,56 @@ interface ICoreWebView2Staging17 : IUnknown { ```csharp namespace Microsoft.Web.WebView2.Core { - /// Specifies the direction of find Parameters. + /// Specifies the direction of Find Parameters. [ms_owner("core", "maxwellmyers@microsoft.com")] [availability("staging")] enum CoreWebView2FindDirection { - /// Specifies a forward find in the document. + /// Specifies a forward Find in the document. Forward, - /// Specifies a backwards find in the document. + /// Specifies a backwards Find in the document. Backward, }; /// - /// Interface providing methods to access the find operation functionalities in the CoreWebView2. + /// Interface providing methods to access the Find operation functionalities in the CoreWebView2. /// [com_interface("staging=ICoreWebView2Staging17")] [ms_owner("core", "maxwellmyers@microsoft.com")] interface ICoreWebView2_25 { - /// Retrieves the find operation interface for the current web view. + /// Retrieves the Find operation interface for the current web view. CoreWebView2Find Find { get; }; } /// Interface that provides methods related to the environment settings of CoreWebView2. - /// This interface allows for the creation of new find options objects. + /// This interface allows for the creation of new Find options objects. [com_interface("staging=ICoreWebView2StagingEnvironment5")] [ms_owner("core", "maxwellmyers@microsoft.com")] interface ICoreWebView2Environment15 { /// Creates a new instance of a CoreWebView2FindOptions object. - /// This find options object can be used to define parameters for a find operation. + /// This Find options object can be used to define parameters for a Find operation. /// Returns the newly created FindOptions object. CoreWebView2FindOptions CreateFindOptions(); }; runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} - /// Interface defining the find options. - /// This interface provides the necessary methods and properties to configure a find operation. + /// Interface defining the Find options. + /// This interface provides the necessary methods and properties to configure a Find operation. [com_interface("staging=ICoreWebView2StagingFindOptions")] [ms_owner("core", "maxwellmyers@microsoft.com")] [availability("staging")] interface ICoreWebView2FindOptions { - /// Gets or sets the find term used for the find operation. Returns the find term. + /// Gets or sets the Find term used for the Find operation. Returns the Find term. String FindTerm { get; set; }; - /// Gets or sets the direction of the find operation (forward or backward). Returns the find direction. + /// Gets or sets the direction of the Find operation (forward or backward). Returns the Find direction. CoreWebView2FindDirection FindDirection { get; set; }; - /// Determines if the find operation is case sensitive. Returns TRUE if the find is case sensitive, FALSE otherwise. + /// Determines if the Find operation is case sensitive. Returns TRUE if the Find is case sensitive, FALSE otherwise. /// The locale used to determine case sensitivity is the document's language specified by the HTML lang attribute. If unspecified then the WebView2's UI locale /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content. @@ -545,7 +545,7 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} /// Similar to case sensitivity, word matching also can vary by locale, which may be influenced by both the browser's UI locale and the document's language settings. The browser's UI locale /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content. - /// ShouldMatchWord determines if only whole words should be matched during the find operation. Returns TRUE if only whole words should be matched, FALSE otherwise. + /// ShouldMatchWord determines if only whole words should be matched during the Find operation. Returns TRUE if only whole words should be matched, FALSE otherwise. Boolean ShouldMatchWord { get; set; }; /// Gets or sets the state of whether all matches are highlighted. @@ -567,43 +567,43 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} runtimeclass CoreWebView2Find : [default]ICoreWebView2Find {} /// Interface providing methods and properties for finding and navigating through text in the web view. - /// This interface allows for finding text, navigation between matches, and customization of the find UI. + /// This interface allows for finding text, navigation between matches, and customization of the Find UI. [com_interface("staging=ICoreWebView2StagingFind")] [ms_owner("core", "maxwellmyers@microsoft.com")] [availability("staging")] interface ICoreWebView2Find { [completed_handler("")] - /// Initiates a find using the specified options asynchronously. - /// Displays the Find bar and starts the find operation. If a find session was already ongoing, it will be stopped and replaced with this new instance. - /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the find options object after initiation won't affect the ongoing find session. - /// To change the ongoing find session, StartFindAsync must be called again with a new or modified find options object. - /// StartFind supports, HTML, PDF, and TXT document queries. In general this api is designed for text based find sessions. - //// If you start a find session programmatically on another file format that doesnt have text fields, the find session will try to execute but will fail to find any matches. (It will silently fail) - /// Note: The asynchronous action completes when the UI has been displayed with the find term in the UI bar, and the matches have populated on the counter on the find bar. + /// Initiates a Find using the specified options asynchronously. + /// Displays the Find bar and starts the Find operation. If a Find session was already ongoing, it will be stopped and replaced with this new instance. + /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the Find options object after initiation won't affect the ongoing Find session. + /// To change the ongoing Find session, StartFindAsync must be called again with a new or modified Find options object. + /// StartFind supports, HTML, PDF, and TXT document queries. In general this api is designed for text based Find sessions. + //// If you start a Find session programmatically on another file format that doesnt have text fields, the Find session will try to execute but will fail to Find any matches. Specifically, it will show the find UI but not find any matches. + /// Note: The asynchronous action completes when the UI has been displayed with the Find term in the UI bar, and the matches have populated on the counter on the Find bar. /// There may be a slight latency between the UI display and the matches populating in the counter. /// The MatchCountChanged and ActiveMatchIndexChanged events are only raised after StartFindAsync has completed, otherwise they will have their default values (-1 for both). - /// When initiating a find session while another session is in progress, the behavior of - /// the active match index depends on the direction set for the find operation (forward or backward). - /// However, calling StartFind again during an ongoing find operation does not resume from the point - /// of the current active match. For example, given the text "1 1 A 1 1" and initiating a find session for "A", - /// then starting another find session for "1", it will start searching from the beginning of the document, - /// regardless of the previous active match. This behavior indicates that changing the find query initiates a - /// completely new find session, rather than continuing from the previous match index. This distinction is essential + /// When initiating a Find session while another session is in progress, the behavior of + /// the active match index depends on the direction set for the Find operation (forward or backward). + /// However, calling StartFind again during an ongoing Find operation does not resume from the point + /// of the current active match. For example, given the text "1 1 A 1 1" and initiating a Find session for "A", + /// then starting another Find session for "1", it will start searching from the beginning of the document, + /// regardless of the previous active match. This behavior indicates that changing the Find query initiates a + /// completely new Find session, rather than continuing from the previous match index. This distinction is essential /// to understand when utilizing the StartFind method for navigating through text matches. Windows.Foundation.IAsyncAction StartFindAsync(CoreWebView2FindOptions options); /// Navigates to the next match in the document. - /// If there are no matches to find, FindNext will wrap around to the first match if the search direction is forward, + /// If there are no matches to Find, FindNext will wrap around to the first match if the search direction is forward, /// or to the last match if the search direction is backward. - /// If called when there is no find session active, FindNext will silently fail. + /// If called when there is no Find session active, FindNext will silently fail. void FindNext(); /// Navigates to the previous match in the document. - /// If there are no matches to find, FindPrevious will wrap around to the last match if the search direction is forward, + /// If there are no matches to Find, FindPrevious will wrap around to the last match if the search direction is forward, /// or to the first match if the search direction is backward. - /// If called when there is no find session active, FindPrevious will silently fail. + /// If called when there is no Find session active, FindPrevious will silently fail. void FindPrevious(); @@ -611,14 +611,14 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} /// If called with no Find session active, it will silently do nothing. void StopFind(); - /// Retrieves the index of the currently active match in the find session. Returns the index of the currently active match, or -1 if there is no active match. + /// Retrieves the index of the currently active match in the Find session. Returns the index of the currently active match, or -1 if there is no active match. Int32 ActiveMatchIndex { get; }; - /// Gets the total count of matches found in the current document based on the last find sessions criteria. Returns the total count of matches. + /// Gets the total count of matches found in the current document based on the last Find sessions criteria. Returns the total count of matches. Int32 MatchCount { get; }; /// Registers an event handler for the MatchCountChanged event. - /// This event is raised when the total count of matches in the document changes due to a new find operation or changes in the document. + /// This event is raised when the total count of matches in the document changes due to a new Find operation or changes in the document. /// The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. [event_handler("", "", "")] event Windows.Foundation.TypedEventHandler MatchCountChanged; @@ -643,6 +643,6 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} This API specification focuses on providing developers with the necessary information to integrate text finding and navigation functionalities into WebView2 applications. It emphasizes the usage of interfaces such as `ICoreWebView2Find` and -`ICoreWebView2FindOptions` to perform find operations effectively. +`ICoreWebView2FindOptions` to perform Find operations effectively. From c619dbb76ec909fc0516faad799c171c8da2669e Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 21 Aug 2024 13:20:25 -0700 Subject: [PATCH 74/80] Update FindOnPage.md Removed staging from interface names --- FindOnPage.md | 36 ++++++++++++++++++------------------ 1 file changed, 18 insertions(+), 18 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index efeec17df..3558258c5 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -278,13 +278,13 @@ typedef enum COREWEBVIEW2_FIND_DIRECTION { /// This interface allows for the creation of new Find options objects. // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(f10bddd3-bb59-5d5b-8748-8a1a53f65d0c), object, pointer_default(unique)] -interface ICoreWebView2StagingEnvironment5 : IUnknown { +interface ICoreWebView2Environment5 : IUnknown { /// Creates a new instance of a FindOptions object. /// This options object can be used to define parameters for a Find operation. /// Returns the newly created FindOptions object. // MSOWNERS: core (maxwellmyers@microsoft.com) HRESULT CreateFindOptions( - [out, retval] ICoreWebView2StagingFindOptions** value + [out, retval] ICoreWebView2FindOptions** value ); @@ -293,7 +293,7 @@ interface ICoreWebView2StagingEnvironment5 : IUnknown { /// Receives the result of the `StartFind` method. [uuid(7c20f8b0-c14e-5135-a099-6c9d11d59dd1), object, pointer_default(unique)] -interface ICoreWebView2StagingFindStartFindCompletedHandler : IUnknown { +interface ICoreWebView2indStartFindCompletedHandler : IUnknown { /// Provides the result of the corresponding asynchronous method. HRESULT Invoke([in] HRESULT errorCode); @@ -301,18 +301,18 @@ interface ICoreWebView2StagingFindStartFindCompletedHandler : IUnknown { /// Receives `FindActiveMatchIndexChanged` events. [uuid(8d3422bf-66df-5bae-9916-71fd23d5bef6), object, pointer_default(unique)] -interface ICoreWebView2StagingFindActiveMatchIndexChangedEventHandler : IUnknown { +interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { /// Provides the event args for the corresponding event. HRESULT Invoke( - [in] ICoreWebView2StagingFind* sender, + [in] ICoreWebView2Find* sender, [in] IUnknown* args); } /// Receives `FindMatchCountChanged` events. [uuid(cecb8e8f-b6c8-55c3-98b1-68fd1e2b9eea), object, pointer_default(unique)] -interface ICoreWebView2StagingFindMatchCountChangedEventHandler : IUnknown { +interface ICoreWebView2FindMatchCountChangedEventHandler : IUnknown { /// Provides the event args for the corresponding event. HRESULT Invoke( - [in] ICoreWebView2StagingFind* sender, + [in] ICoreWebView2Find* sender, [in] IUnknown* args); } @@ -321,7 +321,7 @@ interface ICoreWebView2StagingFindMatchCountChangedEventHandler : IUnknown { /// This interface allows for finding text, navigation between matches, and customization of the Find UI. // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(9c494a0a-c5d8-5fee-b7e6-4926d8d7b391), object, pointer_default(unique)] -interface ICoreWebView2StagingFind : IUnknown { +interface ICoreWebView2Find : IUnknown { /// Retrieves the index of the currently active match in the Find session. Returns the index of the currently active match, or -1 if there is no active match. // MSOWNERS: core (maxwellmyers@microsoft.com) [propget] HRESULT ActiveMatchIndex([out, retval] UINT32* value); @@ -357,7 +357,7 @@ interface ICoreWebView2StagingFind : IUnknown { /// Registers an event handler for the ActiveMatchIndexChanged event. This event is raised when the index of the currently active match changes. This can happen when the user navigates to a different match or when the active match is changed programmatically. The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. // MSOWNERS: core (maxwellmyers@microsoft.com) HRESULT add_ActiveMatchIndexChanged( - [in] ICoreWebView2StagingActiveMatchIndexChangedEventHandler* eventHandler, + [in] ICoreWebView2ActiveMatchIndexChangedEventHandler* eventHandler, [out] EventRegistrationToken* token); /// Removes an event handler previously added with `add_ActiveMatchIndexChanged`. @@ -369,7 +369,7 @@ interface ICoreWebView2StagingFind : IUnknown { /// Registers an event handler for the MatchCountChanged event. This event is raised when the total count of matches in the document changes due to a new Find operation or changes in the document. /// The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. // MSOWNERS: core (maxwellmyers@microsoft.com) HRESULT add_MatchCountChanged( - [in] ICoreWebView2StagingMatchCountChangedEventHandler* eventHandler, + [in] ICoreWebView2MatchCountChangedEventHandler* eventHandler, [out] EventRegistrationToken* token); /// Removes an event handler previously added with `add_MatchCountChanged`. @@ -385,8 +385,8 @@ interface ICoreWebView2StagingFind : IUnknown { /// This method is primarily designed for HTML document queries. // MSOWNERS: core (maxwellmyers@microsoft.com) HRESULT StartFind( - [in] ICoreWebView2StagingFindOptions* options - , [in] ICoreWebView2StagingFindStartFindCompletedHandler* handler + [in] ICoreWebView2FindOptions* options + , [in] ICoreWebView2FindStartFindCompletedHandler* handler ); /// Navigates to the next match in the document. @@ -413,7 +413,7 @@ interface ICoreWebView2StagingFind : IUnknown { /// This interface provides the necessary methods and properties to configure a Find operation. // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(52a04b23-acc8-5659-aa2f-26dbe9faafde), object, pointer_default(unique)] -interface ICoreWebView2StagingFindOptions : IUnknown { +interface ICoreWebView2FindOptions : IUnknown { /// Gets the `FindDirection` property. // MSOWNERS: core (maxwellmyers@microsoft.com) [propget] HRESULT FindDirection([out, retval] COREWEBVIEW2_FIND_DIRECTION* value); @@ -465,10 +465,10 @@ interface ICoreWebView2StagingFindOptions : IUnknown { /// // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(c9a130ca-a807-549c-9d76-8e09ccee3973), object, pointer_default(unique)] -interface ICoreWebView2Staging17 : IUnknown { +interface ICoreWebView2_17 : IUnknown { /// Retrieves the Find operation interface for the current web view. // MSOWNERS: core (maxwellmyers@microsoft.com) - [propget] HRESULT Find([out, retval] ICoreWebView2StagingFind** value); + [propget] HRESULT Find([out, retval] ICoreWebView2Find** value); @@ -501,7 +501,7 @@ namespace Microsoft.Web.WebView2.Core /// /// Interface providing methods to access the Find operation functionalities in the CoreWebView2. /// - [com_interface("staging=ICoreWebView2Staging17")] + [com_interface("staging=ICoreWebView2_17")] [ms_owner("core", "maxwellmyers@microsoft.com")] interface ICoreWebView2_25 { @@ -511,7 +511,7 @@ namespace Microsoft.Web.WebView2.Core /// Interface that provides methods related to the environment settings of CoreWebView2. /// This interface allows for the creation of new Find options objects. - [com_interface("staging=ICoreWebView2StagingEnvironment5")] + [com_interface("staging=ICoreWebView2Environment5")] [ms_owner("core", "maxwellmyers@microsoft.com")] interface ICoreWebView2Environment15 { @@ -525,7 +525,7 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} /// Interface defining the Find options. /// This interface provides the necessary methods and properties to configure a Find operation. - [com_interface("staging=ICoreWebView2StagingFindOptions")] + [com_interface("staging=ICoreWebView2FindOptions")] [ms_owner("core", "maxwellmyers@microsoft.com")] [availability("staging")] interface ICoreWebView2FindOptions From 3ed7d68acee8b38f7c2508a007688a293f36b21d Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 21 Aug 2024 13:21:09 -0700 Subject: [PATCH 75/80] Update FindOnPage.md replaced web view with WebView2 --- FindOnPage.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 3558258c5..88a871163 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -317,7 +317,7 @@ interface ICoreWebView2FindMatchCountChangedEventHandler : IUnknown { } -/// Interface providing methods and properties for finding and navigating through text in the web view. +/// Interface providing methods and properties for finding and navigating through text in the WebView2. /// This interface allows for finding text, navigation between matches, and customization of the Find UI. // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(9c494a0a-c5d8-5fee-b7e6-4926d8d7b391), object, pointer_default(unique)] @@ -466,7 +466,7 @@ interface ICoreWebView2FindOptions : IUnknown { // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(c9a130ca-a807-549c-9d76-8e09ccee3973), object, pointer_default(unique)] interface ICoreWebView2_17 : IUnknown { - /// Retrieves the Find operation interface for the current web view. + /// Retrieves the Find operation interface for the current WebView2. // MSOWNERS: core (maxwellmyers@microsoft.com) [propget] HRESULT Find([out, retval] ICoreWebView2Find** value); @@ -505,7 +505,7 @@ namespace Microsoft.Web.WebView2.Core [ms_owner("core", "maxwellmyers@microsoft.com")] interface ICoreWebView2_25 { - /// Retrieves the Find operation interface for the current web view. + /// Retrieves the Find operation interface for the current WebView2. CoreWebView2Find Find { get; }; } @@ -566,7 +566,7 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} runtimeclass CoreWebView2Find : [default]ICoreWebView2Find {} - /// Interface providing methods and properties for finding and navigating through text in the web view. + /// Interface providing methods and properties for finding and navigating through text in the WebView2. /// This interface allows for finding text, navigation between matches, and customization of the Find UI. [com_interface("staging=ICoreWebView2StagingFind")] [ms_owner("core", "maxwellmyers@microsoft.com")] From 571626fdbffcc96d0a3476bfb9643cb6ef146cd0 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 21 Aug 2024 13:48:04 -0700 Subject: [PATCH 76/80] Update FindOnPage.md updated description of find next and previous to clarify that they dont update properties --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index 88a871163..e19d31bcd 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -550,7 +550,7 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} /// Gets or sets the state of whether all matches are highlighted. /// Returns TRUE if all matches are highlighted, FALSE otherwise. - /// Note: Changes to this property take effect only when StartFind, FindNext, or FindPrevious is called. + /// Note: Changes to this property take effect only when StartFind is called. /// Preferences for the session cannot be updated unless another call to the StartFind function on the server-side is made. /// Therefore, changes will not take effect until one of these functions is called. Boolean ShouldHighlightAllMatches { get; set; }; From 4257d861f283c4bf2a720c218600fc049f3f74b5 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Wed, 21 Aug 2024 13:59:11 -0700 Subject: [PATCH 77/80] Update FindOnPage.md removed Async from getactivematchindex --- FindOnPage.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FindOnPage.md b/FindOnPage.md index e19d31bcd..65a49302f 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -242,7 +242,7 @@ within a WebView2 control using the `ActiveMatchIndex` property. ``` #### .NET C# ```csharp -public async Task GetActiveMatchIndexAsync() +public Task GetActiveMatchIndex() { var webViewFind = webView.CoreWebView2.Find; // Assuming webView is your WebView2 control var activeMatchIndex = webViewFind.ActiveMatchIndex(); From 5e6d5dd6dc39ff07378981db72d2bd39925c004b Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Fri, 23 Aug 2024 11:22:26 -0700 Subject: [PATCH 78/80] Update FindOnPage.md changed startfindasync to startasync --- FindOnPage.md | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 65a49302f..2e5c3aa5b 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -24,7 +24,7 @@ completion, match count changes, and match index changes. #### Description -To initiate a Find operation in a WebView2 control, use the `StartFindAsync` method. +To initiate a Find operation in a WebView2 control, use the `StartAsync` method. This method allows setting the Find term and Find parameters via the `ICoreWebView2FindOptions` interface. Only one Find session can be active per WebView2 environment. Starting another with the same option will adjust @@ -157,7 +157,7 @@ async Task ConfigureAndExecuteFindWithDefaultUIAsync(string findTerm) // you can change the SuppressDefaultDialog and ShouldHighlightAllMatches properties here. // Start the Find operation with the specified options. - await webView.CoreWebView2.Find.StartFindAsync(find_options); + await webView.CoreWebView2.Find.StartAsync(find_options); // End user interaction is handled via UI. } @@ -191,7 +191,7 @@ async Task ConfigureAndExecuteFindWithCustomUIAsync(string findTerm) webView.CoreWebView2.Find.ShouldHighlightAllMatches = true; // Start the Find operation with the specified options. - await webView.CoreWebView2.Find.StartFindAsync(find_options); + await webView.CoreWebView2.Find.StartAsync(find_options); // It's expected that the custom UI for navigating between matches (next, previous) // and stopping the Find operation will be managed by the developer's custom code. } @@ -574,15 +574,15 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} interface ICoreWebView2Find { [completed_handler("")] - /// Initiates a Find using the specified options asynchronously. + /// Initiates a Find session using the specified options asynchronously. /// Displays the Find bar and starts the Find operation. If a Find session was already ongoing, it will be stopped and replaced with this new instance. /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the Find options object after initiation won't affect the ongoing Find session. - /// To change the ongoing Find session, StartFindAsync must be called again with a new or modified Find options object. - /// StartFind supports, HTML, PDF, and TXT document queries. In general this api is designed for text based Find sessions. - //// If you start a Find session programmatically on another file format that doesnt have text fields, the Find session will try to execute but will fail to Find any matches. Specifically, it will show the find UI but not find any matches. - /// Note: The asynchronous action completes when the UI has been displayed with the Find term in the UI bar, and the matches have populated on the counter on the Find bar. + /// To change the ongoing Find session, StartAsync must be called again with a new or modified Find options object. + /// StartAsync supports, HTML, PDF, and TXT document queries. In general this api is designed for text based Find sessions. + //// If you start a Find session programmatically on another file format that doesnt have text fields, the Find session will show the find UI but not find any matches. + /// StartAsync Completion: The asynchronous action completes when the UI has been displayed with the Find term in the UI bar, and the matches have populated on the counter on the Find bar. /// There may be a slight latency between the UI display and the matches populating in the counter. - /// The MatchCountChanged and ActiveMatchIndexChanged events are only raised after StartFindAsync has completed, otherwise they will have their default values (-1 for both). + /// The MatchCountChanged and ActiveMatchIndexChanged events are only raised after StartAsync has completed, otherwise they will have their default values (-1 for ActiveMatchIndex and 0 for TotalMatchCount). /// When initiating a Find session while another session is in progress, the behavior of /// the active match index depends on the direction set for the Find operation (forward or backward). /// However, calling StartFind again during an ongoing Find operation does not resume from the point @@ -591,7 +591,7 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} /// regardless of the previous active match. This behavior indicates that changing the Find query initiates a /// completely new Find session, rather than continuing from the previous match index. This distinction is essential /// to understand when utilizing the StartFind method for navigating through text matches. - Windows.Foundation.IAsyncAction StartFindAsync(CoreWebView2FindOptions options); + Windows.Foundation.IAsyncAction StartAsync(CoreWebView2FindOptions options); /// Navigates to the next match in the document. From d1299fcf38f1c1ec211bca1a4bef73bfa06f857d Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Tue, 15 Oct 2024 14:33:35 -0700 Subject: [PATCH 79/80] Update FindOnPage.md Removed Find Direction and updated documentation --- FindOnPage.md | 49 +++++-------------------------------------------- 1 file changed, 5 insertions(+), 44 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index 2e5c3aa5b..dcc32fce4 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -5,7 +5,7 @@ The WebView2Find API offers methods and events for text finding and navigation within a WebView2 control. It enables developers to programmatically initiate Find operations, navigate Find results, suppress default UI, and customize Find options -like query and Find direction. It also tracks the status of operations, indicating +like find query. It also tracks the status of operations, indicating completion, match count changes, and match index changes. ## Examples @@ -27,8 +27,7 @@ completion, match count changes, and match index changes. To initiate a Find operation in a WebView2 control, use the `StartAsync` method. This method allows setting the Find term and Find parameters via the `ICoreWebView2FindOptions` interface. Only one Find session can be active per -WebView2 environment. Starting another with the same option will adjust -the active match index based on the selected Find Direction. +WebView2 environment. ### Create/Specify a Find Option #### WIN32 C++ @@ -263,16 +262,6 @@ void ActiveMatchIndexChangedSample() ## API Details ```cpp -/// Specifies the direction of Find Parameters. -// MSOWNERS: core (maxwellmyers@microsoft.com) -[v1_enum] -typedef enum COREWEBVIEW2_FIND_DIRECTION { - /// Specifies a forward Find in the document. - COREWEBVIEW2_FIND_DIRECTION_FORWARD, - /// Specifies a backwards Find in the document. - COREWEBVIEW2_FIND_DIRECTION_BACKWARD, -} COREWEBVIEW2_FIND_DIRECTION; - /// Interface that provides methods related to the environment settings of CoreWebView2. /// This interface allows for the creation of new Find options objects. @@ -414,16 +403,6 @@ interface ICoreWebView2Find : IUnknown { // MSOWNERS: core (maxwellmyers@microsoft.com) [uuid(52a04b23-acc8-5659-aa2f-26dbe9faafde), object, pointer_default(unique)] interface ICoreWebView2FindOptions : IUnknown { - /// Gets the `FindDirection` property. - // MSOWNERS: core (maxwellmyers@microsoft.com) - [propget] HRESULT FindDirection([out, retval] COREWEBVIEW2_FIND_DIRECTION* value); - - - /// - // MSOWNERS: core (maxwellmyers@microsoft.com) - [propput] HRESULT FindDirection([in] COREWEBVIEW2_FIND_DIRECTION value); - - /// Gets the `FindTerm` property. /// /// The caller must free the returned string with `CoTaskMemFree`. See @@ -478,7 +457,7 @@ interface ICoreWebView2_17 : IUnknown { ### Setting Up Find Options with MIDL3 -### CoreWebView2 Find Configuration and Direction +### CoreWebView2 Find Configuration @@ -487,17 +466,6 @@ interface ICoreWebView2_17 : IUnknown { ```csharp namespace Microsoft.Web.WebView2.Core { - /// Specifies the direction of Find Parameters. - [ms_owner("core", "maxwellmyers@microsoft.com")] - [availability("staging")] - enum CoreWebView2FindDirection - { - /// Specifies a forward Find in the document. - Forward, - /// Specifies a backwards Find in the document. - Backward, - }; - /// /// Interface providing methods to access the Find operation functionalities in the CoreWebView2. /// @@ -533,9 +501,6 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} /// Gets or sets the Find term used for the Find operation. Returns the Find term. String FindTerm { get; set; }; - /// Gets or sets the direction of the Find operation (forward or backward). Returns the Find direction. - CoreWebView2FindDirection FindDirection { get; set; }; - /// Determines if the Find operation is case sensitive. Returns TRUE if the Find is case sensitive, FALSE otherwise. /// The locale used to determine case sensitivity is the document's language specified by the HTML lang attribute. If unspecified then the WebView2's UI locale /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration @@ -583,8 +548,6 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} /// StartAsync Completion: The asynchronous action completes when the UI has been displayed with the Find term in the UI bar, and the matches have populated on the counter on the Find bar. /// There may be a slight latency between the UI display and the matches populating in the counter. /// The MatchCountChanged and ActiveMatchIndexChanged events are only raised after StartAsync has completed, otherwise they will have their default values (-1 for ActiveMatchIndex and 0 for TotalMatchCount). - /// When initiating a Find session while another session is in progress, the behavior of - /// the active match index depends on the direction set for the Find operation (forward or backward). /// However, calling StartFind again during an ongoing Find operation does not resume from the point /// of the current active match. For example, given the text "1 1 A 1 1" and initiating a Find session for "A", /// then starting another Find session for "1", it will start searching from the beginning of the document, @@ -595,14 +558,12 @@ runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} /// Navigates to the next match in the document. - /// If there are no matches to Find, FindNext will wrap around to the first match if the search direction is forward, - /// or to the last match if the search direction is backward. + /// If there are no matches to Find, FindNext will wrap around to the first match. /// If called when there is no Find session active, FindNext will silently fail. void FindNext(); /// Navigates to the previous match in the document. - /// If there are no matches to Find, FindPrevious will wrap around to the last match if the search direction is forward, - /// or to the first match if the search direction is backward. + /// If there are no matches to Find, FindPrevious will wrap around to the last match. /// If called when there is no Find session active, FindPrevious will silently fail. void FindPrevious(); From 1675000e1f18a628bfdd2f3ea6a602ddae426b14 Mon Sep 17 00:00:00 2001 From: maxwellmyers <161385346+maxwellmyers@users.noreply.github.com> Date: Mon, 13 Jan 2025 08:11:02 -0800 Subject: [PATCH 80/80] Update FindOnPage.md with experimental find options/ Updated MIDL3 Documentation with API promotion to experimental changes and renames --- FindOnPage.md | 126 +++++++++++++++++++++++++------------------------- 1 file changed, 64 insertions(+), 62 deletions(-) diff --git a/FindOnPage.md b/FindOnPage.md index dcc32fce4..bc0fce95d 100644 --- a/FindOnPage.md +++ b/FindOnPage.md @@ -489,106 +489,108 @@ namespace Microsoft.Web.WebView2.Core CoreWebView2FindOptions CreateFindOptions(); }; -runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} + runtimeclass CoreWebView2FindOptions : [default]ICoreWebView2FindOptions {} - /// Interface defining the Find options. - /// This interface provides the necessary methods and properties to configure a Find operation. - [com_interface("staging=ICoreWebView2FindOptions")] + /// Interface defining the find options. + /// This interface provides the necessary methods and properties to configure a find session. + [com_interface("experimental=ICoreWebView2ExperimentalFindOptions")] [ms_owner("core", "maxwellmyers@microsoft.com")] - [availability("staging")] - interface ICoreWebView2FindOptions + [availability("experimental")] + interface ICoreWebView2FindOptions { - /// Gets or sets the Find term used for the Find operation. Returns the Find term. + /// Gets or sets the word or phrase to be searched in the current page. + /// You can set `FindTerm` to any text you want to find on the page. + /// This will take effect the next time you call the `StartAsync()` method. String FindTerm { get; set; }; - /// Determines if the Find operation is case sensitive. Returns TRUE if the Find is case sensitive, FALSE otherwise. - /// The locale used to determine case sensitivity is the document's language specified by the HTML lang attribute. If unspecified then the WebView2's UI locale - /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration + /// Determines if the find session is case sensitive. Returns TRUE if the find is case sensitive, FALSE otherwise. + /// When toggling case sensitivity, the behavior can vary by locale, which may be influenced by both the browser's UI locale and the document's language settings. The browser's UI locale + /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content. Boolean IsCaseSensitive { get; set; }; - /// Similar to case sensitivity, word matching also can vary by locale, which may be influenced by both the browser's UI locale and the document's language settings. The browser's UI locale - /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration + /// Similar to case sensitivity, word matching also can vary by locale, which may be influenced by both the browser's UI locale and the document's language settings. The browser's UI locale + /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content. - /// ShouldMatchWord determines if only whole words should be matched during the Find operation. Returns TRUE if only whole words should be matched, FALSE otherwise. + /// ShouldMatchWord determines if only whole words should be matched during the find session. Returns TRUE if only whole words should be matched, FALSE otherwise. Boolean ShouldMatchWord { get; set; }; - - /// Gets or sets the state of whether all matches are highlighted. + + /// Gets or sets the state of whether all matches are highlighted. /// Returns TRUE if all matches are highlighted, FALSE otherwise. - /// Note: Changes to this property take effect only when StartFind is called. - /// Preferences for the session cannot be updated unless another call to the StartFind function on the server-side is made. + /// Note: Changes to this property take effect only when StartAsync, FindNext, or FindPrevious is called. + /// Preferences for the session cannot be updated unless another call to the StartAsync function on the server-side is made. /// Therefore, changes will not take effect until one of these functions is called. Boolean ShouldHighlightAllMatches { get; set; }; - - /// Sets this property to hide the default Find UI. - /// You can use this to hide the default UI so that you can show your own custom UI or programmatically interact with the Find API while showing no Find UI. + + /// Sets this property to hide the default Find UI. + /// You can use this to hide the default UI so that you can show your own custom UI or programmatically interact with the Find API while showing no Find UI. /// Returns TRUE if hiding the default Find UI and FALSE if using showing the default Find UI. - /// Note: Changes to this property take effect only when StartFind, FindNext, or FindPrevious is called. - /// Preferences for the session cannot be updated unless another call to the StartFind function on the server-side is made. + /// Note: Changes to this property take effect only when StartAsync, FindNext, or FindPrevious is called. + /// Preferences for the session cannot be updated unless another call to the StartAsync function on the server-side is made. /// Therefore, changes will not take effect until one of these functions is called. Boolean SuppressDefaultFindDialog { get; set; }; }; - + runtimeclass CoreWebView2Find : [default]ICoreWebView2Find {} - /// Interface providing methods and properties for finding and navigating through text in the WebView2. - /// This interface allows for finding text, navigation between matches, and customization of the Find UI. - [com_interface("staging=ICoreWebView2StagingFind")] + /// Interface providing methods and properties for finding and navigating through text in the web view. + /// This interface allows for finding text, navigation between matches, and customization of the find UI. + [com_interface("experimental=ICoreWebView2ExperimentalFind")] [ms_owner("core", "maxwellmyers@microsoft.com")] - [availability("staging")] - interface ICoreWebView2Find + [availability("experimental")] + interface ICoreWebView2Find { - [completed_handler("")] - /// Initiates a Find session using the specified options asynchronously. - /// Displays the Find bar and starts the Find operation. If a Find session was already ongoing, it will be stopped and replaced with this new instance. - /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the Find options object after initiation won't affect the ongoing Find session. - /// To change the ongoing Find session, StartAsync must be called again with a new or modified Find options object. - /// StartAsync supports, HTML, PDF, and TXT document queries. In general this api is designed for text based Find sessions. - //// If you start a Find session programmatically on another file format that doesnt have text fields, the Find session will show the find UI but not find any matches. - /// StartAsync Completion: The asynchronous action completes when the UI has been displayed with the Find term in the UI bar, and the matches have populated on the counter on the Find bar. - /// There may be a slight latency between the UI display and the matches populating in the counter. - /// The MatchCountChanged and ActiveMatchIndexChanged events are only raised after StartAsync has completed, otherwise they will have their default values (-1 for ActiveMatchIndex and 0 for TotalMatchCount). - /// However, calling StartFind again during an ongoing Find operation does not resume from the point - /// of the current active match. For example, given the text "1 1 A 1 1" and initiating a Find session for "A", - /// then starting another Find session for "1", it will start searching from the beginning of the document, - /// regardless of the previous active match. This behavior indicates that changing the Find query initiates a - /// completely new Find session, rather than continuing from the previous match index. This distinction is essential - /// to understand when utilizing the StartFind method for navigating through text matches. + /// Initiates a find using the specified find options asynchronously. + /// Displays the Find bar and starts the find session. If a find session was already ongoing, it will be stopped and replaced with this new instance. + /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the FindOptions object after initiation won't affect the ongoing find session. + /// To change the ongoing find session, StartAsync must be called again with a new or modified FindOptions object. + /// StartAsync supports HTML and TXT document queries. In general, this API is designed for text-based find sessions. + /// If you start a find session programmatically on another file format that doesn't have text fields, the find session will try to execute but will fail to find any matches. (It will silently fail) + /// Note: The asynchronous action completes when the UI has been displayed with the find term in the UI bar, and the matches have populated on the counter on the find bar. + /// There may be a slight latency between the UI display and the matches populating in the counter. + /// The MatchCountChanged and ActiveMatchIndexChanged events are only raised after StartAsync has completed; otherwise, they will have their default values (-1 for active match index and 0 for match count). + /// To start a new find session (beginning the search from the first match), call `Stop` before invoking `StartAsync`. + /// If `StartAsync` is called consecutively with the same options and without calling `Stop`, the find session + /// will continue from the current position in the existing session. + /// Calling `StartAsync` without altering its parameters will behave either as `FindNext` or `FindPrevious`, depending on the most recent search action performed. + /// StartAsync will default to forward if neither have been called. + /// However, calling Start again during an ongoing find session does not resume from the point + /// of the current active match. For example, given the text "1 1 A 1 1" and initiating a find session for "A", + /// then starting another find session for "1", it will start searching from the beginning of the document, + /// regardless of the previous active match. This behavior indicates that changing the find query initiates a + /// completely new find session, rather than continuing from the previous match index. Windows.Foundation.IAsyncAction StartAsync(CoreWebView2FindOptions options); - /// Navigates to the next match in the document. - /// If there are no matches to Find, FindNext will wrap around to the first match. - /// If called when there is no Find session active, FindNext will silently fail. + /// If there are no matches to find, FindNext will wrap around to the first match's index. + /// If called when there is no find session active, FindPrevious will silently fail. void FindNext(); - + /// Navigates to the previous match in the document. - /// If there are no matches to Find, FindPrevious will wrap around to the last match. - /// If called when there is no Find session active, FindPrevious will silently fail. + /// If there are no matches to find, FindPrevious will wrap around to the last match's index. + /// If called when there is no find session active, FindPrevious will silently fail. void FindPrevious(); - - /// Stops the current 'Find' operation and hides the Find bar. + /// Stops the current 'Find' session and hides the Find bar. /// If called with no Find session active, it will silently do nothing. - void StopFind(); + void Stop(); - /// Retrieves the index of the currently active match in the Find session. Returns the index of the currently active match, or -1 if there is no active match. + /// Retrieves the index of the currently active match in the find session. Returns the index of the currently active match, or -1 if there is no active match. + /// The index starts at 1 for the first match. Int32 ActiveMatchIndex { get; }; - /// Gets the total count of matches found in the current document based on the last Find sessions criteria. Returns the total count of matches. + /// Gets the total count of matches found in the current document based on the last find sessions criteria. Returns the total count of matches. Int32 MatchCount { get; }; - - /// Registers an event handler for the MatchCountChanged event. - /// This event is raised when the total count of matches in the document changes due to a new Find operation or changes in the document. + + /// Registers an event handler for the MatchCountChanged event. + /// This event is raised when the total count of matches in the document changes due to a new find session or changes in the document. /// The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. - [event_handler("", "", "")] event Windows.Foundation.TypedEventHandler MatchCountChanged; /// Registers an event handler for the ActiveMatchIndexChanged event. This event is raised when the index of the currently active match changes. - /// This can happen when the user navigates to a different match or when the active match is changed programmatically. - /// The parameter is the event handler to be added. Returns a token representing the added event handler. + /// This can happen when the user navigates to a different match or when the active match is changed programmatically. + /// The parameter is the event handler to be added. Returns a token representing the added event handler. /// This token can be used to unregister the event handler. - [event_handler("", "", "")] event Windows.Foundation.TypedEventHandler ActiveMatchIndexChanged; };