{"id":21261,"date":"2014-11-27T14:41:02","date_gmt":"2014-11-27T14:41:02","guid":{"rendered":"http:\/\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading"},"modified":"2024-06-05T16:12:18","modified_gmt":"2024-06-05T23:12:18","slug":"introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading","status":"publish","type":"post","link":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading","title":{"rendered":"Introducing a complete and modern UI widget for cloud based image uploading"},"content":{"rendered":"<div class=\"wp-block-cloudinary-markdown \"><p>Many websites and mobile applications support user uploaded images and other files. This requires a service to receive and process the uploads, store them safely, transform them to match the website or app\u2019s design, and deliver them to your users. This also requires a user interface within your site or app that allows users to easily upload images. \u00a0<\/p>\n<p>At Cloudinary, we have been taking care of the <a href=\"https:\/\/cloudinary.com\/products\/image_video_technology_platform\">entire image management pipeline<\/a> from the time our service was launched: from an upload API, to cloud storage via our rich set of image transformation capabilities, to optimized CDN delivery.<\/p>\n<p>Following our customers\u2019 requests, we wanted to create an out-of-the-box complete UI solution that allows image uploading directly from browsers to Cloudinary. This includes UI features, like drag &amp; drop, progress indications, interactive cropping, and preview thumbnails, that are similar to what you can also find in modern web applications, such as Gmail and Facebook, all with a single line of code. And so, we are very excited to introduce Cloudinary\u2019s new upload widget.<\/p>\n<h2>Cloudinary\u2019s upload widget<\/h2>\n<p>By adding a single line of JavaScript code to your site, you will have a complete modern UI, allowing users to interactively upload images and any other files to the cloud directly from their web browsers. We provide a fast, rich, and modern UI, that enables users to perform a wide variety of tasks.<\/p>\n<p>For example, you can select one or more files from your local computer; drag &amp; drop images; import files from remote URLs; capture photos using a webcam; and display client-side previews immediately after selecting an image, before it is uploaded to Cloudinary.<\/p>\n<p>Additionally, we indicate upload progress, handle errors, support interactive cropping, and allow various types of image validation and processing. For example, we provide maximum file size validation and scaling down images prior to uploading in order to suit the given dimensions.<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/res.cloudinary.com\/cloudinary\/image\/upload\/w_600\/upload_widget_progress_vbzuqt.jpg\" alt=\"Upload widget in progress\" loading=\"lazy\" class=\"c-transformed-asset\"  width=\"600\" height=\"293\"\/><\/p>\n<p>Click the blue button below to try out our live upload widget that uploads images directly to the cloud.<\/p>\n<div class=\"upload_multiple_images_holder\" \"style\"=\"margin-bottom: 20px\">\n    <a href=\"#\" id=\"upload_widget_multiple\" class=\"cloudinary-button\" style=\"color: #fff\">Upload multiple images<\/a>\n<\/div>\n<h2>How-to integrate our widget into your site<\/h2>\n<p>If you still don\u2019t have an account with us, we invite you to <a href=\"https:\/\/cloudinary.com\/users\/register\/free\">create your own Cloudinary account<\/a> for free. In order to use the widget, you need to <a href=\"https:\/\/cloudinary.com\/blog\/direct_upload_made_easy_from_browser_or_mobile_app_to_the_cloud\">enable direct unsigned uploading in your account<\/a>. You will need your Cloudinary account\u2019s cloud name as well as your <a href=\"https:\/\/cloudinary.com\/blog\/centralized_control_for_image_upload_image_size_format_thumbnail_generation_tagging_and_more\">upload preset name<\/a> in order to use the widget. Next, simply include a short JavaScript code, which is quickly delivered via CDN, and add a single line of code to your site in order to open the widget. For example:<\/p>\n<pre class=\"js-syntax-highlighted\" aria-describedby=\"shcb-language-1\" data-shcb-language-name=\"HTML, XML\" data-shcb-language-slug=\"xml\"><span><code class=\"hljs language-xml shcb-wrap-lines\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">\"\/\/widget.cloudinary.com\/global\/all.js\"<\/span> <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"text\/javascript\"<\/span>\/&gt;<\/span><span class=\"handlebars\"><span class=\"xml\">  \n                \n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span> <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"text\/javascript\"<\/span>&gt;<\/span><span class=\"actionscript\">  \n  ...\n  cloudinary.openUploadWidget({ cloud_name: <span class=\"hljs-string\">'demo'<\/span>, upload_preset: <span class=\"hljs-string\">'a5vxnzbp'<\/span>}, \n    <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span><span class=\"hljs-params\">(error, result)<\/span> <\/span>{  ...  });\n  ...\n<\/span><\/span><\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span> \n<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-1\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">HTML, XML<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">xml<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n<p>When the widget is open, your users can select a file that will be directly uploaded to your Cloudinary account. Then an identifier (public ID) is assigned to the uploaded image and your web page is updated with the image\u2019s public ID using a callback method. That will make it possible to later reference the uploaded image and generate dynamic transformation and delivery URLs. For example, below you can see how we have created a 150&#215;150 face detection based thumbnails with rounded corners using an uploaded image\u2019s public ID.<\/p>\n<p><cld-code-widget\n      class=\" c-code-widget\"\n      snippets=\"[{&quot;sdkId&quot;:&quot;nodejs&quot;,&quot;framework&quot;:&quot;nodejs&quot;,&quot;language&quot;:&quot;nodejs&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.image(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, {width: 150, height: 150, gravity: \\&quot;face\\&quot;, radius: 50, crop: \\&quot;thumb\\&quot;})&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.image(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, {width: 150, height: 150, gravity: \\&quot;face\\&quot;, radius: 50, crop: \\&quot;thumb\\&quot;})&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Node.js&quot;,&quot;packageName&quot;:&quot;cloudinary&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;2.x&quot;},{&quot;sdkId&quot;:&quot;react_2&quot;,&quot;framework&quot;:&quot;react_2&quot;,&quot;language&quot;:&quot;react&quot;,&quot;rawCodeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n  .resize(\\n    thumbnail()\\n      .width(150)\\n      .height(150)\\n      .gravity(focusOn(face()))\\n  )\\n  .roundCorners(byRadius(50));&quot;,&quot;codeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n  .resize(\\n    thumbnail()\\n      .width(150)\\n      .height(150)\\n      .gravity(focusOn(face()))\\n  )\\n  .roundCorners(byRadius(50));&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;React&quot;,&quot;packageName&quot;:&quot;@cloudinary\\\/react&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;react&quot;,&quot;framework&quot;:&quot;react&quot;,&quot;language&quot;:&quot;react&quot;,&quot;rawCodeSnippet&quot;:&quot;&lt;Image publicId=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt; &lt;Transformation width=\\&quot;150\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;face\\&quot; radius=\\&quot;50\\&quot; crop=\\&quot;thumb\\&quot; \\\/&gt; &lt;\\\/Image&gt;&quot;,&quot;codeSnippet&quot;:&quot;&lt;Image publicId=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt;\\n\\t&lt;Transformation width=\\&quot;150\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;face\\&quot; radius=\\&quot;50\\&quot; crop=\\&quot;thumb\\&quot; \\\/&gt;\\n&lt;\\\/Image&gt;&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;React&quot;,&quot;packageName&quot;:&quot;cloudinary-react&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;vue_2&quot;,&quot;framework&quot;:&quot;vue_2&quot;,&quot;language&quot;:&quot;vue&quot;,&quot;rawCodeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n  .resize(\\n    thumbnail()\\n      .width(150)\\n      .height(150)\\n      .gravity(focusOn(face()))\\n  )\\n  .roundCorners(byRadius(50));&quot;,&quot;codeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n  .resize(\\n    thumbnail()\\n      .width(150)\\n      .height(150)\\n      .gravity(focusOn(face()))\\n  )\\n  .roundCorners(byRadius(50));&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Vue.js&quot;,&quot;packageName&quot;:&quot;@cloudinary\\\/vue&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;vue&quot;,&quot;framework&quot;:&quot;vue&quot;,&quot;language&quot;:&quot;vue&quot;,&quot;rawCodeSnippet&quot;:&quot;&lt;cld-image public-id=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt; &lt;cld-transformation width=\\&quot;150\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;face\\&quot; radius=\\&quot;50\\&quot; crop=\\&quot;thumb\\&quot; \\\/&gt; &lt;\\\/cld-image&gt;&quot;,&quot;codeSnippet&quot;:&quot;&lt;cld-image public-id=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt;\\n\\t&lt;cld-transformation width=\\&quot;150\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;face\\&quot; radius=\\&quot;50\\&quot; crop=\\&quot;thumb\\&quot; \\\/&gt;\\n&lt;\\\/cld-image&gt;&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Vue.js&quot;,&quot;packageName&quot;:&quot;cloudinary-vue&quot;,&quot;packageStatus&quot;:&quot;legacy&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;angular_2&quot;,&quot;framework&quot;:&quot;angular_2&quot;,&quot;language&quot;:&quot;angular&quot;,&quot;rawCodeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n  .resize(\\n    thumbnail()\\n      .width(150)\\n      .height(150)\\n      .gravity(focusOn(face()))\\n  )\\n  .roundCorners(byRadius(50));&quot;,&quot;codeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n  .resize(\\n    thumbnail()\\n      .width(150)\\n      .height(150)\\n      .gravity(focusOn(face()))\\n  )\\n  .roundCorners(byRadius(50));&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Angular&quot;,&quot;packageName&quot;:&quot;@cloudinary\\\/ng&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;angular&quot;,&quot;framework&quot;:&quot;angular&quot;,&quot;language&quot;:&quot;angular&quot;,&quot;rawCodeSnippet&quot;:&quot;&lt;cl-image public-id=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt; &lt;cl-transformation width=\\&quot;150\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;face\\&quot; radius=\\&quot;50\\&quot; crop=\\&quot;thumb\\&quot;&gt; &lt;\\\/cl-transformation&gt; &lt;\\\/cl-image&gt;&quot;,&quot;codeSnippet&quot;:&quot;&lt;cl-image public-id=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt;\\n\\t&lt;cl-transformation width=\\&quot;150\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;face\\&quot; radius=\\&quot;50\\&quot; crop=\\&quot;thumb\\&quot;&gt;\\n\\t&lt;\\\/cl-transformation&gt;\\n&lt;\\\/cl-image&gt;&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Angular&quot;,&quot;packageName&quot;:&quot;@cloudinary\\\/angular-5.x&quot;,&quot;packageStatus&quot;:&quot;legacy&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;js_2&quot;,&quot;framework&quot;:&quot;js_2&quot;,&quot;language&quot;:&quot;js&quot;,&quot;rawCodeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n  .resize(\\n    thumbnail()\\n      .width(150)\\n      .height(150)\\n      .gravity(focusOn(face()))\\n  )\\n  .roundCorners(byRadius(50));&quot;,&quot;codeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n  .resize(\\n    thumbnail()\\n      .width(150)\\n      .height(150)\\n      .gravity(focusOn(face()))\\n  )\\n  .roundCorners(byRadius(50));&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;JS&quot;,&quot;packageName&quot;:&quot;@cloudinary\\\/url-gen&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;js&quot;,&quot;framework&quot;:&quot;js&quot;,&quot;language&quot;:&quot;js&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.imageTag(&#039;brahghhk8di0ypfrlu7k.jpg&#039;, {width: 150, height: 150, gravity: \\&quot;face\\&quot;, radius: 50, crop: \\&quot;thumb\\&quot;}).toHtml();&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.imageTag(&#039;brahghhk8di0ypfrlu7k.jpg&#039;, {width: 150, height: 150, gravity: \\&quot;face\\&quot;, radius: 50, crop: \\&quot;thumb\\&quot;}).toHtml();&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;JS&quot;,&quot;packageName&quot;:&quot;cloudinary-core&quot;,&quot;packageStatus&quot;:&quot;legacy&quot;,&quot;packageVersion&quot;:&quot;2.x&quot;},{&quot;sdkId&quot;:&quot;python&quot;,&quot;framework&quot;:&quot;python&quot;,&quot;language&quot;:&quot;python&quot;,&quot;rawCodeSnippet&quot;:&quot;CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).image(width=150, height=150, gravity=\\&quot;face\\&quot;, radius=50, crop=\\&quot;thumb\\&quot;)&quot;,&quot;codeSnippet&quot;:&quot;CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).image(width=150, height=150, gravity=\\&quot;face\\&quot;, radius=50, crop=\\&quot;thumb\\&quot;)&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Python&quot;,&quot;packageName&quot;:&quot;cloudinary&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;php_2&quot;,&quot;framework&quot;:&quot;php_2&quot;,&quot;language&quot;:&quot;php&quot;,&quot;rawCodeSnippet&quot;:&quot;(new ImageTag(&#039;brahghhk8di0ypfrlu7k.jpg&#039;))\\n\\t-&gt;resize(Resize::thumbnail()-&gt;width(150)\\n-&gt;height(150)\\n\\t-&gt;gravity(\\n\\tGravity::focusOn(\\n\\tFocusOn::face()))\\n\\t)\\n\\t-&gt;roundCorners(RoundCorners::byRadius(50));&quot;,&quot;codeSnippet&quot;:&quot;(new ImageTag(&#039;brahghhk8di0ypfrlu7k.jpg&#039;))\\n\\t-&gt;resize(Resize::thumbnail()-&gt;width(150)\\n-&gt;height(150)\\n\\t-&gt;gravity(\\n\\tGravity::focusOn(\\n\\tFocusOn::face()))\\n\\t)\\n\\t-&gt;roundCorners(RoundCorners::byRadius(50));&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;PHP&quot;,&quot;packageName&quot;:&quot;cloudinary_php&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;3.x&quot;},{&quot;sdkId&quot;:&quot;php&quot;,&quot;framework&quot;:&quot;php&quot;,&quot;language&quot;:&quot;php&quot;,&quot;rawCodeSnippet&quot;:&quot;cl_image_tag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, array(\\&quot;width\\&quot;=&gt;150, \\&quot;height\\&quot;=&gt;150, \\&quot;gravity\\&quot;=&gt;\\&quot;face\\&quot;, \\&quot;radius\\&quot;=&gt;50, \\&quot;crop\\&quot;=&gt;\\&quot;thumb\\&quot;))&quot;,&quot;codeSnippet&quot;:&quot;cl_image_tag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, array(\\&quot;width\\&quot;=&gt;150, \\&quot;height\\&quot;=&gt;150, \\&quot;gravity\\&quot;=&gt;\\&quot;face\\&quot;, \\&quot;radius\\&quot;=&gt;50, \\&quot;crop\\&quot;=&gt;\\&quot;thumb\\&quot;))&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;PHP&quot;,&quot;packageName&quot;:&quot;cloudinary_php&quot;,&quot;packageStatus&quot;:&quot;legacy&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;java&quot;,&quot;framework&quot;:&quot;java&quot;,&quot;language&quot;:&quot;java&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.url().transformation(new Transformation().width(150).height(150).gravity(\\&quot;face\\&quot;).radius(50).crop(\\&quot;thumb\\&quot;)).imageTag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;);&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.url().transformation(new Transformation().width(150).height(150).gravity(\\&quot;face\\&quot;).radius(50).crop(\\&quot;thumb\\&quot;)).imageTag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;);&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Java&quot;,&quot;packageName&quot;:&quot;cloudinary&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;2.x&quot;},{&quot;sdkId&quot;:&quot;ruby&quot;,&quot;framework&quot;:&quot;ruby&quot;,&quot;language&quot;:&quot;ruby&quot;,&quot;rawCodeSnippet&quot;:&quot;cl_image_tag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, width: 150, height: 150, gravity: \\&quot;face\\&quot;, radius: 50, crop: \\&quot;thumb\\&quot;)&quot;,&quot;codeSnippet&quot;:&quot;cl_image_tag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, width: 150, height: 150, gravity: \\&quot;face\\&quot;, radius: 50, crop: \\&quot;thumb\\&quot;)&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Ruby&quot;,&quot;packageName&quot;:&quot;cloudinary&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;2.x&quot;},{&quot;sdkId&quot;:&quot;csharp&quot;,&quot;framework&quot;:&quot;csharp&quot;,&quot;language&quot;:&quot;csharp&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.Api.UrlImgUp.Transform(new Transformation().Width(150).Height(150).Gravity(\\&quot;face\\&quot;).Radius(50).Crop(\\&quot;thumb\\&quot;)).BuildImageTag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.Api.UrlImgUp.Transform(new Transformation().Width(150).Height(150).Gravity(\\&quot;face\\&quot;).Radius(50).Crop(\\&quot;thumb\\&quot;)).BuildImageTag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;.NET&quot;,&quot;packageName&quot;:&quot;CloudinaryDotNet&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;dart&quot;,&quot;framework&quot;:&quot;dart&quot;,&quot;language&quot;:&quot;dart&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.image(&#039;brahghhk8di0ypfrlu7k.jpg&#039;).transformation(Transformation()\\n\\t.resize(Resize.thumbnail().width(150)\\n.height(150)\\n\\t.gravity(\\n\\tGravity.focusOn(\\n\\tFocusOn.face()))\\n\\t)\\n\\t.roundCorners(RoundCorners.byRadius(50)));&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.image(&#039;brahghhk8di0ypfrlu7k.jpg&#039;).transformation(Transformation()\\n\\t.resize(Resize.thumbnail().width(150)\\n.height(150)\\n\\t.gravity(\\n\\tGravity.focusOn(\\n\\tFocusOn.face()))\\n\\t)\\n\\t.roundCorners(RoundCorners.byRadius(50)));&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Dart&quot;,&quot;packageName&quot;:&quot;cloudinary_dart&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;swift&quot;,&quot;framework&quot;:&quot;swift&quot;,&quot;language&quot;:&quot;swift&quot;,&quot;rawCodeSnippet&quot;:&quot;imageView.cldSetImage(cloudinary.createUrl().setTransformation(CLDTransformation().setWidth(150).setHeight(150).setGravity(\\&quot;face\\&quot;).setRadius(50).setCrop(\\&quot;thumb\\&quot;)).generate(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)!, cloudinary: cloudinary)&quot;,&quot;codeSnippet&quot;:&quot;imageView.cldSetImage(cloudinary.createUrl().setTransformation(CLDTransformation().setWidth(150).setHeight(150).setGravity(\\&quot;face\\&quot;).setRadius(50).setCrop(\\&quot;thumb\\&quot;)).generate(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)!, cloudinary: cloudinary)&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;iOS&quot;,&quot;packageName&quot;:&quot;cloudinary&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;5.x&quot;},{&quot;sdkId&quot;:&quot;android&quot;,&quot;framework&quot;:&quot;android&quot;,&quot;language&quot;:&quot;android&quot;,&quot;rawCodeSnippet&quot;:&quot;MediaManager.get().url().transformation(new Transformation().width(150).height(150).gravity(\\&quot;face\\&quot;).radius(50).crop(\\&quot;thumb\\&quot;)).generate(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;);&quot;,&quot;codeSnippet&quot;:&quot;MediaManager.get().url().transformation(new Transformation().width(150).height(150).gravity(\\&quot;face\\&quot;).radius(50).crop(\\&quot;thumb\\&quot;)).generate(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;);&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Android&quot;,&quot;packageName&quot;:&quot;cloudinary-android&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;3.x&quot;},{&quot;sdkId&quot;:&quot;flutter&quot;,&quot;framework&quot;:&quot;flutter&quot;,&quot;language&quot;:&quot;flutter&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.image(&#039;brahghhk8di0ypfrlu7k.jpg&#039;).transformation(Transformation()\\n\\t.addTransformation(\\&quot;w_150,h_150,c_thumb,g_face,r_50\\&quot;));&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.image(&#039;brahghhk8di0ypfrlu7k.jpg&#039;).transformation(Transformation()\\n\\t.addTransformation(\\&quot;w_150,h_150,c_thumb,g_face,r_50\\&quot;));&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Flutter&quot;,&quot;packageName&quot;:&quot;cloudinary_flutter&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;kotlin&quot;,&quot;framework&quot;:&quot;kotlin&quot;,&quot;language&quot;:&quot;kotlin&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.image {\\n\\tpublicId(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n\\t resize(Resize.thumbnail() { width(150)\\n height(150)\\n\\t gravity(\\n\\tGravity.focusOn(\\n\\tFocusOn.face()))\\n\\t })\\n\\t roundCorners(RoundCorners.byRadius(50)) \\n}.generate()&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.image {\\n\\tpublicId(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n\\t resize(Resize.thumbnail() { width(150)\\n height(150)\\n\\t gravity(\\n\\tGravity.focusOn(\\n\\tFocusOn.face()))\\n\\t })\\n\\t roundCorners(RoundCorners.byRadius(50)) \\n}.generate()&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Kotlin&quot;,&quot;packageName&quot;:&quot;kotlin-url-gen&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;jquery&quot;,&quot;framework&quot;:&quot;jquery&quot;,&quot;language&quot;:&quot;jquery&quot;,&quot;rawCodeSnippet&quot;:&quot;$.cloudinary.image(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, {width: 150, height: 150, gravity: \\&quot;face\\&quot;, radius: 50, crop: \\&quot;thumb\\&quot;})&quot;,&quot;codeSnippet&quot;:&quot;$.cloudinary.image(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, {width: 150, height: 150, gravity: \\&quot;face\\&quot;, radius: 50, crop: \\&quot;thumb\\&quot;})&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;jQuery&quot;,&quot;packageName&quot;:&quot;cloudinary-jquery&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;2.x&quot;},{&quot;sdkId&quot;:&quot;react_native&quot;,&quot;framework&quot;:&quot;react_native&quot;,&quot;language&quot;:&quot;react_native&quot;,&quot;rawCodeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n  .resize(\\n    thumbnail()\\n      .width(150)\\n      .height(150)\\n      .gravity(focusOn(face()))\\n  )\\n  .roundCorners(byRadius(50));&quot;,&quot;codeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n  .resize(\\n    thumbnail()\\n      .width(150)\\n      .height(150)\\n      .gravity(focusOn(face()))\\n  )\\n  .roundCorners(byRadius(50));&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;React Native&quot;,&quot;packageName&quot;:&quot;cloudinary-react-native&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;}]\"\n      parsed-url=\"{&quot;url&quot;:&quot;https:\\\/\\\/res.cloudinary.com\\\/demo\\\/image\\\/upload\\\/w_150,h_150,c_thumb,g_face,r_50\\\/brahghhk8di0ypfrlu7k.jpg&quot;,&quot;cloud_name&quot;:&quot;demo&quot;,&quot;host&quot;:&quot;res.cloudinary.com&quot;,&quot;type&quot;:&quot;upload&quot;,&quot;resource_type&quot;:&quot;image&quot;,&quot;transformation&quot;:[{&quot;width&quot;:&quot;150&quot;,&quot;height&quot;:&quot;150&quot;,&quot;crop_mode&quot;:&quot;thumb&quot;,&quot;gravity&quot;:&quot;face&quot;,&quot;radius&quot;:&quot;50&quot;}],&quot;transformation_string&quot;:&quot;w_150,h_150,c_thumb,g_face,r_50&quot;,&quot;url_suffix&quot;:&quot;&quot;,&quot;version&quot;:&quot;&quot;,&quot;secure&quot;:true,&quot;public_id&quot;:&quot;brahghhk8di0ypfrlu7k.jpg&quot;,&quot;extension&quot;:&quot;jpg&quot;,&quot;format&quot;:&quot;jpg&quot;,&quot;format_code&quot;:true,&quot;url_code&quot;:false,&quot;signature&quot;:&quot;&quot;,&quot;private_cdn&quot;:false,&quot;result_asset_type&quot;:&quot;image&quot;}\"\n      with-url=\"true\"\n    >\n      <span class=\"u-visually-hidden\">Loading code examples<\/span>\n    <\/cld-code-widget><a class=\"c-image-link\" href=\"https:\/\/res.cloudinary.com\/demo\/image\/upload\/w_150,h_150,c_thumb,g_face,r_50\/brahghhk8di0ypfrlu7k.jpg\" target=\"_blank\"><img decoding=\"async\" src=\"https:\/\/res.cloudinary.com\/demo\/image\/upload\/w_150,h_150,c_thumb,g_face,r_50\/brahghhk8di0ypfrlu7k.jpg\" alt=\"Face detection based cropped thumbnail\" loading=\"lazy\" class=\"c-transformed-asset\"  width=\"150\" height=\"150\"\/><\/a><\/p>\n<p>There are various different ways in which you can use the widget. One way is by telling Cloudinary programmatically in your JavaScript code to show the widget. Another way is by rendering a button on your site that opens the widget when it is clicked. In addition, you can tell the widget to automatically create hidden fields in your web page with the uploaded image\u2019s identifiers, or automatically create image thumbnails that are displayed on your site. The upload widget has plenty more options and customizations available. For instance, you can limit the number of files that users are allowed to upload, apply client-side validations that need to be performed regarding file sizes and dimensions, or restrict specific image formats (JPEG or PNG).<\/p>\n<p>For more details, see our <a href=\"https:\/\/cloudinary.com\/documentation\/upload_widget\">documentation page<\/a>.<\/p>\n<h2>Mark areas of interest and crop interactively<\/h2>\n<p>One of our widget\u2019s interesting features is the ability to allow your users to perform interactive image cropping while their images are uploaded to the cloud. This can be done by setting the <code>cropping<\/code> parameter to <code>server<\/code>.<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/res.cloudinary.com\/cloudinary\/image\/upload\/w_600\/upload_widget_cropping_qkre3e.jpg\" alt=\"Upload widget with interactive cropping\" loading=\"lazy\" class=\"c-transformed-asset\"  width=\"600\" height=\"287\"\/><\/p>\n<p>You can try out a live example by clicking on the following button:<\/p>\n<div style='margin-bottom: 20px' class=\"upload_with_crop_holder\">\n  <a href=\"#\" class=\"cloudinary-button\" id=\"upload_widget_crop\" style=\"color: #fff\">Upload &#038; crop image<\/a>\n<\/div>\n<p>Uploaded images can be stored, as they are, in the cloud together with the coordinates that your users marked as areas of interest. Then, you can use Cloudinary\u2019s on-the-fly image transformation URLs to create thumbnails of the original images while cropping the images based on their marked coordinates. This is done by setting the <code>gravity<\/code> transformation parameter to <code>custom<\/code>. As you can see in the example below, that generates a 200&#215;150 thumbnail of an uploaded image based on the marked coordinates.<\/p>\n<p><cld-code-widget\n      class=\" c-code-widget\"\n      snippets=\"[{&quot;sdkId&quot;:&quot;nodejs&quot;,&quot;framework&quot;:&quot;nodejs&quot;,&quot;language&quot;:&quot;nodejs&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.image(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, {width: 200, height: 150, gravity: \\&quot;custom\\&quot;, crop: \\&quot;thumb\\&quot;})&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.image(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, {width: 200, height: 150, gravity: \\&quot;custom\\&quot;, crop: \\&quot;thumb\\&quot;})&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Node.js&quot;,&quot;packageName&quot;:&quot;cloudinary&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;2.x&quot;},{&quot;sdkId&quot;:&quot;react_2&quot;,&quot;framework&quot;:&quot;react_2&quot;,&quot;language&quot;:&quot;react&quot;,&quot;rawCodeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).resize(\\n  thumbnail()\\n    .width(200)\\n    .height(150)\\n    .gravity(focusOn(custom()))\\n);&quot;,&quot;codeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).resize(\\n  thumbnail()\\n    .width(200)\\n    .height(150)\\n    .gravity(focusOn(custom()))\\n);&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;React&quot;,&quot;packageName&quot;:&quot;@cloudinary\\\/react&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;react&quot;,&quot;framework&quot;:&quot;react&quot;,&quot;language&quot;:&quot;react&quot;,&quot;rawCodeSnippet&quot;:&quot;&lt;Image publicId=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt; &lt;Transformation width=\\&quot;200\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;custom\\&quot; crop=\\&quot;thumb\\&quot; \\\/&gt; &lt;\\\/Image&gt;&quot;,&quot;codeSnippet&quot;:&quot;&lt;Image publicId=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt;\\n\\t&lt;Transformation width=\\&quot;200\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;custom\\&quot; crop=\\&quot;thumb\\&quot; \\\/&gt;\\n&lt;\\\/Image&gt;&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;React&quot;,&quot;packageName&quot;:&quot;cloudinary-react&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;vue_2&quot;,&quot;framework&quot;:&quot;vue_2&quot;,&quot;language&quot;:&quot;vue&quot;,&quot;rawCodeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).resize(\\n  thumbnail()\\n    .width(200)\\n    .height(150)\\n    .gravity(focusOn(custom()))\\n);&quot;,&quot;codeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).resize(\\n  thumbnail()\\n    .width(200)\\n    .height(150)\\n    .gravity(focusOn(custom()))\\n);&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Vue.js&quot;,&quot;packageName&quot;:&quot;@cloudinary\\\/vue&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;vue&quot;,&quot;framework&quot;:&quot;vue&quot;,&quot;language&quot;:&quot;vue&quot;,&quot;rawCodeSnippet&quot;:&quot;&lt;cld-image public-id=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt; &lt;cld-transformation width=\\&quot;200\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;custom\\&quot; crop=\\&quot;thumb\\&quot; \\\/&gt; &lt;\\\/cld-image&gt;&quot;,&quot;codeSnippet&quot;:&quot;&lt;cld-image public-id=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt;\\n\\t&lt;cld-transformation width=\\&quot;200\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;custom\\&quot; crop=\\&quot;thumb\\&quot; \\\/&gt;\\n&lt;\\\/cld-image&gt;&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Vue.js&quot;,&quot;packageName&quot;:&quot;cloudinary-vue&quot;,&quot;packageStatus&quot;:&quot;legacy&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;angular_2&quot;,&quot;framework&quot;:&quot;angular_2&quot;,&quot;language&quot;:&quot;angular&quot;,&quot;rawCodeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).resize(\\n  thumbnail()\\n    .width(200)\\n    .height(150)\\n    .gravity(focusOn(custom()))\\n);&quot;,&quot;codeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).resize(\\n  thumbnail()\\n    .width(200)\\n    .height(150)\\n    .gravity(focusOn(custom()))\\n);&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Angular&quot;,&quot;packageName&quot;:&quot;@cloudinary\\\/ng&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;angular&quot;,&quot;framework&quot;:&quot;angular&quot;,&quot;language&quot;:&quot;angular&quot;,&quot;rawCodeSnippet&quot;:&quot;&lt;cl-image public-id=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt; &lt;cl-transformation width=\\&quot;200\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;custom\\&quot; crop=\\&quot;thumb\\&quot;&gt; &lt;\\\/cl-transformation&gt; &lt;\\\/cl-image&gt;&quot;,&quot;codeSnippet&quot;:&quot;&lt;cl-image public-id=\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot; &gt;\\n\\t&lt;cl-transformation width=\\&quot;200\\&quot; height=\\&quot;150\\&quot; gravity=\\&quot;custom\\&quot; crop=\\&quot;thumb\\&quot;&gt;\\n\\t&lt;\\\/cl-transformation&gt;\\n&lt;\\\/cl-image&gt;&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Angular&quot;,&quot;packageName&quot;:&quot;@cloudinary\\\/angular-5.x&quot;,&quot;packageStatus&quot;:&quot;legacy&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;js_2&quot;,&quot;framework&quot;:&quot;js_2&quot;,&quot;language&quot;:&quot;js&quot;,&quot;rawCodeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).resize(\\n  thumbnail()\\n    .width(200)\\n    .height(150)\\n    .gravity(focusOn(custom()))\\n);&quot;,&quot;codeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).resize(\\n  thumbnail()\\n    .width(200)\\n    .height(150)\\n    .gravity(focusOn(custom()))\\n);&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;JS&quot;,&quot;packageName&quot;:&quot;@cloudinary\\\/url-gen&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;js&quot;,&quot;framework&quot;:&quot;js&quot;,&quot;language&quot;:&quot;js&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.imageTag(&#039;brahghhk8di0ypfrlu7k.jpg&#039;, {width: 200, height: 150, gravity: \\&quot;custom\\&quot;, crop: \\&quot;thumb\\&quot;}).toHtml();&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.imageTag(&#039;brahghhk8di0ypfrlu7k.jpg&#039;, {width: 200, height: 150, gravity: \\&quot;custom\\&quot;, crop: \\&quot;thumb\\&quot;}).toHtml();&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;JS&quot;,&quot;packageName&quot;:&quot;cloudinary-core&quot;,&quot;packageStatus&quot;:&quot;legacy&quot;,&quot;packageVersion&quot;:&quot;2.x&quot;},{&quot;sdkId&quot;:&quot;python&quot;,&quot;framework&quot;:&quot;python&quot;,&quot;language&quot;:&quot;python&quot;,&quot;rawCodeSnippet&quot;:&quot;CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).image(width=200, height=150, gravity=\\&quot;custom\\&quot;, crop=\\&quot;thumb\\&quot;)&quot;,&quot;codeSnippet&quot;:&quot;CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).image(width=200, height=150, gravity=\\&quot;custom\\&quot;, crop=\\&quot;thumb\\&quot;)&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Python&quot;,&quot;packageName&quot;:&quot;cloudinary&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;php_2&quot;,&quot;framework&quot;:&quot;php_2&quot;,&quot;language&quot;:&quot;php&quot;,&quot;rawCodeSnippet&quot;:&quot;(new ImageTag(&#039;brahghhk8di0ypfrlu7k.jpg&#039;))\\n\\t-&gt;resize(Resize::thumbnail()-&gt;width(200)\\n-&gt;height(150)\\n\\t-&gt;gravity(\\n\\tGravity::focusOn(\\n\\tFocusOn::custom()))\\n\\t);&quot;,&quot;codeSnippet&quot;:&quot;(new ImageTag(&#039;brahghhk8di0ypfrlu7k.jpg&#039;))\\n\\t-&gt;resize(Resize::thumbnail()-&gt;width(200)\\n-&gt;height(150)\\n\\t-&gt;gravity(\\n\\tGravity::focusOn(\\n\\tFocusOn::custom()))\\n\\t);&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;PHP&quot;,&quot;packageName&quot;:&quot;cloudinary_php&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;3.x&quot;},{&quot;sdkId&quot;:&quot;php&quot;,&quot;framework&quot;:&quot;php&quot;,&quot;language&quot;:&quot;php&quot;,&quot;rawCodeSnippet&quot;:&quot;cl_image_tag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, array(\\&quot;width\\&quot;=&gt;200, \\&quot;height\\&quot;=&gt;150, \\&quot;gravity\\&quot;=&gt;\\&quot;custom\\&quot;, \\&quot;crop\\&quot;=&gt;\\&quot;thumb\\&quot;))&quot;,&quot;codeSnippet&quot;:&quot;cl_image_tag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, array(\\&quot;width\\&quot;=&gt;200, \\&quot;height\\&quot;=&gt;150, \\&quot;gravity\\&quot;=&gt;\\&quot;custom\\&quot;, \\&quot;crop\\&quot;=&gt;\\&quot;thumb\\&quot;))&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;PHP&quot;,&quot;packageName&quot;:&quot;cloudinary_php&quot;,&quot;packageStatus&quot;:&quot;legacy&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;java&quot;,&quot;framework&quot;:&quot;java&quot;,&quot;language&quot;:&quot;java&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.url().transformation(new Transformation().width(200).height(150).gravity(\\&quot;custom\\&quot;).crop(\\&quot;thumb\\&quot;)).imageTag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;);&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.url().transformation(new Transformation().width(200).height(150).gravity(\\&quot;custom\\&quot;).crop(\\&quot;thumb\\&quot;)).imageTag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;);&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Java&quot;,&quot;packageName&quot;:&quot;cloudinary&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;2.x&quot;},{&quot;sdkId&quot;:&quot;ruby&quot;,&quot;framework&quot;:&quot;ruby&quot;,&quot;language&quot;:&quot;ruby&quot;,&quot;rawCodeSnippet&quot;:&quot;cl_image_tag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, width: 200, height: 150, gravity: \\&quot;custom\\&quot;, crop: \\&quot;thumb\\&quot;)&quot;,&quot;codeSnippet&quot;:&quot;cl_image_tag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, width: 200, height: 150, gravity: \\&quot;custom\\&quot;, crop: \\&quot;thumb\\&quot;)&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Ruby&quot;,&quot;packageName&quot;:&quot;cloudinary&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;2.x&quot;},{&quot;sdkId&quot;:&quot;csharp&quot;,&quot;framework&quot;:&quot;csharp&quot;,&quot;language&quot;:&quot;csharp&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.Api.UrlImgUp.Transform(new Transformation().Width(200).Height(150).Gravity(\\&quot;custom\\&quot;).Crop(\\&quot;thumb\\&quot;)).BuildImageTag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.Api.UrlImgUp.Transform(new Transformation().Width(200).Height(150).Gravity(\\&quot;custom\\&quot;).Crop(\\&quot;thumb\\&quot;)).BuildImageTag(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;.NET&quot;,&quot;packageName&quot;:&quot;CloudinaryDotNet&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;dart&quot;,&quot;framework&quot;:&quot;dart&quot;,&quot;language&quot;:&quot;dart&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.image(&#039;brahghhk8di0ypfrlu7k.jpg&#039;).transformation(Transformation()\\n\\t.resize(Resize.thumbnail().width(200)\\n.height(150)\\n\\t.gravity(\\n\\tGravity.focusOn(\\n\\tFocusOn.custom()))\\n\\t));&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.image(&#039;brahghhk8di0ypfrlu7k.jpg&#039;).transformation(Transformation()\\n\\t.resize(Resize.thumbnail().width(200)\\n.height(150)\\n\\t.gravity(\\n\\tGravity.focusOn(\\n\\tFocusOn.custom()))\\n\\t));&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Dart&quot;,&quot;packageName&quot;:&quot;cloudinary_dart&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;swift&quot;,&quot;framework&quot;:&quot;swift&quot;,&quot;language&quot;:&quot;swift&quot;,&quot;rawCodeSnippet&quot;:&quot;imageView.cldSetImage(cloudinary.createUrl().setTransformation(CLDTransformation().setWidth(200).setHeight(150).setGravity(\\&quot;custom\\&quot;).setCrop(\\&quot;thumb\\&quot;)).generate(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)!, cloudinary: cloudinary)&quot;,&quot;codeSnippet&quot;:&quot;imageView.cldSetImage(cloudinary.createUrl().setTransformation(CLDTransformation().setWidth(200).setHeight(150).setGravity(\\&quot;custom\\&quot;).setCrop(\\&quot;thumb\\&quot;)).generate(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)!, cloudinary: cloudinary)&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;iOS&quot;,&quot;packageName&quot;:&quot;cloudinary&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;5.x&quot;},{&quot;sdkId&quot;:&quot;android&quot;,&quot;framework&quot;:&quot;android&quot;,&quot;language&quot;:&quot;android&quot;,&quot;rawCodeSnippet&quot;:&quot;MediaManager.get().url().transformation(new Transformation().width(200).height(150).gravity(\\&quot;custom\\&quot;).crop(\\&quot;thumb\\&quot;)).generate(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;);&quot;,&quot;codeSnippet&quot;:&quot;MediaManager.get().url().transformation(new Transformation().width(200).height(150).gravity(\\&quot;custom\\&quot;).crop(\\&quot;thumb\\&quot;)).generate(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;);&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Android&quot;,&quot;packageName&quot;:&quot;cloudinary-android&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;3.x&quot;},{&quot;sdkId&quot;:&quot;flutter&quot;,&quot;framework&quot;:&quot;flutter&quot;,&quot;language&quot;:&quot;flutter&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.image(&#039;brahghhk8di0ypfrlu7k.jpg&#039;).transformation(Transformation()\\n\\t.resize(Resize.thumbnail().width(200)\\n.height(150)\\n\\t.gravity(\\n\\tGravity.focusOn(\\n\\tFocusOn.custom()))\\n\\t));&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.image(&#039;brahghhk8di0ypfrlu7k.jpg&#039;).transformation(Transformation()\\n\\t.resize(Resize.thumbnail().width(200)\\n.height(150)\\n\\t.gravity(\\n\\tGravity.focusOn(\\n\\tFocusOn.custom()))\\n\\t));&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Flutter&quot;,&quot;packageName&quot;:&quot;cloudinary_flutter&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;kotlin&quot;,&quot;framework&quot;:&quot;kotlin&quot;,&quot;language&quot;:&quot;kotlin&quot;,&quot;rawCodeSnippet&quot;:&quot;cloudinary.image {\\n\\tpublicId(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n\\t resize(Resize.thumbnail() { width(200)\\n height(150)\\n\\t gravity(\\n\\tGravity.focusOn(\\n\\tFocusOn.custom()))\\n\\t }) \\n}.generate()&quot;,&quot;codeSnippet&quot;:&quot;cloudinary.image {\\n\\tpublicId(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;)\\n\\t resize(Resize.thumbnail() { width(200)\\n height(150)\\n\\t gravity(\\n\\tGravity.focusOn(\\n\\tFocusOn.custom()))\\n\\t }) \\n}.generate()&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;Kotlin&quot;,&quot;packageName&quot;:&quot;kotlin-url-gen&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;},{&quot;sdkId&quot;:&quot;jquery&quot;,&quot;framework&quot;:&quot;jquery&quot;,&quot;language&quot;:&quot;jquery&quot;,&quot;rawCodeSnippet&quot;:&quot;$.cloudinary.image(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, {width: 200, height: 150, gravity: \\&quot;custom\\&quot;, crop: \\&quot;thumb\\&quot;})&quot;,&quot;codeSnippet&quot;:&quot;$.cloudinary.image(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;, {width: 200, height: 150, gravity: \\&quot;custom\\&quot;, crop: \\&quot;thumb\\&quot;})&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;jQuery&quot;,&quot;packageName&quot;:&quot;cloudinary-jquery&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;2.x&quot;},{&quot;sdkId&quot;:&quot;react_native&quot;,&quot;framework&quot;:&quot;react_native&quot;,&quot;language&quot;:&quot;react_native&quot;,&quot;rawCodeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).resize(\\n  thumbnail()\\n    .width(200)\\n    .height(150)\\n    .gravity(focusOn(custom()))\\n);&quot;,&quot;codeSnippet&quot;:&quot;new CloudinaryImage(\\&quot;brahghhk8di0ypfrlu7k.jpg\\&quot;).resize(\\n  thumbnail()\\n    .width(200)\\n    .height(150)\\n    .gravity(focusOn(custom()))\\n);&quot;,&quot;status&quot;:0,&quot;statusText&quot;:&quot;Ok&quot;,&quot;displayName&quot;:&quot;React Native&quot;,&quot;packageName&quot;:&quot;cloudinary-react-native&quot;,&quot;packageStatus&quot;:&quot;&quot;,&quot;packageVersion&quot;:&quot;1.x&quot;}]\"\n      parsed-url=\"{&quot;url&quot;:&quot;https:\\\/\\\/res.cloudinary.com\\\/demo\\\/image\\\/upload\\\/w_200,h_150,c_thumb,g_custom\\\/brahghhk8di0ypfrlu7k.jpg&quot;,&quot;cloud_name&quot;:&quot;demo&quot;,&quot;host&quot;:&quot;res.cloudinary.com&quot;,&quot;type&quot;:&quot;upload&quot;,&quot;resource_type&quot;:&quot;image&quot;,&quot;transformation&quot;:[{&quot;width&quot;:&quot;200&quot;,&quot;height&quot;:&quot;150&quot;,&quot;crop_mode&quot;:&quot;thumb&quot;,&quot;gravity&quot;:&quot;custom&quot;}],&quot;transformation_string&quot;:&quot;w_200,h_150,c_thumb,g_custom&quot;,&quot;url_suffix&quot;:&quot;&quot;,&quot;version&quot;:&quot;&quot;,&quot;secure&quot;:true,&quot;public_id&quot;:&quot;brahghhk8di0ypfrlu7k.jpg&quot;,&quot;extension&quot;:&quot;jpg&quot;,&quot;format&quot;:&quot;jpg&quot;,&quot;format_code&quot;:true,&quot;url_code&quot;:false,&quot;signature&quot;:&quot;&quot;,&quot;private_cdn&quot;:false,&quot;result_asset_type&quot;:&quot;image&quot;}\"\n      with-url=\"true\"\n    >\n      <span class=\"u-visually-hidden\">Loading code examples<\/span>\n    <\/cld-code-widget><a class=\"c-image-link\" href=\"https:\/\/res.cloudinary.com\/demo\/image\/upload\/w_200,h_150,c_thumb,g_custom\/brahghhk8di0ypfrlu7k.jpg\" target=\"_blank\"><img decoding=\"async\" src=\"https:\/\/res.cloudinary.com\/demo\/image\/upload\/w_200,h_150,c_thumb,g_custom\/brahghhk8di0ypfrlu7k.jpg\" alt=\"Custom cropped thumbnail\" loading=\"lazy\" class=\"c-transformed-asset\"  width=\"200\" height=\"150\"\/><\/a>\n<a class=\"c-image-link\" href=\"https:\/\/res.cloudinary.com\/demo\/image\/upload\/h_150\/brahghhk8di0ypfrlu7k.jpg\" target=\"_blank\"><img decoding=\"async\" src=\"https:\/\/res.cloudinary.com\/demo\/image\/upload\/h_150\/brahghhk8di0ypfrlu7k.jpg\" alt=\"Original uploaded image\" loading=\"lazy\" class=\"c-transformed-asset\"  width=\"225\" height=\"150\"\/><\/a><\/p>\n<div style=\"clear: both\"><\/div>\n<p>You can also have Cloudinary crop images based on your specified coordinates while uploading before storing them in the cloud using server-side defined <a href=\"https:\/\/cloudinary.com\/blog\/centralized_control_for_image_upload_image_size_format_thumbnail_generation_tagging_and_more\">upload presets<\/a>.<\/p>\n<h2>Summary<\/h2>\n<p>The upload widget is a powerful addition to Cloudinary\u2019s end-to-end image management solution. Cloudinary intelligently removes the hassles involved with image uploading, transformation and delivery, and now with the upload widget, provides you with a dynamic upload UI right on your site.<\/p>\n<p>All it takes is adding a single line of JavaScript code, no additional code is required on the client or server sides. We are very excited to introduce our upload widget and have big plans for further enhancements. As with all of Cloudinary\u2019s features, this widget is available in all of our plans, including the free tier with no additional costs. We welcome all feedback in order to make future versions even better.<\/p>\n<p>We invite you to <a href=\"https:\/\/cloudinary.com\/users\/register\/free\">sign up to Cloudinary<\/a> and start using our upload widget for free today!<\/p>\n<script>\n  \/\/<![CDATA[   \nfunction insertScript(src, callback) {\nvar script = document.createElement('script');\nscript.onload = callback;\nscript.type = 'text\/javascript';\nscript.async = true;\nscript.src = src;\nvar s = document.getElementsByTagName('script')[0];\ns.parentNode.insertBefore(script, s);\n}\nfunction initWidgetDemo() {\n    cloudinary.setCloudName('hzxyensd5');\n    $('#upload_widget_multiple').click(function(e) {\n      e.preventDefault();\n      cloudinary.openUploadWidget({ upload_preset: 'aoh4fpwm', folder: 'widgetblogpost', form: '.upload_multiple_images_holder', thumbnails: '.upload_multiple_images_holder' }, \n      function(error, result) { });\n    });\n\n    $('#upload_widget_crop').click(function(e) {\n      e.preventDefault();\n      cloudinary.openUploadWidget({ upload_preset: 'aoh4fpwm', folder: 'widgetblogpost', form: '.upload_with_crop_holder', thumbnails: '.upload_with_crop_holder', cropping: 'server' }, \n      function(error, result) {  });\n  });\n}\ninsertScript('\/javascripts\/jquery.min.js', function(){insertScript('\/\/widget.cloudinary.com\/global\/all.js', initWidgetDemo)});\n  \/\/]]>\n<\/script>\n<\/div>","protected":false},"excerpt":{"rendered":"","protected":false},"author":41,"featured_media":24065,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"_cloudinary_featured_overwrite":false,"footnotes":""},"categories":[1],"tags":[91,92,119,165,176,177,183,214,229,257],"class_list":["post-21261","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-uncategorized","tag-django","tag-dotnet","tag-file-upload","tag-image-transformation","tag-java","tag-javascript","tag-jquery","tag-node","tag-php","tag-ruby-on-rails"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v25.6 (Yoast SEO v26.9) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>Introducing a new cloud based image upload UI widget<\/title>\n<meta name=\"description\" content=\"A new dynamic upload user interface, within your site or app, that allows users to easily upload images to the cloud\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Introducing a complete and modern UI widget for cloud based image uploading\" \/>\n<meta property=\"og:description\" content=\"A new dynamic upload user interface, within your site or app, that allows users to easily upload images to the cloud\" \/>\n<meta property=\"og:url\" content=\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading\" \/>\n<meta property=\"og:site_name\" content=\"Cloudinary Blog\" \/>\n<meta property=\"article:published_time\" content=\"2014-11-27T14:41:02+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-06-05T23:12:18+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/v1650586080\/76_cloud-upload-widget\/76_cloud-upload-widget-png?_i=AA\" \/>\n\t<meta property=\"og:image:width\" content=\"2000\" \/>\n\t<meta property=\"og:image:height\" content=\"1100\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"NewsArticle\",\"@id\":\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#article\",\"isPartOf\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading\"},\"author\":{\"name\":\"\",\"@id\":\"\"},\"headline\":\"Introducing a complete and modern UI widget for cloud based image uploading\",\"datePublished\":\"2014-11-27T14:41:02+00:00\",\"dateModified\":\"2024-06-05T23:12:18+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading\"},\"wordCount\":12,\"publisher\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/#organization\"},\"image\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#primaryimage\"},\"thumbnailUrl\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1650586080\/76_cloud-upload-widget\/76_cloud-upload-widget.png?_i=AA\",\"keywords\":[\"Django\",\"DotNet\",\"File-upload\",\"Image Transformation\",\"Java\",\"Javascript\",\"jQuery\",\"Node\",\"PHP\",\"Ruby on Rails\"],\"inLanguage\":\"en-US\",\"copyrightYear\":\"2014\",\"copyrightHolder\":{\"@id\":\"https:\/\/cloudinary.com\/#organization\"}},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading\",\"url\":\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading\",\"name\":\"Introducing a new cloud based image upload UI widget\",\"isPartOf\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#primaryimage\"},\"image\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#primaryimage\"},\"thumbnailUrl\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1650586080\/76_cloud-upload-widget\/76_cloud-upload-widget.png?_i=AA\",\"datePublished\":\"2014-11-27T14:41:02+00:00\",\"dateModified\":\"2024-06-05T23:12:18+00:00\",\"description\":\"A new dynamic upload user interface, within your site or app, that allows users to easily upload images to the cloud\",\"breadcrumb\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#primaryimage\",\"url\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1650586080\/76_cloud-upload-widget\/76_cloud-upload-widget.png?_i=AA\",\"contentUrl\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1650586080\/76_cloud-upload-widget\/76_cloud-upload-widget.png?_i=AA\",\"width\":2000,\"height\":1100},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/cloudinary.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Introducing a complete and modern UI widget for cloud based image uploading\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/cloudinary.com\/blog\/#website\",\"url\":\"https:\/\/cloudinary.com\/blog\/\",\"name\":\"Cloudinary Blog\",\"description\":\"\",\"publisher\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/cloudinary.com\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Organization\",\"@id\":\"https:\/\/cloudinary.com\/blog\/#organization\",\"name\":\"Cloudinary Blog\",\"url\":\"https:\/\/cloudinary.com\/blog\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/cloudinary.com\/blog\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1649718331\/Web_Assets\/blog\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877.png?_i=AA\",\"contentUrl\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1649718331\/Web_Assets\/blog\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877.png?_i=AA\",\"width\":312,\"height\":60,\"caption\":\"Cloudinary Blog\"},\"image\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/#\/schema\/logo\/image\/\"}},{\"@type\":\"Person\",\"@id\":\"\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Introducing a new cloud based image upload UI widget","description":"A new dynamic upload user interface, within your site or app, that allows users to easily upload images to the cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading","og_locale":"en_US","og_type":"article","og_title":"Introducing a complete and modern UI widget for cloud based image uploading","og_description":"A new dynamic upload user interface, within your site or app, that allows users to easily upload images to the cloud","og_url":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading","og_site_name":"Cloudinary Blog","article_published_time":"2014-11-27T14:41:02+00:00","article_modified_time":"2024-06-05T23:12:18+00:00","og_image":[{"width":2000,"height":1100,"url":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/v1650586080\/76_cloud-upload-widget\/76_cloud-upload-widget-png?_i=AA","type":"image\/png"}],"twitter_card":"summary_large_image","schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"NewsArticle","@id":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#article","isPartOf":{"@id":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading"},"author":{"name":"","@id":""},"headline":"Introducing a complete and modern UI widget for cloud based image uploading","datePublished":"2014-11-27T14:41:02+00:00","dateModified":"2024-06-05T23:12:18+00:00","mainEntityOfPage":{"@id":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading"},"wordCount":12,"publisher":{"@id":"https:\/\/cloudinary.com\/blog\/#organization"},"image":{"@id":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#primaryimage"},"thumbnailUrl":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1650586080\/76_cloud-upload-widget\/76_cloud-upload-widget.png?_i=AA","keywords":["Django","DotNet","File-upload","Image Transformation","Java","Javascript","jQuery","Node","PHP","Ruby on Rails"],"inLanguage":"en-US","copyrightYear":"2014","copyrightHolder":{"@id":"https:\/\/cloudinary.com\/#organization"}},{"@type":"WebPage","@id":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading","url":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading","name":"Introducing a new cloud based image upload UI widget","isPartOf":{"@id":"https:\/\/cloudinary.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#primaryimage"},"image":{"@id":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#primaryimage"},"thumbnailUrl":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1650586080\/76_cloud-upload-widget\/76_cloud-upload-widget.png?_i=AA","datePublished":"2014-11-27T14:41:02+00:00","dateModified":"2024-06-05T23:12:18+00:00","description":"A new dynamic upload user interface, within your site or app, that allows users to easily upload images to the cloud","breadcrumb":{"@id":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#primaryimage","url":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1650586080\/76_cloud-upload-widget\/76_cloud-upload-widget.png?_i=AA","contentUrl":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1650586080\/76_cloud-upload-widget\/76_cloud-upload-widget.png?_i=AA","width":2000,"height":1100},{"@type":"BreadcrumbList","@id":"https:\/\/cloudinary.com\/blog\/introducing_a_complete_and_modern_ui_widget_for_cloud_based_image_uploading#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/cloudinary.com\/blog\/"},{"@type":"ListItem","position":2,"name":"Introducing a complete and modern UI widget for cloud based image uploading"}]},{"@type":"WebSite","@id":"https:\/\/cloudinary.com\/blog\/#website","url":"https:\/\/cloudinary.com\/blog\/","name":"Cloudinary Blog","description":"","publisher":{"@id":"https:\/\/cloudinary.com\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/cloudinary.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/cloudinary.com\/blog\/#organization","name":"Cloudinary Blog","url":"https:\/\/cloudinary.com\/blog\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/cloudinary.com\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1649718331\/Web_Assets\/blog\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877.png?_i=AA","contentUrl":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1649718331\/Web_Assets\/blog\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877.png?_i=AA","width":312,"height":60,"caption":"Cloudinary Blog"},"image":{"@id":"https:\/\/cloudinary.com\/blog\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":""}]}},"jetpack_featured_media_url":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1650586080\/76_cloud-upload-widget\/76_cloud-upload-widget.png?_i=AA","_links":{"self":[{"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/posts\/21261","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/users\/41"}],"replies":[{"embeddable":true,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/comments?post=21261"}],"version-history":[{"count":2,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/posts\/21261\/revisions"}],"predecessor-version":[{"id":34432,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/posts\/21261\/revisions\/34432"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/media\/24065"}],"wp:attachment":[{"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/media?parent=21261"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/categories?post=21261"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/tags?post=21261"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}