mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-10 21:22:58 +01:00
Creative
This commit is contained in:
parent
56e11ac499
commit
0c6b661f5e
13
tests/Feature/PdfMaker/Creative.php
Normal file
13
tests/Feature/PdfMaker/Creative.php
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Tests\Feature\PdfMaker;
|
||||||
|
|
||||||
|
class creative
|
||||||
|
{
|
||||||
|
public function html()
|
||||||
|
{
|
||||||
|
return file_get_contents(
|
||||||
|
base_path('tests/Feature/PdfMaker/designs/creative.html')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
@ -2,8 +2,6 @@
|
|||||||
|
|
||||||
namespace Tests\Feature\PdfMaker;
|
namespace Tests\Feature\PdfMaker;
|
||||||
|
|
||||||
use Illuminate\Foundation\Testing\RefreshDatabase;
|
|
||||||
use Illuminate\Foundation\Testing\WithFaker;
|
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
|
|
||||||
class PdfMakerDesignsTest extends TestCase
|
class PdfMakerDesignsTest extends TestCase
|
||||||
@ -798,4 +796,117 @@ class PdfMakerDesignsTest extends TestCase
|
|||||||
|
|
||||||
info($maker->getCompiledHTML(true));
|
info($maker->getCompiledHTML(true));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testCreative()
|
||||||
|
{
|
||||||
|
$state = [
|
||||||
|
'template' => [
|
||||||
|
'company-details' => [
|
||||||
|
'id' => 'company-details',
|
||||||
|
'elements' => [
|
||||||
|
['element' => 'p', 'content' => 'Ninja Sample'],
|
||||||
|
['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'],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'client-details' => [
|
||||||
|
'id' => 'client-details',
|
||||||
|
'elements' => [
|
||||||
|
['element' => 'p', 'content' => 'Winterfield Medical Supply', 'properties' => ['class' => 'font-medium']],
|
||||||
|
['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'],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'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']],
|
||||||
|
]],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'product-table' => [
|
||||||
|
'id' => 'product-table',
|
||||||
|
'elements' => [
|
||||||
|
['element' => 'thead', 'content' => '', 'properties' => ['class' => 'text-left'], 'elements' => [
|
||||||
|
['element' => 'th', 'content' => 'Item', 'properties' => ['class' => 'font-medium uppercase text-pink-700 text-xl px-4 py-5']],
|
||||||
|
['element' => 'th', 'content' => 'Description', 'properties' => ['class' => 'font-medium uppercase text-pink-700 text-xl px-4 py-5']],
|
||||||
|
['element' => 'th', 'content' => 'Unit cost', 'properties' => ['class' => 'font-medium uppercase text-pink-700 text-xl px-4 py-5']],
|
||||||
|
['element' => 'th', 'content' => 'Quantity', 'properties' => ['class' => 'font-medium uppercase text-pink-700 text-xl px-4 py-5']],
|
||||||
|
['element' => 'th', 'content' => 'Line total', 'properties' => ['class' => 'font-medium uppercase text-pink-700 text-xl px-4 py-5']],
|
||||||
|
]],
|
||||||
|
['element' => 'tbody', 'content' => '', 'elements' => [
|
||||||
|
['element' => 'tr', 'content' => '', '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' => 'tr', 'content' => '', '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 border-t-4 border-pink-700'], 'elements' => [
|
||||||
|
['element' => 'td', 'content' => 'Balance due', '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 font-semibold text-pink-700']],
|
||||||
|
]],
|
||||||
|
]],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'variables' => array_merge([], $this->state['variables']),
|
||||||
|
];
|
||||||
|
|
||||||
|
$maker = new PdfMaker($state);
|
||||||
|
|
||||||
|
$maker
|
||||||
|
->design(Creative::class)
|
||||||
|
->build();
|
||||||
|
|
||||||
|
exec('echo "" > storage/logs/laravel.log');
|
||||||
|
|
||||||
|
info($maker->getCompiledHTML(true));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
71
tests/Feature/PdfMaker/designs/creative.html
Normal file
71
tests/Feature/PdfMaker/designs/creative.html
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
<!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:nth-child(even) {
|
||||||
|
background-color: #edf2f7;
|
||||||
|
}
|
||||||
|
|
||||||
|
#product-table tbody > tr:nth-child(even) {
|
||||||
|
background-color: #f7fafc;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<body class="$global-margin antialiased bg-white break-words">
|
||||||
|
<!-- Client details, company details, company logo -->
|
||||||
|
<div class="grid grid-cols-12 gap-4">
|
||||||
|
<!-- Client details -->
|
||||||
|
<div class="col-span-4">
|
||||||
|
<div id="client-details"></div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Company details -->
|
||||||
|
<div class="flex flex-col col-span-4 space-y-4">
|
||||||
|
<div id="company-details"></div>
|
||||||
|
<div id="company-address"></div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Logo -->
|
||||||
|
<div class="flex flex-col items-end col-span-4">
|
||||||
|
<img
|
||||||
|
src="$company-logo"
|
||||||
|
alt="$company-name logo"
|
||||||
|
class="w-24 col-span-4 sm:w-32"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Entity label, entity details -->
|
||||||
|
<div class="grid grid-cols-12 mt-10">
|
||||||
|
<!-- Entity number -->
|
||||||
|
<div class="col-span-4 text-3xl font-semibold uppercase">
|
||||||
|
<span>$entity</span>
|
||||||
|
<i class="text-pink-700">#$entity-number</i>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Entity labels -->
|
||||||
|
<div class="flex flex-col items-end col-span-8">
|
||||||
|
<table id="entity-details"></table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<table
|
||||||
|
id="product-table"
|
||||||
|
class="w-full mt-10 border-t-4 border-pink-700 table-auto"
|
||||||
|
></table>
|
||||||
|
</body>
|
||||||
|
</html>
|
Loading…
Reference in New Issue
Block a user