mirror of
https://github.com/KokaKiwi/BarInsta
synced 2024-11-22 06:37:30 +00:00
Move StoriesService object to StoriesRepository constructor parameter.
This commit is contained in:
parent
4f8de4e7df
commit
3d69148d9b
@ -298,7 +298,7 @@ public class HashTagFragment extends Fragment implements SwipeRefreshLayout.OnRe
|
|||||||
final String cookie = settingsHelper.getString(Constants.COOKIE);
|
final String cookie = settingsHelper.getString(Constants.COOKIE);
|
||||||
isLoggedIn = !TextUtils.isEmpty(cookie) && CookieUtils.getUserIdFromCookie(cookie) > 0;
|
isLoggedIn = !TextUtils.isEmpty(cookie) && CookieUtils.getUserIdFromCookie(cookie) > 0;
|
||||||
tagsService = isLoggedIn ? TagsService.getInstance() : null;
|
tagsService = isLoggedIn ? TagsService.getInstance() : null;
|
||||||
storiesRepository = isLoggedIn ? StoriesRepository.INSTANCE : null;
|
storiesRepository = isLoggedIn ? StoriesRepository.Companion.getInstance() : null;
|
||||||
graphQLService = isLoggedIn ? null : GraphQLService.INSTANCE;
|
graphQLService = isLoggedIn ? null : GraphQLService.INSTANCE;
|
||||||
setHasOptionsMenu(true);
|
setHasOptionsMenu(true);
|
||||||
}
|
}
|
||||||
|
@ -291,7 +291,7 @@ public class LocationFragment extends Fragment implements SwipeRefreshLayout.OnR
|
|||||||
final String cookie = settingsHelper.getString(Constants.COOKIE);
|
final String cookie = settingsHelper.getString(Constants.COOKIE);
|
||||||
isLoggedIn = !TextUtils.isEmpty(cookie) && CookieUtils.getUserIdFromCookie(cookie) > 0;
|
isLoggedIn = !TextUtils.isEmpty(cookie) && CookieUtils.getUserIdFromCookie(cookie) > 0;
|
||||||
locationService = isLoggedIn ? LocationService.getInstance() : null;
|
locationService = isLoggedIn ? LocationService.getInstance() : null;
|
||||||
storiesRepository = StoriesRepository.INSTANCE;
|
storiesRepository = StoriesRepository.Companion.getInstance();
|
||||||
graphQLService = isLoggedIn ? null : GraphQLService.INSTANCE;
|
graphQLService = isLoggedIn ? null : GraphQLService.INSTANCE;
|
||||||
setHasOptionsMenu(true);
|
setHasOptionsMenu(true);
|
||||||
}
|
}
|
||||||
|
@ -136,7 +136,7 @@ public final class StoryListViewerFragment extends Fragment implements SwipeRefr
|
|||||||
context = getContext();
|
context = getContext();
|
||||||
if (context == null) return;
|
if (context == null) return;
|
||||||
setHasOptionsMenu(true);
|
setHasOptionsMenu(true);
|
||||||
storiesRepository = StoriesRepository.INSTANCE;
|
storiesRepository = StoriesRepository.Companion.getInstance();
|
||||||
}
|
}
|
||||||
|
|
||||||
@NonNull
|
@NonNull
|
||||||
|
@ -162,7 +162,7 @@ public class StoryViewerFragment extends Fragment {
|
|||||||
userId = CookieUtils.getUserIdFromCookie(cookie);
|
userId = CookieUtils.getUserIdFromCookie(cookie);
|
||||||
deviceId = settingsHelper.getString(Constants.DEVICE_UUID);
|
deviceId = settingsHelper.getString(Constants.DEVICE_UUID);
|
||||||
fragmentActivity = (AppCompatActivity) requireActivity();
|
fragmentActivity = (AppCompatActivity) requireActivity();
|
||||||
storiesRepository = StoriesRepository.INSTANCE;
|
storiesRepository = StoriesRepository.Companion.getInstance();
|
||||||
mediaService = MediaService.INSTANCE;
|
mediaService = MediaService.INSTANCE;
|
||||||
directMessagesService = DirectMessagesService.INSTANCE;
|
directMessagesService = DirectMessagesService.INSTANCE;
|
||||||
setHasOptionsMenu(true);
|
setHasOptionsMenu(true);
|
||||||
|
@ -276,7 +276,7 @@ public class FeedFragment extends Fragment implements SwipeRefreshLayout.OnRefre
|
|||||||
public void onCreate(@Nullable final Bundle savedInstanceState) {
|
public void onCreate(@Nullable final Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
fragmentActivity = (MainActivity) requireActivity();
|
fragmentActivity = (MainActivity) requireActivity();
|
||||||
storiesRepository = StoriesRepository.INSTANCE;
|
storiesRepository = StoriesRepository.Companion.getInstance();
|
||||||
setHasOptionsMenu(true);
|
setHasOptionsMenu(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -335,7 +335,7 @@ public class ProfileFragment extends Fragment implements SwipeRefreshLayout.OnRe
|
|||||||
fragmentActivity = (MainActivity) requireActivity();
|
fragmentActivity = (MainActivity) requireActivity();
|
||||||
friendshipRepository = isLoggedIn ? FriendshipRepository.Companion.getInstance() : null;
|
friendshipRepository = isLoggedIn ? FriendshipRepository.Companion.getInstance() : null;
|
||||||
directMessagesService = isLoggedIn ? DirectMessagesService.INSTANCE : null;
|
directMessagesService = isLoggedIn ? DirectMessagesService.INSTANCE : null;
|
||||||
storiesRepository = isLoggedIn ? StoriesRepository.INSTANCE : null;
|
storiesRepository = isLoggedIn ? StoriesRepository.Companion.getInstance() : null;
|
||||||
mediaService = isLoggedIn ? MediaService.INSTANCE : null;
|
mediaService = isLoggedIn ? MediaService.INSTANCE : null;
|
||||||
userRepository = isLoggedIn ? UserRepository.Companion.getInstance() : null;
|
userRepository = isLoggedIn ? UserRepository.Companion.getInstance() : null;
|
||||||
graphQLService = isLoggedIn ? null : GraphQLService.INSTANCE;
|
graphQLService = isLoggedIn ? null : GraphQLService.INSTANCE;
|
||||||
|
@ -19,8 +19,7 @@ import org.json.JSONArray
|
|||||||
import org.json.JSONObject
|
import org.json.JSONObject
|
||||||
import java.util.*
|
import java.util.*
|
||||||
|
|
||||||
object StoriesRepository {
|
class StoriesRepository(private val service: StoriesService) {
|
||||||
private val service: StoriesService = retrofit.create(StoriesService::class.java)
|
|
||||||
|
|
||||||
suspend fun fetch(mediaId: Long): StoryModel {
|
suspend fun fetch(mediaId: Long): StoryModel {
|
||||||
val response = service.fetch(mediaId)
|
val response = service.fetch(mediaId)
|
||||||
@ -41,7 +40,8 @@ object StoriesRepository {
|
|||||||
if (node.optBoolean("hide_from_feed_unit") && Utils.settingsHelper.getBoolean(PreferenceKeys.HIDE_MUTED_REELS)) continue
|
if (node.optBoolean("hide_from_feed_unit") && Utils.settingsHelper.getBoolean(PreferenceKeys.HIDE_MUTED_REELS)) continue
|
||||||
val userJson = node.getJSONObject(if (node.has("user")) "user" else "owner")
|
val userJson = node.getJSONObject(if (node.has("user")) "user" else "owner")
|
||||||
try {
|
try {
|
||||||
val user = User(userJson.getLong("pk"),
|
val user = User(
|
||||||
|
userJson.getLong("pk"),
|
||||||
userJson.getString("username"),
|
userJson.getString("username"),
|
||||||
userJson.optString("full_name"),
|
userJson.optString("full_name"),
|
||||||
userJson.optBoolean("is_private"),
|
userJson.optBoolean("is_private"),
|
||||||
@ -55,15 +55,18 @@ object StoriesRepository {
|
|||||||
if (itemJson != null) {
|
if (itemJson != null) {
|
||||||
firstStoryModel = ResponseBodyUtils.parseStoryItem(itemJson, false, null)
|
firstStoryModel = ResponseBodyUtils.parseStoryItem(itemJson, false, null)
|
||||||
}
|
}
|
||||||
feedStoryModels.add(FeedStoryModel(
|
feedStoryModels.add(
|
||||||
node.getString("id"),
|
FeedStoryModel(
|
||||||
user,
|
node.getString("id"),
|
||||||
fullyRead,
|
user,
|
||||||
timestamp,
|
fullyRead,
|
||||||
firstStoryModel,
|
timestamp,
|
||||||
node.getInt("media_count"),
|
firstStoryModel,
|
||||||
false,
|
node.getInt("media_count"),
|
||||||
node.optBoolean("has_besties_media")))
|
false,
|
||||||
|
node.optBoolean("has_besties_media")
|
||||||
|
)
|
||||||
|
)
|
||||||
} catch (e: Exception) {
|
} catch (e: Exception) {
|
||||||
Log.e(TAG, "parseStoriesBody: ", e)
|
Log.e(TAG, "parseStoriesBody: ", e)
|
||||||
} // to cover promotional reels with non-long user pk's
|
} // to cover promotional reels with non-long user pk's
|
||||||
@ -72,23 +75,26 @@ object StoriesRepository {
|
|||||||
for (i in 0 until broadcasts.length()) {
|
for (i in 0 until broadcasts.length()) {
|
||||||
val node = broadcasts.getJSONObject(i)
|
val node = broadcasts.getJSONObject(i)
|
||||||
val userJson = node.getJSONObject("broadcast_owner")
|
val userJson = node.getJSONObject("broadcast_owner")
|
||||||
val user = User(userJson.getLong("pk"),
|
val user = User(
|
||||||
|
userJson.getLong("pk"),
|
||||||
userJson.getString("username"),
|
userJson.getString("username"),
|
||||||
userJson.optString("full_name"),
|
userJson.optString("full_name"),
|
||||||
userJson.optBoolean("is_private"),
|
userJson.optBoolean("is_private"),
|
||||||
userJson.getString("profile_pic_url"),
|
userJson.getString("profile_pic_url"),
|
||||||
userJson.optBoolean("is_verified")
|
userJson.optBoolean("is_verified")
|
||||||
)
|
)
|
||||||
feedStoryModels.add(FeedStoryModel(
|
feedStoryModels.add(
|
||||||
node.getString("id"),
|
FeedStoryModel(
|
||||||
user,
|
node.getString("id"),
|
||||||
false,
|
user,
|
||||||
node.getLong("published_time"),
|
false,
|
||||||
ResponseBodyUtils.parseBroadcastItem(node),
|
node.getLong("published_time"),
|
||||||
1,
|
ResponseBodyUtils.parseBroadcastItem(node),
|
||||||
isLive = true,
|
1,
|
||||||
isBestie = false
|
isLive = true,
|
||||||
))
|
isBestie = false
|
||||||
|
)
|
||||||
|
)
|
||||||
}
|
}
|
||||||
return sort(feedStoryModels)
|
return sort(feedStoryModels)
|
||||||
}
|
}
|
||||||
@ -100,15 +106,17 @@ object StoriesRepository {
|
|||||||
val highlightModels: MutableList<HighlightModel> = ArrayList()
|
val highlightModels: MutableList<HighlightModel> = ArrayList()
|
||||||
for (i in 0 until length) {
|
for (i in 0 until length) {
|
||||||
val highlightNode = highlightsReel.getJSONObject(i)
|
val highlightNode = highlightsReel.getJSONObject(i)
|
||||||
highlightModels.add(HighlightModel(
|
highlightModels.add(
|
||||||
highlightNode.getString("title"),
|
HighlightModel(
|
||||||
highlightNode.getString(Constants.EXTRAS_ID),
|
highlightNode.getString("title"),
|
||||||
highlightNode.getJSONObject("cover_media")
|
highlightNode.getString(Constants.EXTRAS_ID),
|
||||||
.getJSONObject("cropped_image_version")
|
highlightNode.getJSONObject("cover_media")
|
||||||
.getString("url"),
|
.getJSONObject("cropped_image_version")
|
||||||
highlightNode.getLong("latest_reel_media"),
|
.getString("url"),
|
||||||
highlightNode.getInt("media_count")
|
highlightNode.getLong("latest_reel_media"),
|
||||||
))
|
highlightNode.getInt("media_count")
|
||||||
|
)
|
||||||
|
)
|
||||||
}
|
}
|
||||||
return highlightModels
|
return highlightModels
|
||||||
}
|
}
|
||||||
@ -129,13 +137,15 @@ object StoriesRepository {
|
|||||||
val highlightModels: MutableList<HighlightModel> = ArrayList()
|
val highlightModels: MutableList<HighlightModel> = ArrayList()
|
||||||
for (i in 0 until length) {
|
for (i in 0 until length) {
|
||||||
val highlightNode = highlightsReel.getJSONObject(i)
|
val highlightNode = highlightsReel.getJSONObject(i)
|
||||||
highlightModels.add(HighlightModel(
|
highlightModels.add(
|
||||||
null,
|
HighlightModel(
|
||||||
highlightNode.getString(Constants.EXTRAS_ID),
|
null,
|
||||||
highlightNode.getJSONObject("cover_image_version").getString("url"),
|
highlightNode.getString(Constants.EXTRAS_ID),
|
||||||
highlightNode.getLong("latest_reel_media"),
|
highlightNode.getJSONObject("cover_image_version").getString("url"),
|
||||||
highlightNode.getInt("media_count")
|
highlightNode.getLong("latest_reel_media"),
|
||||||
))
|
highlightNode.getInt("media_count")
|
||||||
|
)
|
||||||
|
)
|
||||||
}
|
}
|
||||||
return ArchiveFetchResponse(highlightModels, data.getBoolean("more_available"), data.getString("max_id"))
|
return ArchiveFetchResponse(highlightModels, data.getBoolean("more_available"), data.getString("max_id"))
|
||||||
}
|
}
|
||||||
@ -306,4 +316,16 @@ object StoriesRepository {
|
|||||||
return hasNextPage
|
return hasNextPage
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
@Volatile
|
||||||
|
private var INSTANCE: StoriesRepository? = null
|
||||||
|
|
||||||
|
fun getInstance(): StoriesRepository {
|
||||||
|
return INSTANCE ?: synchronized(this) {
|
||||||
|
val service: StoriesService = retrofit.create(StoriesService::class.java)
|
||||||
|
StoriesRepository(service).also { INSTANCE = it }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user