Make a proper onClickThumbnail for Lightbox react-images











up vote
0
down vote

favorite












So I'm setting up a Lightbox component with the react-images library and seem to have everything working. Except for one thing.



I have the thumbnails rendering but I can't create a proper onClick function. This is because I don't know how to get the index of the thumbnail I'm clicking on. If I had the thumbnail index, this wouldn't be a problem.



Here is my current Lightbox component config:



<Lightbox
images={imageObjects}
isOpen={openGallery}
currentImage={middleImageIndex}
showThumbnails={true}
onClickThumbnail={this.onImageSelect.bind(this, index)}
onClickPrev={this.onImageSelect.bind(this, middleImageIndex-1, length)}
onClickNext={this.onImageSelect.bind(this, middleImageIndex+1, length)}
onClose={this.onCloseGallery.bind(this)}
/>


How can I know the index of the thumbnail I'm clicking on so I can set it to currentImage?



Thanks!










share|improve this question


















  • 1




    What does your thumbnail look like?
    – entiendoNull
    Nov 10 at 16:27






  • 1




    What onClickThumbnail returns? Have you checked this? Maybe it returns a thumbnail index.
    – Kort
    Nov 10 at 16:39

















up vote
0
down vote

favorite












So I'm setting up a Lightbox component with the react-images library and seem to have everything working. Except for one thing.



I have the thumbnails rendering but I can't create a proper onClick function. This is because I don't know how to get the index of the thumbnail I'm clicking on. If I had the thumbnail index, this wouldn't be a problem.



Here is my current Lightbox component config:



<Lightbox
images={imageObjects}
isOpen={openGallery}
currentImage={middleImageIndex}
showThumbnails={true}
onClickThumbnail={this.onImageSelect.bind(this, index)}
onClickPrev={this.onImageSelect.bind(this, middleImageIndex-1, length)}
onClickNext={this.onImageSelect.bind(this, middleImageIndex+1, length)}
onClose={this.onCloseGallery.bind(this)}
/>


How can I know the index of the thumbnail I'm clicking on so I can set it to currentImage?



Thanks!










share|improve this question


















  • 1




    What does your thumbnail look like?
    – entiendoNull
    Nov 10 at 16:27






  • 1




    What onClickThumbnail returns? Have you checked this? Maybe it returns a thumbnail index.
    – Kort
    Nov 10 at 16:39















up vote
0
down vote

favorite









up vote
0
down vote

favorite











So I'm setting up a Lightbox component with the react-images library and seem to have everything working. Except for one thing.



I have the thumbnails rendering but I can't create a proper onClick function. This is because I don't know how to get the index of the thumbnail I'm clicking on. If I had the thumbnail index, this wouldn't be a problem.



Here is my current Lightbox component config:



<Lightbox
images={imageObjects}
isOpen={openGallery}
currentImage={middleImageIndex}
showThumbnails={true}
onClickThumbnail={this.onImageSelect.bind(this, index)}
onClickPrev={this.onImageSelect.bind(this, middleImageIndex-1, length)}
onClickNext={this.onImageSelect.bind(this, middleImageIndex+1, length)}
onClose={this.onCloseGallery.bind(this)}
/>


How can I know the index of the thumbnail I'm clicking on so I can set it to currentImage?



Thanks!










share|improve this question













So I'm setting up a Lightbox component with the react-images library and seem to have everything working. Except for one thing.



I have the thumbnails rendering but I can't create a proper onClick function. This is because I don't know how to get the index of the thumbnail I'm clicking on. If I had the thumbnail index, this wouldn't be a problem.



Here is my current Lightbox component config:



<Lightbox
images={imageObjects}
isOpen={openGallery}
currentImage={middleImageIndex}
showThumbnails={true}
onClickThumbnail={this.onImageSelect.bind(this, index)}
onClickPrev={this.onImageSelect.bind(this, middleImageIndex-1, length)}
onClickNext={this.onImageSelect.bind(this, middleImageIndex+1, length)}
onClose={this.onCloseGallery.bind(this)}
/>


How can I know the index of the thumbnail I'm clicking on so I can set it to currentImage?



Thanks!







javascript reactjs react-image






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 10 at 16:20









Adam LaMorre

248




248








  • 1




    What does your thumbnail look like?
    – entiendoNull
    Nov 10 at 16:27






  • 1




    What onClickThumbnail returns? Have you checked this? Maybe it returns a thumbnail index.
    – Kort
    Nov 10 at 16:39
















  • 1




    What does your thumbnail look like?
    – entiendoNull
    Nov 10 at 16:27






  • 1




    What onClickThumbnail returns? Have you checked this? Maybe it returns a thumbnail index.
    – Kort
    Nov 10 at 16:39










1




1




What does your thumbnail look like?
– entiendoNull
Nov 10 at 16:27




What does your thumbnail look like?
– entiendoNull
Nov 10 at 16:27




1




1




What onClickThumbnail returns? Have you checked this? Maybe it returns a thumbnail index.
– Kort
Nov 10 at 16:39






What onClickThumbnail returns? Have you checked this? Maybe it returns a thumbnail index.
– Kort
Nov 10 at 16:39














1 Answer
1






active

oldest

votes

















up vote
0
down vote













Okay, I got it. The react-images docs don't tell your custom onClickThumbnail() function will be passed index by default.



So, you need to make a function that handles the index:



onImageSelect(newIndex){
this.props.setMiddleImage(newIndex)
}


Then you simply add it to onClickThumbnail:



onClickThumbnail={this.onImageSelect.bind(this)}


Then it works.






share|improve this answer





















    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














     

    draft saved


    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53240916%2fmake-a-proper-onclickthumbnail-for-lightbox-react-images%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes








    up vote
    0
    down vote













    Okay, I got it. The react-images docs don't tell your custom onClickThumbnail() function will be passed index by default.



    So, you need to make a function that handles the index:



    onImageSelect(newIndex){
    this.props.setMiddleImage(newIndex)
    }


    Then you simply add it to onClickThumbnail:



    onClickThumbnail={this.onImageSelect.bind(this)}


    Then it works.






    share|improve this answer

























      up vote
      0
      down vote













      Okay, I got it. The react-images docs don't tell your custom onClickThumbnail() function will be passed index by default.



      So, you need to make a function that handles the index:



      onImageSelect(newIndex){
      this.props.setMiddleImage(newIndex)
      }


      Then you simply add it to onClickThumbnail:



      onClickThumbnail={this.onImageSelect.bind(this)}


      Then it works.






      share|improve this answer























        up vote
        0
        down vote










        up vote
        0
        down vote









        Okay, I got it. The react-images docs don't tell your custom onClickThumbnail() function will be passed index by default.



        So, you need to make a function that handles the index:



        onImageSelect(newIndex){
        this.props.setMiddleImage(newIndex)
        }


        Then you simply add it to onClickThumbnail:



        onClickThumbnail={this.onImageSelect.bind(this)}


        Then it works.






        share|improve this answer












        Okay, I got it. The react-images docs don't tell your custom onClickThumbnail() function will be passed index by default.



        So, you need to make a function that handles the index:



        onImageSelect(newIndex){
        this.props.setMiddleImage(newIndex)
        }


        Then you simply add it to onClickThumbnail:



        onClickThumbnail={this.onImageSelect.bind(this)}


        Then it works.







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 13 at 12:58









        Adam LaMorre

        248




        248






























             

            draft saved


            draft discarded



















































             


            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53240916%2fmake-a-proper-onclickthumbnail-for-lightbox-react-images%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            The Sandy Post

            Danny Elfman

            Pages that link to "Head v. Amoskeag Manufacturing Co."