Full disclaimer: This project is being developed as I learn to program, so expect rookie patterns and errors.
This project is created with a Rust and serverless function backend and NextJS frontend while new code is deployed with every commit on Github to the Vercel cloud platform.
The discovery user interface is based on the Danish Library Infrastructure Platform (FBI API).
- Display detailed information about works, including titles, authors, abstract, publication dates, material types, subjects, and more.
- The page now dynamically fetches work details using the new api/work endpoint powered Rust matching the api/search endpoint.
- Rust backend with integration to FBI-API
- Access token is retrieved from the Access Platform
- Access token is reused for every API request in a browser session
- Request parameters are mirrored in the site URL
- Changes to URL parameters will initiate a new search request
- New search result page
- Skeleton screen for better perceived performance
- Piwik Pro integration for user analytics
- Introduction to the website
I use a very simple build pipeline where every commit to Github deploys the site on the Vercel cloud platform.
After committing code to Github you can se the build process under https://vercel.com/dashboard for the corresponding project.
Example: https://rolfmadsen.dk/
It has been a while since I had to reestablish my local development environment, and as the setup is estblished manually, view the following chapters as inspiration as they have not recently been tested.
I have installed Ubuntu on a laptop for my local development environment.
curl -fsSL https://deb.nodesource.com/setup_20.x | sudo -E bash -
_Kilde: https://github.com/nodesource/distributions/blob/master/README.md#debinstall _
sudo apt -y install nodejs
node -v
sudo apt update
sudo apt install git
git --version
Configure your name:
git config --global user.name "ENTER YOUR NAME"
Configure your e-mail-addresse:
git config --global user.email "GITHUB-USERNAME@users.noreply.github.com E-MAIL-ADDRESSE"
NB. Find your Github no-reply e-mail-adress under https://github.com/settings/emails.
See configuration:
git config --list
npm i -g vercel
vercel -v
NB. When running $ "vercel -v" I got the response "command not found" and had to use $ "npm install -g npm".
If you clone this repository and setup a local development environment you can use the Vercel CLI to retrieve your environment variables using the "vercel env pull" command.
N.B. If you encounter the error message: "Error! The specified token is not valid" try "vercel logout" and "vercel login".
Clone the code repository on Github to Github directory on your local development environment.
mkdir Github && cd Github
git clone https//github.com/rolfmadsen/rolfmadsen.git
Install all dependencies:
npm install
- Login (https://vercel.com/login) or create account (https://vercel.com/signup) on Vercel.
- Create a new project (https://vercel.com/new).
- Select "Add GitHub Org or Account".
Login to Vercel from terminal:
vercel login
Link local development environment to Vercel project:
vercel link
Run project on localhost for testing before you commit changes to Github:
vercel dev
- Open https://github.com/settings/tokens
- Click "Generate new token"
- Add token name
- Select scopes/permissions by clicking repo checkmark
- Click "Generate token"
- Copy the token to your preferred password manager
- Open your terminal and navigate to local project directory
- Remove old origin remote:
$ git remote remove origin
- Add new origin remote:
$ git remote add origin https://{TOKEN}@github.com/{USERNAME}/{REPOSITORY}.git
First set up Vercel to build a staging site when you push changes to your staging branch in your Github organization:
- Open https://vercel.com/[ENTER YOUR ORGANIZATION]/rolfmadsen/settings/domains
- Add "staging.[ENTER YOUR DOMAIN].dk"
- Add "https://github.com/[ENTER YOUR ORGANIZATION]/rolfmadsen/tree/staging"
Create staging branch
git branch staging
Shift to staging branch
git checkout staging
Perform the changes you wish on the staging branch.
Shift to master branch
git checkout master
Add the changes made on the staging branch to the master branch.
git merge staging
Push the merged changes on the master branch to origin (Github master branch)
git push
Stage all changes in the current directory and sub-directories:
Show status of working tree/directory and staging area:
git status
Add or track all files from working tree/directory to staging area:
git add .
NB. Add specific files by exchanging "." with the "file-name".
See the history of changes to the repository:
git log --all --decorate --oneline --graph
NB. You can use graph as an alias for the previous "git log" command via:
alias graph="git log --all --decorate --oneline --graph"
See the difference between working tree/direcotr and staging area:
git diff
Saves all changes to the local repository:
git commit -m "ENTER A DESCRIPTION OF THE CHANGE"
Upload all changes from the local repository to the master of the remote repository:
git push
NB. When you push you will be promptet to login to Github and you can use a Github Token for use as a password in the terminal under https://github.com/settings/tokens.
Get updates from remote repository:
git pull
Close staging branch
NB. Checkout master branch before deleting staging branch.
git checkout master
git branch -d staging
- Find the Piwik ID and URL under https://{account_name}.piwik.pro/administration/apps
- Add Piwik variables to https://vercel.com/{account_name}/{project_name}/settings/environment-variables
NEXT_PUBLIC_CONTAINER_ID NEXT_PUBLIC_CONTAINER_URL
"""js function Layout({ children }) { return
export default Layout """
import '../styles/index.scss';
function App({ Component, pageProps }) {
return <Component {...pageProps} />;
}
export default App;
@tailwind base;
h1 {
@apply text-2xl;
}
h2 {
@apply text-xl;
}
h3 {
@apply text-lg;
}
a {
@apply text-blue-600 underline;
}
@font-face {
font-family: Proxima Nova;
font-weight: 400;
src: url(/fonts/proxima-nova/400-regular.woff) format("woff");
}
@font-face {
font-family: Proxima Nova;
font-weight: 500;
src: url(/fonts/proxima-nova/500-medium.woff) format("woff");
}
@tailwind components;
@tailwind utilities;
html,
body,
#__next {
height: 100%;
}
.transition-color-shadow {
transition-property: color, background-color, box-shadow;
}
module.exports = {
plugins: [
'tailwindcss',
'postcss-preset-env'
],
};
module.exports = {
purge: ['./src/components/**/*.tsx', './src/pages/**/*.tsx'],
theme: {
screens: {
xsm: '414px',
sm: '640px',
md: '768px',
lg: '1024px',
xl: '1280px',
},
extend: {},
},
variants: {},
plugins: [],
};
{
"browserslist": [">0.3%", "not ie 11", "not dead", "not op_mini all"]
}
- https://github.com/vercel/next.js/tree/canary/examples/with-tailwindcss
- https://nextjs.org/learn/basics/assets-metadata-css/layout-component
- https://nextjs.org/learn/basics/assets-metadata-css/global-styles
- Consider useing PurgeCSS to removed unused styles from Tailwind CSS. (Source: https://khanna.cc/blog/using-tailwind-ui-and-next-js-together/ - 3. Optimize for production with PurgeCSS.)