Nextjs - How to Redirect to Another Page and Pass State
Introduction We have a page, for example a . And, upon submission we would want…
May 02, 2021
In our previous posts, we have seen How to Create Article in Strapi by REST APIs.
For SEO purpose, you would want that the article URL will have some nice english characters, like title.
In this post, we will configure article content type to have a slug field based on the title.
slug
Auto generated slug
After this, we need to write little code to generate slug.
Edit /api/article/models/article.js
, and put below code:
'use strict';
/**
* Read the documentation (https://strapi.io/documentation/developer-docs/latest/development/backend-customization.html#lifecycle-hooks)
* to customize this model
*/
const slugify = require('slugify');
const getUniqueSlug = async (title, num=0) => {
let input = `${title}`;
if (num > 0) {
input = `${title}-${num}`;
}
const slug = slugify(input, {
lower: true
});
const [article] = await strapi.services.article.find({
slug: slug
});
if (!article){
return slug;
}
else {
return getUniqueSlug(title, num+1);
}
}
module.exports = {
lifecycles: {
beforeCreate: async (data) => {
data.slug = await getUniqueSlug(data.title);
},
},
};
In above code, we are using a new module: slugify
.
Install it via: npm i slugify
Also, I have written a custom function getUniqueSlug
to get a unique slug.
Otherwise, if two users write the same title. My slug will have same string. And, I did not want to give error to users to have unique title across.
Lets look at the examples below:
# title = How to do Exercise
# Slug will be
how-to-do-exercise
# Another user write same title,
# Now the slug will be
how-to-do-exercise-1
# Another user write same title,
# Now the slug will be
how-to-do-exercise-2
Note: Till now we have just populated the slug field. You would not see this slug in the actual URL. For this, now we will need to look at the frontend part.
See out next post for a dive into the frontend with Next.js
Introduction We have a page, for example a . And, upon submission we would want…
Introduction In this post, we will see How to load external images to your next…
Introduction This post is in contuation of our previous post: How to use Draft…
Agenda I will cover following in this post: Prepare Docker image for Next.js app…
Introduction I have my main website, which I run on Lets say: . Now, there is my…
Introduction In this step-by-step tutorial, we will setup strapi headless CMS…
Introduction In this post we will see following: How to schedule a job on cron…
Introduction There are some cases, where I need another git repository while…
Introduction In this post, we will see how to fetch multiple credentials and…
Introduction I have an automation script, that I want to run on different…
Introduction I had to write a CICD system for one of our project. I had to…
Introduction Java log4j has many ways to initialize and append the desired…