Skip to content

KillerCodeMonkey/quill-image-resizor

 
 

Repository files navigation

Quill ImageResizor Module

A module for Quill rich text editor to allow images to be resized.

Fork and adaptions for quill 2 of quill-image-resize-module.

Demo

  • checkout / download
  • npm i && npm run build
  • open demo.html
  • demo page

Usage

Webpack/ES6

import Quill from 'quill'
import { ImageResizor } from 'quill-image-resizor'

// Import to get Quill working, when Quill is not coming from window.Quill!
ImageResizor.Quill = Quill
Quill.register('modules/imageResizor', ImageResizor)

const quill = new Quill(editor, {
  // ...
  modules: {
    // ...
    imageResizor: {
      // See optional "config" below
    }
  }
})

Script Tag

Copy image-resize.min.js into your web root or include from node_modules

<script src="/node_modules/quill-image-resizor/ImageResizor.js"></script>
var quill = new Quill(editor, {
  // ...
  modules: {
    // ...
    ImageResizor: {
      // See optional "config" below
    }
  }
})

Config

For the default experience, pass an empty object, like so:

var quill = new Quill(editor, {
  // ...
  modules: {
    // ...
    ImageResizor: {}
  }
})

Functionality is broken down into modules, which can be mixed and matched as you like. For example, the default is to include all modules:

const quill = new Quill(editor, {
  // ...
  modules: {
    // ...
    ImageResizor: {
      modules: ['Resize', 'DisplaySize', 'Toolbar']
    }
  }
})

Each module is described below.

Resize - Resize the image

Adds handles to the image's corners which can be dragged with the mouse to resize the image.

The look and feel can be controlled with options:

var quill = new Quill(editor, {
  // ...
  modules: {
    // ...
    ImageResizor: {
      // ...
      handleStyles: {
        backgroundColor: 'black',
        border: 'none',
        color: white
        // other camelCase styles for size display
      }
    }
  }
})

DisplaySize - Display pixel size

Shows the size of the image in pixels near the bottom right of the image.

The look and feel can be controlled with options:

var quill = new Quill(editor, {
  // ...
  modules: {
    // ...
    ImageResizor: {
      // ...
      displayStyles: {
        backgroundColor: 'black',
        border: 'none',
        color: white
        // other camelCase styles for size display
      }
    }
  }
})

Toolbar - Image alignment tools

Displays a toolbar below the image, where the user can select an alignment for the image.

The look and feel can be controlled with options:

var quill = new Quill(editor, {
  // ...
  modules: {
    // ...
    ImageResizor: {
      // ...
      toolbarStyles: {
        backgroundColor: 'black',
        border: 'none',
        color: white
        // other camelCase styles for size display
      },
      toolbarButtonStyles: {
        // ...
      },
      toolbarButtonSvgStyles: {
        // ...
      }
    }
  }
})

BaseModule - Include your own custom module

You can write your own module by extending the BaseModule class, and then including it in the module setup.

For example,

import { Resize, BaseModule } from 'quill-image-resize-module'

class MyModule extends BaseModule {
  // See src/modules/BaseModule.js for documentation on the various lifecycle callbacks
}

var quill = new Quill(editor, {
  // ...
  modules: {
    // ...
    ImageResizor: {
      modules: [MyModule, Resize]
      // ...
    }
  }
})

About

A module for Quill rich text editor to allow images to be resized.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 81.8%
  • HTML 10.9%
  • JavaScript 7.3%