| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | # Create a slug system
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-29 20:54:19 +01:00
										 |  |  | This guide will explain how to create a slug system for a Post, Article or any Content Type you want. | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ## Create attributes
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-29 20:54:19 +01:00
										 |  |  | To start building your slug system you need a `string` field as a **base** for your slug, in this example we will use `title`. | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-29 20:54:19 +01:00
										 |  |  | You will also need another `string` field that contains the slugified value of your `title`, in this case we will use `slug`. | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Configure the layout for the content editor
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Let's configure the layout of the **edit page** to make it more user friendly for the content editor. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-08 16:04:57 +01:00
										 |  |  | - Click on the **Article** link in the left menu. | 
					
						
							|  |  |  | - Then on the `+ Add New Article` button. | 
					
						
							| 
									
										
										
										
											2020-03-30 13:34:47 +05:45
										 |  |  | - And finally on the `Configure the layout` button. | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | Here we will be able to setup the `slug` field. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - Click on the `slug` field. | 
					
						
							|  |  |  | - At the bottom of the page, edit the **placeholder** value to `Generated automatically based on the title`. | 
					
						
							|  |  |  | - And click **OFF** for **Editable field** option. | 
					
						
							|  |  |  | - Don't forget to save your updates. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 12:05:39 +01:00
										 |  |  | :::: tabs | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 12:05:39 +01:00
										 |  |  | ::: tab "View before" | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 12:05:39 +01:00
										 |  |  |  | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ::: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 12:05:39 +01:00
										 |  |  | ::: tab "View after" | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 12:05:39 +01:00
										 |  |  |  | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ::: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 12:05:39 +01:00
										 |  |  | ::: tab "View configuration" | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :::: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Auto create/update the `slug` attribute
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | For that you will have to install `slugify` node module in your application. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | When it's done, you have to update the life cycle of the **Article** Content Type to auto complete the `slug` field. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | **Path —** `./api/article/models/Article.js` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 12:05:39 +01:00
										 |  |  | :::: tabs | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 12:05:39 +01:00
										 |  |  | ::: tab Mongoose | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```js | 
					
						
							|  |  |  | const slugify = require('slugify'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module.exports = { | 
					
						
							|  |  |  |   beforeSave: async model => { | 
					
						
							|  |  |  |     if (model.title) { | 
					
						
							|  |  |  |       model.slug = slugify(model.title); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   beforeUpdate: async model => { | 
					
						
							| 
									
										
										
										
											2020-01-20 14:41:10 +01:00
										 |  |  |     if (model.getUpdate() && model.getUpdate().title) { | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  |       model.update({ | 
					
						
							|  |  |  |         slug: slugify(model.getUpdate().title), | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 12:05:39 +01:00
										 |  |  | ::: tab Bookshelf | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```js | 
					
						
							|  |  |  | const slugify = require('slugify'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module.exports = { | 
					
						
							|  |  |  |   beforeSave: async (model, attrs, options) => { | 
					
						
							|  |  |  |     if (options.method === 'insert' && attrs.title) { | 
					
						
							|  |  |  |       model.set('slug', slugify(attrs.title)); | 
					
						
							|  |  |  |     } else if (options.method === 'update' && attrs.title) { | 
					
						
							|  |  |  |       attrs.slug = slugify(attrs.title); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-11-12 17:26:48 +01:00
										 |  |  |   }, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ::: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :::: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Fetch article by `slug`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-22 13:28:03 -04:00
										 |  |  | Then you will be able to fetch your **Articles** by this slug. | 
					
						
							| 
									
										
										
										
											2019-10-29 19:27:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | You will be able to find your articles by slug with this request `GET /articles?slug=my-article-slug` |