jQuery Spellchecker - Redactor demo

This page shows how the spellchecker can be integrated into the Reactor editor:

Include the neccessary files:

<link rel="stylesheet" href="redactor/redactor.css" />
<link rel="stylesheet" href="jquery.spellchecker.css" />

<script src="js/jquery-1.8.2.min.js"></script>
<script src="js/jquery.spellchecker.js"></script>
<script src="redactor/redactor.min.js"></script>

Add the following CSS:

.redactor_toolbar li a.redactor_btn_spellchecker {
  background-image: url() !important;
  background-repeat: no-repeat;
  background-position: center center;
}

Create the spellchecker plugin and init the Reactor editor:

(function() {
  
  if (typeof window.RedactorPlugins === 'undefined') window.RedactorPlugins = {};
   
  window.RedactorPlugins.spellchecker = {
    init: function() {
      
      this.addBtn('spellchecker', 'Spellchecker', function(obj) {
        obj.toggle();
      });
    },
    create: function() {

      this.spellchecker = new $.SpellChecker(this.$editor, {
        lang: 'en',
        parser: 'html',
        webservice: {
          path: "../webservices/php/SpellChecker.php",
          driver: 'pspell'
        },
        suggestBox: {
          position: 'below'
        }
      });

      // Bind spellchecker handler functions
      this.spellchecker.on('check.success', function() {
        alert('There are no incorrectly spelt words.');
      });
    },
    toggle: function() {
      if (!this.spellchecker) {
        this.setBtnActive('spellchecker');
        this.create();
        this.spellchecker.check();
      } else {
        this.setBtnInactive('spellchecker');
        this.spellchecker.destroy();
        this.spellchecker = null;
      }
    }
  };
  
  // Init redactor
  $('.textarea').redactor({ 
    plugins: ['spellchecker']
  });

})();