Skip to content

Commit

Permalink
feat: add "inline" directive (#672)
Browse files Browse the repository at this point in the history
Co-authored-by: Ben McCann <[email protected]>
  • Loading branch information
pzerelles and benmccann authored Mar 27, 2024
1 parent dc25e4b commit 7542fa5
Show file tree
Hide file tree
Showing 5 changed files with 57 additions and 3 deletions.
5 changes: 5 additions & 0 deletions .changeset/loud-comics-kick.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'vite-imagetools': minor
---

feat: add "inline" directive
17 changes: 17 additions & 0 deletions docs/directives.md
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
- [Source](#source)
- [Srcset](#srcset)
- [URL](#url)
- [Inline](#inline)

### Output Directives

Expand Down Expand Up @@ -508,3 +509,19 @@ Returns a URL to the generated image. This is the default when your directives p
```js
import Image from 'example.jpg?w=500' // the type of Image is a string and it's a URL to the transformed image
```

---

### Inline

**Keyword**: `inline`<br>**Type**: _boolean_<br>

Return base64 encoded inline image instead of URL to the generated image. This can be combined with some output directives like `srcset` or `picture`.

**Example**:

```js
import inlineImage from 'example.jpg?format=webp&inline';
```

The returned `inlineImage` will start with `data:image/webp;base64,...`
3 changes: 3 additions & 0 deletions packages/vite/src/__tests__/__fixtures__/inline.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
23 changes: 23 additions & 0 deletions packages/vite/src/__tests__/main.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -516,6 +516,29 @@ describe('vite-imagetools', () => {
expect(files[0].source).toMatchImageSnapshot()
})

test('inline import', async () => {
const bundle = (await build({
root: join(__dirname, '__fixtures__'),
logLevel: 'warn',
build: { write: false },
plugins: [
testEntry(`
import Image from "./inline.png?inline"
window.__IMAGE__ = Image
`),
imagetools()
]
})) as RollupOutput | RollupOutput[]

const files = getFiles(bundle, '**.js') as OutputChunk[]
const { window } = new JSDOM(``, { runScripts: 'outside-only' })
window.eval(files[0].code)

expect(window.__IMAGE__).toBe(
''
)
})

test('non existent file', async () => {
const p = build({
root: join(__dirname, '__fixtures__'),
Expand Down
12 changes: 9 additions & 3 deletions packages/vite/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { basename, extname } from 'node:path'
import { join } from 'node:path/posix'
import type { Plugin, ResolvedConfig } from 'vite'
import {
applyTransforms,
Expand Down Expand Up @@ -126,10 +127,15 @@ export function imagetools(userOptions: Partial<VitePluginOptions> = {}): Plugin
const { transforms } = generateTransforms(config, transformFactories, srcURL.searchParams, logger)
const { image, metadata } = await applyTransforms(transforms, img.clone(), pluginOptions.removeMetadata)

let imageId: string
if (viteConfig.command === 'serve') {
const id = await generateImageID(srcURL, config, img)
generatedImages.set(id, image)
metadata.src = path.posix.join(viteConfig?.server?.origin ?? '', basePath) + id
imageId = await generateImageID(srcURL, config, img)
generatedImages.set(imageId, image)
}
if (directives.has('inline')) {
metadata.src = `data:image/${metadata.format};base64,${(await image.toBuffer()).toString('base64')}`
} else if (viteConfig.command === 'serve') {
metadata.src = join(viteConfig?.server?.origin ?? '', basePath) + imageId
} else {
const fileHandle = this.emitFile({
name: basename(pathname, extname(pathname)) + `.${metadata.format}`,
Expand Down

0 comments on commit 7542fa5

Please sign in to comment.