I am currently trying to build a search component so users can search for Pokemon (since it is currently paginated with 20 per page.) I’m having some difficulty figuring it out, but I’m making progress.

All the information is auto-populated. It’s probably an easy thing for seasoned developers, but I’m proud to have linked the card colors, types and backgrounds to their relevant Pokemon.

Edit: search function is working now! But I I need to add “toLowerCase()”… And add prefix to the type images of some types. Otherwise, it’s working decently! The search field works in real-time, so the page is a little sluggish to load. You can search by Name, ID, Type or Ability, just start typing and your results will appear.

I opted for a single search field for simplicity and to condense the page. I can add filters, but I like it this way for now.

Next I am adding a click-to-zoom on the cards, and when they fill the screen, additional info will populate the card, and even more info on the back.

Edit 2: Instead of making click to zoom, I added a drop-down menu to change sprites between all generations. Maybe now I’ll add click to zoom!

Edit 3: I added the zoom feature and made some tweaks! Added official artwork, better pagination, generation links to display all the Pokemon from a generation, and sound effects! (My fav)

  • wraithcoop@lemmy.one
    link
    fedilink
    arrow-up
    4
    ·
    1 year ago

    Nice work so far, keep it up! Going to another page makes the whole page flash with “Loading” - think about how you can send the next request without re-rendering into that ‘loading’ state each time.

    • reric88🧩@beehaw.orgOP
      link
      fedilink
      arrow-up
      1
      ·
      1 year ago

      Hey! The loading state was on purpose to show the user something was happening, but I did remove it! It didn’t seem to take that long

  • qwacko@lemmy.nz
    link
    fedilink
    arrow-up
    2
    ·
    1 year ago

    Good work, interesting to see how you have made it work with limited additional libraries (i.e. react-query, next etc…), and interesting to see how all the catches can lead to callback hell…

    But good work, and keep it up.

  • venia_sil@vlemmy.net
    link
    fedilink
    arrow-up
    2
    ·
    1 year ago

    Pretty good work. And I know this part doesn’t have much to do with programming but I just love that the items are presented kinda like they were Pokémon cards.

    • reric88🧩@beehaw.orgOP
      link
      fedilink
      arrow-up
      2
      ·
      1 year ago

      Thanks! I put it here because there wasn’t a coding space to put it. But I’ve updated the link, the other one was a little old. Now the Pokemon make sounds! (Their recent cries, not the older ones.)

    • reric88🧩@beehaw.orgOP
      link
      fedilink
      arrow-up
      0
      ·
      1 year ago

      Thanks! It doesn’t work, yet. I’ve commented out the pre-baked search results just so they don’t clutter the interface

          • Kresten@feddit.dk
            link
            fedilink
            arrow-up
            2
            ·
            1 year ago

            That’s awesome dude. I just tested it on my phone. It certainly shows the correct pokemons, and you can even search by any part of their names.

            If you need ideas for furthering the project, then I have a couple:

            • Improve performance. It’s a little sluggish (on my phone anyway)
            • Option to show entire evolution line of the pokemon you are searching for, like how pokemon go does. You could search “ivy” with it enabled and bulbasaur should also show up.
            • search by type (I would probably do it so it only shows when the full text for the type is written e.g. “grass” not already at “gras”.

            Cheers

            • reric88🧩@beehaw.orgOP
              link
              fedilink
              arrow-up
              1
              ·
              1 year ago

              Thanks a lot for the suggestions! Yes, I agree the performance is pretty bad. The reason is because I’m calling ALL the Pokemon data at the beginning into an array. I will optimize this after I learn more!

              I’ll work on adding the evolutionary line, that’s a good idea.

              Currently, you can search by type, but it’s not by the full text of the type. I can definitely implement that. I’ll add a drop-down menu next to the search field to select search criteria to filter irrelevant results.

  • terebat@programming.dev
    link
    fedilink
    arrow-up
    0
    ·
    1 year ago

    What API are you using? Where is the data stored? Would be easier to answer with more data on how this is setup.

    • reric88🧩@beehaw.orgOP
      link
      fedilink
      arrow-up
      4
      ·
      edit-2
      1 year ago

      I’m using https://pokeapi.co/api/v2/pokemon as the api. I can grab all the names but that seems very inefficient and had put a lot of load when calling it.

      I’m looking at just making an array of Pokemon names to exist within the app, and search through that and then call the specific endpoint using that name.

      Edit: Here is the source code https://github.com/reric88/pokemon-vite.git

      Also, I don’t expect anyone to help out, I really just wanted to show it to someone! But any comments, suggestions etc are greatly appreciated. I have less than 3 or 4 months experience with JavaScript