blob: 8db8ffb79bbb608380d4288c624b23466bea131b [file] [log] [blame]
/*
* Copyright (C) 2016 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.documentsui.dirlist;
import android.annotation.Nullable;
import android.view.KeyEvent;
import android.view.View;
/**
* A class that handles navigation and focus within the DirectoryFragment.
*/
public interface FocusHandler extends View.OnFocusChangeListener {
/**
* Handles navigation (setting focus, adjusting selection if needed) arising from incoming key
* events.
*
* @param doc The DocumentHolder receiving the key event.
* @param keyCode
* @param event
* @return Whether the event was handled.
*/
boolean handleKey(DocumentHolder doc, int keyCode, KeyEvent event);
@Override
void onFocusChange(View v, boolean hasFocus);
void onLayoutCompleted();
void focusDocument(String modelId);
/**
* Requests focus on the item that last had focus. Scrolls to that item if necessary. If focus
* is unsuccessful, return false.
*/
boolean requestFocus();
/**
* @return The adapter position of the last focused item.
*/
int getFocusPosition();
/**
* @return True if there is currently an item in focus, false otherwise.
*/
boolean hasFocusedItem();
/**
* @return The modelId of the last focused item. If no item is focused, this should return null.
*/
@Nullable String getFocusModelId();
}