diff --git a/app/Http/Controllers/InvoiceApiController.php b/app/Http/Controllers/InvoiceApiController.php index 1304c4226654..fdace861b768 100644 --- a/app/Http/Controllers/InvoiceApiController.php +++ b/app/Http/Controllers/InvoiceApiController.php @@ -249,6 +249,26 @@ class InvoiceApiController extends BaseAPIController return $item; } + public function emailInvoicev2() + { + $data = Input::all(); + $error = null; + + $invoice = Invoice::scope($data['id'])->firstOrFail(); + + $this->mailer->sendInvoice($invoice); + + if($error) { + $response['error'] = "There was an error sending the invoice"; + } + else { + $response = json_encode(RESULT_SUCCESS, JSON_PRETTY_PRINT); + } + + $headers = Utils::getApiHeaders(); + return Response::make($response, $error ? 400 : 200, $headers); + } + public function emailInvoice() { $data = Input::all(); diff --git a/app/Http/Controllers/ProductApiController.php b/app/Http/Controllers/ProductApiController.php new file mode 100644 index 000000000000..7aef42393b8d --- /dev/null +++ b/app/Http/Controllers/ProductApiController.php @@ -0,0 +1,88 @@ +productService = $productService; + } + + public function index() + { + + $products = Product::scope()->withTrashed(); + $products = $products->paginate(); + + $paginator = Product::scope()->withTrashed()->paginate(); + + $transformer = new ProductTransformer(\Auth::user()->account, $this->serializer); + $data = $this->createCollection($products, $transformer, 'products', $paginator); + + return $this->response($data); + + } + + public function getDatatable() + { + return $this->productService->getDatatable(Auth::user()->account_id); + } + + public function store() + { + return $this->save(); + } + + public function update($publicId) + { + return $this->save($publicId); + } + + public function destroy($publicId) + { + //stub + } + + private function save($productPublicId = false) + { + if ($productPublicId) { + $product = Product::scope($productPublicId)->firstOrFail(); + } else { + $product = Product::createNew(); + } + + $product->product_key = trim(Input::get('product_key')); + $product->notes = trim(Input::get('notes')); + $product->cost = trim(Input::get('cost')); + //$product->default_tax_rate_id = Input::get('default_tax_rate_id'); + + $product->save(); + + $transformer = new ProductTransformer(\Auth::user()->account, Input::get('serializer')); + $data = $this->createItem($product, $transformer, 'products'); + + return $this->response($data); + + } + + +} diff --git a/app/Http/Middleware/VerifyCsrfToken.php b/app/Http/Middleware/VerifyCsrfToken.php index b0f44b79a076..15eeb65c7a8a 100644 --- a/app/Http/Middleware/VerifyCsrfToken.php +++ b/app/Http/Middleware/VerifyCsrfToken.php @@ -7,6 +7,7 @@ class VerifyCsrfToken extends BaseVerifier { private $openRoutes = [ 'signup/register', + 'api/v1/*', 'api/v1/login', 'api/v1/clients/*', 'api/v1/clients', diff --git a/app/Http/routes.php b/app/Http/routes.php index 5d3748153a57..3582c1c83936 100644 --- a/app/Http/routes.php +++ b/app/Http/routes.php @@ -230,7 +230,9 @@ Route::group(['middleware' => 'api', 'prefix' => 'api/v1'], function() Route::resource('tasks', 'TaskApiController'); Route::post('hooks', 'IntegrationController@subscribe'); Route::post('email_invoice', 'InvoiceApiController@emailInvoice'); + Route::post('email_invoicev2', 'InvoiceApiController@emailInvoicev2'); Route::get('user_accounts','AccountApiController@getUserAccounts'); + Route::resource('products', 'ProductApiController'); // Vendor Route::resource('vendors', 'VendorApiController'); diff --git a/app/Ninja/Transformers/ContactTransformer.php b/app/Ninja/Transformers/ContactTransformer.php index 75e3620308f6..e404b73660d4 100644 --- a/app/Ninja/Transformers/ContactTransformer.php +++ b/app/Ninja/Transformers/ContactTransformer.php @@ -19,6 +19,7 @@ class ContactTransformer extends EntityTransformer 'phone' => $contact->phone, 'last_login' => $contact->last_login, 'account_key' => $this->account->account_key, + 'send_invoice' => (bool) $contact->send_invoice, ]; } } \ No newline at end of file diff --git a/resources/lang/es_ES/texts.php b/resources/lang/es_ES/texts.php index 6cf331904cbb..c7ff90968f51 100644 --- a/resources/lang/es_ES/texts.php +++ b/resources/lang/es_ES/texts.php @@ -401,7 +401,7 @@ return array( 'hide_paid_to_date' => 'Ocultar valor pagado a la fecha', 'hide_paid_to_date_help' => 'Solo mostrar la opción “Pagado a la fecha” en sus facturas cuando se ha recibido un pago.', 'charge_taxes' => 'Cargar Impuestos', - 'user_management' => 'Gestión de Usuario', + 'user_management' => 'Gestión de Usuarios', 'add_user' => 'Añadir Usuario', 'send_invite' => 'Enviar Invitación', //Context for its use 'sent_invite' => 'Invitación enviada con éxito', @@ -735,7 +735,7 @@ return array( 'invoice_to' => 'Factura para', 'invoice_no' => 'N.º Factura', 'recent_payments' => 'Pagos recientes', - 'outstanding' => 'Destacado', + 'outstanding' => 'Pendiente de Cobro', 'manage_companies' => 'Gestionar compañías', 'total_revenue' => 'Ingresos Totales', @@ -890,7 +890,7 @@ return array( 'quote_is_approved' => 'Este presupuesto esta aprovado', 'apply_credit' => 'Aplicar Crédito', - 'system_settings' => 'Configuraciones de Sistemas', + 'system_settings' => 'Configuración del Sistema', 'archive_token' => 'Archivar Token', 'archived_token' => 'Token archivado', 'archive_user' => 'Archivar Usuario',