-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #3 from evosys21/feature/dev-v1.0.0
Feature/dev v1.0.0
- Loading branch information
Showing
252 changed files
with
615 additions
and
694 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,83 +1,129 @@ | ||
# Fpdf, TCPDF, tFpdf - Advanced Multicell and Table | ||
<h1>Fpdf, TCPDF, tFpdf - Advanced Multicell and Table</h1> | ||
|
||
`evosys21/pdflib` is a collection of PHP classes facilitating developers to create [Advanced Multicells]() and [Tables]() in [FPDF](http://www.fpdf.org), [TCPDF](https://github.com/tecnickcom/TCPDF) or | ||
[tFPDF](http://fpdf.org/en/script/script92.php). | ||
[data:image/s3,"s3://crabby-images/f7281/f72815beec1be31ef94fd986faf5615d8b4fcc28" alt="Build status"](https://github.com/evosys21/pdflib/actions) | ||
[data:image/s3,"s3://crabby-images/841cb/841cb5645b78b73eab3f7d302ed26e79709e6a2d" alt="Latest Stable Version"](https://packagist.org/packages/evosys21/phplib) | ||
|
||
<!-- TOC --> | ||
* [Overview](#overview) | ||
* [Advanced Multicell](#advanced-multicell) | ||
* [Features](#features) | ||
* [Examples](#examples) | ||
* [Usage and documentation](#usage-and-documentation) | ||
* [Advanced table](#advanced-table) | ||
* [Features](#features-1) | ||
* [Examples](#examples-1) | ||
* [Usage and documentation](#usage-and-documentation-1) | ||
* [FAQ](#faq) | ||
* [Why use the custom pdf class instead of `FPDF/TCPDF/tFPDF`](#why-use-the-custom-pdf-class-instead-of-fpdftcpdftfpdf) | ||
* [Where do I report issues?](#where-do-i-report-issues) | ||
* [Contribute](#contribute) | ||
* [License](#license) | ||
<!-- TOC --> | ||
|
||
[data:image/s3,"s3://crabby-images/f7281/f72815beec1be31ef94fd986faf5615d8b4fcc28" alt="Build status"](https://github.com/evosys21/pdflib/actions) [data:image/s3,"s3://crabby-images/841cb/841cb5645b78b73eab3f7d302ed26e79709e6a2d" alt="Latest Stable Version"](https://packagist.org/packages/evosys21/phplib) | ||
--- | ||
|
||
## Contents | ||
## Overview | ||
|
||
<!-- TOC --> | ||
* [Fpdf, TCPDF, tFpdf - Advanced Multicell and Table](#fpdf-tcpdf-tfpdf---advanced-multicell-and-table-) | ||
* [Contents](#contents) | ||
* [Installation with Composer](#installation-with-composer) | ||
* [Example and Documentation](#example-and-documentation) | ||
* [Advanced Multicell](#advanced-multicell) | ||
* [Advanced table](#advanced-table) | ||
* [FAQ 🔮](#faq-) | ||
* [Where do I report issues?](#where-do-i-report-issues) | ||
* [Contribute 🚀](#contribute-) | ||
* [License 📗](#license-) | ||
<!-- TOC --> | ||
`evosys21/pdflib` is a collection of PHP classes facilitating developers to create [Advanced Multicells](#advanced-multicell) and [Tables](#advanced-table) in [FPDF](http://www.fpdf.org), [TCPDF](https://github.com/tecnickcom/TCPDF), or | ||
[tFPDF](http://fpdf.org/en/script/script92.php). | ||
|
||
*** | ||
## Advanced Multicell | ||
|
||
## Installation with Composer | ||
This addon class allows the creation of an **Advanced Multicell for FPDF/TCPDF/tFPDF**, which uses as input a TAG-based formatted | ||
string instead of a simple string. The use of tags allows changing the font, style (bold, italic, underline), | ||
size, and color of characters and many other features. | ||
|
||
`evosys21/pdflib` can be used with FPDF, TCPDF or tFPDF. Because of this we haven't added a fixed dependency in the main composer.json file. You need to add the dependency to the PDF generation library of your choice yourself. | ||
The function is similar to the Multicell function in the TCPDF base class with extended parameters. | ||
|
||
To use `evosys21/pdflib` with FPDF, install it via Composer: | ||
### Features | ||
|
||
```shell | ||
composer require evosys21/pdflib | ||
composer require setasign/fpdf | ||
``` | ||
- Text can be **aligned**, **centered**, or **justified**. | ||
- Different **fonts**, **sizes**, **styles**, and **colors** can be used. | ||
- The cell block can be **framed**, and the **background** can be **colored**. | ||
- **Links** can be used in any tag. | ||
- **TAB** spaces (`\t`) can be used. | ||
- Variable vertical positions can be used for **subscripts** or **superscripts**. | ||
- **Cell padding** (left, right, top, bottom) can be adjusted. | ||
- Controlled **tag sizes** can be used. | ||
|
||
### Examples | ||
|
||
If you want to use TCPDF: | ||
| | Multicell Example #1 - Overview | multicell Example #1 - Overview | | ||
|---------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------| | ||
| Code | [example-multicell-1-overview.php](examples/Tcpdf/example-multicell-1-overview.php) | [example-multicell-6-shrinking.php](examples/Tcpdf/example-multicell-6-shrinking.php) | | ||
| Preview | [<img src="examples/Tcpdf/example-multicell-1-overview.png" height="300">](examples/Tcpdf/example-multicell-1-overview.pdf) | [<img src="examples/Tcpdf/example-multicell-6-shrinking.png" height="300">](examples/Tcpdf/example-multicell-6-shrinking.pdf) | | ||
| Pdf | [example-multicell-1-overview.pdf](examples/Tcpdf/example-multicell-1-overview.pdf) | [example-multicell-1-overview.pdf](examples/Tcpdf/example-multicell-1-overview.pdf) | | | ||
|
||
```shell | ||
composer require evosys21/pdflib | ||
composer require tecnickcom/tcpdf | ||
``` | ||
Check the [examples](examples) folder for more examples with preview and the associated code. | ||
|
||
If you want to use tFPDF: | ||
### Usage and documentation | ||
|
||
```shell | ||
composer require evosys21/pdflib | ||
composer require setasign/tfpdf | ||
``` | ||
[Click here](docs/multicell.md) for the end-user documentation for Advanced Multicell. | ||
|
||
## Example and Documentation | ||
## Advanced table | ||
|
||
### Advanced Multicell | ||
This addon class allows creation of an **Advanced Table for FPDF/TCPDF/tFPDF** in the pdf document in a very simple way. | ||
|
||
A full end-user documentation for Advanced Multicell is available [here](docs/multicell.md). | ||
### Features | ||
|
||
### Advanced table | ||
- Every table cell supports [Advanced Multicell](#advanced-multicell) functionality. | ||
- Table cells can be aligned both **vertically** and **horizontally**. | ||
- Cells can span multiple **columns** and **rows**. | ||
- The table automatically splits on **page breaks**. | ||
- The **header** is automatically added to every new page. | ||
- Default properties for **headers** and **rows** can be set but can be overridden per individual cell. | ||
- **Advanced cell-splitting mode** is available. | ||
- The table supports **transparency**. | ||
- **Images** can be inserted into table cells. | ||
|
||
A full end-user documentation for Advanced Table is available [here](docs/table.md). | ||
|
||
## FAQ 🔮 | ||
### Examples | ||
|
||
| | Table Example #1 - Overview | Table Example #1 - Overview | | ||
|---------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------| | ||
| Code | [example-table-1-overview.php](examples/Tcpdf/example-table-1-overview.php) | [example-table-2-overview.php](examples/Tcpdf/example-table-2-overview.php) | | ||
| Preview | [<img src="examples/Tcpdf/example-table-1-overview.png" height="300">](examples/Tcpdf/example-table-1-overview.pdf) | [<img src="examples/Tcpdf/example-table-2-overview.png" height="300">](examples/Tcpdf/example-table-2-overview.pdf) | | ||
| Pdf | [example-table-1-overview.pdf](examples/Tcpdf/example-table-1-overview.pdf) | [example-table-1-overview.pdf](examples/Tcpdf/example-table-1-overview.pdf) | | | ||
|
||
### Usage and documentation | ||
|
||
[Click here](docs/table.md) for the end-user documentation for Advanced Table. | ||
|
||
## FAQ | ||
|
||
### Why use the custom pdf class instead of `FPDF/TCPDF/tFPDF` | ||
|
||
The custom `EvoSys21\PdfLib\Fpdf\Pdf` object is used instead of `FPDF` because `FPDF`'s private/protected properties, | ||
like widths, margins, and fonts, need to be accessed to implement add-ons. | ||
Since `FPDF` doesn't provide setters/getters for these properties, the class was extended to access them. | ||
|
||
The same is valid for all 3 pdf classes: `FPDF/TCPDF/tFPDF`. | ||
|
||
For more details see: | ||
- [src/Fpdf/Pdf.php](src/Fpdf/Pdf.php) | ||
- [src/Tcpdf/Pdf.php](src/Tcpdf/Pdf.php) | ||
- [src/Tfpdf/Pdf.php](src/Tfpdf/Pdf.php) | ||
|
||
### Where do I report issues? | ||
|
||
If something is not working as expected, please check or open an | ||
If something is not working as expected, please check or open an | ||
[issue](https://github.com/evosys21/pdflib/issues). | ||
|
||
If you would like to discuss your use case or ask a general question, please use the discussions board: | ||
[discussions](https://github.com/evosys21/pdflib/discussions). | ||
|
||
## Contribute 🚀 | ||
## Contribute | ||
|
||
We welcome contributors to the project. | ||
|
||
- Before opening a pull request, please create an issue to | ||
[discuss the scope of your proposal](https://github.com/evosys21/pdflib/issues). | ||
- Never send PR to `main` unless you want to contribute to the development | ||
version of the client (`main` represents the next major version). | ||
- Each PR should include a **unit test** using [PHPUnit](https://phpunit.de/). | ||
|
||
Thanks in advance for your contribution! :heart: | ||
|
||
## License 📗 | ||
## License | ||
|
||
MIT License. For more information, please see the [LICENSE](LICENSE.TXT) file. |
File renamed without changes
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
<?php | ||
|
||
use evosys21\PdfLib\Table; | ||
use EvoSys21\PdfLib\Table; | ||
|
||
if (!isset($splitMode)) { | ||
$splitMode = true; | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
<?php | ||
|
||
use evosys21\PdfLib\Table; | ||
use EvoSys21\PdfLib\Table; | ||
global $pdf; | ||
|
||
if (!isset($splitMode)) { | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
<?php | ||
|
||
use evosys21\PdfLib\Table; | ||
use EvoSys21\PdfLib\Table; | ||
|
||
if (!isset($splitMode)) { | ||
$splitMode = true; | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.