GitNex/app/src/main/java/org/mian/gitnex/activities/MergePullRequestActivity.java

298 lines
8.5 KiB
Java
Raw Normal View History

2019-11-27 16:09:26 +01:00
package org.mian.gitnex.activities;
import android.annotation.SuppressLint;
2019-11-27 16:09:26 +01:00
import android.content.Context;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.inputmethod.InputMethodManager;
2019-11-27 16:09:26 +01:00
import android.widget.ArrayAdapter;
import androidx.annotation.NonNull;
import com.google.gson.JsonElement;
import org.gitnex.tea4j.models.MergePullRequest;
import org.gitnex.tea4j.models.MergePullRequestSpinner;
2019-11-27 16:09:26 +01:00
import org.mian.gitnex.R;
import org.mian.gitnex.clients.RetrofitClient;
import org.mian.gitnex.databinding.ActivityMergePullRequestBinding;
2019-11-27 16:09:26 +01:00
import org.mian.gitnex.helpers.AlertDialogs;
import org.mian.gitnex.helpers.AppUtil;
2019-11-27 16:09:26 +01:00
import org.mian.gitnex.helpers.Authorization;
import org.mian.gitnex.helpers.Toasty;
import org.mian.gitnex.helpers.Version;
import java.util.ArrayList;
import java.util.Objects;
2019-11-27 16:09:26 +01:00
import okhttp3.ResponseBody;
import retrofit2.Call;
import retrofit2.Callback;
/**
* Author M M Arif
*/
2020-03-04 20:37:28 +01:00
public class MergePullRequestActivity extends BaseActivity {
2019-11-27 16:09:26 +01:00
private View.OnClickListener onClickListener;
private String repoOwner;
private String repoName;
private int prIndex;
private ActivityMergePullRequestBinding viewBinding;
private String Do;
@SuppressLint("SetTextI18n")
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
viewBinding = ActivityMergePullRequestBinding.inflate(getLayoutInflater());
setContentView(viewBinding.getRoot());
String repoFullName = tinyDB.getString("repoFullName");
String[] parts = repoFullName.split("/");
repoOwner = parts[0];
repoName = parts[1];
prIndex = Integer.parseInt(tinyDB.getString("issueNumber"));
boolean connToInternet = AppUtil.hasNetworkConnection(appCtx);
InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
viewBinding.mergeTitle.requestFocus();
assert imm != null;
imm.showSoftInput(viewBinding.mergeTitle, InputMethodManager.SHOW_IMPLICIT);
setMergeAdapter();
if(!tinyDB.getString("issueTitle").isEmpty()) {
viewBinding.toolbarTitle.setText(tinyDB.getString("issueTitle"));
viewBinding.mergeTitle.setText(tinyDB.getString("issueTitle") + " (#" + tinyDB.getString("issueNumber") + ")");
}
2019-11-27 16:09:26 +01:00
initCloseListener();
viewBinding.close.setOnClickListener(onClickListener);
// if gitea version is greater/equal(1.12.0) than user installed version (installed.higherOrEqual(compareVer))
if(new Version(tinyDB.getString("giteaVersion")).higherOrEqual("1.12.0")) {
viewBinding.deleteBranch.setVisibility(View.VISIBLE);
}
if(tinyDB.getString("prMergeable").equals("false")) {
disableProcessButton();
viewBinding.mergeInfoDisabledMessage.setVisibility(View.VISIBLE);
}
else {
viewBinding.mergeInfoDisabledMessage.setVisibility(View.GONE);
}
2020-03-04 20:37:28 +01:00
if(tinyDB.getString("prIsFork").equals("true")) {
viewBinding.deleteBranchForkInfo.setVisibility(View.VISIBLE);
}
else {
viewBinding.deleteBranchForkInfo.setVisibility(View.GONE);
}
2019-11-27 16:09:26 +01:00
if(!connToInternet) {
2019-11-27 16:09:26 +01:00
disableProcessButton();
}
else {
2019-11-27 16:09:26 +01:00
viewBinding.mergeButton.setOnClickListener(mergePullRequest);
}
2019-11-27 16:09:26 +01:00
}
2019-11-27 16:09:26 +01:00
private void setMergeAdapter() {
2019-11-27 16:09:26 +01:00
ArrayList<MergePullRequestSpinner> mergeList = new ArrayList<>();
2019-11-27 16:09:26 +01:00
mergeList.add(new MergePullRequestSpinner("merge", getResources().getString(R.string.mergeOptionMerge)));
mergeList.add(new MergePullRequestSpinner("rebase", getResources().getString(R.string.mergeOptionRebase)));
mergeList.add(new MergePullRequestSpinner("rebase-merge", getResources().getString(R.string.mergeOptionRebaseCommit)));
// squash merge works only on gitea > v1.11.4 due to a bug
if(new Version(tinyDB.getString("giteaVersion")).higher("1.11.4")) {
mergeList.add(new MergePullRequestSpinner("squash", getResources().getString(R.string.mergeOptionSquash)));
}
2019-11-27 16:09:26 +01:00
ArrayAdapter<MergePullRequestSpinner> adapter = new ArrayAdapter<>(MergePullRequestActivity.this, R.layout.list_spinner_items, mergeList);
viewBinding.mergeSpinner.setAdapter(adapter);
2019-11-27 16:09:26 +01:00
viewBinding.mergeSpinner.setOnItemClickListener ((parent, view, position, id) -> {
2019-11-27 16:09:26 +01:00
Do = mergeList.get(position).getId();
});
}
2019-11-27 16:09:26 +01:00
private void initCloseListener() {
2019-11-27 16:09:26 +01:00
onClickListener = view -> finish();
}
2019-11-27 16:09:26 +01:00
private final View.OnClickListener mergePullRequest = v -> processMergePullRequest();
2019-11-27 16:09:26 +01:00
private void processMergePullRequest() {
2019-11-27 16:09:26 +01:00
String mergePRDesc = Objects.requireNonNull(viewBinding.mergeDescription.getText()).toString();
String mergePRTitle = Objects.requireNonNull(viewBinding.mergeTitle.getText()).toString();
boolean deleteBranch = viewBinding.deleteBranch.isChecked();
2019-11-27 16:09:26 +01:00
boolean connToInternet = AppUtil.hasNetworkConnection(appCtx);
2019-11-27 16:09:26 +01:00
if(!connToInternet) {
2019-11-27 16:09:26 +01:00
Toasty.error(ctx, getResources().getString(R.string.checkNetConnection));
return;
}
2019-11-27 16:09:26 +01:00
if(Do == null) {
2019-11-27 16:09:26 +01:00
Toasty.error(ctx, getResources().getString(R.string.selectMergeStrategy));
}
else {
disableProcessButton();
mergeFunction(Do, mergePRDesc, mergePRTitle, deleteBranch);
}
}
2019-11-27 16:09:26 +01:00
private void mergeFunction(String Do, String mergePRDT, String mergeTitle, boolean deleteBranch) {
2019-11-27 16:09:26 +01:00
MergePullRequest mergePR = new MergePullRequest(Do, mergePRDT, mergeTitle);
2019-11-27 16:09:26 +01:00
Call<ResponseBody> call = RetrofitClient.getApiInterface(ctx).mergePullRequest(Authorization.get(ctx), repoOwner, repoName, prIndex, mergePR);
2019-11-27 16:09:26 +01:00
call.enqueue(new Callback<ResponseBody>() {
2019-11-27 16:09:26 +01:00
@Override
public void onResponse(@NonNull Call<ResponseBody> call, @NonNull retrofit2.Response<ResponseBody> response) {
2019-11-27 16:09:26 +01:00
if(response.code() == 200) {
2019-11-27 16:09:26 +01:00
if(deleteBranch) {
if(tinyDB.getString("prIsFork").equals("true")) {
String repoFullName = tinyDB.getString("prForkFullName");
String[] parts = repoFullName.split("/");
final String repoOwner = parts[0];
final String repoName = parts[1];
deleteBranchFunction(repoOwner, repoName);
Toasty.success(ctx, getString(R.string.mergePRSuccessMsg));
tinyDB.putBoolean("prMerged", true);
tinyDB.putBoolean("resumePullRequests", true);
finish();
}
else {
String repoFullName = tinyDB.getString("repoFullName");
String[] parts = repoFullName.split("/");
final String repoOwner = parts[0];
final String repoName = parts[1];
deleteBranchFunction(repoOwner, repoName);
Toasty.success(ctx, getString(R.string.mergePRSuccessMsg));
tinyDB.putBoolean("prMerged", true);
tinyDB.putBoolean("resumePullRequests", true);
finish();
}
}
else {
Toasty.success(ctx, getString(R.string.mergePRSuccessMsg));
tinyDB.putBoolean("prMerged", true);
tinyDB.putBoolean("resumePullRequests", true);
finish();
}
2019-11-27 16:09:26 +01:00
}
else if(response.code() == 401) {
2019-11-27 16:09:26 +01:00
enableProcessButton();
AlertDialogs.authorizationTokenRevokedDialog(ctx, getResources().getString(R.string.alertDialogTokenRevokedTitle), getResources().getString(R.string.alertDialogTokenRevokedMessage), getResources().getString(R.string.alertDialogTokenRevokedCopyNegativeButton), getResources().getString(R.string.alertDialogTokenRevokedCopyPositiveButton));
}
else if(response.code() == 404) {
2019-11-27 16:09:26 +01:00
enableProcessButton();
Toasty.warning(ctx, getString(R.string.mergePR404ErrorMsg));
}
else if(response.code() == 405) {
enableProcessButton();
Toasty.warning(ctx, getString(R.string.mergeNotAllowed));;
}
else {
2019-11-27 16:09:26 +01:00
enableProcessButton();
Toasty.error(ctx, getString(R.string.genericError));
}
2019-11-27 16:09:26 +01:00
}
2019-11-27 16:09:26 +01:00
@Override
public void onFailure(@NonNull Call<ResponseBody> call, @NonNull Throwable t) {
2019-11-27 16:09:26 +01:00
Log.e("onFailure", t.toString());
enableProcessButton();
}
2019-11-27 16:09:26 +01:00
});
2019-11-27 16:09:26 +01:00
}
2019-11-27 16:09:26 +01:00
private void deleteBranchFunction(String repoOwner, String repoName) {
String branchName = tinyDB.getString("prHeadBranch");
Call<JsonElement> call = RetrofitClient
.getApiInterface(ctx)
.deleteBranch(Authorization.get(ctx), repoOwner, repoName, branchName);
call.enqueue(new Callback<JsonElement>() {
@Override
public void onResponse(@NonNull Call<JsonElement> call, @NonNull retrofit2.Response<JsonElement> response) {
if(response.code() == 204) {
Log.i("deleteBranch", "Branch deleted successfully");
}
}
@Override
public void onFailure(@NonNull Call<JsonElement> call, @NonNull Throwable t) {
Log.e("onFailure", t.toString());
enableProcessButton();
}
});
}
private void disableProcessButton() {
2019-11-27 16:09:26 +01:00
viewBinding.mergeButton.setEnabled(false);
}
2019-11-27 16:09:26 +01:00
private void enableProcessButton() {
2019-11-27 16:09:26 +01:00
viewBinding.mergeButton.setEnabled(true);
}
2019-11-27 16:09:26 +01:00
}