Extend Merge Options (#217)
Merge branch 'master' into extend-merge-dialog Minor fixes format ? an AndroidStudio suggestion ? Signed-off-by: 6543 <6543@obermui.de> add Title Text and some Fixes add version check Merge branch 'master' into extend-merge-dialog Merge branch 'master' into extend-merge-dialog use translation and revormat make Merge Options Translateble gitea locale revs: * pulls.merge_pull_request * pulls.rebase_merge_pull_request * pulls.rebase_merge_commit_pull_request * pulls.squash_merge_pull_request Fix menu item Make merge options work Merge branch 'master' into merge-options work - but UGLY UI use enum for merge-modes Co-authored-by: M M Arif <mmarif@swatian.com> Co-authored-by: 6543 <6543@obermui.de> Reviewed-on: https://gitea.com/gitnex/GitNex/pulls/217
This commit is contained in:
@ -1,16 +1,20 @@
|
|||||||
package org.mian.gitnex.activities;
|
package org.mian.gitnex.activities;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import android.annotation.SuppressLint;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.drawable.GradientDrawable;
|
import android.graphics.drawable.GradientDrawable;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.inputmethod.InputMethodManager;
|
import android.view.inputmethod.InputMethodManager;
|
||||||
|
import android.widget.AdapterView;
|
||||||
import android.widget.ArrayAdapter;
|
import android.widget.ArrayAdapter;
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
|
import android.widget.EditText;
|
||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
|
import android.widget.Spinner;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
import com.hendraanggrian.appcompat.socialview.Mention;
|
import com.hendraanggrian.appcompat.socialview.Mention;
|
||||||
import com.hendraanggrian.appcompat.widget.MentionArrayAdapter;
|
import com.hendraanggrian.appcompat.widget.MentionArrayAdapter;
|
||||||
import com.hendraanggrian.appcompat.widget.SocialAutoCompleteTextView;
|
import com.hendraanggrian.appcompat.widget.SocialAutoCompleteTextView;
|
||||||
@ -19,10 +23,13 @@ import org.mian.gitnex.clients.RetrofitClient;
|
|||||||
import org.mian.gitnex.helpers.AlertDialogs;
|
import org.mian.gitnex.helpers.AlertDialogs;
|
||||||
import org.mian.gitnex.helpers.Authorization;
|
import org.mian.gitnex.helpers.Authorization;
|
||||||
import org.mian.gitnex.helpers.Toasty;
|
import org.mian.gitnex.helpers.Toasty;
|
||||||
|
import org.mian.gitnex.helpers.VersionCheck;
|
||||||
import org.mian.gitnex.models.Collaborators;
|
import org.mian.gitnex.models.Collaborators;
|
||||||
import org.mian.gitnex.models.MergePullRequest;
|
import org.mian.gitnex.models.MergePullRequest;
|
||||||
|
import org.mian.gitnex.models.MergePullRequestSpinner;
|
||||||
import org.mian.gitnex.util.AppUtil;
|
import org.mian.gitnex.util.AppUtil;
|
||||||
import org.mian.gitnex.util.TinyDB;
|
import org.mian.gitnex.util.TinyDB;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import okhttp3.ResponseBody;
|
import okhttp3.ResponseBody;
|
||||||
import retrofit2.Call;
|
import retrofit2.Call;
|
||||||
@ -40,17 +47,23 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
|
|
||||||
final Context ctx = this;
|
final Context ctx = this;
|
||||||
|
|
||||||
private SocialAutoCompleteTextView mergePR;
|
private SocialAutoCompleteTextView mergeDescription;
|
||||||
|
private EditText mergeTitle;
|
||||||
|
private Spinner mergeModeSpinner;
|
||||||
private ArrayAdapter<Mention> defaultMentionAdapter;
|
private ArrayAdapter<Mention> defaultMentionAdapter;
|
||||||
private Button mergeButton;
|
private Button mergeButton;
|
||||||
|
private String Do;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected int getLayoutResourceId() {
|
protected int getLayoutResourceId() {
|
||||||
|
|
||||||
return R.layout.activity_merge_pull_request;
|
return R.layout.activity_merge_pull_request;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SuppressLint("SetTextI18n")
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
|
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
boolean connToInternet = AppUtil.haveNetworkConnection(getApplicationContext());
|
boolean connToInternet = AppUtil.haveNetworkConnection(getApplicationContext());
|
||||||
@ -58,23 +71,44 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
|
|
||||||
InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
|
InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
|
||||||
|
|
||||||
mergePR = findViewById(R.id.mergePR);
|
mergeModeSpinner = findViewById(R.id.mergeSpinner);
|
||||||
mergePR.setShowSoftInputOnFocus(true);
|
mergeDescription = findViewById(R.id.mergeDescription);
|
||||||
|
mergeTitle = findViewById(R.id.mergeTitle);
|
||||||
|
|
||||||
mergePR.requestFocus();
|
mergeTitle.requestFocus();
|
||||||
assert imm != null;
|
assert imm != null;
|
||||||
imm.showSoftInput(mergePR, InputMethodManager.SHOW_IMPLICIT);
|
imm.showSoftInput(mergeTitle, InputMethodManager.SHOW_IMPLICIT);
|
||||||
|
|
||||||
|
setMergeAdapter();
|
||||||
|
|
||||||
|
mergeModeSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
|
||||||
|
|
||||||
|
MergePullRequestSpinner mergeId = (MergePullRequestSpinner) parent.getSelectedItem();
|
||||||
|
Do = mergeId.getId();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onNothingSelected(AdapterView<?> parent) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
defaultMentionAdapter = new MentionArrayAdapter<>(this);
|
defaultMentionAdapter = new MentionArrayAdapter<>(this);
|
||||||
loadCollaboratorsList();
|
loadCollaboratorsList();
|
||||||
|
|
||||||
mergePR.setMentionAdapter(defaultMentionAdapter);
|
mergeDescription.setMentionAdapter(defaultMentionAdapter);
|
||||||
|
|
||||||
closeActivity = findViewById(R.id.close);
|
closeActivity = findViewById(R.id.close);
|
||||||
TextView toolbar_title = findViewById(R.id.toolbar_title);
|
TextView toolbar_title = findViewById(R.id.toolbar_title);
|
||||||
|
|
||||||
if(!tinyDb.getString("issueTitle").isEmpty()) {
|
if(!tinyDb.getString("issueTitle").isEmpty()) {
|
||||||
toolbar_title.setText(tinyDb.getString("issueTitle"));
|
toolbar_title.setText(tinyDb.getString("issueTitle"));
|
||||||
|
mergeTitle.setText(tinyDb.getString("issueTitle") + " (#" + tinyDb.getString("issueNumber")+ ")");
|
||||||
}
|
}
|
||||||
|
|
||||||
initCloseListener();
|
initCloseListener();
|
||||||
@ -86,7 +120,8 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
|
|
||||||
disableProcessButton();
|
disableProcessButton();
|
||||||
|
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
|
|
||||||
mergeButton.setOnClickListener(mergePullRequest);
|
mergeButton.setOnClickListener(mergePullRequest);
|
||||||
|
|
||||||
@ -94,6 +129,26 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void setMergeAdapter() {
|
||||||
|
|
||||||
|
TinyDB tinyDb = new TinyDB(getApplicationContext());
|
||||||
|
|
||||||
|
ArrayList<MergePullRequestSpinner> mergeList = new ArrayList<>();
|
||||||
|
|
||||||
|
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.5 and higher due to a bug
|
||||||
|
if(VersionCheck.compareVersion("1.11.5", tinyDb.getString("giteaVersion")) < 1) {
|
||||||
|
mergeList.add(new MergePullRequestSpinner("squash", getResources().getString(R.string.mergeOptionSquash)));
|
||||||
|
}
|
||||||
|
|
||||||
|
ArrayAdapter<MergePullRequestSpinner> adapter = new ArrayAdapter<>(ctx, R.layout.spinner_item, mergeList);
|
||||||
|
adapter.setDropDownViewResource(R.layout.spinner_dropdown_item);
|
||||||
|
mergeModeSpinner.setAdapter(adapter);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public void loadCollaboratorsList() {
|
public void loadCollaboratorsList() {
|
||||||
|
|
||||||
final TinyDB tinyDb = new TinyDB(getApplicationContext());
|
final TinyDB tinyDb = new TinyDB(getApplicationContext());
|
||||||
@ -106,10 +161,7 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
final String repoOwner = parts[0];
|
final String repoOwner = parts[0];
|
||||||
final String repoName = parts[1];
|
final String repoName = parts[1];
|
||||||
|
|
||||||
Call<List<Collaborators>> call = RetrofitClient
|
Call<List<Collaborators>> call = RetrofitClient.getInstance(instanceUrl, getApplicationContext()).getApiInterface().getCollaborators(Authorization.returnAuthentication(getApplicationContext(), loginUid, instanceToken), repoOwner, repoName);
|
||||||
.getInstance(instanceUrl, getApplicationContext())
|
|
||||||
.getApiInterface()
|
|
||||||
.getCollaborators(Authorization.returnAuthentication(getApplicationContext(), loginUid, instanceToken), repoOwner, repoName);
|
|
||||||
|
|
||||||
call.enqueue(new Callback<List<Collaborators>>() {
|
call.enqueue(new Callback<List<Collaborators>>() {
|
||||||
|
|
||||||
@ -124,8 +176,7 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
if(!response.body().get(i).getFull_name().equals("")) {
|
if(!response.body().get(i).getFull_name().equals("")) {
|
||||||
fullName = response.body().get(i).getFull_name();
|
fullName = response.body().get(i).getFull_name();
|
||||||
}
|
}
|
||||||
defaultMentionAdapter.add(
|
defaultMentionAdapter.add(new Mention(response.body().get(i).getUsername(), fullName, response.body().get(i).getAvatar_url()));
|
||||||
new Mention(response.body().get(i).getUsername(), fullName, response.body().get(i).getAvatar_url()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -139,6 +190,7 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onFailure(@NonNull Call<List<Collaborators>> call, @NonNull Throwable t) {
|
public void onFailure(@NonNull Call<List<Collaborators>> call, @NonNull Throwable t) {
|
||||||
|
|
||||||
Log.i("onFailure", t.toString());
|
Log.i("onFailure", t.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -146,23 +198,17 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void initCloseListener() {
|
private void initCloseListener() {
|
||||||
onClickListener = new View.OnClickListener() {
|
|
||||||
@Override
|
onClickListener = view -> finish();
|
||||||
public void onClick(View view) {
|
|
||||||
finish();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private View.OnClickListener mergePullRequest = new View.OnClickListener() {
|
private View.OnClickListener mergePullRequest = v -> processMergePullRequest();
|
||||||
public void onClick(View v) {
|
|
||||||
processMergePullRequest();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private void processMergePullRequest() {
|
private void processMergePullRequest() {
|
||||||
|
|
||||||
String mergePRDT = mergePR.getText().toString();
|
String mergePRDesc = mergeDescription.getText().toString();
|
||||||
|
String mergePRTitle = mergeTitle.getText().toString();
|
||||||
|
|
||||||
boolean connToInternet = AppUtil.haveNetworkConnection(getApplicationContext());
|
boolean connToInternet = AppUtil.haveNetworkConnection(getApplicationContext());
|
||||||
|
|
||||||
if(!connToInternet) {
|
if(!connToInternet) {
|
||||||
@ -173,12 +219,11 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
}
|
}
|
||||||
|
|
||||||
disableProcessButton();
|
disableProcessButton();
|
||||||
String doWhat = "merge";
|
mergeFunction(Do, mergePRDesc, mergePRTitle);
|
||||||
mergeFunction(doWhat, mergePRDT);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void mergeFunction(String doWhat, String mergePRDT) {
|
private void mergeFunction(String Do, String mergePRDT, String mergeTitle) {
|
||||||
|
|
||||||
final TinyDB tinyDb = new TinyDB(getApplicationContext());
|
final TinyDB tinyDb = new TinyDB(getApplicationContext());
|
||||||
|
|
||||||
@ -191,12 +236,9 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
final String repoName = parts[1];
|
final String repoName = parts[1];
|
||||||
final int prIndex = Integer.parseInt(tinyDb.getString("issueNumber"));
|
final int prIndex = Integer.parseInt(tinyDb.getString("issueNumber"));
|
||||||
|
|
||||||
MergePullRequest mergePR = new MergePullRequest(doWhat, mergePRDT, null);
|
MergePullRequest mergePR = new MergePullRequest(Do, mergePRDT, mergeTitle);
|
||||||
|
|
||||||
Call<ResponseBody> call = RetrofitClient
|
Call<ResponseBody> call = RetrofitClient.getInstance(instanceUrl, getApplicationContext()).getApiInterface().mergePullRequest(Authorization.returnAuthentication(getApplicationContext(), loginUid, instanceToken), repoOwner, repoName, prIndex, mergePR);
|
||||||
.getInstance(instanceUrl, getApplicationContext())
|
|
||||||
.getApiInterface()
|
|
||||||
.mergePullRequest(Authorization.returnAuthentication(getApplicationContext(), loginUid, instanceToken), repoOwner, repoName, prIndex, mergePR);
|
|
||||||
|
|
||||||
call.enqueue(new Callback<ResponseBody>() {
|
call.enqueue(new Callback<ResponseBody>() {
|
||||||
|
|
||||||
@ -214,10 +256,7 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
else if(response.code() == 401) {
|
else if(response.code() == 401) {
|
||||||
|
|
||||||
enableProcessButton();
|
enableProcessButton();
|
||||||
AlertDialogs.authorizationTokenRevokedDialog(ctx, getResources().getString(R.string.alertDialogTokenRevokedTitle),
|
AlertDialogs.authorizationTokenRevokedDialog(ctx, getResources().getString(R.string.alertDialogTokenRevokedTitle), getResources().getString(R.string.alertDialogTokenRevokedMessage), getResources().getString(R.string.alertDialogTokenRevokedCopyNegativeButton), getResources().getString(R.string.alertDialogTokenRevokedCopyPositiveButton));
|
||||||
getResources().getString(R.string.alertDialogTokenRevokedMessage),
|
|
||||||
getResources().getString(R.string.alertDialogTokenRevokedCopyNegativeButton),
|
|
||||||
getResources().getString(R.string.alertDialogTokenRevokedCopyPositiveButton));
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else if(response.code() == 404) {
|
else if(response.code() == 404) {
|
||||||
@ -237,6 +276,7 @@ public class MergePullRequestActivity extends BaseActivity {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onFailure(@NonNull Call<ResponseBody> call, @NonNull Throwable t) {
|
public void onFailure(@NonNull Call<ResponseBody> call, @NonNull Throwable t) {
|
||||||
|
|
||||||
Log.e("onFailure", t.toString());
|
Log.e("onFailure", t.toString());
|
||||||
enableProcessButton();
|
enableProcessButton();
|
||||||
}
|
}
|
||||||
|
@ -151,6 +151,7 @@ public class PullRequestsFragment extends Fragment {
|
|||||||
|
|
||||||
loadInitial(Authorization.returnAuthentication(getContext(), loginUid, instanceToken), repoOwner, repoName, pageSize, prState, resultLimit);
|
loadInitial(Authorization.returnAuthentication(getContext(), loginUid, instanceToken), repoOwner, repoName, pageSize, prState, resultLimit);
|
||||||
tinyDb.putBoolean("resumePullRequests", false);
|
tinyDb.putBoolean("resumePullRequests", false);
|
||||||
|
tinyDb.putBoolean("prMerged", false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,9 +11,11 @@ public class MergePullRequest {
|
|||||||
private String MergeTitleField;
|
private String MergeTitleField;
|
||||||
|
|
||||||
public MergePullRequest(String Do, String MergeMessageField, String MergeTitleField) {
|
public MergePullRequest(String Do, String MergeMessageField, String MergeTitleField) {
|
||||||
|
|
||||||
this.Do = Do;
|
this.Do = Do;
|
||||||
this.MergeMessageField = MergeMessageField;
|
this.MergeMessageField = MergeMessageField;
|
||||||
this.MergeTitleField = MergeTitleField;
|
this.MergeTitleField = MergeTitleField;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,55 @@
|
|||||||
|
package org.mian.gitnex.models;
|
||||||
|
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Author M M Arif
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class MergePullRequestSpinner {
|
||||||
|
|
||||||
|
private String id;
|
||||||
|
private String mergerMethod;
|
||||||
|
|
||||||
|
public MergePullRequestSpinner(String id, String mergerMethod) {
|
||||||
|
this.id = id;
|
||||||
|
this.mergerMethod = mergerMethod;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public String getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(String id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getMergerMethod() {
|
||||||
|
return mergerMethod;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(String mergerMethod) {
|
||||||
|
this.mergerMethod = mergerMethod;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NonNull
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return mergerMethod;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
|
||||||
|
if(obj instanceof MergePullRequestSpinner){
|
||||||
|
|
||||||
|
MergePullRequestSpinner spinner = (MergePullRequestSpinner )obj;
|
||||||
|
return spinner.getMergerMethod().equals(mergerMethod) && spinner.getId().equals(id);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -68,32 +68,67 @@
|
|||||||
android:paddingBottom="30dp"
|
android:paddingBottom="30dp"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
||||||
<com.hendraanggrian.appcompat.widget.SocialAutoCompleteTextView
|
<EditText
|
||||||
android:id="@+id/mergePR"
|
android:id="@+id/mergeTitle"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginBottom="20dp"
|
||||||
|
android:padding="10dp"
|
||||||
|
android:textSize="14sp"
|
||||||
|
tools:ignore="Autofill"
|
||||||
|
android:background="@drawable/shape_inputs"
|
||||||
|
android:textColor="?attr/inputTextColor"
|
||||||
|
android:textColorHint="?attr/hintColor"
|
||||||
|
android:textColorHighlight="?attr/primaryTextColor"
|
||||||
|
android:inputType="textCapSentences|text" />
|
||||||
|
|
||||||
|
<com.hendraanggrian.appcompat.widget.SocialAutoCompleteTextView
|
||||||
|
android:id="@+id/mergeDescription"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginBottom="10dp"
|
||||||
android:padding="10dp"
|
android:padding="10dp"
|
||||||
android:completionThreshold="1"
|
android:completionThreshold="1"
|
||||||
android:background="@drawable/shape_inputs"
|
android:background="@drawable/shape_inputs"
|
||||||
android:maxLines="12"
|
android:maxLines="12"
|
||||||
android:minLines="10"
|
android:minLines="10"
|
||||||
tools:ignore="Autofill"
|
tools:ignore="Autofill"
|
||||||
android:labelFor="@+id/mergePR"
|
android:labelFor="@+id/mergeDescription"
|
||||||
android:scrollbars="vertical"
|
android:scrollbars="vertical"
|
||||||
android:gravity="top|start"
|
android:gravity="top|start"
|
||||||
android:textSize="14sp"
|
android:textSize="14sp"
|
||||||
android:textColor="@color/white"
|
android:textColor="?attr/inputTextColor"
|
||||||
android:hint="@string/mergeCommentText"
|
android:hint="@string/mergeCommentText"
|
||||||
android:textColorHint="@color/colorAccent"
|
android:textColorHint="?attr/hintColor"
|
||||||
android:inputType="textCapSentences|textMultiLine"
|
android:inputType="textCapSentences|textMultiLine"
|
||||||
android:textColorHighlight="@color/white" />
|
android:textColorHighlight="?attr/primaryTextColor" />
|
||||||
|
|
||||||
|
<RelativeLayout
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:background="@drawable/shape_dropdown"
|
||||||
|
android:layout_marginTop="10dp"
|
||||||
|
android:layout_marginBottom="10dp" >
|
||||||
|
|
||||||
|
<Spinner
|
||||||
|
android:id="@+id/mergeSpinner"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:spinnerMode="dropdown"
|
||||||
|
android:layout_marginTop="5dp"
|
||||||
|
android:layout_marginBottom="5dp"
|
||||||
|
android:paddingLeft="5dp"
|
||||||
|
android:paddingRight="5dp"
|
||||||
|
android:paddingStart="5dp" />
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/mergeInfo"
|
android:id="@+id/mergeInfo"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="@string/mergeNoteText"
|
android:text="@string/mergeNoteText"
|
||||||
android:textColor="?attr/primaryTextColor"
|
android:textColor="?attr/hintColor"
|
||||||
android:textSize="12sp"
|
android:textSize="12sp"
|
||||||
android:gravity="start"
|
android:gravity="start"
|
||||||
android:layout_marginTop="10dp" />
|
android:layout_marginTop="10dp" />
|
||||||
|
@ -566,6 +566,10 @@
|
|||||||
<string name="mergeCommentText">Merge comment</string>
|
<string name="mergeCommentText">Merge comment</string>
|
||||||
<string name="mergePRSuccessMsg">Pull Request was merged successfully</string>
|
<string name="mergePRSuccessMsg">Pull Request was merged successfully</string>
|
||||||
<string name="mergePR404ErrorMsg">Pull Request is not available for merge</string>
|
<string name="mergePR404ErrorMsg">Pull Request is not available for merge</string>
|
||||||
|
<string name="mergeOptionMerge">Merge Pull Request</string>
|
||||||
|
<string name="mergeOptionRebase">Rebase and Merge</string>
|
||||||
|
<string name="mergeOptionRebaseCommit">Rebase and Merge (--no-ff)</string>
|
||||||
|
<string name="mergeOptionSquash">Squash and Merge</string>
|
||||||
|
|
||||||
<string name="downloadFile">Download This File</string>
|
<string name="downloadFile">Download This File</string>
|
||||||
<string name="waitLoadingDownloadFile">Please wait for the file to load to memory</string>
|
<string name="waitLoadingDownloadFile">Please wait for the file to load to memory</string>
|
||||||
|
Reference in New Issue
Block a user