[Full Stack Web] Reverse Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
![[Full Stack Web] Reverse Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core](/images/2019/07/simon-gilbert-dev-cto-blog-29-1.png)
Geo Location
I blogged recently about tracking a users geo location from their iPhone, but what if all you have is a postcode, yet still require coordinate data?
Enter “www.postcodes.io”…
I discovered this third party api not long ago and it’s been very useful. Typically the most common downside with these api’s is that they’re rate limited, so today we’re going to code a full stack single page app (SPA)…with a built in memory cache, thus reducing how often we’re hitting the endpoint for the same postcode.
Prerequisites
You’ll need to follow the steps I blogged about here to configure your single page app (SPA) setup to run with ReactJS + Redux + C# ASP.Net Core.
Let’s Code…
Firstly we need a data model to interact with www.postcodes.io -
data:image/s3,"s3://crabby-images/9709e/9709e9c364eabef8ff0caa173891f66874800e01" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Next, a web client service to ping the endpoint.
data:image/s3,"s3://crabby-images/4bf10/4bf109727eba900eb047ff01f09227a5e7dea124" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Now we need a dedicated service to handle the requests we pass in, and the output we receive back.
data:image/s3,"s3://crabby-images/48482/484821a33f7ccae50cd8415567b7f4bbd6a36832" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Now to setup our API controller and memory cache -
data:image/s3,"s3://crabby-images/b8a11/b8a11c013f7dd15476782aa5864e6f0228d0fbc1" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Followed by our controller action method.
data:image/s3,"s3://crabby-images/5d245/5d24540a46ecb3f2e3aaa25f2c35ef0b1a5e3e0e" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Now to code our client-side in ReactJS. Let’s start with some imports (I’ll be using the InputField, Button and Table components that I’ve written and published recently in other blog posts). You’ll note that I’ve also added a massive regex to be used when validating the postcodes.
data:image/s3,"s3://crabby-images/9ab65/9ab65c5af1b8bb5528dea7ad4375ce98c3a66ba1" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Next we’ll need a few properties to help with the field validation.
data:image/s3,"s3://crabby-images/c96bf/c96bf38149251d54c28600eabf4253903ca29e72" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Now for a function to handle the user’s input.
data:image/s3,"s3://crabby-images/09683/09683fb327810decdb30f82df180bd0d928fffb1" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Following this comes the field validation functionality.
data:image/s3,"s3://crabby-images/e7cb6/e7cb65d14ff5143773dcfe08ae1ab8e53ef3247e" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
At this point we can render the form, using the components I mentioned previously.
data:image/s3,"s3://crabby-images/b22cb/b22cb09ae4ba43e8481a19dfae8e99b495aa575e" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Now to plug our ReactJS client-side code into our C# ASP.Net Core server-side code using Redux.
data:image/s3,"s3://crabby-images/c1bc3/c1bc32e4d6024e129d1569f26b94a5e47cb160af" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Let’s run our application and see what happens.
data:image/s3,"s3://crabby-images/9c32d/9c32dece660f4fdc143e1a9ac5163b58f0129315" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Our validation has kicked in and requires a valid postcode before we can submit the form.
data:image/s3,"s3://crabby-images/54449/54449788492c9876480a4247c1f7201fb2d75dcd" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Once we enter a valid postcode, our submit button becomes enabled and the postcode regex validation has passed.
data:image/s3,"s3://crabby-images/e02a0/e02a0036d6bfb57b8b931f8e3f50f29d03800b05" alt="Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core"
Revere Geo Location Lookup - ReactJS + Redux + C# ASP.Net Core
Finally, we receive the relevant geo location coordinates for the postcode we submitted, indicating the latitude and longitude.
Enjoy!