mirror of
https://codeberg.org/tom79/Fedilab.git
synced 2025-01-07 00:20:08 +02:00
- Open media description when it is missing in the warning dialog
This commit is contained in:
parent
f045f71337
commit
f6af6f9519
4 changed files with 67 additions and 29 deletions
app/src/main
java/app/fedilab/android/mastodon
res/values
src/fdroid/fastlane/metadata/android/en/changelogs
|
@ -858,7 +858,8 @@ public class ComposeActivity extends BaseActivity implements ComposeAdapter.Mana
|
||||||
dialog.dismiss();
|
dialog.dismiss();
|
||||||
|
|
||||||
});
|
});
|
||||||
materialAlertDialogBuilder.setNegativeButton(R.string.cancel, (dialog, id) -> {
|
materialAlertDialogBuilder.setNegativeButton(R.string.add_description, (dialog, id) -> {
|
||||||
|
composeAdapter.openMissingDescription();
|
||||||
dialog.cancel();
|
dialog.cancel();
|
||||||
});
|
});
|
||||||
AlertDialog alert = materialAlertDialogBuilder.create();
|
AlertDialog alert = materialAlertDialogBuilder.create();
|
||||||
|
|
|
@ -169,6 +169,8 @@ public class ComposeAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder
|
||||||
private List<Emoji> emojisList = new ArrayList<>();
|
private List<Emoji> emojisList = new ArrayList<>();
|
||||||
private boolean unlisted_changed = false;
|
private boolean unlisted_changed = false;
|
||||||
|
|
||||||
|
private RecyclerView mRecyclerView;
|
||||||
|
|
||||||
public ComposeAdapter(List<Status> statusList, int statusCount, BaseAccount account, Account mentionedAccount, String visibility, String editMessageId) {
|
public ComposeAdapter(List<Status> statusList, int statusCount, BaseAccount account, Account mentionedAccount, String visibility, String editMessageId) {
|
||||||
this.statusList = statusList;
|
this.statusList = statusList;
|
||||||
this.statusCount = statusCount;
|
this.statusCount = statusCount;
|
||||||
|
@ -1134,34 +1136,7 @@ public class ComposeAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder
|
||||||
intent.putExtras(b);
|
intent.putExtras(b);
|
||||||
context.startActivity(intent);
|
context.startActivity(intent);
|
||||||
});
|
});
|
||||||
composeAttachmentItemBinding.buttonDescription.setOnClickListener(v -> {
|
composeAttachmentItemBinding.buttonDescription.setOnClickListener(v -> openDescription(holder, attachment, position, finalMediaPosition));
|
||||||
AlertDialog.Builder builderInner = new MaterialAlertDialogBuilder(context);
|
|
||||||
// builderInner.setTitle(R.string.upload_form_description);
|
|
||||||
PopupMediaDescriptionBinding popupMediaDescriptionBinding = PopupMediaDescriptionBinding.inflate(LayoutInflater.from(context), null, false);
|
|
||||||
builderInner.setView(popupMediaDescriptionBinding.getRoot());
|
|
||||||
|
|
||||||
popupMediaDescriptionBinding.mediaDescription.setFilters(new InputFilter[]{new InputFilter.LengthFilter(1500)});
|
|
||||||
popupMediaDescriptionBinding.mediaDescription.requestFocus();
|
|
||||||
Glide.with(popupMediaDescriptionBinding.mediaPicture.getContext())
|
|
||||||
.load(attachmentPath)
|
|
||||||
.apply(new RequestOptions().transform(new RoundedCorners(30)))
|
|
||||||
.into(popupMediaDescriptionBinding.mediaPicture);
|
|
||||||
builderInner.setNegativeButton(R.string.cancel, (dialog, which) -> dialog.dismiss());
|
|
||||||
if (attachment.description != null) {
|
|
||||||
popupMediaDescriptionBinding.mediaDescription.setText(attachment.description);
|
|
||||||
popupMediaDescriptionBinding.mediaDescription.setSelection(popupMediaDescriptionBinding.mediaDescription.getText().length());
|
|
||||||
}
|
|
||||||
builderInner.setPositiveButton(R.string.validate, (dialog, which) -> {
|
|
||||||
attachment.description = popupMediaDescriptionBinding.mediaDescription.getText().toString();
|
|
||||||
displayAttachments(holder, position, finalMediaPosition);
|
|
||||||
dialog.dismiss();
|
|
||||||
});
|
|
||||||
AlertDialog alertDialog = builderInner.create();
|
|
||||||
Objects.requireNonNull(alertDialog.getWindow()).setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE);
|
|
||||||
alertDialog.show();
|
|
||||||
popupMediaDescriptionBinding.mediaDescription.requestFocus();
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
composeAttachmentItemBinding.buttonOrderUp.setOnClickListener(v -> {
|
composeAttachmentItemBinding.buttonOrderUp.setOnClickListener(v -> {
|
||||||
if (finalMediaPosition > 0 && attachmentList.size() > 1) {
|
if (finalMediaPosition > 0 && attachmentList.size() > 1) {
|
||||||
|
@ -1231,6 +1206,66 @@ public class ComposeAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder
|
||||||
buttonState(holder);
|
buttonState(holder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onAttachedToRecyclerView(RecyclerView recyclerView) {
|
||||||
|
super.onAttachedToRecyclerView(recyclerView);
|
||||||
|
mRecyclerView = recyclerView;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void openMissingDescription() {
|
||||||
|
int position = 0;
|
||||||
|
if (mRecyclerView == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (Status status : statusList) {
|
||||||
|
if (getItemViewType(position) == TYPE_COMPOSE) {
|
||||||
|
if (status != null && status.media_attachments != null && status.media_attachments.size() > 0) {
|
||||||
|
int mediaPosition = 0;
|
||||||
|
for (Attachment attachment : status.media_attachments) {
|
||||||
|
if (attachment.description == null || attachment.description.trim().isEmpty()) {
|
||||||
|
ComposeViewHolder composeViewHolder = (ComposeViewHolder) mRecyclerView.findViewHolderForAdapterPosition(position);
|
||||||
|
openDescription(composeViewHolder, attachment, position, mediaPosition);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
mediaPosition++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
position++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private void openDescription(ComposeViewHolder holder, Attachment attachment, int messagePosition, int mediaPosition) {
|
||||||
|
String attachmentPath = attachment.local_path != null && !attachment.local_path.trim().isEmpty() ? attachment.local_path : attachment.preview_url;
|
||||||
|
AlertDialog.Builder builderInner = new MaterialAlertDialogBuilder(context);
|
||||||
|
// builderInner.setTitle(R.string.upload_form_description);
|
||||||
|
PopupMediaDescriptionBinding popupMediaDescriptionBinding = PopupMediaDescriptionBinding.inflate(LayoutInflater.from(context), null, false);
|
||||||
|
builderInner.setView(popupMediaDescriptionBinding.getRoot());
|
||||||
|
|
||||||
|
popupMediaDescriptionBinding.mediaDescription.setFilters(new InputFilter[]{new InputFilter.LengthFilter(1500)});
|
||||||
|
popupMediaDescriptionBinding.mediaDescription.requestFocus();
|
||||||
|
Glide.with(popupMediaDescriptionBinding.mediaPicture.getContext())
|
||||||
|
.load(attachmentPath)
|
||||||
|
.apply(new RequestOptions().transform(new RoundedCorners(30)))
|
||||||
|
.into(popupMediaDescriptionBinding.mediaPicture);
|
||||||
|
builderInner.setNegativeButton(R.string.cancel, (dialog, which) -> dialog.dismiss());
|
||||||
|
if (attachment.description != null) {
|
||||||
|
popupMediaDescriptionBinding.mediaDescription.setText(attachment.description);
|
||||||
|
popupMediaDescriptionBinding.mediaDescription.setSelection(popupMediaDescriptionBinding.mediaDescription.getText().length());
|
||||||
|
}
|
||||||
|
builderInner.setPositiveButton(R.string.validate, (dialog, which) -> {
|
||||||
|
attachment.description = popupMediaDescriptionBinding.mediaDescription.getText().toString();
|
||||||
|
displayAttachments(holder, messagePosition, mediaPosition);
|
||||||
|
dialog.dismiss();
|
||||||
|
});
|
||||||
|
AlertDialog alertDialog = builderInner.create();
|
||||||
|
Objects.requireNonNull(alertDialog.getWindow()).setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE);
|
||||||
|
alertDialog.show();
|
||||||
|
popupMediaDescriptionBinding.mediaDescription.requestFocus();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Manage state of media and poll button
|
* Manage state of media and poll button
|
||||||
*
|
*
|
||||||
|
|
|
@ -1959,4 +1959,5 @@
|
||||||
<string name="toast_error_media">Media cannot be loaded!</string>
|
<string name="toast_error_media">Media cannot be loaded!</string>
|
||||||
<string name="fetch_remote_media">Automatically fetch remote media when they are not available</string>
|
<string name="fetch_remote_media">Automatically fetch remote media when they are not available</string>
|
||||||
<string name="fetching_messages">Fetching messages</string>
|
<string name="fetching_messages">Fetching messages</string>
|
||||||
|
<string name="add_description">Add a description</string>
|
||||||
</resources>
|
</resources>
|
|
@ -1,5 +1,6 @@
|
||||||
Added:
|
Added:
|
||||||
- Visual indicator when fetching missing messages
|
- Visual indicator when fetching missing messages
|
||||||
|
- Open media description when it is missing in the warning dialog
|
||||||
|
|
||||||
Changed:
|
Changed:
|
||||||
- Maths formula aligned to the left
|
- Maths formula aligned to the left
|
||||||
|
|
Loading…
Reference in a new issue