1 /* 2 * Copyright (C) 2018 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package android.telecom; 18 19 import android.annotation.IntDef; 20 import android.annotation.NonNull; 21 import android.os.Parcel; 22 import android.os.Parcelable; 23 24 import java.lang.annotation.Retention; 25 import java.lang.annotation.RetentionPolicy; 26 import java.util.Objects; 27 28 public final class PhoneAccountSuggestion implements Parcelable { 29 30 /** @hide */ 31 @Retention(RetentionPolicy.SOURCE) 32 @IntDef(value = {REASON_NONE, REASON_INTRA_CARRIER, REASON_FREQUENT, 33 REASON_USER_SET, REASON_OTHER}, prefix = { "REASON_" }) 34 public @interface SuggestionReason {} 35 36 /** 37 * Indicates that this account is not suggested for use, but is still available. 38 */ 39 public static final int REASON_NONE = 0; 40 41 /** 42 * Indicates that the {@link PhoneAccountHandle} is suggested because the number we're calling 43 * is on the same carrier, and therefore may have lower rates. 44 */ 45 public static final int REASON_INTRA_CARRIER = 1; 46 47 /** 48 * Indicates that the {@link PhoneAccountHandle} is suggested because the user uses it 49 * frequently for the number that we are calling. 50 */ 51 public static final int REASON_FREQUENT = 2; 52 53 /** 54 * Indicates that the {@link PhoneAccountHandle} is suggested because the user explicitly 55 * specified that it be used for the number we are calling. 56 */ 57 public static final int REASON_USER_SET = 3; 58 59 /** 60 * Indicates that the {@link PhoneAccountHandle} is suggested for a reason not otherwise 61 * enumerated here. 62 */ 63 public static final int REASON_OTHER = 4; 64 65 private PhoneAccountHandle mHandle; 66 private int mReason; 67 private boolean mShouldAutoSelect; 68 69 /** 70 * Creates a new instance of {@link PhoneAccountSuggestion}. This constructor is intended for 71 * use by apps implementing a {@code PhoneAccountSuggestionService}, and generally should not be 72 * used by dialer apps other than for testing purposes. 73 * 74 * @param handle The {@link PhoneAccountHandle} for this suggestion. 75 * @param reason The reason for this suggestion 76 * @param shouldAutoSelect Whether the dialer should automatically place the call using this 77 * account. See {@link #shouldAutoSelect()}. 78 */ PhoneAccountSuggestion(@onNull PhoneAccountHandle handle, @SuggestionReason int reason, boolean shouldAutoSelect)79 public PhoneAccountSuggestion(@NonNull PhoneAccountHandle handle, @SuggestionReason int reason, 80 boolean shouldAutoSelect) { 81 this.mHandle = handle; 82 this.mReason = reason; 83 this.mShouldAutoSelect = shouldAutoSelect; 84 } 85 PhoneAccountSuggestion(Parcel in)86 private PhoneAccountSuggestion(Parcel in) { 87 mHandle = in.readParcelable(PhoneAccountHandle.class.getClassLoader(), android.telecom.PhoneAccountHandle.class); 88 mReason = in.readInt(); 89 mShouldAutoSelect = in.readByte() != 0; 90 } 91 92 public static final @android.annotation.NonNull Creator<PhoneAccountSuggestion> CREATOR = 93 new Creator<PhoneAccountSuggestion>() { 94 @Override 95 public PhoneAccountSuggestion createFromParcel(Parcel in) { 96 return new PhoneAccountSuggestion(in); 97 } 98 99 @Override 100 public PhoneAccountSuggestion[] newArray(int size) { 101 return new PhoneAccountSuggestion[size]; 102 } 103 }; 104 105 /** 106 * @return The {@link PhoneAccountHandle} for this suggestion. 107 */ getPhoneAccountHandle()108 @NonNull public PhoneAccountHandle getPhoneAccountHandle() { 109 return mHandle; 110 } 111 112 /** 113 * @return The reason for this suggestion 114 */ getReason()115 public @SuggestionReason int getReason() { 116 return mReason; 117 } 118 119 /** 120 * Suggests whether the dialer should automatically place the call using this account without 121 * user interaction. This may be set on multiple {@link PhoneAccountSuggestion}s, and the dialer 122 * is free to choose which one to use. 123 * @return {@code true} if the hint is to auto-select, {@code false} otherwise. 124 */ shouldAutoSelect()125 public boolean shouldAutoSelect() { 126 return mShouldAutoSelect; 127 } 128 129 @Override describeContents()130 public int describeContents() { 131 return 0; 132 } 133 134 @Override writeToParcel(Parcel dest, int flags)135 public void writeToParcel(Parcel dest, int flags) { 136 dest.writeParcelable(mHandle, flags); 137 dest.writeInt(mReason); 138 dest.writeByte((byte) (mShouldAutoSelect ? 1 : 0)); 139 } 140 141 @Override equals(Object o)142 public boolean equals(Object o) { 143 if (this == o) return true; 144 if (o == null || getClass() != o.getClass()) return false; 145 PhoneAccountSuggestion that = (PhoneAccountSuggestion) o; 146 return mReason == that.mReason 147 && mShouldAutoSelect == that.mShouldAutoSelect 148 && Objects.equals(mHandle, that.mHandle); 149 } 150 151 @Override hashCode()152 public int hashCode() { 153 return Objects.hash(mHandle, mReason, mShouldAutoSelect); 154 } 155 } 156