{"id":2573,"date":"2023-07-15T10:23:53","date_gmt":"2023-07-15T01:23:53","guid":{"rendered":"https:\/\/www.agile-software.site\/?p=2573"},"modified":"2023-08-01T18:41:33","modified_gmt":"2023-08-01T09:41:33","slug":"next-js-13%e6%96%b0%e6%a9%9f%e8%83%bd%e3%81%aeapp-directory%e3%81%a8supabase%e3%81%a7%e3%83%96%e3%83%ad","status":"publish","type":"post","link":"https:\/\/agile-software.net\/?p=2573","title":{"rendered":"Next.js 13\u65b0\u6a5f\u80fd\u306eApp Directory\u3068Supabase\u3067\u30d6\u30ed\u30b0"},"content":{"rendered":"\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>npx create-next-app@latest .<\/code><\/pre><\/div>\n\n\n\n<p>&#x2714; Would you like to use TypeScript? \u2026 No \/ Yes<br>&#x2714; Would you like to use ESLint? \u2026 No \/ Yes<br>&#x2714; Would you like to use Tailwind CSS? \u2026 No \/ Yes<br>&#x2714; Would you like to use <code>src\/<\/code> directory? \u2026 No \/ Yes<br>&#x2714; Would you like to use App Router? (recommended) \u2026 No \/ Yes<br>&#x2714; Would you like to customize the default import alias? \u2026 No \/ Yes<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>npm i @supabase\/auth-helpers-nextjs @supabase\/supabase-js @types\/uuid date-fns server-only sharp supabase uuid zustand\nnpm i -D encoding<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">\u30da\u30fc\u30b8\u4f5c\u6210<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u753b\u9762<\/h3>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"app\/loading.tsx\"><code><\/code><\/pre><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">\u30a8\u30e9\u30fc\u753b\u9762<\/h3>\n\n\n\n<p>404 \u30da\u30fc\u30b8\u306f\u983b\u7e41\u306b\u30a2\u30af\u30bb\u30b9\u3055\u308c\u307e\u3059\u3002\u30a2\u30af\u30bb\u30b9\u306e\u305f\u3073\u306b\u30a8\u30e9\u30fc\u30da\u30fc\u30b8\u3092\u30b5\u30fc\u30d0\u30fc\u30b5\u30a4\u30c9\u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u3059\u308b\u3068\u3001Next.js \u30b5\u30fc\u30d0\u30fc\u306e\u8ca0\u8377\u304c\u9ad8\u304f\u306a\u3063\u3066\u3057\u307e\u3044\u307e\u3059\u3002\u305d\u306e\u7d50\u679c\u3001\u30b3\u30b9\u30c8\u304c\u5897\u52a0\u3057\u305f\u308a\u3001\u4f53\u9a13\u304c\u9045\u304f\u306a\u3063\u305f\u308a\u3059\u308b\u3053\u3068\u304c\u3042\u308a\u307e\u3059\u3002<br>\u3053\u308c\u3092\u907f\u3051\u308b\u305f\u3081\u306b<code>pages\/404.js<\/code>\u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u6210\u3059\u308b\u3053\u3068\u3067\u3001\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3055\u308c\u305f 404 \u30da\u30fc\u30b8\u3092\u4f5c\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002\u3053\u306e\u30d5\u30a1\u30a4\u30eb\u306f\u30d3\u30eb\u30c9\u6642\u306b\u9759\u7684\u306b\u751f\u6210\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"app\/error.tsx\"><code>&#39;use client&#39;\n\n\/\/ \u30a8\u30e9\u30fc\u753b\u9762\nconst Error = () =&gt; {\n  return (\n    &lt;div&gt;\n      &lt;div className=&quot;text-center text-5xl font-bold mb-3 text-white&quot;&gt;500&lt;\/div&gt;\n      &lt;div className=&quot;text-center text-xl font-bold text-white&quot;&gt;Server Error&lt;\/div&gt;\n    &lt;\/div&gt;\n  )\n}\n\nexport default Error<\/code><\/pre><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">\u30c7\u30fc\u30bf\u304c\u5b58\u5728\u3057\u306a\u3044\u3068\u304d\u306e\u753b\u9762<\/h3>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"app\/not-found.tsx\"><code><\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">.env.local\u30d5\u30a1\u30a4\u30eb\u4f5c\u6210<\/h2>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code><\/code><\/pre><\/div>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>npx supabase login<\/code><\/pre><\/div>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>npx supabase init<\/code><\/pre><\/div>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>npx supabase link --project-ref<\/code><\/pre><\/div>\n\n\n\n<p>supabase\u30c6\u30fc\u30d6\u30eb\u306e\u578b\u3092\u30a4\u30f3\u30dd\u30fc\u30c8\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>npx supabase gen types typescript --linked &gt; utils\/database.types.ts<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">Supabase \u9023\u643a<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">\u30b5\u30fc\u30d0\u30fc\u5074<\/h3>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"utils\/supabase-server.ts\"><code>\/\/ Supabase Client\nimport { headers, cookies } from &#39;next\/headers&#39;\nimport { createServerComponentSupabaseClient } from &#39;@supabase\/auth-helpers-nextjs&#39;\nimport type { Database } from &#39;..\/utils\/database.types&#39;\n\nexport const createClient = () =&gt;\n  createServerComponentSupabaseClient&lt;Database&gt;({\n    headers,\n    cookies,\n  })<\/code><\/pre><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">\u30df\u30c9\u30eb\u30a6\u30a7\u30a2<\/h3>\n\n\n\n<p>\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u306f\u3001\u30e6\u30fc\u30b6\u30fc\u306e\u30bb\u30c3\u30b7\u30e7\u30f3\u3092\u66f4\u65b0\u3059\u308b\u305f\u3081\u306b\u4f7f\u7528\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u5074<\/h3>\n\n\n\n<p><strong>\u30b5\u30fc\u30d3\u30b9\u3084\u6a5f\u80fd\u3092\u4f7f\u3046\u5074\u306e\u30b3\u30f3\u30d4\u30e5\u30fc\u30bf<\/strong>\u3092\u300c\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u300d\u3068\u3044\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u30d7\u30ed\u30d0\u30a4\u30c0\u30fc<\/h3>\n\n\n\n<p>Supabase \u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306e\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u3092\u4f5c\u6210<\/p>\n\n\n\n<p><\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u30ea\u30b9\u30ca\u30fc<\/h3>\n\n\n\n<p>\u8a8d\u8a3c\u72b6\u614b\u306e\u76e3\u8996\u3092\u884c\u3046\u3002<br>\u30e6\u30fc\u30b6\u30fc\u304c\u30ed\u30b0\u30a4\u30f3\u3084\u30ed\u30b0\u30a2\u30a6\u30c8\u3092\u3059\u308b\u3068\u6700\u65b0\u306e\u8a8d\u8a3c\u72b6\u614b\u3092\u53d6\u5f97\u3059\u308b\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"supabase-listener.tsx\"><code><\/code><\/pre><\/div>\n\n\n\n<p>\u30b5\u30fc\u30d0\u30fc\u30b5\u30a4\u30c9\u306e\u307f\u52d5\u4f5c\u3059\u308b\u3088\u3046\u306b\u9650\u5b9a\u3059\u308b<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"app\/layout.tsx\"><code>import &#39;server-only&#39;<\/code><\/pre><\/div>\n\n\n\n<p><\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u30da\u30fc\u30b8\u4f5c\u6210<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">\u30b5\u30a4\u30f3\u30a2\u30c3\u30d7<\/h3>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"app\/auth\/signup\/page.tsx\"><code><\/code><\/pre><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb<\/h3>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"app\/auth\/profile\/page.tsx\"><code><\/code><\/pre><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">\u30ed\u30b0\u30a4\u30f3<\/h3>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"app\/components\/auth\/login.tsx\"><code><\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u9762\u4f5c\u6210<\/h2>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"app\/components\/auth\/profile.tsx\"><code><\/code><\/pre><\/div>\n","protected":false},"excerpt":{"rendered":"<p>#x2714; Would you like to use TypeScript? \u2026 No \/ Yes#x2714; Would you like to use ESLint? \u2026 No \/ Yes#x2714;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jin_ogp_image_url":"","_jin_last_featured_id":0,"footnotes":""},"categories":[1],"tags":[],"class_list":["post-2573","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"_links":{"self":[{"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/posts\/2573","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/agile-software.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=2573"}],"version-history":[{"count":6,"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/posts\/2573\/revisions"}],"predecessor-version":[{"id":2725,"href":"https:\/\/agile-software.net\/index.php?rest_route=\/wp\/v2\/posts\/2573\/revisions\/2725"}],"wp:attachment":[{"href":"https:\/\/agile-software.net\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2573"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/agile-software.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=2573"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/agile-software.net\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=2573"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}