blob: bfd89678dfdbdd946308fcd86557fbceb27ccf1d [file] [log] [blame]
/*
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.launcher3.allapps;
import android.view.KeyEvent;
import androidx.annotation.Nullable;
import com.android.launcher3.ExtendedEditText;
/**
* Interface for controlling the Apps search UI.
*/
public interface SearchUiManager {
/**
* Initializes the search manager.
*/
void initializeSearch(ActivityAllAppsContainerView<?> containerView);
/**
* Notifies the search manager to close any active search session.
*/
void resetSearch();
/**
* Called before dispatching a key event, in case the search manager wants to initialize
* some UI beforehand.
*/
default void preDispatchKeyEvent(KeyEvent keyEvent) { };
/**
* @return the edit text object
*/
@Nullable
ExtendedEditText getEditText();
/**
* Hint to the edit text that it is about to be focused or unfocused. This can be used to start
* animating the edit box accordingly, e.g. after a gesture completes.
*
* @param focused true if the edit text is about to be focused, false if it will be unfocused
*/
default void prepareToFocusEditText(boolean focused) {}
/**
* Sets whether EditText background should be visible
* @param maxAlpha defines the maximum alpha the background should animates to
*/
default void setBackgroundVisibility(boolean visible, float maxAlpha) {}
/**
* Returns whether a visible background is set on EditText
*/
default boolean getBackgroundVisibility() {
return false;
}
/**
* sets highlight result's title
*/
default void setFocusedResultTitle(
@Nullable CharSequence title, @Nullable CharSequence subtitle, boolean showArrow) {}
/** Refresh the currently displayed list of results. */
default void refreshResults() {}
/** Returns whether search is in zero state. */
default boolean inZeroState() {
return false;
}
}