Secret Passage is a poetry browsing application that involves a sort of ISpy-like navigation through pages that are styled conditionally. The styling comes from a list of the 25 most commonly found words in about 3,000 poems from Poetry magazine (you can find a link to the source in the Shout Outs below). This was a really fun project for me to build. The chance operations allow for some really cool juxtaposition between the poetry itself and the imagery paired with it.
- Fork this repository.
- Create a local repository.
- Follow the Github on-screen commands to connect your local repository to your newly forked repository.
- Change directories into client and run npm install, then npm start to start the application locally.
- Navigate to http://localhost:3000 in your browser to use the application.
This was the showcase project for Module Three of the Front End Engineering program at Turing School of Software and Design. The goal was to demonstrate skills in React, Router, Asynchronous Javascript, and end to end testing with Cypress.
There was a very short timeline for this project, about five days for planning and execution. I am really proud of what I was able to accomplish within this timeline. I am very pleased with the passkey's random position, it was an interesting problem to solve within React. I had originally worked it out in this codepen, but it wasn't exactly a plug-and-play to get it to work in the application.
UPDATE: After a component architechure restructuring, the route error handling is now working properly. There was not real reason to iterate over the fetched poems and create an array of the Poem components to hold in App. This is useful if you need to display a lot of instances of a component at once (like items listed for sale in a webstore), but in this case you are only looking at one Poem at a time. Now, the data flowing through component props changes as you navigate through the site, changing the display.
In any case, I'm glad I followed these two structures through, as I now have a deeper understanding of the pros and cons of various architectures.
Original Entry: I structured my application with a set of nested components, and I struggled with handling bad url errors. The Poems component contains an array of Poem components, each which is wrapped in a Route. I wasn't able to get the Reroute to include bad urls like this: /poems/banana
.
I utilized this list of most commonly used poetry words from Robert Peake to create my styling schema.
Thanks to @thundercomb who created this API which made this project possible.
Loading spinner from Loading.io