Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: allow user to choose which event or state change to be captured in the changeStack or not #4178

Closed
whowillcare opened this issue May 23, 2024 · 4 comments
Assignees
Labels
pkg:replay_bloc This issue is related to the replay_bloc package question Further information is requested

Comments

@whowillcare
Copy link

Description

The current solution doesn't have a feature that allow user to specify which events to be added to the changeStack, and which ones are not, which will give user flexiblity to redo or undo specific states changes

Desired Solution

/// allow user to overwrite this method
  bool shouldChangeStack(State current, State next)=>true

@override
  void emit(State state) {
   if (shouldChangeStack(this.state,state)){
     _changeStack.add(
      _Change<State>(
        this.state,
        state,
        () {
          final event = _Redo();
          onEvent(event);
          onTransition(
            Transition(
              currentState: this.state,
              event: event,
              nextState: state,
            ),
          );
          // ignore: invalid_use_of_visible_for_testing_member
          super.emit(state);
        },
        (val) {
          final event = _Undo();
          onEvent(event);
          onTransition(
            Transition(
              currentState: this.state,
              event: event,
              nextState: val,
            ),
          );
          // ignore: invalid_use_of_visible_for_testing_member
          super.emit(val);
        },
      ),
    );
 }
    // ignore: invalid_use_of_visible_for_testing_member
    super.emit(state);
  }

Alternatives Considered

or keep the super.emit to an alternative method name, so the child class can always override the emit method for implementing the similar feature

Additional Context

which will save the resource and allow user to have more flexiblities

@felangel
Copy link
Owner

felangel commented Jun 4, 2024

Hi @whowillcare 👋
Thanks for opening an issue!

Are you able to provide a bit more context around your use-case? ReplayBloc has a shouldReplay API which seems like it might be what you're looking for.

@felangel felangel added question Further information is requested waiting for response Waiting for follow up pkg:replay_bloc This issue is related to the replay_bloc package labels Jun 4, 2024
@felangel felangel self-assigned this Jun 4, 2024
@whowillcare
Copy link
Author

whowillcare commented Jun 4, 2024 via email

@onism0106
Copy link

I have the same requirement. For example, if a certain state is triggered by the PageEventStarted event (an event added when the page is started), this event should not be added to the changeStack.

Is it possible to determine shouldReplay based on the event itself, rather than just the state?

@felangel
Copy link
Owner

This should be possible to do already using shouldReplay. Since you're in full control of the state you can determine whether or not it should be replay-able.

Is it possible to determine shouldReplay based on the event itself, rather than just the state?

Generally, I don't recommend this because the thing that is being replayed is the state not the event so ideally all information that you need to determine whether a state should be replay-able should be encoded in the state itself. Furthermore, there's a ReplayCubit which doesn't support adding events at all and the ReplayBloc and ReplayCubit APIs should ideally be the same.

Closing this for now since this issue is quite old but if this is still an issue for folks I highly recommend filing a new issue with as much context as possible and ideally a minimal reproduction sample, thanks! 🙏

@felangel felangel removed the waiting for response Waiting for follow up label Jan 12, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
pkg:replay_bloc This issue is related to the replay_bloc package question Further information is requested
Projects
None yet
Development

No branches or pull requests

3 participants