extract different appshortcut implementations into classes

This commit is contained in:
f43nd1r 2020-01-17 23:37:05 +01:00
parent 3db14d85d0
commit 79f6d5500e
6 changed files with 249 additions and 254 deletions

View file

@ -130,4 +130,6 @@ android {
dependencies { dependencies {
compile project(':core') compile project(':core')
compile files('libs/sesame-lib-1.2.1.aar')
implementation "androidx.annotation:annotation:1.1.0"
} }

View file

@ -41,6 +41,7 @@ import android.widget.ViewAnimator;
import net.pierrox.lightning_launcher.LLApp; import net.pierrox.lightning_launcher.LLApp;
import net.pierrox.lightning_launcher.api.ScreenIdentity; import net.pierrox.lightning_launcher.api.ScreenIdentity;
import net.pierrox.lightning_launcher.appshortcuts.ShortcutDetails;
import net.pierrox.lightning_launcher.configuration.GlobalConfig; import net.pierrox.lightning_launcher.configuration.GlobalConfig;
import net.pierrox.lightning_launcher.configuration.ItemConfig; import net.pierrox.lightning_launcher.configuration.ItemConfig;
import net.pierrox.lightning_launcher.configuration.PageConfig; import net.pierrox.lightning_launcher.configuration.PageConfig;
@ -331,7 +332,7 @@ public class AppDrawerX extends Dashboard implements EditTextIme.OnEditTextImeLi
} }
@Override @Override
protected void openBubble(int mode, ItemLayout itemLayout, ItemView itemView, Rect focus, List shortcuts) { protected void openBubble(int mode, ItemLayout itemLayout, ItemView itemView, Rect focus, List<ShortcutDetails> shortcuts) {
mItemLayout.cancelDelayedItemViewLoad(); mItemLayout.cancelDelayedItemViewLoad();
super.openBubble(mode, itemLayout, itemView, focus, shortcuts); super.openBubble(mode, itemLayout, itemView, focus, shortcuts);
} }
@ -1118,7 +1119,7 @@ public class AppDrawerX extends Dashboard implements EditTextIme.OnEditTextImeLi
} }
@Override @Override
protected void configureBubbleForItem(int mode, ItemView itemView, List shortcuts) { protected void configureBubbleForItem(int mode, ItemView itemView, List<ShortcutDetails> shortcuts) {
Item item = itemView.getItem(); Item item = itemView.getItem();
if(mode == BUBBLE_MODE_ITEM_EM) { if(mode == BUBBLE_MODE_ITEM_EM) {
boolean is_folder = item instanceof Folder; boolean is_folder = item instanceof Folder;

View file

@ -2,123 +2,45 @@ package net.pierrox.lightning_launcher.activities;
import android.Manifest; import android.Manifest;
import android.annotation.TargetApi; import android.annotation.TargetApi;
import android.app.ActivityManager; import android.app.*;
import android.app.AlertDialog;
import android.app.Dialog;
import android.app.ProgressDialog;
import android.app.WallpaperManager;
import android.appwidget.AppWidgetManager; import android.appwidget.AppWidgetManager;
import android.appwidget.AppWidgetProviderInfo; import android.appwidget.AppWidgetProviderInfo;
import android.content.ActivityNotFoundException; import android.content.*;
import android.content.BroadcastReceiver; import android.content.pm.*;
import android.content.ClipData;
import android.content.ComponentName;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.IntentFilter;
import android.content.pm.ActivityInfo;
import android.content.pm.LauncherActivityInfo;
import android.content.pm.LauncherApps;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.PackageManager.NameNotFoundException; import android.content.pm.PackageManager.NameNotFoundException;
import android.content.pm.ResolveInfo;
import android.content.pm.ShortcutInfo;
import android.content.res.Configuration; import android.content.res.Configuration;
import android.content.res.Resources; import android.content.res.Resources;
import android.graphics.Bitmap; import android.graphics.*;
import android.graphics.Color;
import android.graphics.Matrix;
import android.graphics.PixelFormat;
import android.graphics.Point;
import android.graphics.Rect;
import android.graphics.RectF;
import android.graphics.Typeface;
import android.graphics.drawable.ColorDrawable; import android.graphics.drawable.ColorDrawable;
import android.graphics.drawable.Drawable; import android.graphics.drawable.Drawable;
import android.graphics.drawable.Icon; import android.graphics.drawable.Icon;
import android.net.Uri; import android.net.Uri;
import android.os.AsyncTask;
import android.os.Build;
import android.os.Bundle;
import android.os.Handler;
import android.os.Parcelable;
import android.os.Process; import android.os.Process;
import android.os.SystemClock; import android.os.*;
import android.os.UserHandle;
import android.text.InputType; import android.text.InputType;
import android.util.DisplayMetrics; import android.util.DisplayMetrics;
import android.util.Log; import android.util.Log;
import android.util.Pair; import android.util.Pair;
import android.util.SparseArray; import android.util.SparseArray;
import android.view.Display; import android.view.*;
import android.view.Gravity;
import android.view.HapticFeedbackConstants;
import android.view.KeyEvent;
import android.view.Menu;
import android.view.MenuItem;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener; import android.view.View.OnClickListener;
import android.view.View.OnLongClickListener; import android.view.View.OnLongClickListener;
import android.view.ViewConfiguration; import android.view.animation.*;
import android.view.ViewGroup; import android.widget.*;
import android.view.Window; import androidx.annotation.Nullable;
import android.view.animation.AlphaAnimation;
import android.view.animation.Animation;
import android.view.animation.AnimationSet;
import android.view.animation.AnimationUtils;
import android.view.animation.TranslateAnimation;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.EditText;
import android.widget.FrameLayout;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.ViewAnimator;
import com.boombuler.system.appwidgetpicker.AppWidgetPickerActivity; import com.boombuler.system.appwidgetpicker.AppWidgetPickerActivity;
import com.google.android.hotword.client.HotwordServiceClient; import com.google.android.hotword.client.HotwordServiceClient;
import com.readystatesoftware.systembartint.SystemBarTintManager; import com.readystatesoftware.systembartint.SystemBarTintManager;
import net.pierrox.lightning_launcher.API; import net.pierrox.lightning_launcher.API;
import net.pierrox.lightning_launcher.LLApp; import net.pierrox.lightning_launcher.LLApp;
import net.pierrox.lightning_launcher.Version; import net.pierrox.lightning_launcher.Version;
import net.pierrox.lightning_launcher.api.ScreenIdentity; import net.pierrox.lightning_launcher.api.ScreenIdentity;
import net.pierrox.lightning_launcher.configuration.DynamicTextConfig; import net.pierrox.lightning_launcher.appshortcuts.LauncherAppsShortcutDetails;
import net.pierrox.lightning_launcher.configuration.FolderConfig; import net.pierrox.lightning_launcher.appshortcuts.SesameShortcutDetails;
import net.pierrox.lightning_launcher.configuration.GlobalConfig; import net.pierrox.lightning_launcher.appshortcuts.ShortcutDetails;
import net.pierrox.lightning_launcher.configuration.ItemConfig; import net.pierrox.lightning_launcher.configuration.*;
import net.pierrox.lightning_launcher.configuration.PageConfig;
import net.pierrox.lightning_launcher.configuration.ShortcutConfig;
import net.pierrox.lightning_launcher.configuration.ShortcutConfigStylable;
import net.pierrox.lightning_launcher.configuration.SystemConfig;
import net.pierrox.lightning_launcher.data.Action;
import net.pierrox.lightning_launcher.data.Box;
import net.pierrox.lightning_launcher.data.ContainerPath;
import net.pierrox.lightning_launcher.data.CustomView;
import net.pierrox.lightning_launcher.data.DynamicText;
import net.pierrox.lightning_launcher.data.EmbeddedFolder;
import net.pierrox.lightning_launcher.data.Error; import net.pierrox.lightning_launcher.data.Error;
import net.pierrox.lightning_launcher.data.EventAction; import net.pierrox.lightning_launcher.data.*;
import net.pierrox.lightning_launcher.data.FileUtils;
import net.pierrox.lightning_launcher.data.Folder;
import net.pierrox.lightning_launcher.data.Item;
import net.pierrox.lightning_launcher.data.JsonLoader;
import net.pierrox.lightning_launcher.data.LightningIntent;
import net.pierrox.lightning_launcher.data.Page;
import net.pierrox.lightning_launcher.data.PageIndicator;
import net.pierrox.lightning_launcher.data.SavedItemGeometry;
import net.pierrox.lightning_launcher.data.SelectionState;
import net.pierrox.lightning_launcher.data.Shortcut;
import net.pierrox.lightning_launcher.data.StopPoint;
import net.pierrox.lightning_launcher.data.UndoStack;
import net.pierrox.lightning_launcher.data.Unlocker;
import net.pierrox.lightning_launcher.data.Utils;
import net.pierrox.lightning_launcher.data.Widget;
import net.pierrox.lightning_launcher.engine.LightningEngine; import net.pierrox.lightning_launcher.engine.LightningEngine;
import net.pierrox.lightning_launcher.engine.Screen; import net.pierrox.lightning_launcher.engine.Screen;
import net.pierrox.lightning_launcher.script.Script; import net.pierrox.lightning_launcher.script.Script;
@ -128,24 +50,14 @@ import net.pierrox.lightning_launcher.script.api.ImageBitmap;
import net.pierrox.lightning_launcher.util.AddItemDialog; import net.pierrox.lightning_launcher.util.AddItemDialog;
import net.pierrox.lightning_launcher.util.PhoneUtils; import net.pierrox.lightning_launcher.util.PhoneUtils;
import net.pierrox.lightning_launcher.util.Setup; import net.pierrox.lightning_launcher.util.Setup;
import net.pierrox.lightning_launcher.views.BubbleLayout; import net.pierrox.lightning_launcher.views.*;
import net.pierrox.lightning_launcher.views.CustomizeItemView;
import net.pierrox.lightning_launcher.views.EditBarHiderView;
import net.pierrox.lightning_launcher.views.FolderView;
import net.pierrox.lightning_launcher.views.HandleView;
import net.pierrox.lightning_launcher.views.HandleView.Handle; import net.pierrox.lightning_launcher.views.HandleView.Handle;
import net.pierrox.lightning_launcher.views.HierarchyScreen;
import net.pierrox.lightning_launcher.views.ItemLayout;
import net.pierrox.lightning_launcher.views.MyViewPager;
import net.pierrox.lightning_launcher.views.SnappingContext;
import net.pierrox.lightning_launcher.views.TransformLayout;
import net.pierrox.lightning_launcher.views.item.EmbeddedFolderView; import net.pierrox.lightning_launcher.views.item.EmbeddedFolderView;
import net.pierrox.lightning_launcher.views.item.ItemView; import net.pierrox.lightning_launcher.views.item.ItemView;
import net.pierrox.lightning_launcher.views.item.StopPointView; import net.pierrox.lightning_launcher.views.item.StopPointView;
import net.pierrox.lightning_launcher.views.item.WidgetView; import net.pierrox.lightning_launcher.views.item.WidgetView;
import net.pierrox.lightning_launcher_extreme.BuildConfig; import net.pierrox.lightning_launcher_extreme.BuildConfig;
import net.pierrox.lightning_launcher_extreme.R; import net.pierrox.lightning_launcher_extreme.R;
import ninja.sesame.lib.bridge.v1.SesameFrontend; import ninja.sesame.lib.bridge.v1.SesameFrontend;
import ninja.sesame.lib.bridge.v1.SesameShortcut; import ninja.sesame.lib.bridge.v1.SesameShortcut;
import org.mozilla.javascript.Function; import org.mozilla.javascript.Function;
@ -156,12 +68,7 @@ import java.io.IOException;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.net.URISyntaxException; import java.net.URISyntaxException;
import java.text.DecimalFormat; import java.text.DecimalFormat;
import java.util.ArrayList; import java.util.*;
import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.Stack;
@ -174,7 +81,7 @@ public class Dashboard extends ResourceWrapperActivity implements OnLongClickLis
private static final int DIALOG_IMPORT_LL=204; private static final int DIALOG_IMPORT_LL=204;
private static final int DIALOG_STOP_POINT=206; private static final int DIALOG_STOP_POINT=206;
private static final int DIALOG_WRAP=207; private static final int DIALOG_WRAP=207;
private static final int DIALOG_LAUNCHER_APPS_NO_HOST_PERMISSION =208; public static final int DIALOG_LAUNCHER_APPS_NO_HOST_PERMISSION =208;
private static final String SIS_NAVIGATION="a"; private static final String SIS_NAVIGATION="a";
private static final String SIS_ALLOCATED_APP_WIDGET_ID="b"; private static final String SIS_ALLOCATED_APP_WIDGET_ID="b";
@ -740,14 +647,29 @@ public class Dashboard extends ResourceWrapperActivity implements OnLongClickLis
mScreen.saveInstanceState(outState); mScreen.saveInstanceState(outState);
} }
@Override
public void startActivity(Intent intent, @Nullable Bundle options) {
beforeStartActivity(intent);
super.startActivity(intent, options);
afterStartActivity(intent);
}
@Override @Override
public void startActivity(Intent intent) { public void startActivity(Intent intent) {
beforeStartActivity(intent);
super.startActivity(intent);
afterStartActivity(intent);
}
private void beforeStartActivity(Intent intent) {
mPausedBecauseOfLaunch = true; mPausedBecauseOfLaunch = true;
if("ninja.sesame.app.edge".equals(intent.getPackage()) || if("ninja.sesame.app.edge".equals(intent.getPackage()) ||
(intent.getComponent() != null) && "ninja.sesame.app.edge".equals(intent.getComponent().getPackageName())) { (intent.getComponent() != null) && "ninja.sesame.app.edge".equals(intent.getComponent().getPackageName())) {
SesameFrontend.addPackageAuth(this, intent); SesameFrontend.addPackageAuth(this, intent);
} }
super.startActivity(intent); }
private void afterStartActivity(Intent intent) {
applyLaunchAnimation(mLastLaunchAnimation, true); applyLaunchAnimation(mLastLaunchAnimation, true);
} }
@ -3644,14 +3566,14 @@ public class Dashboard extends ResourceWrapperActivity implements OnLongClickLis
openBubble(mode, itemLayout, null, focus, null); openBubble(mode, itemLayout, null, focus, null);
} }
private void openBubbleAppShortcuts(ItemView itemView, List shortcuts) { private void openBubbleAppShortcuts(ItemView itemView, List<ShortcutDetails> shortcuts) {
openBubble(BUBBLE_MODE_APP_SHORTCUTS, itemView.getParentItemLayout(), itemView, mScreen.computeItemViewBounds(itemView), shortcuts); openBubble(BUBBLE_MODE_APP_SHORTCUTS, itemView.getParentItemLayout(), itemView, mScreen.computeItemViewBounds(itemView), shortcuts);
} }
/** /**
* Do not use directly, use the other versions of openBubble * Do not use directly, use the other versions of openBubble
*/ */
protected void openBubble(int mode, ItemLayout itemLayout, ItemView itemView, Rect focus, List shortcuts) { protected void openBubble(int mode, ItemLayout itemLayout, ItemView itemView, Rect focus, List<ShortcutDetails> shortcuts) {
if(mBubble == null) { if(mBubble == null) {
mBubble=(BubbleLayout) getLayoutInflater().inflate(R.layout.bubble, null); mBubble=(BubbleLayout) getLayoutInflater().inflate(R.layout.bubble, null);
mEditControlsView.addView(mBubble); mEditControlsView.addView(mBubble);
@ -3767,29 +3689,21 @@ public class Dashboard extends ResourceWrapperActivity implements OnLongClickLis
} }
@TargetApi(Build.VERSION_CODES.N_MR1) @TargetApi(Build.VERSION_CODES.N_MR1)
protected void addAppShortcutBubbleItems(List shortcuts) { protected void addAppShortcutBubbleItems(List<ShortcutDetails> shortcuts) {
for (Object shortcut : shortcuts) { for (ShortcutDetails shortcut : shortcuts) {
addAppShortcutBubbleItem(shortcut); addAppShortcutBubbleItem(shortcut);
} }
} }
@TargetApi(Build.VERSION_CODES.N_MR1) @TargetApi(Build.VERSION_CODES.N_MR1)
private void addAppShortcutBubbleItem(Object shortcutObject) { private void addAppShortcutBubbleItem(ShortcutDetails shortcut) {
if(shortcutObject instanceof ShortcutInfo) {
ShortcutInfo shortcut = (ShortcutInfo) shortcutObject;
final LauncherApps launcherApps = (LauncherApps) getSystemService(LAUNCHER_APPS_SERVICE);
final View view = getLayoutInflater().inflate(R.layout.two_lines_list_item, null); final View view = getLayoutInflater().inflate(R.layout.two_lines_list_item, null);
final Drawable iconDrawable = launcherApps.getShortcutIconDrawable(shortcut, Utils.getLauncherIconDensity()); final Drawable iconDrawable = shortcut.getIcon(this);
Bitmap icon = Utils.createBitmapFromDrawable(iconDrawable); Bitmap icon = Utils.createBitmapFromDrawable(iconDrawable);
ImageView iconView = (ImageView) view.findViewById(android.R.id.icon); ImageView iconView = (ImageView) view.findViewById(android.R.id.icon);
iconView.setImageBitmap(icon); iconView.setImageBitmap(icon);
((TextView) view.findViewById(android.R.id.text1)).setText(shortcut.getLabel());
CharSequence label = shortcut.getLongLabel();
if (label == null || label.length() == 0) {
label = shortcut.getShortLabel();
}
((TextView) view.findViewById(android.R.id.text1)).setText(label);
view.findViewById(android.R.id.text2).setVisibility(View.GONE); view.findViewById(android.R.id.text2).setVisibility(View.GONE);
Drawable background = getDrawable(R.drawable.bubble_item_bg); Drawable background = getDrawable(R.drawable.bubble_item_bg);
view.setBackground(background); view.setBackground(background);
@ -3799,15 +3713,7 @@ public class Dashboard extends ResourceWrapperActivity implements OnLongClickLis
@Override @Override
public void onClick(View view) { public void onClick(View view) {
closeBubble(); closeBubble();
((ShortcutDetails) view.getTag()).launch(view);
if(launcherApps.hasShortcutHostPermission()) {
ShortcutInfo shortcutInfo = (ShortcutInfo) view.getTag();
Rect bounds = new Rect();
view.getHitRect(bounds);
launcherApps.startShortcut(shortcutInfo, bounds, null);
} else {
showDialog(DIALOG_LAUNCHER_APPS_NO_HOST_PERMISSION);
}
} }
}; };
} }
@ -3821,10 +3727,10 @@ public class Dashboard extends ResourceWrapperActivity implements OnLongClickLis
view.performHapticFeedback(HapticFeedbackConstants.LONG_PRESS); view.performHapticFeedback(HapticFeedbackConstants.LONG_PRESS);
ShortcutInfo shortcutInfo = (ShortcutInfo) view.getTag(); ShortcutDetails shortcut = (ShortcutDetails) view.getTag();
ClipData clipData = ClipData.newPlainText("id", shortcutInfo.getId()); ClipData clipData = ClipData.newPlainText("id", shortcut.getId());
View shadowView = view.findViewById(android.R.id.icon); View shadowView = view.findViewById(android.R.id.icon);
view.startDragAndDrop(clipData, new View.DragShadowBuilder(shadowView), shortcutInfo, 0); view.startDragAndDrop(clipData, new View.DragShadowBuilder(shadowView), shortcut, 0);
return true; return true;
} }
}; };
@ -3834,57 +3740,6 @@ public class Dashboard extends ResourceWrapperActivity implements OnLongClickLis
view.setOnLongClickListener(mAppShortcutLongClickListener); view.setOnLongClickListener(mAppShortcutLongClickListener);
view.setTag(shortcut); view.setTag(shortcut);
mBubbleContent.addView(view); mBubbleContent.addView(view);
} else if(shortcutObject instanceof SesameShortcut) {
SesameShortcut shortcut = (SesameShortcut) shortcutObject;
final View view = getLayoutInflater().inflate(R.layout.two_lines_list_item, null);
final Drawable iconDrawable = Icon.createWithContentUri(shortcut.iconUri).loadDrawable(this);
Bitmap icon = Utils.createBitmapFromDrawable(iconDrawable);
ImageView iconView = (ImageView) view.findViewById(android.R.id.icon);
iconView.setImageBitmap(icon);
CharSequence label = shortcut.plainLabel;
((TextView) view.findViewById(android.R.id.text1)).setText(label);
view.findViewById(android.R.id.text2).setVisibility(View.GONE);
Drawable background = getDrawable(R.drawable.bubble_item_bg);
view.setBackground(background);
if(mAppShortcutClickListener == null) {
mAppShortcutClickListener = new OnClickListener() {
@Override
public void onClick(View view) {
closeBubble();
SesameShortcut shortcutInfo = (SesameShortcut) view.getTag();
Rect bounds = new Rect();
view.getHitRect(bounds);
SesameFrontend.runAction(Dashboard.this, shortcutInfo.actions[0]);
}
};
}
if(mAppShortcutLongClickListener == null) {
mAppShortcutLongClickListener = new OnLongClickListener() {
@TargetApi(Build.VERSION_CODES.N_MR1)
@Override
public boolean onLongClick(View view) {
closeBubble();
view.performHapticFeedback(HapticFeedbackConstants.LONG_PRESS);
SesameShortcut shortcutInfo = (SesameShortcut) view.getTag();
ClipData clipData = ClipData.newPlainText("id", shortcutInfo.id);
View shadowView = view.findViewById(android.R.id.icon);
view.startDragAndDrop(clipData, new View.DragShadowBuilder(shadowView), shortcutInfo, 0);
return true;
}
};
}
view.setOnClickListener(mAppShortcutClickListener);
view.setOnLongClickListener(mAppShortcutLongClickListener);
view.setTag(shortcut);
mBubbleContent.addView(view);
}
} }
private View.OnClickListener mAppShortcutClickListener; private View.OnClickListener mAppShortcutClickListener;
@ -4053,7 +3908,7 @@ public class Dashboard extends ResourceWrapperActivity implements OnLongClickLis
return true; return true;
} }
protected void configureBubbleForItem(final int mode, final ItemView itemView, List shortcuts) { protected void configureBubbleForItem(final int mode, final ItemView itemView, List<ShortcutDetails> shortcuts) {
Item item = itemView.getItem(); Item item = itemView.getItem();
Class<?> item_class = item.getClass(); Class<?> item_class = item.getClass();
@ -4245,15 +4100,25 @@ public class Dashboard extends ResourceWrapperActivity implements OnLongClickLis
} }
} }
List<?> shortcuts = null; List<ShortcutDetails> shortcuts = null;
if (activity != null) { if (activity != null) {
if (SesameFrontend.isConnected()) { if (SesameFrontend.isConnected()) {
shortcuts = SesameFrontend.getRecentAppShortcuts(activity.getPackageName(), true, 5); List<SesameShortcut> sesameShortcuts = SesameFrontend.getRecentAppShortcuts(activity.getPackageName(), true, 5);
shortcuts = new ArrayList<>(sesameShortcuts.size());
for (SesameShortcut sesameShortcut : sesameShortcuts) {
shortcuts.add(new SesameShortcutDetails(sesameShortcut));
}
} else { } else {
LauncherApps.ShortcutQuery query = new LauncherApps.ShortcutQuery(); LauncherApps.ShortcutQuery query = new LauncherApps.ShortcutQuery();
query.setQueryFlags(LauncherApps.ShortcutQuery.FLAG_MATCH_MANIFEST | LauncherApps.ShortcutQuery.FLAG_MATCH_DYNAMIC | LauncherApps.ShortcutQuery.FLAG_MATCH_PINNED); query.setQueryFlags(LauncherApps.ShortcutQuery.FLAG_MATCH_MANIFEST | LauncherApps.ShortcutQuery.FLAG_MATCH_DYNAMIC | LauncherApps.ShortcutQuery.FLAG_MATCH_PINNED);
query.setActivity(activity); query.setActivity(activity);
shortcuts = launcherApps.getShortcuts(query, userHandle); List<ShortcutInfo> appsShortcuts = launcherApps.getShortcuts(query, userHandle);
if (appsShortcuts != null) {
shortcuts = new ArrayList<>(appsShortcuts.size());
for (ShortcutInfo sesameShortcut : appsShortcuts) {
shortcuts.add(new LauncherAppsShortcutDetails(sesameShortcut));
}
}
} }
} }
@ -6558,25 +6423,12 @@ public class Dashboard extends ResourceWrapperActivity implements OnLongClickLis
@Override @Override
public void onItemLayoutAppShortcutDropped(ItemLayout itemLayout, Object shortcutInfoObject, float x, float y) { public void onItemLayoutAppShortcutDropped(ItemLayout itemLayout, Object shortcutInfoObject, float x, float y) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N_MR1 && shortcutInfoObject instanceof ShortcutInfo) { if (shortcutInfoObject instanceof ShortcutDetails) {
ShortcutInfo shortcutInfo = (ShortcutInfo) shortcutInfoObject; ShortcutDetails shortcut = (ShortcutDetails) shortcutInfoObject;
CharSequence label = shortcutInfo.getLongLabel();
if(label == null || label.length() == 0) {
label = shortcutInfo.getShortLabel();
}
LauncherApps launcherApps = (LauncherApps) getSystemService(LAUNCHER_APPS_SERVICE); LauncherApps launcherApps = (LauncherApps) getSystemService(LAUNCHER_APPS_SERVICE);
Drawable drawable = launcherApps.getShortcutIconDrawable(shortcutInfo, Utils.getLauncherIconDensity()); Drawable drawable = shortcut.getIcon(Dashboard.this);
Bitmap icon = Utils.createBitmapFromDrawable(drawable); Bitmap icon = Utils.createBitmapFromDrawable(drawable);
Intent intent = new Intent(Shortcut.INTENT_ACTION_APP_SHORTCUT); Utils.addShortcut(shortcut.getLabel().toString(), icon, shortcut.getIntent(), itemLayout.getPage(), x, y, 1, true);
intent.putExtra(Shortcut.INTENT_EXTRA_APP_SHORTCUT_ID, shortcutInfo.getId());
intent.putExtra(Shortcut.INTENT_EXTRA_APP_SHORTCUT_PKG, shortcutInfo.getPackage());
intent.putExtra(Shortcut.INTENT_EXTRA_APP_SHORTCUT_DISABLED_MSG, shortcutInfo.getDisabledMessage());
Utils.addShortcut(label.toString(), icon, intent, itemLayout.getPage(), x, y, 1, true);
} else if (shortcutInfoObject instanceof SesameShortcut) {
SesameShortcut shortcut = (SesameShortcut) shortcutInfoObject;
Drawable drawable = Icon.createWithContentUri(shortcut.iconUri).loadDrawable(Dashboard.this);
Bitmap icon = Utils.createBitmapFromDrawable(drawable);
Utils.addShortcut(shortcut.htmlLabel, icon, shortcut.actions[0].intent, itemLayout.getPage(), x,y, 1, true);
} }
} }

View file

@ -0,0 +1,64 @@
package net.pierrox.lightning_launcher.appshortcuts;
import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.content.pm.LauncherApps;
import android.content.pm.ShortcutInfo;
import android.graphics.Rect;
import android.graphics.drawable.Drawable;
import android.os.Build;
import android.view.LayoutInflater;
import android.view.View;
import androidx.annotation.RequiresApi;
import net.pierrox.lightning_launcher.activities.Dashboard;
import net.pierrox.lightning_launcher.data.Shortcut;
import net.pierrox.lightning_launcher.data.Utils;
import net.pierrox.lightning_launcher_extreme.R;
@RequiresApi(api = Build.VERSION_CODES.N_MR1)
public class LauncherAppsShortcutDetails implements ShortcutDetails {
private final ShortcutInfo shortcut;
public LauncherAppsShortcutDetails(ShortcutInfo shortcut) {
this.shortcut = shortcut;
}
@Override
public Drawable getIcon(Context context) {
LauncherApps launcherApps = (LauncherApps) context.getSystemService(Context.LAUNCHER_APPS_SERVICE);
return launcherApps.getShortcutIconDrawable(shortcut, Utils.getLauncherIconDensity());
}
@Override
public CharSequence getLabel() {
CharSequence label = shortcut.getLongLabel();
return label != null && label.length() != 0 ? label : shortcut.getShortLabel();
}
@Override
public String getId() {
return shortcut.getId();
}
@Override
public Intent getIntent() {
Intent intent = new Intent(Shortcut.INTENT_ACTION_APP_SHORTCUT);
intent.putExtra(Shortcut.INTENT_EXTRA_APP_SHORTCUT_ID, shortcut.getId());
intent.putExtra(Shortcut.INTENT_EXTRA_APP_SHORTCUT_PKG, shortcut.getPackage());
intent.putExtra(Shortcut.INTENT_EXTRA_APP_SHORTCUT_DISABLED_MSG, shortcut.getDisabledMessage());
return intent;
}
@Override
public void launch(View view) {
LauncherApps launcherApps = (LauncherApps) view.getContext().getSystemService(Context.LAUNCHER_APPS_SERVICE);
if(launcherApps.hasShortcutHostPermission()) {
Rect bounds = new Rect();
view.getHitRect(bounds);
launcherApps.startShortcut(shortcut, bounds, null);
} else {
((Activity) view.getContext()).showDialog(Dashboard.DIALOG_LAUNCHER_APPS_NO_HOST_PERMISSION);
}
}
}

View file

@ -0,0 +1,52 @@
package net.pierrox.lightning_launcher.appshortcuts;
import android.app.ActivityOptions;
import android.content.Intent;
import android.graphics.Rect;
import android.graphics.drawable.Drawable;
import android.graphics.drawable.Icon;
import android.os.Build;
import android.content.Context;
import android.view.View;
import androidx.annotation.RequiresApi;
import ninja.sesame.lib.bridge.v1.SesameShortcut;
@RequiresApi(api = Build.VERSION_CODES.M)
public class SesameShortcutDetails implements ShortcutDetails {
private final SesameShortcut shortcut;
public SesameShortcutDetails(SesameShortcut shortcut) {
this.shortcut = shortcut;
}
@Override
public Drawable getIcon(Context context) {
return Icon.createWithContentUri(shortcut.iconUri).loadDrawable(context);
}
@Override
public CharSequence getLabel() {
return shortcut.plainLabel;
}
@Override
public String getId() {
return shortcut.id;
}
@Override
public Intent getIntent() {
return shortcut.actions[0].intent;
}
@Override
public void launch(View view) {
ActivityOptions options = ActivityOptions.makeBasic();
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
Rect bounds = new Rect();
view.getHitRect(bounds);
options.setLaunchBounds(bounds);
}
view.getContext().startActivity(shortcut.actions[0].intent, options.toBundle());
}
}

View file

@ -0,0 +1,24 @@
package net.pierrox.lightning_launcher.appshortcuts;
import android.content.Context;
import android.content.Intent;
import android.content.pm.ShortcutInfo;
import android.graphics.drawable.Drawable;
import android.view.View;
public interface ShortcutDetails {
Drawable getIcon(Context context);
CharSequence getLabel();
String getId();
Intent getIntent();
/**
* Launch this shortcut
*
* @param view the view this should be launched from
*/
void launch(View view);
}