1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-10 21:22:58 +01:00
invoiceninja/app/Http/Controllers/CreditController.php

103 lines
3.0 KiB
PHP
Raw Normal View History

2015-03-17 02:30:56 +01:00
<?php namespace App\Http\Controllers;
2015-03-16 22:45:25 +01:00
2015-03-26 07:24:02 +01:00
use Datatable;
use Input;
use Redirect;
use Session;
2015-11-04 08:48:47 +01:00
use URL;
2015-03-26 07:24:02 +01:00
use Utils;
use View;
2015-04-01 17:44:55 +02:00
use Validator;
use App\Models\Client;
2015-10-28 20:22:07 +01:00
use App\Services\CreditService;
use App\Ninja\Repositories\CreditRepository;
2015-10-28 20:22:07 +01:00
use App\Http\Requests\CreateCreditRequest;
2015-03-16 22:45:25 +01:00
2015-03-26 07:24:02 +01:00
class CreditController extends BaseController
2015-03-16 22:45:25 +01:00
{
protected $creditRepo;
2015-11-05 23:37:04 +01:00
protected $creditService;
2015-03-16 22:45:25 +01:00
2015-10-28 20:22:07 +01:00
public function __construct(CreditRepository $creditRepo, CreditService $creditService)
2015-03-16 22:45:25 +01:00
{
parent::__construct();
$this->creditRepo = $creditRepo;
2015-10-28 20:22:07 +01:00
$this->creditService = $creditService;
2015-03-16 22:45:25 +01:00
}
/**
* Display a listing of the resource.
*
* @return Response
*/
public function index()
{
return View::make('list', array(
'entityType' => ENTITY_CREDIT,
'title' => trans('texts.credits'),
2015-04-28 22:13:52 +02:00
'sortCol' => '4',
2015-11-06 00:14:00 +01:00
'columns' => Utils::trans(['checkbox', 'client', 'credit_amount', 'credit_balance', 'credit_date', 'private_notes', '']),
2015-03-16 22:45:25 +01:00
));
}
public function getDatatable($clientPublicId = null)
{
2015-11-05 23:37:04 +01:00
return $this->creditService->getDatatable($clientPublicId, Input::get('sSearch'));
2015-03-16 22:45:25 +01:00
}
public function create($clientPublicId = 0)
{
$data = array(
'clientPublicId' => Input::old('client') ? Input::old('client') : $clientPublicId,
//'invoicePublicId' => Input::old('invoice') ? Input::old('invoice') : $invoicePublicId,
'credit' => null,
'method' => 'POST',
'url' => 'credits',
'title' => trans('texts.new_credit'),
//'invoices' => Invoice::scope()->with('client', 'invoice_status')->orderBy('invoice_number')->get(),
'clients' => Client::scope()->with('contacts')->orderBy('name')->get(), );
return View::make('credits.edit', $data);
}
public function edit($publicId)
{
$credit = Credit::scope($publicId)->firstOrFail();
$credit->credit_date = Utils::fromSqlDate($credit->credit_date);
$data = array(
'client' => null,
'credit' => $credit,
'method' => 'PUT',
'url' => 'credits/'.$publicId,
'title' => 'Edit Credit',
'clients' => Client::scope()->with('contacts')->orderBy('name')->get(), );
return View::make('credit.edit', $data);
}
2015-10-28 20:22:07 +01:00
public function store(CreateCreditRequest $request)
2015-03-16 22:45:25 +01:00
{
2015-10-28 20:22:07 +01:00
$credit = $this->creditRepo->save($request->input());
Session::flash('message', trans('texts.created_credit'));
return redirect()->to($credit->client->getRoute());
2015-03-16 22:45:25 +01:00
}
public function bulk()
{
$action = Input::get('action');
2015-10-28 20:22:07 +01:00
$ids = Input::get('public_id') ? Input::get('public_id') : Input::get('ids');
$count = $this->creditService->bulk($ids, $action);
2015-03-16 22:45:25 +01:00
if ($count > 0) {
$message = Utils::pluralize($action.'d_credit', $count);
Session::flash('message', $message);
}
return Redirect::to('credits');
}
}