blob: 50528b1bdd12afee012f121b977ad83610b3ee6e [file] [log] [blame]
The Android Open Source Project31dd5032009-03-03 19:32:27 -08001/*
2 * Copyright (C) 2009 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
The Android Open Source Project7376fae2009-03-11 12:11:58 -070019import android.appwidget.AppWidgetHostView;
Michael Jurkaaf442092010-06-10 17:01:57 -070020import android.content.ComponentName;
The Android Open Source Project31dd5032009-03-03 19:32:27 -080021import android.content.ContentValues;
Kenny Guyed131872014-04-30 03:02:21 +010022import android.content.Context;
23
24import com.android.launcher3.compat.UserHandleCompat;
The Android Open Source Project31dd5032009-03-03 19:32:27 -080025
26/**
Patrick Dubroy6569f2c2010-07-12 14:25:18 -070027 * Represents a widget (either instantiated or about to be) in the Launcher.
The Android Open Source Project31dd5032009-03-03 19:32:27 -080028 */
Anjali Koppal7b168a12014-03-04 17:16:11 -080029public class LauncherAppWidgetInfo extends ItemInfo {
The Android Open Source Project31dd5032009-03-03 19:32:27 -080030
Sunny Goyal651077b2014-06-30 14:15:31 -070031 public static final int RESTORE_COMPLETED = 0;
32
33 /**
34 * This is set during the package backup creation.
35 */
Sunny Goyalff572272014-07-23 13:58:07 -070036 public static final int FLAG_ID_NOT_VALID = 1;
Sunny Goyal651077b2014-06-30 14:15:31 -070037
38 /**
Sunny Goyalff572272014-07-23 13:58:07 -070039 * Indicates that the provider is not available yet.
Sunny Goyal651077b2014-06-30 14:15:31 -070040 */
Sunny Goyalff572272014-07-23 13:58:07 -070041 public static final int FLAG_PROVIDER_NOT_READY = 2;
42
43 /**
44 * Indicates that the widget UI is not yet ready, and user needs to set it up again.
45 */
46 public static final int FLAG_UI_NOT_READY = 4;
Sunny Goyal651077b2014-06-30 14:15:31 -070047
The Android Open Source Project31dd5032009-03-03 19:32:27 -080048 /**
Patrick Dubroy6569f2c2010-07-12 14:25:18 -070049 * Indicates that the widget hasn't been instantiated yet.
50 */
51 static final int NO_ID = -1;
52
53 /**
Romain Guy629de3e2010-01-13 12:20:59 -080054 * Identifier for this widget when talking with
55 * {@link android.appwidget.AppWidgetManager} for updates.
The Android Open Source Project31dd5032009-03-03 19:32:27 -080056 */
Patrick Dubroy6569f2c2010-07-12 14:25:18 -070057 int appWidgetId = NO_ID;
58
Michael Jurkaaf442092010-06-10 17:01:57 -070059 ComponentName providerName;
Adam Cohended9f8d2010-11-03 13:25:16 -070060
Patrick Dubroy6569f2c2010-07-12 14:25:18 -070061 // TODO: Are these necessary here?
62 int minWidth = -1;
63 int minHeight = -1;
64
Sunny Goyal651077b2014-06-30 14:15:31 -070065 /**
66 * Indicates the restore status of the widget.
67 */
68 int restoreStatus;
69
Sunny Goyal0fc1be12014-08-11 17:05:23 -070070 /**
71 * Indicates the installation progress of the widget provider
72 */
Sunny Goyale7b8cd92014-08-27 14:04:33 -070073 int installProgress = -1;
Sunny Goyal0fc1be12014-08-11 17:05:23 -070074
Winson Chung211bac32012-05-15 13:43:57 -070075 private boolean mHasNotifiedInitialWidgetSizeChanged;
76
The Android Open Source Project31dd5032009-03-03 19:32:27 -080077 /**
The Android Open Source Project7376fae2009-03-11 12:11:58 -070078 * View that holds this widget after it's been created. This view isn't created
The Android Open Source Project31dd5032009-03-03 19:32:27 -080079 * until Launcher knows it's needed.
80 */
The Android Open Source Project7376fae2009-03-11 12:11:58 -070081 AppWidgetHostView hostView = null;
The Android Open Source Project31dd5032009-03-03 19:32:27 -080082
Winson Chung11a49372012-04-27 15:12:38 -070083 LauncherAppWidgetInfo(int appWidgetId, ComponentName providerName) {
Patrick Dubroy6569f2c2010-07-12 14:25:18 -070084 itemType = LauncherSettings.Favorites.ITEM_TYPE_APPWIDGET;
Winson Chung11a49372012-04-27 15:12:38 -070085 this.appWidgetId = appWidgetId;
Patrick Dubroy6569f2c2010-07-12 14:25:18 -070086 this.providerName = providerName;
87
88 // Since the widget isn't instantiated yet, we don't know these values. Set them to -1
89 // to indicate that they should be calculated based on the layout and minWidth/minHeight
90 spanX = -1;
91 spanY = -1;
Kenny Guyed131872014-04-30 03:02:21 +010092 // We only support app widgets on current user.
93 user = UserHandleCompat.myUserHandle();
Sunny Goyal651077b2014-06-30 14:15:31 -070094 restoreStatus = RESTORE_COMPLETED;
Patrick Dubroy6569f2c2010-07-12 14:25:18 -070095 }
96
The Android Open Source Project31dd5032009-03-03 19:32:27 -080097 @Override
Kenny Guyed131872014-04-30 03:02:21 +010098 void onAddToDatabase(Context context, ContentValues values) {
99 super.onAddToDatabase(context, values);
The Android Open Source Project7376fae2009-03-11 12:11:58 -0700100 values.put(LauncherSettings.Favorites.APPWIDGET_ID, appWidgetId);
Chris Wrend5e66bf2013-09-16 14:02:29 -0400101 values.put(LauncherSettings.Favorites.APPWIDGET_PROVIDER, providerName.flattenToString());
Sunny Goyalff572272014-07-23 13:58:07 -0700102 values.put(LauncherSettings.Favorites.RESTORED, restoreStatus);
The Android Open Source Project31dd5032009-03-03 19:32:27 -0800103 }
104
Winson Chung211bac32012-05-15 13:43:57 -0700105 /**
106 * When we bind the widget, we should notify the widget that the size has changed if we have not
107 * done so already (only really for default workspace widgets).
108 */
109 void onBindAppWidget(Launcher launcher) {
Adam Cohenaaa5c212012-10-05 18:14:31 -0700110 if (!mHasNotifiedInitialWidgetSizeChanged) {
Winson Chung211bac32012-05-15 13:43:57 -0700111 notifyWidgetSizeChanged(launcher);
112 }
113 }
114
115 /**
116 * Trigger an update callback to the widget to notify it that its size has changed.
117 */
118 void notifyWidgetSizeChanged(Launcher launcher) {
119 AppWidgetResizeFrame.updateWidgetSizeRanges(hostView, launcher, spanX, spanY);
120 mHasNotifiedInitialWidgetSizeChanged = true;
121 }
122
The Android Open Source Project31dd5032009-03-03 19:32:27 -0800123 @Override
124 public String toString() {
Daniel Sandler8802e962010-05-26 16:28:16 -0400125 return "AppWidget(id=" + Integer.toString(appWidgetId) + ")";
The Android Open Source Project31dd5032009-03-03 19:32:27 -0800126 }
Joe Onorato9c1289c2009-08-17 11:03:03 -0400127
Joe Onorato9c1289c2009-08-17 11:03:03 -0400128 @Override
129 void unbind() {
130 super.unbind();
131 hostView = null;
132 }
Sunny Goyal651077b2014-06-30 14:15:31 -0700133
134 public final boolean isWidgetIdValid() {
Sunny Goyalff572272014-07-23 13:58:07 -0700135 return (restoreStatus & FLAG_ID_NOT_VALID) == 0;
136 }
137
138 public final boolean hasRestoreFlag(int flag) {
139 return (restoreStatus & flag) == flag;
Sunny Goyal651077b2014-06-30 14:15:31 -0700140 }
The Android Open Source Project31dd5032009-03-03 19:32:27 -0800141}