summaryrefslogtreecommitdiffstats
path: root/app/src/main/java/app/fedilab/android/mastodon/viewmodel/mastodon/AnnouncementsVM.java
blob: b168c0bb05c7e4c9eda514b085ab9fd880f30ce6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
package app.fedilab.android.mastodon.viewmodel.mastodon;
/* Copyright 2021 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.os.Handler;
import android.os.Looper;

import androidx.annotation.NonNull;
import androidx.lifecycle.AndroidViewModel;
import androidx.lifecycle.LiveData;
import androidx.lifecycle.MutableLiveData;

import java.net.IDN;
import java.util.List;

import app.fedilab.android.mastodon.client.endpoints.MastodonAnnouncementsService;
import app.fedilab.android.mastodon.client.entities.api.Announcement;
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 AnnouncementsVM extends AndroidViewModel {

    final OkHttpClient okHttpClient = Helper.myOkHttpClient(getApplication().getApplicationContext());
    private MutableLiveData<Announcement> announcementMutableLiveData;
    private MutableLiveData<List<Announcement>> announcementListMutableLiveData;

    public AnnouncementsVM(@NonNull Application application) {
        super(application);
    }

    private MastodonAnnouncementsService init(String instance) {
        Retrofit retrofit = new Retrofit.Builder()
                .baseUrl("https://" + (instance != null ? IDN.toASCII(instance, IDN.ALLOW_UNASSIGNED) : null) + "/api/v1/")
                .addConverterFactory(GsonConverterFactory.create(Helper.getDateBuilder()))
                .client(okHttpClient)
                .build();
        return retrofit.create(MastodonAnnouncementsService.class);
    }

    /**
     * See all currently active announcements set by admins.
     *
     * @param instance      Instance domain of the active account
     * @param token         Access token of the active account
     * @param withDismissed If true, response will include announcements dismissed by the user. Defaults to false.
     * @return {@link LiveData} containing a {@link List} of {@link Announcement}s
     */
    public LiveData<List<Announcement>> getAnnouncements(@NonNull String instance, String token, Boolean withDismissed) {
        MastodonAnnouncementsService mastodonAnnouncementsService = init(instance);
        announcementListMutableLiveData = new MutableLiveData<>();
        new Thread(() -> {
            List<Announcement> announcementList = null;
            Call<List<Announcement>> getAnnouncementsCall = mastodonAnnouncementsService.getAnnouncements(token, withDismissed);
            if (getAnnouncementsCall != null) {
                try {
                    Response<List<Announcement>> getAnnouncementsResponse = getAnnouncementsCall.execute();
                    if (getAnnouncementsResponse.isSuccessful()) {
                        announcementList = getAnnouncementsResponse.body();
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
            Handler mainHandler = new Handler(Looper.getMainLooper());
            List<Announcement> finalAnnouncementList = announcementList;
            Runnable myRunnable = () -> announcementListMutableLiveData.setValue(finalAnnouncementList);
            mainHandler.post(myRunnable);
        }).start();
        return announcementListMutableLiveData;
    }

    /**
     * Allows a user to mark the announcement as read.
     *
     * @param instance Instance domain of the active account
     * @param token    Access token of the active account
     * @param id       Local ID of an announcement
     */
    public void dismiss(@NonNull String instance, String token, @NonNull String id) {
        MastodonAnnouncementsService mastodonAnnouncementsService = init(instance);
        new Thread(() -> {
            Call<Void> dismissCall = mastodonAnnouncementsService.dismiss(token, id);
            if (dismissCall != null) {
                try {
                    dismissCall.execute();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }).start();
    }

    /**
     * React to an announcement with an emoji.
     *
     * @param instance Instance domain of the active account
     * @param token    Access token of the active account
     * @param id       Local ID of an announcement
     * @param name     Unicode emoji, or shortcode of custom emoji
     */
    public void addReaction(@NonNull String instance, String token, @NonNull String id, @NonNull String name) {
        MastodonAnnouncementsService mastodonAnnouncementsService = init(instance);
        new Thread(() -> {
            Call<Void> addReactionCall = mastodonAnnouncementsService.addReaction(token, id, name);
            if (addReactionCall != null) {
                try {
                    addReactionCall.execute();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }).start();
    }

    /**
     * Undo a react emoji to an announcement.
     *
     * @param instance Instance domain of the active account
     * @param token    Access token of the active account
     * @param id       Local ID of an announcement
     * @param name     Unicode emoji, or shortcode of custom emoji
     */
    public void removeReaction(@NonNull String instance, String token, @NonNull String id, @NonNull String name) {
        MastodonAnnouncementsService mastodonAnnouncementsService = init(instance);
        new Thread(() -> {
            Call<Void> removeReactionCall = mastodonAnnouncementsService.removeReaction(token, id, name);
            if (removeReactionCall != null) {
                try {
                    removeReactionCall.execute();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }).start();
    }
}