Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kensnyder/quill-image-resize-module
A module for Quill rich text editor to allow images to be resized.
https://github.com/kensnyder/quill-image-resize-module
Last synced: 3 months ago
JSON representation
A module for Quill rich text editor to allow images to be resized.
- Host: GitHub
- URL: https://github.com/kensnyder/quill-image-resize-module
- Owner: kensnyder
- License: mit
- Created: 2017-03-25T22:53:51.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2023-10-16T12:40:41.000Z (over 1 year ago)
- Last Synced: 2024-04-15T09:18:20.223Z (9 months ago)
- Language: JavaScript
- Size: 269 KB
- Stars: 456
- Watchers: 13
- Forks: 447
- Open Issues: 113
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-quill - quill-image-resize-module - A module to allow images to be resized (not maintained: use quill-blot-formatter instead) (Uncategorized / Uncategorized)
README
# Quill ImageResize Module
A module for Quill rich text editor to allow images to be resized.
Also see [quill-image-drop-module](https://github.com/kensnyder/quill-image-drop-module),
a module that enables copy-paste and drag/drop for Quill.## Demo
[Plunker](https://plnkr.co/edit/gq708AOrSBOWSlHcFslG?p=preview)
## Usage
### Webpack/ES6
```javascript
import Quill from 'quill';
import { ImageResize } from 'quill-image-resize-module';Quill.register('modules/imageResize', ImageResize);
const quill = new Quill(editor, {
// ...
modules: {
// ...
imageResize: {
// See optional "config" below
}
}
});
```### Script Tag
Copy image-resize.min.js into your web root or include from node_modules
```html
```
```javascript
var quill = new Quill(editor, {
// ...
modules: {
// ...
ImageResize: {
// See optional "config" below
}
}
});
```### Config
For the default experience, pass an empty object, like so:
```javascript
var quill = new Quill(editor, {
// ...
modules: {
// ...
ImageResize: {}
}
});
```Functionality is broken down into modules, which can be mixed and matched as you like. For example,
the default is to include all modules:```javascript
const quill = new Quill(editor, {
// ...
modules: {
// ...
ImageResize: {
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:
```javascript
var quill = new Quill(editor, {
// ...
modules: {
// ...
ImageResize: {
// ...
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:
```javascript
var quill = new Quill(editor, {
// ...
modules: {
// ...
ImageResize: {
// ...
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:
```javascript
var quill = new Quill(editor, {
// ...
modules: {
// ...
ImageResize: {
// ...
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,
```javascript
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: {
// ...
ImageResize: {
modules: [ MyModule, Resize ],
// ...
}
}
});
```