pretienda

This commit is contained in:
mynah
2019-04-04 19:45:51 -06:00
parent 49b1256e27
commit 567e991278
10 changed files with 256 additions and 11 deletions

View File

@@ -27,7 +27,8 @@ use Dojo::Model::Users;
$r->any('/contact')->to('home#contact');
$r->any('/contact2')->to('home#contact2');
$r->any('/pang')->to('home#pang');
# $r->any('/tst')->to('home#tst');
$r->any('/storep')->to('home#storep');
$r->any('/storep/:id' => [id => qr/\d+/])->to('home#storep');
# =============================================================================

View File

@@ -43,9 +43,9 @@ sub tst{
# interesan create time, id, payer: email address, shippng address
}
else{
my %f=('descripcion',' Había una vez un lobito bueno al que maltrataban todos los corderos','precio','33','promo','si!','existencia','3','nombre','Super master evil man','titulo'=>'venganzas del medievo');
$c->stash(%f);
$c->stash(res=> "no");
my $data=$c->dbg->store_id($c->param('id'));
$c->redirect_to('store') unless ($data->{'id'});
$c->stash($data);
$c->stash(layout=>'default');
}
#$c->render(text=> $c->config->{radio}{'channel'});
@@ -85,7 +85,9 @@ sub cal {
sub event{
my $c = shift;
$c->stash($c->dbv->event($c->param("id")));
my $data=$c->dbv->event($c->param('id'));
$c->redirect_to('cal') unless ($data->{'cname'});
$c->stash($data);
$c->stash(layout=> "defaultContact");
}
@@ -118,6 +120,50 @@ sub store{
$c->stash(layout=> "defaultContact");
}
sub storep{
my $c=shift;
if( defined($c->req->json) ){
my $oid = $c->req->json->{'orderID'} //0;
log( $oid );
#credentials====
my $client='AQdZ1JJL-GNBgGTI3W6cXChmj6MnZsInRGlWeHw1kbGiE_49eTtZ2fPvEq9ersU2y6O5WpxccdsyAQw7';
my $secter='EBn8CNOCrJbVZ_fNllXB7oUIm9_vhtqrJMm2zSBGbxSyiiych3cHOIWOLAD5NVw4Z3dmNhmsHQwPsrZ0';
my $pauth='https://api.sandbox.paypal.com/v1/oauth2/token/';
my $porder='https://api.sandbox.paypal.com/v2/checkout/orders/';
#=================
#pre auth ====
my $ua = LWP::UserAgent->new;
my $req=POST $pauth, ["grant_type"=>"client_credentials"];
$req->authorization_basic($client,$secter);
$req->content_type('application/x-www-form-urlencoded');
my $res=$ua->request($req);
log("paypal pre auth error! $res->status_line") unless ($res->is_success );
my $json = JSON->new->utf8;
my $r=$json->decode($res->decoded_content);
#==============
#order details ====
my $ub = LWP::UserAgent->new;
$ub->default_header('Content-Type'=> 'application/json' );
$ub->default_header('Authorization'=> 'Bearer ' . $r->{access_token} );
my $resb=$ub->get($porder.$oid);
log("paypal checkout error!") unless ($resb->is_success );
my $jsonb = JSON->new->utf8;
my $s=$jsonb->decode($resb->decoded_content);
#===================
$c->rendered(200); #es default,nomas para enfatizar que puede ser 400 o 500
# interesan create time, id, payer: email address, shippng address
}
else{
my $data=$c->dbg->store_id($c->param('id'));
$c->redirect_to('cal') if ($c->param('id')==4);
$c->redirect_to('store') unless ($data->{'id'});
$c->stash($data);
$c->stash(layout=>'default');
}
}
sub tv{
my $c = shift;
$c->stash( videos=>$c->dbv->tv_videos, table=>$c->dbv->tv_series);

View File

@@ -0,0 +1,14 @@
select
id,
objeto,
nombre,
precio,
subnombre,
promocion,
opcion,
descripcion,
imagenb as "imagen",
existencia,
entrega_id "entrega_id"
from tienda where id=? and activo =1;

View File

@@ -62,6 +62,11 @@ sub store{
return _read ($data_path->child("/store/qStore.q")->slurp);
}
sub store_id{
my ($self,$id)=@_;
return _read ($data_path->child("/store/qIdStore.q")->slurp,$id)->[0];
}
sub _read{
my ($q,@bind)=@_;
my (@empty,$arr);

View File

@@ -6,8 +6,6 @@ article.heading{
background-color: #333333;
text-align: center;
margin-top: 50px;
}
p.heading{
font-size:5em;
@@ -20,6 +18,17 @@ article.shop{
-webkit-justify-content:center;
margin-top: 40px;
}
article.shop:hover{
background-color:rgba(240,240,240);
cursor:pointer;
}
a:link, a:visited {
text-decoration: none;
color:unset;
}
div.simage{
flex:3;
max-width:350px;
@@ -50,3 +59,4 @@ article.separator{
margin-top:30px;
}

BIN
public/home/storep/grulla_10.jpg Executable file

Binary file not shown.

After

Width:  |  Height:  |  Size: 493 KiB

106
public/home/storep/storep.css Executable file
View File

@@ -0,0 +1,106 @@
section.item{
background-size:cover;
background-attachment: fixed;
background-image:url("grulla_10.jpg");
background-position:center;
display:block;
padding:50px 0px 0px 0px;
}
section.transp{
background-color:rgba(255,255,255,0.8);
max-width: 1000px;
margin: auto;
padding: 20px 0px;
}
article.iimage{
flex:5 1;
margin:auto;
display:inline;
padding:0px 5px;
}
img.small{
border-radius:20px;
display:block;
width:auto;
height:100%;
min-height:60vh;
margin:auto;
padding:15px;
}
article.iinfo{
flex:4 1;
margin:auto;
padding: 5px 15px;
}
p.txt{
background-color:white;
font-size:1.2em;
padding: 20px;
text-align: center;
}
section.ibottom{
background: #C22A39;
padding:40px;
}
section.description{
background-color:white;
justify-content: center;
-webkit-justify-content: center;
}
p.promo{
color: #c22a39;
font-size: 1.4em;
text-align:right;
margin-right:10%;
font-weight:bold;
}
p.elow{
color: black;
font-size: 1.4em;
text-align:right;
margin-right:10%;
}
p.eldep{
color: #c22a39;
font-size: 1.4em;
text-align:right;
text-transform: uppercase;
margin-right:10%;
font-weight:bold;
}
div.ppl{
background-color: rgba(0,0,0,0.8);
border-radius: 25px;
padding:20px;
text-align: center;
}
p.nombre{
font-size: 2.2em;
color: white;
text-align: left;
margin: auto;
text-decoration: underline;
max-width:850px;
font-weight:bold;
}
p.tit{
font-size: 1.8em;
color: white;
text-align: center;
margin: 30px auto;
font-style: italic;
}

View File

@@ -2,6 +2,7 @@
<section class="shop">
<article class="heading"> <p class="heading">TIENDA VIRTUAL</p> </article>
% for (@$r){
<a href="/storep/<%= $_->{id} %>">
<article class="shop flex">
<div class="simage" > <img src=<%= "$controller/$action/img/$_->{imagen} "%> ></div>
<div class="description">
@@ -14,6 +15,7 @@
<p class="promo"> <%= $_->{promocion} %> </p>
</div>
</article>
</a>
<article class="separator"></article>
%}
</section>

60
templates/home/storep.html.ep Executable file
View File

@@ -0,0 +1,60 @@
<!--<head>-->
<!--<meta name="viewport" content="width=device-width, initial-scale=1">-->
<!--<meta http-equiv="X-UA-Compatible" content="IE=edge" />-->
<!--</head>-->
%stash css=>["/home/storep/storep.css"];
<section class="item"> <section class="transp flex">
<article class=iimage>
<img class="small" src= "/home/store/img/<%= $imagen %>">
</article>
<article class=iinfo>
<p class="txt"><%= $subnombre %></p>
<p class="txt"><%= $descripcion %></p>
<p class="promo"><%= $promocion %></p>
<p class="precio">Precio:$<%= $precio %> pesos</p>
<p class="existencia">
<% if ($existencia > 10) { =%> <p class="eok"></p> <% } =%>
<% elsif ($existencia >= 1) { =%> <p class="elow">¡Nos quedan pocos!</p> <% } =%>
<% elsif ($existencia == 0) { =%> <p class="eldep">¡Agotado!</p> <% } =%>
<div class=ppl>
<div id="paypal-button-container"></div>
</div>
</article>
</section> </section>
<section class="ibottom">
<p class="nombre"><%= $objeto %></p>
<p class="tit"><%= $nombre %></p>
</section>
<section class="bdat"> </section>
<script src="https://www.paypal.com/sdk/js?client-id=AQdZ1JJL-GNBgGTI3W6cXChmj6MnZsInRGlWeHw1kbGiE_49eTtZ2fPvEq9ersU2y6O5WpxccdsyAQw7&currency=MXN"></script>
<script>
paypal.Buttons({
// Set up the transaction
createOrder: function(data, actions) {
return actions.order.create({
purchase_units: [{
amount: {
value: '0.18'
}
}]
}); },
onApprove: function(data, actions) {
return actions.order.capture().then(function(details) {
return fetch('/tst', {
method: 'post',
headers: {
'content-type': 'application/json'
},
body: JSON.stringify({
orderID: data.orderID
})
})
// .then(response=>response.json())
// .then(data => {alert(data)})
});
}
}).render('#paypal-button-container');
</script>

View File

@@ -5,11 +5,12 @@
%stash css=>["/home/tst/tst.css"];
<section class="item"> <section class="transp flex">
<article class=iimage>
<img class="small" src= "home/store/img/libro.jpg">
<img class="small" src= "/home/store/img/<%= $imagen %>">
</article>
<article class=iinfo>
<p class="txt"><%= $subnombre %></p>
<p class="txt"><%= $descripcion %></p>
<p class="promo"><%= $promo %></p>
<p class="promo"><%= $promocion %></p>
<p class="precio">Precio:$<%= $precio %> pesos</p>
<p class="existencia">
<% if ($existencia > 10) { =%> <p class="eok"></p> <% } =%>
@@ -21,8 +22,8 @@
</article>
</section> </section>
<section class="ibottom">
<p class="nombre"><%= $nombre %></p>
<p class="tit"><%= $titulo %></p>
<p class="nombre"><%= $objeto %></p>
<p class="tit"><%= $nombre %></p>
</section>
<section class="bdat"> </section>