mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-11-03 19:30:07 -05:00 
			
		
		
		
	Playful
This commit is contained in:
		
							parent
							
								
									0c6b661f5e
								
							
						
					
					
						commit
						4caa1f95b1
					
				@ -909,4 +909,110 @@ class PdfMakerDesignsTest extends TestCase
 | 
			
		||||
 | 
			
		||||
        info($maker->getCompiledHTML(true));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function testPlayful()
 | 
			
		||||
    {
 | 
			
		||||
        $state = [
 | 
			
		||||
            'template' => [
 | 
			
		||||
                'entity-details' => [
 | 
			
		||||
                    'id' => 'entity-details',
 | 
			
		||||
                    'elements' => [
 | 
			
		||||
                        ['element' => 'tr', 'content' => '', 'elements' => [
 | 
			
		||||
                            ['element' => 'th', 'content' => '$entity-number-label', 'properties' => ['class' => 'text-left pr-4 font-normal']],
 | 
			
		||||
                            ['element' => 'th', 'content' => '$entity-number', 'properties' => ['class' => 'text-left pr-4 font-medium']],
 | 
			
		||||
                        ]],
 | 
			
		||||
                        ['element' => 'tr', 'content' => '', 'elements' => [
 | 
			
		||||
                            ['element' => 'th', 'content' => '$entity-date-label', 'properties' => ['class' => 'text-left pr-4 font-normal']],
 | 
			
		||||
                            ['element' => 'th', 'content' => '$entity-date', 'properties' => ['class' => 'text-left pr-4 font-normal']],
 | 
			
		||||
                        ]],
 | 
			
		||||
                        ['element' => 'tr', 'content' => '', 'elements' => [
 | 
			
		||||
                            ['element' => 'th', 'content' => '$due-date-label', 'properties' => ['class' => 'text-left pr-4 font-normal']],
 | 
			
		||||
                            ['element' => 'th', 'content' => '$due-date', 'properties' => ['class' => 'text-left pr-4 font-normal']],
 | 
			
		||||
                        ]],
 | 
			
		||||
                        ['element' => 'tr', 'content' => '', 'elements' => [
 | 
			
		||||
                            ['element' => 'th', 'content' => '$balance-due-label', 'properties' => ['class' => 'text-left pr-4 font-normal']],
 | 
			
		||||
                            ['element' => 'th', 'content' => '$balance-due', 'properties' => ['class' => 'text-left pr-4 font-normal']],
 | 
			
		||||
                        ]],
 | 
			
		||||
                    ],
 | 
			
		||||
                ],
 | 
			
		||||
                'client-details' => [
 | 
			
		||||
                    'id' => 'client-details',
 | 
			
		||||
                    'elements' => [
 | 
			
		||||
                        ['element' => 'p', 'content' => 'Winterfield Medical Supply', 'properties' => ['class' => 'text-red-700']],
 | 
			
		||||
                        ['element' => 'p', 'content' => '65 Medical Complex Rd., D98'],
 | 
			
		||||
                        ['element' => 'p', 'content' => 'Atlanta, GA 22546'],
 | 
			
		||||
                        ['element' => 'p', 'content' => 'United States'],
 | 
			
		||||
                        ['element' => 'p', 'content' => 'demo@invoiceninja.com'],
 | 
			
		||||
                    ],
 | 
			
		||||
                ],
 | 
			
		||||
                'company-details' => [
 | 
			
		||||
                    'id' => 'company-details',
 | 
			
		||||
                    'elements' => [
 | 
			
		||||
                        ['element' => 'p', 'content' => 'Ninja Sample', 'properties' => ['class' => 'text-red-700']],
 | 
			
		||||
                        ['element' => 'p', 'content' => 'contact@invoiceninja.com'],
 | 
			
		||||
                        ['element' => 'p', 'content' => '1-800-555-Ninja'],
 | 
			
		||||
                    ],
 | 
			
		||||
                ],
 | 
			
		||||
                'company-address' => [
 | 
			
		||||
                    'id' => 'company-address',
 | 
			
		||||
                    'elements' => [
 | 
			
		||||
                        ['element' => 'p', 'content' => '123 Ninja Blvd.'],
 | 
			
		||||
                        ['element' => 'p', 'content' => 'NinjaLand, 97315'],
 | 
			
		||||
                        ['element' => 'p', 'content' => 'United States'],
 | 
			
		||||
                    ],
 | 
			
		||||
                ],
 | 
			
		||||
                'product-table' => [
 | 
			
		||||
                    'id' => 'product-table',
 | 
			
		||||
                    'elements' => [
 | 
			
		||||
                        ['element' => 'thead', 'content' => '', 'properties' => ['class' => 'text-left bg-teal-600'], 'elements' => [
 | 
			
		||||
                            ['element' => 'th', 'content' => 'Item', 'properties' => ['class' => 'font-semibold text-white px-4 py-3']],
 | 
			
		||||
                            ['element' => 'th', 'content' => 'Description', 'properties' => ['class' => 'font-semibold text-white px-4 py-3']],
 | 
			
		||||
                            ['element' => 'th', 'content' => 'Unit cost', 'properties' => ['class' => 'font-semibold text-white px-4 py-3']],
 | 
			
		||||
                            ['element' => 'th', 'content' => 'Quantity', 'properties' => ['class' => 'font-semibold text-white px-4 py-3']],
 | 
			
		||||
                            ['element' => 'th', 'content' => 'Line total', 'properties' => ['class' => 'font-semibold text-white px-4 py-3']],
 | 
			
		||||
                        ]],
 | 
			
		||||
                        ['element' => 'tbody', 'content' => '', 'elements' => [
 | 
			
		||||
                            ['element' => 'tr', 'content' => '', 'properties' => ['class' => 'border-b-2 border-teal-600 '], 'elements' => [
 | 
			
		||||
                                ['element' => 'td', 'content' => 'Painting service', 'properties' => ['class' => 'px-4 py-4']],
 | 
			
		||||
                                ['element' => 'td', 'content' => '25 hours of painting', 'properties' => ['class' => 'px-4 py-4']],
 | 
			
		||||
                                ['element' => 'td', 'content' => '885.00', 'properties' => ['class' => 'px-4 py-4']],
 | 
			
		||||
                                ['element' => 'td', 'content' => '1', 'properties' => ['class' => 'px-4 py-4']],
 | 
			
		||||
                                ['element' => 'td', 'content' => '$885.00', 'properties' => ['class' => 'px-4 py-4']],
 | 
			
		||||
                            ]],
 | 
			
		||||
                        ]],
 | 
			
		||||
                        ['element' => 'tfoot', 'content' => '', 'elements' => [
 | 
			
		||||
                            ['element' => 'tr', 'content' => '', 'elements' => [
 | 
			
		||||
                                ['element' => 'td', 'content' => 'Trend and SEO report has been sent via email. This is really long text just to test the width of the elements.', 'properties' => ['class' => 'border-l-4 border-white px-4 py-4', 'colspan' => '2']],
 | 
			
		||||
                                ['element' => 'td', 'content' => 'Subtotal', 'properties' => ['class' => 'px-4 py-4 text-right', 'colspan' => '2']],
 | 
			
		||||
                                ['element' => 'td', 'content' => '$0', 'properties' => ['class' => 'px-4 py-2 text-right']],
 | 
			
		||||
                            ]],
 | 
			
		||||
                            ['element' => 'tr', 'content' => '', 'elements' => [
 | 
			
		||||
                                ['element' => 'td', 'content' => 'Paid to date', 'properties' => ['class' => 'border-l-4 border-white px-4 text-right', 'colspan' => '4']],
 | 
			
		||||
                                ['element' => 'td', 'content' => '$0.00', 'properties' => ['class' => 'px-4 py-2 text-right']],
 | 
			
		||||
                            ]],
 | 
			
		||||
                            ['element' => 'tr', 'content' => '', 'elements' => [
 | 
			
		||||
                                ['element' => 'td', 'content' => 'Discount %20', 'properties' => ['class' => 'border-l-4 border-white px-4 text-right', 'colspan' => '4']],
 | 
			
		||||
                                ['element' => 'td', 'content' => '$2.00', 'properties' => ['class' => 'px-4 py-2 text-right']],
 | 
			
		||||
                            ]],
 | 
			
		||||
                            ['element' => 'tr', 'content' => '', 'properties' => ['class' => 'mt-8 px-4 py-2'], 'elements' => [
 | 
			
		||||
                                ['element' => 'td', 'content' => 'Balance due', 'properties' => ['class' => 'px-4 text-right', 'colspan' => '4']],
 | 
			
		||||
                                ['element' => 'td', 'content' => '$2.00', 'properties' => ['class' => 'px-4 py-2 text-right font-semibold text-teal-600']],
 | 
			
		||||
                            ]],
 | 
			
		||||
                        ]],
 | 
			
		||||
                    ],
 | 
			
		||||
                ],
 | 
			
		||||
            ],
 | 
			
		||||
            'variables' => array_merge([], $this->state['variables']),
 | 
			
		||||
        ];
 | 
			
		||||
 | 
			
		||||
        $maker = new PdfMaker($state);
 | 
			
		||||
 | 
			
		||||
        $maker
 | 
			
		||||
            ->design(Playful::class)
 | 
			
		||||
            ->build();
 | 
			
		||||
 | 
			
		||||
        exec('echo "" > storage/logs/laravel.log');
 | 
			
		||||
 | 
			
		||||
        info($maker->getCompiledHTML(true));
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										13
									
								
								tests/Feature/PdfMaker/Playful.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								tests/Feature/PdfMaker/Playful.php
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,13 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
namespace Tests\Feature\PdfMaker;
 | 
			
		||||
 | 
			
		||||
class Playful
 | 
			
		||||
{
 | 
			
		||||
    public function html()
 | 
			
		||||
    {
 | 
			
		||||
        return file_get_contents(
 | 
			
		||||
            base_path('tests/Feature/PdfMaker/designs/playful.html')
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@ -9,10 +9,6 @@
 | 
			
		||||
        <meta http-equiv="x-ua-compatible" content="ie=edge" />
 | 
			
		||||
 | 
			
		||||
        <link rel="stylesheet" href="$css" />
 | 
			
		||||
        <link
 | 
			
		||||
            href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css"
 | 
			
		||||
            rel="stylesheet"
 | 
			
		||||
        />
 | 
			
		||||
    </head>
 | 
			
		||||
 | 
			
		||||
    <style>
 | 
			
		||||
@ -20,7 +16,7 @@
 | 
			
		||||
            background-color: #edf2f7;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        #product-table tbody > tr:nth-child(even) {
 | 
			
		||||
        #product-table tbody > tr:nth-child(odd) {
 | 
			
		||||
            background-color: #f7fafc;
 | 
			
		||||
        }
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										67
									
								
								tests/Feature/PdfMaker/designs/playful.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								tests/Feature/PdfMaker/designs/playful.html
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,67 @@
 | 
			
		||||
<!DOCTYPE html>
 | 
			
		||||
<html>
 | 
			
		||||
    <head>
 | 
			
		||||
        <meta charset="utf-8" />
 | 
			
		||||
        <meta
 | 
			
		||||
            name="viewport"
 | 
			
		||||
            content="width=device-width, initial-scale=1, shrink-to-fit=no"
 | 
			
		||||
        />
 | 
			
		||||
        <meta http-equiv="x-ua-compatible" content="ie=edge" />
 | 
			
		||||
 | 
			
		||||
        <link rel="stylesheet" href="$css" />
 | 
			
		||||
        <link
 | 
			
		||||
            href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css"
 | 
			
		||||
            rel="stylesheet"
 | 
			
		||||
        />
 | 
			
		||||
    </head>
 | 
			
		||||
 | 
			
		||||
    <style>
 | 
			
		||||
        #product-table tbody > tr > td:first-child {
 | 
			
		||||
            color: #9b2c2c;
 | 
			
		||||
        }
 | 
			
		||||
        
 | 
			
		||||
        #product-table tbody > tr > td:last-child {
 | 
			
		||||
            font-weight: bold;
 | 
			
		||||
        }
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    <body class="$global-margin antialiased bg-white break-words">
 | 
			
		||||
        <!-- Company logo, entity details -->
 | 
			
		||||
        <div class="grid grid-cols-12 gap-4">
 | 
			
		||||
            <div class="col-span-4">
 | 
			
		||||
                <img
 | 
			
		||||
                    src="$company-logo"
 | 
			
		||||
                    alt="$company-name logo"
 | 
			
		||||
                    class="w-24 col-span-4 sm:w-32"
 | 
			
		||||
                />
 | 
			
		||||
            </div>
 | 
			
		||||
            <div class="col-span-5 col-start-8 p-5 bg-teal-600 rounded-lg">
 | 
			
		||||
                <table id="entity-details" class="text-white"></table>
 | 
			
		||||
            </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- Company details, client details -->
 | 
			
		||||
        <div class="grid grid-cols-12 gap-12 mt-12">
 | 
			
		||||
            <div class="col-span-6">
 | 
			
		||||
                <p class="px-4 font-semibold text-teal-600">$to:</p>
 | 
			
		||||
                <div
 | 
			
		||||
                    class="p-4 mt-4 border-t-4 border-b-4 border-teal-600 border-dashed"
 | 
			
		||||
                >
 | 
			
		||||
                    <div id="client-details"></div>
 | 
			
		||||
                </div>
 | 
			
		||||
            </div>
 | 
			
		||||
            <div class="col-span-6">
 | 
			
		||||
                <p class="px-4 font-semibold text-teal-600">$from:</p>
 | 
			
		||||
                <div
 | 
			
		||||
                    class="flex p-4 mt-4 space-x-4 border-t-4 border-b-4 border-teal-600 border-dashed"
 | 
			
		||||
                >
 | 
			
		||||
                    <div id="company-details"></div>
 | 
			
		||||
                    <div id="company-address"></div>
 | 
			
		||||
                </div>
 | 
			
		||||
            </div>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <!-- Product table -->
 | 
			
		||||
        <table id="product-table" class="w-full mt-10 table-auto"></table>
 | 
			
		||||
    </body>
 | 
			
		||||
</html>
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user