diff --git a/package-lock.json b/package-lock.json index 796767f0..68961deb 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1637,6 +1637,42 @@ "npm": ">=9.*" } }, + "node_modules/@diplodoc/client/node_modules/@diplodoc/transform": { + "version": "4.40.0", + "resolved": "https://registry.npmjs.org/@diplodoc/transform/-/transform-4.40.0.tgz", + "integrity": "sha512-fJ6Fo/kCv4r3T7ZxEEPBy0l60tU7ArOg1q9zVJcFClMowUtiavT8Pbrn6/wj/nM02OQ2ZeVc+IW3OXkPH2yRmA==", + "dependencies": { + "@diplodoc/cut-extension": "^0.5.0", + "@diplodoc/file-extension": "^0.2.0", + "@diplodoc/tabs-extension": "^3.5.0", + "chalk": "^4.1.2", + "cheerio": "^1.0.0", + "css": "^3.0.0", + "cssfilter": "0.0.10", + "get-root-node-polyfill": "1.0.0", + "github-slugger": "^1.5.0", + "js-yaml": "^4.1.0", + "lodash": "4.17.21", + "markdown-it": "^13.0.2", + "markdown-it-attrs": "^4.2.0", + "markdown-it-deflist": "2.1.0", + "markdown-it-meta": "0.0.1", + "markdown-it-sup": "1.0.0", + "markdownlint": "^0.32.1", + "markdownlint-rule-helpers": "0.17.2", + "sanitize-html": "^2.11.0", + "slugify": "1.6.6", + "svgo": "^3.2.0" + }, + "peerDependencies": { + "highlight.js": "^10.0.3 || ^11" + }, + "peerDependenciesMeta": { + "highlight.js": { + "optional": true + } + } + }, "node_modules/@diplodoc/components": { "version": "4.18.1", "resolved": "https://registry.npmjs.org/@diplodoc/components/-/components-4.18.1.tgz", @@ -2343,6 +2379,8 @@ "integrity": "sha512-1s/iG/K8JfFR9x+BAu5wn1GeR/MWgjlOsFBh5Fjp7KqA/+gX+i3/VNUmiCY146A8VzX99/oFbiYSGcubytWumQ==", "license": "MIT", "dependencies": { + "@diplodoc/cut-extension": "^0.5.0", + "@diplodoc/file-extension": "^0.2.0", "@diplodoc/cut-extension": "^0.5.0", "@diplodoc/file-extension": "^0.2.0", "@diplodoc/tabs-extension": "^3.5.0", @@ -2411,6 +2449,47 @@ "markdown-it": "^13.0.2" } }, + "node_modules/@diplodoc/translation/node_modules/@diplodoc/transform": { + "version": "4.40.0", + "resolved": "https://registry.npmjs.org/@diplodoc/transform/-/transform-4.40.0.tgz", + "integrity": "sha512-fJ6Fo/kCv4r3T7ZxEEPBy0l60tU7ArOg1q9zVJcFClMowUtiavT8Pbrn6/wj/nM02OQ2ZeVc+IW3OXkPH2yRmA==", + "dependencies": { + "@diplodoc/cut-extension": "^0.5.0", + "@diplodoc/file-extension": "^0.2.0", + "@diplodoc/tabs-extension": "^3.5.0", + "chalk": "^4.1.2", + "cheerio": "^1.0.0", + "css": "^3.0.0", + "cssfilter": "0.0.10", + "get-root-node-polyfill": "1.0.0", + "github-slugger": "^1.5.0", + "js-yaml": "^4.1.0", + "lodash": "4.17.21", + "markdown-it": "^13.0.2", + "markdown-it-attrs": "^4.2.0", + "markdown-it-deflist": "2.1.0", + "markdown-it-meta": "0.0.1", + "markdown-it-sup": "1.0.0", + "markdownlint": "^0.32.1", + "markdownlint-rule-helpers": "0.17.2", + "sanitize-html": "^2.11.0", + "slugify": "1.6.6", + "svgo": "^3.2.0" + }, + "peerDependencies": { + "highlight.js": "^10.0.3 || ^11" + }, + "peerDependenciesMeta": { + "highlight.js": { + "optional": true + } + } + }, + "node_modules/@diplodoc/translation/node_modules/@diplodoc/transform/node_modules/markdown-it-deflist": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/markdown-it-deflist/-/markdown-it-deflist-2.1.0.tgz", + "integrity": "sha512-3OuqoRUlSxJiuQYu0cWTLHNhhq2xtoSFqsZK8plANg91+RJQU1ziQ6lA2LzmFAEes18uPBsHZpcX6We5l76Nzg==" + }, "node_modules/@diplodoc/translation/node_modules/markdown-it-deflist": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/markdown-it-deflist/-/markdown-it-deflist-3.0.0.tgz", @@ -2428,7 +2507,6 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/@diplodoc/utils/-/utils-1.0.0.tgz", "integrity": "sha512-rGDVyqZyJ4GUjuUIYeMG7w6w5mb1dLF/nkloWEyxqZWy/POO4GiHAG83d4wK6U3gTFGTe+BXabQzdIKZwNVCTw==", - "license": "MIT", "peer": true }, "node_modules/@esbuild/aix-ppc64": { @@ -3007,7 +3085,6 @@ "resolved": "https://registry.npmjs.org/@gravity-ui/date-components/-/date-components-2.11.0.tgz", "integrity": "sha512-raaoXQ5Uk256difnuQ6Ga4T2/IleZoF2+vE6Sl/HkmYYSNo74YoBhoY1Lo9VxcdZsqTw7uawKaRMqEBzCb3MVQ==", "dev": true, - "license": "MIT", "dependencies": { "@bem-react/classname": "^1.6.0", "@gravity-ui/date-utils": "^2.5.3", @@ -3032,11 +3109,10 @@ } }, "node_modules/@gravity-ui/dynamic-forms": { - "version": "4.14.2", - "resolved": "https://registry.npmjs.org/@gravity-ui/dynamic-forms/-/dynamic-forms-4.14.2.tgz", - "integrity": "sha512-luBKdYZ2tzthnWMPJ7oGOzEMiFN9pNvkRJZntpj6uRkogXBUWhp7X3Embp7ScNr/behqLpn0utkCrcwKigFxmQ==", + "version": "4.14.3", + "resolved": "https://registry.npmjs.org/@gravity-ui/dynamic-forms/-/dynamic-forms-4.14.3.tgz", + "integrity": "sha512-twJbOLRRY1aQR+2RvBfgaHenMoKiGKapYUKtyo17oONVOenFjTASj1dzS2GYUtkVy/Nz3TwLjkF9jo4GXH6s0A==", "dev": true, - "license": "MIT", "dependencies": { "@bem-react/classname": "^1.6.0", "@gravity-ui/components": "^3.0.0", @@ -3107,11 +3183,10 @@ } }, "node_modules/@gravity-ui/page-constructor": { - "version": "5.30.0", - "resolved": "https://registry.npmjs.org/@gravity-ui/page-constructor/-/page-constructor-5.30.0.tgz", - "integrity": "sha512-C6XMZYgADerNTZ3oxOEwvvdg5rPX+stEx79Yi1IdlZZlvV6CCSfo+oFhyJ+hyxeQXLxQtJyLrLb2oO3DAbABlw==", + "version": "5.31.1", + "resolved": "https://registry.npmjs.org/@gravity-ui/page-constructor/-/page-constructor-5.31.1.tgz", + "integrity": "sha512-ZOS8u0BxhTRk1R3BDsObFDrvHUVt4GF4DWQvxXeoTL+mZAety14xhwBU3NRMY/eBd4eYYv4PNN8N7Uj7wXitcw==", "dev": true, - "license": "MIT", "dependencies": { "@bem-react/classname": "^1.6.0", "@gravity-ui/components": "^3.8.0", @@ -3156,7 +3231,6 @@ "url": "https://github.com/sponsors/fb55" } ], - "license": "MIT", "dependencies": { "domelementtype": "^2.3.0", "domhandler": "^5.0.3", @@ -3169,7 +3243,6 @@ "resolved": "https://registry.npmjs.org/sanitize-html/-/sanitize-html-2.12.1.tgz", "integrity": "sha512-Plh+JAn0UVDpBRP/xEjsk+xDCoOvMBwQUf/K+/cBAVuTbtX8bj2VB7S1sL1dssVpykqp0/KPSesHrqXtokVBpA==", "dev": true, - "license": "MIT", "dependencies": { "deepmerge": "^4.2.2", "escape-string-regexp": "^4.0.0", @@ -3686,7 +3759,6 @@ "resolved": "https://registry.npmjs.org/@react-spring/animated/-/animated-9.7.5.tgz", "integrity": "sha512-Tqrwz7pIlsSDITzxoLS3n/v/YCUHQdOIKtOJf4yL6kYVSDTSmVK1LI1Q3M/uu2Sx4X3pIWF3xLUhlsA6SPNTNg==", "dev": true, - "license": "MIT", "dependencies": { "@react-spring/shared": "~9.7.5", "@react-spring/types": "~9.7.5" @@ -3700,7 +3772,6 @@ "resolved": "https://registry.npmjs.org/@react-spring/core/-/core-9.7.5.tgz", "integrity": "sha512-rmEqcxRcu7dWh7MnCcMXLvrf6/SDlSokLaLTxiPlAYi11nN3B5oiCUAblO72o+9z/87j2uzxa2Inm8UbLjXA+w==", "dev": true, - "license": "MIT", "dependencies": { "@react-spring/animated": "~9.7.5", "@react-spring/shared": "~9.7.5", @@ -3718,15 +3789,13 @@ "version": "9.7.5", "resolved": "https://registry.npmjs.org/@react-spring/rafz/-/rafz-9.7.5.tgz", "integrity": "sha512-5ZenDQMC48wjUzPAm1EtwQ5Ot3bLIAwwqP2w2owG5KoNdNHpEJV263nGhCeKKmuA3vG2zLLOdu3or6kuDjA6Aw==", - "dev": true, - "license": "MIT" + "dev": true }, "node_modules/@react-spring/shared": { "version": "9.7.5", "resolved": "https://registry.npmjs.org/@react-spring/shared/-/shared-9.7.5.tgz", "integrity": "sha512-wdtoJrhUeeyD/PP/zo+np2s1Z820Ohr/BbuVYv+3dVLW7WctoiN7std8rISoYoHpUXtbkpesSKuPIw/6U1w1Pw==", "dev": true, - "license": "MIT", "dependencies": { "@react-spring/rafz": "~9.7.5", "@react-spring/types": "~9.7.5" @@ -3739,15 +3808,13 @@ "version": "9.7.5", "resolved": "https://registry.npmjs.org/@react-spring/types/-/types-9.7.5.tgz", "integrity": "sha512-HVj7LrZ4ReHWBimBvu2SKND3cDVUPWKLqRTmWe/fNY6o1owGOX0cAHbdPDTMelgBlVbrTKrre6lFkhqGZErK/g==", - "dev": true, - "license": "MIT" + "dev": true }, "node_modules/@react-spring/web": { "version": "9.7.5", "resolved": "https://registry.npmjs.org/@react-spring/web/-/web-9.7.5.tgz", "integrity": "sha512-lmvqGwpe+CSttsWNZVr+Dg62adtKhauGwLyGE/RRyZ8AAMLgb9x3NDMA5RMElXo+IMyTkPp7nxTB8ZQlmhb6JQ==", "dev": true, - "license": "MIT", "dependencies": { "@react-spring/animated": "~9.7.5", "@react-spring/core": "~9.7.5", @@ -6333,8 +6400,7 @@ "version": "2.0.2", "resolved": "https://registry.npmjs.org/consolidated-events/-/consolidated-events-2.0.2.tgz", "integrity": "sha512-2/uRVMdRypf5z/TW/ncD/66l75P5hH2vM/GR8Jf8HLc2xnfJtmina6F6du8+v4Z2vTrMo7jC+W1tmEEuuELgkQ==", - "dev": true, - "license": "MIT" + "dev": true }, "node_modules/convert-source-map": { "version": "2.0.0", @@ -7344,7 +7410,6 @@ "resolved": "https://registry.npmjs.org/dom7/-/dom7-3.0.0.tgz", "integrity": "sha512-oNlcUdHsC4zb7Msx7JN3K0Nro1dzJ48knvBOnDPKJ2GV9wl1i5vydJZUSyOfrkKFDZEud/jBsTk92S/VGSAe/g==", "dev": true, - "license": "MIT", "dependencies": { "ssr-window": "^3.0.0-alpha.1" } @@ -7401,7 +7466,6 @@ "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.4.tgz", "integrity": "sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==", "dev": true, - "license": "MIT", "dependencies": { "no-case": "^3.0.4", "tslib": "^2.0.3" @@ -7462,8 +7526,7 @@ "version": "2.1.6", "resolved": "https://registry.npmjs.org/enquire.js/-/enquire.js-2.1.6.tgz", "integrity": "sha512-/KujNpO+PT63F7Hlpu4h3pE3TokKRHN26JYmQpPyjkRD/N57R7bPDNojMXdi7uveAKjYB7yQnartCxZnFWr0Xw==", - "dev": true, - "license": "MIT" + "dev": true }, "node_modules/ensure-posix-path": { "version": "1.1.1", @@ -8550,7 +8613,6 @@ "resolved": "https://registry.npmjs.org/final-form/-/final-form-4.20.10.tgz", "integrity": "sha512-TL48Pi1oNHeMOHrKv1bCJUrWZDcD3DIG6AGYVNOnyZPr7Bd/pStN0pL+lfzF5BNoj/FclaoiaLenk4XUIFVYng==", "dev": true, - "license": "MIT", "dependencies": { "@babel/runtime": "^7.10.0" }, @@ -8833,8 +8895,7 @@ "version": "2.23.0", "resolved": "https://registry.npmjs.org/github-buttons/-/github-buttons-2.23.0.tgz", "integrity": "sha512-2REUOV3ue6NmT0QThhfzfYmeSoYpCG73+tL7Ir2C7P+gshRerI05WuIQuhDkE2Zlg5Wc39hc2DHj+pE23mGJvw==", - "dev": true, - "license": "BSD-2-Clause" + "dev": true }, "node_modules/github-slugger": { "version": "1.5.0", @@ -9932,7 +9993,6 @@ "resolved": "https://registry.npmjs.org/js-yaml-source-map/-/js-yaml-source-map-0.2.2.tgz", "integrity": "sha512-z45Aww8oXJh9GuWUnwmvHsAkB7I/oWrkoHU554UQ8Ik4dyhVrk/nwClTI435feU7QIy7E0XaW8jHvZ4QxaAjog==", "dev": true, - "license": "MIT", "peerDependencies": { "js-yaml": "^4.0.0" } @@ -9991,7 +10051,6 @@ "resolved": "https://registry.npmjs.org/json2mq/-/json2mq-0.2.0.tgz", "integrity": "sha512-SzoRg7ux5DWTII9J2qkrZrqV1gt+rTaoufMxEzXbS26Uid0NwaJd123HcoB80TgubEppxxIGdNxCx50fEoEWQA==", "dev": true, - "license": "MIT", "dependencies": { "string-convert": "^0.2.0" } @@ -10341,8 +10400,7 @@ "version": "4.0.8", "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==", - "dev": true, - "license": "MIT" + "dev": true }, "node_modules/lodash.merge": { "version": "4.6.2", @@ -10464,7 +10522,6 @@ "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.2.tgz", "integrity": "sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==", "dev": true, - "license": "MIT", "dependencies": { "tslib": "^2.0.3" } @@ -11457,8 +11514,7 @@ "version": "0.38.0", "resolved": "https://registry.npmjs.org/monaco-editor/-/monaco-editor-0.38.0.tgz", "integrity": "sha512-11Fkh6yzEmwx7O0YoLxeae0qEGFwmyPRlVxpg7oF9czOOCB/iCjdJrG5I67da5WiXK3YJCxoz9TJFE8Tfq/v9A==", - "dev": true, - "license": "MIT" + "dev": true }, "node_modules/mri": { "version": "1.2.0", @@ -11504,7 +11560,6 @@ "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.4.tgz", "integrity": "sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==", "dev": true, - "license": "MIT", "dependencies": { "lower-case": "^2.0.2", "tslib": "^2.0.3" @@ -12420,7 +12475,6 @@ "resolved": "https://registry.npmjs.org/react-final-form/-/react-final-form-6.5.9.tgz", "integrity": "sha512-x3XYvozolECp3nIjly+4QqxdjSSWfcnpGEL5K8OBT6xmGrq5kBqbA6+/tOqoom9NwqIPPbxPNsOViFlbKgowbA==", "dev": true, - "license": "MIT", "dependencies": { "@babel/runtime": "^7.15.4" }, @@ -12501,7 +12555,6 @@ "resolved": "https://registry.npmjs.org/react-monaco-editor/-/react-monaco-editor-0.53.0.tgz", "integrity": "sha512-ZITzsauH4CsicCGddtpgjRACaKNTVEL2hnjYFx8QMuc8zmsgfgq7D2GcF8OQsa2URIdGm/Zl7YwY2fmWpvqs/g==", "dev": true, - "license": "MIT", "dependencies": { "prop-types": "^15.8.1" }, @@ -12516,7 +12569,6 @@ "resolved": "https://registry.npmjs.org/react-player/-/react-player-2.16.0.tgz", "integrity": "sha512-mAIPHfioD7yxO0GNYVFD1303QFtI3lyyQZLY229UEAp/a10cSW+hPcakg0Keq8uWJxT2OiT/4Gt+Lc9bD6bJmQ==", "dev": true, - "license": "MIT", "dependencies": { "deepmerge": "^4.0.0", "load-script": "^1.0.0", @@ -12585,7 +12637,6 @@ "resolved": "https://registry.npmjs.org/react-slick/-/react-slick-0.29.0.tgz", "integrity": "sha512-TGdOKE+ZkJHHeC4aaoH85m8RnFyWqdqRfAGkhd6dirmATXMZWAxOpTLmw2Ll/jPTQ3eEG7ercFr/sbzdeYCJXA==", "dev": true, - "license": "MIT", "dependencies": { "classnames": "^2.2.5", "enquire.js": "^2.1.6", @@ -12632,7 +12683,6 @@ "resolved": "https://registry.npmjs.org/react-waypoint/-/react-waypoint-10.3.0.tgz", "integrity": "sha512-iF1y2c1BsoXuEGz08NoahaLFIGI9gTUAAOKip96HUmylRT6DUtpgoBPjk/Y8dfcFVmfVDvUzWjNXpZyKTOV0SQ==", "dev": true, - "license": "MIT", "dependencies": { "@babel/runtime": "^7.12.5", "consolidated-events": "^1.1.0 || ^2.0.0", @@ -13387,7 +13437,6 @@ "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-3.0.4.tgz", "integrity": "sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg==", "dev": true, - "license": "MIT", "dependencies": { "dot-case": "^3.0.4", "tslib": "^2.0.3" @@ -13398,7 +13447,6 @@ "resolved": "https://registry.npmjs.org/snakecase-keys/-/snakecase-keys-5.5.0.tgz", "integrity": "sha512-r3kRtnoPu3FxGJ3fny6PKNnU3pteb29o6qAa0ugzhSseKNWRkw1dw8nIjXMyyKaU9vQxxVIE62Mb3bKbdrgpiw==", "dev": true, - "license": "MIT", "dependencies": { "map-obj": "^4.1.0", "snake-case": "^3.0.4", @@ -13413,7 +13461,6 @@ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-3.13.1.tgz", "integrity": "sha512-tLq3bSNx+xSpwvAJnzrK0Ep5CLNWjvFTOp71URMaAEWBfRb9nnJiBoUe0tF8bI4ZFO3omgBR6NvnbzVUT3Ly4g==", "dev": true, - "license": "(MIT OR CC0-1.0)", "engines": { "node": ">=14.16" }, @@ -13492,8 +13539,7 @@ "version": "3.0.0", "resolved": "https://registry.npmjs.org/ssr-window/-/ssr-window-3.0.0.tgz", "integrity": "sha512-q+8UfWDg9Itrg0yWK7oe5p/XRCJpJF9OBtXfOPgSJl+u3Xd5KI328RUEvUqSMVM9CiQUEf1QdBzJMkYGErj9QA==", - "dev": true, - "license": "MIT" + "dev": true }, "node_modules/stackback": { "version": "0.0.2", @@ -13537,8 +13583,7 @@ "version": "0.2.1", "resolved": "https://registry.npmjs.org/string-convert/-/string-convert-0.2.1.tgz", "integrity": "sha512-u/1tdPl4yQnPBjnVrmdLo9gtuLvELKsAoRapekWggdiQNvvvum+jYF329d84NAa660KQw7pB2n36KrIKVoXa3A==", - "dev": true, - "license": "MIT" + "dev": true }, "node_modules/string-width": { "version": "5.1.2", @@ -14063,7 +14108,6 @@ } ], "hasInstallScript": true, - "license": "MIT", "dependencies": { "dom7": "^3.0.0", "ssr-window": "^3.0.0" @@ -14527,7 +14571,6 @@ "resolved": "https://registry.npmjs.org/typograf/-/typograf-6.15.1.tgz", "integrity": "sha512-G1IIJlh4ycW+rvTspdgZKQoj/fKpmwif6MUhrmn3LY50W8njRnBqdFIJcfDqbmDg+RmmP51R9jdjjMwBYA5P0Q==", "dev": true, - "license": "MIT", "engines": { "node": ">= 4" } @@ -14680,7 +14723,6 @@ "resolved": "https://registry.npmjs.org/utility-types/-/utility-types-3.11.0.tgz", "integrity": "sha512-6Z7Ma2aVEWisaL6TvBCy7P8rm2LQoPv6dJ7ecIaIixHcwfbJ0x7mWdbcwlIM5IGQxPZSFYeqRCqlOOeKoJYMkw==", "dev": true, - "license": "MIT", "engines": { "node": ">= 4" } diff --git a/src/constants.ts b/src/constants.ts index 9091ac78..5416e5bb 100644 --- a/src/constants.ts +++ b/src/constants.ts @@ -124,6 +124,28 @@ export const YFM_PLUGINS = [ blockAnchor, ]; +export const MD2MD_PARSER_PLUGINS = [ + meta, + deflist, + cut, + images, + notes, + anchors, + tabs, + code, + imsize, + sup, + video, + monospace, + table, + term, + openapi.transform(), + mermaid.transform({bundle: false}), + latex.transform({bundle: false}), + changelog, + blockAnchor, +]; + export const CARRIAGE_RETURN = platform === Platforms.WINDOWS ? '\r\n' : '\n'; export const PROCESSING_FINISHED = 'Processing finished:'; diff --git a/src/models.ts b/src/models.ts index cf35ab10..379bc7f5 100644 --- a/src/models.ts +++ b/src/models.ts @@ -26,7 +26,6 @@ export type NestedContributorsForPathFunction = ( nestedContributors: Contributors, ) => void; export type UserByLoginFunction = (login: string) => Promise; -export type CollectionOfPluginsFunction = (output: string, options: PluginOptions) => string; export type GetModifiedTimeByPathFunction = (filepath: string) => number | undefined; /** @@ -237,7 +236,6 @@ export interface PluginOptions { root?: string; destPath?: string; destRoot?: string; - collectOfPlugins?: (input: string, options: PluginOptions) => string; changelogs?: ChangelogItem[]; extractChangelogs?: boolean; included?: boolean; diff --git a/src/resolvers/md2md.ts b/src/resolvers/md2md.ts index 33ba305b..9a5ea688 100644 --- a/src/resolvers/md2md.ts +++ b/src/resolvers/md2md.ts @@ -7,11 +7,14 @@ import log from '@diplodoc/transform/lib/log'; import liquid from '@diplodoc/transform/lib/liquid'; import {ArgvService, PluginService} from '../services'; -import {getVarsPerFile, logger} from '../utils'; +import {getVarsPerFile, getVarsPerRelativeFile, logger} from '../utils'; import {PluginOptions, ResolveMd2MdOptions} from '../models'; -import {PROCESSING_FINISHED} from '../constants'; +import {MD2MD_PARSER_PLUGINS, PROCESSING_FINISHED} from '../constants'; import {ChangelogItem} from '@diplodoc/transform/lib/plugins/changelog/types'; import {enrichWithFrontMatter} from '../services/metadata'; +import transform from '@diplodoc/transform'; +import {MarkdownItPluginCb} from '@diplodoc/transform/lib/plugins/typings'; +import {getPublicPath} from '@diplodoc/transform/lib/utilsFS'; export async function resolveMd2Md(run: Run, options: ResolveMd2MdOptions): Promise { const {inputPath, outputPath, metadata: metadataOptions} = options; @@ -34,7 +37,6 @@ export async function resolveMd2Md(run: Run, options: ResolveMd2MdOptions): Prom destPath: outputPath, root: resolve(input), destRoot: resolve(output), - collectOfPlugins: PluginService.getCollectOfPlugins(), vars: vars, log, copyFile, @@ -107,28 +109,36 @@ export function liquidMd2Md(input: string, vars: Record, path: } function transformMd2Md(input: string, options: PluginOptions) { - const {disableLiquid, changelogs: changelogsSetting} = ArgvService.getConfig(); - const {vars = {}, path, collectOfPlugins, log: pluginLog} = options; + const {input: inputDir, changelogs: changelogsSetting, ...mdOptions} = ArgvService.getConfig(); + const plugins = PluginService.getPlugins(); + const {vars = {}, path, log: pluginLog} = options; - let output = input; - const changelogs: ChangelogItem[] = []; - - if (!disableLiquid) { - const liquidResult = liquidMd2Md(input, vars, path); + const root = resolve(inputDir); - output = liquidResult.output; - } + const changelogs: ChangelogItem[] = []; - if (collectOfPlugins) { - output = collectOfPlugins(output, { + const output = transform.collect(input, { + mdItInitOptions: { + mdOptions, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + plugins: plugins as MarkdownItPluginCb[], + vars, + root, + path, + assetsPublicPath: './', + getVarsPerFile: getVarsPerRelativeFile, + getPublicPath, + extractTitle: true, + }, + pluginCollectOptions: { ...options, vars, path, - collectOfPlugins, changelogs, extractChangelogs: Boolean(changelogsSetting), - }); - } + }, + parserPluginsOverride: MD2MD_PARSER_PLUGINS, + }); return { result: output, diff --git a/src/services/plugins.ts b/src/services/plugins.ts index b941a0ab..46ee6cae 100644 --- a/src/services/plugins.ts +++ b/src/services/plugins.ts @@ -1,42 +1,18 @@ import {LintConfig, LintRule} from '@diplodoc/transform/lib/yfmlint'; -import {CollectionOfPluginsFunction, Plugin, PluginOptions} from '../models'; +import {Plugin} from '../models'; import {YFM_PLUGINS} from '../constants'; let plugins: Function[] | Plugin[]; -let collectionOfPlugins: CollectionOfPluginsFunction; export function setPlugins(): void { plugins = getAllPlugins(); - collectionOfPlugins = makeCollectOfPlugins(); } export function getPlugins() { return plugins; } -export function getCollectOfPlugins(): CollectionOfPluginsFunction { - return collectionOfPlugins; -} - -function makeCollectOfPlugins(): CollectionOfPluginsFunction { - const pluginsWithCollect = (plugins as Plugin[]).filter((plugin: Plugin) => { - return typeof plugin.collect === 'function'; - }); - - return (output: string, options: PluginOptions) => { - let collectsOutput = output; - - pluginsWithCollect.forEach((plugin: Plugin) => { - const collectOutput = plugin.collect(collectsOutput, options); - - collectsOutput = typeof collectOutput === 'string' ? collectOutput : collectsOutput; - }); - - return collectsOutput; - }; -} - function getAllPlugins(): Function[] { const customPlugins = getCustomPlugins(); return [...YFM_PLUGINS, ...customPlugins];