fix invoice print layout and pdf

This commit is contained in:
Brett Whiteman
2018-10-11 05:35:38 +13:00
parent 8315665daf
commit f039447d8a
3 changed files with 212 additions and 176 deletions

View File

@@ -2,16 +2,100 @@
@section('title', trans_choice('general.invoices', 1) . ': ' . $invoice->invoice_number) @section('title', trans_choice('general.invoices', 1) . ': ' . $invoice->invoice_number)
@push('css')
<style>
body {
margin: 0;
padding: 0;
font-family: Arial, sans-serif;
color: #000;
}
table {
width: 100%;
}
th, td {
text-align: left;
padding: 8px;
}
.row {
font-size: 0; /* prevent whitespace from stuffing up inline-block column layouts */
}
.col-58 {
display: inline-block;
width: 58%;
vertical-align: top;
}
.col-42 {
display: inline-block;
width: 42%;
vertical-align: top;
}
.text {
font-size: 16px;
}
.text-right {
text-align: right;
}
.text-center {
text-align: center;
}
.text-success {
color: #28a745;
}
.invoice-header {
padding-bottom: 9px;
margin: 10px 0 20px 0;
border-bottom: 1px solid #eee;
}
.invoice-company {
padding-left: 23px;
}
.invoice-logo {
max-width: 430px;
max-height: 120px;
}
.invoice-lines {
margin: 30px 0;
border-collapse: collapse;
table-layout: fixed;
border: 1px solid #ccc;
}
.invoice-lines thead tr {
background-color: #eee;
}
.invoice-lines tbody td {
border-bottom: 1px solid #ccc;
}
.invoice-lines .item {
width: 40%;
}
.invoice-lines .quantity {
width: 20%;
text-align: center;
}
.invoice-lines .price {
width: 20%:;
text-align: right;
}
.invoice-lines .total {
width: 20%;
text-align: right;
}
.notes {
font-size: 14px;
}
</style>
@endpush
@section('content') @section('content')
<section class="invoice">
<div class="row invoice-header"> <div class="row invoice-header">
<div class="col-xs-7"> <div class="col-58">
@if ($logo) @if ($logo)
<img src="{{ $logo }}" class="invoice-logo" /> <img src="{{ $logo }}" class="invoice-logo">
@endif @endif
</div> </div>
<div class="col-xs-5 invoice-company"> <div class="col-42">
<address> <div class="text invoice-company">
<strong>{{ setting('general.company_name') }}</strong><br> <strong>{{ setting('general.company_name') }}</strong><br>
{!! nl2br(setting('general.company_address')) !!}<br> {!! nl2br(setting('general.company_address')) !!}<br>
@if (setting('general.company_tax_number')) @if (setting('general.company_tax_number'))
@@ -22,14 +106,14 @@
{{ setting('general.company_phone') }}<br> {{ setting('general.company_phone') }}<br>
@endif @endif
{{ setting('general.company_email') }} {{ setting('general.company_email') }}
</address> </div>
</div> </div>
</div> </div>
<div class="row"> <div class="row">
<div class="col-xs-7"> <div class="col-58">
{{ trans('invoices.bill_to') }} <div class="text">
<address> {{ trans('invoices.bill_to') }}<br><br>
<strong>{{ $invoice->customer_name }}</strong><br> <strong>{{ $invoice->customer_name }}</strong><br>
{!! nl2br($invoice->customer_address) !!}<br> {!! nl2br($invoice->customer_address) !!}<br>
@if ($invoice->customer_tax_number) @if ($invoice->customer_tax_number)
@@ -40,11 +124,11 @@
{{ $invoice->customer_phone }}<br> {{ $invoice->customer_phone }}<br>
@endif @endif
{{ $invoice->customer_email }} {{ $invoice->customer_email }}
</address>
</div> </div>
<div class="col-xs-5"> </div>
<div class="table-responsive"> <div class="col-42">
<table class="table no-border"> <div class="text">
<table>
<tbody> <tbody>
<tr> <tr>
<th>{{ trans('invoices.invoice_number') }}:</th> <th>{{ trans('invoices.invoice_number') }}:</th>
@@ -70,47 +154,43 @@
</div> </div>
</div> </div>
<div class="row"> <table class="invoice-lines">
<div class="col-xs-12 table-responsive"> <thead>
<table class="table table-striped">
<tbody>
<tr> <tr>
<th>{{ trans_choice('general.items', 1) }}</th> <th class="item">{{ trans_choice('general.items', 1) }}</th>
<th class="text-center">{{ trans('invoices.quantity') }}</th> <th class="quantity">{{ trans('invoices.quantity') }}</th>
<th class="text-right">{{ trans('invoices.price') }}</th> <th class="price">{{ trans('invoices.price') }}</th>
<th class="text-right">{{ trans('invoices.total') }}</th> <th class="total">{{ trans('invoices.total') }}</th>
</tr> </tr>
</thead>
<tbody>
@foreach($invoice->items as $item) @foreach($invoice->items as $item)
<tr> <tr>
<td> <td class="item">
{{ $item->name }} {{ $item->name }}
@if ($item->sku) @if ($item->sku)
<br><small>{{ trans('items.sku') }}: {{ $item->sku }}</small> <br><small>{{ trans('items.sku') }}: {{ $item->sku }}</small>
@endif @endif
</td> </td>
<td class="text-center">{{ $item->quantity }}</td> <td class="quantity">{{ $item->quantity }}</td>
<td class="text-right">@money($item->price, $invoice->currency_code, true)</td> <td class="price">@money($item->price, $invoice->currency_code, true)</td>
<td class="text-right">@money($item->total, $invoice->currency_code, true)</td> <td class="total">@money($item->total, $invoice->currency_code, true)</td>
</tr> </tr>
@endforeach @endforeach
</tbody> </tbody>
</table> </table>
</div>
</div>
<div class="row"> <div class="row">
<div class="col-xs-7"> <div class="col-58">
@if ($invoice->notes) @if ($invoice->notes)
<p class="lead">{{ trans_choice('general.notes', 2) }}</p> <table class="text" style="page-break-inside: avoid;">
<tr><th>{{ trans_choice('general.notes', 2) }}</th></tr>
<p class="text-muted well well-sm no-shadow" style="margin-top: 10px;"> <tr><td>{{ $invoice->notes }}</td></tr>
{{ $invoice->notes }} </table>
</p>
@endif @endif
</div> </div>
<div class="col-xs-5"> <div class="col-42">
<div class="table-responsive"> <table class="text" style="page-break-inside: avoid;">
<table class="table">
<tbody> <tbody>
@foreach ($invoice->totals as $total) @foreach ($invoice->totals as $total)
@if ($total->code != 'total') @if ($total->code != 'total')
@@ -135,6 +215,4 @@
</table> </table>
</div> </div>
</div> </div>
</div>
</section>
@endsection @endsection

View File

@@ -4,11 +4,7 @@
<body onload="window.print();"> <body onload="window.print();">
@stack('body_start') @stack('body_start')
<!-- Content Wrapper. Contains page content -->
<div class="wrapper" style="margin-left: 0; page-break-after: always;">
@yield('content') @yield('content')
</div>
<!-- /.content-wrapper -->
@stack('body_end') @stack('body_end')
</body> </body>

View File

@@ -9,48 +9,10 @@
<title>@yield('title') - @setting('general.company_name')</title> <title>@yield('title') - @setting('general.company_name')</title>
<!-- Bootstrap 3.3.6 -->
<link rel="stylesheet" href="{{ asset('vendor/almasaeed2010/adminlte/bootstrap/css/bootstrap.min.css') }}">
<!-- Font Awesome -->
<link rel="stylesheet" href="{{ asset('public/css/font-awesome.min.css') }}">
<!-- Ionicons -->
<link rel="stylesheet" href="{{ asset('public/css/ionicons.min.css') }}">
<!-- Theme style -->
<link rel="stylesheet" href="{{ asset('vendor/almasaeed2010/adminlte/dist/css/AdminLTE.min.css') }}">
<!-- AdminLTE Skins. Choose a skin from the css/skins
folder instead of downloading all of them to reduce the load. -->
<link rel="stylesheet" href="{{ asset('vendor/almasaeed2010/adminlte/dist/css/skins/_all-skins.min.css') }}">
<!-- App style -->
<link rel="stylesheet" href="{{ asset('public/css/app.css?v=' . version('short')) }}">
<style type="text/css">
* {
font-family: "DejaVu Sans Mono", monospace;
}
</style>
@stack('css') @stack('css')
@stack('stylesheet') @stack('stylesheet')
<!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->
<!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
<!--[if lt IE 9]>
<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script>
<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
<![endif]-->
<!-- jQuery 2.2.3 -->
<script src="{{ asset('vendor/almasaeed2010/adminlte/plugins/jQuery/jquery-2.2.3.min.js') }}"></script>
<!-- Bootstrap 3.3.6 -->
<script src="{{ asset('vendor/almasaeed2010/adminlte/bootstrap/js/bootstrap.min.js') }}"></script>
<!-- SlimScroll -->
<script src="{{ asset('vendor/almasaeed2010/adminlte/plugins/slimScroll/jquery.slimscroll.min.js') }}"></script>
<!-- AdminLTE App -->
<script src="{{ asset('vendor/almasaeed2010/adminlte/dist/js/app.min.js') }}"></script>
<script src="{{ asset('public/js/app.js?v=' . version('short')) }}"></script>
@stack('js') @stack('js')
@stack('scripts') @stack('scripts')