fedilab-Android-App/app/src/main/java/app/fedilab/android/mastodon/viewmodel/mastodon/ReorderVM.java

212 lines
9.9 KiB
Java

package app.fedilab.android.mastodon.viewmodel.mastodon;
/* Copyright 2022 Thomas Schneider
*
* This file is a part of Fedilab
*
* This program is free software; you can redistribute it and/or modify it under the terms of the
* GNU General Public License as published by the Free Software Foundation; either version 3 of the
* License, or (at your option) any later version.
*
* Fedilab is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even
* the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
* Public License for more details.
*
* You should have received a copy of the GNU General Public License along with Fedilab; if not,
* see <http://www.gnu.org/licenses>. */
import android.app.Application;
import android.content.SharedPreferences;
import android.os.Handler;
import android.os.Looper;
import androidx.annotation.NonNull;
import androidx.lifecycle.AndroidViewModel;
import androidx.lifecycle.LiveData;
import androidx.lifecycle.MutableLiveData;
import androidx.preference.PreferenceManager;
import java.util.ArrayList;
import java.util.List;
import app.fedilab.android.R;
import app.fedilab.android.mastodon.client.endpoints.MastodonSearchService;
import app.fedilab.android.mastodon.client.entities.api.Results;
import app.fedilab.android.mastodon.client.entities.app.BottomMenu;
import app.fedilab.android.mastodon.client.entities.app.Pinned;
import app.fedilab.android.mastodon.client.entities.app.PinnedTimeline;
import app.fedilab.android.mastodon.client.entities.app.Timeline;
import app.fedilab.android.mastodon.exception.DBException;
import app.fedilab.android.mastodon.helper.Helper;
import okhttp3.OkHttpClient;
import retrofit2.Call;
import retrofit2.Response;
import retrofit2.Retrofit;
import retrofit2.converter.gson.GsonConverterFactory;
public class ReorderVM extends AndroidViewModel {
final OkHttpClient okHttpClient = Helper.myOkHttpClient(getApplication().getApplicationContext());
private MutableLiveData<Results> resultsMutableLiveData;
private MutableLiveData<Pinned> pinnedMutableLiveData;
private MutableLiveData<BottomMenu> bottomMenuMutableLiveData;
public ReorderVM(@NonNull Application application) {
super(application);
}
private MastodonSearchService init(@NonNull String url) {
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(url)
.addConverterFactory(GsonConverterFactory.create())
.client(okHttpClient)
.build();
return retrofit.create(MastodonSearchService.class);
}
public LiveData<Pinned> getPinned() {
pinnedMutableLiveData = new MutableLiveData<>();
new Thread(() -> {
Pinned pinned = null;
try {
pinned = new Pinned(getApplication().getApplicationContext()).getAllPinned(Helper.getCurrentAccount(getApplication().getApplicationContext()));
SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(getApplication().getApplicationContext());
boolean singleBar = sharedpreferences.getBoolean(getApplication().getApplicationContext().getString(R.string.SET_USE_SINGLE_TOPBAR), false);
List<PinnedTimeline> pinnedTimelinesToRemove = new ArrayList<>();
if (!singleBar && pinned != null && pinned.pinnedTimelines != null) {
for (PinnedTimeline pinnedTimeline : pinned.pinnedTimelines) {
if (pinnedTimeline.type == Timeline.TimeLineEnum.HOME) {
pinnedTimelinesToRemove.add(pinnedTimeline);
}
if (pinnedTimeline.type == Timeline.TimeLineEnum.LOCAL) {
pinnedTimelinesToRemove.add(pinnedTimeline);
}
if (pinnedTimeline.type == Timeline.TimeLineEnum.PUBLIC) {
pinnedTimelinesToRemove.add(pinnedTimeline);
}
if (pinnedTimeline.type == Timeline.TimeLineEnum.NOTIFICATION) {
pinnedTimelinesToRemove.add(pinnedTimeline);
}
if (pinnedTimeline.type == Timeline.TimeLineEnum.DIRECT) {
pinnedTimelinesToRemove.add(pinnedTimeline);
}
}
pinned.pinnedTimelines.removeAll(pinnedTimelinesToRemove);
}
} catch (DBException e) {
e.printStackTrace();
}
Handler mainHandler = new Handler(Looper.getMainLooper());
Pinned finalPinned = pinned;
Runnable myRunnable = () -> pinnedMutableLiveData.setValue(finalPinned);
mainHandler.post(myRunnable);
}).start();
return pinnedMutableLiveData;
}
public LiveData<Pinned> getAllPinned() {
pinnedMutableLiveData = new MutableLiveData<>();
new Thread(() -> {
Pinned pinned = null;
try {
pinned = new Pinned(getApplication().getApplicationContext()).getAllPinned(Helper.getCurrentAccount(getApplication().getApplicationContext()));
} catch (DBException e) {
e.printStackTrace();
}
Handler mainHandler = new Handler(Looper.getMainLooper());
Pinned finalPinned = pinned;
Runnable myRunnable = () -> pinnedMutableLiveData.setValue(finalPinned);
mainHandler.post(myRunnable);
}).start();
return pinnedMutableLiveData;
}
public LiveData<BottomMenu> getBottomMenu() {
bottomMenuMutableLiveData = new MutableLiveData<>();
new Thread(() -> {
BottomMenu bottomMenu = null;
try {
bottomMenu = new BottomMenu(getApplication().getApplicationContext()).getAllBottomMenu(Helper.getCurrentAccount(getApplication().getApplicationContext()));
} catch (DBException e) {
e.printStackTrace();
}
if (bottomMenu == null) {
bottomMenu = new BottomMenu(getApplication().getApplicationContext()).defaultBottomMenu();
}
Handler mainHandler = new Handler(Looper.getMainLooper());
BottomMenu finalBottomMenu = bottomMenu;
Runnable myRunnable = () -> bottomMenuMutableLiveData.setValue(finalBottomMenu);
mainHandler.post(myRunnable);
}).start();
return bottomMenuMutableLiveData;
}
/**
* Search for content in accounts, statuses and hashtags with API v2
*
* @param instance Instance domain of the active account
* @param token Access token of the active account
* @param q String - search words
* @param account_id String - If provided, statuses returned will be authored only by this account
* @param type String - Enum(accounts, hashtags, statuses)
* @param exclude_unreviewed boolean - Filter out unreviewed tags? Defaults to false. Use true when trying to find trending tags.
* @param resolve boolean - Attempt WebFinger lookup. Defaults to false.
* @param following boolean - Only include accounts that the user is following. Defaults to false.
* @param offset int - Offset in search results. Used for pagination. Defaults to 0.
* @param max_id String - Return results older than this id
* @param min_id String - Return results immediately newer than this id
* @param limit int - Maximum number of results to load, per type. Defaults to 20. Max 40.
* @return {@link LiveData} containing an {@link Results}
*/
public LiveData<Results> search(@NonNull String instance,
String token,
@NonNull String q,
String account_id,
String type,
boolean exclude_unreviewed,
boolean resolve,
boolean following,
int offset,
String max_id,
String min_id,
int limit) {
MastodonSearchService mastodonSearchService = init(instance);
resultsMutableLiveData = new MutableLiveData<>();
new Thread(() -> {
Call<Results> resultsCall = mastodonSearchService.search(
token, q, account_id, type, exclude_unreviewed,
resolve, following, offset, max_id, min_id, limit);
Results results = null;
if (resultsCall != null) {
try {
Response<Results> resultsResponse = resultsCall.execute();
if (resultsResponse.isSuccessful()) {
results = resultsResponse.body();
if (results != null) {
if (results.statuses == null) {
results.statuses = new ArrayList<>();
}
if (results.accounts == null) {
results.accounts = new ArrayList<>();
}
if (results.hashtags == null) {
results.hashtags = new ArrayList<>();
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
Handler mainHandler = new Handler(Looper.getMainLooper());
Results finalResults = results;
Runnable myRunnable = () -> resultsMutableLiveData.setValue(finalResults);
mainHandler.post(myRunnable);
}).start();
return resultsMutableLiveData;
}
}