mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-24 19:29:22 -04:00 
			
		
		
		
	Refactor invoice calculations class, use FormRequests on destroy()
This commit is contained in:
		
							parent
							
								
									c5e0d2a8d9
								
							
						
					
					
						commit
						cb7eea0e7b
					
				| @ -18,7 +18,7 @@ class InvoiceFactory | ||||
| 		$invoice->due_date = null; | ||||
| 		$invoice->is_deleted = false; | ||||
| 		$invoice->line_items = json_encode([]); | ||||
| 		$invoice->settings = json_encode([]); | ||||
| 		$invoice->settings = json_encode([]); //todo need to embed the settings here
 | ||||
| 		$invoice->backup = json_encode([]); | ||||
| 		$invoice->tax_name1 = ''; | ||||
| 		$invoice->tax_rate1 = 0; | ||||
|  | ||||
| @ -44,12 +44,11 @@ class InvoiceCalc | ||||
| 	 * Constructs the object with Invoice and Settings object | ||||
| 	 * | ||||
| 	 * @param      \App\Models\Invoice  $invoice   The invoice | ||||
| 	 * @param      \stdClass            $settings  The settings | ||||
| 	 */ | ||||
| 	public function __construct($invoice, \stdClass $settings) | ||||
| 	public function __construct($invoice) | ||||
| 	{ | ||||
| 		$this->invoice = $invoice; | ||||
| 		$this->settings = $settings; | ||||
| 		$this->settings = $invoice->settings; | ||||
| 		$this->tax_map = new Collection; | ||||
| 	} | ||||
| 	 | ||||
|  | ||||
| @ -6,6 +6,7 @@ use App\DataMapper\ClientSettings; | ||||
| use App\Factory\ClientFactory; | ||||
| use App\Filters\ClientFilters; | ||||
| use App\Http\Requests\Client\CreateClientRequest; | ||||
| use App\Http\Requests\Client\DestroyClientRequest; | ||||
| use App\Http\Requests\Client\EditClientRequest; | ||||
| use App\Http\Requests\Client\ShowClientRequest; | ||||
| use App\Http\Requests\Client\StoreClientRequest; | ||||
| @ -19,10 +20,10 @@ use App\Models\Country; | ||||
| use App\Models\Currency; | ||||
| use App\Models\Size; | ||||
| use App\Repositories\ClientRepository; | ||||
| use App\Transformers\ClientTransformer; | ||||
| use App\Utils\Traits\MakesHash; | ||||
| use Illuminate\Http\Request; | ||||
| use Illuminate\Support\Facades\Cache; | ||||
| use App\Transformers\ClientTransformer; | ||||
| 
 | ||||
| /** | ||||
|  * Class ClientController | ||||
| @ -142,7 +143,7 @@ class ClientController extends BaseController | ||||
|      * @param  int  $id | ||||
|      * @return \Illuminate\Http\Response | ||||
|      */ | ||||
|     public function destroy(Client $client) | ||||
|     public function destroy(DestroyClientRequest $request, Client $client) | ||||
|     { | ||||
|         $client->delete(); | ||||
| 
 | ||||
|  | ||||
| @ -3,7 +3,13 @@ | ||||
| namespace App\Http\Controllers; | ||||
| 
 | ||||
| use App\Factory\InvoiceFactory; | ||||
| use App\Http\Requests\Invoice\CreateInvoiceRequest; | ||||
| use App\Http\Requests\Invoice\EditInvoiceRequest; | ||||
| use App\Http\Requests\Invoice\ShowInvoiceRequest; | ||||
| use App\Http\Requests\Invoice\StoreInvoiceRequest; | ||||
| use App\Http\Requests\Invoice\UpdateInvoiceRequest; | ||||
| use App\Models\Invoice; | ||||
| use App\Transformers\InvoiceTransformer; | ||||
| use App\Utils\Traits\MakesHash; | ||||
| use Illuminate\Http\Request; | ||||
| 
 | ||||
| @ -56,7 +62,7 @@ class InvoiceController extends BaseController | ||||
|      * | ||||
|      * @return \Illuminate\Http\Response | ||||
|      */ | ||||
|     public function create() | ||||
|     public function create(CreateInvoiceRequest $request) | ||||
|     { | ||||
|         $invoice = InvoiceFactory::create(auth()->user()->company()->id, auth()->user()->id); | ||||
| 
 | ||||
| @ -69,9 +75,12 @@ class InvoiceController extends BaseController | ||||
|      * @param  \Illuminate\Http\Request  $request | ||||
|      * @return \Illuminate\Http\Response | ||||
|      */ | ||||
|     public function store(Request $request) | ||||
|     public function store(StoreInvoiceRequest $request) | ||||
|     { | ||||
|         //
 | ||||
|          | ||||
|         $invoice = $this->invoice_repo->save(); | ||||
|         return $this->itemResponse($invoice); | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
| @ -80,7 +89,7 @@ class InvoiceController extends BaseController | ||||
|      * @param  int  $id | ||||
|      * @return \Illuminate\Http\Response | ||||
|      */ | ||||
|     public function show($id) | ||||
|     public function show(ShowInvoiceRequest $request) | ||||
|     { | ||||
|         //
 | ||||
|     } | ||||
| @ -91,7 +100,7 @@ class InvoiceController extends BaseController | ||||
|      * @param  int  $id | ||||
|      * @return \Illuminate\Http\Response | ||||
|      */ | ||||
|     public function edit($id) | ||||
|     public function edit(EditInvoiceRequest) | ||||
|     { | ||||
|         //
 | ||||
|     } | ||||
| @ -103,7 +112,7 @@ class InvoiceController extends BaseController | ||||
|      * @param  int  $id | ||||
|      * @return \Illuminate\Http\Response | ||||
|      */ | ||||
|     public function update(Request $request, $id) | ||||
|     public function update(UpdateInvoiceRequest $request) | ||||
|     { | ||||
|         //
 | ||||
|     } | ||||
| @ -114,7 +123,7 @@ class InvoiceController extends BaseController | ||||
|      * @param  int  $id | ||||
|      * @return \Illuminate\Http\Response | ||||
|      */ | ||||
|     public function destroy($id) | ||||
|     public function destroy(DestroyInvoiceRequest $request, Invoice $invoice) | ||||
|     { | ||||
|         //
 | ||||
|     } | ||||
|  | ||||
| @ -13,7 +13,7 @@ class EditClientRequest extends Request | ||||
|      * @return bool | ||||
|      */ | ||||
| 
 | ||||
|     public function authorize() | ||||
|     public function authorize() : bool | ||||
|     { | ||||
|         return auth()->user()->can('edit', $this->client); | ||||
|     } | ||||
|  | ||||
| @ -2,15 +2,17 @@ | ||||
| 
 | ||||
| namespace App\Repositories; | ||||
| 
 | ||||
| use App\Helpers\Invoice\InvoiceCalc; | ||||
| use App\Models\Invoice; | ||||
| use Illuminate\Http\Request; | ||||
| 
 | ||||
| /** | ||||
|  *  | ||||
|  * InvoiceRepository | ||||
|  */ | ||||
| class InvoiceRepository extends BaseRepository | ||||
| { | ||||
| 
 | ||||
| 
 | ||||
|     public function getClassName() | ||||
|     { | ||||
|         return Invoice::class; | ||||
| @ -21,6 +23,8 @@ class InvoiceRepository extends BaseRepository | ||||
|         $invoice->fill($request->input()); | ||||
|         $invoice->save(); | ||||
| 
 | ||||
| 
 | ||||
|         $invoice_calc = new InvoiceCalc($invoice, $invoice->settings); | ||||
|         return $invoice; | ||||
| 	} | ||||
| 
 | ||||
|  | ||||
| @ -21,7 +21,6 @@ $factory->define(App\Models\Invoice::class, function (Faker $faker) { | ||||
| 		'invoice_date' => $faker->date(), | ||||
| 		'due_date' => $faker->date(), | ||||
| 		'line_items' => false, | ||||
| 		'options' => '', | ||||
| 		'backup' => '',  | ||||
|     ]; | ||||
| }); | ||||
| @ -111,7 +111,7 @@ class ClientTest extends TestCase | ||||
|         $this->assertNotNull($company); | ||||
|         $this->assertNotNull($user->tokens->first()->company); | ||||
| 
 | ||||
|         factory(\App\Models\Client::class, 20)->create(['user_id' => $user->id, 'company_id' => $company->id])->each(function ($c) use ($user, $company){ | ||||
|         factory(\App\Models\Client::class, 5)->create(['user_id' => $user->id, 'company_id' => $company->id])->each(function ($c) use ($user, $company){ | ||||
| 
 | ||||
|             factory(\App\Models\ClientContact::class,1)->create([ | ||||
|                 'user_id' => $user->id, | ||||
| @ -120,7 +120,7 @@ class ClientTest extends TestCase | ||||
|                 'is_primary' => 1 | ||||
|             ]); | ||||
| 
 | ||||
|             factory(\App\Models\ClientContact::class,10)->create([ | ||||
|             factory(\App\Models\ClientContact::class,2)->create([ | ||||
|                 'user_id' => $user->id, | ||||
|                 'client_id' => $c->id, | ||||
|                 'company_id' => $company->id | ||||
| @ -162,7 +162,7 @@ class ClientTest extends TestCase | ||||
|             ])->delete('/api/v1/clients/'.$this->encodePrimaryKey($client->id)); | ||||
| 
 | ||||
|         $response->assertStatus(200); | ||||
| 
 | ||||
| /* | ||||
| 
 | ||||
|         $response = $this->withHeaders([ | ||||
|             'X-API-SECRET' => config('ninja.api_secret'), | ||||
| @ -173,7 +173,7 @@ class ClientTest extends TestCase | ||||
| 
 | ||||
|         $response->assertStatus(200); | ||||
| 
 | ||||
| */ | ||||
|         } | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
|  | ||||
| @ -25,12 +25,11 @@ class InvoiceTest extends TestCase | ||||
|      | ||||
|     parent::setUp(); | ||||
| 	 | ||||
| 		$this->invoice = InvoiceFactory::create(); | ||||
| 		$this->invoice = InvoiceFactory::create(1,1);//stub the company and user_id
 | ||||
| 		$this->invoice->line_items = $this->buildLineItems(); | ||||
| 
 | ||||
| 		$this->settings = $this->buildSettings(); | ||||
| 
 | ||||
| 		$this->invoice_calc = new InvoiceCalc($this->invoice, $this->settings); | ||||
| 		$this->invoice->settings = $this->buildSettings(); | ||||
| 		$this->invoice_calc = new InvoiceCalc($this->invoice); | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| @ -119,9 +118,9 @@ class InvoiceTest extends TestCase | ||||
| 		$this->invoice->custom_value1 = 5; | ||||
| 		$this->invoice->tax_name1 = 'GST'; | ||||
| 		$this->invoice->tax_rate1 = 10; | ||||
| 		$this->settings->inclusive_taxes = false; | ||||
| 		$this->invoice->settings->inclusive_taxes = false; | ||||
| 
 | ||||
| 		$this->invoice_calc = new InvoiceCalc($this->invoice, $this->settings); | ||||
| 		$this->invoice_calc = new InvoiceCalc($this->invoice); | ||||
| 
 | ||||
| 		$this->invoice_calc->build(); | ||||
| 
 | ||||
| @ -134,7 +133,7 @@ class InvoiceTest extends TestCase | ||||
| 	public function testInvoiceTotalsWithDiscountWithSurchargeWithDoubleExclusiveTax() | ||||
| 	{ | ||||
| 
 | ||||
| 		$this->invoice_calc = new InvoiceCalc($this->invoice, $this->settings); | ||||
| 		$this->invoice_calc = new InvoiceCalc($this->invoice); | ||||
| 
 | ||||
| 		$this->invoice->discount = 5; | ||||
| 		$this->invoice->custom_value1 = 5; | ||||
| @ -142,7 +141,7 @@ class InvoiceTest extends TestCase | ||||
| 		$this->invoice->tax_rate1 = 10; | ||||
| 		$this->invoice->tax_name2 = 'GST'; | ||||
| 		$this->invoice->tax_rate2 = 10; | ||||
| 		$this->settings->inclusive_taxes = false; | ||||
| 		$this->invoice->settings->inclusive_taxes = false; | ||||
| 
 | ||||
| 		$this->invoice_calc->build(); | ||||
| 
 | ||||
| @ -174,11 +173,11 @@ class InvoiceTest extends TestCase | ||||
| 		$line_items[] = $item; | ||||
| 
 | ||||
| 		$this->invoice->line_items = $line_items; | ||||
| 		$this->settings->inclusive_taxes = true; | ||||
| 		$this->invoice->settings->inclusive_taxes = true; | ||||
| 		$this->invoice->discount = 0; | ||||
| 		$this->invoice->custom_value1 = 0; | ||||
| 
 | ||||
| 		$this->invoice_calc = new InvoiceCalc($this->invoice, $this->settings); | ||||
| 		$this->invoice_calc = new InvoiceCalc($this->invoice); | ||||
| 		$this->invoice_calc->build(); | ||||
| 
 | ||||
| 		$this->assertEquals($this->invoice_calc->getSubTotal(), 20); | ||||
| @ -216,8 +215,8 @@ class InvoiceTest extends TestCase | ||||
| 		$this->invoice->tax_name2 = 'GST'; | ||||
| 		$this->invoice->tax_rate2 = 10; | ||||
| 
 | ||||
| 		$this->settings->inclusive_taxes = false; | ||||
| 		$this->invoice_calc = new InvoiceCalc($this->invoice, $this->settings); | ||||
| 		$this->invoice->settings->inclusive_taxes = false; | ||||
| 		$this->invoice_calc = new InvoiceCalc($this->invoice); | ||||
| 		$this->invoice_calc->build(); | ||||
| 
 | ||||
| 		$this->assertEquals($this->invoice_calc->getSubTotal(), 20); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user