mirror of
https://codeberg.org/gitnex/GitNex.git
synced 2024-12-16 15:48:13 +08:00
Filter my issues and use remote search (#1091)
Closes #1090 - [x] Filter my issues - [x] Add search to my issues Co-authored-by: M M Arif <mmarif@swatian.com> Reviewed-on: https://codeberg.org/gitnex/GitNex/pulls/1091 Reviewed-by: qwerty287 <qwerty287@noreply.codeberg.org>
This commit is contained in:
parent
1e7a0a20b2
commit
6654ba4abd
@ -76,7 +76,7 @@ Thanks to all the open source libraries, contributors and donators.
|
|||||||
- [noties/Markwon](https://github.com/noties/Markwon)
|
- [noties/Markwon](https://github.com/noties/Markwon)
|
||||||
- [noties/Prism4j](https://github.com/noties/Prism4j)
|
- [noties/Prism4j](https://github.com/noties/Prism4j)
|
||||||
- [ocpsoft/prettytime](https://github.com/ocpsoft/prettytime)
|
- [ocpsoft/prettytime](https://github.com/ocpsoft/prettytime)
|
||||||
- [amulyakhare/TextDrawable](https://github.com/amulyakhare/TextDrawable)
|
- [ramseth001/TextDrawable](https://github.com/ramseth001/TextDrawable)
|
||||||
- [vdurmont/emoji-java](https://github.com/vdurmont/emoji-java)
|
- [vdurmont/emoji-java](https://github.com/vdurmont/emoji-java)
|
||||||
- [Pes8/android-material-color-picker-dialog](https://github.com/Pes8/android-material-color-picker-dialog)
|
- [Pes8/android-material-color-picker-dialog](https://github.com/Pes8/android-material-color-picker-dialog)
|
||||||
- [HamidrezaAmz/BreadcrumbsView](https://github.com/HamidrezaAmz/BreadcrumbsView)
|
- [HamidrezaAmz/BreadcrumbsView](https://github.com/HamidrezaAmz/BreadcrumbsView)
|
||||||
|
@ -71,7 +71,7 @@ dependencies {
|
|||||||
implementation "com.squareup.picasso:picasso:2.71828"
|
implementation "com.squareup.picasso:picasso:2.71828"
|
||||||
implementation 'jp.wasabeef:picasso-transformations:2.4.0'
|
implementation 'jp.wasabeef:picasso-transformations:2.4.0'
|
||||||
implementation 'jp.co.cyberagent.android:gpuimage:2.1.0'
|
implementation 'jp.co.cyberagent.android:gpuimage:2.1.0'
|
||||||
implementation 'com.github.amulyakhare:TextDrawable:558677ea31'
|
implementation 'com.github.ramseth001:TextDrawable:1.1.3'
|
||||||
implementation 'com.squareup.retrofit2:retrofit:2.9.0'
|
implementation 'com.squareup.retrofit2:retrofit:2.9.0'
|
||||||
implementation 'com.squareup.retrofit2:converter-gson:2.9.0'
|
implementation 'com.squareup.retrofit2:converter-gson:2.9.0'
|
||||||
implementation 'com.squareup.retrofit2:converter-scalars:2.9.0'
|
implementation 'com.squareup.retrofit2:converter-scalars:2.9.0'
|
||||||
|
@ -36,6 +36,7 @@ import org.mian.gitnex.database.models.UserAccount;
|
|||||||
import org.mian.gitnex.databinding.ActivityMainBinding;
|
import org.mian.gitnex.databinding.ActivityMainBinding;
|
||||||
import org.mian.gitnex.fragments.AdministrationFragment;
|
import org.mian.gitnex.fragments.AdministrationFragment;
|
||||||
import org.mian.gitnex.fragments.BottomSheetDraftsFragment;
|
import org.mian.gitnex.fragments.BottomSheetDraftsFragment;
|
||||||
|
import org.mian.gitnex.fragments.BottomSheetMyIssuesFilterFragment;
|
||||||
import org.mian.gitnex.fragments.DraftsFragment;
|
import org.mian.gitnex.fragments.DraftsFragment;
|
||||||
import org.mian.gitnex.fragments.ExploreFragment;
|
import org.mian.gitnex.fragments.ExploreFragment;
|
||||||
import org.mian.gitnex.fragments.MyIssuesFragment;
|
import org.mian.gitnex.fragments.MyIssuesFragment;
|
||||||
@ -53,6 +54,7 @@ import org.mian.gitnex.helpers.ColorInverter;
|
|||||||
import org.mian.gitnex.helpers.RoundedTransformation;
|
import org.mian.gitnex.helpers.RoundedTransformation;
|
||||||
import org.mian.gitnex.helpers.Toasty;
|
import org.mian.gitnex.helpers.Toasty;
|
||||||
import org.mian.gitnex.structs.BottomSheetListener;
|
import org.mian.gitnex.structs.BottomSheetListener;
|
||||||
|
import org.mian.gitnex.structs.FragmentRefreshListener;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import jp.wasabeef.picasso.transformations.BlurTransformation;
|
import jp.wasabeef.picasso.transformations.BlurTransformation;
|
||||||
@ -81,6 +83,7 @@ public class MainActivity extends BaseActivity implements NavigationView.OnNavig
|
|||||||
private TextView notificationCounter;
|
private TextView notificationCounter;
|
||||||
|
|
||||||
private BottomSheetListener profileInitListener;
|
private BottomSheetListener profileInitListener;
|
||||||
|
private FragmentRefreshListener fragmentRefreshListenerMyIssues;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
@ -461,8 +464,9 @@ public class MainActivity extends BaseActivity implements NavigationView.OnNavig
|
|||||||
public void onButtonClicked(String text) {
|
public void onButtonClicked(String text) {
|
||||||
int currentActiveAccountId = tinyDB.getInt("currentActiveAccountId");
|
int currentActiveAccountId = tinyDB.getInt("currentActiveAccountId");
|
||||||
|
|
||||||
if("deleteDrafts".equals(text)) {
|
switch(text) {
|
||||||
|
|
||||||
|
case "deleteDrafts":
|
||||||
if(currentActiveAccountId > 0) {
|
if(currentActiveAccountId > 0) {
|
||||||
|
|
||||||
FragmentManager fm = getSupportFragmentManager();
|
FragmentManager fm = getSupportFragmentManager();
|
||||||
@ -493,7 +497,18 @@ public class MainActivity extends BaseActivity implements NavigationView.OnNavig
|
|||||||
|
|
||||||
Toasty.error(ctx, getResources().getString(R.string.genericError));
|
Toasty.error(ctx, getResources().getString(R.string.genericError));
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "openMyIssues":
|
||||||
|
if(getFragmentRefreshListener() != null) {
|
||||||
|
getFragmentRefreshListener().onRefresh("open");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "closedMyIssues":
|
||||||
|
if(getFragmentRefreshListener() != null) {
|
||||||
|
getFragmentRefreshListener().onRefresh("closed");
|
||||||
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -591,6 +606,12 @@ public class MainActivity extends BaseActivity implements NavigationView.OnNavig
|
|||||||
bottomSheet.show(getSupportFragmentManager(), "draftsBottomSheet");
|
bottomSheet.show(getSupportFragmentManager(), "draftsBottomSheet");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
else if(id == R.id.filter) {
|
||||||
|
|
||||||
|
BottomSheetMyIssuesFilterFragment filterBottomSheet = new BottomSheetMyIssuesFilterFragment();
|
||||||
|
filterBottomSheet.show(getSupportFragmentManager(), "myIssuesFilterMenuBottomSheet");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
return super.onOptionsItemSelected(item);
|
return super.onOptionsItemSelected(item);
|
||||||
}
|
}
|
||||||
@ -698,4 +719,7 @@ public class MainActivity extends BaseActivity implements NavigationView.OnNavig
|
|||||||
this.profileInitListener = profileInitListener;
|
this.profileInitListener = profileInitListener;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// My issues-open-close interface
|
||||||
|
public FragmentRefreshListener getFragmentRefreshListener() { return fragmentRefreshListenerMyIssues; }
|
||||||
|
public void setFragmentRefreshListenerMyIssues(FragmentRefreshListener fragmentRefreshListener) { this.fragmentRefreshListenerMyIssues = fragmentRefreshListener; }
|
||||||
}
|
}
|
||||||
|
@ -136,7 +136,7 @@ public class ExploreRepositoriesAdapter extends RecyclerView.Adapter<RecyclerVie
|
|||||||
repoName.setText(userRepositories.getFullName().split("/")[1]);
|
repoName.setText(userRepositories.getFullName().split("/")[1]);
|
||||||
repoStars.setText(userRepositories.getStars_count());
|
repoStars.setText(userRepositories.getStars_count());
|
||||||
|
|
||||||
ColorGenerator generator = ColorGenerator.MATERIAL;
|
ColorGenerator generator = ColorGenerator.Companion.getMATERIAL();
|
||||||
int color = generator.getColor(userRepositories.getName());
|
int color = generator.getColor(userRepositories.getName());
|
||||||
String firstCharacter = String.valueOf(userRepositories.getFullName().charAt(0));
|
String firstCharacter = String.valueOf(userRepositories.getFullName().charAt(0));
|
||||||
|
|
||||||
|
@ -115,7 +115,7 @@ public class RepoForksAdapter extends RecyclerView.Adapter<RecyclerView.ViewHold
|
|||||||
repoName.setText(forksModel.getFullName().split("/")[1]);
|
repoName.setText(forksModel.getFullName().split("/")[1]);
|
||||||
repoStars.setText(forksModel.getStars_count());
|
repoStars.setText(forksModel.getStars_count());
|
||||||
|
|
||||||
ColorGenerator generator = ColorGenerator.MATERIAL;
|
ColorGenerator generator = ColorGenerator.Companion.getMATERIAL();
|
||||||
int color = generator.getColor(forksModel.getName());
|
int color = generator.getColor(forksModel.getName());
|
||||||
String firstCharacter = String.valueOf(forksModel.getFullName().charAt(0));
|
String firstCharacter = String.valueOf(forksModel.getFullName().charAt(0));
|
||||||
|
|
||||||
|
@ -125,7 +125,7 @@ public class ReposListAdapter extends RecyclerView.Adapter<ReposListAdapter.Repo
|
|||||||
holder.repoName.setText(currentItem.getFullName().split("/")[1]);
|
holder.repoName.setText(currentItem.getFullName().split("/")[1]);
|
||||||
holder.repoStars.setText(currentItem.getStars_count());
|
holder.repoStars.setText(currentItem.getStars_count());
|
||||||
|
|
||||||
ColorGenerator generator = ColorGenerator.MATERIAL;
|
ColorGenerator generator = ColorGenerator.Companion.getMATERIAL();
|
||||||
int color = generator.getColor(currentItem.getName());
|
int color = generator.getColor(currentItem.getName());
|
||||||
String firstCharacter = String.valueOf(currentItem.getFullName().charAt(0));
|
String firstCharacter = String.valueOf(currentItem.getFullName().charAt(0));
|
||||||
|
|
||||||
|
@ -125,7 +125,7 @@ public class RepositoriesByOrgAdapter extends RecyclerView.Adapter<RepositoriesB
|
|||||||
holder.repoName.setText(currentItem.getFullName().split("/")[1]);
|
holder.repoName.setText(currentItem.getFullName().split("/")[1]);
|
||||||
holder.repoStars.setText(currentItem.getStars_count());
|
holder.repoStars.setText(currentItem.getStars_count());
|
||||||
|
|
||||||
ColorGenerator generator = ColorGenerator.MATERIAL;
|
ColorGenerator generator = ColorGenerator.Companion.getMATERIAL();
|
||||||
int color = generator.getColor(currentItem.getName());
|
int color = generator.getColor(currentItem.getName());
|
||||||
String firstCharacter = String.valueOf(currentItem.getFullName().charAt(0));
|
String firstCharacter = String.valueOf(currentItem.getFullName().charAt(0));
|
||||||
|
|
||||||
|
@ -136,7 +136,7 @@ public class RepositoriesAdapter extends RecyclerView.Adapter<RecyclerView.ViewH
|
|||||||
repoName.setText(userRepositories.getFullName().split("/")[1]);
|
repoName.setText(userRepositories.getFullName().split("/")[1]);
|
||||||
repoStars.setText(userRepositories.getStars_count());
|
repoStars.setText(userRepositories.getStars_count());
|
||||||
|
|
||||||
ColorGenerator generator = ColorGenerator.MATERIAL;
|
ColorGenerator generator = ColorGenerator.Companion.getMATERIAL();
|
||||||
int color = generator.getColor(userRepositories.getName());
|
int color = generator.getColor(userRepositories.getName());
|
||||||
String firstCharacter = String.valueOf(userRepositories.getFullName().charAt(0));
|
String firstCharacter = String.valueOf(userRepositories.getFullName().charAt(0));
|
||||||
|
|
||||||
|
@ -135,7 +135,7 @@ public class StarredRepositoriesAdapter extends RecyclerView.Adapter<RecyclerVie
|
|||||||
repoName.setText(userRepositories.getFullName().split("/")[1]);
|
repoName.setText(userRepositories.getFullName().split("/")[1]);
|
||||||
repoStars.setText(userRepositories.getStars_count());
|
repoStars.setText(userRepositories.getStars_count());
|
||||||
|
|
||||||
ColorGenerator generator = ColorGenerator.MATERIAL;
|
ColorGenerator generator = ColorGenerator.Companion.getMATERIAL();
|
||||||
int color = generator.getColor(userRepositories.getName());
|
int color = generator.getColor(userRepositories.getName());
|
||||||
String firstCharacter = String.valueOf(userRepositories.getFullName().charAt(0));
|
String firstCharacter = String.valueOf(userRepositories.getFullName().charAt(0));
|
||||||
|
|
||||||
|
@ -0,0 +1,53 @@
|
|||||||
|
package org.mian.gitnex.fragments;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.ViewGroup;
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
|
import com.google.android.material.bottomsheet.BottomSheetDialogFragment;
|
||||||
|
import org.mian.gitnex.databinding.BottomSheetMyIssuesFilterBinding;
|
||||||
|
import org.mian.gitnex.structs.BottomSheetListener;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author M M Arif
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class BottomSheetMyIssuesFilterFragment extends BottomSheetDialogFragment {
|
||||||
|
|
||||||
|
private BottomSheetListener bmListener;
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
@Override
|
||||||
|
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
|
||||||
|
|
||||||
|
BottomSheetMyIssuesFilterBinding bottomSheetIssuesFilterBinding = BottomSheetMyIssuesFilterBinding.inflate(inflater, container, false);
|
||||||
|
|
||||||
|
bottomSheetIssuesFilterBinding.openMyIssues.setOnClickListener(v1 -> {
|
||||||
|
bmListener.onButtonClicked("openMyIssues");
|
||||||
|
dismiss();
|
||||||
|
});
|
||||||
|
|
||||||
|
bottomSheetIssuesFilterBinding.closedMyIssues.setOnClickListener(v12 -> {
|
||||||
|
bmListener.onButtonClicked("closedMyIssues");
|
||||||
|
dismiss();
|
||||||
|
});
|
||||||
|
|
||||||
|
return bottomSheetIssuesFilterBinding.getRoot();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onAttach(@NonNull Context context) {
|
||||||
|
|
||||||
|
super.onAttach(context);
|
||||||
|
|
||||||
|
try {
|
||||||
|
bmListener = (BottomSheetListener) context;
|
||||||
|
}
|
||||||
|
catch(ClassCastException e) {
|
||||||
|
throw new ClassCastException(context + " must implement BottomSheetListener");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -4,14 +4,20 @@ import android.os.Bundle;
|
|||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.Menu;
|
||||||
|
import android.view.MenuInflater;
|
||||||
|
import android.view.MenuItem;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
import android.view.inputmethod.EditorInfo;
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.fragment.app.Fragment;
|
import androidx.fragment.app.Fragment;
|
||||||
import androidx.lifecycle.ViewModelProvider;
|
import androidx.lifecycle.ViewModelProvider;
|
||||||
import androidx.recyclerview.widget.DividerItemDecoration;
|
import androidx.recyclerview.widget.DividerItemDecoration;
|
||||||
import androidx.recyclerview.widget.LinearLayoutManager;
|
import androidx.recyclerview.widget.LinearLayoutManager;
|
||||||
|
import org.mian.gitnex.R;
|
||||||
import org.mian.gitnex.activities.BaseActivity;
|
import org.mian.gitnex.activities.BaseActivity;
|
||||||
|
import org.mian.gitnex.activities.MainActivity;
|
||||||
import org.mian.gitnex.adapters.ExploreIssuesAdapter;
|
import org.mian.gitnex.adapters.ExploreIssuesAdapter;
|
||||||
import org.mian.gitnex.databinding.FragmentIssuesBinding;
|
import org.mian.gitnex.databinding.FragmentIssuesBinding;
|
||||||
import org.mian.gitnex.viewmodels.IssuesViewModel;
|
import org.mian.gitnex.viewmodels.IssuesViewModel;
|
||||||
@ -25,11 +31,14 @@ public class MyIssuesFragment extends Fragment {
|
|||||||
private FragmentIssuesBinding fragmentIssuesBinding;
|
private FragmentIssuesBinding fragmentIssuesBinding;
|
||||||
private ExploreIssuesAdapter adapter;
|
private ExploreIssuesAdapter adapter;
|
||||||
private int page = 1;
|
private int page = 1;
|
||||||
|
private Menu menu;
|
||||||
|
public String state = "open";
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
|
public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
|
||||||
|
|
||||||
fragmentIssuesBinding = FragmentIssuesBinding.inflate(inflater, container, false);
|
fragmentIssuesBinding = FragmentIssuesBinding.inflate(inflater, container, false);
|
||||||
|
setHasOptionsMenu(true);
|
||||||
|
|
||||||
fragmentIssuesBinding.recyclerView.setHasFixedSize(true);
|
fragmentIssuesBinding.recyclerView.setHasFixedSize(true);
|
||||||
fragmentIssuesBinding.recyclerView.setLayoutManager(new LinearLayoutManager(getContext()));
|
fragmentIssuesBinding.recyclerView.setLayoutManager(new LinearLayoutManager(getContext()));
|
||||||
@ -37,24 +46,40 @@ public class MyIssuesFragment extends Fragment {
|
|||||||
DividerItemDecoration.VERTICAL);
|
DividerItemDecoration.VERTICAL);
|
||||||
fragmentIssuesBinding.recyclerView.addItemDecoration(dividerItemDecoration);
|
fragmentIssuesBinding.recyclerView.addItemDecoration(dividerItemDecoration);
|
||||||
|
|
||||||
|
((MainActivity) requireActivity()).setFragmentRefreshListenerMyIssues(myIssuesState -> {
|
||||||
|
|
||||||
|
state = myIssuesState;
|
||||||
|
if(myIssuesState.equals("open")) {
|
||||||
|
menu.getItem(1).setIcon(R.drawable.ic_filter);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
menu.getItem(1).setIcon(R.drawable.ic_filter_closed);
|
||||||
|
}
|
||||||
|
|
||||||
|
fragmentIssuesBinding.progressBar.setVisibility(View.VISIBLE);
|
||||||
|
fragmentIssuesBinding.noDataIssues.setVisibility(View.GONE);
|
||||||
|
|
||||||
|
fetchDataAsync(((BaseActivity) requireActivity()).getAccount().getAuthorization(), null, myIssuesState);
|
||||||
|
});
|
||||||
|
|
||||||
fragmentIssuesBinding.pullToRefresh.setOnRefreshListener(() -> new Handler(Looper.getMainLooper()).postDelayed(() -> {
|
fragmentIssuesBinding.pullToRefresh.setOnRefreshListener(() -> new Handler(Looper.getMainLooper()).postDelayed(() -> {
|
||||||
|
|
||||||
page = 1;
|
page = 1;
|
||||||
fragmentIssuesBinding.pullToRefresh.setRefreshing(false);
|
fragmentIssuesBinding.pullToRefresh.setRefreshing(false);
|
||||||
IssuesViewModel.loadIssuesList(((BaseActivity) requireActivity()).getAccount().getAuthorization(), null, "issues", true, "open", getContext());
|
IssuesViewModel.loadIssuesList(((BaseActivity) requireActivity()).getAccount().getAuthorization(), null, "issues", true, state, getContext());
|
||||||
fragmentIssuesBinding.progressBar.setVisibility(View.VISIBLE);
|
fragmentIssuesBinding.progressBar.setVisibility(View.VISIBLE);
|
||||||
}, 50));
|
}, 50));
|
||||||
|
|
||||||
fetchDataAsync(((BaseActivity) requireActivity()).getAccount().getAuthorization());
|
fetchDataAsync(((BaseActivity) requireActivity()).getAccount().getAuthorization(), null, state);
|
||||||
|
|
||||||
return fragmentIssuesBinding.getRoot();
|
return fragmentIssuesBinding.getRoot();
|
||||||
};
|
};
|
||||||
|
|
||||||
private void fetchDataAsync(String instanceToken) {
|
private void fetchDataAsync(String instanceToken, String query, String state) {
|
||||||
|
|
||||||
IssuesViewModel issuesModel = new ViewModelProvider(this).get(IssuesViewModel.class);
|
IssuesViewModel issuesModel = new ViewModelProvider(this).get(IssuesViewModel.class);
|
||||||
|
|
||||||
issuesModel.getIssuesList(instanceToken, "", "issues", true, "open", getContext()).observe(getViewLifecycleOwner(), issuesListMain -> {
|
issuesModel.getIssuesList(instanceToken, query, "issues", true, state, getContext()).observe(getViewLifecycleOwner(), issuesListMain -> {
|
||||||
|
|
||||||
adapter = new ExploreIssuesAdapter(issuesListMain, getContext());
|
adapter = new ExploreIssuesAdapter(issuesListMain, getContext());
|
||||||
adapter.setLoadMoreListener(new ExploreIssuesAdapter.OnLoadMoreListener() {
|
adapter.setLoadMoreListener(new ExploreIssuesAdapter.OnLoadMoreListener() {
|
||||||
@ -63,7 +88,7 @@ public class MyIssuesFragment extends Fragment {
|
|||||||
public void onLoadMore() {
|
public void onLoadMore() {
|
||||||
|
|
||||||
page += 1;
|
page += 1;
|
||||||
IssuesViewModel.loadMoreIssues(instanceToken, "", "issues", true, "open", page, getContext(), adapter);
|
IssuesViewModel.loadMoreIssues(instanceToken, query, "issues", true, state, page, getContext(), adapter);
|
||||||
fragmentIssuesBinding.progressBar.setVisibility(View.VISIBLE);
|
fragmentIssuesBinding.progressBar.setVisibility(View.VISIBLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -87,4 +112,33 @@ public class MyIssuesFragment extends Fragment {
|
|||||||
fragmentIssuesBinding.progressBar.setVisibility(View.GONE);
|
fragmentIssuesBinding.progressBar.setVisibility(View.GONE);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCreateOptionsMenu(@NonNull Menu menu, @NonNull MenuInflater inflater) {
|
||||||
|
|
||||||
|
this.menu = menu;
|
||||||
|
inflater.inflate(R.menu.search_menu, menu);
|
||||||
|
inflater.inflate(R.menu.filter_menu, menu);
|
||||||
|
super.onCreateOptionsMenu(menu, inflater);
|
||||||
|
|
||||||
|
MenuItem searchItem = menu.findItem(R.id.action_search);
|
||||||
|
androidx.appcompat.widget.SearchView searchView = (androidx.appcompat.widget.SearchView) searchItem.getActionView();
|
||||||
|
searchView.setImeOptions(EditorInfo.IME_ACTION_DONE);
|
||||||
|
|
||||||
|
searchView.setOnQueryTextListener(new androidx.appcompat.widget.SearchView.OnQueryTextListener() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onQueryTextSubmit(String query) {
|
||||||
|
fetchDataAsync(((BaseActivity) requireActivity()).getAccount().getAuthorization(), query, state);
|
||||||
|
searchView.setQuery(null, false);
|
||||||
|
searchItem.collapseActionView();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onQueryTextChange(String newText) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,59 +0,0 @@
|
|||||||
package org.mian.gitnex.viewmodels;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.util.Log;
|
|
||||||
import androidx.annotation.NonNull;
|
|
||||||
import androidx.lifecycle.LiveData;
|
|
||||||
import androidx.lifecycle.MutableLiveData;
|
|
||||||
import androidx.lifecycle.ViewModel;
|
|
||||||
import org.gitnex.tea4j.models.Branches;
|
|
||||||
import org.mian.gitnex.clients.RetrofitClient;
|
|
||||||
import java.util.List;
|
|
||||||
import retrofit2.Call;
|
|
||||||
import retrofit2.Callback;
|
|
||||||
import retrofit2.Response;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Author M M Arif
|
|
||||||
*/
|
|
||||||
|
|
||||||
public class BranchesViewModel extends ViewModel {
|
|
||||||
|
|
||||||
private static MutableLiveData<List<Branches>> branchesList;
|
|
||||||
|
|
||||||
public LiveData<List<Branches>> getBranchesList(String token, String owner, String repo, Context ctx) {
|
|
||||||
|
|
||||||
branchesList = new MutableLiveData<>();
|
|
||||||
loadBranchesList(token, owner, repo, ctx);
|
|
||||||
|
|
||||||
return branchesList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void loadBranchesList(String token, String owner, String repo, Context ctx) {
|
|
||||||
|
|
||||||
Call<List<Branches>> call = RetrofitClient
|
|
||||||
.getApiInterface(ctx)
|
|
||||||
.getBranches(token, owner, repo);
|
|
||||||
|
|
||||||
call.enqueue(new Callback<List<Branches>>() {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onResponse(@NonNull Call<List<Branches>> call, @NonNull Response<List<Branches>> response) {
|
|
||||||
|
|
||||||
if (response.isSuccessful()) {
|
|
||||||
branchesList.postValue(response.body());
|
|
||||||
} else {
|
|
||||||
Log.i("onResponse", String.valueOf(response.code()));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onFailure(@NonNull Call<List<Branches>> call, Throwable t) {
|
|
||||||
Log.i("onFailure", t.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -7,17 +7,19 @@ import androidx.lifecycle.LiveData;
|
|||||||
import androidx.lifecycle.MutableLiveData;
|
import androidx.lifecycle.MutableLiveData;
|
||||||
import androidx.lifecycle.ViewModel;
|
import androidx.lifecycle.ViewModel;
|
||||||
import org.gitnex.tea4j.models.Issues;
|
import org.gitnex.tea4j.models.Issues;
|
||||||
|
import org.mian.gitnex.R;
|
||||||
import org.mian.gitnex.activities.BaseActivity;
|
import org.mian.gitnex.activities.BaseActivity;
|
||||||
import org.mian.gitnex.adapters.ExploreIssuesAdapter;
|
import org.mian.gitnex.adapters.ExploreIssuesAdapter;
|
||||||
import org.mian.gitnex.clients.RetrofitClient;
|
import org.mian.gitnex.clients.RetrofitClient;
|
||||||
import org.mian.gitnex.helpers.Constants;
|
import org.mian.gitnex.helpers.Constants;
|
||||||
|
import org.mian.gitnex.helpers.Toasty;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import retrofit2.Call;
|
import retrofit2.Call;
|
||||||
import retrofit2.Callback;
|
import retrofit2.Callback;
|
||||||
import retrofit2.Response;
|
import retrofit2.Response;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Author M M Arif
|
* @author M M Arif
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class IssuesViewModel extends ViewModel {
|
public class IssuesViewModel extends ViewModel {
|
||||||
@ -45,21 +47,22 @@ public class IssuesViewModel extends ViewModel {
|
|||||||
.getApiInterface(ctx)
|
.getApiInterface(ctx)
|
||||||
.queryIssues(token, searchKeyword, type, created, state, resultLimit, 1);
|
.queryIssues(token, searchKeyword, type, created, state, resultLimit, 1);
|
||||||
|
|
||||||
call.enqueue(new Callback<List<Issues>>() {
|
call.enqueue(new Callback<>() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onResponse(@NonNull Call<List<Issues>> call, @NonNull Response<List<Issues>> response) {
|
public void onResponse(@NonNull Call<List<Issues>> call, @NonNull Response<List<Issues>> response) {
|
||||||
|
|
||||||
if (response.isSuccessful()) {
|
if(response.isSuccessful()) {
|
||||||
issuesList.postValue(response.body());
|
issuesList.postValue(response.body());
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Log.e("onResponse", String.valueOf(response.code()));
|
Toasty.error(ctx, ctx.getString(R.string.genericError));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onFailure(@NonNull Call<List<Issues>> call, Throwable t) {
|
public void onFailure(@NonNull Call<List<Issues>> call, @NonNull Throwable t) {
|
||||||
|
|
||||||
Log.e("onFailure", t.toString());
|
Log.e("onFailure", t.toString());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -90,7 +93,7 @@ public class IssuesViewModel extends ViewModel {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Log.e("onResponse", String.valueOf(response.code()));
|
Toasty.error(ctx, ctx.getString(R.string.genericError));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
80
app/src/main/res/layout/bottom_sheet_my_issues_filter.xml
Normal file
80
app/src/main/res/layout/bottom_sheet_my_issues_filter.xml
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<LinearLayout
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:paddingTop="6dp"
|
||||||
|
android:paddingBottom="12dp"
|
||||||
|
android:background="?attr/primaryBackgroundColor">
|
||||||
|
|
||||||
|
<androidx.core.widget.NestedScrollView
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:id="@+id/repoCreate"
|
||||||
|
android:padding="8dp"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/bottomSheetHeader"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:gravity="center"
|
||||||
|
android:text="@string/strFilter"
|
||||||
|
android:textColor="?attr/primaryTextColor"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
<com.google.android.flexbox.FlexboxLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:id="@+id/repoCreateSection"
|
||||||
|
app:flexWrap="wrap"
|
||||||
|
app:alignItems="stretch"
|
||||||
|
android:padding="8dp"
|
||||||
|
app:alignContent="stretch" >
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/openMyIssues"
|
||||||
|
android:layout_width="98dp"
|
||||||
|
android:layout_height="100dp"
|
||||||
|
android:padding="8dp"
|
||||||
|
android:background="?android:attr/selectableItemBackgroundBorderless"
|
||||||
|
android:gravity="center"
|
||||||
|
app:layout_alignSelf="flex_start"
|
||||||
|
app:drawableTopCompat="@drawable/ic_issue"
|
||||||
|
android:text="@string/isOpen"
|
||||||
|
android:textColor="?attr/primaryTextColor"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/closedMyIssues"
|
||||||
|
android:layout_width="98dp"
|
||||||
|
android:layout_height="100dp"
|
||||||
|
android:padding="8dp"
|
||||||
|
android:background="?android:attr/selectableItemBackgroundBorderless"
|
||||||
|
app:layout_alignSelf="flex_start"
|
||||||
|
android:gravity="center"
|
||||||
|
app:drawableTopCompat="@drawable/ic_issue_closed"
|
||||||
|
android:text="@string/isClosed"
|
||||||
|
android:textColor="?attr/primaryTextColor"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
</com.google.android.flexbox.FlexboxLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</androidx.core.widget.NestedScrollView>
|
||||||
|
|
||||||
|
</LinearLayout>
|
Loading…
Reference in New Issue
Block a user