A JavaScript library to convert HTML-rich offer & product descriptions into a format accepted by Allegro Rest API.
Provide means to ease the conversion of HTML-rich offer & product descriptions into a format accepted by Allegro Rest API. As such, the library covers basic functionality. Any client-specific behavior must be provided externally. The library can facilitate that through extensibility.
The library requires DOM API, which can be provided in two ways: either implicitly
as globals by the browser environment or explicitly as the parseToDOM
function in the Node.js environment (see
Usage section).
The following requirements apply to Node.js as a runtime or build environment.
- node version >=20
- npm version >=10
npm i @allegro/convert-description
For the Node.js runtime environment, include jsdom.
npm i @allegro/convert-description jsdom
JavaScript code
import { convertDescriptionToItems } from '@allegro/convert-description';
const description = `
<div>
<div>test content</div>
<img src="/test_url" />
</div>
`;
const items = convertDescriptionToItems(description);
console.log(JSON.stringify(items));
Code output
[{"type":"TEXT","content":"<p>test content</p>"},{"type":"IMAGE","url":"/test_url"}]
For the Node.js runtime environment, pass the parseToDOM
function.
import { convertDescriptionToItems } from '@allegro/convert-description';
import { JSDOM } from 'jsdom';
function parseToDOM(html) {
return new JSDOM(html);
}
const description = `
<div>
<div>test content</div>
<img src="/test_url" />
</div>
`;
const items = convertDescriptionToItems(description, { parseToDOM });
console.log(JSON.stringify(items));
Caution
Any option to convertDescriptionToItems
that is not mentioned in the documentation is subject to change. If you
need anything more than the listed options, ask a question by opening an issue or contribute by creating a pull
request.
$ echo "<p>Hello World</p>" | npx @allegro/convert-description
[{"type":"TEXT","content":"<p>Hello World</p>"}]