Commit 591ef1ff by Angel MAS

cobro con mercado pago

parent ddacbe0d
...@@ -13,7 +13,7 @@ use Onestartup\Shop\Model\ClientShop as Client; ...@@ -13,7 +13,7 @@ use Onestartup\Shop\Model\ClientShop as Client;
use Onestartup\Shop\Model\ShippingAddres as Addres; use Onestartup\Shop\Model\ShippingAddres as Addres;
use Onestartup\Shop\Model\SaleShop as Sale; use Onestartup\Shop\Model\SaleShop as Sale;
use Onestartup\Shop\Model\DetailShop as Item; use Onestartup\Shop\Model\DetailShop as Item;
use Onestartup\Shop\Payment\MP;
class CartController extends Controller class CartController extends Controller
{ {
...@@ -98,7 +98,10 @@ class CartController extends Controller ...@@ -98,7 +98,10 @@ class CartController extends Controller
public function shipping() public function shipping()
{ {
//\Session::forget('client'); /*\Session::forget('client');
\Session::forget('cart');
\Session::forget('sale');*/
$client = new Client(); $client = new Client();
$addres = new Addres(); $addres = new Addres();
...@@ -132,6 +135,11 @@ class CartController extends Controller ...@@ -132,6 +135,11 @@ class CartController extends Controller
if(\Session::has('client')) { if(\Session::has('client')) {
$client = \Session::get('client'); $client = \Session::get('client');
$addres = $client->shipping; $addres = $client->shipping;
if (\Session::get('client')->email != $request->email) {
$client = new Client();
$addres = new Addres();
}
} }
/** Crea cliente ········· */ /** Crea cliente ········· */
...@@ -210,6 +218,88 @@ class CartController extends Controller ...@@ -210,6 +218,88 @@ class CartController extends Controller
} }
public function payment(Request $request)
{
if (!\Session::has('client')) {
return redirect()->route('cart.shipping');
}
if (!\Session::has('sale')) {
return redirect()->route('cart.shipping');
}
$sale = Sale::find(\Session::get('sale')->id);
$client = $sale->client;
$items = $sale->items;
$addres = $client->shipping;
$detail = '';
foreach ($sale->items as $item) {
$detail = $detail." ".$item->quantity." ".$item->product->name.", ";
}
$detail = $detail." Envio ". $addres->shipping_price->name ." $". $addres->shipping_price->cost .".00";
$mp = new MP('TEST-7957752184054483-101318-9bbc7ef53f975318d2521f05257cb66a__LB_LC__-60150825');
$payment_data = array(
"transaction_amount" => $this->total() + $addres->shipping_price->cost,
"token" => $request->card_token_id,
"description" => $detail,
"installments" => 1,
"payment_method_id" => $request->paymentMethodId,
"payer" => array (
"email" => $client->email,
"first_name"=>$client->name,
)
);
$payment = $mp->post("/v1/payments", $payment_data);
if ($payment['response']['status'] == 'approved') {
$sale->status = 2;
$sale->transaction_id = $payment['response']['id'];
$sale->save();
\Session::forget('client');
\Session::forget('cart');
\Session::forget('sale');
return redirect()
->route('main.shop')
->with('payment_approved', 'payment_approved');
} elseif ($payment['response']['status'] == 'in_process') {
$sale->status = 3;
$sale->transaction_id = $payment['response']['id'];
$sale->save();
\Session::forget('client');
\Session::forget('cart');
\Session::forget('sale');
return redirect()
->route('main.shop')
->with('payment_pending', 'payment_pending');
} else {
return redirect()
->back()
->with('payment_reject', 'payment_reject');
}
//dd($payment);
return $request;
}
private function total() private function total()
{ {
......
This source diff could not be displayed because it is too large. You can view the blob instead.
...@@ -16,6 +16,7 @@ class CreateSaleShopsTable extends Migration ...@@ -16,6 +16,7 @@ class CreateSaleShopsTable extends Migration
Schema::create('sale_shops', function (Blueprint $table) { Schema::create('sale_shops', function (Blueprint $table) {
$table->increments('id'); $table->increments('id');
$table->string('transaction_id', 455)->nullable();
$table->tinyInteger('status'); $table->tinyInteger('status');
$table->float('total'); $table->float('total');
......
...@@ -7,7 +7,7 @@ use Illuminate\Database\Eloquent\Model; ...@@ -7,7 +7,7 @@ use Illuminate\Database\Eloquent\Model;
class SaleShop extends Model class SaleShop extends Model
{ {
protected $table = 'sale_shops'; protected $table = 'sale_shops';
protected $fillable = ['status', 'total', 'client_id']; protected $fillable = ['status', 'total', 'client_id', 'transaction_id'];
public function client() public function client()
......
...@@ -59,6 +59,8 @@ Route::group(['middleware' => ['web']], function(){ ...@@ -59,6 +59,8 @@ Route::group(['middleware' => ['web']], function(){
Route::get('cart/cancel', 'Onestartup\Shop\Controller\CartController@cancel')->name('cart.cancel'); Route::get('cart/cancel', 'Onestartup\Shop\Controller\CartController@cancel')->name('cart.cancel');
Route::post('cart/store/client', 'Onestartup\Shop\Controller\CartController@storeClient')->name('cart.store.client'); Route::post('cart/store/client', 'Onestartup\Shop\Controller\CartController@storeClient')->name('cart.store.client');
Route::post('cart/payment', 'Onestartup\Shop\Controller\CartController@payment')->name('cart.payment');
Route::get('cart/update/{product_slug}/{quantity}', 'Onestartup\Shop\Controller\CartController@update') Route::get('cart/update/{product_slug}/{quantity}', 'Onestartup\Shop\Controller\CartController@update')
->where('quantity', '[0-9]+') ->where('quantity', '[0-9]+')
->name('cart.update'); ->name('cart.update');
......
@extends('shop-public::layout') @extends('shop-public::layout')
@section('pageTitle', 'Finalizar compra') @section('pageTitle', 'Finalizar compra')
@section('content') @section('content')
@php @php
setlocale(LC_MONETARY, 'en_US'); setlocale(LC_MONETARY, 'en_US');
@endphp @endphp
<code> <code>
Variables disponibles: Variables disponibles:
<ul> <ul>
...@@ -54,16 +56,124 @@ setlocale(LC_MONETARY, 'en_US'); ...@@ -54,16 +56,124 @@ setlocale(LC_MONETARY, 'en_US');
<section> <section>
<h4>Formulario de pago</h4> <h4>Formulario de pago</h4>
<pre>
form
</pre>
</section>
@include('shop-public::forms.fields-payment')
</section>
@endsection @endsection
@section('scripts_extra') @section('scripts_extra')
<script type="text/javascript">
Mercadopago.setPublishableKey("TEST-73a8fe53-17bf-4060-b2b8-a069cc779a11");
$("#form-pagar-mp").submit(function( event ) {
$('.btn-submit').attr('disabled', 'disabled');
swal({
text: "Espera por favor, estamos enviando tu pago...",
imageUrl: "/assets/img/ripple.gif",
showConfirmButton: false,
allowEscapeKey: false,
allowOutsideClick: false,
closeOnConfirm: false,
closeOnCancel: false
});
var $form = $(this);
Mercadopago.createToken($form, mpResponseHandler);
event.preventDefault();
return false;
});
var mpResponseHandler = function(status, response) {
var $form = $('#form-pagar-mp');
if (response.error) {
alert("ocurri&oacute; un error: "+JSON.stringify(response));
console.log(response);
swal.close();
var error = '<div class="alert alert-dismissable alert-danger">'+
'<button type="button" class="close" data-dismiss="alert" aria-hidden="true">&times;</button>'+
'Haz ingresado valores invalidos: <br>Revisa los datos capturados o intenta con otra tarjeta'+
'</div>';
$("#errors-card").html(error);
$('.btn-submit').removeAttr('disabled');
} else {
var card_token_id = response.id;
$form.append($('<input type="hidden" id="card_token_id" name="card_token_id"/>').val(card_token_id));
//alert("card_token_id: "+card_token_id);
$("#errors-card").html("");
$form.get(0).submit();
}
}
function addEvent(el, eventName, handler){
if (el.addEventListener) {
el.addEventListener(eventName, handler);
} else {
el.attachEvent('on' + eventName, function(){
handler.call(el);
});
}
};
function getBin() {
var ccNumber = document.querySelector('input[data-checkout="cardNumber"]');
return ccNumber.value.replace(/[ .-]/g, '').slice(0, 6);
};
function guessingPaymentMethod(event) {
var bin = getBin();
if (event.type == "keyup") {
if (bin.length >= 6) {
Mercadopago.getPaymentMethod({
"bin": bin
}, setPaymentMethodInfo);
}
} else {
setTimeout(function() {
if (bin.length >= 6) {
Mercadopago.getPaymentMethod({
"bin": bin
}, setPaymentMethodInfo);
}
}, 100);
}
};
function setPaymentMethodInfo(status, response) {
console.log("holiholi");
if (status == 200) {
// do somethings ex: show logo of the payment method
var form = document.querySelector('#form-pagar-mp');
if (document.querySelector("input[name=paymentMethodId]") == null) {
var paymentMethod = document.createElement('input');
paymentMethod.setAttribute('name', "paymentMethodId");
paymentMethod.setAttribute('type', "hidden");
paymentMethod.setAttribute('value', response[0].id);
form.appendChild(paymentMethod);
} else {
document.querySelector("input[name=paymentMethodId]").value = response[0].id;
}
}
};
addEvent(document.querySelector('input[data-checkout="cardNumber"]'), 'keyup', guessingPaymentMethod);
addEvent(document.querySelector('input[data-checkout="cardNumber"]'), 'change', guessingPaymentMethod);
</script>
@endsection @endsection
\ No newline at end of file
<form action="{{route('cart.payment')}}" method="POST" id="form-pagar-mp">
{{ csrf_field() }}
<p>Número de tarjeta</p>
<input type="text" id="cardNumber" data-checkout="cardNumber" placeholder="4509 9535 6623 3704" size="16" name="number" required="required" class="form-control" min="16" max="16" />
<p>Nombre del titular</p>
<input type="text" size="20" name="name" data-checkout="cardholderName" placeholder="Ej. Roberto Carlos" required="required" class="form-control" />
<p>Fecha de expiración</p>
<input type="text" size="2" name="month" data-checkout="cardExpirationMonth" placeholder="Ej. 09" required="required" class="form-control" align="right" />
<input type="text" size="4" name="year" data-checkout="cardExpirationYear" placeholder="Ej. 2018" required="required" class="form-control" align="left"/>
<p>Código de seguridad</p>
<input class="form-white" type="text" size="4" name="cvc" data-checkout="securityCode" placeholder="Ej. 543" required="required" class="form-control"/>
<input name="paymentMethodId" type="hidden">
<button type="submit">
Pagar {{ money_format('%(#10n', ($total + $addres->shipping_price->cost)) }}
</button>
</form>
\ No newline at end of file
...@@ -25,8 +25,27 @@ ...@@ -25,8 +25,27 @@
integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8="
crossorigin="anonymous"></script> crossorigin="anonymous"></script>
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/jquery-steps/1.1.0/jquery.steps.min.js"></script> <script src="https://secure.mlstatic.com/sdk/javascript/v1/mercadopago.js"></script>
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/jquery-validate/1.17.0/jquery.validate.js"></script>
{{-- Mensajes de alerta de pagos --}}
@if(Session::has('payment_approved'))
<script type="text/javascript">
swal("Gracias por tu compra", "El pago ha sido aceptado, revisa tu correo", "success")
</script>
@endif
@if(Session::has('payment_reject'))
<script type="text/javascript">
swal("Pago rechazado", "Tuvimos problemas para procesar tu pago, verifica tus datos o intenta con otra tarjeta", "error")
</script>
@endif
@if(Session::has('payment_pending'))
<script type="text/javascript">
swal("Pago pendiente", "Estamos procesando tu pago, te notificaremos por correo el estatus", "warning")
</script>
@endif
<!-- ******************************************* --> <!-- ******************************************* -->
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment