blob: 1b7f9fba2f47c8f5a29c604b62da1ea36591c9e5 [file] [log] [blame]
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <Foundation/Foundation.h>
#include "base/ios/block_types.h"
#include "base/macros.h"
#include "ios/web/public/web_state/web_state_observer.h"
#import "ios/web/public/web_state/web_state_user_data.h"
@class FindInPageController;
@class FindInPageModel;
typedef void (^FindInPageCompletionBlock)(FindInPageModel*);
// Names for Find In Page UMA actions (Find, FindNext, FindPrevious).
extern const char kFindActionName[];
extern const char kFindNextActionName[];
extern const char kFindPreviousActionName[];
// Adds support for the "Find in page" feature.
class FindTabHelper : public web::WebStateObserver,
public web::WebStateUserData<FindTabHelper> {
~FindTabHelper() override;
enum FindDirection {
// Starts an asynchronous Find operation that will call the given completion
// handler with results. Highlights matches on the current page. Always
// searches in the FORWARD direction.
void StartFinding(NSString* search_string,
FindInPageCompletionBlock completion);
// Runs an asynchronous Find operation that will call the given completion
// handler with results. Highlights matches on the current page. Uses the
// previously remembered search string and searches in the given |direction|.
void ContinueFinding(FindDirection direction,
FindInPageCompletionBlock completion);
// Stops any running find operations and runs the given completion block.
// Removes any highlighting from the current page.
void StopFinding(ProceduralBlock completion);
// Returns the FindInPageModel that contains the latest find results.
FindInPageModel* GetFindResult() const;
// Returns true if the currently loaded page supports Find in Page.
bool CurrentPageSupportsFindInPage() const;
// Returns true if the Find in Page UI is currently visible.
bool IsFindUIActive() const;
// Marks the Find in Page UI as visible or not. This method does not directly
// show or hide the UI. It simply acts as a marker for whether or not the UI
// is visible.
void SetFindUIActive(bool active);
// Saves the current find text to persistent storage.
void PersistSearchTerm();
// Restores the current find text from persistent storage.
void RestoreSearchTerm();
friend class FindTabHelperTest;
friend class web::WebStateUserData<FindTabHelper>;
// Private constructor used by CreateForWebState().
FindTabHelper(web::WebState* web_state);
// web::WebStateObserver.
void DidFinishNavigation(web::WebState* web_state,
web::NavigationContext* navigation_context) override;
void WebStateDestroyed(web::WebState* web_state) override;
// The ObjC find in page controller.
FindInPageController* controller_;