mirror of
https://codeberg.org/Bazsalanszky/Infinity-For-Lemmy.git
synced 2025-01-02 14:27:10 +01:00
Continue adding support for submitting gallery posts.
This commit is contained in:
parent
19a94f7e0a
commit
299813d527
@ -5,7 +5,7 @@ import android.os.Parcelable;
|
|||||||
|
|
||||||
import com.google.gson.annotations.SerializedName;
|
import com.google.gson.annotations.SerializedName;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
public class RedditGalleryPayload {
|
public class RedditGalleryPayload {
|
||||||
@SerializedName("sr")
|
@SerializedName("sr")
|
||||||
@ -29,17 +29,24 @@ public class RedditGalleryPayload {
|
|||||||
public boolean sendReplies;
|
public boolean sendReplies;
|
||||||
@SerializedName("validate_on_submit")
|
@SerializedName("validate_on_submit")
|
||||||
public boolean validateOnSubmit = true;
|
public boolean validateOnSubmit = true;
|
||||||
public List<Item> items;
|
@SerializedName("flair_id")
|
||||||
|
public String flairId;
|
||||||
|
@SerializedName("flair_text")
|
||||||
|
public String flairText;
|
||||||
|
public ArrayList<Item> items;
|
||||||
|
|
||||||
public RedditGalleryPayload(String subredditName, String submitType, String kind, String title,
|
public RedditGalleryPayload(String subredditName, String submitType, String title,
|
||||||
boolean isSpoiler, boolean isNSFW, boolean sendReplies, List<Item> items) {
|
boolean isSpoiler, boolean isNSFW, boolean sendReplies, Flair flair, ArrayList<Item> items) {
|
||||||
this.subredditName = subredditName;
|
this.subredditName = subredditName;
|
||||||
this.submitType = submitType;
|
this.submitType = submitType;
|
||||||
this.title = title;
|
this.title = title;
|
||||||
this.isSpoiler = isSpoiler;
|
this.isSpoiler = isSpoiler;
|
||||||
this.isNSFW = isNSFW;
|
this.isNSFW = isNSFW;
|
||||||
this.kind = kind;
|
|
||||||
this.sendReplies = sendReplies;
|
this.sendReplies = sendReplies;
|
||||||
|
if (flair != null) {
|
||||||
|
flairId = flair.getId();
|
||||||
|
flairText = flair.getText();
|
||||||
|
}
|
||||||
this.items = items;
|
this.items = items;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,7 +24,6 @@ import androidx.annotation.NonNull;
|
|||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.appcompat.widget.Toolbar;
|
import androidx.appcompat.widget.Toolbar;
|
||||||
import androidx.coordinatorlayout.widget.CoordinatorLayout;
|
import androidx.coordinatorlayout.widget.CoordinatorLayout;
|
||||||
import androidx.core.content.ContextCompat;
|
|
||||||
import androidx.core.content.FileProvider;
|
import androidx.core.content.FileProvider;
|
||||||
import androidx.recyclerview.widget.GridLayoutManager;
|
import androidx.recyclerview.widget.GridLayoutManager;
|
||||||
import androidx.recyclerview.widget.RecyclerView;
|
import androidx.recyclerview.widget.RecyclerView;
|
||||||
@ -459,9 +458,9 @@ public class PostGalleryActivity extends BaseActivity implements FlairBottomShee
|
|||||||
try {
|
try {
|
||||||
Bitmap resource = Glide.with(PostGalleryActivity.this).asBitmap().load(imageUri).submit().get();
|
Bitmap resource = Glide.with(PostGalleryActivity.this).asBitmap().load(imageUri).submit().get();
|
||||||
String response = UploadImageUtils.uploadImage(mOauthRetrofit, mUploadMediaRetrofit, mAccessToken, resource, true);
|
String response = UploadImageUtils.uploadImage(mOauthRetrofit, mUploadMediaRetrofit, mAccessToken, resource, true);
|
||||||
RedditGalleryPayload.Item item = new Gson().fromJson(new JSONObject(response).getJSONObject(JSONUtils.ASSET_KEY).toString(), RedditGalleryPayload.Item.class);
|
String mediaId = new JSONObject(response).getJSONObject(JSONUtils.ASSET_KEY).getString(JSONUtils.ASSET_ID_KEY);
|
||||||
handler.post(() -> {
|
handler.post(() -> {
|
||||||
adapter.setImageAsUploaded(item);
|
adapter.setImageAsUploaded(mediaId);
|
||||||
isUploading = false;
|
isUploading = false;
|
||||||
});
|
});
|
||||||
} catch (ExecutionException | InterruptedException e) {
|
} catch (ExecutionException | InterruptedException e) {
|
||||||
@ -475,7 +474,7 @@ public class PostGalleryActivity extends BaseActivity implements FlairBottomShee
|
|||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
handler.post(() -> {
|
handler.post(() -> {
|
||||||
adapter.removeFailedToUploadImage();
|
adapter.removeFailedToUploadImage();
|
||||||
Snackbar.make(coordinatorLayout, R.string.error_processing_image, Snackbar.LENGTH_LONG).show();
|
Snackbar.make(coordinatorLayout, R.string.upload_image_failed, Snackbar.LENGTH_LONG).show();
|
||||||
isUploading = false;
|
isUploading = false;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -516,7 +515,7 @@ public class PostGalleryActivity extends BaseActivity implements FlairBottomShee
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onCreateOptionsMenu(Menu menu) {
|
public boolean onCreateOptionsMenu(Menu menu) {
|
||||||
getMenuInflater().inflate(R.menu.post_image_activity, menu);
|
getMenuInflater().inflate(R.menu.post_gallery_activity, menu);
|
||||||
applyMenuItemTheme(menu);
|
applyMenuItemTheme(menu);
|
||||||
mMemu = menu;
|
mMemu = menu;
|
||||||
if (isPosting) {
|
if (isPosting) {
|
||||||
@ -541,7 +540,7 @@ public class PostGalleryActivity extends BaseActivity implements FlairBottomShee
|
|||||||
}
|
}
|
||||||
finish();
|
finish();
|
||||||
return true;
|
return true;
|
||||||
} else if (itemId == R.id.action_send_post_image_activity) {
|
} else if (itemId == R.id.action_send_post_gallery_activity) {
|
||||||
if (!subredditSelected) {
|
if (!subredditSelected) {
|
||||||
Snackbar.make(coordinatorLayout, R.string.select_a_subreddit, Snackbar.LENGTH_SHORT).show();
|
Snackbar.make(coordinatorLayout, R.string.select_a_subreddit, Snackbar.LENGTH_SHORT).show();
|
||||||
return true;
|
return true;
|
||||||
@ -552,11 +551,16 @@ public class PostGalleryActivity extends BaseActivity implements FlairBottomShee
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (redditGalleryImageInfoList == null) {
|
if (redditGalleryImageInfoList == null || redditGalleryImageInfoList.isEmpty()) {
|
||||||
Snackbar.make(coordinatorLayout, R.string.select_an_image, Snackbar.LENGTH_SHORT).show();
|
Snackbar.make(coordinatorLayout, R.string.select_an_image, Snackbar.LENGTH_SHORT).show();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (redditGalleryImageInfoList.get(redditGalleryImageInfoList.size() - 1).payload == null) {
|
||||||
|
Snackbar.make(coordinatorLayout, R.string.please_wait_image_is_uploading, Snackbar.LENGTH_LONG).show();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
isPosting = true;
|
isPosting = true;
|
||||||
|
|
||||||
item.setEnabled(false);
|
item.setEnabled(false);
|
||||||
@ -574,13 +578,17 @@ public class PostGalleryActivity extends BaseActivity implements FlairBottomShee
|
|||||||
Intent intent = new Intent(this, SubmitPostService.class);
|
Intent intent = new Intent(this, SubmitPostService.class);
|
||||||
intent.putExtra(SubmitPostService.EXTRA_ACCESS_TOKEN, mAccessToken);
|
intent.putExtra(SubmitPostService.EXTRA_ACCESS_TOKEN, mAccessToken);
|
||||||
intent.putExtra(SubmitPostService.EXTRA_SUBREDDIT_NAME, subredditName);
|
intent.putExtra(SubmitPostService.EXTRA_SUBREDDIT_NAME, subredditName);
|
||||||
intent.putExtra(SubmitPostService.EXTRA_TITLE, titleEditText.getText().toString());
|
intent.putExtra(SubmitPostService.EXTRA_POST_TYPE, SubmitPostService.EXTRA_POST_TYPE_GALLERY);
|
||||||
intent.putExtra(SubmitPostService.EXTRA_FLAIR, flair);
|
ArrayList<RedditGalleryPayload.Item> items = new ArrayList<>();
|
||||||
intent.putExtra(SubmitPostService.EXTRA_IS_SPOILER, isSpoiler);
|
for (RedditGallerySubmissionRecyclerViewAdapter.RedditGalleryImageInfo i : redditGalleryImageInfoList) {
|
||||||
intent.putExtra(SubmitPostService.EXTRA_IS_NSFW, isNSFW);
|
items.add(i.payload);
|
||||||
intent.putExtra(SubmitPostService.EXTRA_RECEIVE_POST_REPLY_NOTIFICATIONS, receivePostReplyNotificationsSwitchMaterial.isChecked());
|
}
|
||||||
|
RedditGalleryPayload payload = new RedditGalleryPayload(subredditName, subredditIsUser ? "profile" : "subreddit",
|
||||||
|
titleEditText.getText().toString(), isSpoiler, isNSFW, receivePostReplyNotificationsSwitchMaterial.isChecked(),
|
||||||
|
flair, items);
|
||||||
|
intent.putExtra(SubmitPostService.EXTRA_REDDIT_GALLERY_PAYLOAD, new Gson().toJson(payload));
|
||||||
|
|
||||||
ContextCompat.startForegroundService(this, intent);
|
//ContextCompat.startForegroundService(this, intent);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -131,8 +131,8 @@ public class RedditGallerySubmissionRecyclerViewAdapter extends RecyclerView.Ada
|
|||||||
notifyItemInserted(redditGalleryImageInfoList.size() - 1);
|
notifyItemInserted(redditGalleryImageInfoList.size() - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setImageAsUploaded(RedditGalleryPayload.Item item) {
|
public void setImageAsUploaded(String mediaId) {
|
||||||
redditGalleryImageInfoList.get(redditGalleryImageInfoList.size() - 1).payload = item;
|
redditGalleryImageInfoList.get(redditGalleryImageInfoList.size() - 1).payload = new RedditGalleryPayload.Item("", "", mediaId);
|
||||||
notifyItemChanged(redditGalleryImageInfoList.size() - 1);
|
notifyItemChanged(redditGalleryImageInfoList.size() - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -0,0 +1,15 @@
|
|||||||
|
package ml.docilealligator.infinityforreddit.events;
|
||||||
|
|
||||||
|
import ml.docilealligator.infinityforreddit.post.Post;
|
||||||
|
|
||||||
|
public class SubmitGalleryPostEvent {
|
||||||
|
public boolean postSuccess;
|
||||||
|
public Post post;
|
||||||
|
public String errorMessage;
|
||||||
|
|
||||||
|
public SubmitGalleryPostEvent(boolean postSuccess, Post post, String errorMessage) {
|
||||||
|
this.postSuccess = postSuccess;
|
||||||
|
this.post = post;
|
||||||
|
this.errorMessage = errorMessage;
|
||||||
|
}
|
||||||
|
}
|
@ -41,6 +41,7 @@ import javax.inject.Named;
|
|||||||
import ml.docilealligator.infinityforreddit.Flair;
|
import ml.docilealligator.infinityforreddit.Flair;
|
||||||
import ml.docilealligator.infinityforreddit.Infinity;
|
import ml.docilealligator.infinityforreddit.Infinity;
|
||||||
import ml.docilealligator.infinityforreddit.R;
|
import ml.docilealligator.infinityforreddit.R;
|
||||||
|
import ml.docilealligator.infinityforreddit.apis.RedditAPI;
|
||||||
import ml.docilealligator.infinityforreddit.customtheme.CustomThemeWrapper;
|
import ml.docilealligator.infinityforreddit.customtheme.CustomThemeWrapper;
|
||||||
import ml.docilealligator.infinityforreddit.events.SubmitCrosspostEvent;
|
import ml.docilealligator.infinityforreddit.events.SubmitCrosspostEvent;
|
||||||
import ml.docilealligator.infinityforreddit.events.SubmitImagePostEvent;
|
import ml.docilealligator.infinityforreddit.events.SubmitImagePostEvent;
|
||||||
@ -50,6 +51,7 @@ import ml.docilealligator.infinityforreddit.post.Post;
|
|||||||
import ml.docilealligator.infinityforreddit.post.SubmitPost;
|
import ml.docilealligator.infinityforreddit.post.SubmitPost;
|
||||||
import ml.docilealligator.infinityforreddit.utils.APIUtils;
|
import ml.docilealligator.infinityforreddit.utils.APIUtils;
|
||||||
import ml.docilealligator.infinityforreddit.utils.NotificationUtils;
|
import ml.docilealligator.infinityforreddit.utils.NotificationUtils;
|
||||||
|
import retrofit2.Response;
|
||||||
import retrofit2.Retrofit;
|
import retrofit2.Retrofit;
|
||||||
|
|
||||||
public class SubmitPostService extends Service {
|
public class SubmitPostService extends Service {
|
||||||
@ -67,7 +69,8 @@ public class SubmitPostService extends Service {
|
|||||||
public static final int EXTRA_POST_TEXT_OR_LINK = 0;
|
public static final int EXTRA_POST_TEXT_OR_LINK = 0;
|
||||||
public static final int EXTRA_POST_TYPE_IMAGE = 1;
|
public static final int EXTRA_POST_TYPE_IMAGE = 1;
|
||||||
public static final int EXTRA_POST_TYPE_VIDEO = 2;
|
public static final int EXTRA_POST_TYPE_VIDEO = 2;
|
||||||
public static final int EXTRA_POST_TYPE_CROSSPOST = 3;
|
public static final int EXTRA_POST_TYPE_GALLERY = 3;
|
||||||
|
public static final int EXTRA_POST_TYPE_CROSSPOST = 4;
|
||||||
|
|
||||||
private static final String EXTRA_MEDIA_URI = "EU";
|
private static final String EXTRA_MEDIA_URI = "EU";
|
||||||
@Inject
|
@Inject
|
||||||
@ -126,10 +129,12 @@ public class SubmitPostService extends Service {
|
|||||||
Uri mediaUri = Uri.parse(bundle.getString(EXTRA_MEDIA_URI));
|
Uri mediaUri = Uri.parse(bundle.getString(EXTRA_MEDIA_URI));
|
||||||
submitImagePost(accessToken, mediaUri, subredditName, title, flair, isSpoiler, isNSFW,
|
submitImagePost(accessToken, mediaUri, subredditName, title, flair, isSpoiler, isNSFW,
|
||||||
receivePostReplyNotifications);
|
receivePostReplyNotifications);
|
||||||
} else {
|
} else if (postType == EXTRA_POST_TYPE_VIDEO) {
|
||||||
Uri mediaUri = Uri.parse(bundle.getString(EXTRA_MEDIA_URI));
|
Uri mediaUri = Uri.parse(bundle.getString(EXTRA_MEDIA_URI));
|
||||||
submitVideoPost(accessToken, mediaUri, subredditName, title, flair, isSpoiler, isNSFW,
|
submitVideoPost(accessToken, mediaUri, subredditName, title, flair, isSpoiler, isNSFW,
|
||||||
receivePostReplyNotifications);
|
receivePostReplyNotifications);
|
||||||
|
} else {
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -176,9 +181,11 @@ public class SubmitPostService extends Service {
|
|||||||
} else if (postType == EXTRA_POST_TYPE_IMAGE) {
|
} else if (postType == EXTRA_POST_TYPE_IMAGE) {
|
||||||
bundle.putString(EXTRA_MEDIA_URI, intent.getData().toString());
|
bundle.putString(EXTRA_MEDIA_URI, intent.getData().toString());
|
||||||
startForeground(NotificationUtils.SUBMIT_POST_SERVICE_NOTIFICATION_ID + randomNotificationIdOffset, createNotification(R.string.posting_image));
|
startForeground(NotificationUtils.SUBMIT_POST_SERVICE_NOTIFICATION_ID + randomNotificationIdOffset, createNotification(R.string.posting_image));
|
||||||
} else {
|
} else if (postType == EXTRA_POST_TYPE_VIDEO) {
|
||||||
bundle.putString(EXTRA_MEDIA_URI, intent.getData().toString());
|
bundle.putString(EXTRA_MEDIA_URI, intent.getData().toString());
|
||||||
startForeground(NotificationUtils.SUBMIT_POST_SERVICE_NOTIFICATION_ID + randomNotificationIdOffset, createNotification(R.string.posting_video));
|
startForeground(NotificationUtils.SUBMIT_POST_SERVICE_NOTIFICATION_ID + randomNotificationIdOffset, createNotification(R.string.posting_video));
|
||||||
|
} else {
|
||||||
|
startForeground(NotificationUtils.SUBMIT_POST_SERVICE_NOTIFICATION_ID + randomNotificationIdOffset, createNotification(R.string.posting_gallery));
|
||||||
}
|
}
|
||||||
|
|
||||||
Message msg = serviceHandler.obtainMessage();
|
Message msg = serviceHandler.obtainMessage();
|
||||||
@ -328,6 +335,14 @@ public class SubmitPostService extends Service {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void submitGalleryPost(String accessToken, String payload) {
|
||||||
|
try {
|
||||||
|
Response<String> response = mOauthRetrofit.create(RedditAPI.class).submitGalleryPost(APIUtils.getOAuthHeader(accessToken), payload).execute();
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private static void copyFileToCache(InputStream fileInputStream, String destinationFilePath) throws IOException {
|
private static void copyFileToCache(InputStream fileInputStream, String destinationFilePath) throws IOException {
|
||||||
OutputStream out = new FileOutputStream(destinationFilePath);
|
OutputStream out = new FileOutputStream(destinationFilePath);
|
||||||
byte[] buf = new byte[2048];
|
byte[] buf = new byte[2048];
|
||||||
|
@ -165,4 +165,5 @@ public class JSONUtils {
|
|||||||
public static final String PAYLOAD_KEY = "payload";
|
public static final String PAYLOAD_KEY = "payload";
|
||||||
public static final String AUTHOR_ICON_IMAGE = "author_icon_img";
|
public static final String AUTHOR_ICON_IMAGE = "author_icon_img";
|
||||||
public static final String ASSET_KEY = "asset";
|
public static final String ASSET_KEY = "asset";
|
||||||
|
public static final String ASSET_ID_KEY = "asset_id";
|
||||||
}
|
}
|
||||||
|
@ -287,6 +287,7 @@
|
|||||||
|
|
||||||
<string name="posting_video">Posting Video</string>
|
<string name="posting_video">Posting Video</string>
|
||||||
<string name="posting_image">Posting Image</string>
|
<string name="posting_image">Posting Image</string>
|
||||||
|
<string name="posting_gallery">Posting Gallery</string>
|
||||||
<string name="please_wait">Please wait</string>
|
<string name="please_wait">Please wait</string>
|
||||||
|
|
||||||
<string name="add_account">Add account</string>
|
<string name="add_account">Add account</string>
|
||||||
|
Loading…
Reference in New Issue
Block a user