From 74669a9dcba6082006e6aa68a9a9051057038b73 Mon Sep 17 00:00:00 2001 From: M M Arif Date: Wed, 30 Sep 2020 16:53:31 +0200 Subject: [PATCH] Enhance explore repos (#715) Enhance explore repos Co-authored-by: M M Arif Reviewed-on: https://codeberg.org/gitnex/GitNex/pulls/715 --- .../adapters/ExploreRepositoriesAdapter.java | 5 + .../ExploreRepositoriesFragment.java | 280 +++++++++--------- .../fragments/SearchIssuesFragment.java | 2 - .../mian/gitnex/interfaces/ApiInterface.java | 2 +- .../custom_explore_repositories_dialog.xml | 9 - .../main/res/layout/fragment_explore_repo.xml | 27 +- 6 files changed, 167 insertions(+), 158 deletions(-) diff --git a/app/src/main/java/org/mian/gitnex/adapters/ExploreRepositoriesAdapter.java b/app/src/main/java/org/mian/gitnex/adapters/ExploreRepositoriesAdapter.java index 5cc2e917..92be07df 100644 --- a/app/src/main/java/org/mian/gitnex/adapters/ExploreRepositoriesAdapter.java +++ b/app/src/main/java/org/mian/gitnex/adapters/ExploreRepositoriesAdapter.java @@ -318,4 +318,9 @@ public class ExploreRepositoriesAdapter extends RecyclerView.Adapter dataList; + private ExploreRepositoriesAdapter adapter; - private OnFragmentInteractionListener mListener; + private String instanceUrl; + private String loginUid; + private String instanceToken; private Dialog dialogFilterOptions; private CustomExploreRepositoriesDialogBinding filterBinding; - public ExploreRepositoriesFragment() { - - } - - public static ExploreRepositoriesFragment newInstance(String param1, String param2) { - - ExploreRepositoriesFragment fragment = new ExploreRepositoriesFragment(); - Bundle args = new Bundle(); - args.putString(repoOwnerF, param1); - args.putString(repoNameF, param2); - fragment.setArguments(args); - return fragment; - } - - @Override - public void onCreate(Bundle savedInstanceState) { - - super.onCreate(savedInstanceState); - if(getArguments() != null) { - String repoName = getArguments().getString(repoNameF); - String repoOwner = getArguments().getString(repoOwnerF); - } - } - @Override public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { - final View v = inflater.inflate(R.layout.fragment_explore_repo, container, false); + viewBinding = FragmentExploreRepoBinding.inflate(inflater, container, false); setHasOptionsMenu(true); - ctx = getContext(); + ctx = 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"); + + instanceUrl = tinyDb.getString("instanceUrl"); + loginUid = tinyDb.getString("loginUid"); + instanceToken = "token " + tinyDb.getString(loginUid + "-token"); + + dataList = new ArrayList<>(); + adapter = new ExploreRepositoriesAdapter(dataList, ctx); 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); - mRecyclerView = v.findViewById(R.id.recyclerViewReposSearch); + // if gitea is 1.12 or higher use the new limit + if(new Version(tinyDb.getString("giteaVersion")).higherOrEqual("1.12.0")) { + limit = StaticGlobalVariables.resultLimitNewGiteaInstances; + } - mProgressBar.setVisibility(View.VISIBLE); + LinearLayoutManager linearLayoutManager = new LinearLayoutManager(ctx); - searchKeyword.setOnEditorActionListener((v1, actionId, event) -> { + viewBinding.recyclerViewReposSearch.setHasFixedSize(true); + viewBinding.recyclerViewReposSearch.setLayoutManager(linearLayoutManager); + viewBinding.recyclerViewReposSearch.setAdapter(adapter); + + viewBinding.searchKeyword.setOnEditorActionListener((v1, actionId, event) -> { if(actionId == EditorInfo.IME_ACTION_SEND) { - if(!searchKeyword.getText().toString().equals("")) { - mProgressBar.setVisibility(View.VISIBLE); - mRecyclerView.setVisibility(View.GONE); - 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); + + if(!Objects.requireNonNull(viewBinding.searchKeyword.getText()).toString().equals("")) { + + InputMethodManager imm = (InputMethodManager) requireActivity().getSystemService(Context.INPUT_METHOD_SERVICE); + imm.hideSoftInputFromWindow(viewBinding.searchKeyword.getWindowToken(), 0); + + // if gitea is 1.12 or higher use the new limit + if(new Version(tinyDb.getString("giteaVersion")).higherOrEqual("1.12.0")) { + limit = StaticGlobalVariables.resultLimitNewGiteaInstances; + } + else { + limit = 10; + } + + pageCurrentIndex = 1; + viewBinding.progressBar.setVisibility(View.VISIBLE); + loadData(false, viewBinding.searchKeyword.getText().toString(), tinyDb.getBoolean("exploreRepoIncludeTopic"), tinyDb.getBoolean("exploreRepoIncludeDescription"), tinyDb.getBoolean("exploreRepoIncludeTemplate"), tinyDb.getBoolean("exploreRepoOnlyArchived")); } } return false; }); - int limitDefault = 25; - loadDefaultList(instanceUrl, instanceToken, loginUid, repoTypeInclude, sort, order, getContext(), limitDefault); - - return v; - - } - - 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, tinyDb.getBoolean("exploreRepoIncludeTopic"), tinyDb.getBoolean("exploreRepoIncludeDescription"), tinyDb.getBoolean("exploreRepoIncludeTemplate"), tinyDb.getBoolean("exploreRepoOnlyArchived"), tinyDb.getBoolean("exploreRepoOnlyPrivate"), limit); - - call.enqueue(new Callback() { + viewBinding.recyclerViewReposSearch.addOnScrollListener(new InfiniteScrollListener(pageCurrentIndex, linearLayoutManager) { @Override - public void onResponse(@NonNull Call call, @NonNull Response response) { - - if(response.isSuccessful()) { - assert response.body() != null; - getReposList(response.body().getSearchedData(), context); - } - else { - Log.i("onResponse", String.valueOf(response.code())); - } + public void onScrolledToEnd(int firstVisibleItemPosition) { + pageCurrentIndex++; + loadData(true, Objects.requireNonNull(viewBinding.searchKeyword.getText()).toString(), tinyDb.getBoolean("exploreRepoIncludeTopic"), tinyDb.getBoolean("exploreRepoIncludeDescription"), tinyDb.getBoolean("exploreRepoIncludeTemplate"), tinyDb.getBoolean("exploreRepoOnlyArchived")); } - - @Override - public void onFailure(@NonNull Call call, @NonNull Throwable t) { - - Log.i("onFailure", Objects.requireNonNull(t.getMessage())); - } - }); - } + viewBinding.pullToRefresh.setOnRefreshListener(() -> { - 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, topic, includeDesc, template, onlyArchived, onlyPrivate, limit); - - call.enqueue(new Callback() { - - @Override - public void onResponse(@NonNull Call call, @NonNull Response response) { - - if(response.isSuccessful()) { - assert response.body() != null; - getReposList(response.body().getSearchedData(), context); - } - else { - Log.i("onResponse", String.valueOf(response.code())); - } + pageCurrentIndex = 1; + // if gitea is 1.12 or higher use the new limit + if(new Version(tinyDb.getString("giteaVersion")).higherOrEqual("1.12.0")) { + limit = StaticGlobalVariables.resultLimitNewGiteaInstances; + } + else { + limit = 10; } - @Override - public void onFailure(@NonNull Call call, @NonNull Throwable t) { - - Log.i("onFailure", Objects.requireNonNull(t.getMessage())); - } - + loadData(false, Objects.requireNonNull(viewBinding.searchKeyword.getText()).toString(), tinyDb.getBoolean("exploreRepoIncludeTopic"), tinyDb.getBoolean("exploreRepoIncludeDescription"), tinyDb.getBoolean("exploreRepoIncludeTemplate"), tinyDb.getBoolean("exploreRepoOnlyArchived")); }); + loadData(false, "", tinyDb.getBoolean("exploreRepoIncludeTopic"), tinyDb.getBoolean("exploreRepoIncludeDescription"), tinyDb.getBoolean("exploreRepoIncludeTemplate"), tinyDb.getBoolean("exploreRepoOnlyArchived")); + + return viewBinding.getRoot(); + } - private void getReposList(List dataList, Context context) { + private void loadData(boolean append, String searchKeyword, boolean exploreRepoIncludeTopic, boolean exploreRepoIncludeDescription, boolean exploreRepoIncludeTemplate, boolean exploreRepoOnlyArchived) { - ExploreRepositoriesAdapter adapter = new ExploreRepositoriesAdapter(dataList, context); + viewBinding.noData.setVisibility(View.GONE); - mRecyclerView.setVisibility(View.VISIBLE); + int apiCallDefaultLimit = 10; + // if gitea is 1.12 or higher use the new limit + if(new Version(tinyDb.getString("giteaVersion")).higherOrEqual("1.12.0")) { + apiCallDefaultLimit = StaticGlobalVariables.resultLimitNewGiteaInstances; + } - mRecyclerView.setHasFixedSize(true); - mRecyclerView.setLayoutManager(new LinearLayoutManager(getContext())); - DividerItemDecoration dividerItemDecoration = new DividerItemDecoration(mRecyclerView.getContext(), DividerItemDecoration.VERTICAL); - mRecyclerView.addItemDecoration(dividerItemDecoration); + if(apiCallDefaultLimit > limit) { + return; + } - if(adapter.getItemCount() > 0) { - - mRecyclerView.setAdapter(adapter); - noData.setVisibility(View.GONE); - mProgressBar.setVisibility(View.GONE); + if(pageCurrentIndex == 1 || !append) { + dataList.clear(); + adapter.notifyDataSetChanged(); + viewBinding.pullToRefresh.setRefreshing(false); + viewBinding.progressBar.setVisibility(View.VISIBLE); } else { - noData.setVisibility(View.VISIBLE); - mProgressBar.setVisibility(View.GONE); - + viewBinding.loadingMoreView.setVisibility(View.VISIBLE); } + Call call = RetrofitClient.getInstance(instanceUrl, getContext()).getApiInterface().queryRepos(Authorization.returnAuthentication(getContext(), loginUid, instanceToken), searchKeyword, repoTypeInclude, sort, order, exploreRepoIncludeTopic, exploreRepoIncludeDescription, exploreRepoIncludeTemplate, exploreRepoOnlyArchived, limit, pageCurrentIndex); + + call.enqueue(new Callback() { + + @Override + public void onResponse(@NonNull Call call, @NonNull Response response) { + + if(response.code() == 200) { + + assert response.body() != null; + + limit = response.body().getSearchedData().size(); + + Log.e("exploreRepos", String.valueOf(limit)); + + if(!append) { + + dataList.clear(); + } + + dataList.addAll(response.body().getSearchedData()); + adapter.notifyDataSetChanged(); + + } + else { + + dataList.clear(); + adapter.notifyDataChanged(); + viewBinding.noData.setVisibility(View.VISIBLE); + + } + + onCleanup(); + + } + + @Override + public void onFailure(@NonNull Call call, @NonNull Throwable t) { + + Log.e("onFailure", Objects.requireNonNull(t.getMessage())); + onCleanup(); + + } + + private void onCleanup() { + + AppUtil.setMultiVisibility(View.GONE, viewBinding.loadingMoreView, viewBinding.progressBar); + + if(dataList.isEmpty()) { + + viewBinding.noData.setVisibility(View.VISIBLE); + } + } + }); } @Override @@ -292,23 +313,11 @@ public class ExploreRepositoriesFragment extends Fragment { } }); - 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(); @@ -317,24 +326,15 @@ public class ExploreRepositoriesFragment extends Fragment { dialogFilterOptions.show(); } - public void onButtonPressed(Uri uri) { - - if(mListener != null) { - mListener.onFragmentInteraction(uri); - } - } - @Override public void onDetach() { super.onDetach(); - mListener = null; } public interface OnFragmentInteractionListener { void onFragmentInteraction(Uri uri); - } } diff --git a/app/src/main/java/org/mian/gitnex/fragments/SearchIssuesFragment.java b/app/src/main/java/org/mian/gitnex/fragments/SearchIssuesFragment.java index 72ba3582..5bb77e07 100644 --- a/app/src/main/java/org/mian/gitnex/fragments/SearchIssuesFragment.java +++ b/app/src/main/java/org/mian/gitnex/fragments/SearchIssuesFragment.java @@ -146,8 +146,6 @@ public class SearchIssuesFragment extends Fragment { assert response.body() != null; apiCallCurrentValue = response.body().size(); - Log.e("searchIssues", String.valueOf(apiCallCurrentValue)); - if(!append) { dataList.clear(); 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 78acb25e..dcf3ab38 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("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); + 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("limit") int limit, @Query("page") int page); @GET("repos/issues/search") // get all the issues which match the query string Call> queryIssues(@Header("Authorization") String token, @Query("q") String searchKeyword, @Query("type") String type, @Query("state") String state, @Query("page") int page); diff --git a/app/src/main/res/layout/custom_explore_repositories_dialog.xml b/app/src/main/res/layout/custom_explore_repositories_dialog.xml index aa060b26..dfa28018 100644 --- a/app/src/main/res/layout/custom_explore_repositories_dialog.xml +++ b/app/src/main/res/layout/custom_explore_repositories_dialog.xml @@ -81,15 +81,6 @@ android:text="@string/exploreFilterIncludeArchive" android:textSize="16sp" /> - - diff --git a/app/src/main/res/layout/fragment_explore_repo.xml b/app/src/main/res/layout/fragment_explore_repo.xml index 1c005b5c..94235585 100644 --- a/app/src/main/res/layout/fragment_explore_repo.xml +++ b/app/src/main/res/layout/fragment_explore_repo.xml @@ -7,7 +7,15 @@ android:orientation="vertical"> + + - + android:layout_height="match_parent"> + + + +