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 package android.app.prediction;
17 
18 import android.annotation.IntDef;
19 import android.annotation.NonNull;
20 import android.annotation.Nullable;
21 import android.annotation.SystemApi;
22 import android.annotation.TestApi;
23 import android.os.Parcel;
24 import android.os.Parcelable;
25 
26 import java.lang.annotation.Retention;
27 import java.lang.annotation.RetentionPolicy;
28 
29 /**
30  * A representation of an app target event.
31  *
32  * @hide
33  */
34 @SystemApi
35 @TestApi
36 public final class AppTargetEvent implements Parcelable {
37 
38     /**
39      * @hide
40      */
41     @IntDef({ACTION_LAUNCH, ACTION_DISMISS, ACTION_PIN})
42     @Retention(RetentionPolicy.SOURCE)
43     public @interface ActionType {}
44 
45     /**
46      * Event type constant indicating an app target has been launched.
47      */
48     public static final int ACTION_LAUNCH = 1;
49 
50     /**
51      * Event type constant indicating an app target has been dismissed.
52      */
53     public static final int ACTION_DISMISS = 2;
54 
55     /**
56      * Event type constant indicating an app target has been pinned.
57      */
58     public static final int ACTION_PIN = 3;
59 
60     private final AppTarget mTarget;
61     private final String mLocation;
62     private final int mAction;
63 
AppTargetEvent(@ullable AppTarget target, @Nullable String location, @ActionType int actionType)64     private AppTargetEvent(@Nullable AppTarget target, @Nullable String location,
65             @ActionType int actionType) {
66         mTarget = target;
67         mLocation = location;
68         mAction = actionType;
69     }
70 
AppTargetEvent(Parcel parcel)71     private AppTargetEvent(Parcel parcel) {
72         mTarget = parcel.readParcelable(null);
73         mLocation = parcel.readString();
74         mAction = parcel.readInt();
75     }
76 
77     /**
78      * Returns the app target.
79      */
80     @Nullable
getTarget()81     public AppTarget getTarget() {
82         return mTarget;
83     }
84 
85     /**
86      * Returns the launch location.
87      */
88     @Nullable
getLaunchLocation()89     public String getLaunchLocation() {
90         return mLocation;
91     }
92 
93     /**
94      * Returns the action type.
95      */
getAction()96     public @ActionType int getAction() {
97         return mAction;
98     }
99 
100     @Override
equals(@ullable Object o)101     public boolean equals(@Nullable Object o) {
102         if (!getClass().equals(o != null ? o.getClass() : null)) return false;
103 
104         AppTargetEvent other = (AppTargetEvent) o;
105         return mTarget.equals(other.mTarget)
106                 && mLocation.equals(other.mLocation)
107                 && mAction == other.mAction;
108     }
109 
110     @Override
describeContents()111     public int describeContents() {
112         return 0;
113     }
114 
115     @Override
writeToParcel(Parcel dest, int flags)116     public void writeToParcel(Parcel dest, int flags) {
117         dest.writeParcelable(mTarget, 0);
118         dest.writeString(mLocation);
119         dest.writeInt(mAction);
120     }
121 
122     public static final @android.annotation.NonNull Creator<AppTargetEvent> CREATOR =
123             new Creator<AppTargetEvent>() {
124                 public AppTargetEvent createFromParcel(Parcel parcel) {
125                     return new AppTargetEvent(parcel);
126                 }
127 
128                 public AppTargetEvent[] newArray(int size) {
129                     return new AppTargetEvent[size];
130                 }
131             };
132 
133     /**
134      * A builder for app target events.
135      *
136      * @hide
137      */
138     @SystemApi
139     @TestApi
140     public static final class Builder {
141         private AppTarget mTarget;
142         private String mLocation;
143         private @ActionType int mAction;
144 
145         /**
146          * @param target The app target that is associated with this event.
147          * @param actionType The event type, which is one of the values in {@link ActionType}.
148          */
Builder(@ullable AppTarget target, @ActionType int actionType)149         public Builder(@Nullable AppTarget target, @ActionType int actionType) {
150             mTarget = target;
151             mAction = actionType;
152         }
153 
154         /**
155          * Sets the launch location.
156          */
157         @NonNull
setLaunchLocation(@ullable String location)158         public Builder setLaunchLocation(@Nullable String location) {
159             mLocation = location;
160             return this;
161         }
162 
163         /**
164          * Builds a new event instance.
165          */
166         @NonNull
build()167         public AppTargetEvent build() {
168             return new AppTargetEvent(mTarget, mLocation, mAction);
169         }
170     }
171 }
172