ng-easycommerce-v18 0.0.9 → 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/ec-i18n/es.json +13 -1
- package/esm2022/lib/api/connection.service.mjs +6 -2
- package/esm2022/lib/constants/core.constants.service.mjs +2 -1
- package/esm2022/lib/ec-components/abstractions-components/menu-ec.component.mjs +4 -1
- package/esm2022/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.mjs +11 -6
- package/esm2022/lib/ec-components/blocks-ec/block-form-contact-ec/block-form-contact-ec.component.mjs +5 -3
- package/esm2022/lib/ec-components/breadcrumb-ec/breadcrumb-ec.component.mjs +3 -2
- package/esm2022/lib/ec-components/cart-ec/cart-ec.component.mjs +13 -1
- package/esm2022/lib/ec-components/collection-ec/collection-ec.component.mjs +2 -2
- package/esm2022/lib/ec-components/coupon-ec/coupon-ec.component.mjs +3 -3
- package/esm2022/lib/ec-components/faqs-ec/faqs-ec.component.mjs +35 -0
- package/esm2022/lib/ec-components/filters-ec/filters-ec.component.mjs +11 -2
- package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +10 -8
- package/esm2022/lib/ec-components/index.mjs +6 -4
- package/esm2022/lib/ec-components/product-detail-ec/product-detail-ec.component.mjs +7 -1
- package/esm2022/lib/ec-components/related-products-ec/related-products-ec.component.mjs +43 -72
- package/esm2022/lib/ec-components/reviews-ec/reviews-ec.component.mjs +76 -0
- package/esm2022/lib/ec-components/reviews-form-ec/reviews-form-ec.component.mjs +135 -0
- package/esm2022/lib/ec-components/section-container-ec/section-container-ec.component.mjs +75 -0
- package/esm2022/lib/ec-components/share-ec/share-buttons-ec/index.mjs +6 -0
- package/esm2022/lib/ec-components/share-ec/share-buttons-ec/share-email-ec/share-email-ec.component.mjs +17 -0
- package/esm2022/lib/ec-components/share-ec/share-buttons-ec/share-facebook-ec/share-facebook-ec.component.mjs +17 -0
- package/esm2022/lib/ec-components/share-ec/share-buttons-ec/share-pinterest-ec/share-pinterest-ec.component.mjs +17 -0
- package/esm2022/lib/ec-components/share-ec/share-buttons-ec/share-twitter-ec/share-twitter-ec.component.mjs +17 -0
- package/esm2022/lib/ec-components/share-ec/share-buttons-ec/share-whatsapp-ec/share-whatsapp-ec.component.mjs +17 -0
- package/esm2022/lib/ec-components/share-ec/share-ec.component.mjs +124 -0
- package/esm2022/lib/ec-components/sidebar-ec/sidebar-ec.component.mjs +3 -3
- package/esm2022/lib/ec-components/widgets-ec/rating-ec/rating-ec.component.mjs +74 -0
- package/esm2022/lib/ec-services/auth.service.mjs +3 -3
- package/esm2022/lib/ec-services/cart.service.mjs +16 -1
- package/esm2022/lib/ec-services/filters.service.mjs +28 -13
- package/esm2022/lib/ec-services/options.service.mjs +30 -5
- package/esm2022/lib/ec-services/pagination.service.mjs +12 -5
- package/esm2022/lib/ec-services/products.service.mjs +4 -10
- package/esm2022/lib/ec-services/re-captcha.service.mjs +2 -2
- package/esm2022/lib/ec-services/reviews.service.mjs +98 -0
- package/esm2022/lib/interfaces/faqs.mjs +2 -0
- package/esm2022/lib/interfaces/filter.mjs +1 -1
- package/esm2022/lib/interfaces/index.mjs +2 -1
- package/fesm2022/ng-easycommerce-v18.mjs +830 -134
- package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
- package/lib/api/connection.service.d.ts +1 -0
- package/lib/constants/core.constants.service.d.ts +1 -0
- package/lib/ec-components/abstractions-components/menu-ec.component.d.ts +1 -0
- package/lib/ec-components/blocks-ec/block-form-contact-ec/block-form-contact-ec.component.d.ts +1 -0
- package/lib/ec-components/cart-ec/cart-ec.component.d.ts +3 -0
- package/lib/ec-components/faqs-ec/faqs-ec.component.d.ts +14 -0
- package/lib/ec-components/filters-ec/filters-ec.component.d.ts +3 -0
- package/lib/ec-components/header-ec/header-ec.component.d.ts +1 -1
- package/lib/ec-components/index.d.ts +5 -0
- package/lib/ec-components/product-detail-ec/product-detail-ec.component.d.ts +2 -0
- package/lib/ec-components/related-products-ec/related-products-ec.component.d.ts +21 -24
- package/lib/ec-components/reviews-ec/reviews-ec.component.d.ts +34 -0
- package/lib/ec-components/reviews-form-ec/reviews-form-ec.component.d.ts +64 -0
- package/lib/ec-components/section-container-ec/section-container-ec.component.d.ts +22 -0
- package/lib/ec-components/share-ec/share-buttons-ec/index.d.ts +5 -0
- package/lib/ec-components/share-ec/share-buttons-ec/share-email-ec/share-email-ec.component.d.ts +6 -0
- package/lib/ec-components/share-ec/share-buttons-ec/share-facebook-ec/share-facebook-ec.component.d.ts +6 -0
- package/lib/ec-components/share-ec/share-buttons-ec/share-pinterest-ec/share-pinterest-ec.component.d.ts +6 -0
- package/lib/ec-components/share-ec/share-buttons-ec/share-twitter-ec/share-twitter-ec.component.d.ts +6 -0
- package/lib/ec-components/share-ec/share-buttons-ec/share-whatsapp-ec/share-whatsapp-ec.component.d.ts +6 -0
- package/lib/ec-components/share-ec/share-ec.component.d.ts +27 -0
- package/lib/ec-components/widgets-ec/rating-ec/rating-ec.component.d.ts +31 -0
- package/lib/ec-services/cart.service.d.ts +1 -0
- package/lib/ec-services/filters.service.d.ts +3 -1
- package/lib/ec-services/options.service.d.ts +10 -5
- package/lib/ec-services/pagination.service.d.ts +1 -0
- package/lib/ec-services/products.service.d.ts +1 -1
- package/lib/ec-services/reviews.service.d.ts +74 -0
- package/lib/interfaces/faqs.d.ts +12 -0
- package/lib/interfaces/filter.d.ts +1 -0
- package/lib/interfaces/index.d.ts +1 -0
- package/package.json +1 -1
|
@@ -1,30 +1,32 @@
|
|
|
1
|
-
import { Component, Input,
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
1
|
+
import { Component, inject, Input, CUSTOM_ELEMENTS_SCHEMA, signal, PLATFORM_ID, afterNextRender } from '@angular/core';
|
|
2
|
+
import { AnalyticsService, ProductsService } from '../../ec-services';
|
|
3
|
+
import { Router } from '@angular/router';
|
|
4
|
+
import { BehaviorSubject, take } from 'rxjs';
|
|
5
|
+
import { AsyncPipe, CommonModule, isPlatformBrowser } from '@angular/common';
|
|
6
|
+
import { ProductEcComponent } from '../product-ec/product-ec.component';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
export class RelatedProductsEcComponent extends ComponentHelper {
|
|
11
|
-
productsService;
|
|
12
|
-
analyticsService;
|
|
13
|
-
consts;
|
|
14
|
-
router;
|
|
8
|
+
export class RelatedProductsEcComponent {
|
|
9
|
+
_productsService = inject(ProductsService);
|
|
10
|
+
_analyticsService = inject(AnalyticsService);
|
|
11
|
+
_router = inject(Router);
|
|
15
12
|
/**
|
|
16
|
-
|
|
17
|
-
|
|
13
|
+
* Signal utlizado para guarda el contenedor del carrusel
|
|
14
|
+
*/
|
|
18
15
|
swiperElement = signal(null);
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
16
|
+
/**
|
|
17
|
+
* Input que recibe un template para el producto.
|
|
18
|
+
*/
|
|
19
|
+
appProduct;
|
|
20
|
+
productID;
|
|
22
21
|
document;
|
|
23
|
-
|
|
22
|
+
platformId = inject(PLATFORM_ID);
|
|
23
|
+
_relatedProductsSubject = new BehaviorSubject([]);
|
|
24
|
+
relatedProducts$ = this._relatedProductsSubject.asObservable();
|
|
24
25
|
keywordsToCompare = ['compare', 'comparar', 'comparacion', 'comparación', 'compared'];
|
|
25
|
-
|
|
26
|
+
swiperRelatedOptions = () => {
|
|
26
27
|
return {
|
|
27
28
|
navigation: true,
|
|
29
|
+
loop: true,
|
|
28
30
|
breakpoints: {
|
|
29
31
|
0: {
|
|
30
32
|
slidesPerView: 1
|
|
@@ -44,33 +46,30 @@ export class RelatedProductsEcComponent extends ComponentHelper {
|
|
|
44
46
|
}
|
|
45
47
|
};
|
|
46
48
|
};
|
|
47
|
-
constructor(
|
|
48
|
-
super();
|
|
49
|
-
this.productsService = productsService;
|
|
50
|
-
this.analyticsService = analyticsService;
|
|
51
|
-
this.consts = consts;
|
|
52
|
-
this.router = router;
|
|
49
|
+
constructor() {
|
|
53
50
|
if (isPlatformBrowser(this.platformId)) {
|
|
54
51
|
this.document = document;
|
|
55
52
|
}
|
|
56
53
|
afterNextRender(() => {
|
|
57
|
-
const swiperElemConstructor = this.document?.querySelector('#
|
|
54
|
+
const swiperElemConstructor = this.document?.querySelector('#relatedProductsSwiper');
|
|
55
|
+
console.log('swiperElemConstructor', swiperElemConstructor);
|
|
58
56
|
if (swiperElemConstructor) {
|
|
59
|
-
Object.assign(swiperElemConstructor, this.
|
|
57
|
+
Object.assign(swiperElemConstructor, this.swiperRelatedOptions());
|
|
60
58
|
this.swiperElement.set(swiperElemConstructor);
|
|
61
59
|
this.swiperElement()?.initialize();
|
|
62
60
|
}
|
|
63
61
|
});
|
|
64
|
-
this.ecOnConstruct();
|
|
65
62
|
}
|
|
66
63
|
ngOnInit() {
|
|
67
|
-
|
|
68
|
-
this.
|
|
64
|
+
console.log(this.productID);
|
|
65
|
+
this.load(this.productID);
|
|
69
66
|
}
|
|
70
67
|
load(product_id) {
|
|
71
|
-
this.
|
|
72
|
-
|
|
73
|
-
res.
|
|
68
|
+
this._productsService.getRelatedProducts(product_id).pipe(take(1)).subscribe(res => {
|
|
69
|
+
console.log('response', res);
|
|
70
|
+
const relatedProducts = res.filter((elem) => !this.includeKeyword(elem.title.toLowerCase()));
|
|
71
|
+
this._relatedProductsSubject.next(relatedProducts);
|
|
72
|
+
res.map((products) => this._analyticsService.callEvent('view_item_list', { products: products.items, item_list_name: products.title || 'Related Products', item_list_id: products.id || 'related-products' }));
|
|
74
73
|
});
|
|
75
74
|
}
|
|
76
75
|
includeKeyword = (word) => {
|
|
@@ -80,46 +79,18 @@ export class RelatedProductsEcComponent extends ComponentHelper {
|
|
|
80
79
|
});
|
|
81
80
|
return result;
|
|
82
81
|
};
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
top: 0,
|
|
86
|
-
left: 0,
|
|
87
|
-
behavior: 'smooth'
|
|
88
|
-
});
|
|
89
|
-
this.load(changes['product_id'].currentValue);
|
|
90
|
-
//this.doSomething(changes.categoryId.currentValue);
|
|
91
|
-
// You can also use categoryId.previousValue and
|
|
92
|
-
// categoryId.firstChange for comparing old and new values
|
|
93
|
-
}
|
|
94
|
-
customOptions = {
|
|
95
|
-
loop: true,
|
|
96
|
-
dots: false,
|
|
97
|
-
navSpeed: 950,
|
|
98
|
-
margin: 0,
|
|
99
|
-
navText: ['', ''],
|
|
100
|
-
nav: true,
|
|
101
|
-
responsive: {
|
|
102
|
-
0: {
|
|
103
|
-
items: 1,
|
|
104
|
-
nav: true
|
|
105
|
-
},
|
|
106
|
-
600: {
|
|
107
|
-
items: 3,
|
|
108
|
-
nav: true
|
|
109
|
-
},
|
|
110
|
-
900: {
|
|
111
|
-
items: 4,
|
|
112
|
-
nav: true,
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
};
|
|
116
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RelatedProductsEcComponent, deps: [{ token: i1.ProductsService }, { token: i2.AnalyticsService }, { token: i3.CoreConstantsService }, { token: i4.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
117
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: RelatedProductsEcComponent, isStandalone: true, selector: "app-related-products-ec", inputs: { product_id: "product_id" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: " <!-- @for (products of relatedProducts; track $index) {\r\n<section class=\"destacados\" id=\"destacados\">\r\n <div class=\"container-fluid mx-auto py-5\">\r\n <div class=\"row mx-auto d-flex justify-content-start px-3 py-3\">\r\n <h3 class=\"my-auto mx-2 text-left w-fit bold text-beige1\">\r\n {{ products.title ? products.title : 'PRODUCTOS RECOMENDADOS' | uppercase}}\r\n </h3>\r\n </div>\r\n\r\n <owl-carousel-o [options]=\"customOptionsDestacados\" class=\"row mx-auto d-flex justify-content-center p-3 pb-1\">\r\n <ng-template carouselSlide *ngFor=\"let product of products.items\">\r\n <app-product-destacados [product]=\"product\" [isValorados]=\"false\"></app-product-destacados>\r\n </ng-template>\r\n </owl-carousel-o> \r\n\r\n <div class=\"row mx-auto d-flex justify-content-center pb-3 d-md-none\">\r\n <a routerLink=\"/collection\" role=\"button\"\r\n class=\"btn btn-dark bg-beige1 text-blanco bold rounded-pill px-5 py-2\">IR A LA TIENDA</a>\r\n </div>\r\n </div>\r\n</section>\r\n} -->\r\n", styles: [""] });
|
|
82
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RelatedProductsEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
83
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: RelatedProductsEcComponent, isStandalone: true, selector: "app-related-products-ec", inputs: { appProduct: "appProduct", productID: "productID" }, ngImport: i0, template: "\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }] });
|
|
118
84
|
}
|
|
119
85
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RelatedProductsEcComponent, decorators: [{
|
|
120
86
|
type: Component,
|
|
121
|
-
args: [{ selector: 'app-related-products-ec', standalone: true, imports: [
|
|
122
|
-
}], ctorParameters: () => [
|
|
87
|
+
args: [{ selector: 'app-related-products-ec', standalone: true, imports: [AsyncPipe, ProductEcComponent, CommonModule], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "\r\n" }]
|
|
88
|
+
}], ctorParameters: () => [], propDecorators: { appProduct: [{
|
|
123
89
|
type: Input
|
|
90
|
+
}], productID: [{
|
|
91
|
+
type: Input,
|
|
92
|
+
args: [{
|
|
93
|
+
required: true
|
|
94
|
+
}]
|
|
124
95
|
}] } });
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"related-products-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/related-products-ec/related-products-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/related-products-ec/related-products-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAiB,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEtH,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AAIjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;;;;;;AAWpD,MAAM,OAAO,0BAA2B,SAAQ,eAAe;IAmCrC;IACV;IACD;IACA;IArCd;;OAEG;IACH,aAAa,GAAG,MAAM,CAAyB,IAAI,CAAC,CAAA;IAC1C,eAAe,GAAO,EAAE,CAAC;IACxB,UAAU,GAAQ,MAAM,CAAC,WAAW,CAAC,CAAA;IACpC,UAAU,CAAM;IACjB,QAAQ,CAAY;IAErB,IAAI,GAAG,IAAI,CAAC;IACX,iBAAiB,GAAY,CAAC,SAAS,EAAE,UAAU,EAAE,aAAa,EAAE,aAAa,EAAE,UAAU,CAAC,CAAC;IAEnG,aAAa,GAAG,GAAkB,EAAE;QAChC,OAAO;YACH,UAAU,EAAE,IAAI;YAChB,WAAW,EAAE;gBACT,CAAC,EAAE;oBACC,aAAa,EAAE,CAAC;iBACnB;gBACD,GAAG,EAAE;oBACD,aAAa,EAAE,CAAC;iBACnB;gBACD,GAAG,EAAE;oBACD,aAAa,EAAE,CAAC;iBACnB;gBACD,GAAG,EAAE;oBACD,aAAa,EAAE,CAAC;iBACnB;gBACD,IAAI,EAAE;oBACF,aAAa,EAAE,CAAC;iBACnB;aACJ;SACJ,CAAA;IACL,CAAC,CAAA;IACL,YAAsB,eAAgC,EAC1C,gBAAkC,EACnC,MAA4B,EAC5B,MAAc;QACrB,KAAK,EAAE,CAAC;QAJU,oBAAe,GAAf,eAAe,CAAiB;QAC1C,qBAAgB,GAAhB,gBAAgB,CAAkB;QACnC,WAAM,GAAN,MAAM,CAAsB;QAC5B,WAAM,GAAN,MAAM,CAAQ;QAErB,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YAC9C,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAA;QACzB,CAAC;QACD,eAAe,CAAC,GAAG,EAAE;YACpB,MAAM,qBAAqB,GAAG,IAAI,CAAC,QAAQ,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAA;YAC9E,IAAI,qBAAqB,EAAE,CAAC;gBAC3B,MAAM,CAAC,MAAM,CAAC,qBAAsB,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAA;gBAC3D,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,qBAAwC,CAAC,CAAA;gBAChE,IAAI,CAAC,aAAa,EAAE,EAAE,UAAU,EAAE,CAAC;YACpC,CAAC;QACF,CAAC,CAAC,CAAA;QACI,IAAI,CAAC,aAAa,EAAE,CAAA;IACxB,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;QAC1B,IAAI,CAAC,QAAQ,EAAE,CAAA;IACnB,CAAC;IAED,IAAI,CAAC,UAAkB;QACnB,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAClF,GAAG,CAAC,EAAE;YACF,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC,CAAA;YAChG,GAAG,CAAC,GAAG,CAAC,CAAC,QAAa,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,gBAAgB,EAAE,EAAE,QAAQ,EAAE,QAAQ,CAAC,KAAK,EAAE,cAAc,EAAE,QAAQ,CAAC,KAAK,IAAI,kBAAkB,EAAE,YAAY,EAAE,QAAQ,CAAC,EAAE,IAAI,kBAAkB,EAAE,CAAC,CAAC,CAAA;QACtN,CAAC,CAGJ,CAAA;IACL,CAAC;IAED,cAAc,GAAG,CAAC,IAAW,EAAE,EAAE;QAC7B,IAAI,MAAM,GAAG,KAAK,CAAA;QAClB,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAE,OAAO,CAAC,EAAE;YACtC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA;QACjD,CAAC,CAAC,CAAA;QACF,OAAO,MAAM,CAAA;IACjB,CAAC,CAAA;IACD,WAAW,CAAC,OAAsB;QAC9B,MAAM,CAAC,MAAM,CAAC;YACV,GAAG,EAAE,CAAC;YACN,IAAI,EAAE,CAAC;YACP,QAAQ,EAAE,QAAQ;SACrB,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAA;QAC7C,oDAAoD;QACpD,iDAAiD;QACjD,0DAA0D;IAE9D,CAAC;IAIM,aAAa,GAAQ;QACxB,IAAI,EAAE,IAAI;QACV,IAAI,EAAE,KAAK;QACX,QAAQ,EAAE,GAAG;QACb,MAAM,EAAE,CAAC;QACT,OAAO,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;QACjB,GAAG,EAAE,IAAI;QACT,UAAU,EAAE;YACR,CAAC,EAAE;gBACC,KAAK,EAAE,CAAC;gBACR,GAAG,EAAE,IAAI;aACZ;YACD,GAAG,EAAE;gBACD,KAAK,EAAE,CAAC;gBACR,GAAG,EAAE,IAAI;aACZ;YACD,GAAG,EAAE;gBACD,KAAK,EAAE,CAAC;gBACR,GAAG,EAAE,IAAI;aACZ;SACJ;KACJ,CAAA;wGAjHQ,0BAA0B;4FAA1B,0BAA0B,qKClBvC,woCAsBA;;4FDJa,0BAA0B;kBAPtC,SAAS;+BACI,yBAAyB,cACvB,IAAI,WACP,EAAE;2KAWF,UAAU;sBAAlB,KAAK","sourcesContent":["import { Component, OnInit, Input, SimpleChanges, inject, PLATFORM_ID, afterNextRender, signal } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { take } from 'rxjs/operators';\r\nimport { ComponentHelper } from '../../classes/component-helper';\r\nimport { CoreConstantsService } from '../../constants/core.constants.service';\r\nimport { AnalyticsService } from '../../ec-services/analytics/analytics.service';\r\nimport { ProductsService } from '../../ec-services/products.service';\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport { SwiperOptions } from 'swiper/types';\r\nimport { SwiperContainer } from 'swiper/element';\r\n\r\n@Component({\r\n    selector: 'app-related-products-ec',\r\n    standalone: true,\r\n    imports: [],\r\n    templateUrl: './related-products-ec.component.html',\r\n    styleUrls: ['./related-products-ec.component.scss']\r\n})\r\nexport class RelatedProductsEcComponent extends ComponentHelper implements OnInit {\r\n\t/**\r\n\t * Signal utlizado para guarda el contenedor del carrusel\r\n\t */\r\n\tswiperElement = signal<SwiperContainer | null>(null)\r\n    public relatedProducts:any = [];\r\n    private platformId: any = inject(PLATFORM_ID)\r\n    @Input() product_id: any;\r\n    private document?: Document;\r\n\r\n    public name = null;\r\n    private keywordsToCompare:string[] = ['compare', 'comparar', 'comparacion', 'comparación', 'compared'];\r\n\r\n        swiperRelated = (): SwiperOptions => {\r\n            return {\r\n                navigation: true,\r\n                breakpoints: {\r\n                    0: {\r\n                        slidesPerView: 1\r\n                    },\r\n                    576: {\r\n                        slidesPerView: 2\r\n                    },\r\n                    768: {\r\n                        slidesPerView: 3,\r\n                    },\r\n                    992: {\r\n                        slidesPerView: 4,\r\n                    },\r\n                    1200: {\r\n                        slidesPerView: 4,\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    constructor(protected productsService: ProductsService,\r\n        private analyticsService: AnalyticsService,\r\n        public consts: CoreConstantsService,\r\n        public router: Router) {\r\n        super();\r\n        if (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.document = document\r\n\t\t}\r\n\t\tafterNextRender(() => {\r\n\t\t\tconst swiperElemConstructor = this.document?.querySelector('#relatedProducts')\r\n\t\t\tif (swiperElemConstructor) {\r\n\t\t\t\tObject.assign(swiperElemConstructor!, this.swiperRelated())\r\n\t\t\t\tthis.swiperElement.set(swiperElemConstructor as SwiperContainer)\r\n\t\t\t\tthis.swiperElement()?.initialize();\r\n\t\t\t}\r\n\t\t})\r\n        this.ecOnConstruct()\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.load(this.product_id)\r\n        this.ecOnInit()\r\n    }\r\n\r\n    load(product_id: number) {\r\n        this.productsService.getRelatedProducts(product_id.toString()).pipe(take(1)).subscribe(\r\n            res => {\r\n                this.relatedProducts = res.filter((elem: any) => !this.includeKeyword(elem.title.toLowerCase()))\r\n                res.map((products: any) => this.analyticsService.callEvent('view_item_list', { products: products.items, item_list_name: products.title || 'Related Products', item_list_id: products.id || 'related-products' }))\r\n            },\r\n            //res => res.items ? this.products = res.items : null\r\n            // err => this.toastrService.show('unable-to-fetch-products')\r\n        )\r\n    }\r\n\r\n    includeKeyword = (word:string) => {\r\n        let result = false\r\n        this.keywordsToCompare.forEach( keyword => {\r\n            word.includes(keyword) ? result = true : null\r\n        })\r\n        return result\r\n    }\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        window.scroll({\r\n            top: 0,\r\n            left: 0,\r\n            behavior: 'smooth'\r\n        });\r\n        this.load(changes['product_id'].currentValue)\r\n        //this.doSomething(changes.categoryId.currentValue);\r\n        // You can also use categoryId.previousValue and \r\n        // categoryId.firstChange for comparing old and new values\r\n\r\n    }\r\n\r\n\r\n\r\n    public customOptions: any = {\r\n        loop: true,\r\n        dots: false,\r\n        navSpeed: 950,\r\n        margin: 0,\r\n        navText: ['', ''],\r\n        nav: true,\r\n        responsive: {\r\n            0: {\r\n                items: 1,\r\n                nav: true\r\n            },\r\n            600: {\r\n                items: 3,\r\n                nav: true\r\n            },\r\n            900: {\r\n                items: 4,\r\n                nav: true,\r\n            }\r\n        }\r\n    }\r\n\r\n    \r\n}\r\n","  <!-- @for (products of relatedProducts; track $index) {\r\n<section class=\"destacados\" id=\"destacados\">\r\n    <div class=\"container-fluid mx-auto py-5\">\r\n        <div class=\"row mx-auto d-flex justify-content-start px-3 py-3\">\r\n            <h3 class=\"my-auto mx-2 text-left w-fit bold text-beige1\">\r\n                {{ products.title ? products.title : 'PRODUCTOS RECOMENDADOS' | uppercase}}\r\n            </h3>\r\n        </div>\r\n\r\n       <owl-carousel-o [options]=\"customOptionsDestacados\" class=\"row mx-auto d-flex justify-content-center p-3  pb-1\">\r\n            <ng-template carouselSlide *ngFor=\"let product of products.items\">\r\n                <app-product-destacados [product]=\"product\" [isValorados]=\"false\"></app-product-destacados>\r\n            </ng-template>\r\n        </owl-carousel-o> \r\n\r\n        <div class=\"row mx-auto d-flex justify-content-center pb-3 d-md-none\">\r\n            <a routerLink=\"/collection\" role=\"button\"\r\n                class=\"btn btn-dark bg-beige1 text-blanco bold rounded-pill px-5 py-2\">IR A LA TIENDA</a>\r\n        </div>\r\n    </div>\r\n</section>\r\n} -->\r\n"]}
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"related-products-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/related-products-ec/related-products-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/related-products-ec/related-products-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, TemplateRef, CUSTOM_ELEMENTS_SCHEMA, signal, PLATFORM_ID, afterNextRender } from '@angular/core';\r\nimport { AnalyticsService, ProductsService } from '../../ec-services';\r\nimport { Router } from '@angular/router';\r\nimport { BehaviorSubject, Observable, take } from 'rxjs';\r\nimport { AsyncPipe, CommonModule, isPlatformBrowser } from '@angular/common';\r\nimport { Product } from '../../interfaces';\r\nimport { ProductEcComponent } from '../product-ec/product-ec.component';\r\nimport { SwiperContainer } from 'swiper/element';\r\nimport { SwiperOptions } from 'swiper/types';\r\n\r\n@Component({\r\n    selector: 'app-related-products-ec',\r\n    standalone: true,\r\n    imports: [AsyncPipe, ProductEcComponent, CommonModule],\r\n    templateUrl: './related-products-ec.component.html',\r\n    styleUrl: './related-products-ec.component.scss',\r\n    schemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class RelatedProductsEcComponent {\r\n    private _productsService: ProductsService = inject(ProductsService)\r\n    private _analyticsService: AnalyticsService = inject(AnalyticsService)\r\n    private _router: Router = inject(Router)\r\n    \t/**\r\n\t * Signal utlizado para guarda el contenedor del carrusel\r\n\t */\r\n\tswiperElement = signal<SwiperContainer | null>(null)\r\n    /**\r\n     * Input que recibe un template para el producto.\r\n     */\r\n    @Input() appProduct: TemplateRef<any> | undefined;\r\n    @Input({\r\n        required: true\r\n    }) productID: any;\r\n\r\n        private document?: Document;\r\n        private platformId: any = inject(PLATFORM_ID)\r\n    \r\n    private _relatedProductsSubject:BehaviorSubject<Product[]> =  new BehaviorSubject<Product[]>([])\r\n    public relatedProducts$:Observable<any[]> = this._relatedProductsSubject.asObservable();\r\n    private keywordsToCompare:string[] = ['compare', 'comparar', 'comparacion', 'comparación', 'compared'];\r\n    swiperRelatedOptions = (): SwiperOptions => {\r\n        return {\r\n            navigation: true,\r\n            loop: true,\r\n            breakpoints: {\r\n                0: {\r\n                    slidesPerView: 1\r\n                },\r\n                576: {\r\n                    slidesPerView: 2\r\n                },\r\n                768: {\r\n                    slidesPerView: 3,\r\n                },\r\n                992: {\r\n                    slidesPerView: 4,\r\n                },\r\n                1200: {\r\n                    slidesPerView: 4,\r\n                }\r\n            }\r\n        }\r\n    }\r\n    constructor() {\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            this.document = document\r\n        }\r\n        afterNextRender(() => {\r\n            const swiperElemConstructor = this.document?.querySelector('#relatedProductsSwiper')\r\n            console.log('swiperElemConstructor', swiperElemConstructor)\r\n            if (swiperElemConstructor) {\r\n                Object.assign(swiperElemConstructor!, this.swiperRelatedOptions())\r\n                this.swiperElement.set(swiperElemConstructor as SwiperContainer)\r\n                this.swiperElement()?.initialize();\r\n            }\r\n        })\r\n    }\r\n\r\n    ngOnInit() {\r\n        console.log(this.productID)\r\n        this.load(this.productID)\r\n    }\r\n\r\n    private load(product_id:any) {\r\n        this._productsService.getRelatedProducts(product_id).pipe(take(1)).subscribe(\r\n            res => {\r\n                console.log('response',res);\r\n                const relatedProducts:any = res.filter((elem:any) => !this.includeKeyword(elem.title.toLowerCase()))\r\n                this._relatedProductsSubject.next(relatedProducts)\r\n                res.map((products:any) => this._analyticsService.callEvent('view_item_list', { products: products.items, item_list_name: products.title || 'Related Products', item_list_id: products.id || 'related-products' }))\r\n            }\r\n        )\r\n    }\r\n\r\n    includeKeyword = (word:string) => {\r\n        let result = false\r\n        this.keywordsToCompare.forEach( keyword => {\r\n            word.includes(keyword) ? result = true : null\r\n        })\r\n        return result\r\n    }\r\n}\r\n\r\n","\r\n"]}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { ComponentHelper } from '../../classes/component-helper';
|
|
3
|
+
import { RatingEcComponent } from '../widgets-ec/rating-ec/rating-ec.component';
|
|
4
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../ec-services/reviews.service";
|
|
7
|
+
import * as i2 from "../../constants/core.constants.service";
|
|
8
|
+
import * as i3 from "@ngx-translate/core";
|
|
9
|
+
export class ReviewsEcComponent extends ComponentHelper {
|
|
10
|
+
reviewsService;
|
|
11
|
+
consts;
|
|
12
|
+
/**
|
|
13
|
+
* @description producto del cual se obtendran las reviews.
|
|
14
|
+
*/
|
|
15
|
+
product;
|
|
16
|
+
reviews;
|
|
17
|
+
constructor(reviewsService, consts) {
|
|
18
|
+
super();
|
|
19
|
+
this.reviewsService = reviewsService;
|
|
20
|
+
this.consts = consts;
|
|
21
|
+
this.reviewsService.reviews$.subscribe(res => this.reviews = res);
|
|
22
|
+
this.ecOnConstruct();
|
|
23
|
+
}
|
|
24
|
+
ngOnInit() {
|
|
25
|
+
this.reviewsService.getReviewsByCode(this.product.id);
|
|
26
|
+
this.ecOnInit();
|
|
27
|
+
}
|
|
28
|
+
next = () => {
|
|
29
|
+
this.reviewsService.getReviews('next');
|
|
30
|
+
};
|
|
31
|
+
last = () => {
|
|
32
|
+
this.reviewsService.getReviews('last');
|
|
33
|
+
};
|
|
34
|
+
first = () => {
|
|
35
|
+
this.reviewsService.getReviews('first');
|
|
36
|
+
};
|
|
37
|
+
self = () => {
|
|
38
|
+
this.reviewsService.getReviews();
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* @description genera un arreglo con tamaño igual a la cantidad de paginas que tiene la review.
|
|
42
|
+
* @returns {number[]} un arreglo cuyo contendio es un entero que indica el numero de pagina.
|
|
43
|
+
*/
|
|
44
|
+
getPages = () => {
|
|
45
|
+
let pages = [];
|
|
46
|
+
for (let index = 0; index < this.reviews.pages; index++) {
|
|
47
|
+
pages.push(index + 1);
|
|
48
|
+
}
|
|
49
|
+
return pages;
|
|
50
|
+
};
|
|
51
|
+
/**
|
|
52
|
+
* @description actualiza las reviews con el contenido asociado a la pagina pasada por parametro
|
|
53
|
+
* @param page
|
|
54
|
+
*/
|
|
55
|
+
goPage = (page) => {
|
|
56
|
+
this.reviewsService.getReviewsByPage(this.product.id, page, this.reviews.limit);
|
|
57
|
+
};
|
|
58
|
+
getAuthorName(email) {
|
|
59
|
+
if (!email || email.indexOf('@') === -1) {
|
|
60
|
+
return '';
|
|
61
|
+
}
|
|
62
|
+
return email.split('@')[0];
|
|
63
|
+
}
|
|
64
|
+
getStarArray(rating) {
|
|
65
|
+
return Array(5).fill(0);
|
|
66
|
+
}
|
|
67
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ReviewsEcComponent, deps: [{ token: i1.ReviewsService }, { token: i2.CoreConstantsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
68
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ReviewsEcComponent, isStandalone: true, selector: "app-reviews-ec", inputs: { product: "product" }, usesInheritance: true, ngImport: i0, template: "<div class=\"row px-3\">\r\n <div class=\"col-12 pb-2 pb-md-0\">\r\n <div class=\"row w-100\">\r\n <div class=\"col-12 col-md-6\">\r\n <h4 class=\"mb-0 pt-2 pb-1\">{{\"product-review\" | translate}}</h4>\r\n <small class=\"pb-2 escribir\" data-bs-toggle=\"modal\" href=\"#modalReview\">\r\n {{\"write-a-review\" | translate}}\r\n <i class=\"bi bi-pencil-square\"></i>\r\n </small>\r\n </div>\r\n <div class=\"col-12 col-md-6 d-flex align-items-center justify-content-start justify-content-md-end\">\r\n <div class=\"puntaje d-flex\">\r\n <ng-template #number let-ratingValue=\"ratingValue\">\r\n <p class=\"puntos mb-0\">\r\n {{ratingValue}}\r\n </p>\r\n </ng-template>\r\n <app-rating-ec [ratingValue]=\"product.rating\" [template]=\"number\"></app-rating-ec>\r\n <div class=\"ms-2\">\r\n <div class=\"stars mb-1\">\r\n <app-rating-ec [ratingValue]=\"product.rating\"></app-rating-ec>\r\n </div>\r\n <small><strong>{{reviews.total}} {{\"reviews\" | translate}}</strong></small>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <hr>\r\n\r\n <div class=\"tab-content mt-4\" id=\"myTabContent\">\r\n <div class=\"row g-5\">\r\n @for (item of reviews.items; track $index) {\r\n <div class=\"col-12 col-sm-6 col-md-4\">\r\n <div class=\"row\">\r\n <div class=\"col-9 col-sm-10\">\r\n <div class=\"ranking\">\r\n <app-rating-ec [ratingValue]=\"item.rating\"></app-rating-ec>\r\n </div>\r\n <h4 class=\"text-uppercase\">{{item.title}}</h4>\r\n <div class=\"d-flex justify-content-between\">\r\n <div class=\"ususario\">\r\n <i class=\"bi bi-person-fill\"></i> {{ getAuthorName(item.author) }}\r\n </div>\r\n </div>\r\n <div class=\"resenia mt-2\">\r\n <p style=\"font-size: 14px;\"> {{item.comment}}</p>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n }\r\n @if (getPages() && getPages().length > 1) {\r\n <nav aria-label=\"Page navigation example\">\r\n <ul class=\"pagination custom-pagination\">\r\n <li class=\"page-item\">\r\n <a class=\"page-link cursor-pointer\" (click)=\"first()\" aria-label=\"Previous\">\r\n <span aria-hidden=\"true\">«</span>\r\n </a>\r\n </li>\r\n @for (page of getPages(); track $index) {\r\n <li class=\"page-item\">\r\n <a class=\"page-link cursor-pointer\" (click)=\"goPage(page)\">{{ page }}</a>\r\n </li>\r\n }\r\n <li class=\"page-item\">\r\n <a class=\"page-link cursor-pointer\" (click)=\"next()\" aria-label=\"Next\">\r\n <span aria-hidden=\"true\">»</span>\r\n </a>\r\n </li>\r\n </ul>\r\n </nav>\r\n\r\n }\r\n\r\n </div>\r\n </div>\r\n\r\n</div>", styles: [".custom-pagination{display:flex;justify-content:center;list-style:none;padding:0;margin-top:20px}.custom-pagination .page-item{margin:0 5px}.custom-pagination .page-link{color:#131716;background-color:#f3f3f3;border:1px solid #ccc;padding:8px 12px;border-radius:5px;text-decoration:none;transition:background-color .3s ease}.custom-pagination .page-link:hover{background-color:#0b0c0c;color:#fff}.custom-pagination .page-item.active .page-link{background-color:#131716;color:#fff;font-weight:700}.cursor-pointer{cursor:pointer}\n"], dependencies: [{ kind: "component", type: RatingEcComponent, selector: "app-rating-ec", inputs: ["template", "type", "ratingValue"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }] });
|
|
69
|
+
}
|
|
70
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ReviewsEcComponent, decorators: [{
|
|
71
|
+
type: Component,
|
|
72
|
+
args: [{ selector: 'app-reviews-ec', standalone: true, imports: [RatingEcComponent, TranslateModule], template: "<div class=\"row px-3\">\r\n <div class=\"col-12 pb-2 pb-md-0\">\r\n <div class=\"row w-100\">\r\n <div class=\"col-12 col-md-6\">\r\n <h4 class=\"mb-0 pt-2 pb-1\">{{\"product-review\" | translate}}</h4>\r\n <small class=\"pb-2 escribir\" data-bs-toggle=\"modal\" href=\"#modalReview\">\r\n {{\"write-a-review\" | translate}}\r\n <i class=\"bi bi-pencil-square\"></i>\r\n </small>\r\n </div>\r\n <div class=\"col-12 col-md-6 d-flex align-items-center justify-content-start justify-content-md-end\">\r\n <div class=\"puntaje d-flex\">\r\n <ng-template #number let-ratingValue=\"ratingValue\">\r\n <p class=\"puntos mb-0\">\r\n {{ratingValue}}\r\n </p>\r\n </ng-template>\r\n <app-rating-ec [ratingValue]=\"product.rating\" [template]=\"number\"></app-rating-ec>\r\n <div class=\"ms-2\">\r\n <div class=\"stars mb-1\">\r\n <app-rating-ec [ratingValue]=\"product.rating\"></app-rating-ec>\r\n </div>\r\n <small><strong>{{reviews.total}} {{\"reviews\" | translate}}</strong></small>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <hr>\r\n\r\n <div class=\"tab-content mt-4\" id=\"myTabContent\">\r\n <div class=\"row g-5\">\r\n @for (item of reviews.items; track $index) {\r\n <div class=\"col-12 col-sm-6 col-md-4\">\r\n <div class=\"row\">\r\n <div class=\"col-9 col-sm-10\">\r\n <div class=\"ranking\">\r\n <app-rating-ec [ratingValue]=\"item.rating\"></app-rating-ec>\r\n </div>\r\n <h4 class=\"text-uppercase\">{{item.title}}</h4>\r\n <div class=\"d-flex justify-content-between\">\r\n <div class=\"ususario\">\r\n <i class=\"bi bi-person-fill\"></i> {{ getAuthorName(item.author) }}\r\n </div>\r\n </div>\r\n <div class=\"resenia mt-2\">\r\n <p style=\"font-size: 14px;\"> {{item.comment}}</p>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n }\r\n @if (getPages() && getPages().length > 1) {\r\n <nav aria-label=\"Page navigation example\">\r\n <ul class=\"pagination custom-pagination\">\r\n <li class=\"page-item\">\r\n <a class=\"page-link cursor-pointer\" (click)=\"first()\" aria-label=\"Previous\">\r\n <span aria-hidden=\"true\">«</span>\r\n </a>\r\n </li>\r\n @for (page of getPages(); track $index) {\r\n <li class=\"page-item\">\r\n <a class=\"page-link cursor-pointer\" (click)=\"goPage(page)\">{{ page }}</a>\r\n </li>\r\n }\r\n <li class=\"page-item\">\r\n <a class=\"page-link cursor-pointer\" (click)=\"next()\" aria-label=\"Next\">\r\n <span aria-hidden=\"true\">»</span>\r\n </a>\r\n </li>\r\n </ul>\r\n </nav>\r\n\r\n }\r\n\r\n </div>\r\n </div>\r\n\r\n</div>", styles: [".custom-pagination{display:flex;justify-content:center;list-style:none;padding:0;margin-top:20px}.custom-pagination .page-item{margin:0 5px}.custom-pagination .page-link{color:#131716;background-color:#f3f3f3;border:1px solid #ccc;padding:8px 12px;border-radius:5px;text-decoration:none;transition:background-color .3s ease}.custom-pagination .page-link:hover{background-color:#0b0c0c;color:#fff}.custom-pagination .page-item.active .page-link{background-color:#131716;color:#fff;font-weight:700}.cursor-pointer{cursor:pointer}\n"] }]
|
|
73
|
+
}], ctorParameters: () => [{ type: i1.ReviewsService }, { type: i2.CoreConstantsService }], propDecorators: { product: [{
|
|
74
|
+
type: Input
|
|
75
|
+
}] } });
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reviews-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/reviews-ec/reviews-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/reviews-ec/reviews-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAoB,MAAM,eAAe,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AAGjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,6CAA6C,CAAC;AAChF,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;;;;;AAQtD,MAAM,OAAO,kBAAmB,SAAQ,eAAe;IAQ/B;IAAuC;IAP3D;;OAEG;IACM,OAAO,CAAK;IAEd,OAAO,CAAK;IAEnB,YAAoB,cAA8B,EAAS,MAA2B;QAClF,KAAK,EAAE,CAAA;QADS,mBAAc,GAAd,cAAc,CAAgB;QAAS,WAAM,GAAN,MAAM,CAAqB;QAElF,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,CAAA;QACjE,IAAI,CAAC,aAAa,EAAE,CAAA;IACxB,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;QACrD,IAAI,CAAC,QAAQ,EAAE,CAAA;IAEnB,CAAC;IAED,IAAI,GAAG,GAAG,EAAE;QACR,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IAC3C,CAAC,CAAA;IAED,IAAI,GAAG,GAAG,EAAE;QACR,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IAC3C,CAAC,CAAA;IAED,KAAK,GAAG,GAAG,EAAE;QACT,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAC5C,CAAC,CAAA;IAED,IAAI,GAAG,GAAG,EAAE;QACR,IAAI,CAAC,cAAc,CAAC,UAAU,EAAE,CAAC;IACrC,CAAC,CAAA;IAED;;;OAGG;IACH,QAAQ,GAAG,GAAY,EAAE;QACrB,IAAI,KAAK,GAAU,EAAE,CAAA;QACrB,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC;YACtD,KAAK,CAAC,IAAI,CAAC,KAAK,GAAC,CAAC,CAAC,CAAA;QACvB,CAAC;QACD,OAAO,KAAK,CAAA;IAChB,CAAC,CAAA;IAED;;;OAGG;IACH,MAAM,GAAG,CAAC,IAAW,EAAE,EAAE;QACrB,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,EAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IAClF,CAAC,CAAA;IAED,aAAa,CAAC,KAAa;QACvB,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;YACtC,OAAO,EAAE,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC;IAED,YAAY,CAAC,MAAc;QACvB,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC;wGAjEQ,kBAAkB;4FAAlB,kBAAkB,iICb/B,osHA+EM,2kBDtEQ,iBAAiB,sGAAE,eAAe;;4FAInC,kBAAkB;kBAP9B,SAAS;+BACI,gBAAgB,cACd,IAAI,WACP,CAAC,iBAAiB,EAAE,eAAe,CAAC;sHAQpC,OAAO;sBAAf,KAAK","sourcesContent":["import { Component, Input, NgModule, OnInit } from '@angular/core';\r\nimport { ComponentHelper } from '../../classes/component-helper';\r\nimport { CoreConstantsService } from '../../constants/core.constants.service';\r\nimport { ReviewsService } from '../../ec-services/reviews.service';\r\nimport { RatingEcComponent } from '../widgets-ec/rating-ec/rating-ec.component';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\n@Component({\r\n    selector: 'app-reviews-ec',\r\n    standalone: true,\r\n    imports: [RatingEcComponent, TranslateModule],\r\n    templateUrl: './reviews-ec.component.html',\r\n    styleUrls: ['./reviews-ec.component.scss']\r\n})\r\nexport class ReviewsEcComponent extends ComponentHelper implements OnInit {\r\n    /**\r\n     * @description producto del cual se obtendran las reviews. \r\n     */\r\n    @Input() product:any;\r\n\r\n    public reviews:any;\r\n\r\n    constructor(private reviewsService: ReviewsService, public consts:CoreConstantsService) {\r\n        super()\r\n        this.reviewsService.reviews$.subscribe(res => this.reviews = res)\r\n        this.ecOnConstruct()\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.reviewsService.getReviewsByCode(this.product.id)\r\n        this.ecOnInit()\r\n        \r\n    }\r\n\r\n    next = () => {\r\n        this.reviewsService.getReviews('next');\r\n    }\r\n\r\n    last = () => {\r\n        this.reviewsService.getReviews('last');\r\n    }\r\n\r\n    first = () => {\r\n        this.reviewsService.getReviews('first');\r\n    }\r\n\r\n    self = () => {\r\n        this.reviewsService.getReviews();\r\n    }\r\n\r\n    /**\r\n     * @description genera un arreglo con tamaño igual a la cantidad de paginas que tiene la review.\r\n     * @returns {number[]} un arreglo cuyo contendio es un entero que indica el numero de pagina. \r\n     */\r\n    getPages = ():number[] => {\r\n        let pages:number[]=[]\r\n        for (let index = 0; index < this.reviews.pages; index++) {\r\n            pages.push(index+1)\r\n        }\r\n        return pages\r\n    }\r\n\r\n    /**\r\n     * @description actualiza las reviews con el contenido asociado a la pagina pasada por parametro\r\n     * @param page \r\n     */\r\n    goPage = (page:number) => {\r\n        this.reviewsService.getReviewsByPage(this.product.id,page, this.reviews.limit)\r\n    }\r\n\r\n    getAuthorName(email: string): string {\r\n        if (!email || email.indexOf('@') === -1) {\r\n            return '';\r\n        }\r\n        return email.split('@')[0];\r\n    }\r\n\r\n    getStarArray(rating: number): number[] {\r\n        return Array(5).fill(0);\r\n    }\r\n    \r\n}\r\n","<div class=\"row px-3\">\r\n    <div class=\"col-12 pb-2 pb-md-0\">\r\n        <div class=\"row w-100\">\r\n            <div class=\"col-12 col-md-6\">\r\n                <h4 class=\"mb-0 pt-2 pb-1\">{{\"product-review\" | translate}}</h4>\r\n                <small class=\"pb-2 escribir\" data-bs-toggle=\"modal\" href=\"#modalReview\">\r\n                    {{\"write-a-review\" | translate}}\r\n                    <i class=\"bi bi-pencil-square\"></i>\r\n                </small>\r\n            </div>\r\n            <div class=\"col-12 col-md-6 d-flex align-items-center justify-content-start justify-content-md-end\">\r\n                <div class=\"puntaje d-flex\">\r\n                    <ng-template #number let-ratingValue=\"ratingValue\">\r\n                        <p class=\"puntos mb-0\">\r\n                            {{ratingValue}}\r\n                        </p>\r\n                    </ng-template>\r\n                    <app-rating-ec [ratingValue]=\"product.rating\" [template]=\"number\"></app-rating-ec>\r\n                    <div class=\"ms-2\">\r\n                        <div class=\"stars mb-1\">\r\n                            <app-rating-ec [ratingValue]=\"product.rating\"></app-rating-ec>\r\n                        </div>\r\n                        <small><strong>{{reviews.total}} {{\"reviews\" | translate}}</strong></small>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <hr>\r\n\r\n    <div class=\"tab-content mt-4\" id=\"myTabContent\">\r\n        <div class=\"row g-5\">\r\n            @for (item of reviews.items; track $index) {\r\n            <div class=\"col-12 col-sm-6 col-md-4\">\r\n                <div class=\"row\">\r\n                    <div class=\"col-9 col-sm-10\">\r\n                        <div class=\"ranking\">\r\n                            <app-rating-ec [ratingValue]=\"item.rating\"></app-rating-ec>\r\n                        </div>\r\n                        <h4 class=\"text-uppercase\">{{item.title}}</h4>\r\n                        <div class=\"d-flex justify-content-between\">\r\n                            <div class=\"ususario\">\r\n                                <i class=\"bi bi-person-fill\"></i> {{ getAuthorName(item.author) }}\r\n                            </div>\r\n                        </div>\r\n                        <div class=\"resenia mt-2\">\r\n                            <p style=\"font-size: 14px;\"> {{item.comment}}</p>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n            }\r\n            @if (getPages() && getPages().length > 1) {\r\n            <nav aria-label=\"Page navigation example\">\r\n                <ul class=\"pagination custom-pagination\">\r\n                    <li class=\"page-item\">\r\n                        <a class=\"page-link cursor-pointer\" (click)=\"first()\" aria-label=\"Previous\">\r\n                            <span aria-hidden=\"true\">&laquo;</span>\r\n                        </a>\r\n                    </li>\r\n                    @for (page of getPages(); track $index) {\r\n                    <li class=\"page-item\">\r\n                        <a class=\"page-link cursor-pointer\" (click)=\"goPage(page)\">{{ page }}</a>\r\n                    </li>\r\n                    }\r\n                    <li class=\"page-item\">\r\n                        <a class=\"page-link cursor-pointer\" (click)=\"next()\" aria-label=\"Next\">\r\n                            <span aria-hidden=\"true\">&raquo;</span>\r\n                        </a>\r\n                    </li>\r\n                </ul>\r\n            </nav>\r\n\r\n            }\r\n\r\n        </div>\r\n    </div>\r\n\r\n</div>"]}
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { Validators } from '@angular/forms';
|
|
3
|
+
import { ComponentHelper } from '../../classes/component-helper';
|
|
4
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
5
|
+
import { ReactiveFormsModule } from '@angular/forms';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../../ec-services/toast.service";
|
|
8
|
+
import * as i2 from "@angular/router";
|
|
9
|
+
import * as i3 from "../../constants/core.constants.service";
|
|
10
|
+
import * as i4 from "@angular/forms";
|
|
11
|
+
import * as i5 from "../../ec-services/products.service";
|
|
12
|
+
import * as i6 from "../../ec-services/auth.service";
|
|
13
|
+
import * as i7 from "../../ec-services/reviews.service";
|
|
14
|
+
import * as i8 from "@ngx-translate/core";
|
|
15
|
+
export class ReviewsFormEcComponent extends ComponentHelper {
|
|
16
|
+
toastrService;
|
|
17
|
+
router;
|
|
18
|
+
consts;
|
|
19
|
+
formBuilder;
|
|
20
|
+
productService;
|
|
21
|
+
authService;
|
|
22
|
+
reviewsService;
|
|
23
|
+
/**
|
|
24
|
+
* @description producto al que se le va a agregar la reseña.
|
|
25
|
+
*/
|
|
26
|
+
product;
|
|
27
|
+
/**
|
|
28
|
+
* @description para controlar si esta logueado.
|
|
29
|
+
*/
|
|
30
|
+
withAuthenticated = true;
|
|
31
|
+
/**
|
|
32
|
+
* @description número maximo de valor de puntuación
|
|
33
|
+
*/
|
|
34
|
+
max = 5;
|
|
35
|
+
/**
|
|
36
|
+
* @description para indicar cuando se termino la operación de consulta.
|
|
37
|
+
*/
|
|
38
|
+
ready = new EventEmitter();
|
|
39
|
+
reviews_form;
|
|
40
|
+
loading = false;
|
|
41
|
+
form_data = new FormData();
|
|
42
|
+
limit = [];
|
|
43
|
+
constructor(toastrService, router, consts, formBuilder, productService, authService, reviewsService) {
|
|
44
|
+
super();
|
|
45
|
+
this.toastrService = toastrService;
|
|
46
|
+
this.router = router;
|
|
47
|
+
this.consts = consts;
|
|
48
|
+
this.formBuilder = formBuilder;
|
|
49
|
+
this.productService = productService;
|
|
50
|
+
this.authService = authService;
|
|
51
|
+
this.reviewsService = reviewsService;
|
|
52
|
+
this.reviews_form = formBuilder.group({
|
|
53
|
+
title: ['', Validators.required],
|
|
54
|
+
comment: ['', Validators.required],
|
|
55
|
+
rating: [0, Validators.required],
|
|
56
|
+
email: ['', this.withAuthenticated ? [] : [Validators.required, Validators.email]],
|
|
57
|
+
//attachment: [''],
|
|
58
|
+
});
|
|
59
|
+
this.ecOnConstruct(); // Removed as the method does not exist
|
|
60
|
+
}
|
|
61
|
+
ngOnInit() {
|
|
62
|
+
for (let index = 0; index < this.max; index++) {
|
|
63
|
+
this.limit.push(index + 1);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* @description guarda el valor que contiene la puntuación de la reseña.
|
|
68
|
+
* @param value
|
|
69
|
+
*/
|
|
70
|
+
setRatingValue = (value = 0) => {
|
|
71
|
+
this.reviews_form.controls['rating'].setValue(value);
|
|
72
|
+
};
|
|
73
|
+
/**
|
|
74
|
+
* @description procesa el formulario con los datos.
|
|
75
|
+
* @param form
|
|
76
|
+
* @param success_message mensaje para que se muestre en el caso de exito.
|
|
77
|
+
*/
|
|
78
|
+
sendForm = (form, success_message) => {
|
|
79
|
+
if (form.valid) {
|
|
80
|
+
this.withAuthenticated ? this.reviews_form.controls['email'].setValue(this.authService.getUserProfileAsUser().email) : null;
|
|
81
|
+
this.productService.saveReviews(this.product.id, form.value).toPromise().then(res => {
|
|
82
|
+
this.reviews_form.reset();
|
|
83
|
+
this.toastrService.show(success_message ? success_message : 'success-review');
|
|
84
|
+
this.loading = false;
|
|
85
|
+
this.ready.emit(true);
|
|
86
|
+
// Queda preparado por si algun dia se quiere manejar sincronismo.
|
|
87
|
+
//this.updateReviews()
|
|
88
|
+
}, err => {
|
|
89
|
+
this.toastrService.show('inquiry-error');
|
|
90
|
+
this.loading = false;
|
|
91
|
+
this.ready.emit(true);
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
this.toastrService.show('invalid-form');
|
|
96
|
+
this.loading = false;
|
|
97
|
+
this.ready.emit(true);
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
/**
|
|
101
|
+
* @descirption controla que el usuario este logueado para comentar. Si la variable withAuthenticated es falso entonces no realiza este control.
|
|
102
|
+
* @param e evento producido por el submit del formulario
|
|
103
|
+
*/
|
|
104
|
+
toastReviewsForm = (e, message) => {
|
|
105
|
+
this.loading = true;
|
|
106
|
+
e.preventDefault();
|
|
107
|
+
if (this.withAuthenticated) {
|
|
108
|
+
this.authService.isAuthenticated() ?
|
|
109
|
+
this.sendForm(this.reviews_form, message ? message : 'success-review') : this.toastrService.show('authenticated-for-comment');
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
this.sendForm(this.reviews_form, message ? message : 'success-review');
|
|
113
|
+
}
|
|
114
|
+
};
|
|
115
|
+
/**
|
|
116
|
+
* @description actualiza las reviews
|
|
117
|
+
* @returns
|
|
118
|
+
*/
|
|
119
|
+
updateReviews = () => this.reviewsService.updateReviewsByCode(this.product.id);
|
|
120
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ReviewsFormEcComponent, deps: [{ token: i1.ToastService }, { token: i2.Router }, { token: i3.CoreConstantsService }, { token: i4.FormBuilder }, { token: i5.ProductsService }, { token: i6.AuthService }, { token: i7.ReviewsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
121
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ReviewsFormEcComponent, isStandalone: true, selector: "app-reviews-form-ec", inputs: { product: "product", withAuthenticated: "withAuthenticated", max: "max" }, outputs: { ready: "ready" }, usesInheritance: true, ngImport: i0, template: "<form class=\"formResenia\" [formGroup]=\"reviews_form\" (submit)=\"toastReviewsForm($event)\">\r\n <div class=\"row\">\r\n <div class=\"col-4\">\r\n <label class=\"pt-2\">{{\"product\" | translate }}*</label>\r\n </div>\r\n <div class=\"col-8\">\r\n <p class=\"mt-1 mb-3\">{{ product.name }}</p>\r\n </div>\r\n </div>\r\n\r\n <!-- Calificaci\u00F3n -->\r\n <div class=\"row\">\r\n <div class=\"col-4\">\r\n <label class=\"pt-2\">{{\"rating\" | translate}}*</label>\r\n </div>\r\n <div class=\"col-8\">\r\n <div class=\"cont-star mt-1 mb-3\">\r\n @for(star of limit; track $index){\r\n <input type=\"radio\" class=\"d-none\" [id]=\"'star-' + (limit.length - $index)\" [value]=\"limit.length - $index\"\r\n formControlName=\"rating\">\r\n <label class=\"star-label\" [for]=\"'star-' + (limit.length - $index)\">\r\n <i class=\"bi bi-star-fill\"></i>\r\n </label>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Resumen -->\r\n <div class=\"row\">\r\n <div class=\"col-4\">\r\n <label for=\"review-summary\" class=\"pt-2\">{{\"summary\" | translate }}*</label>\r\n </div>\r\n <div class=\"col-8\">\r\n <textarea id=\"review-summary\" class=\"w-100\" placeholder=\"\u00BFC\u00F3mo fue tu experiencia?\" formControlName=\"title\"></textarea>\r\n </div>\r\n </div>\r\n\r\n <!-- Detalle -->\r\n <div class=\"row\">\r\n <div class=\"col-4\">\r\n <label for=\"review-detail\" class=\"pt-2\">{{\"detail\" | translate }}*</label>\r\n </div>\r\n <div class=\"col-8\">\r\n <textarea id=\"review-detail\" class=\"w-100\" placeholder=\"Contanos por qu\u00E9\" formControlName=\"comment\"></textarea>\r\n <small class=\"text-uppercase\">(*) {{\"mandatory-fields\" | translate }}</small>\r\n </div>\r\n </div>\r\n\r\n <!-- Bot\u00F3n de env\u00EDo -->\r\n <div class=\"row\">\r\n <div class=\"col-4\"></div>\r\n <div class=\"col-8\">\r\n <button type=\"submit\" class=\"btn btn-dark py-2 px-4 rounded-0 mt-4\"\r\n [disabled]=\"reviews_form.invalid\">{{\"submit-review\" | translate }}</button>\r\n </div>\r\n </div> \r\n</form>", styles: [".cont-star{direction:rtl;unicode-bidi:bidi-override;display:flex;justify-content:end}.cont-star label{display:flex}.cont-star label i{color:#ccc!important;cursor:pointer;font-size:26px;line-height:30px}.cont-star label i:hover,.cont-star label:hover~label i{color:#ffc107!important}input[type=radio]:checked~label i{color:#ffc107!important}input[type=radio]:checked~label i:before,label:hover i:before{content:\"\\f586\"}\n"], dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
|
|
122
|
+
}
|
|
123
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ReviewsFormEcComponent, decorators: [{
|
|
124
|
+
type: Component,
|
|
125
|
+
args: [{ selector: 'app-reviews-form-ec', standalone: true, imports: [TranslateModule, ReactiveFormsModule], template: "<form class=\"formResenia\" [formGroup]=\"reviews_form\" (submit)=\"toastReviewsForm($event)\">\r\n <div class=\"row\">\r\n <div class=\"col-4\">\r\n <label class=\"pt-2\">{{\"product\" | translate }}*</label>\r\n </div>\r\n <div class=\"col-8\">\r\n <p class=\"mt-1 mb-3\">{{ product.name }}</p>\r\n </div>\r\n </div>\r\n\r\n <!-- Calificaci\u00F3n -->\r\n <div class=\"row\">\r\n <div class=\"col-4\">\r\n <label class=\"pt-2\">{{\"rating\" | translate}}*</label>\r\n </div>\r\n <div class=\"col-8\">\r\n <div class=\"cont-star mt-1 mb-3\">\r\n @for(star of limit; track $index){\r\n <input type=\"radio\" class=\"d-none\" [id]=\"'star-' + (limit.length - $index)\" [value]=\"limit.length - $index\"\r\n formControlName=\"rating\">\r\n <label class=\"star-label\" [for]=\"'star-' + (limit.length - $index)\">\r\n <i class=\"bi bi-star-fill\"></i>\r\n </label>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Resumen -->\r\n <div class=\"row\">\r\n <div class=\"col-4\">\r\n <label for=\"review-summary\" class=\"pt-2\">{{\"summary\" | translate }}*</label>\r\n </div>\r\n <div class=\"col-8\">\r\n <textarea id=\"review-summary\" class=\"w-100\" placeholder=\"\u00BFC\u00F3mo fue tu experiencia?\" formControlName=\"title\"></textarea>\r\n </div>\r\n </div>\r\n\r\n <!-- Detalle -->\r\n <div class=\"row\">\r\n <div class=\"col-4\">\r\n <label for=\"review-detail\" class=\"pt-2\">{{\"detail\" | translate }}*</label>\r\n </div>\r\n <div class=\"col-8\">\r\n <textarea id=\"review-detail\" class=\"w-100\" placeholder=\"Contanos por qu\u00E9\" formControlName=\"comment\"></textarea>\r\n <small class=\"text-uppercase\">(*) {{\"mandatory-fields\" | translate }}</small>\r\n </div>\r\n </div>\r\n\r\n <!-- Bot\u00F3n de env\u00EDo -->\r\n <div class=\"row\">\r\n <div class=\"col-4\"></div>\r\n <div class=\"col-8\">\r\n <button type=\"submit\" class=\"btn btn-dark py-2 px-4 rounded-0 mt-4\"\r\n [disabled]=\"reviews_form.invalid\">{{\"submit-review\" | translate }}</button>\r\n </div>\r\n </div> \r\n</form>", styles: [".cont-star{direction:rtl;unicode-bidi:bidi-override;display:flex;justify-content:end}.cont-star label{display:flex}.cont-star label i{color:#ccc!important;cursor:pointer;font-size:26px;line-height:30px}.cont-star label i:hover,.cont-star label:hover~label i{color:#ffc107!important}input[type=radio]:checked~label i{color:#ffc107!important}input[type=radio]:checked~label i:before,label:hover i:before{content:\"\\f586\"}\n"] }]
|
|
126
|
+
}], ctorParameters: () => [{ type: i1.ToastService }, { type: i2.Router }, { type: i3.CoreConstantsService }, { type: i4.FormBuilder }, { type: i5.ProductsService }, { type: i6.AuthService }, { type: i7.ReviewsService }], propDecorators: { product: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], withAuthenticated: [{
|
|
129
|
+
type: Input
|
|
130
|
+
}], max: [{
|
|
131
|
+
type: Input
|
|
132
|
+
}], ready: [{
|
|
133
|
+
type: Output
|
|
134
|
+
}] } });
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reviews-form-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/reviews-form-ec/reviews-form-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/reviews-form-ec/reviews-form-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators} from '@angular/forms';\r\nimport { Router } from '@angular/router';\r\nimport { ComponentHelper } from '../../classes/component-helper';\r\nimport { CoreConstantsService } from '../../constants/core.constants.service';\r\nimport { AuthService } from '../../ec-services/auth.service';\r\nimport { ProductsService } from '../../ec-services/products.service';\r\nimport { ReviewsService } from '../../ec-services/reviews.service';\r\nimport { ToastService } from '../../ec-services/toast.service';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n    selector: 'app-reviews-form-ec',\r\n    standalone: true,\r\n\timports: [TranslateModule, ReactiveFormsModule],\r\n    templateUrl: './reviews-form-ec.component.html',\r\n    styleUrls: ['./reviews-form-ec.component.scss'],\r\n   \r\n})\r\nexport class ReviewsFormEcComponent extends ComponentHelper implements OnInit {\r\n    \r\n    /**\r\n     * @description producto al que se le va a agregar la reseña.\r\n     */\r\n    @Input() product:any;\r\n    /**\r\n     * @description para controlar si esta logueado.\r\n     */\r\n    @Input() withAuthenticated: boolean = true;\r\n    /**\r\n     * @description número maximo de valor de puntuación\r\n     */\r\n    @Input() max:number = 5;\r\n    /**\r\n     * @description para indicar cuando se termino la operación de consulta.\r\n     */\r\n    @Output() ready = new EventEmitter<boolean>();\r\n    \r\n    public reviews_form: FormGroup;\r\n\r\n    public loading:boolean = false;\r\n    protected form_data: any = new FormData();\r\n    public limit:number[]=[];\r\n\r\n    constructor(protected toastrService: ToastService, public router: Router, public consts: CoreConstantsService,\r\n        public formBuilder: FormBuilder, public productService: ProductsService, public authService:AuthService, public reviewsService:ReviewsService) {\r\n        super()\r\n        this.reviews_form = formBuilder.group({\r\n            title: ['', Validators.required],\r\n            comment: ['', Validators.required],\r\n            rating: [0, Validators.required],\r\n            email:['', this.withAuthenticated ? [] : [Validators.required, Validators.email]],\r\n            //attachment: [''],\r\n        })\r\n         this.ecOnConstruct() // Removed as the method does not exist\r\n    }\r\n     \r\n    ngOnInit() {\r\n        for (let index = 0; index < this.max; index++) {\r\n            this.limit.push(index + 1)\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @description guarda el valor que contiene la puntuación de la reseña.\r\n     * @param value \r\n     */\r\n    setRatingValue = (value:number=0) => {\r\n        this.reviews_form.controls['rating'].setValue(value)\r\n    }\r\n\r\n    /**\r\n     * @description procesa el formulario con los datos.\r\n     * @param form \r\n     * @param success_message mensaje para que se muestre en el caso de exito.\r\n     */\r\n    sendForm = (form:FormGroup, success_message?:string ) => {\r\n        if (form.valid) {\r\n            this.withAuthenticated ? this.reviews_form.controls['email'].setValue(this.authService.getUserProfileAsUser().email) : null\r\n            \r\n            this.productService.saveReviews(this.product.id,form.value).toPromise().then(\r\n                res => {\r\n                    this.reviews_form.reset()\r\n                    this.toastrService.show(success_message ? success_message : 'success-review');\r\n                    this.loading = false\r\n                    this.ready.emit(true)\r\n                    // Queda preparado por si algun dia se quiere manejar sincronismo.\r\n                    //this.updateReviews()\r\n                },\r\n                err => {\r\n                    this.toastrService.show('inquiry-error');\r\n                    this.loading = false\r\n                    this.ready.emit(true)\r\n                }\r\n            );\r\n        } else {\r\n            this.toastrService.show('invalid-form');\r\n            this.loading = false\r\n            this.ready.emit(true)\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @descirption controla que el usuario este logueado para comentar. Si la variable withAuthenticated es falso entonces no realiza este control.\r\n     * @param e evento producido por el submit del formulario\r\n     */\r\n    toastReviewsForm = (e: Event, message?: string): void => {\r\n        this.loading = true;\r\n        e.preventDefault();\r\n        if (this.withAuthenticated) {\r\n            this.authService.isAuthenticated() ? \r\n            this.sendForm(this.reviews_form, message ? message : 'success-review') : this.toastrService.show('authenticated-for-comment')\r\n        } else {\r\n            this.sendForm(this.reviews_form, message ? message : 'success-review')\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @description actualiza las reviews\r\n     * @returns \r\n     */\r\n    updateReviews = () => this.reviewsService.updateReviewsByCode(this.product.id)\r\n}\r\n","<form class=\"formResenia\"  [formGroup]=\"reviews_form\" (submit)=\"toastReviewsForm($event)\">\r\n  <div class=\"row\">\r\n      <div class=\"col-4\">\r\n          <label class=\"pt-2\">{{\"product\" | translate }}*</label>\r\n      </div>\r\n      <div class=\"col-8\">\r\n          <p class=\"mt-1 mb-3\">{{ product.name }}</p>\r\n      </div>\r\n  </div>\r\n\r\n  <!-- Calificación -->\r\n  <div class=\"row\">\r\n      <div class=\"col-4\">\r\n          <label class=\"pt-2\">{{\"rating\" | translate}}*</label>\r\n      </div>\r\n      <div class=\"col-8\">\r\n          <div class=\"cont-star mt-1 mb-3\">\r\n              @for(star of limit; track $index){\r\n                  <input type=\"radio\" class=\"d-none\" [id]=\"'star-' + (limit.length - $index)\" [value]=\"limit.length - $index\"\r\n                      formControlName=\"rating\">\r\n                  <label class=\"star-label\" [for]=\"'star-' + (limit.length - $index)\">\r\n                      <i class=\"bi bi-star-fill\"></i>\r\n                  </label>\r\n                }\r\n          </div>\r\n      </div>\r\n  </div>\r\n\r\n  <!-- Resumen -->\r\n  <div class=\"row\">\r\n      <div class=\"col-4\">\r\n          <label for=\"review-summary\" class=\"pt-2\">{{\"summary\" | translate }}*</label>\r\n      </div>\r\n      <div class=\"col-8\">\r\n          <textarea id=\"review-summary\" class=\"w-100\" placeholder=\"¿Cómo fue tu experiencia?\" formControlName=\"title\"></textarea>\r\n      </div>\r\n  </div>\r\n\r\n  <!-- Detalle -->\r\n  <div class=\"row\">\r\n      <div class=\"col-4\">\r\n          <label for=\"review-detail\" class=\"pt-2\">{{\"detail\" | translate }}*</label>\r\n      </div>\r\n      <div class=\"col-8\">\r\n          <textarea id=\"review-detail\" class=\"w-100\" placeholder=\"Contanos por qué\" formControlName=\"comment\"></textarea>\r\n          <small class=\"text-uppercase\">(*) {{\"mandatory-fields\" | translate }}</small>\r\n      </div>\r\n  </div>\r\n\r\n  <!-- Botón de envío -->\r\n  <div class=\"row\">\r\n      <div class=\"col-4\"></div>\r\n      <div class=\"col-8\">\r\n          <button type=\"submit\" class=\"btn btn-dark py-2 px-4 rounded-0 mt-4\"\r\n              [disabled]=\"reviews_form.invalid\">{{\"submit-review\" | translate }}</button>\r\n      </div>\r\n  </div> \r\n</form>"]}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { Component, inject, Input } from '@angular/core';
|
|
2
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
3
|
+
import { ActivatedRoute } from '@angular/router';
|
|
4
|
+
import { ToastrService } from 'ngx-toastr';
|
|
5
|
+
import { ComponentHelper } from '../../classes/component-helper';
|
|
6
|
+
import { OptionsService } from '../../ec-services';
|
|
7
|
+
import { BlocksEcComponent } from "../blocks-ec/blocks-ec.component";
|
|
8
|
+
import { LoadingFullEcComponent } from "../widgets-ec/loading/loading-full-ec/loading-full-ec.component";
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
export class SectionContainerEcComponent extends ComponentHelper {
|
|
11
|
+
content_html = "<p>Sin información</p>";
|
|
12
|
+
loadSection = false;
|
|
13
|
+
sanitizeHtml = false;
|
|
14
|
+
name = null;
|
|
15
|
+
dataSection;
|
|
16
|
+
sections = [];
|
|
17
|
+
optionsService = inject(OptionsService);
|
|
18
|
+
activatedRoute = inject(ActivatedRoute);
|
|
19
|
+
toastrService = inject(ToastrService);
|
|
20
|
+
sanitizer = inject(DomSanitizer);
|
|
21
|
+
constructor() {
|
|
22
|
+
super();
|
|
23
|
+
this.optionsService.getSections();
|
|
24
|
+
this.ecOnConstruct();
|
|
25
|
+
}
|
|
26
|
+
ngOnInit() {
|
|
27
|
+
if (this.name) {
|
|
28
|
+
this.getSection(this.name);
|
|
29
|
+
this.getDataSection(this.name);
|
|
30
|
+
//console.log('con parametro')
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
this.activatedRoute.params.subscribe(params => {
|
|
34
|
+
this.name = params['name'];
|
|
35
|
+
this.getSection(this.name);
|
|
36
|
+
this.getDataSection(this.name);
|
|
37
|
+
//console.log('sin parametro', this.name)
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
this.ecOnInit();
|
|
41
|
+
}
|
|
42
|
+
getSection = (link) => {
|
|
43
|
+
this.loadSection = false;
|
|
44
|
+
this.optionsService.getSectionContentByLink(link).toPromise().then((html) => {
|
|
45
|
+
if (html)
|
|
46
|
+
this.content_html =
|
|
47
|
+
this.sanitizeHtml
|
|
48
|
+
? html
|
|
49
|
+
: this.sanitizer.bypassSecurityTrustHtml(html);
|
|
50
|
+
this.loadSection = true;
|
|
51
|
+
}, (error) => {
|
|
52
|
+
console.log(error);
|
|
53
|
+
this.loadSection = true;
|
|
54
|
+
this.content_html = "<p>Sin información</p>";
|
|
55
|
+
this.toastrService.show('No fue posible encontrar la sección solicitada');
|
|
56
|
+
}).catch((error) => {
|
|
57
|
+
this.content_html = "<p>Sin información</p>";
|
|
58
|
+
this.loadSection = true;
|
|
59
|
+
});
|
|
60
|
+
};
|
|
61
|
+
getDataSection = (code) => {
|
|
62
|
+
this.dataSection = this.sections.find(section => section.code == code);
|
|
63
|
+
};
|
|
64
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SectionContainerEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
65
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SectionContainerEcComponent, isStandalone: true, selector: "app-section-container-ec", inputs: { sanitizeHtml: "sanitizeHtml", name: "name" }, usesInheritance: true, ngImport: i0, template: "<div class=\"container-fluid\">\r\n <div class=\"row\">\r\n <div class=\"col-12\">\r\n <div class=\"scrol-if\">\r\n @if (loadSection){\r\n <div [innerHtml]=\"content_html\"></div>\r\n } @else {\r\n <div class=\"col-12 align-items-center\">\r\n <div class=\"d-flex flex-column jusitfy-content-center align-items-center my-5\">\r\n <app-loading-full-ec></app-loading-full-ec>\r\n </div>\r\n </div>\r\n }\r\n\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<app-blocks-ec [section]=\"name\"></app-blocks-ec>", styles: [".custom-page{background-color:#fff!important;padding-top:5%!important;padding-bottom:5%!important}.scrol-if{overflow:auto}\n"], dependencies: [{ kind: "component", type: BlocksEcComponent, selector: "app-blocks-ec", inputs: ["templates", "show_loading", "section", "blockFilters"] }, { kind: "component", type: LoadingFullEcComponent, selector: "app-loading-full-ec" }] });
|
|
66
|
+
}
|
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SectionContainerEcComponent, decorators: [{
|
|
68
|
+
type: Component,
|
|
69
|
+
args: [{ selector: 'app-section-container-ec', standalone: true, imports: [BlocksEcComponent, LoadingFullEcComponent], template: "<div class=\"container-fluid\">\r\n <div class=\"row\">\r\n <div class=\"col-12\">\r\n <div class=\"scrol-if\">\r\n @if (loadSection){\r\n <div [innerHtml]=\"content_html\"></div>\r\n } @else {\r\n <div class=\"col-12 align-items-center\">\r\n <div class=\"d-flex flex-column jusitfy-content-center align-items-center my-5\">\r\n <app-loading-full-ec></app-loading-full-ec>\r\n </div>\r\n </div>\r\n }\r\n\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<app-blocks-ec [section]=\"name\"></app-blocks-ec>", styles: [".custom-page{background-color:#fff!important;padding-top:5%!important;padding-bottom:5%!important}.scrol-if{overflow:auto}\n"] }]
|
|
70
|
+
}], ctorParameters: () => [], propDecorators: { sanitizeHtml: [{
|
|
71
|
+
type: Input
|
|
72
|
+
}], name: [{
|
|
73
|
+
type: Input
|
|
74
|
+
}] } });
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"section-container-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/section-container-ec/section-container-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/section-container-ec/section-container-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, OnInit } from '@angular/core';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { ComponentHelper } from '../../classes/component-helper';\r\nimport { OptionsService } from '../../ec-services';\r\nimport { BlocksEcComponent } from \"../blocks-ec/blocks-ec.component\";\r\nimport { LoadingFullEcComponent } from \"../widgets-ec/loading/loading-full-ec/loading-full-ec.component\";\r\n\r\n@Component({\r\n    selector: 'app-section-container-ec',\r\n    standalone: true,\r\n    imports: [BlocksEcComponent, LoadingFullEcComponent],\r\n    templateUrl: './section-container-ec.component.html',\r\n    styleUrls: ['./section-container-ec.component.scss']\r\n})\r\nexport class SectionContainerEcComponent extends ComponentHelper implements OnInit {\r\n\r\n    public content_html: SafeHtml = \"<p>Sin información</p>\";\r\n    public loadSection: boolean = false;\r\n    @Input() sanitizeHtml: boolean = false\r\n    @Input() name = null;\r\n    public dataSection: any;\r\n    private sections: any[] = [];\r\n\r\n    private optionsService: OptionsService = inject(OptionsService)\r\n    private activatedRoute: ActivatedRoute = inject(ActivatedRoute)\r\n    private toastrService: ToastrService = inject(ToastrService)\r\n    private sanitizer: DomSanitizer = inject(DomSanitizer)\r\n    constructor() {\r\n        super();\r\n        this.optionsService.getSections();\r\n        this.ecOnConstruct()\r\n    }\r\n\r\n    ngOnInit() {\r\n        if (this.name) {\r\n            this.getSection(this.name)\r\n            this.getDataSection(this.name)\r\n            //console.log('con parametro')\r\n        } else {\r\n            this.activatedRoute.params.subscribe(\r\n                params => {\r\n                    this.name = params['name'];\r\n                    this.getSection(this.name)\r\n                    this.getDataSection(this.name)\r\n                    //console.log('sin parametro', this.name)\r\n                }\r\n            );\r\n        }\r\n\r\n        this.ecOnInit()\r\n    }\r\n\r\n    getSection = (link: any) => {\r\n        this.loadSection = false\r\n        this.optionsService.getSectionContentByLink(link).toPromise().then(\r\n            (html: string) => {\r\n                if (html) this.content_html =\r\n                    this.sanitizeHtml\r\n                        ? html\r\n                        : this.sanitizer.bypassSecurityTrustHtml(html)\r\n                this.loadSection = true\r\n            }\r\n            ,\r\n            (error: any) => {\r\n                console.log(error);\r\n                this.loadSection = true\r\n                this.content_html = \"<p>Sin información</p>\";\r\n                this.toastrService.show('No fue posible encontrar la sección solicitada');\r\n            }\r\n        ).catch((error: any) => {\r\n            this.content_html = \"<p>Sin información</p>\"\r\n            this.loadSection = true\r\n        });\r\n    }\r\n\r\n    getDataSection = (code: any) => {\r\n        this.dataSection = this.sections.find(section => section.code == code)\r\n    }\r\n}","<div class=\"container-fluid\">\r\n    <div class=\"row\">\r\n        <div class=\"col-12\">\r\n            <div class=\"scrol-if\">\r\n                @if (loadSection){\r\n                <div [innerHtml]=\"content_html\"></div>\r\n                } @else {\r\n                <div class=\"col-12 align-items-center\">\r\n                    <div class=\"d-flex flex-column jusitfy-content-center align-items-center my-5\">\r\n                        <app-loading-full-ec></app-loading-full-ec>\r\n                    </div>\r\n                </div>\r\n                }\r\n\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<app-blocks-ec [section]=\"name\"></app-blocks-ec>"]}
|