2.0.0 • Published 3 years ago
remark-copy-reference-files v2.0.0
remark-copy-reference-files
installation
yarn add remark-copy-reference-files
usage
Say we have the following markdown:
[path to file](files/sample-file.txt)
<img src="images/sample-image.png" />
<img src="images/sample-image.jpeg" />
<img src="images/sample-image.jpg" />
<a href="files/sample-file.txt">link to file</a>
<a href="http://example.com/">Link to example.com</a>
data:image/s3,"s3://crabby-images/e26c1/e26c155d89b8dff1a5874f5a68456a126aa1efe7" alt="some svg image"
data:image/s3,"s3://crabby-images/2abc5/2abc53d358deb206dd83b4ddd4ae4d77e15541be" alt="some gif image"
data:image/s3,"s3://crabby-images/59c4e/59c4e51971685cd8fffa3441b88d8ae3a0bce2e2" alt="some png image"
data:image/s3,"s3://crabby-images/86be1/86be13e65d69902a115d6aecdfe5fc1814af68a6" alt="some jpg image"
data:image/s3,"s3://crabby-images/ab454/ab454a5f287effdecb87f666121412baa036d0d1" alt="some jpeg image"
data:image/s3,"s3://crabby-images/1f90a/1f90af822abe15ccba11ace80d1252317444e3b6" alt="some absolute image"
<video controls="controls" autoplay loop>
<source type="video/mp4" src="videos/sample-video.mp4"/>
<p>Your browser does not support the video element.</p>
</video>
![sample][1]
[1]: images/sample-image.png
And our script looks as follows:
const destinationDir = __dirname;
remark()
.use(require('remark-copy-reference-files'), { destinationDir })
.use(require('remark-html'))
.process(VFile({ path, contents }));
Now, running it yields:
<p>
<a href="/sample-file-3324f2167c.txt">path to file</a>
</p>
<img src="/sample-image-1e02a85bee.png" />
<img src="/sample-image-5aa858befc.jpeg" />
<img src="/sample-image-5aa858befc.jpg" />
<a href="/sample-file-3324f2167c.txt">link to file</a>
<a href="http://example.com/">Link to example.com</a>
<p>
<img src="/sample-image-5e25d61b3f.svg" alt="some svg image" />
<img src="/sample-image-76faedf4c5.gif" alt="some gif image" />
<img src="/sample-image-1e02a85bee.png" alt="some png image" />
<img src="/sample-image-5aa858befc.jpg" alt="some jpg image" />
<img src="/sample-image-5aa858befc.jpeg" alt="some jpeg image" />
<img
src="https://google.com/images/sample-image.gif"
alt="some absolute image"
/>
</p>
<video controls="controls" autoplay loop>
<source type="video/mp4" src="/sample-video-d9061d3da8.mp4" />
<p>Your browser does not support the video element.</p>
</video>
<p>
<img src="/sample-image-1e02a85bee.png" alt="sample" />
</p>
And writes the following files:
.
├── sample-file-3324f2167c.txt
├── sample-image-1e02a85bee.png
├── sample-image-5aa858befc.jpeg
├── sample-image-5aa858befc.jpg
├── sample-image-5e25d61b3f.svg
├── sample-image-76faedf4c5.gif
└── sample-video-d9061d3da8.mp4
0 directories, 7 files
license
BSD-3-Clause