markdown2notion

Convert markdown files to notion database. The folder structure is also fully represented as tags in notion.
Please refer to here for how to issue notion token and how to link with DB.
๐ Links
ๆฅๆฌ่ชใฎ่ชฌๆๆธ๐JP-README.md
๐ฝ Installation
npm install markdown2notion
yarn add markdown2notion
๐ง Usage
javascript and typescript are supported.
markdownToNotion()
import {markdownToNotion} from 'markdown2notion'
async function main(){
try{
await markdownToNotion(
'notion token',
'notion database id',
'markdown folder path',
'Column of notion displaying file names. Default is Title',
'Column of notion displaying folder name as tag. Default is Tags'
)
} catch (error) {
console.error(error);
}
}
searchPage()
Since the URL of the page changes every time you use markdownToNotion(), if you want to do something with the URL, please use this function to get the URL of the page.
import {searchPage} from 'markdown2notion'
async function main(){
try{
const result = await searchPage(
'notion token',
'notion database id',
'Column of notion displaying file names. Default is Title',
'Column of notion displaying folder name as tag. Default is Tags',
'search file name',
'search tags name array'
)
console.log(result)
} catch (error) {
console.error(error);
}
}
๐ฐ Example
๐ฝmarkdownToNotion()
markdown folder structure
โโโ docs
โ โโโ sample1
โ โ โโโ sample1_1
โ โ โ โโโ sampleContent1_1.md
โ โ โโโ sampleContent1.md
โ โโโ sample2
โ โ โโโ sampleContent2.md
โโโ src
โ โโโ index.ts
โโโ .env
notion DB

markdown files
Sample Markdown Folder
index.ts
import {markdownToNotion} from 'markdown2notion'
import * as dotenv from 'dotenv'
async function main() {
dotenv.config()
const token = process.env.NOTION_TOKEN
const databaseId = process.env.NOTION_DATABASE_ID
try {
await markdownToNotion(token, databaseId, 'docs', 'Title', 'Tags');
} catch (error) {
console.error(error);
}
}
main()
.env
NOTION_TOKEN=secret_xxxxxxxxxxxxxx
NOTION_DATABASE_ID=xxxxxxxxxxxxxxx
Result
The folder name becomes a tag.

Filtering using tags makes it easier to access specific files.

๐ฝsearchPage()
index.ts
import {searchPage} from 'markdown2notion'
import * as dotenv from 'dotenv'
async function main() {
dotenv.config()
const token = process.env.NOTION_TOKEN
const databaseId = process.env.NOTION_DATABASE_ID
const title = 'sampleContent1_1';
const tags = ['sample1_1'];
try {
const result = await searchPage(token, databaseId, 'Title', 'Tags', title, tags);
console.log(result['results'][0]['url']);
} catch (error) {
console.error('Error searching for page:', error);
}
}
main()
result
{
object: 'list',
results: [
{
object: 'page',
id: '33.....',
created_time: '2023-03-29T14:15:00.000Z',
last_edited_time: '2023-03-29T14:15:00.000Z',
created_by: [Object],
last_edited_by: [Object],
cover: null,
icon: null,
parent: [Object],
archived: false,
properties: [Object],
url: 'https://www.notion.so/sampleContent1_1-33...'
}
],
next_cursor: null,
has_more: false,
type: 'page',
page: {}
}
๐ Important Point
If there is a page with the same filename on the DB of notion to be operated on, it will be overwritten.
License
MIT