blob: c99465c77c55b98908f37f44e5857b326e9da4e4 [file] [log] [blame]
The Android Open Source Project31dd5032009-03-03 19:32:27 -08001/*
2 * Copyright (C) 2008 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
Daniel Sandler325dc232013-06-05 22:57:57 -040017package com.android.launcher3;
The Android Open Source Project31dd5032009-03-03 19:32:27 -080018
Tony Wickham1bce7fd2016-04-28 17:39:03 -070019import android.content.ComponentName;
The Android Open Source Project31dd5032009-03-03 19:32:27 -080020import android.content.ContentValues;
Winson Chungbe365162012-05-07 10:34:12 -070021import android.content.Intent;
Sunny Goyal7c74e4a2016-12-15 15:53:17 -080022import android.os.Process;
23import android.os.UserHandle;
The Android Open Source Project31dd5032009-03-03 19:32:27 -080024
Pinyao Ting2f9019e2019-08-16 13:28:24 -070025import androidx.annotation.Nullable;
26
Sunny Goyal32f3dda2016-11-11 11:45:00 -080027import com.android.launcher3.util.ContentWriter;
Kenny Guyed131872014-04-30 03:02:21 +010028
The Android Open Source Project31dd5032009-03-03 19:32:27 -080029/**
30 * Represents an item in the launcher.
31 */
Mathew Inwood72fbec12013-11-19 15:45:07 +000032public class ItemInfo {
Kenny Guyed131872014-04-30 03:02:21 +010033
Hyunyoung Song3f471442015-04-08 19:01:34 -070034 public static final int NO_ID = -1;
Sunny Goyalaa8ef112015-06-12 20:04:41 -070035
The Android Open Source Project31dd5032009-03-03 19:32:27 -080036 /**
37 * The id in the settings database for this item
38 */
Sunny Goyalefb7e842018-10-04 15:11:00 -070039 public int id = NO_ID;
Sunny Goyalaa8ef112015-06-12 20:04:41 -070040
The Android Open Source Project31dd5032009-03-03 19:32:27 -080041 /**
42 * One of {@link LauncherSettings.Favorites#ITEM_TYPE_APPLICATION},
43 * {@link LauncherSettings.Favorites#ITEM_TYPE_SHORTCUT},
Hyunyoung Song86160f52017-02-06 10:46:24 -080044 * {@link LauncherSettings.Favorites#ITEM_TYPE_DEEP_SHORTCUT}
45 * {@link LauncherSettings.Favorites#ITEM_TYPE_FOLDER},
46 * {@link LauncherSettings.Favorites#ITEM_TYPE_APPWIDGET} or
47 * {@link LauncherSettings.Favorites#ITEM_TYPE_CUSTOM_APPWIDGET}.
The Android Open Source Project31dd5032009-03-03 19:32:27 -080048 */
Anjali Koppale3e646e2014-03-17 09:34:39 -070049 public int itemType;
Sunny Goyalaa8ef112015-06-12 20:04:41 -070050
The Android Open Source Project31dd5032009-03-03 19:32:27 -080051 /**
Sunny Goyalaa8ef112015-06-12 20:04:41 -070052 * The id of the container that holds this item. For the desktop, this will be
The Android Open Source Project31dd5032009-03-03 19:32:27 -080053 * {@link LauncherSettings.Favorites#CONTAINER_DESKTOP}. For the all applications folder it
54 * will be {@link #NO_ID} (since it is not stored in the settings DB). For user folders
55 * it will be the id of the folder.
56 */
Sunny Goyalefb7e842018-10-04 15:11:00 -070057 public int container = NO_ID;
Sunny Goyalaa8ef112015-06-12 20:04:41 -070058
The Android Open Source Project31dd5032009-03-03 19:32:27 -080059 /**
Hyunyoung Song86160f52017-02-06 10:46:24 -080060 * Indicates the screen in which the shortcut appears if the container types is
61 * {@link LauncherSettings.Favorites#CONTAINER_DESKTOP}. (i.e., ignore if the container type is
62 * {@link LauncherSettings.Favorites#CONTAINER_HOTSEAT})
The Android Open Source Project31dd5032009-03-03 19:32:27 -080063 */
Sunny Goyalefb7e842018-10-04 15:11:00 -070064 public int screenId = -1;
Sunny Goyalaa8ef112015-06-12 20:04:41 -070065
The Android Open Source Project31dd5032009-03-03 19:32:27 -080066 /**
67 * Indicates the X position of the associated cell.
68 */
Anjali Koppale3e646e2014-03-17 09:34:39 -070069 public int cellX = -1;
The Android Open Source Project31dd5032009-03-03 19:32:27 -080070
71 /**
72 * Indicates the Y position of the associated cell.
73 */
Anjali Koppale3e646e2014-03-17 09:34:39 -070074 public int cellY = -1;
The Android Open Source Project31dd5032009-03-03 19:32:27 -080075
76 /**
77 * Indicates the X cell span.
78 */
Anjali Koppale3e646e2014-03-17 09:34:39 -070079 public int spanX = 1;
The Android Open Source Project31dd5032009-03-03 19:32:27 -080080
81 /**
82 * Indicates the Y cell span.
83 */
Hyunyoung Song3f471442015-04-08 19:01:34 -070084 public int spanY = 1;
The Android Open Source Project31dd5032009-03-03 19:32:27 -080085
Romain Guy73b979d2009-06-09 12:57:21 -070086 /**
Adam Cohend41fbf52012-02-16 23:53:59 -080087 * Indicates the minimum X cell span.
88 */
Anjali Koppale3e646e2014-03-17 09:34:39 -070089 public int minSpanX = 1;
Adam Cohend41fbf52012-02-16 23:53:59 -080090
91 /**
92 * Indicates the minimum Y cell span.
93 */
Anjali Koppale3e646e2014-03-17 09:34:39 -070094 public int minSpanY = 1;
Adam Cohen487f7dd2012-06-28 18:12:10 -070095
Adam Cohend41fbf52012-02-16 23:53:59 -080096 /**
Sunny Goyal08f72612015-01-05 13:41:43 -080097 * Indicates the position in an ordered list.
98 */
99 public int rank = 0;
100
101 /**
Adam Cohen487f7dd2012-06-28 18:12:10 -0700102 * Title of the item
103 */
Hyunyoung Song3f471442015-04-08 19:01:34 -0700104 public CharSequence title;
Romain Guy73b979d2009-06-09 12:57:21 -0700105
Patrick Dubroybbaa75c2011-03-08 18:47:40 -0800106 /**
Kenny Guyc2bd8102014-06-30 12:30:31 +0100107 * Content description of the item.
108 */
Hyunyoung Song3f471442015-04-08 19:01:34 -0700109 public CharSequence contentDescription;
Kenny Guyc2bd8102014-06-30 12:30:31 +0100110
Sunny Goyal7c74e4a2016-12-15 15:53:17 -0800111 public UserHandle user;
Kenny Guyed131872014-04-30 03:02:21 +0100112
Hyunyoung Song3f471442015-04-08 19:01:34 -0700113 public ItemInfo() {
Sunny Goyal7c74e4a2016-12-15 15:53:17 -0800114 user = Process.myUserHandle();
The Android Open Source Project31dd5032009-03-03 19:32:27 -0800115 }
116
Michael Jurkac9d95c52011-08-29 14:03:34 -0700117 ItemInfo(ItemInfo info) {
Sunny Goyalff572272014-07-23 13:58:07 -0700118 copyFrom(info);
Sunny Goyalff572272014-07-23 13:58:07 -0700119 }
120
121 public void copyFrom(ItemInfo info) {
The Android Open Source Project31dd5032009-03-03 19:32:27 -0800122 id = info.id;
123 cellX = info.cellX;
124 cellY = info.cellY;
125 spanX = info.spanX;
126 spanY = info.spanY;
Sunny Goyal08f72612015-01-05 13:41:43 -0800127 rank = info.rank;
Adam Cohendcd297f2013-06-18 13:13:40 -0700128 screenId = info.screenId;
The Android Open Source Project31dd5032009-03-03 19:32:27 -0800129 itemType = info.itemType;
130 container = info.container;
Kenny Guyed131872014-04-30 03:02:21 +0100131 user = info.user;
Kenny Guyc2bd8102014-06-30 12:30:31 +0100132 contentDescription = info.contentDescription;
The Android Open Source Project31dd5032009-03-03 19:32:27 -0800133 }
134
Anjali Koppale3e646e2014-03-17 09:34:39 -0700135 public Intent getIntent() {
Vadim Tryshevd6c8e7e2015-07-08 13:40:14 -0700136 return null;
Winson Chung997a9232013-07-24 15:33:46 -0700137 }
138
Pinyao Ting2f9019e2019-08-16 13:28:24 -0700139 @Nullable
Tony Wickham1bce7fd2016-04-28 17:39:03 -0700140 public ComponentName getTargetComponent() {
Sunny Goyal34ab6df2017-07-06 06:16:01 -0700141 Intent intent = getIntent();
Mario Bertschler8ff9e1d2017-08-08 16:26:18 -0700142 if (intent != null) {
143 return intent.getComponent();
144 } else {
Sunny Goyal34ab6df2017-07-06 06:16:01 -0700145 return null;
146 }
Tony Wickham1bce7fd2016-04-28 17:39:03 -0700147 }
148
Sunny Goyal32f3dda2016-11-11 11:45:00 -0800149 public void writeToValues(ContentWriter writer) {
150 writer.put(LauncherSettings.Favorites.ITEM_TYPE, itemType)
151 .put(LauncherSettings.Favorites.CONTAINER, container)
152 .put(LauncherSettings.Favorites.SCREEN, screenId)
153 .put(LauncherSettings.Favorites.CELLX, cellX)
154 .put(LauncherSettings.Favorites.CELLY, cellY)
155 .put(LauncherSettings.Favorites.SPANX, spanX)
156 .put(LauncherSettings.Favorites.SPANY, spanY)
157 .put(LauncherSettings.Favorites.RANK, rank);
Sunny Goyal756cd262015-08-20 12:33:21 -0700158 }
159
160 public void readFromValues(ContentValues values) {
161 itemType = values.getAsInteger(LauncherSettings.Favorites.ITEM_TYPE);
Sunny Goyalefb7e842018-10-04 15:11:00 -0700162 container = values.getAsInteger(LauncherSettings.Favorites.CONTAINER);
163 screenId = values.getAsInteger(LauncherSettings.Favorites.SCREEN);
Sunny Goyalde51d1d2015-08-31 11:47:03 -0700164 cellX = values.getAsInteger(LauncherSettings.Favorites.CELLX);
165 cellY = values.getAsInteger(LauncherSettings.Favorites.CELLY);
166 spanX = values.getAsInteger(LauncherSettings.Favorites.SPANX);
167 spanY = values.getAsInteger(LauncherSettings.Favorites.SPANY);
168 rank = values.getAsInteger(LauncherSettings.Favorites.RANK);
Sunny Goyal756cd262015-08-20 12:33:21 -0700169 }
170
171 /**
172 * Write the fields of this item to the DB
Sunny Goyal756cd262015-08-20 12:33:21 -0700173 */
Sunny Goyal658058b2017-01-21 01:33:02 -0800174 public void onAddToDatabase(ContentWriter writer) {
Adrian Roos8f3f6832014-04-28 15:45:52 +0200175 if (screenId == Workspace.EXTRA_EMPTY_SCREEN_ID) {
176 // We should never persist an item on the extra empty screen.
177 throw new RuntimeException("Screen id should not be EXTRA_EMPTY_SCREEN_ID");
178 }
The Android Open Source Project31dd5032009-03-03 19:32:27 -0800179
Sunny Goyal32f3dda2016-11-11 11:45:00 -0800180 writeToValues(writer);
181 writer.put(LauncherSettings.Favorites.PROFILE_ID, user);
The Android Open Source Project31dd5032009-03-03 19:32:27 -0800182 }
Adam Cohen4eac29a2011-07-11 17:53:37 -0700183
Daniel Sandler8802e962010-05-26 16:28:16 -0400184 @Override
Sunny Goyal1edab712016-09-01 10:55:20 -0700185 public final String toString() {
186 return getClass().getSimpleName() + "(" + dumpProperties() + ")";
187 }
188
189 protected String dumpProperties() {
190 return "id=" + id
Hyunyoung Song86160f52017-02-06 10:46:24 -0800191 + " type=" + LauncherSettings.Favorites.itemTypeToString(itemType)
192 + " container=" + LauncherSettings.Favorites.containerToString((int)container)
Sunny Goyal1edab712016-09-01 10:55:20 -0700193 + " screen=" + screenId
Hyunyoung Song86160f52017-02-06 10:46:24 -0800194 + " cell(" + cellX + "," + cellY + ")"
195 + " span(" + spanX + "," + spanY + ")"
196 + " minSpan(" + minSpanX + "," + minSpanY + ")"
Sunny Goyal1edab712016-09-01 10:55:20 -0700197 + " rank=" + rank
198 + " user=" + user
199 + " title=" + title;
Daniel Sandler8802e962010-05-26 16:28:16 -0400200 }
Kenny Guy44cba692016-01-21 19:50:02 +0000201
202 /**
203 * Whether this item is disabled.
204 */
205 public boolean isDisabled() {
206 return false;
207 }
Sunny Goyalef92b822018-11-21 14:12:00 -0800208
209 public int getViewId() {
210 // aapt-generated IDs have the high byte nonzero; clamp to the range under that.
211 // This cast is safe as long as the id < 0x00FFFFFF
212 // Since we jail all the dynamically generated views, there should be no clashes
213 // with any other views.
214 return id;
215 }
216
Samuel Fufa5cf3e862020-02-03 20:22:54 -0800217 /**
218 * Returns if an Item is a predicted item
219 */
220 public boolean isPredictedItem() {
221 return container == LauncherSettings.Favorites.CONTAINER_HOTSEAT_PREDICTION
222 || container == LauncherSettings.Favorites.CONTAINER_PREDICTION;
223 }
The Android Open Source Project31dd5032009-03-03 19:32:27 -0800224}