some fixes

This commit is contained in:
Thomas 2022-10-06 17:01:24 +02:00
parent b3ed8661c4
commit d27faa3113
5 changed files with 40 additions and 3 deletions

View file

@ -182,6 +182,7 @@ public abstract class BaseMainActivity extends BaseActivity implements NetworkSt
.setAction(getString(R.string.open_draft), view -> { .setAction(getString(R.string.open_draft), view -> {
Intent intentCompose = new Intent(context, ComposeActivity.class); Intent intentCompose = new Intent(context, ComposeActivity.class);
intentCompose.putExtra(Helper.ARG_STATUS_DRAFT, statusDraft); intentCompose.putExtra(Helper.ARG_STATUS_DRAFT, statusDraft);
intentCompose.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(intentCompose); context.startActivity(intentCompose);
}) })
.setTextColor(ThemeHelper.getAttColor(BaseMainActivity.this, R.attr.mTextColor)) .setTextColor(ThemeHelper.getAttColor(BaseMainActivity.this, R.attr.mTextColor))

View file

@ -110,6 +110,7 @@ public class ComposeActivity extends BaseActivity implements ComposeAdapter.Mana
private StatusDraft statusDraft; private StatusDraft statusDraft;
private ComposeAdapter composeAdapter; private ComposeAdapter composeAdapter;
private final BroadcastReceiver imageReceiver = new BroadcastReceiver() { private final BroadcastReceiver imageReceiver = new BroadcastReceiver() {
@Override @Override
public void onReceive(android.content.Context context, Intent intent) { public void onReceive(android.content.Context context, Intent intent) {
@ -513,6 +514,7 @@ public class ComposeActivity extends BaseActivity implements ComposeAdapter.Mana
statusDraft = new StatusDraft(); statusDraft = new StatusDraft();
List<Status> statuses = new ArrayList<>(); List<Status> statuses = new ArrayList<>();
Status status = new Status(); Status status = new Status();
status.id = Helper.generateIdString();
status.text = scheduledStatus.params.text; status.text = scheduledStatus.params.text;
status.in_reply_to_id = scheduledStatus.params.in_reply_to_id; status.in_reply_to_id = scheduledStatus.params.in_reply_to_id;
status.poll = scheduledStatus.params.poll; status.poll = scheduledStatus.params.poll;
@ -567,6 +569,7 @@ public class ComposeActivity extends BaseActivity implements ComposeAdapter.Mana
//Empty compose //Empty compose
List<Status> statusDraftList = new ArrayList<>(); List<Status> statusDraftList = new ArrayList<>();
Status status = new Status(); Status status = new Status();
status.id = Helper.generateIdString();
statusDraftList.add(status); statusDraftList.add(status);
if (statusReplyId != null && statusDraft != null) {//Delete and redraft if (statusReplyId != null && statusDraft != null) {//Delete and redraft
@ -713,6 +716,8 @@ public class ComposeActivity extends BaseActivity implements ComposeAdapter.Mana
@Override @Override
public void onItemDraftAdded(int position) { public void onItemDraftAdded(int position) {
Status status = new Status(); Status status = new Status();
status.id = Helper.generateIdString();
status.mentions = statusList.get(position).mentions; status.mentions = statusList.get(position).mentions;
status.visibility = statusList.get(position).visibility; status.visibility = statusList.get(position).visibility;
status.spoiler_text = statusList.get(position).spoiler_text; status.spoiler_text = statusList.get(position).spoiler_text;
@ -750,7 +755,7 @@ public class ComposeActivity extends BaseActivity implements ComposeAdapter.Mana
List<Status> statusDrafts = new ArrayList<>(); List<Status> statusDrafts = new ArrayList<>();
List<Status> statusReplies = new ArrayList<>(); List<Status> statusReplies = new ArrayList<>();
for (Status status : statusList) { for (Status status : statusList) {
if (status.id == null) { if (status.id == null || status.id.startsWith("@fedilab_compose_")) {
statusDrafts.add(status); statusDrafts.add(status);
} else { } else {
statusReplies.add(status); statusReplies.add(status);

View file

@ -1628,6 +1628,11 @@ public class Helper {
return "@fedilab_fetch_more_" + uuid; return "@fedilab_fetch_more_" + uuid;
} }
public static String generateIdString() {
String uuid = UUID.randomUUID().toString();
return "@fedilab_compose_" + uuid;
}
public static Gson getDateBuilder() { public static Gson getDateBuilder() {
SimpleDateFormat[] formats = new SimpleDateFormat[]{ SimpleDateFormat[] formats = new SimpleDateFormat[]{
new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSZ", Locale.getDefault()), new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSZ", Locale.getDefault()),

View file

@ -124,7 +124,7 @@ public class ComposeWorker extends Worker {
//Check if previous messages in thread have already been published (ie: when resending after a fail) //Check if previous messages in thread have already been published (ie: when resending after a fail)
int startingPosition = 0; int startingPosition = 0;
for (PostState.Post post : dataPost.statusDraft.state.posts) { for (PostState.Post post : dataPost.statusDraft.state.posts) {
if (post.id == null) { if (post.id == null || post.id.startsWith("@fedilab_compose_")) {
break; break;
} }
startingPosition++; startingPosition++;

View file

@ -278,6 +278,12 @@ public class ComposeAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder
} }
} }
/**
* Manage the actions when picking up a media
*
* @param type - type of media in the list of {@link ComposeActivity.mediaType}
* @param position - int position of the media in the message
*/
private void pickupMedia(ComposeActivity.mediaType type, int position) { private void pickupMedia(ComposeActivity.mediaType type, int position) {
if (ContextCompat.checkSelfPermission(context, Manifest.permission.READ_EXTERNAL_STORAGE) != if (ContextCompat.checkSelfPermission(context, Manifest.permission.READ_EXTERNAL_STORAGE) !=
PackageManager.PERMISSION_GRANTED) { PackageManager.PERMISSION_GRANTED) {
@ -475,6 +481,13 @@ public class ComposeAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder
notifyItemChanged(statusList.size() - 1); notifyItemChanged(statusList.size() - 1);
} }
/**
* Display attachment for a holder
*
* @param holder - view related to a compose element {@link ComposeViewHolder}
* @param position - int position of the message in the thread
* @param scrollToMediaPosition - int the position to scroll to media
*/
private void displayAttachments(ComposeViewHolder holder, int position, int scrollToMediaPosition) { private void displayAttachments(ComposeViewHolder holder, int position, int scrollToMediaPosition) {
if (statusList.size() > position && statusList.get(position).media_attachments != null) { if (statusList.size() > position && statusList.get(position).media_attachments != null) {
holder.binding.attachmentsList.removeAllViews(); holder.binding.attachmentsList.removeAllViews();
@ -1345,6 +1358,12 @@ public class ComposeAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder
} }
/**
* Display the emoji picker in the current message
*
* @param holder - view for the message {@link ComposeViewHolder}
* @throws DBException
*/
private void displayEmojiPicker(ComposeViewHolder holder) throws DBException { private void displayEmojiPicker(ComposeViewHolder holder) throws DBException {
final AlertDialog.Builder builder = new AlertDialog.Builder(context, Helper.dialogStyle()); final AlertDialog.Builder builder = new AlertDialog.Builder(context, Helper.dialogStyle());
@ -1372,7 +1391,14 @@ public class ComposeAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder
alertDialogEmoji = builder.show(); alertDialogEmoji = builder.show();
} }
private void displayPollPopup(ComposeAdapter.ComposeViewHolder holder, Status statusDraft, int position) { /**
* Display the popup to attach a poll to message
*
* @param holder - view for the message {@link ComposeViewHolder}
* @param statusDraft - Status message instance {@link Status} linked to the view
* @param position - int position
*/
private void displayPollPopup(ComposeViewHolder holder, Status statusDraft, int position) {
AlertDialog.Builder alertPoll = new AlertDialog.Builder(context, Helper.dialogStyle()); AlertDialog.Builder alertPoll = new AlertDialog.Builder(context, Helper.dialogStyle());
alertPoll.setTitle(R.string.create_poll); alertPoll.setTitle(R.string.create_poll);
ComposePollBinding composePollBinding = ComposePollBinding.inflate(LayoutInflater.from(context), new LinearLayout(context), false); ComposePollBinding composePollBinding = ComposePollBinding.inflate(LayoutInflater.from(context), new LinearLayout(context), false);