mirror of
https://codeberg.org/Bazsalanszky/Infinity-For-Lemmy.git
synced 2025-01-02 14:27:10 +01:00
Directly send comment in FullMarkdownActivity for CommentActivity.
This commit is contained in:
parent
8b0aed58b2
commit
d2900b66c4
@ -91,6 +91,7 @@ public class CommentActivity extends BaseActivity implements UploadImageEnabledA
|
|||||||
public static final int WRITE_COMMENT_REQUEST_CODE = 1;
|
public static final int WRITE_COMMENT_REQUEST_CODE = 1;
|
||||||
private static final int PICK_IMAGE_REQUEST_CODE = 100;
|
private static final int PICK_IMAGE_REQUEST_CODE = 100;
|
||||||
private static final int CAPTURE_IMAGE_REQUEST_CODE = 200;
|
private static final int CAPTURE_IMAGE_REQUEST_CODE = 200;
|
||||||
|
private static final int MARKDOWN_PREVIEW_REQUEST_CODE = 300;
|
||||||
private static final String UPLOADED_IMAGES_STATE = "UIS";
|
private static final String UPLOADED_IMAGES_STATE = "UIS";
|
||||||
|
|
||||||
@BindView(R.id.coordinator_layout_comment_activity)
|
@BindView(R.id.coordinator_layout_comment_activity)
|
||||||
@ -134,6 +135,7 @@ public class CommentActivity extends BaseActivity implements UploadImageEnabledA
|
|||||||
private int markdownColor;
|
private int markdownColor;
|
||||||
private Uri capturedImageUri;
|
private Uri capturedImageUri;
|
||||||
private ArrayList<UploadedImage> uploadedImages = new ArrayList<>();
|
private ArrayList<UploadedImage> uploadedImages = new ArrayList<>();
|
||||||
|
private Menu mMenu;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
@ -335,6 +337,7 @@ public class CommentActivity extends BaseActivity implements UploadImageEnabledA
|
|||||||
@Override
|
@Override
|
||||||
public boolean onCreateOptionsMenu(Menu menu) {
|
public boolean onCreateOptionsMenu(Menu menu) {
|
||||||
getMenuInflater().inflate(R.menu.comment_activity, menu);
|
getMenuInflater().inflate(R.menu.comment_activity, menu);
|
||||||
|
mMenu = menu;
|
||||||
applyMenuItemTheme(menu);
|
applyMenuItemTheme(menu);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -349,61 +352,71 @@ public class CommentActivity extends BaseActivity implements UploadImageEnabledA
|
|||||||
Intent intent = new Intent(this, FullMarkdownActivity.class);
|
Intent intent = new Intent(this, FullMarkdownActivity.class);
|
||||||
intent.putExtra(FullMarkdownActivity.EXTRA_COMMENT_MARKDOWN, commentEditText.getText().toString());
|
intent.putExtra(FullMarkdownActivity.EXTRA_COMMENT_MARKDOWN, commentEditText.getText().toString());
|
||||||
intent.putExtra(FullMarkdownActivity.EXTRA_SUBMIT_POST, true);
|
intent.putExtra(FullMarkdownActivity.EXTRA_SUBMIT_POST, true);
|
||||||
startActivity(intent);
|
startActivityForResult(intent, MARKDOWN_PREVIEW_REQUEST_CODE);
|
||||||
} else if (itemId == R.id.action_send_comment_activity) {
|
} else if (itemId == R.id.action_send_comment_activity) {
|
||||||
if (!isSubmitting) {
|
sendComment(item);
|
||||||
isSubmitting = true;
|
|
||||||
if (commentEditText.getText() == null || commentEditText.getText().toString().equals("")) {
|
|
||||||
isSubmitting = false;
|
|
||||||
Snackbar.make(coordinatorLayout, R.string.comment_content_required, Snackbar.LENGTH_SHORT).show();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
item.setEnabled(false);
|
|
||||||
item.getIcon().setAlpha(130);
|
|
||||||
Snackbar sendingSnackbar = Snackbar.make(coordinatorLayout, R.string.sending_comment, Snackbar.LENGTH_INDEFINITE);
|
|
||||||
sendingSnackbar.show();
|
|
||||||
|
|
||||||
SendComment.sendComment(mExecutor, new Handler(), commentEditText.getText().toString(),
|
|
||||||
parentFullname, parentDepth, mOauthRetrofit, mAccessToken,
|
|
||||||
new SendComment.SendCommentListener() {
|
|
||||||
@Override
|
|
||||||
public void sendCommentSuccess(Comment comment) {
|
|
||||||
isSubmitting = false;
|
|
||||||
item.setEnabled(true);
|
|
||||||
item.getIcon().setAlpha(255);
|
|
||||||
Toast.makeText(CommentActivity.this, R.string.send_comment_success, Toast.LENGTH_SHORT).show();
|
|
||||||
Intent returnIntent = new Intent();
|
|
||||||
returnIntent.putExtra(RETURN_EXTRA_COMMENT_DATA_KEY, comment);
|
|
||||||
returnIntent.putExtra(EXTRA_PARENT_FULLNAME_KEY, parentFullname);
|
|
||||||
if (isReplying) {
|
|
||||||
returnIntent.putExtra(EXTRA_PARENT_POSITION_KEY, parentPosition);
|
|
||||||
}
|
|
||||||
setResult(RESULT_OK, returnIntent);
|
|
||||||
finish();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void sendCommentFailed(@Nullable String errorMessage) {
|
|
||||||
isSubmitting = false;
|
|
||||||
sendingSnackbar.dismiss();
|
|
||||||
item.setEnabled(true);
|
|
||||||
item.getIcon().setAlpha(255);
|
|
||||||
|
|
||||||
if (errorMessage == null || !errorMessage.equals("")) {
|
|
||||||
Snackbar.make(coordinatorLayout, R.string.send_comment_failed, Snackbar.LENGTH_SHORT).show();
|
|
||||||
} else {
|
|
||||||
Snackbar.make(coordinatorLayout, errorMessage, Snackbar.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void sendComment(@Nullable MenuItem item) {
|
||||||
|
if (!isSubmitting) {
|
||||||
|
isSubmitting = true;
|
||||||
|
if (commentEditText.getText() == null || commentEditText.getText().toString().equals("")) {
|
||||||
|
isSubmitting = false;
|
||||||
|
Snackbar.make(coordinatorLayout, R.string.comment_content_required, Snackbar.LENGTH_SHORT).show();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (item != null) {
|
||||||
|
item.setEnabled(false);
|
||||||
|
item.getIcon().setAlpha(130);
|
||||||
|
}
|
||||||
|
Snackbar sendingSnackbar = Snackbar.make(coordinatorLayout, R.string.sending_comment, Snackbar.LENGTH_INDEFINITE);
|
||||||
|
sendingSnackbar.show();
|
||||||
|
|
||||||
|
SendComment.sendComment(mExecutor, new Handler(), commentEditText.getText().toString(),
|
||||||
|
parentFullname, parentDepth, mOauthRetrofit, mAccessToken,
|
||||||
|
new SendComment.SendCommentListener() {
|
||||||
|
@Override
|
||||||
|
public void sendCommentSuccess(Comment comment) {
|
||||||
|
isSubmitting = false;
|
||||||
|
if (item != null) {
|
||||||
|
item.setEnabled(true);
|
||||||
|
item.getIcon().setAlpha(255);
|
||||||
|
}
|
||||||
|
Toast.makeText(CommentActivity.this, R.string.send_comment_success, Toast.LENGTH_SHORT).show();
|
||||||
|
Intent returnIntent = new Intent();
|
||||||
|
returnIntent.putExtra(RETURN_EXTRA_COMMENT_DATA_KEY, comment);
|
||||||
|
returnIntent.putExtra(EXTRA_PARENT_FULLNAME_KEY, parentFullname);
|
||||||
|
if (isReplying) {
|
||||||
|
returnIntent.putExtra(EXTRA_PARENT_POSITION_KEY, parentPosition);
|
||||||
|
}
|
||||||
|
setResult(RESULT_OK, returnIntent);
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void sendCommentFailed(@Nullable String errorMessage) {
|
||||||
|
isSubmitting = false;
|
||||||
|
sendingSnackbar.dismiss();
|
||||||
|
if (item != null) {
|
||||||
|
item.setEnabled(true);
|
||||||
|
item.getIcon().setAlpha(255);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (errorMessage == null || !errorMessage.equals("")) {
|
||||||
|
Snackbar.make(coordinatorLayout, R.string.send_comment_failed, Snackbar.LENGTH_SHORT).show();
|
||||||
|
} else {
|
||||||
|
Snackbar.make(coordinatorLayout, errorMessage, Snackbar.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void promptAlertDialog(int titleResId, int messageResId) {
|
private void promptAlertDialog(int titleResId, int messageResId) {
|
||||||
new MaterialAlertDialogBuilder(this, R.style.MaterialAlertDialogTheme)
|
new MaterialAlertDialogBuilder(this, R.style.MaterialAlertDialogTheme)
|
||||||
.setTitle(titleResId)
|
.setTitle(titleResId)
|
||||||
@ -428,6 +441,8 @@ public class CommentActivity extends BaseActivity implements UploadImageEnabledA
|
|||||||
} else if (requestCode == CAPTURE_IMAGE_REQUEST_CODE) {
|
} else if (requestCode == CAPTURE_IMAGE_REQUEST_CODE) {
|
||||||
Utils.uploadImageToReddit(this, mExecutor, mOauthRetrofit, mUploadMediaRetrofit,
|
Utils.uploadImageToReddit(this, mExecutor, mOauthRetrofit, mUploadMediaRetrofit,
|
||||||
mAccessToken, commentEditText, coordinatorLayout, capturedImageUri, uploadedImages);
|
mAccessToken, commentEditText, coordinatorLayout, capturedImageUri, uploadedImages);
|
||||||
|
} else if (requestCode == MARKDOWN_PREVIEW_REQUEST_CODE) {
|
||||||
|
sendComment(mMenu == null ? null : mMenu.findItem(R.id.action_send_comment_activity));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -240,6 +240,7 @@ public class FullMarkdownActivity extends BaseActivity {
|
|||||||
public boolean onCreateOptionsMenu(Menu menu) {
|
public boolean onCreateOptionsMenu(Menu menu) {
|
||||||
if (getIntent().getBooleanExtra(EXTRA_SUBMIT_POST, false)) {
|
if (getIntent().getBooleanExtra(EXTRA_SUBMIT_POST, false)) {
|
||||||
getMenuInflater().inflate(R.menu.full_markdown_activity, menu);
|
getMenuInflater().inflate(R.menu.full_markdown_activity, menu);
|
||||||
|
applyMenuItemTheme(menu);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user