OutSystems + ChatGPT — Making fast, faster

kelterantunes

Miguel Antunes

Posted on December 20, 2022

OutSystems + ChatGPT — Making fast, faster

Can we combine OutSystems and ChatGPT to build our next app faster than before? Let’s build a weather app in 10 minutes or less without writing one single line of code.

Hero image

What is ChatGPT?

ChatGPT, the incredible AI-powered program that responds to user prompts, has taken over social media in recent days! It’s been composing Shakespearean poetry, having deep philosophical discussions, and even identifying bugs in computer code.

The team behind it made ChatGPT available to the public for testing last month, and it’s been an absolute hit! In just its first week, the program drew over a million users and sparked a renewed interest in the effort to replicate human intelligence. And of course, it’s also sparked some controversy over potential bias and free speech limits.

Created by the brilliant team at OpenAI, ChatGPT is a chatbot that uses an algorithm to select words based on lessons learned from scanning billions of pieces of text from the internet. It’s truly amazing to see what it’s capable of!


What is OutSystems?

OutSystems is a low-code platform that allows businesses to develop and deploy custom software applications quickly and easily. The platform uses a visual drag-and-drop interface to make it easy for users to create and customize their applications without needing to write a lot of code. It also includes a range of pre-built components and integrations that can be used to speed up the development process. OutSystems is often used to create web and mobile applications, as well as to automate business processes and integrate systems.

Fun fact: the last paragraph about OutSystems was written by ChatGPT! 😄

Me asking ChatGPT what’s OutSystems


So let’s put them together and see what happens!

I asked ChatGPT if it was willing to help me build a webpage/app, and it promptly said ‘Sure’.

Prompting ChatGPT if it wants to build an app with me

So, I’ve created and prepared an OutSystems app that will use code suggested by ChatGPT and hopefully in the end, we’ll have a simple yet working OutSystems weather application coded by myself and my code companion ChatGPT.

Creating the OutSystems application

I created a simple screen, with a small card that will show an icon and the temperature of the current weather in my location.

Simple home screen

This is the bare-minimum that we need to prove that we can work together with ChatGPT while building this weather app. The icon image and the temperature HTML span are just placeholders that will be replaced with data coming from an API call response.

So I told ChatGPT what I wanted:

I would like it to be a weather forecast page. 
It will have a card on top of the page showing the current temperature and 
an icon with the current weather status. 
Then the next section will have the forecast for the next 5 days. 
The information needs to be retrieved via API, and user location should be 
used.
Enter fullscreen mode Exit fullscreen mode

Surprisingly, ChatGPT responded with some steps to create our application and an actual snippet of JavaScript code to get the user location, make an API call, handle the response and place the results on screen:

Great! To get started, you will first need to set up the HTML structure for 
your webpage. This will include creating the main container elements, 
such as the <body> and any <div> elements that you will use to organize 
the layout of your page. You can use the <h1> and <p> tags to add headings 
and paragraph text, and the <img> tag to add an image for the current weather 
icon.

Once you have the basic structure in place, you can use CSS to add styles 
to your page. This will involve selecting the elements that you want to 
style and defining the styles that you want to apply. For example, you 
might use the font-size and color properties to style your headings and 
paragraphs, and the width and height properties to control the size of 
your weather icon image.

To retrieve the weather data, you will need to use a weather API. There are 
many different weather APIs available, and they will typically provide 
instructions on how to use their API to retrieve the weather data that you 
need. Once you have retrieved the data, you can use JavaScript to extract 
the relevant information and display it on your webpage.

To get the user's location, you can use the navigator.geolocation object in 
JavaScript. This will allow you to access the user's latitude and longitude, 
which you can then use to query the weather API and retrieve the weather 
data for their location.

Here is an example of how you might use JavaScript to retrieve the weather 
data and display it on your webpage:
Enter fullscreen mode Exit fullscreen mode
// Get the user's location
navigator.geolocation.getCurrentPosition(function(position) {
  // Query the weather API using the user's latitude and longitude
  fetch(`https://api.weather.com/v1/geocode/${position.coords.latitude}/${position.coords.longitude}/observations.json`)
    .then(function(response) {
      return response.json();
    })
    .then(function(data) {
      // Extract the current temperature and weather icon from the API response
      const temperature = data.observation.temp;
      const icon = data.observation.icon;

      // Update the page with the current temperature and weather icon
      document.getElementById('temperature').innerHTML = temperature;
      document.getElementById('icon').src = icon;
    });
});
Enter fullscreen mode Exit fullscreen mode

As we can see in the ChatGPT snippet, we need to have two HTML DOM ids to hold the API response values, one for the temperature and another one for the weather icon/image. And isn’t beautiful that the code comes already commented? 🤯

But I also want to have a 5-day weather forecast in our page, so I asked ChatGPT for that:

Can you give me now the snippet that will fetch the forecast for the next 5 
days?
Enter fullscreen mode Exit fullscreen mode

At this point, we shouldn’t be surprised that ChatGPT is here to help… And we can confirm that as we see it again, responding with the following:

Sure, here is an example of how you might retrieve the forecast for the 
next 5 days using JavaScript:
Enter fullscreen mode Exit fullscreen mode
// Get the user's location
navigator.geolocation.getCurrentPosition(function(position) {
  // Query the weather API using the user's latitude and longitude
  fetch(`https://api.weather.com/v1/geocode/${position.coords.latitude}/${position.coords.longitude}/forecast/daily/5day.json`)
    .then(function(response) {
      return response.json();
    })
    .then(function(data) {
      // Loop through the forecast data for the next 5 days
      for (let i = 0; i < data.forecasts.length; i++) {
        // Extract the date, temperature, and weather icon for each day
        const date = data.forecasts[i].date;
        const temperature = data.forecasts[i].day.temp;
        const icon = data.forecasts[i].day.icon;

        // Update the page with the forecast data for each day
        document.getElementById(`date-${i}`).innerHTML = date;
        document.getElementById(`temperature-${i}`).innerHTML = temperature;
        document.getElementById(`icon-${i}`).src = icon;
      }
    });
});
Enter fullscreen mode Exit fullscreen mode
In this code, we are using the fetch function to query the weather API and 
retrieve the forecast data for the next 5 days. We are then looping through 
the forecast data and extracting the date, temperature, and weather icon 
for each day. Finally, we are using the innerHTML and src properties to 
update the page with the forecast data.

Note that this code is just an example and may need to be adapted to work 
with your specific weather API and HTML structure. Also, be sure to replace 
api.weather.com with the URL for the weather API that you are using.

I hope this helps! Let me know if you have any other questions or need 
additional help.
Enter fullscreen mode Exit fullscreen mode

Again, full working code, commented and with a brief explanation on what it does!

You can see in the ChatGPT response notes, that it states api.weather.com should be replaced with our specific weather API. So I asked ChatGPT to do that for me. At this point, I’m too lazy to do it!

can you replace api.weather.com with an actual free weather api?

Enter fullscreen mode Exit fullscreen mode

It not only replaced the endpoint, but also suggested a list of other free weather APIs available for use!

Sure, there are many free weather APIs that you can use in your JavaScript 
code. Some examples include:

OpenWeatherMap: https://openweathermap.org/api
AccuWeather: https://developer.accuweather.com/
Weatherbit: https://www.weatherbit.io/api
Dark Sky: https://darksky.net/dev

Each of these APIs will provide documentation and examples on how to use 
their API to retrieve the weather data that you need. For example, the 
OpenWeatherMap API provides the following example for retrieving the 
current weather data for a given latitude and longitude:
Enter fullscreen mode Exit fullscreen mode
fetch(`https://api.openweathermap.org/data/2.5/weather?lat=${lat}&lon=${lon}&appid=${API_KEY}`)
  .then(function(response) {
    return response.json();
  })
  .then(function(data) {
    // Extract the current temperature and weather icon from the API response
    const temperature = data.main.temp;
    const icon = data.weather[0].icon;

    // Update the page with the current temperature and weather icon
    document.getElementById('temperature').innerHTML = temperature;
    document.getElementById('icon').src = `https://openweathermap.org/img/wn/${icon}@2x.png`;
  });
Enter fullscreen mode Exit fullscreen mode
As you can see, the API provides a URL that you can use with the fetch 
function to retrieve the weather data, and the response includes the 
current temperature and weather icon. You can then use this information 
to update your webpage.

Be sure to check the documentation for the specific API that you choose 
to use, as the exact syntax and format of the API requests and responses 
may vary. Also, be sure to register for an API key if the API requires one, 
as this will typically be required in order to access the API.

I hope this helps! Let me know if you have any other questions or need 
additional help.
Enter fullscreen mode Exit fullscreen mode

It’s impressive how detailed ChatGPT responses are… It not only responds to our requests while at the same time it gives explanations on the response.

By now, we have everything we need to tie together and see if we can:

  • Get user location
  • Call openweathermap.org API
  • Update screen information according to the API response

Let’s grab the JavaScript provided by ChatGPT and add it to the screen OnReady event and pass the HTML DOM IDs.

OutSystems widget Name property will become HTML element id

We need to add two parameters that will hold the icon and temperature span IDs, and replace them in the snippet by changing ‘temperature’ to $parameters.temperature_id and ‘icon’ to $parameters.icon_id. I’ve also grabbed a free openweathermap.org API Key and added it to the code provided by ChatGPT.

Passing widget IDs to the JavaScript code

With this in place, I can now publish our app and check in the browser if the image and temperature placeholders are replaced with actual data.

Browser will ask for permission to access my current location, which is being requested in the JavaScript code.

Browser asks for user location

After allowing the browser to access my current location, the API call is made using my current coordinates and our app HTML is updated with the response data coming from the API call.

Our app with data returned by the API endpoint

We can now move to the next part, where we show the 5-day weather forecast using again the JavaScript code provided by ChatGPT.

We need to add another JavaScript node in our screen OnReady action, that will call the forecast API endpoint. Add some HTML elements to our page to hold the 5-day forecast information, tie everything together, tweak here and there and let’s see if it works:

Our app with weather information and 5-day forecast

And we have a fully functional weather app that displays the current and 5-day weather information, while we didn’t have to write a single line of JavaScript... Because ChatGPT did it for us!


While this is not a production ready weather app, with insanely good UX/UI and a beautiful design, it shows how far we’ve come either in low-code tools like OutSystems and artificial intelligence chatbots like ChatGPT.

This took me no more than 10 minutes to build, and not a single line of JavaScript was written by me. While ChatGPT is far from fully replace developers, it can already be used as your code companion, that can come up with code snippets, can help you debug parts of the code or even help with code explanations.


In case this is the first time you are hearing/reading about OutSystems, here’s the link to the free trial. You just need to follow the steps to set up your environment in the cloud and download the IDE.

The full source code is also available for download here.

💖 💪 🙅 🚩
kelterantunes
Miguel Antunes

Posted on December 20, 2022

Join Our Newsletter. No Spam, Only the good stuff.

Sign up to receive the latest update from our blog.

Related

OutSystems + ChatGPT — Making fast, faster