This is the last blog for OSD600 and the last part of release 0.4! I am excited to be writing this as after this I will be done with everything I need to do for my classes this semester, and graduate! One issue I noticed while working on this is I did not fully understand what was needed to "port" a component from Gatsby to Next. At first, I thought everything you needed to do to port a component was in this migration guide posted in the issue. After talking to some people on Slack I learned we must not only follow the migration guide but also convert the JavaScript code in the components to TypeScript. I have worked with Typescript before so I had an idea of how it works/what it is (it's basically JavaScript with types), but I never knew how to convert JavaScript code to TypeScript code. After doing some research I learned this process can be broken down into two simple steps:
1. Change all the .jsx files to .tsx files.
2. Add types to all the variables made. Eg. function LogIn(style) becomes:
function LogIn({style}: {style: any})
So I started by creating a new branch, then copying the LogIn component files, contexts/ and hooks/ from the gatsby directory to the next directory. The files I needed to change where: LogIn/index.tsx, LogIn/LoggedIn.tsx LogIn/LoggedOut.tsx, LogIn/login.tsx and hooks/use-site-metadata.ts. This issue was much more challenging than I thought. First off I had a hard time understanding how the useSiteMetaData function worked and how I would need to convert it. I did a lot of research and read these docs:
- https://nextjs.org/docs/basic-features/data-fetching
- https://www.gatsbyjs.com/docs/page-query/
- https://nextjs.org/docs/migrating/from-gatsby
I came out with a lot of ideas but nothing seemed to work, so I decided to ask on Slack and push to my branch so people can see the code. Cindy replied with a fix to this issue. However, after that, another issue popped up which was even more strange.
I ran npm install when I first started this, so I checked the code, but everything seemed correct. I read on
stack overflow this can be caused but not having the component as a functional component, but it was... after discussing it with some people on Slack, Calvin figured out that @material-ui/core was not installed. I didn't think of this as I thought it would already be in package.json and installed when I run npm install. On the bright side, this lead to the discovery of a new issue. However, the problems didn't end there! After I installed @material-ui/core a new issue arose!!
The first thing I tried was to just hard code colors in place of these lines... and it worked!
Since this issue was just to port the component I left it like this. I let people know about this on Slack and in my
pull request so this issue can be fixed in the future. I'd like to thank Cindy and Calvin for their guidance with this port. Overall release 0.4 was by far the hardest pull request I had to do this semester, but I see that as a good thing for two reasons: I am continuing to push myself further and do things I would otherwise be scared to do, and now I know for sure this will satisfy the 0.4 requirements 🤣. That puts an end to release 0.4, OSD600, and my journey at Seneca. I learned a lot not only in this class but in the past six semesters! I am very grateful for the knowledge I have gained here and I am sure will be very useful in the future. I am also very grateful I had David Humphery as my professor, not just because he was a good teacher and always helped his students. More importantly, he is always pushing us to go "bigger" and challenge ourselves. He helped guide us through the world of open source development. He taught us to have confidence in ourselves. He reminds me a lot of my grade 12 Computer Science teacher who did the same. I know for a fact this will pay off later on. The future looks bright!
Comments
Post a Comment