1.0.1 • Published 2 years ago

@devlulcas/rehype-base64-image-swapper v1.0.1

Weekly downloads
-
License
ISC
Repository
github
Last release
2 years ago

javascript

REHYPE BASE64 IMAGE SRC SWAPPER

Warning: Work in progress

USAGE

import { unified } from "unified";
import rehypeParse from "rehype-parse";
import rehypeStringify from "rehype-stringify";
import rehypeBase64ImageExtractor from "./index.js";

const html = `
<p>AVIF</p>
<p>
  <img
    src=""
  />
</p>
`;

const virtualFile = unified()
  .use(rehypeParse, { fragment: true })
  .use(rehypeBase64ImageExtractor, {
    handler: async ({ mimetype, content }) => {
      const response = await fetch("https://my.api.com/send", {
        method: "POST",
        body: JSON.stringify({ mimetype, content }),
      });

      const data = await response.json();

      // Ex: https://my.api.com/images/example.avif
      return data.resourceUrl;
    },
  })
  .use(rehypeStringify)
  .process(html);

// Tranformed HTML
virtualFile.then((newHtmlVirtualFile) => {
  console.log(String(newHtmlVirtualFile));
});

ROADMAP

  • Migrate to Typescript
  • Add tests
  • Publish in NPM
  • Add documentation