2020-05-20 20:21:09 +02:00
|
|
|
package org.mian.gitnex.actions;
|
|
|
|
|
|
|
|
import android.content.Context;
|
|
|
|
import androidx.annotation.NonNull;
|
|
|
|
import com.google.gson.JsonElement;
|
|
|
|
import org.mian.gitnex.R;
|
|
|
|
import org.mian.gitnex.activities.AddNewTeamMemberActivity;
|
|
|
|
import org.mian.gitnex.clients.RetrofitClient;
|
|
|
|
import org.mian.gitnex.helpers.AlertDialogs;
|
|
|
|
import org.mian.gitnex.helpers.Authorization;
|
2020-07-07 19:15:01 +02:00
|
|
|
import org.mian.gitnex.helpers.TinyDB;
|
2020-05-20 20:21:09 +02:00
|
|
|
import org.mian.gitnex.helpers.Toasty;
|
|
|
|
import retrofit2.Call;
|
|
|
|
import retrofit2.Callback;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Author M M Arif
|
|
|
|
*/
|
|
|
|
|
|
|
|
public class TeamActions {
|
|
|
|
|
|
|
|
public static void removeTeamMember(final Context context, String userName, int teamId) {
|
|
|
|
|
2020-11-02 16:17:00 +01:00
|
|
|
final TinyDB tinyDb = TinyDB.getInstance(context);
|
2020-05-20 20:21:09 +02:00
|
|
|
|
|
|
|
Call<JsonElement> call;
|
|
|
|
|
|
|
|
call = RetrofitClient
|
2020-11-02 16:17:00 +01:00
|
|
|
.getApiInterface(context)
|
|
|
|
.removeTeamMember(Authorization.get(context), teamId, userName);
|
2020-05-20 20:21:09 +02:00
|
|
|
|
|
|
|
call.enqueue(new Callback<JsonElement>() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onResponse(@NonNull Call<JsonElement> call, @NonNull retrofit2.Response<JsonElement> response) {
|
|
|
|
|
|
|
|
if(response.isSuccessful()) {
|
|
|
|
|
|
|
|
if(response.code() == 204) {
|
|
|
|
|
|
|
|
tinyDb.putBoolean("teamActionFlag", true);
|
2020-08-06 17:16:51 +02:00
|
|
|
Toasty.success(context, context.getString(R.string.memberRemovedMessage));
|
2020-05-20 20:21:09 +02:00
|
|
|
((AddNewTeamMemberActivity)context).finish();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
else if(response.code() == 401) {
|
|
|
|
|
|
|
|
AlertDialogs.authorizationTokenRevokedDialog(context, context.getResources().getString(R.string.alertDialogTokenRevokedTitle),
|
|
|
|
context.getResources().getString(R.string.alertDialogTokenRevokedMessage),
|
|
|
|
context.getResources().getString(R.string.alertDialogTokenRevokedCopyNegativeButton),
|
|
|
|
context.getResources().getString(R.string.alertDialogTokenRevokedCopyPositiveButton));
|
|
|
|
|
|
|
|
}
|
|
|
|
else if(response.code() == 403) {
|
|
|
|
|
2020-08-06 17:16:51 +02:00
|
|
|
Toasty.error(context, context.getString(R.string.authorizeError));
|
2020-05-20 20:21:09 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
else if(response.code() == 404) {
|
|
|
|
|
2020-08-06 17:16:51 +02:00
|
|
|
Toasty.warning(context, context.getString(R.string.apiNotFound));
|
2020-05-20 20:21:09 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
|
2020-08-06 17:16:51 +02:00
|
|
|
Toasty.error(context, context.getString(R.string.genericError));
|
2020-05-20 20:21:09 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onFailure(@NonNull Call<JsonElement> call, @NonNull Throwable t) {
|
|
|
|
|
|
|
|
Toasty.error(context, context.getResources().getString(R.string.genericServerResponseError));
|
|
|
|
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void addTeamMember(final Context context, String userName, int teamId) {
|
|
|
|
|
2020-11-02 16:17:00 +01:00
|
|
|
final TinyDB tinyDb = TinyDB.getInstance(context);
|
2020-05-20 20:21:09 +02:00
|
|
|
|
2020-11-02 16:17:00 +01:00
|
|
|
Call<JsonElement> call = RetrofitClient
|
|
|
|
.getApiInterface(context)
|
|
|
|
.addTeamMember(Authorization.get(context), teamId, userName);
|
2020-05-20 20:21:09 +02:00
|
|
|
|
|
|
|
call.enqueue(new Callback<JsonElement>() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onResponse(@NonNull Call<JsonElement> call, @NonNull retrofit2.Response<JsonElement> response) {
|
|
|
|
|
|
|
|
if(response.isSuccessful()) {
|
|
|
|
|
|
|
|
if(response.code() == 204) {
|
|
|
|
|
|
|
|
tinyDb.putBoolean("teamActionFlag", true);
|
2020-08-06 17:16:51 +02:00
|
|
|
Toasty.success(context, context.getString(R.string.memberAddedMessage));
|
2020-05-20 20:21:09 +02:00
|
|
|
((AddNewTeamMemberActivity)context).finish();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
else if(response.code() == 401) {
|
|
|
|
|
|
|
|
AlertDialogs.authorizationTokenRevokedDialog(context, context.getResources().getString(R.string.alertDialogTokenRevokedTitle),
|
|
|
|
context.getResources().getString(R.string.alertDialogTokenRevokedMessage),
|
|
|
|
context.getResources().getString(R.string.alertDialogTokenRevokedCopyNegativeButton),
|
|
|
|
context.getResources().getString(R.string.alertDialogTokenRevokedCopyPositiveButton));
|
|
|
|
|
|
|
|
}
|
|
|
|
else if(response.code() == 403) {
|
|
|
|
|
2020-08-06 17:16:51 +02:00
|
|
|
Toasty.error(context, context.getString(R.string.authorizeError));
|
2020-05-20 20:21:09 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
else if(response.code() == 404) {
|
|
|
|
|
2020-08-06 17:16:51 +02:00
|
|
|
Toasty.warning(context, context.getString(R.string.apiNotFound));
|
2020-05-20 20:21:09 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
|
2020-08-06 17:16:51 +02:00
|
|
|
Toasty.error(context, context.getString(R.string.genericError));
|
2020-05-20 20:21:09 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onFailure(@NonNull Call<JsonElement> call, @NonNull Throwable t) {
|
|
|
|
|
|
|
|
Toasty.error(context, context.getResources().getString(R.string.genericServerResponseError));
|
|
|
|
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|