Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/borjamrd/ngx-notion-cms

Unnoficial Notion renderer for Angular: display your posts, docs or proyects easily from Notion
https://github.com/borjamrd/ngx-notion-cms

angular blogging cms notion

Last synced: about 1 month ago
JSON representation

Unnoficial Notion renderer for Angular: display your posts, docs or proyects easily from Notion

Awesome Lists containing this project

README

        

![Alt text](public/ngx-notion-cms-rounded.png)

Render your Notion content through your Angular application as a CMS.
Possible uses:

- 💡 Write your blog
- 🚀 Showcase your projects
- 📄 Write documentation

Huge thanks to [react-notion](https://github.com/splitbee/react-notion), this library simulates much of what they have previously created with React. ❤️

_This package doesn't handle the communication with the API. Check out [notion-api-worker](https://github.com/splitbee/notion-api-worker) for an easy solution_.

Created by Borja Muñoz with the help of all contributors

## Table of Contents

1. [Type of content](#type-of-content)
2. [Get started](#get-started)
3. [Global Options](#aditional-options)
4. [Supported blocks](#supported-blocks)

## Type of content

You can display any content you want and configure your style to your liking. But we offer you these two options by default:

- Post: which allows you to use all the potential of Notion to write your best articles.
- Project: to showcase your projects in an attractive visual format.

For both, only the styles change, the components are the same:

- Notion databases: display multiple items
- Notion pages: display the content in blocks for each item.

## Get started

```bash
npm install ngx-notion-cms
```

Import the providers in your `app.config.ts`

```typescript
import { globalSettingsProvider } from 'ngx-notion-cms';
import { provideHttpClient } from '@angular/common/http';

export const appConfig: ApplicationConfig = {
providers: [
provideHttpClient(),
globalSettingsProvider({}), //you can pass global settings here,
],
};
```

If you want to use the default Tailwind classes you must import this in your `styles.css`

```css
@import 'ngx-notion-cms/styles';
```

### Code Highlight

If you are going to use code blocks ``ngx-notion-cms` uses `ngx-hightlightsjs` under the hood. Here is the configuration:

```bash
npm install ngx-highlightjs
```

```typescript
import { globalSettingsProvider } from 'ngx-notion-cms';
import { provideHttpClient } from '@angular/common/http';
import { provideHighlightOptions } from 'ngx-highlightjs';

export const appConfig: ApplicationConfig = {
providers: [
provideHttpClient(),
globalSettingsProvider({}), //you can pass global settings here,
provideHighlightOptions({
fullLibraryLoader: () => import('highlight.js'),
lineNumbersLoader: () => import('ngx-highlightjs/line-numbers'),
}),
],
};
```

## Example

### Add database component

### Add page component

### Global Options

By default, global options are configured that are easily modified. For example, in case we want the images of the articles in the databases to not be displayed:

```typescript
import { globalSettingsProvider } from 'ngx-notion-cms';

export const appConfig: ApplicationConfig = {
providers: [
// ....
globalSettingsProvider({
cacheOptions: {
stateTime: 100000,
storeInCache: true,
},
database: {
showImage: false,
},
page: {
showTableOfContents: true,
},
}),
],
};
```

## Supported Blocks

Most common block types are supported. We happily accept pull requests to add support for the missing blocks.

| Block Type | Supported | Notes |
| ----------------- | ---------- | -------------------- |
| Table Of Contents | ✅ Yes |
| Text | ✅ Yes | |
| Heading | ✅ Yes | |
| Image | ✅ Yes | |
| Image Caption | ❌ Missing | |
| Bulleted List | ✅ Yes | |
| Numbered List | ✅ Yes | |
| Quote | ✅ Yes | |
| Callout | ✅ Yes | |
| Column | ✅ Yes | |
| iframe | ✅ Yes | |
| Video | ✅ Yes | Only embedded videos |
| Divider | ✅ Yes | |
| Link | ✅ Yes | |
| Code | ✅ Yes | |
| Web Bookmark | ✅ Yes | |
| Toggle List | ❌ Missing | |
| Page Links | ✅ Yes | |
| Header | ❌ Missing | |
| Databases | ❌ Missing |
| Checkbox | ❌ Missing |