summaryrefslogtreecommitdiff
path: root/src/com/android/car/media/drawer/MediaDrawerAdapter.java
blob: dc483a2bb46be11038f4a2d0e2751593168a3d8b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
/*
 * 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.car.media.drawer;

import com.android.car.app.CarDrawerActivity;
import com.android.car.app.CarDrawerAdapter;
import com.android.car.app.DrawerItemViewHolder;

/**
 * Subclass of CarDrawerAdapter used by the Media app.
 * <p>
 * This adapter delegates actual fetching of items (and other operations) to a
 * {@link MediaItemsFetcher}. The current fetcher being used can be updated at runtime.
 */
class MediaDrawerAdapter extends CarDrawerAdapter {
    private final CarDrawerActivity mActivity;
    private MediaItemsFetcher mCurrentFetcher;

    MediaDrawerAdapter(CarDrawerActivity activity, boolean useSmallLayout) {
        super(activity, true /* showDisabledListOnEmpty */, useSmallLayout);
        mActivity = activity;
    }

    /**
     * Switch the {@link MediaItemsFetcher} being used to fetch items. The new fetcher is kicked-off
     * and the drawer's content's will be updated to show newly loaded items. Any old fetcher is
     * cleaned up and released.
     *
     * @param fetcher New {@link MediaItemsFetcher} to use for display Drawer items.
     */
    void setFetcher(MediaItemsFetcher fetcher) {
        if (mCurrentFetcher != null) {
            mCurrentFetcher.cleanup();
        }
        mCurrentFetcher = fetcher;
        mCurrentFetcher.start(() -> {
            mActivity.showLoadingProgressBar(false);
            notifyDataSetChanged();
        });
        // Initially there will be no items and we don't want to show empty-list indicator briefly
        // until items are fetched.
        mActivity.showLoadingProgressBar(true);
    }

    @Override
    protected int getActualItemCount() {
        return mCurrentFetcher != null ? mCurrentFetcher.getItemCount() : 0;
    }

    @Override
    protected void populateViewHolder(DrawerItemViewHolder holder, int position) {
        if (mCurrentFetcher != null) {
            mCurrentFetcher.populateViewHolder(holder, position);
        }
    }

    @Override
    public void onItemClick(int position) {
        if (mCurrentFetcher != null) {
            mCurrentFetcher.onItemClick(position);
        }
    }
}