acollins1991 / biglight-test

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

biglight-test

To run this repo:

  • Create a .env file from the .env-example file and populate with the required values (I can provide these)
  • Install npm packages: npm i
  • Run and serve in production mode: npm run serve:prod
  • Open http://localhost:3000 in a browser

Approach

Client side

I have taken a 'bare bones' approach in building the client-side assets, only using modern-normalize and custom CSS to keep the client-side assets as small as possible. I've used BEM syntax to build the CSS for the frontend components.

The CSS and JS are bundled using Webpack for optimisations, although this is just to show usage of a bundler as the JS only includes the lazy load functionality.

Backend

The backend uses the EJS templating engine to manage page data, templates and partials, and I have used the google-spreadsheet npm package to connect with the spreadsheet and inject data.

Lighthouse scores

Performance scores are 97-100/100. Biggest markdown relates to the connection with the Google Spreadsheet.

Improvements

  • The connection with the Google Spreadsheet is quite slow. I started out using cell targeting to get content, but using rows might have been more efficient
  • 'loadInfo' to setup the spreadsheet connection could be shared via some form of singleton class pattern so that it's only done on the first page
  • Single-page app implementation (barba.js e.g.) for better user experience (page transitions e.g.)
  • Code splitting with Webpack was the original intention but wasn't necessary given the small amount of JS involved
  • Use ES modules to only import the JS when necessary
  • A static generator approach would help resolve the spreadsheet connection speed problem, favoured method for this would be a mixture of Webpack and Gulp
  • Not flagged by Google Lighthouse but inlining critical CSS to avoid render blocking
  • Responsive behaviour, but not necessary given the design other than srcset
  • Reorganise the project structure to follow the MVC pattern
  • Create multiple webpack configs for base, dev, and production
  • A test suite using Jest, chai and JSDOM
  • Upload a favicon to stop 404 error following browser automatic request
  • Use PostCSS to purge unused CSS classes
  • In a live project a CDN would speed up asset serving. A potential static setup would be AWS S3 and Cloudfront.

Gatsby and WordPress

Gatsby is a high-level framework built on top of React, providing utilities to speed up development of advanced and high-performance web apps using static generation. The static architecture benefits from better server response time as the assets are pre-built, improved security as there is no attached backend, and fewer points of failure because the site simply serves static content and does not need to build anything when the server received a request.

The WordPress REST API exposes the stored content via endpoints, which could be consumed by the a Gatsby setup, however Gatsby's own documentation on integrating with WordPress does not suggest this. Instead it directs the users to install plugins on the WordPress CMS to enable a GraphQL service exposing the content, and using the gatsby-source-wordpress plugin.

PRPL

PRPL stands for; Push, Render, Pre-cache, Lazy Load. This described a web app architecture designed Google to improve web app performance, and is a core principal behind how Gatsby works. The main objective of this architecture is to load the critical client assets as early as possible, render the initial route, and lazy load the remaining assets for the initial route and other routes.

About


Languages

Language:JavaScript 61.1%Language:HTML 24.0%Language:SCSS 14.9%