Commit 1671dbe8c7f6c25b9ded80adbbf2c8bb36bf53dc
Exists in
master
and in
1 other branch
Merge branch 'master' of http://git.focasoftware.com/angular/autoservicio
Showing
11 changed files
Show diff stats
src/app/app-routing.module.ts
... | ... | @@ -3,11 +3,13 @@ import { Routes, RouterModule } from '@angular/router'; |
3 | 3 | import { HomeComponent } from './components/home/home.component'; |
4 | 4 | import { InicioComponent } from './components/inicio/inicio.component'; |
5 | 5 | import { BusquedaProductosComponent } from './components/busqueda-productos/busqueda-productos.component'; |
6 | +import { ConfirmacionCarritoComponent } from './components/confirmacion-carrito/confirmacion-carrito.component'; | |
6 | 7 | |
7 | 8 | const routes: Routes = [ |
8 | 9 | { path: 'home', component: HomeComponent }, |
9 | 10 | { path: 'inicio', component: InicioComponent }, |
10 | 11 | { path: 'busqueda-productos', component: BusquedaProductosComponent }, |
12 | + { path: 'confirmacion-carrito', component: ConfirmacionCarritoComponent }, | |
11 | 13 | { path: '**', redirectTo: '/home', pathMatch: 'full' }, |
12 | 14 | ]; |
13 | 15 | |
... | ... | @@ -15,4 +17,5 @@ const routes: Routes = [ |
15 | 17 | imports: [RouterModule.forRoot(routes)], |
16 | 18 | exports: [RouterModule] |
17 | 19 | }) |
20 | + | |
18 | 21 | export class AppRoutingModule { } |
src/app/app.module.ts
... | ... | @@ -13,6 +13,7 @@ import { CarouselComponent } from './components/carousel/carousel.component'; |
13 | 13 | import { HomeComponent } from './components/home/home.component'; |
14 | 14 | import { InicioComponent } from './components/inicio/inicio.component'; |
15 | 15 | import { BusquedaProductosComponent } from './components/busqueda-productos/busqueda-productos.component'; |
16 | +import { ConfirmacionCarritoComponent } from './components/confirmacion-carrito/confirmacion-carrito.component'; | |
16 | 17 | //#endregion |
17 | 18 | |
18 | 19 | @NgModule({ |
... | ... | @@ -23,7 +24,8 @@ import { BusquedaProductosComponent } from './components/busqueda-productos/busq |
23 | 24 | CarouselComponent, |
24 | 25 | HomeComponent, |
25 | 26 | InicioComponent, |
26 | - BusquedaProductosComponent | |
27 | + BusquedaProductosComponent, | |
28 | + ConfirmacionCarritoComponent | |
27 | 29 | ], |
28 | 30 | imports: [ |
29 | 31 | BrowserModule, |
src/app/components/busqueda-productos/busqueda-productos.component.html
... | ... | @@ -6,45 +6,104 @@ |
6 | 6 | <!-- NOMBRE DE SECCION --> |
7 | 7 | <div class="row m-0"> |
8 | 8 | <div class="col-12 p-0"> |
9 | - <p class="h5 py-1 bg-light text-muted text-center">Búsqueda</p> | |
9 | + <p class="h5 py-1 bg-light text-muted text-center"> | |
10 | + Búsqueda | |
11 | + <i class="fa fa-search"></i> | |
12 | + </p> | |
10 | 13 | </div> |
11 | 14 | </div> |
12 | 15 | |
13 | - <div class="row m-4 d-flex align-items-center"> | |
16 | + <div class="row m-4 disable-user-select"> | |
14 | 17 | |
15 | - <div class="col-sm-7"> | |
16 | - <!-- SEARCH INPUT --> | |
17 | - <div class="form-group search"> | |
18 | - <span class="fa fa-search form-control-lg form-control-search pl-3"></span> | |
19 | - <input | |
20 | - type="text" | |
21 | - class="form-control form-control-lg rounded-pill px-5" | |
22 | - placeholder="Búsqueda productos"> | |
18 | + <!-- FILTROS --> | |
19 | + <div class="col-sm-2"> | |
20 | + <div class="text-center"> | |
21 | + <p class="font-weight-bold text-muted border-bottom pb-2">Buscar por Categoría</p> | |
23 | 22 | </div> |
23 | + <ul class="list-group"> | |
24 | + <li class="list-group-item list-group-item-action my-1 py-2 h6"> | |
25 | + Combos y Promociones | |
26 | + </li> | |
27 | + <li | |
28 | + class="list-group-item list-group-item-action my-1 p-2 h6 shadow-sm font-weight-bold"> | |
29 | + Todos | |
30 | + </li> | |
31 | + <li | |
32 | + class="list-group-item list-group-item-action my-1 p-2 h6 shadow-sm"> | |
33 | + Bebidas | |
34 | + </li> | |
35 | + <li | |
36 | + class="list-group-item list-group-item-action my-1 p-2 h6 shadow-sm"> | |
37 | + Sandwichería | |
38 | + </li> | |
39 | + <li | |
40 | + class="list-group-item list-group-item-action my-1 p-2 h6 shadow-sm"> | |
41 | + Panaderia | |
42 | + </li> | |
43 | + <li | |
44 | + class="list-group-item list-group-item-action my-1 p-2 h6 shadow-sm"> | |
45 | + Golosinas | |
46 | + </li> | |
47 | + <li | |
48 | + class="list-group-item list-group-item-action my-1 p-2 h6 shadow-sm"> | |
49 | + Tabaqueria | |
50 | + </li> | |
51 | + </ul> | |
52 | + </div> | |
24 | 53 | |
25 | - <div class="row pr-3 vh-50 overflow-scroll"> | |
54 | + <!-- SEARCH INPUT --> | |
55 | + <div class="col-sm-10"> | |
56 | + | |
57 | + <div class="form-group row search"> | |
58 | + <div class="col-sm-10"> | |
59 | + <span class="fa fa-search form-control-lg form-control-search pl-3"></span> | |
60 | + <input | |
61 | + type="text" | |
62 | + class="form-control form-control-lg shadow-sm rounded-pill px-5" | |
63 | + placeholder="Búsqueda productos"> | |
64 | + </div> | |
65 | + <!-- BOTON VOLVER --> | |
66 | + <div class="col-sm-2"> | |
67 | + <button | |
68 | + type="button" | |
69 | + class="btn btn-light btn-lg shadow-sm" | |
70 | + [routerLink]="['/inicio']"> | |
71 | + <span class="font-weight-normal h6">Volver </span> | |
72 | + <i class="fa fa-undo text-warning" aria-hidden="true"></i> | |
73 | + </button> | |
74 | + </div> | |
75 | + </div> | |
76 | + | |
77 | + <!-- LISTA DE PRODUCTOS --> | |
78 | + <div class="row pr-3 vh-50 overflow-scroll disable-user-select"> | |
26 | 79 | <div |
27 | 80 | class="col-4 p-2" |
28 | 81 | *ngFor="let producto of productos"> |
29 | 82 | <div class="card card-effect bg-white rounded-sm shadow border-0"> |
30 | 83 | <img src="../../../assets/img/descarga.jpg" class="card-img-top w-75 m-auto"> |
31 | - <div class="card-body"> | |
32 | - <p class="h5 text-left m-0">{{producto.variable}}</p> | |
33 | - <div class="text-left"> | |
34 | - <p class="m-0"><small>ASDASDSADASDSA</small></p> | |
35 | - <p class="m-0"><small>COD. 1222</small></p> | |
84 | + <div class="card-body p-2"> | |
85 | + <p class="h6 text-left m-0">{{producto.DetArt}}</p> | |
86 | + <div class="row justify-content-between m-0"> | |
87 | + <div class="col-12 p-0"> | |
88 | + <div class="text-left"> | |
89 | + <p class="m-0 h6"><small>{{producto.DetArt}}</small></p> | |
90 | + <p class="m-0 h6"><small>COD. {{producto.CodRub}}</small></p> | |
91 | + </div> | |
92 | + </div> | |
93 | + <div class="col-12 my-auto pt-2 pr-2 p-0"> | |
94 | + <p class="text-right m-0 h6">{{producto.PreVen | currency}}</p> | |
95 | + </div> | |
36 | 96 | </div> |
37 | 97 | </div> |
38 | 98 | </div> |
39 | - | |
40 | 99 | </div> |
41 | 100 | </div> |
42 | - | |
43 | 101 | </div> |
102 | + | |
44 | 103 | </div> |
45 | 104 | |
46 | 105 | </div> |
47 | 106 | |
48 | 107 | <!-- SIDEBAR --> |
49 | 108 | <app-sidebar class="col-3 col-md-2 vh-100 bg-dark text-white"></app-sidebar> |
50 | -</div> | |
51 | 109 | \ No newline at end of file |
110 | +</div> |
src/app/components/confirmacion-carrito/confirmacion-carrito.component.html
... | ... | @@ -0,0 +1,48 @@ |
1 | +<app-header></app-header> | |
2 | +<div class="row"> | |
3 | + <div class="col-10"> | |
4 | + | |
5 | + <!-- NOMBRE DE SECCION --> | |
6 | + <div class="row m-0"> | |
7 | + <div class="col-12 p-0"> | |
8 | + <p class="h5 py-1 bg-light text-muted text-center">Pago <i class="fa fa-usd"></i></p> | |
9 | + </div> | |
10 | + </div> | |
11 | + | |
12 | + <div class="row m-4 d-flex align-items-center"> | |
13 | + <div class="col-4"> | |
14 | + <h1>Mi Compra <i class="fa fa-shopping-cart "></i></h1> | |
15 | + </div> | |
16 | + <div class="col-8"> | |
17 | + <h2>¿Desea finalizar su compra?</h2> | |
18 | + <h3>Por favor, controle y confirme su compra.</h3> | |
19 | + </div> | |
20 | + <div class="col-sm-7"> | |
21 | + | |
22 | + <div class="row pr-3 vh-50 overflow-scroll"> | |
23 | + <div | |
24 | + class="col-4 p-2" | |
25 | + *ngFor="let producto of productos"> | |
26 | + <div class="card card-effect bg-white rounded-sm shadow border-0"> | |
27 | + <img src="../../../assets/img/descarga.jpg" class="card-img-top w-75 m-auto"> | |
28 | + <div class="card-body"> | |
29 | + <p class="h5 text-left m-0">{{producto.variable}}</p> | |
30 | + <div class="text-left"> | |
31 | + <p class="m-0"><small>ASDASDSADASDSA</small></p> | |
32 | + <p class="m-0"><small>COD. 1222</small></p> | |
33 | + <p class="m-0"><strong>$ 563</strong></p> | |
34 | + </div> | |
35 | + </div> | |
36 | + </div> | |
37 | + </div> | |
38 | + </div> | |
39 | + </div> | |
40 | + <div class="col-sm-5"> | |
41 | + <h3>TOTAL: $553</h3> | |
42 | + </div> | |
43 | +</div> | |
44 | + | |
45 | +<!-- SIDEBAR --> | |
46 | +</div> | |
47 | + <app-sidebar class="col-3 col-md-2 vh-100 bg-dark text-white"></app-sidebar> | |
48 | +</div> |
src/app/components/confirmacion-carrito/confirmacion-carrito.component.scss
src/app/components/confirmacion-carrito/confirmacion-carrito.component.spec.ts
... | ... | @@ -0,0 +1,25 @@ |
1 | +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; | |
2 | + | |
3 | +import { ConfirmacionCarritoComponent } from './confirmacion-carrito.component'; | |
4 | + | |
5 | +describe('ConfirmacionCarritoComponent', () => { | |
6 | + let component: ConfirmacionCarritoComponent; | |
7 | + let fixture: ComponentFixture<ConfirmacionCarritoComponent>; | |
8 | + | |
9 | + beforeEach(async(() => { | |
10 | + TestBed.configureTestingModule({ | |
11 | + declarations: [ ConfirmacionCarritoComponent ] | |
12 | + }) | |
13 | + .compileComponents(); | |
14 | + })); | |
15 | + | |
16 | + beforeEach(() => { | |
17 | + fixture = TestBed.createComponent(ConfirmacionCarritoComponent); | |
18 | + component = fixture.componentInstance; | |
19 | + fixture.detectChanges(); | |
20 | + }); | |
21 | + | |
22 | + it('should create', () => { | |
23 | + expect(component).toBeTruthy(); | |
24 | + }); | |
25 | +}); |
src/app/components/confirmacion-carrito/confirmacion-carrito.component.ts
... | ... | @@ -0,0 +1,16 @@ |
1 | +import { Component, OnInit } from '@angular/core'; | |
2 | + | |
3 | +@Component({ | |
4 | + selector: 'app-confirmacion-carrito', | |
5 | + templateUrl: './confirmacion-carrito.component.html', | |
6 | + styleUrls: ['./confirmacion-carrito.component.scss'] | |
7 | +}) | |
8 | +export class ConfirmacionCarritoComponent implements OnInit { | |
9 | + | |
10 | + productos = [{}, {}, {}] | |
11 | + constructor() { } | |
12 | + | |
13 | + ngOnInit() { | |
14 | + } | |
15 | + | |
16 | +} |
src/app/components/inicio/inicio.component.html
... | ... | @@ -10,7 +10,7 @@ |
10 | 10 | </div> |
11 | 11 | </div> |
12 | 12 | |
13 | - <div class="row m-4 d-flex align-items-center"> | |
13 | + <div class="row m-4 d-flex align-items-center disable-user-select"> | |
14 | 14 | <div class="col-md-5 d-flex align-items-end flex-column"> |
15 | 15 | |
16 | 16 | <!-- PROMOCIONES --> |
... | ... | @@ -91,4 +91,4 @@ |
91 | 91 | |
92 | 92 | <!-- SIDEBAR --> |
93 | 93 | <app-sidebar class="col-3 col-md-2 vh-100 bg-dark text-white"></app-sidebar> |
94 | -</div> | |
95 | 94 | \ No newline at end of file |
95 | +</div> |
src/app/components/sidebar/sidebar.component.html
... | ... | @@ -36,7 +36,7 @@ |
36 | 36 | <h3 class="text-dark"><strong>{{total | currency}}</strong></h3> |
37 | 37 | </div> |
38 | 38 | <div class="col 12 p-0"> |
39 | - <button type="button" class="btn btn-light shadow mb-2"><strong>Finalizar y pagar</strong></button> | |
39 | + <button type="button" class="btn btn-light shadow mb-2" routerLink="/confirmacion-carrito"><strong>Finalizar y pagar</strong></button> | |
40 | 40 | <button type="button" class="btn btn-light shadow btn-sm" (click)="clearCar()">Cancelar</button> |
41 | 41 | </div> |
42 | 42 | </div> |
src/assets/scss/bootstrap-override.scss
src/styles.scss
1 | 1 | @import "./assets/scss/animation.scss"; |
2 | +@import "./assets/scss/bootstrap-override.scss"; | |
2 | 3 | |
3 | -html, body { | |
4 | +html, | |
5 | +body { | |
4 | 6 | background-color: rgb(245, 245, 245); |
5 | 7 | overflow: hidden; |
6 | 8 | } |
... | ... | @@ -57,11 +59,11 @@ html, body { |
57 | 59 | outline: 1px solid slategrey; |
58 | 60 | border-radius: 10px; |
59 | 61 | height: 12px; |
60 | - &:active{ | |
62 | + &:active { | |
61 | 63 | -webkit-box-shadow: inset 0 0 8px rgba(255, 0, 0, 0.9); |
62 | 64 | } |
63 | 65 | } |
64 | 66 | &::-webkit-scrollbar-corner { |
65 | 67 | border-radius: 10px; |
66 | 68 | } |
67 | -} | |
68 | 69 | \ No newline at end of file |
70 | +} |