this post was submitted on 13 Jun 2023
26 points (100.0% liked)

Programming

3347 readers
1 users here now

All things programming and coding related. Subcommunity of Technology.


This community's icon was made by Aaron Schneider, under the CC-BY-NC-SA 4.0 license.

founded 1 year ago
MODERATORS
 

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!

top 14 comments
sorted by: hot top controversial new old
[–] [email protected] 5 points 1 year ago (1 children)

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.

[–] [email protected] 1 points 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

[–] [email protected] 3 points 1 year ago (1 children)

It looks really nice! Keep up the good work!

[–] [email protected] 5 points 1 year ago
[–] KerPop47 2 points 1 year ago

Oooh, I love the style!

[–] [email protected] 2 points 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.

[–] [email protected] 1 points 1 year ago (1 children)

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

[–] [email protected] 3 points 1 year ago* (last edited 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

[–] [email protected] 0 points 1 year ago (1 children)

It looks pretty nice. Though, I couldn't get the search to work on mobile

[–] [email protected] 0 points 1 year ago (1 children)

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

[–] [email protected] 2 points 1 year ago (1 children)
[–] [email protected] 0 points 1 year ago (1 children)

The search function is working now

[–] [email protected] 1 points 1 year ago (1 children)

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

[–] [email protected] 1 points 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.