Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/skyybbanerjee/temp-contentful-cms-app

contentful-cms project ⚛️
https://github.com/skyybbanerjee/temp-contentful-cms-app

Last synced: 3 days ago
JSON representation

contentful-cms project ⚛️

Awesome Lists containing this project

README

        

## Figma URL

[Contentful](https://www.figma.com/file/XtVr3JRCGWyZESYxd9EhZK/Contentful?node-id=0%3A1&t=SNnU6FgNUQXktIFb-1)

## Steps

#### Install and Setup

- npm install
- npm run dev

#### Structure

Create Hero and Projects components

#### Hero

Setup Hero component.

#### Nice Images

[Undraw](https://undraw.co/)

#### Data

Explore data.js

#### Headless CMS

A headless CMS is a back-end only content management system that provides content creators with an intuitive interface for creating and managing content, while leaving the front-end presentation layer to be handled by a separate system or platform. This approach allows for greater flexibility and scalability, as the content can be easily distributed to multiple channels and devices, without being limited by the constraints of a particular front-end system.

#### Contentful

Create a Contentful account

[Contentful ](https://www.contentful.com/)

##### Create Data

Setup content type and create few entries

#### Explore API

Get Space ID, Access Token and explore code examples.

#### Install SDK

- npm install contentful

#### Get Entries

```js
import { createClient } from 'contentful';

const client = createClient({
space: 'qz00uzgg3leh',
environment: 'master', // defaults to 'master' if not set
accessToken: import.meta.env.VITE_API_KEY,
});

client
.getEntries({ content_type: 'projects' })
.then((response) => console.log(response.items))
.catch(console.error);
```

#### Custom Hook

Create custom hook with loading and projects state values.

#### Parse Data

Setup projects array

#### Setup Products Component

Render data in Products component