Infofinland Nextjs-frontend for headless drupal site. Drupal integration is implemented using next-drupal module.
See also https://github.com/City-of-Helsinki/drupal-infofinland for instructions on running corresponding Drupal site locally.
Install Yarn if not already installed
npm install -g yarn
Clone the InfoFinland UI repo
git clone [email protected]:City-of-Helsinki/infofinland-ui.git
cd info-finland-ui
git checkout dev
git checkout -b feature/newstuff
Install dependencies
yarn
Copy one of .env.example.local
,.env.example.dev
or .env.example.production
to .env.local. This is a .gitignore
d local checkout's env file. Modify it as you need, depending on which drupal instance you want to connect to.
Required environment variables are
NEXT_PUBLIC_DRUPAL_BASE_URL='https://url-to-site.com
NEXT_IMAGE_DOMAIN=image.domain.com
DRUPAL_SITE_ID=THE SITE ID HASH FROM DRUPAL INSTANCE
DRUPAL_FRONT_PAGE=/
DRUPAL_PREVIEW_SECRET=PREVIEW SECRET FROM DRUPAL INSTANCE
DRUPAL_CLIENT_ID=PREVIEW CLIENT ID HASH FROM DRUPAL INSTANCE
DRUPAL_CLIENT_SECRET=CLIENT_SECRET FROM DRUPAL INSTANCE
# Use this if your dev connection does not have a signed certificate
NODE_TLS_REJECT_UNAUTHORIZED=0
#Always make sure this is set to 0
NEXT_TELEMETRY_DISABLED=0
yarn dev
Go to localhost:3000
in your browser.
Make changes to your feature branch, run linter. This project uses ESlint NextJS plugin rules and ESLint Tailwind plugin rules.
yarn next lint
Format your code before committing. You can set your IDE to run prettier automaticallt but if you dont, run it manually before you commit. For now, there are no precommit tasks.
yarn format
Run all tests (again, but now if you didn't). Check all snapshots, make sure you include new tests for new code.
yarn test
Use watch-mode for test runner
yarn test --watch
Commit to you feature branch, push to repo, make a merge request.
Preferred editor is VSCode but any editor or IDE is quite fine. Just remember to use Editorconfig.
VSCode with the following extensions:
- Editorconfig (see .editorconfig)
- Docker
- ENV (file type support for .env files)
- ESLint
- Prettier (See .prettierrc)
- Prettier ESlint
- TailwindCSS Intellisense, Tailwind Docs
- Azure toolkit, Azure CLI Tools
TODO: Check env variables in docker container
Ensure you have set next-drupal environment variables.
You may create a local .env.producion
file using the .env.example
files
Make a build and start Nextjs server. See localhost:3000
yarn build && yarn start
Build Dockerfile, start container. See localhost:8080
- Check environment variables (TODO instructions here)
- Install Docker Extension if not installed
- Build image
- Right-click on Dockerfile, select Build Image. (no build-args)
- or run from command line
docker build --build-arg [NEXT_DRUPAL_SITE_ID|and other variables]='env values to docker container' -t infofinlandui .
OR (but you need to clear all comments from env file)
docker build -t infofinlandui $(for i in `cat .env.local`; do out+="--build-arg $i " ; done; echo $out;out="") .
- Check that image is built without errors.
- Select the new image from Docker-tab, Run Interactive, See localhost:8080.
This project uses TailwindCSS for styling. In this project we AVOID using any CSS-in-JS or other dynamic styling techniques.
Use Tailwind classes as much as possible. Custom classes use BEM marking with ifu-prefix to differentiate custom classes from Tailwind classes.
All component class collections can be converted to custom class using Tailwind classes with @apply. Prefer this, especially when dealing with spacing and other relational units.
EXAMPLE:
.ifu-block__element--modifier {
@apply text-body-small text-blue-white shadow hover:text-blue-light;
}
The project includes a Tailwind config viewer for inspecting and developing desing assets and tokens.
yarn twconfig
In the UI, use React SVG components as much as possible.
Static UI texts are localized with next-i18next.
See public/locales/[locale]/common.json
. Page-level localization files are not required at this point but can be added as needed.
Dont use {process.env}
directly in application runtime code.
Use next/config
getConfig().serverRuntimeConfig
and getConfig().publicRuntimeConfig
instead to avoid building env variables directly as strings to build files.
Basic pages use a set of menus from Drupal. These are configured as environment variables in next.config.js and accessed via getConfig(). You may pass them as env variables as well if you need to configure them by site. Just remove them from next.confing.js
env
object.
// next.config.js
const env = {
...
//Remove these
DRUPAL_MENUS: {
MAIN: 'main',
FOOTER: 'footer-about',
ABOUT: 'about',
CITIES:'cities',
CITIES_LANDING:'cities-landing'
},
serverRuntimeConfig: {
//And move here.
DRUPAL_MENUS: {
MAIN: process.env.DRUPAL_MENU_MAIN //for example. Set this in your env variables
...
TODO/Discuss: Hardcode to next.config or env vars?
Automatic static optimization revalidates page content every XX seconds. Change this if you need to to optimize page refreshing time and server loads.
// next.config.js
const env = {
... REVALIDATE_TIME: 60, //seconds
TODO/Discuss: Hardcode to next.config or env vars?
// next.config.js
const env = {
FB_URL: 'https://www.facebook.com/infofinland.fi',
INSTAGRAM_URL: 'https://www.instagram.com/infofinland.fi/',
YOUTUBE_URL: 'https://www.youtube.com/c/infofinland',
TWITTER_URL: 'https://twitter.com/InfoFinlandfi',
TODO/Discuss: Hardcode to next.config or env vars?
List of locales to be prerendered in buildtime/static optimization cycle
This may create request burst so use with discression.
Currenlty prerendering is disabled due to insufficient dev capacity.
See async getStaticPaths()
in /pages
files.
// next.config.js
const env = {
...
PRERENDER_LOCALES: ['fi', 'en', 'sv', 'ar', 'ru'],
...
TODO/Discuss: Hardcode to next.config or env vars?
The URL for cookie consent page. This is used by the cookie consent banner and cookie consent page to ensure that the banner is not shown when we are on the consent page.
// next.config.js
const env = {
...
COOKIE_PAGE_PATH: '/about/cookie-settings',
...
Images loaded from Drupal (or anywhere else than static imports or nextjs app) need CORS permissions. Add all drupal domains here
// next.config.js
module.exports = {
images: {
// populate all envs here
domains: [
'drupal-infofinland.docker.so',
'nginx-infofinland-drupal-dev.agw.arodevtest.hel.fi'
],
},
The root page of the site is mapped to a specific node
in in drupal instance. The default value in drupal should be set to a Landing Page type, assumed /landingpage
Make sure your drupal instance contains one Landing Page
with matching url to Drupal Basic Settings:: Front Page (/landingpage
by convention).
TODO