mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-25 12:09:26 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			173 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			173 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Http\Controllers;
 | |
| 
 | |
| use App\Http\Requests\InvoiceRequest;
 | |
| use App\Http\Requests\QuoteRequest;
 | |
| use App\Models\Account;
 | |
| use App\Models\Client;
 | |
| use App\Models\Country;
 | |
| use App\Models\Invitation;
 | |
| use App\Models\Invoice;
 | |
| use App\Models\InvoiceDesign;
 | |
| use App\Models\Product;
 | |
| use App\Models\TaxRate;
 | |
| use App\Ninja\Datatables\InvoiceDatatable;
 | |
| use App\Ninja\Mailers\ContactMailer as Mailer;
 | |
| use App\Ninja\Repositories\ClientRepository;
 | |
| use App\Ninja\Repositories\InvoiceRepository;
 | |
| use App\Services\InvoiceService;
 | |
| use Auth;
 | |
| use Cache;
 | |
| use Input;
 | |
| use Redirect;
 | |
| use Session;
 | |
| use Utils;
 | |
| use View;
 | |
| 
 | |
| class QuoteController extends BaseController
 | |
| {
 | |
|     protected $mailer;
 | |
|     protected $invoiceRepo;
 | |
|     protected $clientRepo;
 | |
|     protected $invoiceService;
 | |
|     protected $entityType = ENTITY_INVOICE;
 | |
| 
 | |
|     public function __construct(Mailer $mailer, InvoiceRepository $invoiceRepo, ClientRepository $clientRepo, InvoiceService $invoiceService)
 | |
|     {
 | |
|         // parent::__construct();
 | |
| 
 | |
|         $this->mailer = $mailer;
 | |
|         $this->invoiceRepo = $invoiceRepo;
 | |
|         $this->clientRepo = $clientRepo;
 | |
|         $this->invoiceService = $invoiceService;
 | |
|     }
 | |
| 
 | |
|     public function index()
 | |
|     {
 | |
|         $datatable = new InvoiceDatatable();
 | |
|         $datatable->entityType = ENTITY_QUOTE;
 | |
| 
 | |
|         $data = [
 | |
|           'title' => trans('texts.quotes'),
 | |
|           'entityType' => ENTITY_QUOTE,
 | |
|           'datatable' => $datatable,
 | |
|         ];
 | |
| 
 | |
|         return response()->view('list_wrapper', $data);
 | |
|     }
 | |
| 
 | |
|     public function getDatatable($clientPublicId = null)
 | |
|     {
 | |
|         $accountId = Auth::user()->account_id;
 | |
|         $search = Input::get('sSearch');
 | |
| 
 | |
|         return $this->invoiceService->getDatatable($accountId, $clientPublicId, ENTITY_QUOTE, $search);
 | |
|     }
 | |
| 
 | |
|     public function create(QuoteRequest $request, $clientPublicId = 0)
 | |
|     {
 | |
|         if (! Utils::hasFeature(FEATURE_QUOTES)) {
 | |
|             return Redirect::to('/invoices/create');
 | |
|         }
 | |
| 
 | |
|         $account = Auth::user()->account;
 | |
|         $clientId = null;
 | |
|         if ($clientPublicId) {
 | |
|             $clientId = Client::getPrivateId($clientPublicId);
 | |
|         }
 | |
|         $invoice = $account->createInvoice(ENTITY_QUOTE, $clientId);
 | |
|         $invoice->public_id = 0;
 | |
| 
 | |
|         $data = [
 | |
|             'entityType' => $invoice->getEntityType(),
 | |
|             'invoice' => $invoice,
 | |
|             'data' => Input::old('data'),
 | |
|             'method' => 'POST',
 | |
|             'url' => 'invoices',
 | |
|             'title' => trans('texts.new_quote'),
 | |
|         ];
 | |
|         $data = array_merge($data, self::getViewModel());
 | |
| 
 | |
|         return View::make('invoices.edit', $data);
 | |
|     }
 | |
| 
 | |
|     private static function getViewModel()
 | |
|     {
 | |
|         $account = Auth::user()->account;
 | |
| 
 | |
|         return [
 | |
|           'entityType' => ENTITY_QUOTE,
 | |
|           'account' => Auth::user()->account->load('country'),
 | |
|           'products' => Product::scope()->orderBy('product_key')->get(),
 | |
|           'taxRateOptions' => $account->present()->taxRateOptions,
 | |
|           'clients' => Client::scope()->with('contacts', 'country')->orderBy('name')->get(),
 | |
|           'taxRates' => TaxRate::scope()->orderBy('name')->get(),
 | |
|           'sizes' => Cache::get('sizes'),
 | |
|           'paymentTerms' => Cache::get('paymentTerms'),
 | |
|           'invoiceDesigns' => InvoiceDesign::getDesigns(),
 | |
|           'invoiceFonts' => Cache::get('fonts'),
 | |
|           'invoiceLabels' => Auth::user()->account->getInvoiceLabels(),
 | |
|           'isRecurring' => false,
 | |
|           'expenses' => collect(),
 | |
|         ];
 | |
|     }
 | |
| 
 | |
|     public function bulk()
 | |
|     {
 | |
|         $action = Input::get('bulk_action') ?: Input::get('action');
 | |
|         ;
 | |
|         $ids = Input::get('bulk_public_id') ?: (Input::get('public_id') ?: Input::get('ids'));
 | |
| 
 | |
|         if ($action == 'convert') {
 | |
|             $invoice = Invoice::with('invoice_items')->scope($ids)->firstOrFail();
 | |
|             $clone = $this->invoiceService->convertQuote($invoice);
 | |
| 
 | |
|             Session::flash('message', trans('texts.converted_to_invoice'));
 | |
| 
 | |
|             return Redirect::to('invoices/'.$clone->public_id);
 | |
|         }
 | |
| 
 | |
|         $count = $this->invoiceService->bulk($ids, $action);
 | |
| 
 | |
|         if ($count > 0) {
 | |
|             if ($action == 'markSent') {
 | |
|                 $key = 'updated_quote';
 | |
|             } elseif ($action == 'download') {
 | |
|                 $key = 'downloaded_quote';
 | |
|             } else {
 | |
|                 $key = "{$action}d_quote";
 | |
|             }
 | |
|             $message = Utils::pluralize($key, $count);
 | |
|             Session::flash('message', $message);
 | |
|         }
 | |
| 
 | |
|         return $this->returnBulk(ENTITY_QUOTE, $action, $ids);
 | |
|     }
 | |
| 
 | |
|     public function approve($invitationKey)
 | |
|     {
 | |
|         $invitation = Invitation::with('invoice.invoice_items', 'invoice.invitations')->where('invitation_key', '=', $invitationKey)->firstOrFail();
 | |
|         $invoice = $invitation->invoice;
 | |
|         $account = $invoice->account;
 | |
| 
 | |
|         if ($account->requiresAuthorization($invoice) && ! session('authorized:' . $invitation->invitation_key)) {
 | |
|             return redirect()->to('view/' . $invitation->invitation_key);
 | |
|         }
 | |
| 
 | |
|         if ($invoice->due_date) {
 | |
|             $carbonDueDate = \Carbon::parse($invoice->due_date);
 | |
|             if (! $carbonDueDate->isToday() && ! $carbonDueDate->isFuture()) {
 | |
|                 return redirect("view/{$invitationKey}")->withError(trans('texts.quote_has_expired'));
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         if ($invoiceInvitationKey = $this->invoiceService->approveQuote($invoice, $invitation)) {
 | |
|             Session::flash('message', trans('texts.quote_is_approved'));
 | |
|             return Redirect::to("view/{$invoiceInvitationKey}");
 | |
|         } else {
 | |
|             return Redirect::to("view/{$invitationKey}");
 | |
|         }
 | |
|     }
 | |
| }
 |