Plugin implementation for content management systems
Start up the Spryker shop and run:
To get the package running, register the "Scaleflex" namespace into the config_default.php in the KernelConstants::CORE_NAMESPACES
Set these constants in the config, where it is needed. the BaseUrl and the ignoredUrlPaths need to be set according to the use case.
Register the Twig plugin in the Pyz\Yves\Twig\TwigDependencyProvider.php
Example
Use the TwigFilter for the images. Here is an example of how to extend the Pyz\Yves\ShopUi\Theme\default\components\molecules\lazy-image.twig. Everywhere this molecule will use Cloudimage and apply a grey filter.
How to use the plugin
Cloudimage documentation for the operations: https://docs.cloudimage.io/transformations/image-operations
Cloudimage documentation for the filters: https://docs.cloudimage.io/transformations/image-filters
Cloudimage Drupal module
You can install the Cloudimage module from Github or by using Packagist.
Step 1: Download the latest version Download Latest release of the Module
Step 2: Extract the zip file at location "/modules"
Step 3: In Admin go to Extend -> find Cloudimage by Scaleflex -> Install
Step 1: Run "composer require 'drupal/cloudimage_by_scaleflex:^1.0'"
Step 2: In Admin go to Extend -> find Cloudimage by Scaleflex -> Install
Activation: Enable/Disable the module
Standard Mode: Replace image URLs not using any Javascript or Javascript library.
Token or CNAME: Please enter your cloudimage token here (eg: abcdefgh), or your complete CNAME (eg. media.company.com) if the configuration is already validated in your Cloudimage Admin.
Use origin URL: If enabled, the module will only add query parameters to the image source URL without prefixing it with {token}.cloudimg.io
.
Lazy Load: If enabled, only images close to the current viewpoint will be loaded.
Ignore SVG Size: If enabled, the module will ignore the image size node in the SVG file.
Image Size Attributes: Used to calculate width and height of images
Prevent Image Upsize: If you set Maximum "Pixel ratio" equal to 2, but some of your assets does not have min retina size(at least 2560x960), please enable this to prevent image resized. By default, yes.
Image Quality: The smaller the value, the more your image will be compressed. Careful — the quality of the image will decrease as well. By default, 90.
Maximum Pixel Ratio: The maximum pixel ratio of the image. By default, 2.
Remove V7: If enabled, the module will remove the "/v7" part in URL format. Activate for token created after October 20th 2021.
Custom JS Function: The valid js function starting with { and finishing with }
Custom Library Options: Modifies the library URL (to add transformations)
Cloudimage Kontent.ai connector
You need to have a Kontent CMS setup. https://kontent.ai/
Content model (left hand side) > Create new > Custom element (right hand side). You will then have the below view.
Hosted code URL: https://scaleflex.cloudimg.io/v7/plugins/cloudimage-kontent/cloudimage.html?func=proxy
Parameters are the information that Kontent-Cloudimage needs to accelerate your images. See below:
note: "mgmtApiKey" is obtained from:
Content & asset (left hand side) > Create new > Chose type: Cloudimage. Chose add/remove some images, publish. You will then have the below view.
After publishing, it will look like below. The URLs are Cloudimage accelerated.
Here, you can find a tutorial on how to set up a preview: https://kontent.ai/learn/tutorials/develop-apps/build-strong-foundation/set-up-preview/
Go to Settings > API Keys. For this, you will definitely need your Project ID. You may also need your API Key (depends on what you want to do, but for simple things Project ID is enough).
Write a client app that utilizes the Delivery API
Recall that Kontent have 3 set of APIs that you can interact with
Delivery APIs in plain HTTPS form can be taken from https://kontent.ai/learn/tutorials/develop-apps/get-started/postman-collection/ , imported into POSTMAN
For the 3 content items that comes out of the box, Kontent already have an example client app, which we can imitate.
This example app was made by using React JS https://github.com/Kentico/kontent-sample-app-react
Hosted on Github Pages: https://kentico.github.io/kontent-sample-app-preview-react/{restof the URL}
After writing and hosting your client app, go to Settings > Preview URLs and define your Preview URL formats.
See how Kontent defined their preview URLS for their example app
Codename
, URLSlug
& ItemId
are obtained as follows:
Once you done all the above, you can preview by clicking Preview
https://scaleflex.zendesk.com/hc/en-gb/requests/new or hello@scaleflex.com
Cloudimage Contentful plugin
You need to have a Contentful account. Contentful is 100% Cloud Native, so you have to sign up for a hosted CMS at https://be.contentful.com
You’ll get :
Find it here https://www.contentful.com/marketplace/ and install it.
Or click "Install now" on https://www.contentful.com/marketplace/app/scaleflex-cloudimage/
Then save and install.
Absolutely important: The Field ID must be "cloudimage".
By doing the above, you will associate the Cloudimage field (the field that you named Cloudimage) to the Cloudimage App. Recall the warning message you saw during the app configuration stage "There are no content types with ..."? By doing the above, that will no longer be an issue.
Now you can create a content item of Cloudimage type.
You can add and remove images.
Cloudimage will optimize those images in the background. (If you inspect in developer console, you will see the call to its infrastructure)
Magento plugin
Cloudimage can be implemented to accelerate Magento shops in 2 modes:
Simple configuration change in Magento settings
JPEG optimization WebP delivery CDN acceleration
Requires the installation and configuration of the Cloudimage Content Transformation & Acceleration Magento plugin or Github.
Basic + Responsive images
Magento simple implementation
This simple and fast implementation in Magento 2 enables JPEG optimization, WebP compression and CDN delivery of your images.
To use the plugin, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
First, you need to log in to your Magento 2 website admin
On the Admin sidebar, go to Stores > Settings > Configuration.
Navigate to the settings page - from the left panel, in the General group, choose Web.
Then, you need to set up the Base URLs.
It is important to set this prefix in both - Base URL for User Media Files and Secure Base URL for User Media Files.
In Base URL for User Media Files in Base URLs and Base URLs (Secure) add the following value, replacing your token: https://<token>.cloudimg.io/{{secure_base_url}}pub/media/
For example, if your website is https://sfxmagento.site
, and your token is demo
, the final URL address should be: https://demo.cloudimg.io/https://sfxmagento.site/pub/media/
You can also use your own domain instead of {token}.cloudmg.io via CNAME records. Please contact us and an engineer will help setting it up.
When complete, do not forget to click Save Config.
On the Admin sidebar, go to System > Tools > Cache Management and Flush the cache of Magento.
Magento’s cache management system is an easy way to improve the performance of your site. Whenever a cache needs to be refreshed, a notice appears at the top of the workspace to guide you through the process. Find additional information and tips in this Magento tutorial for cache management.
Please ensure that you are properly delivering static content via the CDN.
You can now modify your template to resize your images with us.
Cloudimage Content Transformation & Acceleration in Magento
To use the plugin, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
To be able to install the module by Composer, you need to get a copy of the module on the Magento Marketplace, or directly from Github.
Enable and install module in Magento:
Activate the module and enter your Cloudimage token in the module configuration in Magento admin interface: Stores / Configuration / Cloudimage by Scaleflex / Cloudimage Responsive
:
Use origin URL
If enabled, the module will only add query parameters to the image source URL without prefixing it with {token}.cloudimg.io. This is required if you use a dedicated subdomain for delivering your images (media) in Magento. You will need to enable a custom CNAME in Cloudimage.
Ignore Image Size Node
Useful for improving compatibility with some themes.
Ignore Image Size Style
Useful for improving compatibility with some themes.
Lazy Loading
If enabled, images will be lazy-loaded for better loading times and user experience.
This setting is for advanced users only and allows to inject a custom JS function into the Magento templates in order to support some specific Magento templates. Feel free to contact us in order to get the custom JS function to address issues with your specific template.
Inject Custom JS function
If enabled, you will be able to customize the JS function used to get the DOM information dynamically.
Custom JS function
The JS function to customize Cloudimage library.
Once activated, the Cloudimage Responsive module will replace your template's classic image tag elements on-the-fly. This functionality is 100% compatible with the Magento Luma theme.
In the case of a personalized template, please consult the Manual integration in Magento templates section in the Cloudimage plugin Github page.
Cloudimage Opencart plugin
The Cloudimage Opencart Plugin will automatically adapt the image URLs in your Opencart site to deliver your images rocket fast over the Cloudimage multi-CDN infrastructure. You only need to register with Cloudimage and install the plugin in your Opencart Admin.
To use the plugin, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
To get the plugin, you need to open Opencart Extension Marketplace.
Then, search for "Cloudimage" in the search bar.
Select the Cloudimage by Scaleflex plugin and click on Download. The Download button will be available on the right side. This will download the .zip file.
First, you need to log in to your Opencart Admin:
Then, navigate to Extension->Installer.
Click on "Upload" and upload the .zip file that you downloaded in the previous step:
Navigate to Extensions->Modifications and select refresh in the Modification panel. Refresh button will be available on the top right corner as shown below:
Navigate to Extensions->Extensions->Modules.
Select Cloudimage from the list of modules and click on Edit.
Enable the plugin and enter Cloudimage Token or CNAME
You need to enter your Cloudimage account token which you have received upon account creation (step 1).If you need a CNAME please contact our sales team.
After you enter your token and save the changes, the plugin will start to deliver your images via Cloudimage.
Remove v7 from URL
If your token/CNAME was created after 20th October 2021 you need to tick this option.This option will remove the "v7" part from image URLs.
Enable debug image overlays
For troubleshooting purposes to view details about resizing and compression. Note:This will print information over your images.
Cloudimage image output quality
To increase or decrease the quality of images delivered by cloudimage.Slide to the right to increase quality.
Javascript Mode
To turn on responsive images,this option makes use of Cloudimage javascrpt libarary. All img tags "src" is changed to "ci-src" .
When Javascript Mode is active, make sure that no other module is overwriting the plugin's delivery with "ci-src" image source.
Cloudimage Prestashop module
The Cloudimage Prestashop Module will automatically adapt the image URLs in your Prestashop Theme to deliver your images rocket fast over the Cloudimage multi-CDN infrastructure. You only need to register with Cloudimage and install the plugin in your Prestashop Admin.
First, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
Download the latest version Download Latest release of Module
Unzip the file and change the folder name to "cloudimage"
Zip the file with the name "cloudimage.zip"
In Admin go to Modules/Module Manager -> Upload the Zipped file
In Admin go to Modules/Module Catalog search for "Clouldimage by Scaleflex"
Click "Install"
Go to Modules/Module Manager -> Other Section -> Click on Configure on "Cloudimage by Scaleflex"
Update configuration and activate the Module, then your site is ready to go. (Please clear the Cache)
Activation: Enable/Disable the module
Cloudimage API Key: Your Cloudimage Token
Prerender: If enabled, the plugin will disable JS Responsive and Change URL to {token}.cloudimg.io/{origin_url}
Auto Base URL Image: If enabled, Production with SSL only, The Plugin auto add base url to some missing Base URL Images
Use origin URL: If enabled, the plugin will only add query parameters to the image source URL, avoiding double CDNization in some cases, like if you have aliases configured.
Lazy Load: If enabled, only images close to the current viewpoint will be loaded.
Ignore SVG Size: If enabled, the module will ignore the image size node in the SVG file.
Prevent Image Resize: If you set Maximum "Pixel ratio" equal to 2, but some of your assets does not have min retina size(at least 2560x960), please enable this to prevent image resized. By default, yes.
Image Quality: The smaller the value, the more your image will be compressed. Careful — the quality of the image will decrease as well. By default, 90.
Maximum Pixel Ratio: The maximum pixel ratio of the image. By default, 2.
Remove V7: If enabled, the module will remove the "/v7" part in URL format. Activate for token created after October 20th 2021.
Advanced User
Custom JS Function: The valid js function starting with { and finishing with }
Custom Library Options: Modifies the library URL and must begin with the symbol &. Please read document before use.
Please note: if you are using an earlier version of Prestashop (v1.6.x or less) and / or this plugins is not compatible with some of your add-ons, it is always possible to make a manual integration of the Cloudimage acceleration, following the Prestashop tutorial.
Implement Cloudimage on Prestashop 1.6+
This simple and fast implementation in Prestashop leverages JPEG optimisation, WebP compression and CDN delivery of your images. Contact us if you want to use Cloudimage at its full extend and also resize, watermark, transform and leverage responsive images on your Prestashop store.
Please note that to use your Cloudimage account with Prestashop, you need to use the Origin URL prefix function. This means that you will be able to use your Cloudimage token for delivering images only from your Prestashop site.
To use the plugin, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
There are two basic configuration steps:
First, you need to contact us at hello@cloudimage.io and let us know that you would like to use your Cloudimage token with Prestashop. We will lock your account to the v7 API of Cloudimage. Note: This step is required only for tokens created before November 1, 2021.
Then, you need to set up the Origin URL prefix in your Cloudimage admin to your Prestashop domain. By doing this, your token will fetch images only from your Prestashop site.
Add in Media Server #1, the Cloudimage domain and click to Save.
Please ensure that you are properly delivering static content via the CDN.
This simple and fast implementation in Prestashop leverages JPEG optimisation, WebP compression and CDN delivery of your images. Contact us if you want to use Cloudimage at its full extent and also resize, watermark, transform and leverage responsive images on your Prestashop store.
Cloudimage Shopware module
To use the plugin, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
Step 1: Download the latest version Download Latest release of Module
Step 2: Zip the file with the name "cloudimage.zip"
Step 3: In Admin go to Extensions -> My extensions -> Upload extension
Step 1: In Admin go to Extensions -> Store -> Catalog and search for "Cloudimage by Scaleflex"
Step 2: Click on extension and after that "Add extension"
Step 3: Go to Extensions -> My extensions -> Cloudimage by Scaleflex -> Click on Configuration
Step 4: Update configuration and activate the Module, then your site is ready to go.
Activation: Enable/Disable the module
Standard Mode: Replace image URLs not using any Javascript or Javascript library.
Token or CNAME: Please enter your cloudimage token here (eg: abcdefgh), or your complete CNAME (eg. media.company.com) if the configuration is already validated in your Cloudimage Admin.
Use origin URL: If enabled, the module will only add query parameters to the image source URL without prefixing it with {token}.cloudimg.io
.
Lazy Load: If enabled, only images close to the current viewpoint will be loaded.
Ignore SVG Size: If enabled, the module will ignore the image size node in the SVG file.
Prevent Image Upsize: If you set Maximum "Pixel ratio" equal to 2, but some of your assets does not have min retina size(at least 2560x960), please enable this to prevent image resized. By default, yes.
Image Quality: The smaller the value, the more your image will be compressed. Careful — the quality of the image will decrease as well. By default, 90.
Maximum Pixel Ratio: The maximum pixel ratio of the image. By default, 2.
Remove V7: If enabled, the module will remove the "/v7" part in URL format. Activate for token created after October 20th 2021.
Advanced User's options
Custom JS Function: The valid js function starting with { and finishing with }
Custom Library Options: Modifies the library URL (to add transformations)
Cloudimage Sylius Plugin
The Cloudimage Sylius Plugin will automatically adapt the image URLs in your Sylius site to deliver your images rocket fast over the Cloudimage multi-CDN infrastructure. You only need to register with Cloudimage and install the plugin in your Sylius Admin.
To use the plugin, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
Open a command console on your Sylius hosting server, enter your project directory and execute the following command to download the latest stable version of this bundle:
Then, enable the plugin by adding it to the list of registered plugins/bundles in config/bundles.php file of your project
Update Channel Model Your Entity Channel has to implement \Scaleflex\SyliusCloudimagePlugin\Model\ExtendedChannelInterface
You can use Trait \Scaleflex\SyliusCloudimagePlugin\Model\ExtendedChannelTrait
Update Database Schema
Include
in your templates/bundles/SyliusAdminBundle\Channel_form.html.twig form.
Then you can start to personalize the configuration (token, options) in Admin / Channel -> Choose one Channel
To process your image through Cloudimage you have two ways to implement
Option 1: Use the ci_src(path)
Twig Function
Option 2: Define your own
Update the image src
to ci-src="{path}?q={sylius.channel.cloudimageImageQuality}"
Add the script
Here are the available configuration options:
Activation
Enable/Disable the plugin
Token
Token from Cloudimage (found in your admin panel)
Use origin URL
If enabled, the module will only add query parameters to the image source URL without prefixing it with {token}.cloudimg.io : might be useful to avoid double CDNization, for exemple if you have aliases configured
Ignore Image Size Node
Useful for improving compatibility with some themes.
Ignore Image Size Style
Useful for improving compatibility with some themes.
Lazy Loading
If enabled, images will be lazy-loaded for better initial loading times and user experience. ⚠️ lazy loading can have variable results on some websites as for the first rows of images loaded, therefore it is recommended to make use of an integrated new class provided: “lazy-off”. You can specify the "lazy-off" class either in the page builder through the back-office, or in the templates directly (eg. category page and product page).
Custom js function
🚨 Any js function to customize the behavior of the Cloudimage library. Attention, adding js should only be done by advanced administrators as it can break the js or have unintended effects if not thoroughly tested and validated.
Image Quality
Customizes image quality, therefore compression -influences the size of image-.applied by default. Warning, a setting under 80 might have a potentially visible impact.
Ignore SVG images
If enabled, all SVG images will be skipped from acceleration as anyway vector images will not be compressed.
Maximum "Pixel ratio"
List of supported device pixel ratios, default is 2, eg: 2 for Retina devices
Custom Library Options
🚨 Those optional parameters will be added to the request for each URL going through the Cloudimage acceleration infrastructure. It can allow you to force image formats, apply automatic transformations or watermarking, and might be used for troubleshooting purposes. For advanced users only, please refer to the Cloudimage documentation here for the list of possible parameters.
When Javascript Mode is active, make sure that no other module is overwriting the plugin's delivery with "ci-src" image source.
Cloudimage Wordpress Plugin
The Cloudimage Wordpress plugin will automatically adapt the image URLs in your Wordpress site to deliver your images rocket fast over Cloudimage. You only need to register with Cloudimage and install the plugin in your Wordpress site.
If you need to adjust the behaviour of the plugin, please see the Advanced Configuration settings.
Create an account if you have not registered already. You can create an account on the Cloudimage registration page.
You need to enter your Cloudimage account token which you have received upon account creation (step 1).
The v7 option
Some tokens are associated with a v7 URL, while others are not.
But not to worry, this plugin automatically checks and sets it for you, all within a few seconds.
Eg: If you enter a v7 token into the text input field, then a few seconds later, the v7 dial will automatically turn itself on.
Please be patient and wait for the “The v7 checking process …” message to disappear, before pressing the “SAVE ALL CHANGES“ button.
Your image URL will be like this:
Notice that the URLs has been appended with https://token.cloudimg.io/
to ensure CDN delivery and optimization of images.
With JS Mode turned on, Cloudimage will:
the ci-src
(https://github.com/scaleflex/js-cloudimage-responsive#step-3-implement-in-an-img-tag-or-use-it-as-a-background-image) attribute will be added into theimg
element, which will
generate data-srcset
set resize
srcset
standard settingsNotice the 666 in the srcset
With this turned on, Cloudimage will only take effect when the user is logged in
Please note that Cloudimage will not take effect on localhosts
Disable image downsize filter
ON: disable WordPress’s default image-cropping functionality
Enable srcset
adding
If this is turned off, then “Srcset widths“ will have no effect.
srcset
widths (px)Add more sizes to srcset
For example
Cloudimage URL: token.cloudimg.io/mywebsite/wp-uploads/2020/image.png
Replaceable text: wp-uploads/2020
Replacement text: upload
Then from frontend users will see the image URL as: token.cloudimg.io/mywebsite/upload/image.png
But we need to configure Aliases in Cloudimage admin and set up the alias upload
with value wp-uploads/2020
(See above)
Exclude Cloudimage processing by class name
Exclude Cloudimage processing by file type, eg “.gif“
OFF: use ob_buffer
PHP function
ON: use the_content
filter from WordPress.
ON: use Cloudimage JS files from CDN
OFF: use Cloudimage JS files from plugin locally
Can become helpful to turn on when using non-standard WordPress themes. Especially for badly-made themes, to compensate for some adverse impact on images.
Enable Save Image Node Ratio to preserve the aspect ratio.
Turn on Ignore Image Node Size to bypass the incorrect width
and height
attributes.
Optionally, use Destroy Node Image Size if you want to completely remove size attributes from the image tags.
Use Detect Image Node CSS if the theme's CSS is involved in setting these incorrect sizes.
This setting ensures that only the width is considered for image processing, and the height is adjusted proportionally to maintain the aspect ratio.
setTimeout
checksBetter to turn this on when there are AJAX loaded images, so that the late-loaded images don’t miss out on Cloudimage processing
Step-by-step instructions how to set up Cloudimage with Shopify
Shopify integration
Cloudimage will accelerate your Shopify shop by compressing images and delivering them over CDN.
After finding out your Shopify URL as shown below (i.e. https://cdn.shopify.com
, https://cdn2.shopify.com
or https://cdn.shopifycloud.com
), you can create a HTTP-Storage in Cloudimage.
Create the Storage record in the Cloudimage admin as follows:
Adding an HTTP-based Storage will make you create a Cloudimage Alias. After saving the storage in Step 1 above, verify that images are delivered correctly over your Cloudimage URL with the Alias:
Origin image URL on Shopify:
Cloudimage URL with Alias:
https://{token}.cloudimg.io/_myshopify_/shopifycloud/brochure/assets/home/hero-stock-small-72c1242fc5bbf6cfe135968110e9c52435af1e389c0fd4fe68208d21427e21e0.jpg
Replace {token}
with your Cloudimage token.
Unable to delivery images over your Cloudimage URL? Contact hello@cloudimage.io if you are not able to fetch the image as explained above. In such a situation, do not move to step 3 as this could break your website images.
Proceed with making the changes in our Shopify settings and theme files to switch the image delivery to Cloudimage.
From your Shopify admin, click Online Store > Themes. Find the theme you want to edit, click the Actions button and then Edit code.
Under Config, click settings_schema.json
and append the code below after the last section of this file:
Create new files cloudimage.liquid
and cloudimage-video-tag.liquid
under the Snippets directory. Copy the code below into that file, and save it:
cloudimage.liquid
cloudimage-video-tag.liquid
Navigate to Online store > Themes > Customize theme. In the sidebar, under Theme Settings open Cloudimage and enable it. Fill out the below two fields:
Cloudimage Token - It should be your Cloudimage Token
Default URL endpoint - It should be //{token}.cloudimg.io/
myshopify
(where token
is your Cloudimage token)
Shopify CDN domain - Its value should be //cdn2.shopify.com
, //cdn.shopify.com
Hit the "Save" button.
The final step of this tutorial is to adapt your theme files to start delivering your images over Cloudimage.
For more information, please see the Theme files and FAQ sections.
Shopify integration - theme files
You need to adapt your individual theme files for the image URLs to be changed to Cloudimage URLs. Identify first which theme files are used by your shop and edit them one by one as detailled below.
Here are a couple of examples indicating the change that needs to be made in the theme files. You can follow similar steps to change all of your theme files. List of some files that need to be changed (files may vary between themes):
featured-product.liquid
product-template.liquid
collection-grid-item.liquid
Product-grid-item.liquid
header.liquid
video.liquid
As general what you need to do is:
assign new variable inheriting the original theme image url
replace the old image invocation with inclusion of cloudimage
You can make the changes inside product-template.liquid
.
If there is a tag inside image URL and you cannot simply assign it, use capture
You can also take a look at the FAQ section.
Shopify integration - frequently asked questions
Can I disable Cloudimage with a single click?
Yes you can enable and disable Cloudimage on your Shopify store with a single click. Navigate to Online store > Themes > Customize theme. In the sidebar, under general settings open Cloudimage.io and enable/disable it.
Can Cloudimage automatically detect the right image dimension and load it?
No Cloudimage only changes the base URL of your images because there is no way the server would have knowledge of your website layout. However, just by loading images through Cloudimage URL-endpoint, your images are automatically optimised for format and quality.
How do I make sure my integration is working?
Once you are done editing these files, save these files. Now refresh the webpage for your Shopify store and check the image URLs. They should now load from URLs beginning with https://{token}.cloudimg.io/v7
. You can use the Chrome Developer Tools to check that all the images are being loaded via Cloudimage.io and that all images are loading correctly. If you find that images on a particular page or section are still being served from Shopify, then find out the responsible theme file and edit it as well.
Commercetools implementation
The react-cloudimage-responsive library is a React component that allows you to easily add responsive images to your web application using the Cloudimage service. With this package, you can load and display optimized images that are automatically resized based on the device screen size and pixel density.
It is a simple and easy-to-use package that can help you improve the performance and user experience of your web application by optimizing it.
You can create an account on the Cloudimage registration page.
You can install react-cloudimage-responsive using npm or yarn:
or
To use react-cloudimage-responsive, you need to provide it with a Cloudimage URL and some additional parameters. Here's an example:
In this example, we're passing three props to the "CloudimageResponsive" component:
alt: The alternate text to display for the image. This is required for accessibility reasons.
image: The URL of the original image to be optimized and resized by Cloudimage.
cloudimageConfig: An object that contains the Cloudimage configuration parameters. This includes your Cloudimage API token, the base URL of your Cloudimage service, and the resizing, quality, and format parameters for the image.
Here are the configuration parameters you can use in the "cloudimageConfig" object:
token
Type: String | Default: "demo" | required
Your Cloudimage customer token. Subscribe for a Cloudimage account to get one. The subscription takes less than a minute and is totally free.
customDomain
Type: String | Default: "cloudimage.io" | optional
If you use a custom CNAME for your cloudimage integration, you can set it here.
baseURL
Type: String | Default: "/" | optional
Your image folder on server, this alows to shorten your origin image URLs.
apiVersion
Type: String |Default: 'v7' | optional
Allow to use a specific version of API.
set a specific version of API
disable API version
Note: this will disregard your token above as this should be built into the CNAME entry.
doNotReplaceURL
Type: bool | Default: false
If set to true the plugin will only add query params to the given source of image.
lazyLoading
Type: Bool | Default: true | optional
Only images close to the client's viewport will be loaded, hence accelerating the page loading time. The plugin uses react-lazyload library to achieve it.
lazyLoadOffset
Type: Number/Array(Number) | Default: 100
Say if you want to preload a component even if it's 100px below the viewport (user have to scroll 100px more to see this component), you can set offset props to 100. On the other hand, if you want to delay loading a component even if it's top edge has already appeared at viewport, set offset to negative number.
Library supports horizontal lazy load out of the box. So when you provide this prop with number like 100 it will automatically set left edge offset to 100 and top edge to 100;
If you provide this prop with array like [100, 200], it will set left edge offset to 100 and top offset to 200.
params
Type: String | Default: 'org_if_sml=1' | optional
Applies default Cloudimage operations/ filters to your image, e.g. brightness, contrast, rotation... Multiple params can be applied, separated by "&" e.g. wat_scale=35&wat_gravity=northeast&wat_pad=10&grey=1
alternative syntax: type: Object
placeholderBackground
Type: String | Default: '#f4f4f4' | optional
Placeholder coloured background while the image is loading or use it to set your custom placeholder image or gif
For example:
lowQualityPreview
Type: Object
lowQualityPreview.minImgWidth number (default: 400) - minimum width of an image to load a low-quality preview image
presets
Type: Object
Default:
Breakpoints shortcuts to use in image size property, can be overridden.
limitFactor
Type: Number | Default: 100 | optional
Rounds up the size of an image to the nearest limitFactor value.
For example:
For an image with width 358px and limitFactor equal to 100, the plugin will round up to 400px.
For an image with width 358px and limitFactor equal to 5, the plugin will round up to 360px.
devicePixelRatioList
Type: [Number,...] | Default: [1, 1.5, 2] | optional
List of supported device pixel ratios. If there is no need to support retina devices, you should set an empty array devicePixelRatioList: [].
delay
Type: Number | optional
Delay for processing an image after rendering component.
NOTE: Normally, the parameter is not needed but in some cases with integrating third-party libraries, it can fix wrong calculation of image container.
ImageSizeAttributes
Type: String | possible values: 'use', 'ignore', 'take-ratio' | Default: 'use'
If width and height attributes are set:
use - width & height attributes values will be used to calculate image size (according to user's DPR) and ratio.
take-ratio - width & height attributes values will be used only to calculate ratio.
ignore - width & height attributes will be ignored.
If width and height attributes are NOT set, image container size will be detected to calculate result image size (according to user's DPR)
Note: If only width or height attributes is set, ratio is going to be taken from ci-ratio image attribute
Here are the properties you can use with the "CloudimageResponsive" component:
alt: The alternate text to display for the image. This is required for accessibility reasons.
image: The URL of the original image to be optimized and resized by Cloudimage.
cloudimageConfig: An object that contains the Cloudimage configuration parameters.
className: An optional class name to apply to the image container.
style: An optional object that contains CSS styles to apply to the image container.
The Ruby wrapper allows you to seamlessly interface with the Cloudimage API.
Supported with Ruby 2.4+, JRuby, and TruffleRuby github
Add this line to your application's Gemfile:
And then execute:
Or install it yourself as:
The only requirement to get started is your customer token. You can find it within your Admin interface.
In order to interact with Cloudimage, we'll first initialize a client service object:
The Cloudimage client accepts the following options:
token
string
Required if cname
is missing.
cname
string
Required if token
is missing. See CNAME.
salt
string
Optional. See Security. Needed if you are using URL sealing or URL signatures.
signature_length
integer
Optional. Integer value in the range 6..40
. Defaults to 18.
sign_urls
boolean
Optional. Defaults to true. See Security.
aliases
hash
Optional. See URL aliases.
The calling path on the client object returns an instance of Cloudimage::URI. It accepts the path to the image as a string and we we will use it to build Cloudimage URLs.
Here are some common approaches for constructing Cloudimage URLs using this gem:
Hash of params
Pass a hash to to_url
. Every key becomes a param in the final Cloudimage URL so this gives you the freedom to pass arbitrary params if need be.
Chainable helpers
Every param supported by Cloudimage can be used as a helper method.
While every key passed into the to_url
method gets appended to the URL, chainable helper methods will throw a NoMethodError
when using an unsupported method.
This is useful for catching typos and identifying deprecated methods in case Cloudimage's API changes.
Method aliases
The gem comes with a handful of useful aliases. Consult the Cloudimage::Params module for their full list.
From the example above you can see that parameters that only serve as a flag don't need to accept arguments and will be translated into param=1
within the final URL.