|
@ -58,6 +58,7 @@ import java.io.File; |
|
|
import java.util.ArrayList; |
|
|
import java.util.ArrayList; |
|
|
import java.util.List; |
|
|
import java.util.List; |
|
|
import java.util.Set; |
|
|
import java.util.Set; |
|
|
|
|
|
import java.util.function.Function; |
|
|
|
|
|
|
|
|
import awais.instagrabber.ProfileNavGraphDirections; |
|
|
import awais.instagrabber.ProfileNavGraphDirections; |
|
|
import awais.instagrabber.R; |
|
|
import awais.instagrabber.R; |
|
@ -258,7 +259,7 @@ public class DirectMessageThreadFragment extends Fragment implements DirectReact |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Override |
|
|
@Override |
|
|
public void onOptionSelect(final DirectItem item, final int itemId) { |
|
|
|
|
|
|
|
|
public void onOptionSelect(final DirectItem item, final int itemId, final Function<DirectItem, Void> cb) { |
|
|
if (itemId == R.id.unsend) { |
|
|
if (itemId == R.id.unsend) { |
|
|
handleSentMessage(viewModel.unsend(item)); |
|
|
handleSentMessage(viewModel.unsend(item)); |
|
|
return; |
|
|
return; |
|
@ -275,21 +276,17 @@ public class DirectMessageThreadFragment extends Fragment implements DirectReact |
|
|
final NavController navController = NavHostFragment.findNavController(DirectMessageThreadFragment.this); |
|
|
final NavController navController = NavHostFragment.findNavController(DirectMessageThreadFragment.this); |
|
|
navController.navigate(actionGlobalUserSearch); |
|
|
navController.navigate(actionGlobalUserSearch); |
|
|
} |
|
|
} |
|
|
if (itemId == R.id.detail) { |
|
|
|
|
|
final Context context = getContext(); |
|
|
|
|
|
if (context == null) return; |
|
|
|
|
|
final DirectItemType itemType = item.getItemType(); |
|
|
|
|
|
switch (itemType) { |
|
|
|
|
|
case ANIMATED_MEDIA: |
|
|
|
|
|
Utils.openURL(context, "https://giphy.com/gifs/" + item.getAnimatedMedia().getId()); |
|
|
|
|
|
break; |
|
|
|
|
|
case VOICE_MEDIA: |
|
|
|
|
|
downloadItem(item.getVoiceMedia() == null ? null : item.getVoiceMedia().getMedia(), context); |
|
|
|
|
|
break; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
if (itemId == R.id.download) { |
|
|
|
|
|
downloadItem(item); |
|
|
|
|
|
return; |
|
|
|
|
|
} |
|
|
|
|
|
// otherwise call callback if present |
|
|
|
|
|
if (cb != null) { |
|
|
|
|
|
cb.apply(item); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
private final DirectItemLongClickListener directItemLongClickListener = position -> { |
|
|
private final DirectItemLongClickListener directItemLongClickListener = position -> { |
|
|
// viewModel.setSelectedPosition(position); |
|
|
// viewModel.setSelectedPosition(position); |
|
|
}; |
|
|
}; |
|
@ -319,6 +316,7 @@ public class DirectMessageThreadFragment extends Fragment implements DirectReact |
|
|
}; |
|
|
}; |
|
|
private final MutableLiveData<Integer> inputLength = new MutableLiveData<>(0); |
|
|
private final MutableLiveData<Integer> inputLength = new MutableLiveData<>(0); |
|
|
private MenuItem markAsSeenMenuItem; |
|
|
private MenuItem markAsSeenMenuItem; |
|
|
|
|
|
private Media tempMedia; |
|
|
|
|
|
|
|
|
@Override |
|
|
@Override |
|
|
public void onCreate(@Nullable final Bundle savedInstanceState) { |
|
|
public void onCreate(@Nullable final Bundle savedInstanceState) { |
|
@ -329,11 +327,13 @@ public class DirectMessageThreadFragment extends Fragment implements DirectReact |
|
|
final Bundle arguments = getArguments(); |
|
|
final Bundle arguments = getArguments(); |
|
|
if (arguments == null) return; |
|
|
if (arguments == null) return; |
|
|
final DirectMessageThreadFragmentArgs fragmentArgs = DirectMessageThreadFragmentArgs.fromBundle(arguments); |
|
|
final DirectMessageThreadFragmentArgs fragmentArgs = DirectMessageThreadFragmentArgs.fromBundle(arguments); |
|
|
viewModel = new ViewModelProvider(this, new DirectThreadViewModelFactory(fragmentActivity.getApplication(), |
|
|
|
|
|
fragmentArgs.getThreadId(), |
|
|
|
|
|
fragmentArgs.getPending(), |
|
|
|
|
|
appStateViewModel.getCurrentUser())) |
|
|
|
|
|
.get(DirectThreadViewModel.class); |
|
|
|
|
|
|
|
|
final DirectThreadViewModelFactory viewModelFactory = new DirectThreadViewModelFactory( |
|
|
|
|
|
fragmentActivity.getApplication(), |
|
|
|
|
|
fragmentArgs.getThreadId(), |
|
|
|
|
|
fragmentArgs.getPending(), |
|
|
|
|
|
appStateViewModel.getCurrentUser() |
|
|
|
|
|
); |
|
|
|
|
|
viewModel = new ViewModelProvider(this, viewModelFactory).get(DirectThreadViewModel.class); |
|
|
setHasOptionsMenu(true); |
|
|
setHasOptionsMenu(true); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -454,7 +454,9 @@ public class DirectMessageThreadFragment extends Fragment implements DirectReact |
|
|
final Context context = getContext(); |
|
|
final Context context = getContext(); |
|
|
if (context == null) return; |
|
|
if (context == null) return; |
|
|
if (requestCode == STORAGE_PERM_REQUEST_CODE && grantResults[0] == PackageManager.PERMISSION_GRANTED) { |
|
|
if (requestCode == STORAGE_PERM_REQUEST_CODE && grantResults[0] == PackageManager.PERMISSION_GRANTED) { |
|
|
// downloadItem(context); |
|
|
|
|
|
|
|
|
if (tempMedia == null) return; |
|
|
|
|
|
downloadItem(context, tempMedia); |
|
|
|
|
|
return; |
|
|
} |
|
|
} |
|
|
if (requestCode == AUDIO_RECORD_PERM_REQUEST_CODE) { |
|
|
if (requestCode == AUDIO_RECORD_PERM_REQUEST_CODE) { |
|
|
if (PermissionUtils.hasAudioRecordPerms(context)) { |
|
|
if (PermissionUtils.hasAudioRecordPerms(context)) { |
|
@ -1317,18 +1319,31 @@ public class DirectMessageThreadFragment extends Fragment implements DirectReact |
|
|
appExecutors.mainThread().execute(prevTitleRunnable, 1000); |
|
|
appExecutors.mainThread().execute(prevTitleRunnable, 1000); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private void downloadItem(final DirectItem item) { |
|
|
|
|
|
final Context context = getContext(); |
|
|
|
|
|
if (context == null) return; |
|
|
|
|
|
final DirectItemType itemType = item.getItemType(); |
|
|
|
|
|
//noinspection SwitchStatementWithTooFewBranches |
|
|
|
|
|
switch (itemType) { |
|
|
|
|
|
case VOICE_MEDIA: |
|
|
|
|
|
downloadItem(context, item.getVoiceMedia() == null ? null : item.getVoiceMedia().getMedia()); |
|
|
|
|
|
break; |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
// currently ONLY for voice |
|
|
// currently ONLY for voice |
|
|
private void downloadItem(final Media media, final Context context) { |
|
|
|
|
|
|
|
|
private void downloadItem(@NonNull final Context context, final Media media) { |
|
|
if (media == null) { |
|
|
if (media == null) { |
|
|
Toast.makeText(context, R.string.downloader_unknown_error, Toast.LENGTH_SHORT).show(); |
|
|
Toast.makeText(context, R.string.downloader_unknown_error, Toast.LENGTH_SHORT).show(); |
|
|
} else { |
|
|
|
|
|
if (ContextCompat.checkSelfPermission(context, DownloadUtils.PERMS[0]) == PackageManager.PERMISSION_GRANTED) { |
|
|
|
|
|
DownloadUtils.download(context, media); |
|
|
|
|
|
} else { |
|
|
|
|
|
requestPermissions(DownloadUtils.PERMS, STORAGE_PERM_REQUEST_CODE); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
return; |
|
|
|
|
|
} |
|
|
|
|
|
if (ContextCompat.checkSelfPermission(context, DownloadUtils.PERMS[0]) == PackageManager.PERMISSION_GRANTED) { |
|
|
|
|
|
DownloadUtils.download(context, media); |
|
|
Toast.makeText(context, R.string.downloader_downloading_media, Toast.LENGTH_SHORT).show(); |
|
|
Toast.makeText(context, R.string.downloader_downloading_media, Toast.LENGTH_SHORT).show(); |
|
|
|
|
|
return; |
|
|
} |
|
|
} |
|
|
|
|
|
tempMedia = media; |
|
|
|
|
|
requestPermissions(DownloadUtils.PERMS, STORAGE_PERM_REQUEST_CODE); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@NonNull |
|
|
@NonNull |
|
|