WIP Work on new Quotes
This commit is contained in:
parent
0b8fd00f67
commit
ba71d92f1f
@ -41,6 +41,7 @@ public static function form(Form $form): Form
|
|||||||
->columnSpan(1),
|
->columnSpan(1),
|
||||||
|
|
||||||
DatePicker::make('date')
|
DatePicker::make('date')
|
||||||
|
->default(today())
|
||||||
->required(),
|
->required(),
|
||||||
|
|
||||||
TextArea::make('notes')
|
TextArea::make('notes')
|
||||||
@ -65,7 +66,9 @@ public static function form(Form $form): Form
|
|||||||
->prefix('$'),
|
->prefix('$'),
|
||||||
TextInput::make('run_charge')
|
TextInput::make('run_charge')
|
||||||
->prefix('$'),
|
->prefix('$'),
|
||||||
]),
|
])
|
||||||
|
->addActionLabel('Add Embroidery Entry')
|
||||||
|
->defaultItems(0),
|
||||||
|
|
||||||
TableRepeater::make('screenPrintEntries')
|
TableRepeater::make('screenPrintEntries')
|
||||||
->relationship('screenPrintEntries')
|
->relationship('screenPrintEntries')
|
||||||
@ -87,8 +90,11 @@ public static function form(Form $form): Form
|
|||||||
->prefix('$'),
|
->prefix('$'),
|
||||||
TextInput::make('poly_ink')
|
TextInput::make('poly_ink')
|
||||||
->prefix('$'),
|
->prefix('$'),
|
||||||
TextInput::make('other_charges'),
|
TextInput::make('other_charges')
|
||||||
]),
|
->prefix('$'),
|
||||||
|
])
|
||||||
|
->addActionLabel('Add Screen Print Entry')
|
||||||
|
->defaultItems(0),
|
||||||
|
|
||||||
TableRepeater::make('heatTransferEntries')
|
TableRepeater::make('heatTransferEntries')
|
||||||
->relationship('heatTransferEntries')
|
->relationship('heatTransferEntries')
|
||||||
@ -97,13 +103,15 @@ public static function form(Form $form): Form
|
|||||||
->label('Logo name'),
|
->label('Logo name'),
|
||||||
TextInput::make('quantity')
|
TextInput::make('quantity')
|
||||||
->prefix('#'),
|
->prefix('#'),
|
||||||
TextInput::make('Width')
|
TextInput::make('width')
|
||||||
->suffix('"'),
|
->suffix('"'),
|
||||||
TextInput::make('Height')
|
TextInput::make('height')
|
||||||
->suffix('"'),
|
->suffix('"'),
|
||||||
TextInput::make('price')
|
TextInput::make('price')
|
||||||
->prefix('$'),
|
->prefix('$'),
|
||||||
]),
|
])
|
||||||
|
->addActionLabel('Add Heat Transfer Entry')
|
||||||
|
->defaultItems(0),
|
||||||
])->columns(1);
|
])->columns(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,7 +3,9 @@
|
|||||||
namespace App\Filament\Admin\Resources\QuoteResource\Pages;
|
namespace App\Filament\Admin\Resources\QuoteResource\Pages;
|
||||||
|
|
||||||
use App\Filament\Admin\Resources\QuoteResource;
|
use App\Filament\Admin\Resources\QuoteResource;
|
||||||
|
use App\Models\Quote;
|
||||||
use Filament\Actions;
|
use Filament\Actions;
|
||||||
|
use Filament\Actions\Action;
|
||||||
use Filament\Resources\Pages\EditRecord;
|
use Filament\Resources\Pages\EditRecord;
|
||||||
|
|
||||||
class EditQuote extends EditRecord
|
class EditQuote extends EditRecord
|
||||||
@ -13,6 +15,12 @@ class EditQuote extends EditRecord
|
|||||||
protected function getHeaderActions(): array
|
protected function getHeaderActions(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
|
||||||
|
Action::make('print')
|
||||||
|
->icon('lucide-printer')
|
||||||
|
->url(fn (Quote $record) => route('pdf.quote', $record))
|
||||||
|
->openUrlInNewTab(),
|
||||||
|
|
||||||
Actions\DeleteAction::make(),
|
Actions\DeleteAction::make(),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
namespace App\Http\Controllers;
|
namespace App\Http\Controllers;
|
||||||
|
|
||||||
use App\Models\InvoiceReport;
|
use App\Models\InvoiceReport;
|
||||||
|
use App\Models\Quote;
|
||||||
use Spatie\Browsershot\Browsershot;
|
use Spatie\Browsershot\Browsershot;
|
||||||
use Spatie\LaravelPdf\Facades\Pdf;
|
use Spatie\LaravelPdf\Facades\Pdf;
|
||||||
|
|
||||||
@ -23,4 +24,18 @@ public function invoiceReport(int $id)
|
|||||||
|
|
||||||
return redirect($url);
|
return redirect($url);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function quote(int $id)
|
||||||
|
{
|
||||||
|
$quote = Quote::find($id);
|
||||||
|
$url = strtolower('quote-'.$quote->id.'.pdf');
|
||||||
|
|
||||||
|
Pdf::view('pdf.quote', ['quote' => $quote])
|
||||||
|
->withBrowsershot(function (Browsershot $browsershot) {
|
||||||
|
$browsershot->noSandbox();
|
||||||
|
})
|
||||||
|
->margins(8, 8, 15, 8)
|
||||||
|
->footerView('pdf.quote-footer', ['quote' => $quote])
|
||||||
|
->save($url);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -14,7 +14,7 @@ class EmbroideryEntry extends Model
|
|||||||
'width',
|
'width',
|
||||||
'height',
|
'height',
|
||||||
'placement',
|
'placement',
|
||||||
'stitches',
|
'stitch_count',
|
||||||
'digitizing_cost',
|
'digitizing_cost',
|
||||||
'run_charge',
|
'run_charge',
|
||||||
];
|
];
|
||||||
|
@ -36,4 +36,19 @@ public function heatTransferEntries(): HasMany
|
|||||||
{
|
{
|
||||||
return $this->hasMany(HeatTransferEntry::class);
|
return $this->hasMany(HeatTransferEntry::class);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function embroideryEntries(): HasMany
|
||||||
|
{
|
||||||
|
return $this->hasMany(EmbroideryEntry::class);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function screenPrintEntries(): HasMany
|
||||||
|
{
|
||||||
|
return $this->hasMany(ScreenPrintEntry::class);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function heatTransferEntries(): HasMany
|
||||||
|
{
|
||||||
|
return $this->hasMany(HeatTransferEntry::class);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -21,7 +21,7 @@ public function up(): void
|
|||||||
$table->decimal('width', 6, 2)->nullable();
|
$table->decimal('width', 6, 2)->nullable();
|
||||||
$table->decimal('height', 6, 2)->nullable();
|
$table->decimal('height', 6, 2)->nullable();
|
||||||
$table->string('placement')->nullable();
|
$table->string('placement')->nullable();
|
||||||
$table->string('stitches')->nullable();
|
$table->string('stitch_count')->nullable();
|
||||||
$table->string('digitizing_cost')->nullable();
|
$table->string('digitizing_cost')->nullable();
|
||||||
$table->string('run_charge')->nullable();
|
$table->string('run_charge')->nullable();
|
||||||
$table->text('notes')->nullable();
|
$table->text('notes')->nullable();
|
||||||
|
@ -26,7 +26,7 @@ public function run(): void
|
|||||||
ServiceTypeSeeder::class,
|
ServiceTypeSeeder::class,
|
||||||
ProductServiceSeeder::class,
|
ProductServiceSeeder::class,
|
||||||
ServiceFileSeeder::class,
|
ServiceFileSeeder::class,
|
||||||
QuoteSeeder::class,
|
// QuoteSeeder::class,
|
||||||
InvoiceSeeder::class,
|
InvoiceSeeder::class,
|
||||||
InvoiceReportSeeder::class,
|
InvoiceReportSeeder::class,
|
||||||
]);
|
]);
|
||||||
|
10
resources/views/pdf/quote-footer.blade.php
Normal file
10
resources/views/pdf/quote-footer.blade.php
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<style>
|
||||||
|
* {
|
||||||
|
font-size: 12px;
|
||||||
|
margin: 10px 5px;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<footer>
|
||||||
|
{{$quote->internal_id}}, page @pageNumber of @totalPages
|
||||||
|
</footer>'
|
@ -19,6 +19,8 @@
|
|||||||
// Auth::routes();
|
// Auth::routes();
|
||||||
|
|
||||||
Route::get('/pdf/invoicereport/{id}', [PdfController::class, 'invoiceReport'])->name('pdf.invoice-report');
|
Route::get('/pdf/invoicereport/{id}', [PdfController::class, 'invoiceReport'])->name('pdf.invoice-report');
|
||||||
|
Route::get('/pdf/quote/{id}', [PdfController::class, 'quote'])->name('pdf.quote');
|
||||||
|
|
||||||
Route::get('orders/{order}/pdf', [OrderController::class, 'pdf'])->name('orders.pdf');
|
Route::get('orders/{order}/pdf', [OrderController::class, 'pdf'])->name('orders.pdf');
|
||||||
Route::get('invoices/{invoice}/pdf', [InvoiceController::class, 'pdf'])->name('invoice.pdf');
|
Route::get('invoices/{invoice}/pdf', [InvoiceController::class, 'pdf'])->name('invoice.pdf');
|
||||||
Route::get('customers/{customer}/pdf', [CustomerController::class, 'pdf'])->name('customer.pdf');
|
Route::get('customers/{customer}/pdf', [CustomerController::class, 'pdf'])->name('customer.pdf');
|
||||||
|
Loading…
x
Reference in New Issue
Block a user