PdfExportService   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 44
Duplicated Lines 0 %

Importance

Changes 4
Bugs 0 Features 0
Metric Value
eloc 5
c 4
b 0
f 0
dl 0
loc 44
rs 10
wmc 4

4 Methods

Rating   Name   Duplication   Size   Complexity  
A fromView() 0 3 1
A fromHtml() 0 3 1
A fromViewModel() 0 3 1
A fromHtmlFile() 0 3 1
1
<?php
2
3
namespace Sfneal\ViewExport\Pdf;
4
5
use Illuminate\Contracts\View\View;
6
use Sfneal\ViewExport\Pdf\Utils\PdfRenderer;
7
use Sfneal\ViewExport\Support\Adapters\ExportService;
8
use Sfneal\ViewExport\Support\Interfaces\FromHtml;
9
use Sfneal\ViewModels\ViewModel;
10
11
class PdfExportService extends ExportService implements FromHtml
12
{
13
    /**
14
     * Provide a view to build the PDF from.
15
     *
16
     * @param View $view
17
     * @return PdfRenderer
18
     */
19
    public static function fromView(View $view): PdfRenderer
20
    {
21
        return new PdfRenderer($view->render());
0 ignored issues
show
Bug introduced by
It seems like $view->render() can also be of type array; however, parameter $content of Sfneal\ViewExport\Pdf\Ut...Renderer::__construct() does only seem to accept string, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

21
        return new PdfRenderer(/** @scrutinizer ignore-type */ $view->render());
Loading history...
22
    }
23
24
    /**
25
     * Provide a view to build the PDF from.
26
     *
27
     * @param ViewModel $viewModel
28
     * @return PdfRenderer
29
     */
30
    public static function fromViewModel(ViewModel $viewModel): PdfRenderer
31
    {
32
        return new PdfRenderer($viewModel->renderNoCache());
33
    }
34
35
    /**
36
     * Provide an HTML string to build the PDF from.
37
     *
38
     * @param string $html
39
     * @return PdfRenderer
40
     */
41
    public static function fromHtml(string $html): PdfRenderer
42
    {
43
        return new PdfRenderer($html);
44
    }
45
46
    /**
47
     * Provide an HTML path or URL to build the PDF from.
48
     *
49
     * @param string $path
50
     * @return PdfRenderer
51
     */
52
    public static function fromHtmlFile(string $path): PdfRenderer
53
    {
54
        return new PdfRenderer(file_get_contents($path));
55
    }
56
}
57