VercelとNotionを連動させる手順は以下の通りです。この手順は、Next.js Notion Starter Kitを使用している場合の手順です。※VercelとNotionのアカウントを持っていることが前提です。
Next.js Notion Starter Kitのセットアップ
- Next.js Notion Starter Kitのリポジトリをクローンします。またはGithubにフォークするか、コードをダウンロードして、ローカルのGithub上にコピーしてCommit、Pushします。
data:image/s3,"s3://crabby-images/7f418/7f418497272db53c03b8882a037791f430330c1a" alt=""
data:image/s3,"s3://crabby-images/2f54e/2f54ebb4aae584d14e63f4e45a790d33ba00a6e0" alt=""
data:image/s3,"s3://crabby-images/8124b/8124bb81dafa30f19b11f736a1e2138dd87c3797" alt=""
プロジェクトの新規作成
Projectの新規作成をします。
New>「Project」をクリックし、リポジトリをインポートします。Push OriginしたNext.js Notion Starter Kitのリポジトリを選択します。
data:image/s3,"s3://crabby-images/17cff/17cffaf726ee55b71f1daab8349e74ed579ef276" alt=""
data:image/s3,"s3://crabby-images/4656f/4656f48922f60267ddfaf42390038846935c1644" alt=""
Deployします。
data:image/s3,"s3://crabby-images/a27c1/a27c1a5e79a7e90019895bdab2f9408bef532afd" alt=""
サイトが公開されました!
data:image/s3,"s3://crabby-images/5fe49/5fe49d74d873d446daa76d8c4afbb1c4f4220bb1" alt=""
この時点では、まだテンプレートのサイトが公開された状態になっているので、Notionと連携させます。
Notionの設定
- Notionにログインし、新しいページを作成します。このページは、Next.jsアプリケーションに表示するコンテンツを含むページになります。
- ページ内にテキスト、画像、リンク、テーブルなどのブロックを追加します。これらのブロックがNext.jsアプリケーションに表示されます。
- Webページとして公開します。
data:image/s3,"s3://crabby-images/c542d/c542d6553c2d9e31497c68bf98830016b2549793" alt=""
Webページが公開されました。
data:image/s3,"s3://crabby-images/23b0a/23b0a7e6f8a59ef69a6b2e80e9608c80602a7d71" alt=""
公開ページURL:
https://tidy-match-f2e.notion.site/bd4523a79a0a46ad83780259aa873df2?pvs=4
「bd4523a79a0a46ad83780259aa873df2」の部分がページIDとなります。
こちらをコピーして控えます。
Vercelとの連携
Next.js Notion Starter Kitのりリポジトリ上に「site.config.ts」という名称のファイルがあります。
data:image/s3,"s3://crabby-images/bb62e/bb62e2b15438e03951da97f15746e5d49e33d4e6" alt=""
この中にrootNotionPageIdという場所があるので、こちらに先ほどコピーしたNotionのPageIdを設定します。
[rml_read_more]
import { siteConfig } from './lib/site-config'
export default siteConfig({
// the site's root Notion page (required)
rootNotionPageId: 'your-pageIdXXXXXXXXXXXX',
// if you want to restrict pages to a single notion workspace (optional)
// (this should be a Notion ID; see the docs for how to extract this)
rootNotionSpaceId: null,
あとは、Pushしてデプロイを待つと、NotionのページがVercelに公開された状態になります。
NotionのページがVercel上に公開されて自動連携できました!
data:image/s3,"s3://crabby-images/f9476/f9476705b36e563d9430df84f83f3ed738c502db" alt=""
まとめ
これで、Vercel上にデプロイされたNext.jsアプリケーションがNotionのデータにアクセスできるようになります。Notionのページを編集すると、Next.jsアプリケーションに反映されます。
ただし、Notion APIの機能や仕様が変更されている可能性もあるので、公式ドキュメントなどで最新の情報を確認してください。また、セキュリティ上の理由から、Notionのトークンなどの重要な情報を公開されないようにしてください。