Chromium Code Reviews| Index: chrome/android/java/src/org/chromium/chrome/browser/download/ui/OfflineGroupHeaderView.java |
| diff --git a/chrome/android/java/src/org/chromium/chrome/browser/download/ui/OfflineGroupHeaderView.java b/chrome/android/java/src/org/chromium/chrome/browser/download/ui/OfflineGroupHeaderView.java |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..93d1ef9026cb262ae79950e4214eb3705c8cc822 |
| --- /dev/null |
| +++ b/chrome/android/java/src/org/chromium/chrome/browser/download/ui/OfflineGroupHeaderView.java |
| @@ -0,0 +1,64 @@ |
| +// Copyright 2016 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. |
| + |
| +package org.chromium.chrome.browser.download.ui; |
| + |
| +import android.content.Context; |
| +import android.text.format.Formatter; |
| +import android.util.AttributeSet; |
| +import android.view.View; |
| +import android.widget.FrameLayout; |
| +import android.widget.ImageView; |
| +import android.widget.TextView; |
| + |
| +import org.chromium.chrome.R; |
| + |
| +/** A header that presents users to view or hide the suggested offline pages. */ |
| +public class OfflineGroupHeaderView extends FrameLayout { |
| + private TextView mPageCountHeader; |
| + private TextView mDescription; |
| + private TextView mFileSizeView; |
| + private ImageView mImageView; |
| + |
| + private DownloadItemGroup mGroup; |
| + private DownloadHistoryAdapter mAdapter; |
| + |
| + public OfflineGroupHeaderView(Context context, AttributeSet attrs) { |
| + super(context, attrs); |
| + setOnClickListener(new View.OnClickListener() { |
| + @Override |
| + public void onClick(View v) { |
| + if (!mGroup.offlinePageExpanded()) { |
|
gone
2017/02/02 23:59:48
Positive condition on top.
shaktisahu
2017/02/04 18:57:43
Done.
|
| + mAdapter.expandOfflineHeader(mGroup); |
| + mImageView.setImageResource(R.drawable.ic_collapsed); |
| + } else { |
| + mAdapter.collapseOfflineHeader(mGroup); |
| + mImageView.setImageResource(R.drawable.ic_expanded); |
| + } |
| + } |
| + }); |
| + } |
| + |
| + @Override |
| + protected void onFinishInflate() { |
| + super.onFinishInflate(); |
| + mPageCountHeader = (TextView) findViewById(R.id.page_count_text); |
| + mDescription = (TextView) findViewById(R.id.description); |
| + mFileSizeView = (TextView) findViewById(R.id.filesize_view); |
| + mImageView = (ImageView) findViewById(R.id.expand_icon); |
| + mDescription.setText(R.string.download_manager_offline_header_description); |
|
gone
2017/02/02 23:59:48
If this text never changes, put it in the XML itse
shaktisahu
2017/02/04 18:57:43
Done.
|
| + } |
| + |
| + public void bindGroupAndAdapter(DownloadItemGroup group, DownloadHistoryAdapter adapter) { |
| + mGroup = group; |
| + mAdapter = adapter; |
|
gone
2017/02/02 23:59:48
This should call updateTitleText directly.
shaktisahu
2017/02/04 18:57:43
Done.
|
| + } |
| + |
| + public void updateTitleText(int pageCount) { |
| + mPageCountHeader.setText(getResources().getString( |
| + R.string.download_manager_offline_header_title, pageCount)); |
| + mFileSizeView.setText( |
| + Formatter.formatFileSize(getContext(), mGroup.getOfflinePagesFileSize())); |
| + } |
| +} |