c55d1f912f
* v1.0.0-alpha44
123 lines
4.9 KiB
Plaintext
123 lines
4.9 KiB
Plaintext
---
|
|
group: Media
|
|
title: Uploadcare
|
|
weight: 30
|
|
---
|
|
|
|
## <img src="https://img.shields.io/badge/-Beta%20Feature-blue" alt="Beta Feature. Use at your own risk" title="Beta Feature. Use at your own risk" />
|
|
|
|
Uploadcare is a sleek service that allows you to upload files without worrying about maintaining a growing collection — more of an asset store than a library. Just upload when you need to, and the files are hosted on their CDN. They provide image processing controls from simple cropping and rotation to filters and face detection, and a lot more. You can check out Uploadcare's full feature set on their [website](https://uploadcare.com/).
|
|
|
|
The Uploadcare media library integration for Static CMS allows you to use Uploadcare as your media handler within the CMS itself. It's available by default as of our 2.1.0 release, and works in tandem with the existing file and image widgets, so using it only requires creating an Uploadcare account and updating your Static CMS configuration.
|
|
|
|
**Please make sure that Static CMS is updated to 2.1.0 or greater before proceeding.**
|
|
|
|
## Creating an Uploadcare Account
|
|
|
|
You can [sign up](https://uploadcare.com/accounts/signup/) for a free Uploadcare account to get started. Once you've signed up, go to your dashboard, select a project, and then select "API keys" from the menu on the left. The public key on the API keys page will be needed in your Static CMS configuration. For more info on getting your API key, visit their [walkthrough](https://uploadcare.com/docs/keys/).
|
|
|
|
## Updating Static CMS Configuration
|
|
|
|
The next and final step is updating your Static CMS configuration file:
|
|
|
|
1. Add a `media_library` property at the same level as `media_folder`, with an object as it's value.
|
|
2. In the `media_library` object, add the name of the media player under `name`.
|
|
3. Add a `config` object under name with a `publicKey` property with your Uploadcare public key as it's value.
|
|
|
|
Your `config` should now include something like this (except with a real API key):
|
|
|
|
<CodeTabs>
|
|
```yaml
|
|
media_library:
|
|
name: uploadcare
|
|
config:
|
|
publicKey: YOUR_UPLOADCARE_PUBLIC_KEY
|
|
```
|
|
|
|
```js
|
|
media_library: {
|
|
name: 'uploadcare',
|
|
config: {
|
|
publicKey: 'YOUR_UPLOADCARE_PUBLIC_KEY',
|
|
},
|
|
},
|
|
```
|
|
</CodeTabs>
|
|
|
|
Once you've finished updating your Static CMS configuration, the Uploadcare widget will appear when using the image or file widgets.
|
|
|
|
**Note:** You'll need to [register the media libraries yourself](/blog/2019/07/netlify-cms-gatsby-plugin-4-0-0#using-media-libraries-with-netlify-cms-app).
|
|
|
|
## Configuring the Uploadcare Widget
|
|
|
|
The Uploadcare widget can be configured with settings that are outlined [in their docs](https://uploadcare.com/docs/file_uploads/widget/options/). The widget itself accepts configuration through global variables and data properties on HTML elements, but with Static CMS you can pass configuration options directly through your `config`.
|
|
|
|
**Note:** all default values described in Uploadcare's documentation also apply in the Static CMS integration, except for `previewStep`, which is set to `true`. This was done because the preview step provides helpful information like upload status, and provides access to image editing controls. This option can be disabled through the configuration options below.
|
|
|
|
### Global configuration
|
|
|
|
Global configuration, which is meant to affect the Uploadcare widget at all times, can be provided as seen above, under the primary `media_library` property. Settings applied here will affect every instance of the Uploadcare widget.
|
|
|
|
## Field configuration
|
|
|
|
Configuration can also be provided for individual fields that use the media library. The structure is very similar to the global configuration, except the settings are added to an individual `field`. For example:
|
|
|
|
<CodeTabs>
|
|
```yaml
|
|
fields:
|
|
name: cover
|
|
label: Cover Image
|
|
widget: image
|
|
media_library:
|
|
config:
|
|
multiple: true
|
|
previewStep: false
|
|
```
|
|
|
|
```js
|
|
fields: {
|
|
name: 'cover',
|
|
label: 'Cover Image',
|
|
widget: 'image',
|
|
media_library: {
|
|
config: {
|
|
multiple: true,
|
|
previewStep: false,
|
|
},
|
|
},
|
|
},
|
|
```
|
|
</CodeTabs>
|
|
|
|
## Integration settings
|
|
|
|
There are several settings that control the behavior of integration with the widget.
|
|
|
|
* `autoFilename` (`boolean`) - specify whether to add a filename to the end of the url. Example: `http://ucarecdn.com/:uuid/filename.png`
|
|
* `defaultOperations` (`string`) - specify a string added at the end of the url. This could be useful to apply a set of CDN operations to each image, for example resizing or compression. All the possible operations are listed [here](https://uploadcare.com/docs/api_reference/cdn/).
|
|
|
|
<CodeTabs>
|
|
```yaml
|
|
media_library:
|
|
name: uploadcare
|
|
config:
|
|
publicKey: YOUR_UPLOADCARE_PUBLIC_KEY
|
|
settings:
|
|
autoFiletitle: true
|
|
defaultOperations: '/resize/800x600/'
|
|
```
|
|
|
|
```js
|
|
media_library: {
|
|
name: 'uploadcare',
|
|
config: {
|
|
publicKey: 'YOUR_UPLOADCARE_PUBLIC_KEY',
|
|
},
|
|
settings: {
|
|
autoFiletitle: true,
|
|
defaultOperations: '/resize/800x600/',
|
|
},
|
|
},
|
|
```
|
|
</CodeTabs>
|