Days
Hours
Minutes
Seconds
x

Froala Editor v4.2.0 is Here LEARN MORE

Skip to content

Node.JS Image Server Delete

How it works

  1. Your code intercepts the image being removed from the javascript editor.
  2. When an image is removed, a request is made to the server telling it to delete the image from disk.
  3. Once the request hits the server, it deletes the image.

Jump to Complete Example

Intercept image being removed

When an image is being removed from the javascript editor, it triggers two events: froalaEditor.image.beforeRemove and froalaEditor.image.removed. You could use either of them to delete the image from server, however we recommend the second one because at that point you're sure that the image was removed from the editable area.

Send request to the server

There is no built-in feature that makes the request to the server, however it can easily be done using an AJAX request.

<script>
  $(function() {
    // Catch the image being removed.
    $('.selector').on('froalaEditor.image.removed', function (e, editor, $img) {
      $.ajax({
        // Request method.
        method: 'POST',

        // Request URL.
        url: '/delete_image',

        // Request params.
        data: {
          src: $img.attr('src')
        }
      })
      .done (function (data) {
        console.log ('Image was deleted');
      })
      .fail (function (err) {
        console.log ('Image delete problem: ' + JSON.stringify(err));
      })
    });
  });
</script>

Delete the image

The server implementation is responsible for receiving the request and handling it appropriately. Using the code from the previous step, makes the image path available in the body of the request: request.body.src. The FroalaEditor.Image.delete() method from the Node.JS SDK is expecting the path of the image to remove from disk.

Note: The path of the image is relative to the root of your application.

FroalaEditor.Image.delete(req.body.src, function(err) { ... });

Complete Example

<script>
  $(function() {
    // Catch the image being removed.
    $('.selector').on('froalaEditor.image.removed', function (e, editor, $img) {
      $.ajax({
        // Request method.
        method: 'POST',

        // Request URL.
        url: '/delete_image',

        // Request params.
        data: {
          src: $img.attr('src')
        }
      })
      .done (function (data) {
        console.log ('Image was deleted');
      })
      .fail (function (err) {
        console.log ('Image delete problem: ' + JSON.stringify(err));
      })
    });
  });
</script>
var express = require('express');
var app = express();
var bodyParser = require('body-parser')
var path = require('path');
var fs = require('fs');
var FroalaEditor = require('PATH_TO_FROALA_SDK/lib/froalaEditor.js');

app.use(express.static(__dirname + '/'));
app.use('/bower_components',  express.static(path.join(__dirname, '../bower_components')));
app.use(bodyParser.urlencoded({ extended: false }));

// Listen to the delete request.
app.post('/delete_image', function (req, res) {

  // Do delete.
  FroalaEditor.Image.delete(req.body.src, function(err) {

    if (err) {
      return res.status(404).end(JSON.stringify(err));
    }

    return res.end();
  });
});
[class^="wpforms-"]
[class^="wpforms-"]
[bws_google_captcha]
<div class="gglcptch gglcptch_v2"><div id="gglcptch_recaptcha_116343343" class="gglcptch_recaptcha"></div> <noscript> <div style="width: 302px;"> <div style="width: 302px; height: 422px; position: relative;"> <div style="width: 302px; height: 422px; position: absolute;"> <iframe src="https://www.google.com/recaptcha/api/fallback?k=6Ld6lNoUAAAAAM626LfCOrnkBFJtYZAKESFCjgv_" frameborder="0" scrolling="no" style="width: 302px; height:422px; border-style: none;"></iframe> </div> </div> <div style="border-style: none; bottom: 12px; left: 25px; margin: 0px; padding: 0px; right: 25px; background: #f9f9f9; border: 1px solid #c1c1c1; border-radius: 3px; height: 60px; width: 300px;"> <textarea id="g-recaptcha-response" name="g-recaptcha-response" class="g-recaptcha-response" style="width: 250px !important; height: 40px !important; border: 1px solid #c1c1c1 !important; margin: 10px 25px !important; padding: 0px !important; resize: none !important;"></textarea> </div> </div> </noscript></div>
[class^="wpforms-"]
[class^="wpforms-"]
[bws_google_captcha]
<div class="gglcptch gglcptch_v2"><div id="gglcptch_recaptcha_1162530362" class="gglcptch_recaptcha"></div> <noscript> <div style="width: 302px;"> <div style="width: 302px; height: 422px; position: relative;"> <div style="width: 302px; height: 422px; position: absolute;"> <iframe src="https://www.google.com/recaptcha/api/fallback?k=6Ld6lNoUAAAAAM626LfCOrnkBFJtYZAKESFCjgv_" frameborder="0" scrolling="no" style="width: 302px; height:422px; border-style: none;"></iframe> </div> </div> <div style="border-style: none; bottom: 12px; left: 25px; margin: 0px; padding: 0px; right: 25px; background: #f9f9f9; border: 1px solid #c1c1c1; border-radius: 3px; height: 60px; width: 300px;"> <textarea id="g-recaptcha-response" name="g-recaptcha-response" class="g-recaptcha-response" style="width: 250px !important; height: 40px !important; border: 1px solid #c1c1c1 !important; margin: 10px 25px !important; padding: 0px !important; resize: none !important;"></textarea> </div> </div> </noscript></div>
[class^="wpforms-"]
[class^="wpforms-"]
[bws_google_captcha]
<div class="gglcptch gglcptch_v2"><div id="gglcptch_recaptcha_1273685273" class="gglcptch_recaptcha"></div> <noscript> <div style="width: 302px;"> <div style="width: 302px; height: 422px; position: relative;"> <div style="width: 302px; height: 422px; position: absolute;"> <iframe src="https://www.google.com/recaptcha/api/fallback?k=6Ld6lNoUAAAAAM626LfCOrnkBFJtYZAKESFCjgv_" frameborder="0" scrolling="no" style="width: 302px; height:422px; border-style: none;"></iframe> </div> </div> <div style="border-style: none; bottom: 12px; left: 25px; margin: 0px; padding: 0px; right: 25px; background: #f9f9f9; border: 1px solid #c1c1c1; border-radius: 3px; height: 60px; width: 300px;"> <textarea id="g-recaptcha-response" name="g-recaptcha-response" class="g-recaptcha-response" style="width: 250px !important; height: 40px !important; border: 1px solid #c1c1c1 !important; margin: 10px 25px !important; padding: 0px !important; resize: none !important;"></textarea> </div> </div> </noscript></div>