antd-img-crop
Version:
An image cropper for Ant Design Upload
107 lines (80 loc) • 5.6 kB
Markdown
<div align="center">
Link in bio to **widgets**,
your online **home screen**. ➫ [🔗 kee.so](https://kee.so/)
</div>
---
# antd-img-crop
An image cropper for Ant Design [Upload](https://ant.design/components/upload/)
[](https://www.npmjs.com/package/antd-img-crop)
[](https://www.npmtrends.com/antd-img-crop)
[](https://bundlephobia.com/result?p=antd-img-crop)
[](https://github.com/nanxiaobei/antd-img-crop/blob/main/LICENSE)
[](https://github.com/nanxiaobei/antd-img-crop/blob/main/src/types.ts)
English | [简体中文](./README.zh-CN.md)
## Demo
[](https://codesandbox.io/p/sandbox/antd-img-crop-5x4j3r)
## Install
```sh
pnpm add antd-img-crop
# or
yarn add antd-img-crop
# or
npm i antd-img-crop
```
## Usage
```jsx harmony
import { Upload } from 'antd';
import ImgCrop from 'antd-img-crop';
const Demo = () => (
<ImgCrop>
<Upload>+ Add image</Upload>
</ImgCrop>
);
```
## Props
| Prop | Type | Default | Description |
| -------------- | ---------- | -------------- | -------------------------------------------------------------------------------- |
| quality | `number` | `0.4` | Cropped image quality, `0` to `1` |
| fillColor | `string` | `'white'` | Fill color for cropped image |
| zoomSlider | `boolean` | `true` | Enable zoom |
| rotationSlider | `boolean` | `false` | Enable rotation |
| aspectSlider | `boolean` | `false` | Enable aspect |
| showReset | `boolean` | `false` | Show reset button to reset zoom & rotation & aspect |
| resetText | `string` | `Reset` | Reset button text |
| aspect | `number` | `1 / 1` | Aspect of crop area , `width / height` |
| minZoom | `number` | `1` | Minimum zoom |
| maxZoom | `number` | `3` | Maximum zoom |
| minAspect | `number` | `0.5` | Minimum aspect |
| maxAspect | `number` | `2` | Maximum aspect |
| cropShape | `string` | `'rect'` | Shape of crop area, `'rect'` or `'round'` |
| showGrid | `boolean` | `false` | Show grid of crop area (third-lines) |
| cropperProps | `object` | - | [react-easy-crop] props (\* existing props cannot be overridden) |
| modalClassName | `string` | `''` | Modal classname |
| modalTitle | `string` | `'Edit image'` | Modal title |
| modalWidth | `number` | `string` | Modal width |
| modalOk | `string` | | Ok button text |
| modalCancel | `string` | | Cancel button text |
| onModalOk | `function` | - | Callback of click ok button |
| onModalCancel | `function` | - | Callback of click cancel button (or modal mask & top right "x") |
| modalProps | `object` | | [Ant Design Modal] props (\* existing props cannot be overridden) |
| beforeCrop | `function` | - | Callback before crop modal, if return `false` or `reject()`, modal will not open |
## FAQ
### `ConfigProvider` not work?
Try to set `libraryDirectory`(`'es'` or `'lib'`) to `babel-plugin-import` config, see which one will work.
```js
module.exports = {
plugins: [
['import', { libraryName: 'antd', libraryDirectory: 'es', style: true }],
],
};
```
### No style? (only `antd<=v4`)
If you use `antd<=v4` + `babel-plugin-import`, and no `Modal` or `Slider` were imported, please import these styles manually:
```js
import 'antd/es/modal/style';
import 'antd/es/slider/style';
```
## License
[MIT License](https://github.com/nanxiaobei/antd-img-crop/blob/main/LICENSE) (c) [nanxiaobei](https://lee.so/)
[react-easy-crop]: https://github.com/ValentinH/react-easy-crop#props
[Ant Design Modal]: https://ant.design/components/modal#api