From d20a773d1dc7ac249777074927ed297fb416264f Mon Sep 17 00:00:00 2001 From: M M Arif Date: Sun, 27 Sep 2020 09:55:59 +0200 Subject: [PATCH] Extend explore repositories search (#703) Merge branch 'master' into improve-explore-screen improve email address input ui Add filter query actions Add radio buttons improve nav accounts list images Merge branch 'master' into improve-explore-screen # Conflicts: # app/src/main/res/values/strings.xml Implement dialog and use new input layout Co-authored-by: M M Arif Reviewed-on: https://codeberg.org/gitnex/GitNex/pulls/703 --- .../ExploreRepositoriesFragment.java | 137 +++++++++++++++++- .../mian/gitnex/interfaces/ApiInterface.java | 2 +- .../res/layout/activity_profile_email.xml | 43 +++--- .../custom_explore_repositories_dialog.xml | 125 ++++++++++++++++ .../main/res/layout/fragment_explore_repo.xml | 48 ++++-- app/src/main/res/layout/nav_header.xml | 2 +- app/src/main/res/layout/nav_user_accounts.xml | 6 +- app/src/main/res/values/strings.xml | 7 + app/src/main/res/values/themes.xml | 2 +- 9 files changed, 326 insertions(+), 46 deletions(-) create mode 100644 app/src/main/res/layout/custom_explore_repositories_dialog.xml diff --git a/app/src/main/java/org/mian/gitnex/fragments/ExploreRepositoriesFragment.java b/app/src/main/java/org/mian/gitnex/fragments/ExploreRepositoriesFragment.java index dc354883..b883b583 100644 --- a/app/src/main/java/org/mian/gitnex/fragments/ExploreRepositoriesFragment.java +++ b/app/src/main/java/org/mian/gitnex/fragments/ExploreRepositoriesFragment.java @@ -1,10 +1,16 @@ package org.mian.gitnex.fragments; +import android.app.Dialog; import android.content.Context; +import android.graphics.Color; +import android.graphics.drawable.ColorDrawable; import android.net.Uri; import android.os.Bundle; import android.util.Log; import android.view.LayoutInflater; +import android.view.Menu; +import android.view.MenuInflater; +import android.view.MenuItem; import android.view.View; import android.view.ViewGroup; import android.view.inputmethod.EditorInfo; @@ -18,6 +24,7 @@ import androidx.recyclerview.widget.RecyclerView; import org.mian.gitnex.R; import org.mian.gitnex.adapters.ExploreRepositoriesAdapter; import org.mian.gitnex.clients.RetrofitClient; +import org.mian.gitnex.databinding.CustomExploreRepositoriesDialogBinding; import org.mian.gitnex.helpers.Authorization; import org.mian.gitnex.helpers.TinyDB; import org.mian.gitnex.models.ExploreRepositories; @@ -29,12 +36,14 @@ import retrofit2.Callback; import retrofit2.Response; /** - * Template Author Author M M Arif + * Template Author M M Arif * Author 6543 */ public class ExploreRepositoriesFragment extends Fragment { + private Context ctx; + private TinyDB tinyDb; private static String repoNameF = "param2"; private static String repoOwnerF = "param1"; private ProgressBar mProgressBar; @@ -48,6 +57,9 @@ public class ExploreRepositoriesFragment extends Fragment { private OnFragmentInteractionListener mListener; + private Dialog dialogFilterOptions; + private CustomExploreRepositoriesDialogBinding filterBinding; + public ExploreRepositoriesFragment() { } @@ -76,13 +88,20 @@ public class ExploreRepositoriesFragment extends Fragment { public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { final View v = inflater.inflate(R.layout.fragment_explore_repo, container, false); - //setHasOptionsMenu(true); + setHasOptionsMenu(true); + ctx = getContext(); - TinyDB tinyDb = new TinyDB(getContext()); + tinyDb = new TinyDB(getContext()); final String instanceUrl = tinyDb.getString("instanceUrl"); final String loginUid = tinyDb.getString("loginUid"); final String instanceToken = "token " + tinyDb.getString(loginUid + "-token"); + tinyDb.putBoolean("exploreRepoIncludeTopic", false); + tinyDb.putBoolean("exploreRepoIncludeDescription", false); + tinyDb.putBoolean("exploreRepoIncludeTemplate", false); + tinyDb.putBoolean("exploreRepoOnlyArchived", false); + tinyDb.putBoolean("exploreRepoOnlyPrivate", false); + searchKeyword = v.findViewById(R.id.searchKeyword); noData = v.findViewById(R.id.noData); mProgressBar = v.findViewById(R.id.progress_bar); @@ -96,7 +115,7 @@ public class ExploreRepositoriesFragment extends Fragment { if(!searchKeyword.getText().toString().equals("")) { mProgressBar.setVisibility(View.VISIBLE); mRecyclerView.setVisibility(View.GONE); - loadSearchReposList(instanceUrl, instanceToken, loginUid, searchKeyword.getText().toString(), repoTypeInclude, sort, order, getContext(), limit); + loadSearchReposList(instanceUrl, instanceToken, loginUid, searchKeyword.getText().toString(), repoTypeInclude, sort, order, getContext(), tinyDb.getBoolean("exploreRepoIncludeTopic"), tinyDb.getBoolean("exploreRepoIncludeDescription"), tinyDb.getBoolean("exploreRepoIncludeTemplate"), tinyDb.getBoolean("exploreRepoOnlyArchived"), tinyDb.getBoolean("exploreRepoOnlyPrivate"), limit); } } return false; @@ -111,7 +130,7 @@ public class ExploreRepositoriesFragment extends Fragment { private void loadDefaultList(String instanceUrl, String instanceToken, String loginUid, Boolean repoTypeInclude, String sort, String order, final Context context, int limit) { - Call call = RetrofitClient.getInstance(instanceUrl, getContext()).getApiInterface().queryRepos(Authorization.returnAuthentication(getContext(), loginUid, instanceToken), null, repoTypeInclude, sort, order, limit); + Call call = RetrofitClient.getInstance(instanceUrl, getContext()).getApiInterface().queryRepos(Authorization.returnAuthentication(getContext(), loginUid, instanceToken), null, repoTypeInclude, sort, order, tinyDb.getBoolean("exploreRepoIncludeTopic"), tinyDb.getBoolean("exploreRepoIncludeDescription"), tinyDb.getBoolean("exploreRepoIncludeTemplate"), tinyDb.getBoolean("exploreRepoOnlyArchived"), tinyDb.getBoolean("exploreRepoOnlyPrivate"), limit); call.enqueue(new Callback() { @@ -138,9 +157,9 @@ public class ExploreRepositoriesFragment extends Fragment { } - private void loadSearchReposList(String instanceUrl, String instanceToken, String loginUid, String searchKeyword, Boolean repoTypeInclude, String sort, String order, final Context context, int limit) { + private void loadSearchReposList(String instanceUrl, String instanceToken, String loginUid, String searchKeyword, Boolean repoTypeInclude, String sort, String order, final Context context, boolean topic, boolean includeDesc, boolean template, boolean onlyArchived, boolean onlyPrivate, int limit) { - Call call = RetrofitClient.getInstance(instanceUrl, getContext()).getApiInterface().queryRepos(Authorization.returnAuthentication(getContext(), loginUid, instanceToken), searchKeyword, repoTypeInclude, sort, order, limit); + Call call = RetrofitClient.getInstance(instanceUrl, getContext()).getApiInterface().queryRepos(Authorization.returnAuthentication(getContext(), loginUid, instanceToken), searchKeyword, repoTypeInclude, sort, order, topic, includeDesc, template, onlyArchived, onlyPrivate, limit); call.enqueue(new Callback() { @@ -194,6 +213,110 @@ public class ExploreRepositoriesFragment extends Fragment { } + @Override + public void onCreateOptionsMenu(@NonNull Menu menu, @NonNull MenuInflater inflater) { + + menu.clear(); + inflater.inflate(R.menu.filter_menu, menu); + super.onCreateOptionsMenu(menu, inflater); + + MenuItem filter = menu.findItem(R.id.filter); + + filter.setOnMenuItemClickListener(filter_ -> { + + showFilterOptions(); + return false; + }); + + } + + private void showFilterOptions() { + + dialogFilterOptions = new Dialog(ctx, R.style.ThemeOverlay_MaterialComponents_Dialog_Alert); + + if (dialogFilterOptions.getWindow() != null) { + + dialogFilterOptions.getWindow().setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT)); + } + + filterBinding = CustomExploreRepositoriesDialogBinding.inflate(LayoutInflater.from(ctx)); + + View view = filterBinding.getRoot(); + dialogFilterOptions.setContentView(view); + + filterBinding.includeTopic.setOnClickListener(includeTopic -> { + + if(filterBinding.includeTopic.isChecked()) { + + tinyDb.putBoolean("exploreRepoIncludeTopic", true); + } + else { + + tinyDb.putBoolean("exploreRepoIncludeTopic", false); + } + }); + + filterBinding.includeDesc.setOnClickListener(includeDesc -> { + + if(filterBinding.includeDesc.isChecked()) { + + tinyDb.putBoolean("exploreRepoIncludeDescription", true); + } + else { + + tinyDb.putBoolean("exploreRepoIncludeDescription", false); + } + }); + + filterBinding.includeTemplate.setOnClickListener(includeTemplate -> { + + if(filterBinding.includeTemplate.isChecked()) { + + tinyDb.putBoolean("exploreRepoIncludeTemplate", true); + } + else { + + tinyDb.putBoolean("exploreRepoIncludeTemplate", false); + } + }); + + filterBinding.onlyArchived.setOnClickListener(onlyArchived -> { + + if(filterBinding.onlyArchived.isChecked()) { + + tinyDb.putBoolean("exploreRepoOnlyArchived", true); + } + else { + + tinyDb.putBoolean("exploreRepoOnlyArchived", false); + } + }); + + filterBinding.onlyPrivate.setOnClickListener(onlyPrivate -> { + + if(filterBinding.onlyPrivate.isChecked()) { + + tinyDb.putBoolean("exploreRepoOnlyPrivate", true); + } + else { + + tinyDb.putBoolean("exploreRepoOnlyPrivate", false); + } + }); + + filterBinding.includeTopic.setChecked(tinyDb.getBoolean("exploreRepoIncludeTopic")); + filterBinding.includeDesc.setChecked(tinyDb.getBoolean("exploreRepoIncludeDescription")); + filterBinding.includeTemplate.setChecked(tinyDb.getBoolean("exploreRepoIncludeTemplate")); + filterBinding.onlyArchived.setChecked(tinyDb.getBoolean("exploreRepoOnlyArchived")); + filterBinding.onlyPrivate.setChecked(tinyDb.getBoolean("exploreRepoOnlyPrivate")); + + filterBinding.cancel.setOnClickListener(editProperties -> { + dialogFilterOptions.dismiss(); + }); + + dialogFilterOptions.show(); + } + public void onButtonPressed(Uri uri) { if(mListener != null) { diff --git a/app/src/main/java/org/mian/gitnex/interfaces/ApiInterface.java b/app/src/main/java/org/mian/gitnex/interfaces/ApiInterface.java index 460b2cea..379cbf8f 100644 --- a/app/src/main/java/org/mian/gitnex/interfaces/ApiInterface.java +++ b/app/src/main/java/org/mian/gitnex/interfaces/ApiInterface.java @@ -266,7 +266,7 @@ public interface ApiInterface { Call> getRepoWatchers(@Header("Authorization") String token, @Path("owner") String ownerName, @Path("repo") String repoName); @GET("repos/search") // get all the repos which match the query string - Call queryRepos(@Header("Authorization") String token, @Query("q") String searchKeyword, @Query("private") Boolean repoTypeInclude, @Query("sort") String sort, @Query("order") String order, @Query("limit") int limit); + Call queryRepos(@Header("Authorization") String token, @Query("q") String searchKeyword, @Query("private") Boolean repoTypeInclude, @Query("sort") String sort, @Query("order") String order, @Query("topic") boolean topic, @Query("includeDesc") boolean includeDesc, @Query("template") boolean template, @Query("archived") boolean archived, @Query("is_private") boolean is_private, @Query("limit") int limit); @POST("repos/{owner}/{repo}/contents/{file}") // create new file Call createNewFile(@Header("Authorization") String token, @Path("owner") String ownerName, @Path("repo") String repoName, @Path("file") String fileName, @Body NewFile jsonStr); diff --git a/app/src/main/res/layout/activity_profile_email.xml b/app/src/main/res/layout/activity_profile_email.xml index 1a5287b9..36a60dce 100644 --- a/app/src/main/res/layout/activity_profile_email.xml +++ b/app/src/main/res/layout/activity_profile_email.xml @@ -1,8 +1,8 @@ - @@ -50,27 +50,30 @@ android:padding="16dp" android:orientation="vertical"> - - - + app:hintTextColor="?attr/hintColor" + app:boxStrokeErrorColor="@color/darkRed" + android:layout_marginTop="8dp" + android:layout_marginBottom="8dp" + app:endIconMode="clear_text" + app:endIconTint="?attr/iconsColor" + android:hint="@string/profileEmailTitle"> + + + +