summaryrefslogtreecommitdiff
path: root/java/com/android/dialer/searchfragment/nearbyplaces/NearbyPlacesCursor.java
blob: a4142a41d367c5440dd80cf0d784b4b76f5245f3 (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
/*
 * 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.dialer.searchfragment.nearbyplaces;

import android.content.Context;
import android.database.Cursor;
import android.database.MatrixCursor;
import android.database.MergeCursor;
import android.support.annotation.Nullable;
import com.android.dialer.searchfragment.common.SearchCursor;

/** {@link SearchCursor} implementation for displaying on nearby places. */
final class NearbyPlacesCursor extends MergeCursor implements SearchCursor {

  private final Cursor nearbyPlacesCursor;

  public static NearbyPlacesCursor newInstnace(Context context, Cursor nearbyPlacesCursor) {
    MatrixCursor headerCursor = new MatrixCursor(HEADER_PROJECTION);
    headerCursor.addRow(new String[] {context.getString(R.string.nearby_places)});
    return new NearbyPlacesCursor(new Cursor[] {headerCursor, nearbyPlacesCursor});
  }

  private NearbyPlacesCursor(Cursor[] cursors) {
    super(cursors);
    nearbyPlacesCursor = cursors[1];
  }

  @Override
  public boolean isHeader() {
    return isFirst();
  }

  @Override
  public boolean updateQuery(@Nullable String query) {
    // When the query changes, a new network request is made for nearby places. Meaning this cursor
    // will be closed and another created, so return false.
    return false;
  }

  @Override
  public int getCount() {
    // If we don't have any contents, we don't want to show the header
    if (nearbyPlacesCursor == null || nearbyPlacesCursor.isClosed()) {
      return 0;
    }

    int count = nearbyPlacesCursor.getCount();
    return count == 0 ? 0 : count + 1;
  }
}