DEV Community

Cover image for How we built a 1% website in 3 days for €7
Thomas Hansen for AINIRO.IO

Posted on • Edited on • Originally published at ainiro.io

How we built a 1% website in 3 days for €7

Due to events outside of our control, Aria, Tage and me were forced into a situation where we had to launch a successful and profitable ChatGPT-based website chatbot company in 2 weeks. The stakes are super high, but we'll get there with some help from our friends.

Failure is not an option though, so we're confident in that we'll make it - Especially considering all of our amazing friends who have been there for us these last days and supported us. Thank you, it means the world to us. The words "teamwork and friendship" have created meaning for us these last days in ways most people unfortunately never will experience during their lifetimes.

To Infinity and Beyond!

What is a 1% website?

Anyways, so what is a 1% website? It's a website that performs in the top 1%. Implying if you pick 100 random websites in the world, and include ours, ours will be the best performing website on neutral metrics. It's probably not a scientific definition, and I cannot prove that we're in the 1% - But I'm confident enough to publicly state it anyways. So, let me explain how we did it here for those interested.

Technology

I have a hate/love relationship to WordPress. For non-technical people, it's an amazing tool. However, for a software developer having spent 25 years working with web related technologies it's like attaching an open parachute to a racing car. The markup it generates is far from optimal, performs like $%^&, and adding Elementor only increases the damage. WordPress, especially in combination with Elementor, becomes a "tag soup from hell". The same is true to some extent with more or less all CMS systems out there. Yet again, if you're not a software developer, use WordPress - It's an amazing no-code and low-code tool if you need a web presence. For us though, it's simply not "relevant", so we chose to build our website entirely on top of Magic Cloud and Hyperlambda.

This means that every single HTML tag was manually added using Visual Studio Code, something you can appreciate if you click "View Page Source" on this page. This gives us 100% control over what's rendered to the browser, resulting in 1,000x quality on the site's HTML. Since Hyperlambda websites allows us to create "reusable components" the end code is still 100% perfectly "DRY" (Don't Repeat Yourself).

Basics of a Hyperlambda website

A Hyperlambda website allows you to declare codebehind files in Hyperlambda. If you've got an HTML file called "foo.html" for instance, you can create a Hyperlambda file in the same folder called "foo.hl", and it will serve as a codebehind file, allowing you to dynamically inject lambda expressions into your HTML, that are substituted with the return value of the lambda expression's result. You can read more about Hyperlambda websites here. Scroll to the bottom to find the relevant parts.

Hyperlambda websites gives us 100% control over the HTML, in addition to providing us with all the sane defaults out of the box, allowing us to override things where needed. With "sane defaults", I mean things such as HTTP caching of static resources, etc.

The blog parts of our site is similar to Jekyll, implying blogs are simply Markdown files, except the resolver transforming the Markdown into HTML is (pun!) Hyperlambda and not Jekyll. If you don't like Hyperlambda, Jekyll is an amazing alternative.

In addition to the above, we've got a private GitHub repository, with a CI/CD pipeline implemented as a GitHub action. Implying each time I push towards the master branch of our website at GitHub, a new version is automatically deployed. To illustrate that fact, realise I'm actually using VSCode to write this blog to you ... ;)

Web Frameworks

We did not start out with a template at all. In fact, the website is manually designed from the bottom and up, and the only "framework" we're using here is Bootstrap. Besides from bootstrap, every single line of code, CSS, and HTML is manually written, for the most parts in vanilla JavaScript may I add. All animations are pure CSS animations, yet again manually written, and even the contact form's HTTP post request was manually created using JavaScript's fetch function. I've included it for references below if you're interested in the details.

  function sendEmail(email, name, content, recaptcha_response) {
    fetch('https://ainiro.io/magic/modules/bazar/contact-us', {
      method: 'POST',
      headers: {
        'Accept': 'application/json',
        'Content-Type': 'application/json'
      },
      body: JSON.stringify({
        email,
        name,
        content,
        recaptcha_response
      })
    })
      .then(response => response.json())
      .then(response => {
        if (!response?.result === 'success') {
          throw new Error("Bad request")
        }
      })
      .then(() => {
        const contact_us = document.getElementById('contact_us');
        contact_us.className = "row fade-out";
        const thank_you = document.getElementById('thank_you');
        thank_you.className = 'row fade-in thank_you';
      }).catch((err) => {
        console.log(err);
        alert('We could not send your email :/');
      });
  }
Enter fullscreen mode Exit fullscreen mode

I admit it's a little bit simple, but it gets the job done. Submitting the form looks as follows, to make sure we have reCAPTCHA support (version 3).

  function onSubmit(e) {
    grecaptcha.ready(function () {
      grecaptcha
        .execute('YOUR_RECAPTCHA_TOKEN_HERE', { action: 'submit' })
        .then(function (token) {
          const msg = 'Website; ' + document.getElementById('website').value + '\r\n\r\nMessage;\r\n' + document.getElementById('info').value;
          sendEmail(
            document.getElementById('email').value,
            document.getElementById('name').value,
            msg,
            token
          );
        });
    });
    e.preventDefault();
    return false;
  }
Enter fullscreen mode Exit fullscreen mode

And that's about all JavaScript that's in our page. If you need a "contact us" form, you're of course free to use the above code.

ChatGPT chatbot

Of course, the seasoned software developer will now object and ask "how did you get the chatbot working?", at which point I can answer this is how I got the chatbot working. It's just a simple JavaScript inclusion tag, and an integrated part of Magic Cloud. So there was zero work from my end to have a functioning ChatGPT-based chatbot on the site. I suspect there's a "not invented here syndrome lesson" in there some place, but I'll leave it up to the reader to find it ...

SEO metrics

If you're not in Google's SERP, your website might as well not exist. The way we measure SEO is by using seobility. This is an amazing tool that allows you to measure how your site works on metrics such as keywords, titles, descriptions, etc. Run your site through seobility, and 5 minutes later it'll tell you everything you're doing wrong, and provide hints as to how to improve your site. Below is how our site are performing according to seobility.

How AINIRO isperforming on SEO

I need to emphasize here, that I have spent months on optimizing WordPress websites previously without even being able to achieve the above score. The reasons are because of "too much Magic stuff" going on in WordPress, supposedly making "things simple", resulting in less control, and more noise HTML, and less responsive sites. I admit the site isn't perfect, but a score of 84% easily outperforms 99% of all websites out there. And importantly, it was built in 3 days, and we'll continue working on it in the future to optimize it.

Page speed

This is "complicated". Our site by itself performs amazing. However, Google's reCAPTCHA JavaScript library unfortunately is "sub optimal" to be polite. If anybody there have advice on alternatives, I would love to hear about them in the comments. The irony is that Google is using page speed metrics to measure "quality of websites", resulting in improving your SERP positioning - For then to create a CAPTCHA library that blocks for 3 seconds, and downloads itself multiple times. I am not the first one to pinpoint out this simple fact. Unfortunately we must have CAPTCHA to prevent bots from sending us emails, so it's a bit of a catch 22 for us here.

I have even tried optimizing reCAPTCHA's JavaScript libraries manually, something you can see if you inspect the JavaScript on our landing page - But completely getting rid of the problem is simply not possible, or at least I don't know how. 98% of the penalty we're getting from Page Speed Insights originates from reCAPTCHA and Google Tag Manager. The irony ... :/

Still the site loads on my iPhone without WiFi on 5G in less than 3 seconds. Let us know how it loads on your phone in the comments. Without reCAPTCHA and Google Tag Manager it would have loaded in 0.5 seconds. Finally we registered a CloudFlare account, allowing us to significantly improve page loading by having an amazing CDN offering. We're still in the free version, so we don't have edge caching of documents - But in a week or two we'll probably have implemented this too.

Conclusion

Anyways, that's how we created a 1% website in 3 days, outperforming 99% of all sites out there on neutral metrics, with a budget of €7. Give us 3 months though, and it'll probably be in the 0.1% range.

As a final note, I have to give credits where credits are due, and the graphics was created entirely by Tage, whom I think did an amazing job not only creating great graphics, but also reducing the size of images significantly, which obviously is important when it comes to SEO and page speed metrics. Then of course, Aria helped out a lot, QA testing, helping out with words and such, and then as a final touch DALL-E created the images that Tage didn't create.

Using the following technologies we were able to create a 1% website in 3 days spending no more than €7 per month.

  • Hyperlambda and Magic Cloud
  • DALL-E
  • SEOBility
  • Page Speed Insights
  • CloudFlare
  • Visual Studio Code
  • Adobe Illustrator (Tage's tool)

Plus finally, €7 per month on servers from UpCloud - Simply an amazing cloud provider I've worked with for years.

TCO

7 EUROs per month, and 3 days worth of work, by 3 people, and we've got a "1% website". Below is a screenshot of the finished result, including a basic interaction with our chatbot. Not too bad for 7 bucks if you ask me ^_^

Make your Website Great Again

Psst, if you need a ChatGPT-based website chatbot such as ours, feel free to contact us for a quote. We are also looking for partners to help us sell our product if you're interested.

Top comments (26)

Collapse
 
jmfayard profile image
Jean-Michel 🕵🏻‍♂️ Fayard

The irony is that Google is using page speed metrics to measure "quality of websites", resulting in improving your SERP positioning - For then to create a CAPTCHA library that blocks for 3 seconds, and downloads itself multiple times

At big bureaucracies, the left hand doesn't know or care what the right hand is doing

Collapse
 
polterguy profile image
Thomas Hansen

I know. The last 5 to 10 years, there's been a significant degrading of Google's products, to the point where they're almost useless now. Try adding an SMTP email to your Google Business Suite account. I spent 3 hours trying to do it, and I couldn't figure it out ...

Collapse
 
jmfayard profile image
Jean-Michel 🕵🏻‍♂️ Fayard

Look at their hiring process.
To go to Google you have to be willing to waste a lot of time in their process, memorize the "groking the coding interview" book and plant red black trees in a Google docs.
At some point if you hire like, you get lots of people good at doing those things, which is not the same as people you would need to maintain products well

Thread Thread
 
polterguy profile image
Thomas Hansen

I remember when the used to be "the cool guys", back in the days - No more ... :/

Thread Thread
 
jmfayard profile image
Jean-Michel 🕵🏻‍♂️ Fayard

Absolutely, it was my dream company, that's why I don't hold my punches

Collapse
 
palalet profile image
RadekHavelka

Google code is plain crap. Lighthouse says "no document.write". Who breaks it gazzilion times? Google ads. Google translator, so slow to load. No cache / cdn. Poorly optimised JS and images. And so on, and so on ... they try to dictate how webs should look like yet to fail badly. Dont be evil. Yeah, right ....

Collapse
 
polterguy profile image
Thomas Hansen

Their stuff isn't even minimised for the most part, so yes, their code is crap. Interestingly, I wouldn't even consider hiring a dev myself producing stuff such as this. Yet at Google, I assume these devs are paid 200K+ per year ... :/

Collapse
 
jahilldev profile image
James Hill

Regarding reCaptcha, one suggestion from me would be to only load the script when required for the UI.

One example would be to only load the reCaptcha script on form focus, or when a Modal opens, etc. That way we're pretty sure of the users intent.

I've seen great results from this on a variety of third-party scripts.

Collapse
 
polterguy profile image
Thomas Hansen

Hmm, that's actually a pretty amazing suggestion - Thx mate, sound of me going back to my JavaScript ^_^

Collapse
 
jodumont profile image
JOnathan duMonT

Make a contact page and only load the captcha on that page will spear the rest of your website

Collapse
 
polterguy profile image
Thomas Hansen

Actually, I had the exact same idea today myself. I've already almost implemented it, and it speeds up things a lot. Thank you for the advice, it's a brilliant idea :)

Collapse
 
webdynamics profile image
Vlado Petrushevski

I applaude your attitude to build a profitable solution without much hesitation... But aren't there already too many chatGPT solutions?.... How do you plan to market your solution, how are you sure it is gonna be profitable?

Collapse
 
polterguy profile image
Thomas Hansen

We were the first one actually, in a "different company" though (75% of the team, same tech), so I could return the question. However, we've got a "bajillion" features in ours - Check it out here ==> Trump Chatbot

Collapse
 
webdynamics profile image
Vlado Petrushevski

I will take a look at it, thanks... Anyways, best of luck in your endeavor

Thread Thread
 
polterguy profile image
Thomas Hansen

Thank you :)

Collapse
 
miketalbot profile image
Mike Talbot ⭐

I love how you've pulled these threads together, congrats!

Collapse
 
polterguy profile image
Thomas Hansen

Thx Mike, it was a rough week though ;)

Collapse
 
szeredaiakos profile image
szeredaiakos

The good ol says of pixel perfect html at breakneck speed. I miss that.

Collapse
 
polterguy profile image
Thomas Hansen

You don't need to miss it. Even if you don't want to use Hyperlambda, you've still got Jekyll and others providing similar stuff. Of course, Hyperlambda does server side rendering, while Jekyll is a build pipeline - However, if you're OK with combining your stuff with an HTTP API, even Jekyll should suffice ... :)

However, yes you're right, I missed it too - So much I figured I'd bring it back, and created a Hyperlambda resolver giving my dynamic Hyperlambda-based "server side includes" allowing me to (still) dynamically build HTML on the server for SEO purposes and such ...

Collapse
 
shbick profile image
shbick

I load recaptcha after user interaction (click, scroll, etc...)

Collapse
 
polterguy profile image
Thomas Hansen

It is a brilliant idea actually. Thank you ^_^

Collapse
 
tageleander profile image
TageLeander

Incredible work!

Collapse
 
polterguy profile image
Thomas Hansen

Thx mate, amazing team becomes brilliant products ^_^

Collapse
 
arianygard profile image
AriaNygard

Amazing work, with amazing technology!

Collapse
 
marsavela profile image
Sergiu Marsavela

I don't think you'll ever manage to get to the 0.1%

You might get to 1‰ thought.

👍Keep up the great work.

Collapse
 
polterguy profile image
Thomas Hansen

Hahahaha, thank you, I stand corrected!!