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

items in props are cleared if press "back" or "previous page" #18

Open
FrankChung opened this issue Nov 28, 2016 · 1 comment
Open

items in props are cleared if press "back" or "previous page" #18

FrankChung opened this issue Nov 28, 2016 · 1 comment

Comments

@FrankChung
Copy link

FrankChung commented Nov 28, 2016

As title,

for example in the demo page, if press "back" in the PhotoSwipe view and then the gallery cannot be opened again.

after dip, the reason is:

this.photoSwipe.items.length = 0;
    items.forEach((item) => {
      this.photoSwipe.items.push(item);
    });

this.photoSwipe.items.length = 0;

this line will clean the items.

@mbrochh
Copy link

mbrochh commented May 28, 2018

We encountered this bug as well. Before, we were mounting PhotoSwipe like this:

      <PhotoSwipe
        isOpen={isOpen}
        items={this.state.items}
        onClose={() => onClose()}
        options={options}
      />

And whenever we closed PhotoSwipe, this.state.items suddenly became an empty array, even though none of our this.setState calls in our own component were triggered.

It turns out, we seem to be passing in a reference to the item and when PhotoSwipe internally wipes that array, it also gets wiped in our calling component. We simply added .slice(0) to pass in a clone of the array and not a reference to the original array like this:

      <PhotoSwipe
        isOpen={isOpen}
        items={items.slice(0)}
        onClose={() => onClose()}
        options={options}
      />

Maybe that will help someone save a few hours of head-scratching in the future....

Maybe important: We only experienced this issue when we opened the page that has the PhotoSwipe directly, by typing in the URL. That means, the user sees the server side rendered result first and then the bundle picks up after a while and probably somehow re-mounts PhotoSwipe.

When we just click around on our site and then navigate to the page that has the PhotoSwipe, this bug does not happen. So it seems like SSR does trip up PhotoSwipe in some way.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants