From eced26b4c2e99d2cc8b2a767e0d4496192f21d25 Mon Sep 17 00:00:00 2001 From: Nikita Gorin <36075690+NikitaCG@users.noreply.github.com> Date: Tue, 22 Oct 2024 18:21:36 +0300 Subject: [PATCH] chore: update readme about server utils and Vite (#1052) --- README.md | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) diff --git a/README.md b/README.md index 6cc185418..fe24306e6 100644 --- a/README.md +++ b/README.md @@ -109,6 +109,42 @@ interface NavigationLogo { } ``` +### Server utils + +The package provides a set of server utilities for transforming your content. + +```ts +const {fullTransform} = require('@gravity-ui/page-constructor/server'); + +const {html} = fullTransform(content, { + lang, + extractTitle: true, + allowHTML: true, + path: __dirname, + plugins, +}); +``` + +Under the hood, a package is used to transform Yandex Flavored Markdown into HTML - `diplodoc/transfrom`, so it is also in peer dependencies + +You can also use useful utilities in the places you need, for example in your custom components + +```ts +const { + typografToText, + typografToHTML, + yfmTransformer, +} = require('@gravity-ui/page-constructor/server'); + +const post = { + title: typografToText(title, lang), + content: typografToHTML(content, lang), + description: yfmTransformer(lang, description, {plugins}), +}; +``` + +You can find more utilities in this [section](https://github.com/gravity-ui/page-constructor/tree/main/src/text-transform) + ### Custom blocks The page constructor lets you use blocks that are user-defined in their app. Blocks are regular React components. @@ -316,6 +352,24 @@ npm ci npm run dev ``` +#### Note about Vite + +```ts +import react from '@vitejs/plugin-react-swc'; +import dynamicImport from 'vite-plugin-dynamic-import'; + +export default defineConfig({ + plugins: [ + react(), + dynamicImport({ + filter: (id) => id.includes('/node_modules/@gravity-ui/page-constructor'), + }), + ], +}); +``` + +For Vite, you need to install the `vite-plugin-dynamic-import` plugin and configure the config so that dynamic imports work + ## Release flow In usual cases we use two types of commits: