Портирование WordPress Gutenberg на отдельный компонент React - CSS Стили не отображаются - PullRequest
1 голос
/ 18 января 2020

Я пытаюсь создать автономную версию редактора блоков Wordpress Gutenberg , который будет работать независимо от экосистемы Wordpress. В идеале я хотел бы иметь возможность просто использовать редактор Гутенберга в существующем проекте React в качестве компонента React.

Я заметил, что в официальном репозитории размещен каталог "сборник рассказов", в котором размещен компонент React по адресу " storybook / story / plays / index. js":

/**
 * WordPress dependencies
 */
import "@wordpress/editor"; // This shouldn't be necessary

import { useEffect, useState } from "@wordpress/element";
import { BlockEditorKeyboardShortcuts, BlockEditorProvider, BlockList, BlockInspector, WritingFlow, ObserveTyping } from "@wordpress/block-editor";
import { Popover, SlotFillProvider, DropZoneProvider } from "@wordpress/components";
import { registerCoreBlocks } from "@wordpress/block-library";
import "@wordpress/format-library";

/**
 * Internal dependencies
 */
import "./style.scss";

function App() {
    const [blocks, updateBlocks] = useState([]);

    useEffect(() => {
        registerCoreBlocks();
    }, []);

    return (
        <div className="playground">
            <SlotFillProvider>
                <DropZoneProvider>
                    <BlockEditorProvider
                        value={blocks}
                        onInput={updateBlocks}
                        onChange={updateBlocks}
                    >
                        <div className="playground__sidebar">
                            <BlockInspector />
                        </div>
                        <div className="editor-styles-wrapper">
                            <BlockEditorKeyboardShortcuts />
                            <WritingFlow>
                                <ObserveTyping>
                                    <BlockList />
                                </ObserveTyping>
                            </WritingFlow>
                        </div>
                        <Popover.Slot />
                    </BlockEditorProvider>
                </DropZoneProvider>
            </SlotFillProvider>
        </div>
    );
}

export default {
    title: "Playground|Block Editor"
};

export const _default = () => {
    return <App />;
};

Это выглядело как идеальный кандидат для преобразования в автономный компонент, поэтому я немного изменил его, чтобы он работал в новом проекте create-реагировать-app :

import React from "react";
import "@wordpress/editor"; // This shouldn't be necessary

import { useEffect, useState } from "@wordpress/element";
import { BlockEditorKeyboardShortcuts, BlockEditorProvider, BlockList, BlockInspector, WritingFlow, ObserveTyping } from "@wordpress/block-editor";
import { Popover, SlotFillProvider, DropZoneProvider } from "@wordpress/components";
import { registerCoreBlocks } from "@wordpress/block-library";
import "@wordpress/format-library";

import "./style.scss";

export default function App() {
  const [blocks, updateBlocks] = useState([]);

  useEffect(() => {
    registerCoreBlocks();
  }, []);

  return (
    <div className="playground">
      <SlotFillProvider>
        <DropZoneProvider>
          <BlockEditorProvider value={blocks} onInput={updateBlocks} onChange={updateBlocks}>
            <div className="playground__sidebar">
              <BlockInspector />
            </div>
            <div className="editor-styles-wrapper">
              <BlockEditorKeyboardShortcuts />
              <WritingFlow>
                <ObserveTyping>
                  <BlockList />
                </ObserveTyping>
              </WritingFlow>
            </div>
            <Popover.Slot />
          </BlockEditorProvider>
        </DropZoneProvider>
      </SlotFillProvider>
    </div>
  );
}

I увидел, что компонент ссылался на файл « style.s css» (который в свою очередь ссылался на «editor-styles.s css» и «reset.s css»), поэтому я скопировал эти файлы в мой новый проект React:

React project src directory

Я видел в файле "package. json" в репозитории Gutenberg, что все Wordpress ссылки на зависимости осуществлялись через каталог «packages», например:

"@wordpress/babel-plugin-import-jsx-pragma": "file:packages/babel-plugin-import-jsx-pragma",
"@wordpress/babel-plugin-makepot": "file:packages/babel-plugin-makepot",
"@wordpress/babel-preset-default": "file:packages/babel-preset-default",
"@wordpress/base-styles": "file:packages/base-styles",

Поэтому я скопировал каталог «packages» из Gutenberg в мой новый проект React, а затем добавил все зависимости Wordpress в мой «пакет». json "file:

    "dependencies": {
            "@testing-library/jest-dom": "^4.2.4",
            "@testing-library/react": "^9.4.0",
            "@testing-library/user-event": "^7.2.1",
            "@wordpress/a11y": "file:packages/a11y",
            "@wordpress/annotations": "file:packages/annotations",
            "@wordpress/api-fetch": "file:packages/api-fetch",
            "@wordpress/autop": "file:packages/autop",
            "@wordpress/blob": "file:packages/blob",
            "@wordpress/block-directory": "file:packages/block-directory",
            "@wordpress/block-editor": "file:packages/block-editor",
            "@wordpress/block-library": "file:packages/block-library",
            "@wordpress/block-serialization-default-parser": "file:packages/block-serialization-default-parser",
            "@wordpress/block-serialization-spec-parser": "file:packages/block-serialization-spec-parser",
            "@wordpress/blocks": "file:packages/blocks",
            "@wordpress/components": "file:packages/components",
            "@wordpress/compose": "file:packages/compose",
            "@wordpress/core-data": "file:packages/core-data",
            "@wordpress/data": "file:packages/data",
            "@wordpress/data-controls": "file:packages/data-controls",
            "@wordpress/date": "file:packages/date",
            "@wordpress/deprecated": "file:packages/deprecated",
            "@wordpress/dom": "file:packages/dom",
            "@wordpress/dom-ready": "file:packages/dom-ready",
            "@wordpress/edit-post": "file:packages/edit-post",
            "@wordpress/edit-site": "file:packages/edit-site",
            "@wordpress/edit-widgets": "file:packages/edit-widgets",
            "@wordpress/editor": "file:packages/editor",
            "@wordpress/element": "file:packages/element",
            "@wordpress/escape-html": "file:packages/escape-html",
            "@wordpress/format-library": "file:packages/format-library",
            "@wordpress/hooks": "file:packages/hooks",
            "@wordpress/html-entities": "file:packages/html-entities",
            "@wordpress/i18n": "file:packages/i18n",
            "@wordpress/is-shallow-equal": "file:packages/is-shallow-equal",
            "@wordpress/keyboard-shortcuts": "file:packages/keyboard-shortcuts",
            "@wordpress/keycodes": "file:packages/keycodes",
            "@wordpress/list-reusable-blocks": "file:packages/list-reusable-blocks",
            "@wordpress/media-utils": "file:packages/media-utils",
            "@wordpress/notices": "file:packages/notices",
            "@wordpress/nux": "file:packages/nux",
            "@wordpress/plugins": "file:packages/plugins",
            "@wordpress/priority-queue": "file:packages/priority-queue",
            "@wordpress/redux-routine": "file:packages/redux-routine",
            "@wordpress/rich-text": "file:packages/rich-text",
            "@wordpress/server-side-render": "file:packages/server-side-render",
            "@wordpress/shortcode": "file:packages/shortcode",
            "@wordpress/token-list": "file:packages/token-list",
            "@wordpress/url": "file:packages/url",
            "@wordpress/viewport": "file:packages/viewport",
            "@wordpress/wordcount": "file:packages/wordcount",
            "concurrently": "^5.0.2",
            "css-loader": "^3.4.2",
            "node-sass": "^4.13.0",
            "node-sass-chokidar": "^1.4.0",
            "node-watch": "^0.6.3",
            "npm-run-all": "^4.1.5",
            "postcss-loader": "^3.0.0",
            "react": "^16.12.0",
            "react-dom": "^16.12.0",
            "react-scripts": "3.3.0",
            "sass-loader": "^8.0.2",
    },
    "devDependencies": {
            "@wordpress/babel-plugin-import-jsx-pragma": "file:packages/babel-plugin-import-jsx-pragma",
            "@wordpress/babel-plugin-makepot": "file:packages/babel-plugin-makepot",
            "@wordpress/babel-preset-default": "file:packages/babel-preset-default",
            "@wordpress/base-styles": "file:packages/base-styles",
            "@wordpress/browserslist-config": "file:packages/browserslist-config",
            "@wordpress/custom-templated-path-webpack-plugin": "file:packages/custom-templated-path-webpack-plugin",
            "@wordpress/dependency-extraction-webpack-plugin": "file:packages/dependency-extraction-webpack-plugin",
            "@wordpress/docgen": "file:packages/docgen",
            "@wordpress/e2e-test-utils": "file:packages/e2e-test-utils",
            "@wordpress/e2e-tests": "file:packages/e2e-tests",
            "@wordpress/env": "file:packages/env",
            "@wordpress/eslint-plugin": "file:packages/eslint-plugin",
            "@wordpress/jest-console": "file:packages/jest-console",
            "@wordpress/jest-preset-default": "file:packages/jest-preset-default",
            "@wordpress/jest-puppeteer-axe": "file:packages/jest-puppeteer-axe",
            "@wordpress/library-export-default-webpack-plugin": "file:packages/library-export-default-webpack-plugin",
            "@wordpress/npm-package-json-lint-config": "file:packages/npm-package-json-lint-config",
            "@wordpress/postcss-themes": "file:packages/postcss-themes",
            "@wordpress/scripts": "file:packages/scripts"
    },

Затем запустил" npm i ", чтобы мой R Приложение eact может ссылаться на пакеты Wordpress через операторы импорта.

Теперь, когда я запускаю «npm start», приложение React запустится в моем браузере, и появится редактор Гутенберга, но ни один из CSS / стили работают:

Gutenberg Editor without CSS Styles

Я не совсем уверен, как поступить. Кажется, что приложение работает должным образом (я могу создавать, редактировать и удалять блоки), но стили просто отсутствуют.

Я попытался скомпилировать существующие файлы s css (в каталогах sr c, node_modules и ) через) следующие пакеты в пакетах. json:

"build-css": "node-sass-chokidar --include-path ./src --include-path ./node_modules --include-path ./packages src packages node_modules -o src --recursive --watch",
"watch-css": "npm run build-css && node-sass-chokidar --include-path ./src --include-path ./node_modules --include-path ./packages -o src --watch"

Но полученный файл стиля . css при импорте в мой индекс . html файл, похоже, ничего не меняет. Любая помощь будет принята с благодарностью.

1 Ответ

0 голосов
/ 24 января 2020

Я обнаружил, что в каталоге storybook есть еще один файл style.s css, который после помещения в каталог root моего приложения React вместе с обновлением пакет. json сценарии для:

"build-css": "node-sass-chokidar style.scss -o public/css",
"watch-css": "npm run build-css && node-sass-chokidar --include-path node_modules style.scss -o public/css --watch"

Стили были скомпилированы правильно.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...