{"id":276,"date":"2023-12-16T03:56:54","date_gmt":"2023-12-16T03:56:54","guid":{"rendered":"https:\/\/aki-hamano.blog\/?p=276"},"modified":"2025-10-25T03:53:37","modified_gmt":"2025-10-25T03:53:37","slug":"gutenberg-as-a-framework","status":"publish","type":"post","link":"https:\/\/aki-hamano.blog\/ja\/2023\/12\/16\/gutenberg-as-a-framework\/","title":{"rendered":"Gutenberg as a framework: WordPress \u5916\u3067\u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\u3092\u52d5\u304b\u3057\u3066\u307f\u308b"},"content":{"rendered":"\n<h2 class=\"wp-block-heading\">\u8a18\u4e8b\u306e\u80cc\u666f<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">2023\u5e748\u6708\u306b\u3001Gutenberg \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u304a\u3044\u3066\u300c<a href=\"https:\/\/github.com\/WordPress\/gutenberg\/issues\/53874\" target=\"_blank\" rel=\"noreferrer noopener\">Gutenberg as a framework: streamline the experience<\/a>\u300d\u3068\u3044\u3046 issue \u304c\u7acb\u3061\u4e0a\u304c\u308a\u307e\u3057\u305f\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u81ea\u5206\u306b\u306f\u975e\u5e38\u306b\u96e3\u89e3\u306a\u5185\u5bb9\u3067\u3059\u304c\u3001\u591a\u304f\u306e\u8b70\u8ad6\u304c\u4ea4\u308f\u3055\u308c\u3066\u304a\u308a\u3001\u73fe\u5728\u3082\u9032\u884c\u4e2d\u306e issue \u306e\u3088\u3046\u3067\u3059\u3002\u305d\u306e\u4e00\u65b9\u3001\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3068\u3057\u3066 \u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\u3092\u52d5\u4f5c\u3055\u305b\u308b\u305f\u3081\u306e<a href=\"https:\/\/github.com\/WordPress\/gutenberg\/pull\/54375\" target=\"_blank\" rel=\"noreferrer noopener\">\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306e\u6574\u5099<\/a>\u3082\u9032\u3081\u3089\u308c\u3066\u304a\u308a\u3001\u4eca\u56de\u306f\u3001\u3053\u306e\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306b\u5f93\u3063\u3066\u74b0\u5883\u69cb\u7bc9\u306b\u6311\u6226\u3057\u3001\u73fe\u6642\u70b9\u3067\u3069\u3053\u307e\u3067\/\u3069\u306e\u3088\u3046\u306a\u4e8b\u304c\u51fa\u6765\u308b\u306e\u304b\u3092\u78ba\u8a8d\u3057\u3066\u307f\u3088\u3046\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u4f7f\u7528\u6280\u8853<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u74b0\u5883\u69cb\u7bc9\u306b\u3042\u305f\u3063\u3066\u3001\u4eca\u56de\u306f Bun \u3068 Vite \u3092\u4f7f\u7528\u3057\u3066\u307f\u307e\u3059\u3002\u3069\u3061\u3089\u3082\u521d\u3081\u3066\u4f7f\u7528\u3059\u308b\u305f\u3081\u3001\u3082\u3057\u9593\u9055\u3044\u7b49\u3042\u308a\u307e\u3057\u305f\u3089\u305c\u3072\u3054\u6307\u6458\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u958b\u767a\u74b0\u5883\u306e\u521d\u671f\u69cb\u7bc9<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u3068\u308a\u3042\u3048\u305a <a href=\"https:\/\/zenn.dev\/yamakenji24\/articles\/bcba86de05e5d5\" target=\"_blank\" rel=\"noreferrer noopener\">Bun \u306e\u30c8\u30c3\u30d7\u30da\u30fc\u30b8<\/a>\u306b\u3042\u308b\u30b3\u30de\u30f3\u30c9\u3092\u4f7f\u3063\u3066\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b<\/p>\n\n\n\n<pre class=\"wp-block-code lang-bash\"><code>$curl -fsSL https:\/\/bun.sh\/install | bash\n######################################################################### 100.0%\nbun was installed successfully to ~\/.bun\/bin\/bun \nRun 'bun --help' to get started<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u5165\u3063\u305f\u3063\u307d\u3044<\/p>\n\n\n\n<pre class=\"wp-block-code lang-bash\"><code>$bun --version\n1.0.0<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">Vite \u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u3092\u4f5c\u6210\u3002\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u306f\u3082\u3061\u308d\u3093 React\u3002Gutenberg \u306e\u5404\u7a2e\u30d1\u30c3\u30b1\u30fc\u30b8\u306b\u5bfe\u3057\u3066\u6700\u65b0\u306e\u578b\u5b9a\u7fa9\u304c\u5168\u3066\u3042\u308b\u304b\u4e0d\u660e\u306a\u306e\u3067\u3001<code>variant<\/code> \u306f JavaScript \u3092\u9078\u629e\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code lang-bash\"><code>s$ bun create vite block-editor-platform\n\u2714 Select a framework: \u203a React\n\u2714 Select a variant: \u203a JavaScript\n\u200b\nScaffolding project in \/home\/wildworks\/projects\/block-editor-platform...\n\u200b\nDone. Now run:\n\u200b\n  cd block-editor-platform\n  bun install\n  bun run dev<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u3093\u306a\u30d5\u30a1\u30a4\u30eb\u304c\u751f\u6210\u3055\u308c\u307e\u3057\u305f<\/p>\n\n\n\n<pre class=\"wp-block-code lang-bash\"><code>$ tree\n.\n\u251c\u2500\u2500 index.html\n\u251c\u2500\u2500 package.json\n\u251c\u2500\u2500 public\n\u2502 \u00a0 \u2514\u2500\u2500 vite.svg\n\u251c\u2500\u2500 README.md\n\u251c\u2500\u2500 src\n\u2502 \u00a0 \u251c\u2500\u2500 App.css\n\u2502 \u00a0 \u251c\u2500\u2500 App.jsx\n\u2502 \u00a0 \u251c\u2500\u2500 assets\n\u2502 \u00a0 \u2502 \u00a0 \u2514\u2500\u2500 react.svg\n\u2502 \u00a0 \u251c\u2500\u2500 index.css\n\u2502 \u00a0 \u2514\u2500\u2500 main.jsx\n\u2514\u2500\u2500 vite.config.js\n\u200b\n3 directories, 10 files<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3066\u8d77\u52d5\u3057\u3066\u307f\u308b<\/p>\n\n\n\n<pre class=\"wp-block-code lang-bash\"><code>$ bun install\nbun install v1.0.0 (822a00c4)\n + @types\/react@18.2.45\n + @types\/react-dom@18.2.18\n + @vitejs\/plugin-react@4.2.1\n + eslint@8.56.0\n + eslint-plugin-react@7.33.2\n + eslint-plugin-react-hooks@4.6.0\n + eslint-plugin-react-refresh@0.4.5\n + vite@5.0.10\n + react@18.2.0\n + react-dom@18.2.0\n\u200b\n 270 packages installed &#91;13.59s]\n \n$ bun dev\n$ vite\n\u200b\n  VITE v5.0.10  ready in 315 ms\n\u200b\n  \u279c  Local: \u00a0 http:\/\/localhost:5173\/\n  \u279c  Network: use --host to expose\n  \u279c  press h + enter to show help<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u8d77\u52d5\u3057\u307e\u3057\u305f\u3002\u4e2d\u592e\u3042\u305f\u308a\u306e\u30dc\u30bf\u30f3\u3092\u30af\u30ea\u30c3\u30af\u3059\u308b\u3068\u3001\u6570\u5b57\u304c\u30ab\u30a6\u30f3\u30c8\u30a2\u30c3\u30d7\u3055\u308c\u308b\u6a21\u69d8<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"909\" height=\"604\" src=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_1.png\" alt=\"\u521d\u671f\u753b\u9762\" class=\"wp-image-286\" srcset=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_1.png 909w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_1-300x199.png 300w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_1-768x510.png 768w\" sizes=\"auto, (max-width: 909px) 100vw, 909px\" \/><\/figure>\n\n\n\n<h2 class=\"wp-block-heading\">Gutenberg \u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306e\u78ba\u8a8d<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u3053\u304b\u3089\u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\u3092\u7d44\u307f\u8fbc\u3093\u3067\u3044\u304f\u3053\u3068\u306b\u306a\u308a\u307e\u3059\u304c\u3001\u305d\u306e\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306f <a href=\"https:\/\/github.com\/WordPress\/gutenberg\/blob\/trunk\/platform-docs\/docs\/intro.md\" target=\"_blank\" rel=\"noreferrer noopener\">Gutenberg \u306eGitHub \u30ea\u30dd\u30b8\u30c8\u30ea<\/a>\u306b\u3042\u308a\u307e\u3059\u3002\u3053\u306e README \u3092\u76f4\u63a5\u898b\u3066\u3082\u826f\u3044\u306e\u3067\u3059\u304c\u3001\u3053\u306e\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306b\u306f <a href=\"https:\/\/docusaurus.io\/\" target=\"_blank\" rel=\"noreferrer noopener\">Docusaurus 2<\/a> \u304c\u4f7f\u308f\u308c\u3066\u3044\u308b\u3068\u306e\u4e8b\u306a\u306e\u3067\u3001\u305b\u3063\u304b\u304f\u306a\u306e\u3067\u30d3\u30eb\u30c9\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><a href=\"https:\/\/github.com\/WordPress\/gutenberg\/blob\/trunk\/platform-docs\/README.md\">README<\/a> \u306b\u5f93\u3063\u3066\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3057\u307e\u3059 (Gutenberg \u30ea\u30dd\u30b8\u30c8\u30ea\u306f\u30ed\u30fc\u30ab\u30eb\u306b\u30af\u30ed\u30fc\u30f3\u6e08\u3067\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30eb\u30fc\u30c8\u306b\u3044\u308b\u3068\u3057\u307e\u3059)\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code lang-bash\"><code>$ cd .\/platform-docs\/\n$ npm install\n\u200b\nup to date, audited 1145 packages in 19s\n\u200b\n215 packages are looking for funding\n  run `npm fund` for details\n\u200b\n26 vulnerabilities (14 moderate, 11 high, 1 critical)\n\u200b\nTo address issues that do not require attention, run:\n  npm audit fix\n\u200b\nTo address all issues (including breaking changes), run:\n  npm audit fix --force\n\u200b\nRun `npm audit` for details.<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u691c\u8a3c\u6642\u70b9\u3067\u306f\u3001broken links \u304c\u3042\u308b\u3068\u306e\u4e8b\u3067 <code>npm run build<\/code> \u304c\u5931\u6557\u3057\u305f\u306e\u3067\u3001\u4ee3\u308f\u308a\u306b <code>npm run start<\/code> \u3092\u5b9f\u884c<\/p>\n\n\n\n<pre class=\"wp-block-code lang-bash\"><code>$ npm run start\n\u200b\n> platform-docs@0.0.1 start\n> docusaurus start\n\u200b\n(\u4e2d\u7565)\n\u200b\n\u2714 Client\n  Compiled successfully in 3.84s\n\u200b\n&#91;WARNING] Docs markdown link couldn't be resolved: (\/docs\/reference-guides\/block-api\/block-attributes.md) in \"\/home\/wildworks\/projects\/gutenberg\/platform-docs\/docs\/basic-concepts\/data.md\" for version current\nclient (webpack 5.88.2) compiled successfully<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u30b5\u30a4\u30c8\u304c\u7acb\u3061\u4e0a\u304c\u308a\u307e\u3057\u305f !<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"585\" src=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_2-1024x585.png\" alt=\"\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u30b5\u30a4\u30c8\" class=\"wp-image-287\" srcset=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_2-1024x585.png 1024w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_2-300x171.png 300w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_2-768x438.png 768w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_2.png 1184w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/figure>\n\n\n\n<p class=\"wp-block-paragraph\">\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306e <a href=\"https:\/\/github.com\/WordPress\/gutenberg\/blob\/trunk\/platform-docs\/docs\/intro.md#installing-dependencies\" target=\"_blank\" rel=\"noreferrer noopener\">Getting Started<\/a> \u3092\u898b\u308b\u3068\u3001\u307e\u305a\u306f\u4f9d\u5b58\u95a2\u4fc2\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u5fc5\u8981\u304c\u3042\u308b\u3068\u306e\u4e8b<\/p>\n\n\n\n<pre class=\"wp-block-code lang-bash\"><code>$bun i -D @wordpress\/block-editor @wordpress\/block-library @wordpress\/components<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\">\u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\u306e\u7d44\u307f\u8fbc\u307f<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u3044\u3088\u3044\u3088\u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\u306e\u7d44\u307f\u8fbc\u307f\u3092\u8a66\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u307e\u305a\u306f\u3001\u30a2\u30d7\u30ea\u3092 CSS \u3082\u9069\u7528\u3055\u308c\u3066\u3044\u306a\u3044\u3068\u306b\u304b\u304f\u30d5\u30e9\u30c3\u30c8\u306a\u72b6\u614b\u306b\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code lang-jsx\"><code>import React from 'react'\nimport ReactDOM from 'react-dom\/client'\nimport App from '.\/App.jsx'\n\nReactDOM.createRoot(document.getElementById('root')).render(\n  &lt;React.StrictMode>\n    &lt;App \/>\n  &lt;\/React.StrictMode>,\n)<\/code><\/pre>\n\n\n\n<pre class=\"wp-block-code lang-jsx\"><code>function App() {\n  return (\n    &lt;div>Hello World!&lt;\/div>\n  )\n}\n\nexport default App<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u3053\u306b\u3001<a href=\"http:\/\/localhost:3000\/docs\/intro#bootstrap-your-block-editor\" target=\"_blank\" rel=\"noreferrer noopener\">\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8<\/a>\u306b\u8a18\u8f09\u3055\u308c\u3066\u3044\u308b\u901a\u308a\u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\u3092\u7d44\u307f\u8fbc\u3093\u3067\u307f\u307e\u3059\u3002\u958b\u767a\u74b0\u5883\u306e\u69cb\u6210\u306b\u5408\u308f\u305b\u3066\u3001\u4e00\u90e8\u8abf\u6574\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code lang-jsx\"><code>import { useState } from \"react\";\nimport {\n  BlockEditorProvider,\n  BlockCanvas,\n} from \"@wordpress\/block-editor\";\nimport { registerCoreBlocks } from \"@wordpress\/block-library\";\n\nimport \"@wordpress\/components\/build-style\/style.css\";\nimport \"@wordpress\/block-editor\/build-style\/style.css\";\nimport \"@wordpress\/block-library\/build-style\/common.css\";\nimport \"@wordpress\/block-library\/build-style\/style.css\";\nimport \"@wordpress\/block-library\/build-style\/editor.css\";\n\nregisterCoreBlocks();\n\nfunction App() {\n  const &#91;blocks, setBlocks] = useState(&#91;]);\n  return (\n    &lt;BlockEditorProvider\n      value={blocks}\n      onChange={setBlocks}\n      onInput={setBlocks}\n    >\n      &lt;BlockCanvas height=\"500px\" \/>\n    &lt;\/BlockEditorProvider>\n  );\n}\n\nexport default App<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u30a8\u30e9\u30fc\u304c\u30d6\u30e9\u30a6\u30b6\u30b3\u30f3\u30bd\u30fc\u30eb\u306b\u8a18\u9332\u3055\u308c\u3001\u4f55\u3082\u8868\u793a\u3055\u308c\u305a\u3002\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code lang-textile\"><code>@wordpress_block-library.js?v=3a76d5ae:64859 Uncaught ReferenceError: process is not defined at @wordpress_block-library.js?v=3a76d5ae:64859:52<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u30a8\u30e9\u30fc\u304c\u8d77\u3053\u3063\u3066\u3044\u308b\u884c\u3092\u898b\u3066\u307f\u308b\u3068\u3001\u78ba\u304b\u306b <code>processs.env.IS_GUTENBERG_PLUGIN<\/code> \u3092\u8aad\u307f\u53d6\u3063\u3066\u3044\u308b\u3063\u307d\u3044\u3067\u3059\u304c\u3001\u305d\u3082\u305d\u3082 <code>process<\/code> \u304c <code>undefined<\/code> \u3067\u3042\u308b\u306e\u304c\u554f\u984c<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"922\" height=\"254\" src=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_3.png\" alt=\"\u30a8\u30e9\u30fc\" class=\"wp-image-288\" srcset=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_3.png 922w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_3-300x83.png 300w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_3-768x212.png 768w\" sizes=\"auto, (max-width: 922px) 100vw, 922px\" \/><\/figure>\n\n\n\n<p class=\"wp-block-paragraph\"><a href=\"https:\/\/blog.okaryo.io\/20220319-env-variables-for-vite\">\u3053\u306e\u8a18\u4e8b<\/a>\u306b\u3088\u308b\u3068\u3001Vite \u3067\u306f\u300c<code>process.env.HOGE<\/code>\u3092<code>import.meta.env.VITE_HOGE<\/code>\u306b\u66f8\u304d\u63db\u3048\u308b\u300d\u3068\u3042\u308a\u307e\u3059\u304c\u3001\u305d\u3082\u305d\u3082\u5916\u90e8\u30e9\u30a4\u30d6\u30e9\u30ea\u306a\u306e\u3067\u66f8\u304d\u63db\u3048\u308b\u4e8b\u304c\u51fa\u6765\u306a\u3044\u3002\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Gutenberg \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u3082\u4f3c\u305f\u554f\u984c\u304c\u5831\u544a\u3055\u308c\u3066\u3044\u305f<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><a href=\"https:\/\/github.com\/WordPress\/gutenberg\/issues\/48949\" target=\"_blank\" rel=\"noreferrer noopener\">https:\/\/github.com\/WordPress\/gutenberg\/issues\/48949<\/a><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">issue \u306e<a href=\"https:\/\/github.com\/WordPress\/gutenberg\/issues\/48949#issuecomment-1461267364\" target=\"_blank\" rel=\"noreferrer noopener\">\u3053\u306e\u30b3\u30e1\u30f3\u30c8<\/a>\u306b\u3088\u308b\u3068\u3001<code>@rollup.plugin-replace<\/code> \u3092\u4f7f\u7528\u3057\u3066\u7f6e\u304d\u63db\u3048\u308b\u4e8b\u3067\u3082\u89e3\u6c7a\u51fa\u6765\u308b\u3089\u3057\u3044\u3067\u3059\u304c\u3001<a href=\"https:\/\/ja.vitejs.dev\/config\/shared-options.html#define\" target=\"_blank\" rel=\"noreferrer noopener\">Vite \u306e\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8<\/a>\u306b\u3088\u308b\u3068\u3001<code>define<\/code> \u30d7\u30ed\u30d1\u30c6\u30a3\u3067\u30b0\u30ed\u30fc\u30d0\u30eb\u5b9a\u6570\u306e\u7f6e\u63db ? \u3092\u5b9a\u7fa9\u51fa\u6765\u308b\u3089\u3057\u3044\u306e\u3067\u8a66\u3057\u3066\u307f\u308b<\/p>\n\n\n\n<pre class=\"wp-block-code lang-jsx\"><code>import { defineConfig } from 'vite'\nimport react from '@vitejs\/plugin-react'\n\n\/\/ https:\/\/vitejs.dev\/config\/\nexport default defineConfig({\n  plugins: &#91;react()],\n  \/\/ \u3053\u308c\u3092\u8ffd\u52a0\n  define: {\n    'process.env': {}\n  },\n})<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\u304c\u52d5\u3044\u305f !<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"461\" height=\"460\" src=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_4.png\" alt=\"\u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\" class=\"wp-image-290\" srcset=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_4.png 461w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_4-300x300.png 300w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_4-150x150.png 150w\" sizes=\"auto, (max-width: 461px) 100vw, 461px\" \/><\/figure>\n\n\n\n<p class=\"wp-block-paragraph\">WordPress \u306e\u4e2d\u306e\u5834\u5408\u306e\u898b\u305f\u76ee\u30fb\u52d5\u4f5c\u3068\u9055\u3046\u90e8\u5206\u306f\u591a\u304f\u3042\u308a\u307e\u3059\u304c\u3001\u57fa\u672c\u7684\u306a\u6a5f\u80fd\u306f\u52d5\u4f5c\u3059\u308b\u3088\u3046\u3067\u3059\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u305b\u3063\u304b\u304f\u306a\u306e\u3067\u3001\u30d6\u30ed\u30c3\u30af\u30b5\u30a4\u30c9\u30d0\u30fc\u3082\u8ffd\u52a0\u3057\u3066\u307f\u307e\u3059\u3002Gutenberg \u3067\u516c\u958b\u3055\u308c\u3066\u3044\u308b Storybook \u306b\u306f\u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\u3082\u3042\u308a\u3001<a href=\"https:\/\/wordpress.github.io\/gutenberg\/?path=\/story\/playground-block-editor--default\" target=\"_blank\" rel=\"noreferrer noopener\">\u30b5\u30a4\u30c9\u30d0\u30fc\u4ed8\u304d\u306e\u30b9\u30c8\u30fc\u30ea\u30fc<\/a>\u3082\u5b58\u5728\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><a href=\"https:\/\/github.com\/WordPress\/gutenberg\/blob\/41e18933df3e9851635fe8f0d78b5bc59bf52237\/storybook\/stories\/playground\/fullpage\/index.js#L46\" target=\"_blank\" rel=\"noreferrer noopener\">\u8a72\u5f53\u30d5\u30a1\u30a4\u30eb<\/a>\u3092\u898b\u3066\u307f\u308b\u3068\u3001<code>BlockInspector<\/code> \u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u4f7f\u7528\u3059\u308c\u3070\u3088\u3044\u3088\u3046\u3067\u3059\u3002\u30a8\u30c7\u30a3\u30bf\u30fc\u30ad\u30e3\u30f3\u30d0\u30b9 (<code>BlockCanvas<\/code> \u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8) \u306e\u9ad8\u3055\u3082 <code>100%<\/code> \u306b\u5909\u66f4\u3057\u3066\u304a\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code lang-jsx\"><code>import { useState } from \"react\";\nimport {\n  BlockEditorProvider,\n  BlockCanvas,\n  BlockInspector,\n} from \"@wordpress\/block-editor\";\nimport { registerCoreBlocks } from \"@wordpress\/block-library\";\n\nimport \"@wordpress\/components\/build-style\/style.css\";\nimport \"@wordpress\/block-editor\/build-style\/style.css\";\nimport \"@wordpress\/block-library\/build-style\/common.css\";\nimport \"@wordpress\/block-library\/build-style\/style.css\";\nimport \"@wordpress\/block-library\/build-style\/editor.css\";\nimport '.\/App.scss';\n\nregisterCoreBlocks();\n\nfunction App() {\n  const &#91;blocks, setBlocks] = useState(&#91;]);\n\n  return (\n    &lt;div className=\"playground\">\n      &lt;BlockEditorProvider\n        value={blocks}\n        onChange={setBlocks}\n        onInput={setBlocks}\n      >\n        &lt;div className=\"playground__sidebar\">\n          &lt;BlockInspector \/>\n        &lt;\/div>\n        &lt;div className=\"playground__content\">\n          &lt;BlockCanvas height=\"100%\" \/>\n        &lt;\/div>\n      &lt;\/BlockEditorProvider>\n    &lt;\/div>\n  );\n}\n\nexport default App<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u3055\u3089\u306b\u3001\u30a8\u30c7\u30a3\u30bf\u30fc\u30ad\u30e3\u30f3\u30d0\u30b9\u3068\u30d6\u30ed\u30c3\u30af\u30b5\u30a4\u30c9\u30d0\u30fc\u3092\u30ec\u30a4\u30a2\u30a6\u30c8\u3059\u308b\u305f\u3081\u306b\u3001<a href=\"https:\/\/github.com\/WordPress\/gutenberg\/blob\/41e18933df3e9851635fe8f0d78b5bc59bf52237\/storybook\/stories\/playground\/fullpage\/style.lazy.scss\" target=\"_blank\" rel=\"noreferrer noopener\">Storybook \u306e\u30b9\u30bf\u30a4\u30eb<\/a>\u3092\u53c2\u8003\u306b\u8ffd\u52a0\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u306e\u30b9\u30bf\u30a4\u30eb\u306f Sass \u3067\u8a18\u8ff0\u3055\u308c\u3066\u3044\u308b\u306e\u3067\u3001<code>sass<\/code> \u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u3055\u3089\u306b\u3001Gutenberg \u306e <code>@wordpress\/base-styles<\/code> \u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u30a4\u30f3\u30dd\u30fc\u30c8\u3057\u3066\u3044\u308b\u306e\u3067\u3001\u3053\u308c\u3082\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3066\u304a\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code lang-bash\"><code>$ bun i -D sass @wordpress\/base-styles<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u6700\u4f4e\u9650\u306e\u30b9\u30bf\u30a4\u30eb\u3068\u3057\u3066\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u8a18\u8ff0\u3057\u307e\u3057\u305f\u3002CSS \u5909\u6570\u306f\u3001<code>@wordpres\/base-styles<\/code> \u306e <a href=\"https:\/\/github.com\/WordPress\/gutenberg\/blob\/trunk\/packages\/base-styles\/_variables.scss\" target=\"_blank\" rel=\"noreferrer noopener\">variables<\/a> \u306b\u5b9a\u7fa9\u3055\u308c\u3066\u3044\u308b\u3082\u306e\u3092\u4f7f\u7528\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code lang-jsx\"><code>@import \"@wordpress\/base-styles\/colors\";\n@import \"@wordpress\/base-styles\/variables\";\n@import \"@wordpress\/base-styles\/mixins\";\n@import \"@wordpress\/base-styles\/breakpoints\";\n@import \"@wordpress\/base-styles\/animations\";\n@import \"@wordpress\/base-styles\/z-index\";\n\n.playground {\n\tiframe {\n\t\twidth: 100%;\n\t}\n}\n\n.playground__content {\n\tposition: fixed;\n\ttop: 0;\n\tright: $sidebar-width;\n\tbottom: 0;\n\tleft: 0;\n\tpadding: 0 $grid-unit-20;\n}\n\n.playground__sidebar {\n\tposition: fixed;\n\ttop: 0;\n\tright: 0;\n\tbottom: 0;\n\twidth: $sidebar-width;\n\tborder-left: $border-width solid $gray-300;\n\theight: auto;\n\toverflow: auto;\n}<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u30b5\u30a4\u30c9\u30d0\u30fc\u306b\u306f\u30bf\u30a4\u30dd\u30b0\u30e9\u30d5\u30a3\u30d1\u30cd\u30eb (\u30d5\u30a9\u30f3\u30c8\u30b5\u30a4\u30ba\u306e\u307f) \u3068 Advanced \u30d1\u30cd\u30eb\u3057\u304b\u3042\u308a\u307e\u305b\u3093\u304c\u3001\u305d\u308c\u3063\u307d\u304f\u306a\u308a\u307e\u3057\u305f !<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"633\" src=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_5-1024x633.png\" alt=\"\u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\u30b5\u30a4\u30c9\u30d0\u30fc\" class=\"wp-image-289\" srcset=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_5-1024x633.png 1024w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_5-300x186.png 300w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_5-768x475.png 768w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_5.png 1117w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/figure>\n\n\n\n<h2 class=\"wp-block-heading\">State \u306b\u3064\u3044\u3066<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u3053\u3067\u3001<code>useState<\/code> \u3092\u4ecb\u3057\u3066\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3055\u308c\u3066\u3044\u308b <code>blocks<\/code> \u306b\u3069\u306e\u3088\u3046\u306a\u60c5\u5831\u304c\u5165\u3063\u3066\u3044\u308b\u304b\u3092\u78ba\u8a8d\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">WordPress \u306e\u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\u4e0a\u3067\u30d6\u30ed\u30c3\u30af\u306e <code>Edit<\/code> \u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u304c\u6301\u3064\u3082\u306e\u3068\u4f3c\u3066\u3044\u308b\u3088\u3046\u3067\u3059\u304c\u3001RichText \u30c7\u30fc\u30bf\u306e\u6301\u3061\u65b9 (<code>attributes.content<\/code> \u7b49) \u304c\u7570\u306a\u308b\u3088\u3046\u3067\u3059\u3002<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"755\" height=\"728\" src=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_6.png\" alt=\"State\" class=\"wp-image-291\" srcset=\"https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_6.png 755w, https:\/\/aki-hamano.blog\/wp-content\/uploads\/2024\/06\/gutenberg-as-a-framework_6-300x289.png 300w\" sizes=\"auto, (max-width: 755px) 100vw, 755px\" \/><\/figure>\n\n\n\n<h2 class=\"wp-block-heading\">\u307e\u3068\u3081<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u904e\u53bb\u306b\u3082\u3001WordPress \u5916\u3067\u30d6\u30ed\u30c3\u30af\u30a8\u30c7\u30a3\u30bf\u30fc\u3092\u69cb\u7bc9\u3059\u308b\u4e8b\u3092\u8a66\u307f\u305f\u4e8b\u306f\u3042\u308a\u307e\u3059\u304c\u3001\u60c5\u5831\u3082\u5c11\u306a\u304f\u632b\u6298\u3057\u3066\u3057\u307e\u3044\u307e\u3057\u305f\u3002\u4eca\u56de\u3001\u3064\u307e\u3065\u304d\u30dd\u30a4\u30f3\u30c8\u306f\u591a\u5c11\u3042\u308a\u307e\u3057\u305f\u304c\u3001\u304b\u306a\u308a\u30b7\u30f3\u30d7\u30eb\u306a\u65b9\u6cd5\u3067\u69cb\u7bc9\u51fa\u6765\u308b\u3053\u3068\u304c\u5206\u304b\u308a\u307e\u3057\u305f\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u300cGutenberg as a framework\u300d\u306b\u95a2\u3059\u308b\u53d6\u308a\u7d44\u307f\u306f\u3053\u308c\u304b\u3089\u3082\u7d9a\u3044\u3066\u3044\u304f\u3068\u601d\u3046\u306e\u3067\u3001\u307e\u3059\u307e\u3059\u697d\u3057\u307f\u3067\u3059 !<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u8a18\u4e8b\u306e\u80cc\u666f 2023\u5e748\u6708\u306b\u3001Gutenberg \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u304a\u3044\u3066\u300cGutenberg as a framework: streamline the experience\u300d\u3068\u3044\u3046 issue \u304c\u7acb\u3061\u4e0a\u304c\u308a\u307e\u3057\u305f\u3002 \u81ea [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_locale":"ja","_original_post":"https:\/\/aki-hamano.blog\/?p=276","footnotes":""},"categories":[16],"tags":[],"class_list":["post-276","post","type-post","status-publish","format-standard","hentry","category-gutenberg","ja"],"_links":{"self":[{"href":"https:\/\/aki-hamano.blog\/wp-json\/wp\/v2\/posts\/276","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/aki-hamano.blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/aki-hamano.blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/aki-hamano.blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/aki-hamano.blog\/wp-json\/wp\/v2\/comments?post=276"}],"version-history":[{"count":9,"href":"https:\/\/aki-hamano.blog\/wp-json\/wp\/v2\/posts\/276\/revisions"}],"predecessor-version":[{"id":292,"href":"https:\/\/aki-hamano.blog\/wp-json\/wp\/v2\/posts\/276\/revisions\/292"}],"wp:attachment":[{"href":"https:\/\/aki-hamano.blog\/wp-json\/wp\/v2\/media?parent=276"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/aki-hamano.blog\/wp-json\/wp\/v2\/categories?post=276"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/aki-hamano.blog\/wp-json\/wp\/v2\/tags?post=276"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}