dartlangeditorflutterflutter-appsflutter-examplesflutter-packageflutter-widgetquillquill-deltaquilljsreactquillrich-textrich-text-editorwysiwygwysiwyg-editor
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
255 lines
8.8 KiB
255 lines
8.8 KiB
3 years ago
|
# Flutter Quill Extensions
|
||
|
|
||
2 years ago
|
An extensions for [flutter_quill](https://pub.dev/packages/flutter_quill)
|
||
2 years ago
|
to support embedding widgets like images, formulas, videos, and more.
|
||
2 years ago
|
|
||
|
Check [Flutter Quill](https://github.com/singerdmx/flutter-quill) for details of use.
|
||
|
|
||
|
## Table of Contents
|
||
|
|
||
|
- [Flutter Quill Extensions](#flutter-quill-extensions)
|
||
|
- [Table of Contents](#table-of-contents)
|
||
|
- [About](#about)
|
||
|
- [Installation](#installation)
|
||
2 years ago
|
- [Platform Specific Configurations](#platform-specific-configurations)
|
||
2 years ago
|
- [Usage](#usage)
|
||
2 years ago
|
- [Embed Blocks](#embed-blocks)
|
||
2 years ago
|
- [Element properties](#element-properties)
|
||
|
- [Custom Element properties](#custom-element-properties)
|
||
2 years ago
|
- [Image Assets](#image-assets)
|
||
2 years ago
|
- [Drag and drop feature](#drag-and-drop-feature)
|
||
2 years ago
|
- [Features](#features)
|
||
|
- [Contributing](#contributing)
|
||
|
- [Acknowledgments](#acknowledgments)
|
||
|
|
||
|
|
||
|
## About
|
||
2 years ago
|
|
||
2 years ago
|
Flutter Quill is a rich editor text. It'd allow you to customize a lot of things,
|
||
|
it has custom embed builders that allow you to render custom widgets in the editor <br>
|
||
2 years ago
|
this is an extension to extend its functionalities by adding more features like images, videos, and more
|
||
2 years ago
|
|
||
|
## Installation
|
||
|
|
||
2 years ago
|
Before starting using this package, please make sure to install
|
||
|
[flutter_quill](https://github.com/singerdmx/flutter-quill) package first and follow
|
||
|
its usage instructions.
|
||
2 years ago
|
|
||
|
```yaml
|
||
|
dependencies:
|
||
|
flutter_quill_extensions: ^<latest-version-here>
|
||
|
```
|
||
|
|
||
2 years ago
|
<p align="center">OR</p>
|
||
|
|
||
|
```yaml
|
||
|
dependencies:
|
||
|
flutter_quill_extensions:
|
||
|
git: https://github.com/singerdmx/flutter-quill.git
|
||
|
path: flutter_quill_extensions
|
||
|
```
|
||
|
|
||
2 years ago
|
## Platform Specific Configurations
|
||
2 years ago
|
|
||
|
>
|
||
2 years ago
|
> 1. We are using the [`gal`](https://github.com/natsuk4ze/) plugin to save images.
|
||
2 years ago
|
> For this to work, you need to add the appropriate configurations
|
||
2 years ago
|
> See <https://github.com/natsuk4ze/gal#-get-started> to add the needed lines.
|
||
|
>
|
||
2 years ago
|
> 2. We also use [`image_picker`](https://pub.dev/packages/image_picker) plugin for picking images so please make sure to follow the instructions
|
||
2 years ago
|
>
|
||
2 years ago
|
> 3. For loading the image from the internet, we need the internet permission
|
||
|
> 1. For Android, you need to add some permissions in `AndroidManifest.xml`, Please follow this [link](https://developer.android.com/training/basics/network-ops/connecting) for more info, the internet permission is included by default only for debugging so you need to follow this link to add it in the release version too. you should allow loading images and videos only for the `https` protocol but if you want http too then you need to configure your Android application to accept `http` in the release mode, follow this [link](https://stackoverflow.com/questions/45940861/android-8-cleartext-http-traffic-not-permitted) for more info.
|
||
|
> 2. For macOS, you also need to include a key in your `Info.plist`, please follow this [link](https://stackoverflow.com/a/61201081/18519412) to add the required configurations
|
||
2 years ago
|
>
|
||
2 years ago
|
> The extension package also uses [image_picker](https://pub.dev/packages/image_picker) which also
|
||
2 years ago
|
> requires some configurations, follow this [link](https://pub.dev/packages/image_picker#installation). It's needed for Android, iOS, and macOS, we must inform you that you can't pick photos using the camera on a desktop so make sure to handle that if you plan on adding support for the desktop, this may change in the future, and for more info follow this [link](https://pub.dev/packages/image_picker#windows-macos-and-linux) <br>
|
||
2 years ago
|
>
|
||
3 years ago
|
|
||
|
## Usage
|
||
|
|
||
2 years ago
|
Before starting to use this package you must follow the [setup](#installation)
|
||
2 years ago
|
|
||
|
Set the `embedBuilders` and `embedToolbar` params in configurations of `QuillEditor` and `QuillToolbar` with the
|
||
3 years ago
|
values provided by this repository.
|
||
|
|
||
2 years ago
|
**Quill Toolbar**:
|
||
2 years ago
|
```dart
|
||
|
QuillToolbar(
|
||
|
configurations: QuillToolbarConfigurations(
|
||
2 years ago
|
embedButtons: FlutterQuillEmbeds.toolbarButtons(),
|
||
2 years ago
|
),
|
||
|
),
|
||
3 years ago
|
```
|
||
2 years ago
|
|
||
|
**Quill Editor**
|
||
|
```dart
|
||
|
Expanded(
|
||
|
child: QuillEditor.basic(
|
||
|
configurations: QuillEditorConfigurations(
|
||
2 years ago
|
embedBuilders: kIsWeb ? FlutterQuillEmbeds.editorWebBuilders() : FlutterQuillEmbeds.editorBuilders(),
|
||
2 years ago
|
),
|
||
|
),
|
||
|
)
|
||
3 years ago
|
```
|
||
|
|
||
2 years ago
|
## Embed Blocks
|
||
|
|
||
2 years ago
|
As of version [flutter_quill](https://pub.dev/packages/flutter_quill) 6.0, embed blocks are not provided by default as part of Flutter quill. Instead, it provides an interface for all the users to provide their implementations for embed blocks. Implementations for image, video, and formula embed blocks are proved in this package
|
||
2 years ago
|
|
||
2 years ago
|
The instructions for using the embed blocks are in the [Usage](#usage) section
|
||
2 years ago
|
|
||
2 years ago
|
### Element properties
|
||
2 years ago
|
|
||
2 years ago
|
Currently the library has limitied support for the image and video properties
|
||
|
and it supports only `width`, `height`, `margin`
|
||
2 years ago
|
|
||
|
```json
|
||
|
{
|
||
|
"insert": {
|
||
|
"image": "https://user-images.githubusercontent.com/122956/72955931-ccc07900-3d52-11ea-89b1-d468a6e2aa2b.png"
|
||
|
},
|
||
2 years ago
|
"attributes": {
|
||
|
"style":"width: 50px; height: 50px; margin: 10px;"
|
||
2 years ago
|
}
|
||
|
}
|
||
|
```
|
||
|
|
||
2 years ago
|
### Custom Element properties
|
||
|
|
||
|
Doesn't apply to official Quill JS
|
||
2 years ago
|
|
||
2 years ago
|
Define flutterAlignment` as follows:
|
||
2 years ago
|
|
||
|
```json
|
||
|
{
|
||
|
"insert": {
|
||
|
"image": "https://user-images.githubusercontent.com/122956/72955931-ccc07900-3d52-11ea-89b1-d468a6e2aa2b.png"
|
||
|
},
|
||
2 years ago
|
"attributes":{
|
||
|
"style":"flutterAlignment: topLeft"
|
||
2 years ago
|
}
|
||
|
}
|
||
|
```
|
||
|
|
||
2 years ago
|
This works for all platforms except Web
|
||
2 years ago
|
|
||
2 years ago
|
### Image Assets
|
||
|
|
||
|
If you want to use image assets in the Quill Editor, you need to make sure your assets folder is `assets` otherwise:
|
||
|
|
||
|
```dart
|
||
|
QuillEditor.basic(
|
||
|
configurations: const QuillEditorConfigurations(
|
||
|
// ...
|
||
|
sharedConfigurations: QuillSharedConfigurations(
|
||
|
extraConfigurations: {
|
||
|
QuillSharedExtensionsConfigurations.key:
|
||
|
QuillSharedExtensionsConfigurations(
|
||
|
assetsPrefix: 'your-assets-folder-name', // Defaults to `assets`
|
||
|
),
|
||
|
},
|
||
|
),
|
||
|
),
|
||
|
);
|
||
|
```
|
||
|
|
||
|
This info is needed by the package to check if it asset image to use the `AssetImage` provider
|
||
|
|
||
2 years ago
|
### Drag and drop feature
|
||
2 years ago
|
Currently, the drag-and-drop feature is not officially supported, but you can achieve this very easily in the following steps:
|
||
2 years ago
|
|
||
2 years ago
|
1. Drag and drop require native code, you can use any Flutter plugin you like, if you want a suggestion we recommend [desktop_drop](https://pub.dev/packages/desktop_drop), it was originally developed for desktop but it has support for the web as well as Android (that is not the case for iOS)
|
||
2 years ago
|
2. Add the dependency in your `pubspec.yaml` using the following command:
|
||
2 years ago
|
|
||
|
```yaml
|
||
|
flutter pub add desktop_drop
|
||
|
```
|
||
|
and import it with
|
||
|
```dart
|
||
|
import 'package:desktop_drop/desktop_drop.dart';
|
||
|
```
|
||
2 years ago
|
3. in the configurations of `QuillEditor`, use the `builder` to wrap the editor with `DropTarget` which comes from `desktop_drop`
|
||
|
|
||
2 years ago
|
```dart
|
||
|
import 'package:flutter_quill_extensions/flutter_quill_extensions.dart';
|
||
|
|
||
|
QuillEditor.basic(
|
||
|
configurations: QuillEditorConfigurations(
|
||
|
padding: const EdgeInsets.all(16),
|
||
|
builder: (context, rawEditor) {
|
||
|
return DropTarget(
|
||
|
onDragDone: _onDragDone,
|
||
|
child: rawEditor,
|
||
|
);
|
||
|
},
|
||
|
embedBuilders: kIsWeb
|
||
2 years ago
|
? FlutterQuillEmbeds.editorWebBuilders()
|
||
2 years ago
|
: FlutterQuillEmbeds.editorBuilders(),
|
||
|
),
|
||
|
)
|
||
|
```
|
||
|
4. Implement the `_onDragDone`, it depends on your use case but this is just a simple example
|
||
2 years ago
|
```dart
|
||
|
const List<String> imageFileExtensions = [
|
||
|
'.jpeg',
|
||
|
'.png',
|
||
|
'.jpg',
|
||
|
'.gif',
|
||
|
'.webp',
|
||
|
'.tif',
|
||
|
'.heic'
|
||
|
];
|
||
|
OnDragDoneCallback get _onDragDone {
|
||
|
return (details) {
|
||
|
final scaffoldMessenger = ScaffoldMessenger.of(context);
|
||
|
final file = details.files.first;
|
||
|
final isSupported =
|
||
|
imageFileExtensions.any((ext) => file.name.endsWith(ext));
|
||
|
if (!isSupported) {
|
||
|
scaffoldMessenger.showSnackBar(
|
||
|
SnackBar(
|
||
|
content: Text(
|
||
|
'Only images are supported right now: ${file.mimeType}, ${file.name}, ${file.path}, $imageFileExtensions',
|
||
|
),
|
||
|
),
|
||
|
);
|
||
|
return;
|
||
|
}
|
||
|
// To get this extension function please import flutter_quill_extensions
|
||
|
_controller.insertImageBlock(
|
||
|
imageSource: file.path,
|
||
|
);
|
||
|
scaffoldMessenger.showSnackBar(
|
||
|
const SnackBar(
|
||
|
content: Text('Image is inserted.'),
|
||
|
),
|
||
|
);
|
||
|
};
|
||
|
}
|
||
|
```
|
||
|
|
||
2 years ago
|
## Features
|
||
|
|
||
|
```markdown
|
||
|
## Features
|
||
|
|
||
2 years ago
|
— Easy to use and customizable
|
||
2 years ago
|
- Has the option to use a custom image provider for the images
|
||
2 years ago
|
- Useful utilities and widgets
|
||
2 years ago
|
- Handle different errors
|
||
|
```
|
||
|
|
||
2 years ago
|
Please notice that the saving image functionality is not supported on Linux yet.
|
||
|
|
||
2 years ago
|
## Contributing
|
||
|
|
||
|
We welcome contributions!
|
||
|
|
||
2 years ago
|
Please follow these guidelines when contributing to our project. See [CONTRIBUTING.md](../CONTRIBUTING.md) for more details.
|
||
2 years ago
|
|
||
|
## Acknowledgments
|
||
|
|
||
|
- Thanks to the [Flutter Team](https://flutter.dev/)
|
||
2 years ago
|
- Thanks to [flutter_quill](https://pub.dev/packages/flutter_quill)
|