Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/elrizwiraswara/webcontent_converter_plus

This plugin was made for developer to convert any webcontent, web uri to image bitmap or pdf file. This plugin use WebView on android, WKWebView on Ios and chromium for desktop support.
https://github.com/elrizwiraswara/webcontent_converter_plus

converter html-converter html-to-pdf webcontent-converter

Last synced: 5 days ago
JSON representation

This plugin was made for developer to convert any webcontent, web uri to image bitmap or pdf file. This plugin use WebView on android, WKWebView on Ios and chromium for desktop support.

Awesome Lists containing this project

README

        

# webcontent_converter_plus

This is a fork of [webcontent_converter](https://github.com/kechankrisna/webcontent_converter) with unnecessary code and dependencies removed.

This plugin was made for developer to convert any webcontent, web uri to image bitmap or pdf file. This plugin use WebView on android, WKWebView on Ios and chromium for desktop support. This plugin was test for android, ios and desktop.

## Support :

- ✓ Android Minimum SDK Version: 21
- ✓ IOS minimum target Version: 11
- ✓ Deskop linux, windows, macos

| Android | IOS | Desktop|
| --- | --- | --- |
| WebView | WkWebView | Puppeteer |

## Methods

`CONVERT TO IMAGE`

- filePathToImage(String path, double duration) : path is asset path and duration is delay time. This function will return Uint8List Image

Example:

```
var bytes = await WebcontentConverter.filePathToImage(path: "assets/receipt.html");
if (bytes.length > 0) _saveFile(bytes);
```

- webUriToImage(String uri, double duration) : uri is web uri(url) and duration is delay time. This function will return Uint8List Image

Example:

```
var bytes = await WebcontentConverter.webUriToImage(
uri: "http://127.0.0.1:5500/example/assets/receipt.html");
if (bytes.length > 0) _saveFile(bytes);
```

- contentToImage(String content, double duration) : content is html or web content and duration is delay time. This function will return Uint8List Image

Example:

```
final content = Demo.getReceiptContent();
var bytes = await WebcontentConverter.contentToImage(content: content);
if (bytes.length > 0) _saveFile(bytes);
```

`*** Purpose: The three above functions will help developer to get screenshot of html content as Uint8List Image and push it to esc printer`

`CONVERT TO PDF`

- filePathToPdf(String path, double duration, String savedPath, PdfMargins margins, PaperFormat format )

Example:

```
var dir = await getApplicationDocumentsDirectory();
var savedPath = join(dir.path, "sample.pdf");
var result = await WebcontentConverter.filePathToPdf(
path: "assets/invoice.html",
savedPath: savedPath,
format: PaperFormat.a4,
margins: PdfMargins.px(top: 35, bottom: 35, right: 35, left: 35),
);
```

- webUriToPdf(String uri, double duration, String savedPath, PdfMargins margins, PaperFormat format )

Example:

```
var dir = await getApplicationDocumentsDirectory();
var savedPath = join(dir.path, "sample.pdf");
var result = await WebcontentConverter.webUriToPdf(
uri: "http://127.0.0.1:5500/example/assets/invoice.html",
savedPath: savedPath,
format: PaperFormat.a4,
margins: PdfMargins.px(top: 35, bottom: 35, right: 35, left: 35),
);
```

- contentToPDF(String content, double duration, String savedPath, PdfMargins margins, PaperFormat format )

Example:

```
final content = Demo.getInvoiceContent();
var dir = await getApplicationDocumentsDirectory();
var savedPath = join(dir.path, "sample.pdf");
var result = await WebcontentConverter.contentToPDF(
content: content,
savedPath: savedPath,
format: PaperFormat.a4,
margins: PdfMargins.px(top: 55, bottom: 55, right: 55, left: 55),
);
```

`*** Purpose: The three above functions will help developer to get pdf printed file of html content as. It will return a savedPath when saved successful otherwise null`

### Desktop top
```
flutter pub run webcontent_converter:install_desktop download
```
This cli will download the chrome version base on your current operating system and save into path assets/.local-chromium/ directory as a zip file

```
flutter pub run webcontent_converter:install_desktop extract
```
This cli will extract the chrome zip file based on your current operating system and save into path assets/.local-chromium/ directory

add this code into your flutter app will help you to ship chromium zip in asset directory into production build for desktop deployment
```dart
var executablePath = await ChromeDesktopDirectoryHelper.saveChromeFromAssetToApp();
WebViewHelper.customBrowserPath = [executablePath];
await WebcontentConverter.ensureInitialized(executablePath: executablePath);
```