Arpit todewale
Arpit todewale

Reputation: 153

How to provide listeners for different fragment in a viewpager from a button in activity

I am trying to create a form using fragments in a viewpager which is a step by step process.

there are 6 fragments in the viewpager. a "Back" button and a "Next" button(in the activity).

I want to save the form when the user clicks the "Next" button.

To the Reference here is the code

The Adapter to load the Fragments

public class RegistrationPagerAdapter extends FragmentPagerAdapter {

Fragment fragment;


public RegistrationPagerAdapter(@NonNull FragmentManager fm, int behavior) {
 super(fm, behavior);
}

@NonNull
@Override
public Fragment getItem(int position) {
 switch (position){
  case 0:
   fragment = new PersonalDetailsFragment();
  break;

  case 1:
   fragment = new AboutMeFragment();
  break;

  case 2:
   fragment = new HoroscopeFragment();
  break;

  case 3:
   fragment = new EducationFragment();
  break;

  case 4:
   fragment = new FamilyFragment();
  break;

  case 5:
   fragment = new ExpectationFragment();
   break;

 }
    return fragment;
}

@Override
public int getCount() {
    return 6;
}

@Override
public int getItemPosition(@NonNull Object object) {
    return POSITION_NONE;
}

}

There are two buttons in the activity(not in fragments)

public class FormActivity extends AppCompatActivity implements View.OnClickListener {

private static final String TAG = "FormActivity";

AppCompatButton backButton, nextButton;
CustomViewPager viewpager;
Toolbar toolbar;
ApiInterface apiInterface;
RegistrationPagerAdapter adapter;
int status;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_form);
    initilizeToolbar();

}

@Override
protected void onRestart() {
    super.onRestart();
}

private void initilizeToolbar() {
    apiInterface = ApiClient.getClient(getApplicationContext()).create(ApiInterface.class);
    toolbar = findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);
    if (getSupportActionBar() != null) {
        getSupportActionBar().setDisplayHomeAsUpEnabled(true);
        getSupportActionBar().setDisplayShowHomeEnabled(true);
    }
    castComponents();
}

private void castComponents() {
    viewpager = findViewById(R.id.viewPager);
    backButton = findViewById(R.id.backButton);
    nextButton = findViewById(R.id.nextButton);
    nextButton.setOnClickListener(this);
    backButton.setOnClickListener(this);
    GetAllDetailsOfUser();

}

@Override
public void onResume() {
    initilizeToolbar();
    super.onResume();
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    return super.onCreateOptionsMenu(menu);
}

public void setViewPagerData(int status) {
    FragmentManager fm = getSupportFragmentManager();
    adapter = new RegistrationPagerAdapter(fm, 0);
    viewpager.setAdapter(adapter);
    viewpager.setCurrentItem(status);
    viewpager.setPagingEnabled(false);
}

public void GetAllDetailsOfUser() {
    Call<AllProfileDetails> allDetails = apiInterface.allDetails(PrefUtils.getToken(this), PrefUtils.getID(this));
    allDetails.enqueue(new Callback<AllProfileDetails>() {
        @Override
        public void onResponse(Call<AllProfileDetails> call, Response<AllProfileDetails> response) {
            AllProfileDetails all = response.body();
            if (all != null) {
                if (all.getStatus()) {
                    Data data = all.getData();
                    setViewPagerData(data.getProfileCurrentStatus());
                    status = data.getProfileCurrentStatus();
                }
            }
        }

        public void onFailure(Call<AllProfileDetails> call, Throwable t) {
            Crashlytics.log(t.getLocalizedMessage());
        }
    });
}

@Override
public void onClick(View view) {
 switch (view.getId()) {
  case R.id.backButton:
   if (viewpager.getCurrentItem() == 0){

   }else{
       viewpager.setCurrentItem(viewpager.getCurrentItem() - 1);
   }
  break;

  case R.id.nextButton:
      if (viewpager.getCurrentItem() == 6){

      }else{
          viewpager.setCurrentItem(viewpager.getCurrentItem() + 1);
      }

  break;
 }
}

}

this is Code is Fine but here is the problem...

When i save the data in Fragment1 i.e "PersonalDetailsFragment", it moves to fragment2 i.e "AboutMeFragment"

again when i click on save button for "AboutMeFragment" it runs the method of "PersonalDetailsFragment" only

please note that i call the activity buttons in fragments as

getActivity().findViewById(R.id.backButton);
getActivity().findViewById(R.id.nextButton);

Upvotes: 0

Views: 81

Answers (1)

TaQuangTu
TaQuangTu

Reputation: 2343

You should have a interface like OnSaveTapped.

public interface OnSaveTapped{
   void onSaveTapped();
}

Then make the fragments implement the interface above, ex:

public class PersonalDetailsFragment extends Fragment implements OnSaveTapped{

   public void onSaveTapped(){
       //do your business code here to save data 
   }
}

Finally ,In the activity class:

@Override
public void onClick(View view) {
   switch (view.getId()) {
   case R.id.backButton:
   if (viewpager.getCurrentItem() == 0){

   }else{
       viewpager.setCurrentItem(viewpager.getCurrentItem() - 1);
   }
   break;

   case R.id.nextButton:
      if (viewpager.getCurrentItem() == 6){

      }else{
          viewpager.setCurrentItem(viewpager.getCurrentItem() + 1);
      }

  break;
  case R.id.button_save:
     ((OnSaveTapped)viewpager.getCurrentFragment()).onSaveTapped();
}

Don't forget to create new method named getCurrentFragment() to return current item (fragment) in RegistrationPagerAdapter.

public class RegistrationPagerAdapter extends FragmentPagerAdapter {

     private Fragment fragment;
     /**other lines of code*/
     public Fragment getCurrentFragment(){
        return fragment;
     }
}

Upvotes: 1

Related Questions