mirror of
https://github.com/tenrok/BBob.git
synced 2026-06-11 18:02:26 +03:00
feat: typescript support (#185)
* feat: initial typescript support * feat: typescript support * feat(plugin-helper): move files to typescript * chore: update lock files * feat: preset types * fix: build * fix: benchmark * fix: remove pnpm cache * fix: bench action * fix: pnpm recursive install * fix: nx cache * fix: lock file * fix: workflows * fix: lerna support in pnpm * fix: pnpm workspace * fix: remove unused files * fix: pnpm lock file * fix: update lerna for support pnpm * fix: lerna bootstrap * fix: rollup build * fix: update nx * fix: build * fix: add nx dep target * fix: remove nx cache * fix: workflow run on push only for master * fix: test workflow run on push only for master * fix: remove parallel for gen types * fix: benchmark * fix: benchmark imports * fix: pnpm * fix: types errors and pnpm * fix: types * fix: types * refactor: parser * fix(parser): tests * fix: preset tests * fix: react types * fix: react type declarations * fix: pnpm lock file * fix: react preset types * fix: lock file * fix: vue2 types * feat: dev container support * fix: types * fix: types * refactor: rewrite pkg-task, add nx gen-types deps, fix react/render.ts * refactor: types * fix: types * fix: rename gen-types to types * fix: nx build order * fix: nx reset * fix: define nx deps explicit * fix: build * fix: nx * fix: nx order build * fix: nx deps * fix: bbob cli tests * fix: tests * fix: cli tests and import * fix: test cover * fix: cli cover
This commit is contained in:
@@ -1,47 +0,0 @@
|
||||
import core from '@bbob/core';
|
||||
import { attrsToString } from '@bbob/plugin-helper';
|
||||
|
||||
const SELFCLOSE_END_TAG = '/>';
|
||||
const CLOSE_START_TAG = '</';
|
||||
const START_TAG = '<';
|
||||
const END_TAG = '>';
|
||||
|
||||
const renderNode = (node, { stripTags = false }) => {
|
||||
if (!node) return '';
|
||||
const type = typeof node;
|
||||
|
||||
if (type === 'string' || type === 'number') {
|
||||
return node;
|
||||
}
|
||||
|
||||
if (type === 'object') {
|
||||
if (stripTags === true) {
|
||||
// eslint-disable-next-line no-use-before-define
|
||||
return renderNodes(node.content, { stripTags });
|
||||
}
|
||||
|
||||
if (node.content === null) {
|
||||
return [START_TAG, node.tag, attrsToString(node.attrs), SELFCLOSE_END_TAG].join('');
|
||||
}
|
||||
|
||||
// eslint-disable-next-line no-use-before-define
|
||||
return [START_TAG, node.tag, attrsToString(node.attrs), END_TAG, renderNodes(node.content), CLOSE_START_TAG, node.tag, END_TAG].join('');
|
||||
}
|
||||
|
||||
if (Array.isArray(node)) {
|
||||
// eslint-disable-next-line no-use-before-define
|
||||
return renderNodes(node, { stripTags });
|
||||
}
|
||||
|
||||
return '';
|
||||
};
|
||||
|
||||
const renderNodes = (nodes, { stripTags = false } = {}) => []
|
||||
.concat(nodes)
|
||||
.reduce((r, node) => r + renderNode(node, { stripTags }), '');
|
||||
|
||||
const toHTML = (source, plugins, options) => core(plugins)
|
||||
.process(source, { ...options, render: renderNodes }).html;
|
||||
|
||||
export const render = renderNodes;
|
||||
export default toHTML;
|
||||
@@ -0,0 +1,61 @@
|
||||
import core, { BBobCoreOptions, BBobPlugins } from '@bbob/core';
|
||||
import { attrsToString, isTagNode, TagNode, TagNodeTree } from '@bbob/plugin-helper';
|
||||
|
||||
const SELFCLOSE_END_TAG = '/>';
|
||||
const CLOSE_START_TAG = '</';
|
||||
const START_TAG = '<';
|
||||
const END_TAG = '>';
|
||||
|
||||
export type BBobHTMLOptions = {
|
||||
stripTags?: boolean
|
||||
} & BBobCoreOptions
|
||||
|
||||
function renderNode(node?: TagNodeTree, options?: BBobHTMLOptions): string {
|
||||
const { stripTags = false } = options || {}
|
||||
|
||||
if (typeof node === 'undefined' || node === null) {
|
||||
return ''
|
||||
}
|
||||
|
||||
if (typeof node === 'string' || typeof node === 'number') {
|
||||
return String(node);
|
||||
}
|
||||
|
||||
if (Array.isArray(node)) {
|
||||
return render(node, options);
|
||||
}
|
||||
|
||||
if (isTagNode(node)) {
|
||||
if (stripTags) {
|
||||
return render(node.content, options);
|
||||
}
|
||||
|
||||
const attrs = attrsToString(node.attrs)
|
||||
|
||||
if (node.content === null) {
|
||||
return START_TAG + node.tag + attrs + SELFCLOSE_END_TAG
|
||||
}
|
||||
|
||||
return START_TAG + node.tag + attrs + END_TAG + render(node.content, options) + CLOSE_START_TAG + node.tag + END_TAG;
|
||||
}
|
||||
|
||||
return '';
|
||||
}
|
||||
|
||||
export function render(nodes: TagNodeTree, options?: BBobHTMLOptions): string {
|
||||
if (Array.isArray(nodes)) {
|
||||
return nodes.reduce<string>((r, node) => r + renderNode(node, options), '')
|
||||
}
|
||||
|
||||
if (nodes) {
|
||||
return renderNode(nodes, options)
|
||||
}
|
||||
|
||||
return ''
|
||||
}
|
||||
|
||||
export function html<InputValue = string | TagNode[]>(source: InputValue, plugins: BBobPlugins, options?: BBobHTMLOptions) {
|
||||
return core<InputValue, BBobHTMLOptions>(plugins).process(source, { ...options, render: render }).html
|
||||
}
|
||||
|
||||
export default html;
|
||||
Reference in New Issue
Block a user