blob: f4f7d7c59c2098b184e51404df886545f1956a14 [file] [log] [blame]
/*
* Copyright (C) 2015 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 static com.android.documentsui.base.DocumentInfo.getCursorLong;
import static com.android.documentsui.base.DocumentInfo.getCursorString;
import android.annotation.ColorInt;
import android.content.Context;
import android.database.Cursor;
import android.provider.DocumentsContract.Document;
import android.text.format.Formatter;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;
import com.android.documentsui.R;
import com.android.documentsui.base.DebugFlags;
import com.android.documentsui.base.DocumentInfo;
import com.android.documentsui.base.Events.InputEvent;
import com.android.documentsui.base.Shared;
import com.android.documentsui.roots.RootCursorWrapper;
final class GridDocumentHolder extends DocumentHolder {
final TextView mTitle;
final TextView mDate;
final TextView mDetails;
final ImageView mIconMimeLg;
final ImageView mIconMimeSm;
final ImageView mIconThumb;
final ImageView mIconCheck;
final IconHelper mIconHelper;
private final @ColorInt int mDisabledBgColor;
// This is used in as a convenience in our bind method.
private final DocumentInfo mDoc = new DocumentInfo();
public GridDocumentHolder(Context context, ViewGroup parent, IconHelper iconHelper) {
super(context, parent, R.layout.item_doc_grid);
mDisabledBgColor = context.getColor(R.color.item_doc_background_disabled);
mTitle = (TextView) itemView.findViewById(android.R.id.title);
mDate = (TextView) itemView.findViewById(R.id.date);
mDetails = (TextView) itemView.findViewById(R.id.details);
mIconMimeLg = (ImageView) itemView.findViewById(R.id.icon_mime_lg);
mIconMimeSm = (ImageView) itemView.findViewById(R.id.icon_mime_sm);
mIconThumb = (ImageView) itemView.findViewById(R.id.icon_thumb);
mIconCheck = (ImageView) itemView.findViewById(R.id.icon_check);
mIconHelper = iconHelper;
}
@Override
public void setSelected(boolean selected, boolean animate) {
// We always want to make sure our check box disappears if we're not selected,
// even if the item is disabled. This is because this object can be reused
// and this method will be called to setup initial state.
float checkAlpha = selected ? 1f : 0f;
if (animate) {
fade(mIconMimeSm, checkAlpha).start();
fade(mIconCheck, checkAlpha).start();
} else {
mIconCheck.setAlpha(checkAlpha);
}
// But it should be an error to be set to selected && be disabled.
if (!itemView.isEnabled()) {
assert(!selected);
return;
}
super.setSelected(selected, animate);
if (animate) {
fade(mIconMimeSm, 1f - checkAlpha).start();
} else {
mIconMimeSm.setAlpha(1f - checkAlpha);
}
}
@Override
public void setEnabled(boolean enabled) {
super.setEnabled(enabled);
// Text colors enabled/disabled is handle via a color set.
itemView.setBackgroundColor(enabled ? mDefaultBgColor : mDisabledBgColor);
float imgAlpha = enabled ? 1f : DISABLED_ALPHA;
mIconMimeLg.setAlpha(imgAlpha);
mIconMimeSm.setAlpha(imgAlpha);
mIconThumb.setAlpha(imgAlpha);
}
@Override
public boolean isInDragHotspot(InputEvent event) {
// Entire grid box should be draggable
return true;
}
/**
* Bind this view to the given document for display.
* @param cursor Pointing to the item to be bound.
* @param modelId The model ID of the item.
* @param state Current display state.
*/
@Override
public void bind(Cursor cursor, String modelId) {
assert(cursor != null);
mModelId = modelId;
mDoc.updateFromCursor(cursor, getCursorString(cursor, RootCursorWrapper.COLUMN_AUTHORITY));
mIconHelper.stopLoading(mIconThumb);
mIconMimeLg.animate().cancel();
mIconMimeLg.setAlpha(1f);
mIconThumb.animate().cancel();
mIconThumb.setAlpha(0f);
mIconHelper.load(mDoc, mIconThumb, mIconMimeLg, mIconMimeSm);
mTitle.setText(mDoc.displayName, TextView.BufferType.SPANNABLE);
mTitle.setVisibility(View.VISIBLE);
// If file is partial, we want to show summary field as that's more relevant than fileSize
// and date
if (mDoc.isPartial()) {
final String docSummary = getCursorString(cursor, Document.COLUMN_SUMMARY);
mDetails.setVisibility(View.VISIBLE);
mDate.setText(null);
mDetails.setText(docSummary);
} else {
if (mDoc.lastModified == -1) {
mDate.setText(null);
} else {
mDate.setText(Shared.formatTime(mContext, mDoc.lastModified));
}
final long docSize = getCursorLong(cursor, Document.COLUMN_SIZE);
if (mDoc.isDirectory() || docSize == -1) {
mDetails.setVisibility(View.GONE);
} else {
mDetails.setVisibility(View.VISIBLE);
mDetails.setText(Formatter.formatFileSize(mContext, docSize));
}
}
if (DebugFlags.getDocumentDetailsEnabled()) {
includeDebugInfo(mDoc);
}
}
}