mirror of
https://github.com/nextcloud/talk-android
synced 2025-08-11 14:05:14 +01:00
Implement confirmation dialog for delete in conversations list
Signed-off-by: Mario Danic <mario@lovelyhq.com>
This commit is contained in:
parent
3f58e260c0
commit
8007a95755
@ -30,6 +30,7 @@ import android.os.Bundle;
|
|||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.text.InputType;
|
import android.text.InputType;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
|
import android.util.Log;
|
||||||
import android.view.*;
|
import android.view.*;
|
||||||
import android.view.inputmethod.EditorInfo;
|
import android.view.inputmethod.EditorInfo;
|
||||||
import android.widget.ProgressBar;
|
import android.widget.ProgressBar;
|
||||||
@ -41,6 +42,9 @@ import androidx.core.view.MenuItemCompat;
|
|||||||
import androidx.recyclerview.widget.DividerItemDecoration;
|
import androidx.recyclerview.widget.DividerItemDecoration;
|
||||||
import androidx.recyclerview.widget.RecyclerView;
|
import androidx.recyclerview.widget.RecyclerView;
|
||||||
import androidx.swiperefreshlayout.widget.SwipeRefreshLayout;
|
import androidx.swiperefreshlayout.widget.SwipeRefreshLayout;
|
||||||
|
import androidx.work.Data;
|
||||||
|
import androidx.work.OneTimeWorkRequest;
|
||||||
|
import androidx.work.WorkManager;
|
||||||
import autodagger.AutoInjector;
|
import autodagger.AutoInjector;
|
||||||
import butterknife.BindView;
|
import butterknife.BindView;
|
||||||
import com.bluelinelabs.conductor.RouterTransaction;
|
import com.bluelinelabs.conductor.RouterTransaction;
|
||||||
@ -68,6 +72,8 @@ import com.nextcloud.talk.controllers.bottomsheet.EntryMenuController;
|
|||||||
import com.nextcloud.talk.events.BottomSheetLockEvent;
|
import com.nextcloud.talk.events.BottomSheetLockEvent;
|
||||||
import com.nextcloud.talk.events.EventStatus;
|
import com.nextcloud.talk.events.EventStatus;
|
||||||
import com.nextcloud.talk.events.MoreMenuClickEvent;
|
import com.nextcloud.talk.events.MoreMenuClickEvent;
|
||||||
|
import com.nextcloud.talk.interfaces.ConversationMenuInterface;
|
||||||
|
import com.nextcloud.talk.jobs.DeleteConversationWorker;
|
||||||
import com.nextcloud.talk.models.database.UserEntity;
|
import com.nextcloud.talk.models.database.UserEntity;
|
||||||
import com.nextcloud.talk.models.json.participants.Participant;
|
import com.nextcloud.talk.models.json.participants.Participant;
|
||||||
import com.nextcloud.talk.models.json.rooms.Conversation;
|
import com.nextcloud.talk.models.json.rooms.Conversation;
|
||||||
@ -79,6 +85,8 @@ import com.nextcloud.talk.utils.bundle.BundleKeys;
|
|||||||
import com.nextcloud.talk.utils.database.user.UserUtils;
|
import com.nextcloud.talk.utils.database.user.UserUtils;
|
||||||
import com.nextcloud.talk.utils.glide.GlideApp;
|
import com.nextcloud.talk.utils.glide.GlideApp;
|
||||||
import com.nextcloud.talk.utils.preferences.AppPreferences;
|
import com.nextcloud.talk.utils.preferences.AppPreferences;
|
||||||
|
import com.yarolegovich.lovelydialog.LovelySaveStateHandler;
|
||||||
|
import com.yarolegovich.lovelydialog.LovelyStandardDialog;
|
||||||
import eu.davidea.fastscroller.FastScroller;
|
import eu.davidea.fastscroller.FastScroller;
|
||||||
import eu.davidea.flexibleadapter.FlexibleAdapter;
|
import eu.davidea.flexibleadapter.FlexibleAdapter;
|
||||||
import eu.davidea.flexibleadapter.common.SmoothScrollLinearLayoutManager;
|
import eu.davidea.flexibleadapter.common.SmoothScrollLinearLayoutManager;
|
||||||
@ -101,11 +109,12 @@ import java.util.List;
|
|||||||
@AutoInjector(NextcloudTalkApplication.class)
|
@AutoInjector(NextcloudTalkApplication.class)
|
||||||
public class ConversationsListController extends BaseController implements SearchView.OnQueryTextListener,
|
public class ConversationsListController extends BaseController implements SearchView.OnQueryTextListener,
|
||||||
FlexibleAdapter.OnItemClickListener, FlexibleAdapter.OnItemLongClickListener, FastScroller
|
FlexibleAdapter.OnItemClickListener, FlexibleAdapter.OnItemLongClickListener, FastScroller
|
||||||
.OnScrollStateChangeListener {
|
.OnScrollStateChangeListener, ConversationMenuInterface {
|
||||||
|
|
||||||
public static final String TAG = "ConversationsListController";
|
public static final String TAG = "ConversationsListController";
|
||||||
|
|
||||||
private static final String KEY_SEARCH_QUERY = "ContactsController.searchQuery";
|
private static final String KEY_SEARCH_QUERY = "ContactsController.searchQuery";
|
||||||
|
public static final int ID_DELETE_CONVERSATION_DIALOG = 0;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
UserUtils userUtils;
|
UserUtils userUtils;
|
||||||
@ -116,6 +125,9 @@ public class ConversationsListController extends BaseController implements Searc
|
|||||||
@Inject
|
@Inject
|
||||||
NcApi ncApi;
|
NcApi ncApi;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
Context context;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
AppPreferences appPreferences;
|
AppPreferences appPreferences;
|
||||||
|
|
||||||
@ -159,6 +171,10 @@ public class ConversationsListController extends BaseController implements Searc
|
|||||||
private String lastClickedConversationToken;
|
private String lastClickedConversationToken;
|
||||||
private int scrollTo = 0;
|
private int scrollTo = 0;
|
||||||
|
|
||||||
|
private LovelySaveStateHandler saveStateHandler;
|
||||||
|
|
||||||
|
private Bundle conversationMenuBundle = null;
|
||||||
|
|
||||||
public ConversationsListController() {
|
public ConversationsListController() {
|
||||||
super();
|
super();
|
||||||
setHasOptionsMenu(true);
|
setHasOptionsMenu(true);
|
||||||
@ -178,6 +194,10 @@ public class ConversationsListController extends BaseController implements Searc
|
|||||||
getActionBar().show();
|
getActionBar().show();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (saveStateHandler == null) {
|
||||||
|
saveStateHandler = new LovelySaveStateHandler();
|
||||||
|
}
|
||||||
|
|
||||||
if (adapter == null) {
|
if (adapter == null) {
|
||||||
adapter = new FlexibleAdapter<>(callItems, getActivity(), true);
|
adapter = new FlexibleAdapter<>(callItems, getActivity(), true);
|
||||||
} else {
|
} else {
|
||||||
@ -505,16 +525,24 @@ public class ConversationsListController extends BaseController implements Searc
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSaveViewState(@NonNull View view, @NonNull Bundle outState) {
|
public void onSaveViewState(@NonNull View view, @NonNull Bundle outState) {
|
||||||
super.onSaveViewState(view, outState);
|
saveStateHandler.saveInstanceState(outState);
|
||||||
|
|
||||||
if (searchView != null && !TextUtils.isEmpty(searchView.getQuery())) {
|
if (searchView != null && !TextUtils.isEmpty(searchView.getQuery())) {
|
||||||
outState.putString(KEY_SEARCH_QUERY, searchView.getQuery().toString());
|
outState.putString(KEY_SEARCH_QUERY, searchView.getQuery().toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
super.onSaveViewState(view, outState);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onRestoreViewState(@NonNull View view, @NonNull Bundle savedViewState) {
|
public void onRestoreViewState(@NonNull View view, @NonNull Bundle savedViewState) {
|
||||||
super.onRestoreViewState(view, savedViewState);
|
super.onRestoreViewState(view, savedViewState);
|
||||||
searchQuery = savedViewState.getString(KEY_SEARCH_QUERY, "");
|
searchQuery = savedViewState.getString(KEY_SEARCH_QUERY, "");
|
||||||
|
if (LovelySaveStateHandler.wasDialogOnScreen(savedViewState)) {
|
||||||
|
//Dialog won't be restarted automatically, so we need to call this method.
|
||||||
|
//Each dialog knows how to restore its state
|
||||||
|
showLovelyDialog(LovelySaveStateHandler.getSavedDialogId(savedViewState), savedViewState);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -584,7 +612,7 @@ public class ConversationsListController extends BaseController implements Searc
|
|||||||
|
|
||||||
if (shouldShowCallMenuController) {
|
if (shouldShowCallMenuController) {
|
||||||
getChildRouter((ViewGroup) view).setRoot(
|
getChildRouter((ViewGroup) view).setRoot(
|
||||||
RouterTransaction.with(new CallMenuController(bundle))
|
RouterTransaction.with(new CallMenuController(bundle, this))
|
||||||
.popChangeHandler(new VerticalChangeHandler())
|
.popChangeHandler(new VerticalChangeHandler())
|
||||||
.pushChangeHandler(new VerticalChangeHandler()));
|
.pushChangeHandler(new VerticalChangeHandler()));
|
||||||
} else {
|
} else {
|
||||||
@ -677,7 +705,7 @@ public class ConversationsListController extends BaseController implements Searc
|
|||||||
|
|
||||||
@Subscribe(sticky = true, threadMode = ThreadMode.BACKGROUND)
|
@Subscribe(sticky = true, threadMode = ThreadMode.BACKGROUND)
|
||||||
public void onMessageEvent(EventStatus eventStatus) {
|
public void onMessageEvent(EventStatus eventStatus) {
|
||||||
if (currentUser != null && eventStatus.getUserId() == currentUser.getId()){
|
if (currentUser != null && eventStatus.getUserId() == currentUser.getId()) {
|
||||||
switch (eventStatus.getEventType()) {
|
switch (eventStatus.getEventType()) {
|
||||||
case CONVERSATION_UPDATE:
|
case CONVERSATION_UPDATE:
|
||||||
if (eventStatus.isAllGood() && !isRefreshing) {
|
if (eventStatus.isAllGood() && !isRefreshing) {
|
||||||
@ -689,4 +717,71 @@ public class ConversationsListController extends BaseController implements Searc
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void showDeleteConversationDialog(Bundle savedInstanceState) {
|
||||||
|
if (getActivity() != null && conversationMenuBundle != null && currentUser != null && conversationMenuBundle.getLong(BundleKeys.KEY_INTERNAL_USER_ID) == currentUser.getId()) {
|
||||||
|
|
||||||
|
Conversation conversation =
|
||||||
|
Parcels.unwrap(conversationMenuBundle.getParcelable(BundleKeys.KEY_ROOM));
|
||||||
|
|
||||||
|
if (conversation != null) {
|
||||||
|
new LovelyStandardDialog(getActivity(), LovelyStandardDialog.ButtonLayout.HORIZONTAL)
|
||||||
|
.setTopColorRes(R.color.nc_darkRed)
|
||||||
|
.setIcon(DisplayUtils.getTintedDrawable(context.getResources(),
|
||||||
|
R.drawable.ic_delete_black_24dp, R.color.white))
|
||||||
|
.setPositiveButtonColor(context.getResources().getColor(R.color.nc_darkRed))
|
||||||
|
.setTitle(R.string.nc_delete_call)
|
||||||
|
.setMessage(conversation.getDeleteWarningMessage())
|
||||||
|
.setPositiveButton(R.string.nc_delete, new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
Data.Builder data = new Data.Builder();
|
||||||
|
data.putLong(BundleKeys.KEY_INTERNAL_USER_ID,
|
||||||
|
conversationMenuBundle.getLong(BundleKeys.KEY_INTERNAL_USER_ID));
|
||||||
|
data.putString(BundleKeys.KEY_ROOM_TOKEN, conversation.getToken());
|
||||||
|
conversationMenuBundle = null;
|
||||||
|
deleteConversation(data.build());
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.setNegativeButton(R.string.nc_cancel, new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
conversationMenuBundle = null;
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.setInstanceStateHandler(ID_DELETE_CONVERSATION_DIALOG, saveStateHandler)
|
||||||
|
.setSavedInstanceState(savedInstanceState)
|
||||||
|
.show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void deleteConversation(Data data) {
|
||||||
|
OneTimeWorkRequest deleteConversationWorker =
|
||||||
|
new OneTimeWorkRequest.Builder(DeleteConversationWorker.class).setInputData(data).build();
|
||||||
|
WorkManager.getInstance().enqueue(deleteConversationWorker);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void showLovelyDialog(int dialogId, Bundle savedInstanceState) {
|
||||||
|
switch (dialogId) {
|
||||||
|
case ID_DELETE_CONVERSATION_DIALOG:
|
||||||
|
showDeleteConversationDialog(savedInstanceState);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void openLovelyDialogWithIdAndBundle(int dialogId, Bundle bundle) {
|
||||||
|
conversationMenuBundle = bundle;
|
||||||
|
switch (dialogId) {
|
||||||
|
case ID_DELETE_CONVERSATION_DIALOG:
|
||||||
|
showLovelyDialog(dialogId, null);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
@ -28,6 +28,7 @@ import android.view.LayoutInflater;
|
|||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
import androidx.recyclerview.widget.LinearLayoutManager;
|
import androidx.recyclerview.widget.LinearLayoutManager;
|
||||||
import androidx.recyclerview.widget.RecyclerView;
|
import androidx.recyclerview.widget.RecyclerView;
|
||||||
import androidx.work.Data;
|
import androidx.work.Data;
|
||||||
@ -42,8 +43,10 @@ import com.nextcloud.talk.R;
|
|||||||
import com.nextcloud.talk.adapters.items.AppItem;
|
import com.nextcloud.talk.adapters.items.AppItem;
|
||||||
import com.nextcloud.talk.adapters.items.MenuItem;
|
import com.nextcloud.talk.adapters.items.MenuItem;
|
||||||
import com.nextcloud.talk.application.NextcloudTalkApplication;
|
import com.nextcloud.talk.application.NextcloudTalkApplication;
|
||||||
|
import com.nextcloud.talk.controllers.ConversationsListController;
|
||||||
import com.nextcloud.talk.controllers.base.BaseController;
|
import com.nextcloud.talk.controllers.base.BaseController;
|
||||||
import com.nextcloud.talk.events.BottomSheetLockEvent;
|
import com.nextcloud.talk.events.BottomSheetLockEvent;
|
||||||
|
import com.nextcloud.talk.interfaces.ConversationMenuInterface;
|
||||||
import com.nextcloud.talk.jobs.DeleteConversationWorker;
|
import com.nextcloud.talk.jobs.DeleteConversationWorker;
|
||||||
import com.nextcloud.talk.jobs.LeaveConversationWorker;
|
import com.nextcloud.talk.jobs.LeaveConversationWorker;
|
||||||
import com.nextcloud.talk.models.database.UserEntity;
|
import com.nextcloud.talk.models.database.UserEntity;
|
||||||
@ -81,6 +84,7 @@ public class CallMenuController extends BaseController implements FlexibleAdapte
|
|||||||
private Intent shareIntent;
|
private Intent shareIntent;
|
||||||
|
|
||||||
private UserEntity currentUser;
|
private UserEntity currentUser;
|
||||||
|
private ConversationMenuInterface conversationMenuInterface;
|
||||||
|
|
||||||
public CallMenuController(Bundle args) {
|
public CallMenuController(Bundle args) {
|
||||||
super(args);
|
super(args);
|
||||||
@ -90,6 +94,15 @@ public class CallMenuController extends BaseController implements FlexibleAdapte
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public CallMenuController(Bundle args, @Nullable ConversationMenuInterface conversationMenuInterface) {
|
||||||
|
super(args);
|
||||||
|
this.conversation = Parcels.unwrap(args.getParcelable(BundleKeys.KEY_ROOM));
|
||||||
|
if (args.containsKey(BundleKeys.KEY_MENU_TYPE)) {
|
||||||
|
this.menuType = Parcels.unwrap(args.getParcelable(BundleKeys.KEY_MENU_TYPE));
|
||||||
|
}
|
||||||
|
this.conversationMenuInterface = conversationMenuInterface;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected View inflateView(@NonNull LayoutInflater inflater, @NonNull ViewGroup container) {
|
protected View inflateView(@NonNull LayoutInflater inflater, @NonNull ViewGroup container) {
|
||||||
return inflater.inflate(R.layout.controller_call_menu, container, false);
|
return inflater.inflate(R.layout.controller_call_menu, container, false);
|
||||||
@ -217,19 +230,20 @@ public class CallMenuController extends BaseController implements FlexibleAdapte
|
|||||||
|
|
||||||
if (tag > 0) {
|
if (tag > 0) {
|
||||||
if (tag == 1 || tag == 9) {
|
if (tag == 1 || tag == 9) {
|
||||||
|
if (tag == 1) {
|
||||||
Data data;
|
Data data;
|
||||||
if ((data = getWorkerData()) != null) {
|
if ((data = getWorkerData()) != null) {
|
||||||
if (tag == 1) {
|
|
||||||
OneTimeWorkRequest leaveConversationWorker =
|
OneTimeWorkRequest leaveConversationWorker =
|
||||||
new OneTimeWorkRequest.Builder(LeaveConversationWorker.class).setInputData(data).build();
|
new OneTimeWorkRequest.Builder(LeaveConversationWorker.class).setInputData(data).build();
|
||||||
WorkManager.getInstance().enqueue(leaveConversationWorker);
|
WorkManager.getInstance().enqueue(leaveConversationWorker);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
OneTimeWorkRequest deleteConversationWorker =
|
Bundle deleteConversationBundle;
|
||||||
new OneTimeWorkRequest.Builder(DeleteConversationWorker.class).setInputData(data).build();
|
if ((deleteConversationBundle = getDeleteConversationBundle()) != null) {
|
||||||
WorkManager.getInstance().enqueue(deleteConversationWorker);
|
conversationMenuInterface.openLovelyDialogWithIdAndBundle(ConversationsListController.ID_DELETE_CONVERSATION_DIALOG, deleteConversationBundle);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
eventBus.post(new BottomSheetLockEvent(true, 0, false, true));
|
eventBus.post(new BottomSheetLockEvent(true, 0, false, true));
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
bundle.putInt(BundleKeys.KEY_OPERATION_CODE, tag);
|
bundle.putInt(BundleKeys.KEY_OPERATION_CODE, tag);
|
||||||
if (tag != 2 && tag != 4 && tag != 6 && tag != 7) {
|
if (tag != 2 && tag != 4 && tag != 6 && tag != 7) {
|
||||||
@ -243,7 +257,7 @@ public class CallMenuController extends BaseController implements FlexibleAdapte
|
|||||||
.popChangeHandler(new HorizontalChangeHandler()));
|
.popChangeHandler(new HorizontalChangeHandler()));
|
||||||
} else {
|
} else {
|
||||||
bundle.putParcelable(BundleKeys.KEY_MENU_TYPE, Parcels.wrap(MenuType.SHARE));
|
bundle.putParcelable(BundleKeys.KEY_MENU_TYPE, Parcels.wrap(MenuType.SHARE));
|
||||||
getRouter().pushController(RouterTransaction.with(new CallMenuController(bundle))
|
getRouter().pushController(RouterTransaction.with(new CallMenuController(bundle, null))
|
||||||
.pushChangeHandler(new HorizontalChangeHandler())
|
.pushChangeHandler(new HorizontalChangeHandler())
|
||||||
.popChangeHandler(new HorizontalChangeHandler()));
|
.popChangeHandler(new HorizontalChangeHandler()));
|
||||||
}
|
}
|
||||||
@ -292,4 +306,15 @@ public class CallMenuController extends BaseController implements FlexibleAdapte
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Bundle getDeleteConversationBundle() {
|
||||||
|
if (!TextUtils.isEmpty(conversation.getToken())) {
|
||||||
|
Bundle bundle = new Bundle();
|
||||||
|
bundle.putLong(BundleKeys.KEY_INTERNAL_USER_ID, currentUser.getId());
|
||||||
|
bundle.putParcelable(BundleKeys.KEY_ROOM, Parcels.wrap(conversation));
|
||||||
|
return bundle;
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,27 @@
|
|||||||
|
/*
|
||||||
|
* Nextcloud Talk application
|
||||||
|
*
|
||||||
|
* @author Mario Danic
|
||||||
|
* Copyright (C) 2017-2018 Mario Danic <mario@lovelyhq.com>
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.nextcloud.talk.interfaces;
|
||||||
|
|
||||||
|
import android.os.Bundle;
|
||||||
|
|
||||||
|
public interface ConversationMenuInterface {
|
||||||
|
void openLovelyDialogWithIdAndBundle(int dialogId, Bundle bundle);
|
||||||
|
}
|
@ -160,6 +160,7 @@ public class PowerManagerUtils {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fullLock.release();
|
fullLock.release();
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
|
||||||
proximityLock.release();
|
proximityLock.release();
|
||||||
}
|
}
|
||||||
@ -180,6 +181,7 @@ public class PowerManagerUtils {
|
|||||||
if (!wifiLock.isHeld()) {
|
if (!wifiLock.isHeld()) {
|
||||||
wifiLock.acquire();
|
wifiLock.acquire();
|
||||||
}
|
}
|
||||||
|
|
||||||
fullLock.release(
|
fullLock.release(
|
||||||
|
|
||||||
);
|
);
|
||||||
|
Loading…
Reference in New Issue
Block a user