Skip to content

Commit

Permalink
docs: add clearer examples of making a custom provider (nuxt#1074)
Browse files Browse the repository at this point in the history
  • Loading branch information
reslear authored and riddla committed Mar 1, 2024
1 parent cc63f6d commit cc16e2d
Showing 1 changed file with 35 additions and 16 deletions.
51 changes: 35 additions & 16 deletions docs/content/4.advanced/1.custom-provider.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,18 +7,27 @@ description: If a CDN provider is not supported, you can define it yourself.

The runtime will receive a source, image modifiers and its provider options. It is responsible for generating a url for optimized images, and needs to be isomorphic because it may be called on either server or client.

```js
```ts [providers/my-provider.ts]
import { joinURL } from 'ufo'
import type { ProviderGetImage } from '@nuxt/image'
import { createOperationsGenerator } from '#image'

// import {} from '#image'
const operationsGenerator = createOperationsGenerator()

export const getImage: ProviderGetImage = (
src,
{ modifiers = {}, baseURL } = {}
) => {

if (!baseURL) {
// also support runtime config
baseURL = useRuntimeConfig().public.siteUrl
}

const operations = operationsGenerator(modifiers)

export function getImage(src, { modifiers, baseURL } = {}, { options, $img }) {
const { width, height, format, fit, ...providerModifiers } = modifiers
const operations = []
// process modifiers
const operationsString = operations.join(',')
return {
url: joinURL(baseURL, operationsString, src)
url: joinURL(baseURL, src + (operations ? '?' + operations : '')),
}
}
```
Expand All @@ -43,21 +52,31 @@ export function getImage(src, { modifiers, baseURL } = {}, { options, $img }) {

After you create your own provider, you should register it in the `nuxt.config`. In order to do that create a property inside `image.provider`.

```js
export default {
...
```ts [nuxt.config.ts]
export default defineNuxtConfig({
// ...
image: {
providers: {
customProvider: {
name: 'customProvider', // optional value to overrider provider name
provider: '~/providers/custom', // Path to custom provider
myProvider: {
name: 'myProvider', // optional value to overrider provider name
provider: '~/providers/my-provider.ts', // Path to custom provider
options: {
// ... provider options
baseURL: "https://site.com"
}
}
}
}
}
})
```

There are plenty of useful utilities that can be used to write providers by importing from `#image`. See [src/runtime/providers](https://github.com/nuxt/image/tree/dev/src/runtime/providers) for more info.

### Usage
Set attribute `provider` as your custom provider name.

```vue [pages/index.vue]
<NuxtImg provider="myProvider" src="/image.png" >
<!-- <img src="https://site.com/image.png" /> -->
```

There are plenty of useful utilities that can be used to write providers by importing from `#img`. See [src/runtime/providers](https://github.com/nuxt/image/tree/dev/src/runtime/providers) for more info.

0 comments on commit cc16e2d

Please sign in to comment.