simpo-component-library 3.6.121 → 3.6.123
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/esm2022/lib/directive/button-directive.directive.mjs +4 -4
- package/esm2022/lib/directive/button-editor.directive.mjs +4 -1
- package/esm2022/lib/ecommerce/sections/order-details/order-details.component.mjs +26 -11
- package/esm2022/lib/ecommerce/sections/store-list/store-list.component.mjs +133 -0
- package/esm2022/lib/ecommerce/sections/store-list/store-list.modal.mjs +2 -0
- package/esm2022/lib/ecommerce/sections/store-page/store-page.component.mjs +109 -0
- package/esm2022/lib/ecommerce/sections/store-page/store-page.model.mjs +2 -0
- package/esm2022/lib/sections/header-section/header-section.component.mjs +37 -9
- package/esm2022/lib/sections/news-letter-component/news-letter-component.component.mjs +106 -0
- package/esm2022/lib/sections/news-letter-component/news-letter.modal.mjs +2 -0
- package/esm2022/lib/services/rest.service.mjs +26 -2
- package/esm2022/public-api.mjs +4 -1
- package/fesm2022/simpo-component-library.mjs +577 -233
- package/fesm2022/simpo-component-library.mjs.map +1 -1
- package/lib/ecommerce/sections/order-details/order-details.component.d.ts +5 -1
- package/lib/ecommerce/sections/product-desc/product-desc.component.d.ts +1 -1
- package/lib/ecommerce/sections/store-list/store-list.component.d.ts +36 -0
- package/lib/ecommerce/sections/store-list/store-list.modal.d.ts +11 -0
- package/lib/ecommerce/sections/store-page/store-page.component.d.ts +26 -0
- package/lib/ecommerce/sections/store-page/store-page.model.d.ts +11 -0
- package/lib/sections/header-section/header-section.component.d.ts +11 -1
- package/lib/sections/news-letter-component/news-letter-component.component.d.ts +26 -0
- package/lib/sections/news-letter-component/news-letter.modal.d.ts +19 -0
- package/lib/services/rest.service.d.ts +4 -0
- package/package.json +1 -1
- package/public-api.d.ts +3 -0
- package/simpo-component-library-3.6.123.tgz +0 -0
- package/src/lib/styles/global-styles.css +6 -0
- package/simpo-component-library-3.6.121.tgz +0 -0
@@ -0,0 +1,133 @@
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
2
|
+
import BaseSection from '../../../sections/BaseSection';
|
3
|
+
import { CommonModule } from '@angular/common';
|
4
|
+
import { AnimationDirective } from '../../../directive/animation-directive';
|
5
|
+
import { BackgroundDirective } from '../../../directive/background-directive';
|
6
|
+
import { CornerDirective } from '../../../directive/corner-directive';
|
7
|
+
import { SimpoComponentModule } from '../../../components/index';
|
8
|
+
import { HoverDirective } from '../../../directive/hover-element-directive';
|
9
|
+
import { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';
|
10
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
11
|
+
import { MatIcon } from '@angular/material/icon';
|
12
|
+
import { ContentFitDirective } from '../../../directive/content-fit-directive';
|
13
|
+
import { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';
|
14
|
+
import * as i0 from "@angular/core";
|
15
|
+
import * as i1 from "../../../services/rest.service";
|
16
|
+
import * as i2 from "@angular/router";
|
17
|
+
import * as i3 from "@angular/common";
|
18
|
+
import * as i4 from "@angular/forms";
|
19
|
+
import * as i5 from "../../../components/hover-elements/hover-elements.component";
|
20
|
+
import * as i6 from "../../../components/delete-hover-element/delete-hover-element.component";
|
21
|
+
import * as i7 from "ngx-skeleton-loader";
|
22
|
+
export class StoreListComponent extends BaseSection {
|
23
|
+
constructor(restService, router) {
|
24
|
+
super();
|
25
|
+
this.restService = restService;
|
26
|
+
this.router = router;
|
27
|
+
this.edit = true;
|
28
|
+
this.pageNo = 0;
|
29
|
+
this.isLoading = false;
|
30
|
+
this.cardSize = 50;
|
31
|
+
this.storesList = [];
|
32
|
+
this.storePayload = {
|
33
|
+
businessId: localStorage.getItem('businessId') ?? "",
|
34
|
+
pageNo: 0,
|
35
|
+
pageSize: 15
|
36
|
+
};
|
37
|
+
this.showMessage = false;
|
38
|
+
this.totalCount = 0;
|
39
|
+
this.submit = false;
|
40
|
+
this.loader = false;
|
41
|
+
this.error = false;
|
42
|
+
}
|
43
|
+
ngOnInit() {
|
44
|
+
this.styles = this.data?.styles;
|
45
|
+
this.getStoreDetails();
|
46
|
+
}
|
47
|
+
getDataWithPincode() {
|
48
|
+
if (this.pincode.toString().length != 6) {
|
49
|
+
this.error = true;
|
50
|
+
return;
|
51
|
+
}
|
52
|
+
this.storePayload.pincode = this.pincode;
|
53
|
+
this.getStoreDetails();
|
54
|
+
}
|
55
|
+
getStoreDetails() {
|
56
|
+
this.submit = true;
|
57
|
+
this.loader = true;
|
58
|
+
this.restService.getAllStores(this.storePayload).subscribe((res) => {
|
59
|
+
this.storesList = res?.data?.data;
|
60
|
+
this.totalCount = res?.data?.count;
|
61
|
+
if (this.pincode?.toString().length == 6)
|
62
|
+
this.showMessage = res?.data?.storePresent;
|
63
|
+
this.storePayload.pageNo++;
|
64
|
+
this.isLoading = false;
|
65
|
+
this.loader = false;
|
66
|
+
}, (error) => {
|
67
|
+
this.loader = false;
|
68
|
+
});
|
69
|
+
}
|
70
|
+
getTextColor(bgColor) {
|
71
|
+
if (bgColor) {
|
72
|
+
const threshold = 130; // Adjust this threshold as needed
|
73
|
+
const r = parseInt(bgColor.slice(1, 3), 16);
|
74
|
+
const g = parseInt(bgColor.slice(3, 5), 16);
|
75
|
+
const b = parseInt(bgColor.slice(5, 7), 16);
|
76
|
+
const brightness = (r * 299 + g * 587 + b * 114) / 1000;
|
77
|
+
return brightness > threshold ? '#000000' : '#ffffff';
|
78
|
+
}
|
79
|
+
return "#ffffff;";
|
80
|
+
}
|
81
|
+
openWhatsapp(phone) {
|
82
|
+
if (phone) {
|
83
|
+
const whatsappUrl = `https://wa.me/${phone}`;
|
84
|
+
window.open(whatsappUrl, '_blank');
|
85
|
+
}
|
86
|
+
}
|
87
|
+
viewStore(storeId) {
|
88
|
+
this.router.navigate(['/store'], { queryParams: { storeId: storeId } });
|
89
|
+
}
|
90
|
+
getTime(storeHours, type) {
|
91
|
+
const today = new Date();
|
92
|
+
const dayName = today.toLocaleDateString('en-US', { weekday: 'long' }).toUpperCase();
|
93
|
+
for (let ele of storeHours) {
|
94
|
+
if (ele.dayOfWeek == dayName) {
|
95
|
+
if (type == 'OPEN') {
|
96
|
+
return ele.openingTime;
|
97
|
+
}
|
98
|
+
else {
|
99
|
+
return ele.closingTime;
|
100
|
+
}
|
101
|
+
}
|
102
|
+
}
|
103
|
+
}
|
104
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: StoreListComponent, deps: [{ token: i1.RestService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
|
105
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: StoreListComponent, isStandalone: true, selector: "simpo-store-list", inputs: { data: "data", edit: "edit", customClass: "customClass", delete: "delete", index: "index" }, usesInheritance: true, ngImport: i0, template: "<div class=\"total-container position-relative\" simpoHover (hovering)=\"showEditTabs($event)\" [id]=\"data?.id\">\r\n <div class=\"main-container\" [simpoAnimation]=\"styles?.animation\" [id]=\"data?.id\">\r\n <div class=\"top-section w-100 d-flex align-items-center justify-content-center text-center flex-column\"\r\n [simpoBackground]=\"styles?.background\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\">\r\n <ng-container *ngIf=\"!loader\">\r\n <div class=\"store-header mb-3\">\r\n {{ submit && showMessage == true && pincode && pincode.toString().length == 6 ? \"Stores in \" +\r\n pincode :\r\n \"Find a Store Near You\"}}\r\n </div>\r\n <div class=\"sub-text\">\r\n {{ submit && showMessage == true && pincode && pincode.toString().length == 6 ? 'We have ' +\r\n totalCount\r\n + ' stores in this locality, scroll down to view the stores\r\n and browse the designs available.' : 'Locate a store near you \u2014 our presence is expanding every day,\r\n and\r\n we look forward to serving you.' }}\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"loader\">\r\n <div class=\"sub-text\">\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '35%',\r\n height: '3vh',\r\n 'border-radius': '12px',\r\n }\"></ngx-skeleton-loader>\r\n </div>\r\n <div class=\"sub-text w-75\">\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '35%',\r\n height: '2vh',\r\n 'border-radius': '12px',\r\n }\"></ngx-skeleton-loader>\r\n </div>\r\n </ng-container>\r\n <div class=\"location-container d-flex align-items-center justify-content-between w-25\" [class.error-border]=\"error\">\r\n <div class=\"d-flex align-items-center w-90\">\r\n <div class=\"d-flex mx-1\"><mat-icon class=\"d-flex align-items-center justify-content-center f-20\"\r\n [style.color]=\"data?.styles?.background?.accentColor\">gps_fixed</mat-icon>\r\n </div>\r\n <input type=\"number\" placeholder=\"Pin Code\" [(ngModel)]=\"pincode\" class=\"w-90\"\r\n [style.backgroundColor]=\"data?.styles?.background?.color\"\r\n [style.color]=\"getTextColor(data?.styles?.background?.color)\"\r\n (ngModelChange)=\"pincode.toString().length != 6 ? submit = false : error = false\"/>\r\n </div>\r\n <div (click)=\"getDataWithPincode()\" class=\"f-13 cursor-pointer\">Submit</div>\r\n </div>\r\n </div>\r\n <div class=\"bottom-container row w-75 mx-auto\">\r\n <div class=\"w-100 d-flex align-items-center justify-content-center mb-3\"\r\n *ngIf=\"submit && showMessage == false && pincode && pincode.toString().length ==6 && !loader\">\r\n <div class=\"text-center not-available-text\">We are not available in this location currently</div>\r\n </div>\r\n <ng-container *ngIf=\"loader\">\r\n <div class=\"sub-text w-100 text-center\">\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '35%',\r\n height: '6vh',\r\n 'border-radius': '12px',\r\n }\"></ngx-skeleton-loader>\r\n </div>\r\n </ng-container>\r\n <div class=\"bottom-sub-text mb-3 w-100 f-20\">Showing Stores</div>\r\n <ng-container *ngIf=\"!loader;else loaderScreen\">\r\n <div class=\"col-4 p-2\" style=\"border-radius: 12px; border: none;\"\r\n *ngFor=\"let ele of storesList; let i = index\">\r\n <div class=\"card-body p-4 h-100 position-relative\">\r\n <div class=\"d-flex justify-content-between align-items-start mb-3\">\r\n <div>\r\n <h5 class=\"card-title fw-bold mb-1\">{{ele?.name}}</h5>\r\n </div>\r\n </div>\r\n <div class=\"mb-3\">\r\n <p class=\"mb-1 text-dark fw-medium\">{{ele?.addressDetails?.address}},</p>\r\n <p class=\"mb-1 text-dark fw-medium\">{{ele?.addressDetails?.city}},\r\n {{ele?.addressDetails?.state}},{{ele?.addressDetails?.pincode}},</p>\r\n <p class=\"mb-0\">Phone-<span [style.color]=\"data?.styles?.background?.accentColor\">{{ele?.phone}}</span></p>\r\n </div>\r\n <div class=\"mb-4\">\r\n <p class=\"mb-0\" [style.color]=\"data?.styles?.background?.accentColor\">STORE HOURS -\r\n {{getTime(ele?.storeHours,'OPEN')}} to {{getTime(ele?.storeHours,'CLOSE')}}\r\n </p>\r\n </div>\r\n <div class=\"d-flex gap-3 align-items-center card-bottom\">\r\n <div class=\"rounded-circle d-flex align-items-center justify-content-center\"\r\n style=\"width: 40px; height: 30px; background-color: #25d366;\"\r\n (click)=\"openWhatsapp(ele?.phone)\">\r\n <i class=\"fab fa-whatsapp text-white fs-5\"></i>\r\n </div>\r\n <!-- <button class=\"btn flex-fill py-2 fw-semibold\"\r\n style=\"background-color: #e8e3ff; color: #6b46c1; border: none; border-radius: 25px;font-size: 12px !important;\">\r\n BOOK A VISIT\r\n </button> -->\r\n <button class=\"btn flex-fill py-2 fw-semibold text-white\"\r\n style=\"background: linear-gradient(135deg, #a855f7, #ec4899); border: none; border-radius: 25px;font-size: 12px !important;\"\r\n (click)=\"viewStore(ele.storeId)\">\r\n VIEW STORE\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-template #loaderScreen>\r\n <div class=\"row\">\r\n <ng-container *ngFor=\"let ele of [1,2,3,4,5,6]\">\r\n <ngx-skeleton-loader class=\"col-4\" [theme]=\"{\r\n width: '100%',\r\n height: '40vh',\r\n 'border-radius': '12px',\r\n }\"></ngx-skeleton-loader>\r\n </ng-container>\r\n </div>\r\n </ng-template>\r\n </div>\r\n </div>\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n </div>\r\n\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n</div>", styles: [".hover_effect{position:unset;width:100%;top:0;left:0;height:100%}.store-header{font-size:27px;font-weight:700}.sub-text{font-size:16px;width:35%;margin-bottom:15px}.location-container{border:1px solid;padding:8px;border-radius:12px}.location-container input{border:unset;appearance:unset;outline:unset;font-size:13px}.not-available-text{color:#ff5151;font-weight:600;border-radius:22px;text-align:center;padding:12px;background:#ff51511a;width:35%}.f-20{font-size:20px}.f-13{font-size:13px}.w-90{width:90%}.card-body{border:1px solid;border-radius:18px;height:100%}.cdk-virtual-scroll-viewport{display:unset}.cdk-virtual-scroll-content-wrapper{position:unset!important}.card-bottom{position:absolute;bottom:8px;left:25px;width:90%}.error-border{border:2px solid #dc3545!important}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { 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.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: SimpoComponentModule }, { kind: "component", type: i5.HoverElementsComponent, selector: "simpo-hover-elements", inputs: ["data", "index", "editOptions", "isMerged", "isEcommerce"], outputs: ["edit"] }, { kind: "component", type: i6.DeleteHoverElementComponent, selector: "simpo-delete-hover-element", inputs: ["index", "data"], outputs: ["edit"] }, { kind: "component", type: i7.NgxSkeletonLoaderComponent, selector: "ngx-skeleton-loader", inputs: ["count", "loadingText", "appearance", "animation", "ariaLabel", "theme"] }, { kind: "directive", type: AnimationDirective, selector: "[simpoAnimation]", inputs: ["simpoAnimation"] }, { kind: "directive", type: BackgroundDirective, selector: "[simpoBackground]", inputs: ["simpoBackground", "scrollValue"] }, { kind: "directive", type: HoverDirective, selector: "[simpoHover]", outputs: ["hovering"] }, { kind: "directive", type: ContentFitDirective, selector: "[simpoLayout]", inputs: ["simpoLayout"] }, { kind: "ngmodule", type: NgxSkeletonLoaderModule }] }); }
|
106
|
+
}
|
107
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: StoreListComponent, decorators: [{
|
108
|
+
type: Component,
|
109
|
+
args: [{ selector: 'simpo-store-list', standalone: true, imports: [CommonModule,
|
110
|
+
FormsModule,
|
111
|
+
ReactiveFormsModule,
|
112
|
+
MatIcon,
|
113
|
+
SimpoComponentModule,
|
114
|
+
AnimationDirective,
|
115
|
+
BackgroundDirective,
|
116
|
+
CornerDirective,
|
117
|
+
HoverDirective,
|
118
|
+
ButtonDirectiveDirective,
|
119
|
+
ContentFitDirective,
|
120
|
+
NgxSkeletonLoaderModule,
|
121
|
+
], template: "<div class=\"total-container position-relative\" simpoHover (hovering)=\"showEditTabs($event)\" [id]=\"data?.id\">\r\n <div class=\"main-container\" [simpoAnimation]=\"styles?.animation\" [id]=\"data?.id\">\r\n <div class=\"top-section w-100 d-flex align-items-center justify-content-center text-center flex-column\"\r\n [simpoBackground]=\"styles?.background\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\">\r\n <ng-container *ngIf=\"!loader\">\r\n <div class=\"store-header mb-3\">\r\n {{ submit && showMessage == true && pincode && pincode.toString().length == 6 ? \"Stores in \" +\r\n pincode :\r\n \"Find a Store Near You\"}}\r\n </div>\r\n <div class=\"sub-text\">\r\n {{ submit && showMessage == true && pincode && pincode.toString().length == 6 ? 'We have ' +\r\n totalCount\r\n + ' stores in this locality, scroll down to view the stores\r\n and browse the designs available.' : 'Locate a store near you \u2014 our presence is expanding every day,\r\n and\r\n we look forward to serving you.' }}\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"loader\">\r\n <div class=\"sub-text\">\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '35%',\r\n height: '3vh',\r\n 'border-radius': '12px',\r\n }\"></ngx-skeleton-loader>\r\n </div>\r\n <div class=\"sub-text w-75\">\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '35%',\r\n height: '2vh',\r\n 'border-radius': '12px',\r\n }\"></ngx-skeleton-loader>\r\n </div>\r\n </ng-container>\r\n <div class=\"location-container d-flex align-items-center justify-content-between w-25\" [class.error-border]=\"error\">\r\n <div class=\"d-flex align-items-center w-90\">\r\n <div class=\"d-flex mx-1\"><mat-icon class=\"d-flex align-items-center justify-content-center f-20\"\r\n [style.color]=\"data?.styles?.background?.accentColor\">gps_fixed</mat-icon>\r\n </div>\r\n <input type=\"number\" placeholder=\"Pin Code\" [(ngModel)]=\"pincode\" class=\"w-90\"\r\n [style.backgroundColor]=\"data?.styles?.background?.color\"\r\n [style.color]=\"getTextColor(data?.styles?.background?.color)\"\r\n (ngModelChange)=\"pincode.toString().length != 6 ? submit = false : error = false\"/>\r\n </div>\r\n <div (click)=\"getDataWithPincode()\" class=\"f-13 cursor-pointer\">Submit</div>\r\n </div>\r\n </div>\r\n <div class=\"bottom-container row w-75 mx-auto\">\r\n <div class=\"w-100 d-flex align-items-center justify-content-center mb-3\"\r\n *ngIf=\"submit && showMessage == false && pincode && pincode.toString().length ==6 && !loader\">\r\n <div class=\"text-center not-available-text\">We are not available in this location currently</div>\r\n </div>\r\n <ng-container *ngIf=\"loader\">\r\n <div class=\"sub-text w-100 text-center\">\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '35%',\r\n height: '6vh',\r\n 'border-radius': '12px',\r\n }\"></ngx-skeleton-loader>\r\n </div>\r\n </ng-container>\r\n <div class=\"bottom-sub-text mb-3 w-100 f-20\">Showing Stores</div>\r\n <ng-container *ngIf=\"!loader;else loaderScreen\">\r\n <div class=\"col-4 p-2\" style=\"border-radius: 12px; border: none;\"\r\n *ngFor=\"let ele of storesList; let i = index\">\r\n <div class=\"card-body p-4 h-100 position-relative\">\r\n <div class=\"d-flex justify-content-between align-items-start mb-3\">\r\n <div>\r\n <h5 class=\"card-title fw-bold mb-1\">{{ele?.name}}</h5>\r\n </div>\r\n </div>\r\n <div class=\"mb-3\">\r\n <p class=\"mb-1 text-dark fw-medium\">{{ele?.addressDetails?.address}},</p>\r\n <p class=\"mb-1 text-dark fw-medium\">{{ele?.addressDetails?.city}},\r\n {{ele?.addressDetails?.state}},{{ele?.addressDetails?.pincode}},</p>\r\n <p class=\"mb-0\">Phone-<span [style.color]=\"data?.styles?.background?.accentColor\">{{ele?.phone}}</span></p>\r\n </div>\r\n <div class=\"mb-4\">\r\n <p class=\"mb-0\" [style.color]=\"data?.styles?.background?.accentColor\">STORE HOURS -\r\n {{getTime(ele?.storeHours,'OPEN')}} to {{getTime(ele?.storeHours,'CLOSE')}}\r\n </p>\r\n </div>\r\n <div class=\"d-flex gap-3 align-items-center card-bottom\">\r\n <div class=\"rounded-circle d-flex align-items-center justify-content-center\"\r\n style=\"width: 40px; height: 30px; background-color: #25d366;\"\r\n (click)=\"openWhatsapp(ele?.phone)\">\r\n <i class=\"fab fa-whatsapp text-white fs-5\"></i>\r\n </div>\r\n <!-- <button class=\"btn flex-fill py-2 fw-semibold\"\r\n style=\"background-color: #e8e3ff; color: #6b46c1; border: none; border-radius: 25px;font-size: 12px !important;\">\r\n BOOK A VISIT\r\n </button> -->\r\n <button class=\"btn flex-fill py-2 fw-semibold text-white\"\r\n style=\"background: linear-gradient(135deg, #a855f7, #ec4899); border: none; border-radius: 25px;font-size: 12px !important;\"\r\n (click)=\"viewStore(ele.storeId)\">\r\n VIEW STORE\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-template #loaderScreen>\r\n <div class=\"row\">\r\n <ng-container *ngFor=\"let ele of [1,2,3,4,5,6]\">\r\n <ngx-skeleton-loader class=\"col-4\" [theme]=\"{\r\n width: '100%',\r\n height: '40vh',\r\n 'border-radius': '12px',\r\n }\"></ngx-skeleton-loader>\r\n </ng-container>\r\n </div>\r\n </ng-template>\r\n </div>\r\n </div>\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n </div>\r\n\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n</div>", styles: [".hover_effect{position:unset;width:100%;top:0;left:0;height:100%}.store-header{font-size:27px;font-weight:700}.sub-text{font-size:16px;width:35%;margin-bottom:15px}.location-container{border:1px solid;padding:8px;border-radius:12px}.location-container input{border:unset;appearance:unset;outline:unset;font-size:13px}.not-available-text{color:#ff5151;font-weight:600;border-radius:22px;text-align:center;padding:12px;background:#ff51511a;width:35%}.f-20{font-size:20px}.f-13{font-size:13px}.w-90{width:90%}.card-body{border:1px solid;border-radius:18px;height:100%}.cdk-virtual-scroll-viewport{display:unset}.cdk-virtual-scroll-content-wrapper{position:unset!important}.card-bottom{position:absolute;bottom:8px;left:25px;width:90%}.error-border{border:2px solid #dc3545!important}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\n"] }]
|
122
|
+
}], ctorParameters: () => [{ type: i1.RestService }, { type: i2.Router }], propDecorators: { data: [{
|
123
|
+
type: Input
|
124
|
+
}], edit: [{
|
125
|
+
type: Input
|
126
|
+
}], customClass: [{
|
127
|
+
type: Input
|
128
|
+
}], delete: [{
|
129
|
+
type: Input
|
130
|
+
}], index: [{
|
131
|
+
type: Input
|
132
|
+
}] } });
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"store-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/store-list/store-list.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/store-list/store-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, NgModule, ViewChild } from '@angular/core';\r\nimport BaseSection from '../../../sections/BaseSection';\r\nimport { StoreListModal, StoreListStyleModel } from './store-list.modal';\r\nimport { CommonModule } from '@angular/common';\r\nimport { AnimationDirective } from '../../../directive/animation-directive';\r\nimport { BackgroundDirective } from '../../../directive/background-directive';\r\nimport { CornerDirective } from '../../../directive/corner-directive';\r\nimport { SimpoComponentModule } from '../../../components/index';\r\nimport { HoverDirective } from '../../../directive/hover-element-directive';\r\nimport { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { ContentFitDirective } from '../../../directive/content-fit-directive';\r\nimport { RestService } from '../../../services/rest.service';\r\nimport { Router } from '@angular/router';\r\nimport { NgxSkeletonLoaderComponent, NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'simpo-store-list',\r\n  standalone: true,\r\n  imports: [CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    MatIcon,\r\n    SimpoComponentModule,\r\n    AnimationDirective,\r\n    BackgroundDirective,\r\n    CornerDirective,\r\n    HoverDirective,\r\n    ButtonDirectiveDirective,\r\n    ContentFitDirective,\r\n    NgxSkeletonLoaderModule,\r\n  ],\r\n  templateUrl: './store-list.component.html',\r\n  styleUrl: './store-list.component.css'\r\n})\r\nexport class StoreListComponent extends BaseSection {\r\n\r\n  @Input() data?: StoreListModal\r\n  @Input() edit?: boolean = true;\r\n  @Input() customClass?: string;\r\n  @Input() delete?: boolean;\r\n  @Input() index?: number;\r\n  pageNo: number = 0;\r\n  isLoading: boolean = false;\r\n  cardSize: number = 50;\r\n\r\n\r\n  styles?: StoreListStyleModel;\r\n\r\n  constructor(private restService: RestService,\r\n    private router: Router\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.styles = this.data?.styles;\r\n    this.getStoreDetails();\r\n  }\r\n  storesList: any = [];\r\n  pincode: any;\r\n  storePayload: any = {\r\n    businessId: localStorage.getItem('businessId') ?? \"\",\r\n    pageNo: 0,\r\n    pageSize: 15\r\n  }\r\n  getDataWithPincode() {\r\n    if (this.pincode.toString().length != 6) {\r\n      this.error = true\r\n      return;\r\n    }\r\n    this.storePayload.pincode = this.pincode;\r\n    this.getStoreDetails();\r\n  }\r\n  showMessage: boolean = false;\r\n  totalCount: number = 0;\r\n  submit: boolean = false;\r\n  loader: boolean = false;\r\n  error: boolean = false;\r\n  getStoreDetails() {\r\n    this.submit = true;\r\n    this.loader = true;\r\n    this.restService.getAllStores(this.storePayload).subscribe((res: any) => {\r\n      this.storesList = res?.data?.data;\r\n      this.totalCount = res?.data?.count;\r\n      if (this.pincode?.toString().length == 6)\r\n        this.showMessage = res?.data?.storePresent;\r\n      this.storePayload.pageNo++;\r\n      this.isLoading = false\r\n      this.loader = false;\r\n    },\r\n      (error) => {\r\n        this.loader = false\r\n      })\r\n  }\r\n  getTextColor(bgColor: any) {\r\n    if (bgColor) {\r\n      const threshold = 130; // Adjust this threshold as needed\r\n      const r = parseInt(bgColor.slice(1, 3), 16);\r\n      const g = parseInt(bgColor.slice(3, 5), 16);\r\n      const b = parseInt(bgColor.slice(5, 7), 16);\r\n      const brightness = (r * 299 + g * 587 + b * 114) / 1000;\r\n\r\n      return brightness > threshold ? '#000000' : '#ffffff';\r\n    }\r\n    return \"#ffffff;\"\r\n  }\r\n  openWhatsapp(phone: string) {\r\n    if (phone) {\r\n      const whatsappUrl = `https://wa.me/${phone}`;\r\n      window.open(whatsappUrl, '_blank');\r\n    }\r\n  }\r\n  viewStore(storeId: string) {\r\n    this.router.navigate(['/store'], { queryParams: { storeId: storeId } });\r\n  }\r\n  getTime(storeHours: any, type: string) {\r\n    const today = new Date();\r\n    const dayName = today.toLocaleDateString('en-US', { weekday: 'long' }).toUpperCase();\r\n    for (let ele of storeHours) {\r\n      if (ele.dayOfWeek == dayName) {\r\n        if (type == 'OPEN') {\r\n          return ele.openingTime\r\n        } else {\r\n          return ele.closingTime\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div class=\"total-container position-relative\" simpoHover (hovering)=\"showEditTabs($event)\" [id]=\"data?.id\">\r\n    <div class=\"main-container\" [simpoAnimation]=\"styles?.animation\" [id]=\"data?.id\">\r\n        <div class=\"top-section w-100 d-flex align-items-center justify-content-center text-center flex-column\"\r\n            [simpoBackground]=\"styles?.background\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\">\r\n            <ng-container *ngIf=\"!loader\">\r\n                <div class=\"store-header mb-3\">\r\n                    {{ submit && showMessage == true && pincode && pincode.toString().length == 6 ? \"Stores in \" +\r\n                    pincode :\r\n                    \"Find a Store Near You\"}}\r\n                </div>\r\n                <div class=\"sub-text\">\r\n                    {{ submit && showMessage == true && pincode && pincode.toString().length == 6 ? 'We have ' +\r\n                    totalCount\r\n                    + ' stores in this locality, scroll down to view the stores\r\n                    and browse the designs available.' : 'Locate a store near you — our presence is expanding every day,\r\n                    and\r\n                    we look forward to serving you.' }}\r\n                </div>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"loader\">\r\n                <div class=\"sub-text\">\r\n                    <ngx-skeleton-loader [theme]=\"{\r\n                width: '35%',\r\n                height: '3vh',\r\n               'border-radius': '12px',\r\n                 }\"></ngx-skeleton-loader>\r\n                </div>\r\n                <div class=\"sub-text w-75\">\r\n                    <ngx-skeleton-loader [theme]=\"{\r\n                width: '35%',\r\n                height: '2vh',\r\n               'border-radius': '12px',\r\n                 }\"></ngx-skeleton-loader>\r\n                </div>\r\n            </ng-container>\r\n            <div class=\"location-container d-flex align-items-center justify-content-between w-25\" [class.error-border]=\"error\">\r\n                <div class=\"d-flex align-items-center w-90\">\r\n                    <div class=\"d-flex mx-1\"><mat-icon class=\"d-flex align-items-center justify-content-center f-20\"\r\n                            [style.color]=\"data?.styles?.background?.accentColor\">gps_fixed</mat-icon>\r\n                    </div>\r\n                    <input type=\"number\" placeholder=\"Pin Code\" [(ngModel)]=\"pincode\" class=\"w-90\"\r\n                        [style.backgroundColor]=\"data?.styles?.background?.color\"\r\n                        [style.color]=\"getTextColor(data?.styles?.background?.color)\"\r\n                        (ngModelChange)=\"pincode.toString().length != 6 ? submit = false : error = false\"/>\r\n                </div>\r\n                <div (click)=\"getDataWithPincode()\" class=\"f-13 cursor-pointer\">Submit</div>\r\n            </div>\r\n        </div>\r\n        <div class=\"bottom-container row w-75 mx-auto\">\r\n            <div class=\"w-100 d-flex align-items-center justify-content-center mb-3\"\r\n                *ngIf=\"submit && showMessage == false && pincode && pincode.toString().length ==6 && !loader\">\r\n                <div class=\"text-center not-available-text\">We are not available in this location currently</div>\r\n            </div>\r\n            <ng-container *ngIf=\"loader\">\r\n                <div class=\"sub-text w-100 text-center\">\r\n                    <ngx-skeleton-loader [theme]=\"{\r\n                width: '35%',\r\n                height: '6vh',\r\n               'border-radius': '12px',\r\n                 }\"></ngx-skeleton-loader>\r\n                </div>\r\n            </ng-container>\r\n            <div class=\"bottom-sub-text mb-3 w-100 f-20\">Showing Stores</div>\r\n            <ng-container *ngIf=\"!loader;else loaderScreen\">\r\n                <div class=\"col-4 p-2\" style=\"border-radius: 12px; border: none;\"\r\n                    *ngFor=\"let ele of storesList; let i = index\">\r\n                    <div class=\"card-body p-4 h-100 position-relative\">\r\n                        <div class=\"d-flex justify-content-between align-items-start mb-3\">\r\n                            <div>\r\n                                <h5 class=\"card-title fw-bold mb-1\">{{ele?.name}}</h5>\r\n                            </div>\r\n                        </div>\r\n                        <div class=\"mb-3\">\r\n                            <p class=\"mb-1 text-dark fw-medium\">{{ele?.addressDetails?.address}},</p>\r\n                            <p class=\"mb-1 text-dark fw-medium\">{{ele?.addressDetails?.city}},\r\n                                {{ele?.addressDetails?.state}},{{ele?.addressDetails?.pincode}},</p>\r\n                            <p class=\"mb-0\">Phone-<span [style.color]=\"data?.styles?.background?.accentColor\">{{ele?.phone}}</span></p>\r\n                        </div>\r\n                        <div class=\"mb-4\">\r\n                            <p class=\"mb-0\" [style.color]=\"data?.styles?.background?.accentColor\">STORE HOURS -\r\n                                {{getTime(ele?.storeHours,'OPEN')}} to {{getTime(ele?.storeHours,'CLOSE')}}\r\n                            </p>\r\n                        </div>\r\n                        <div class=\"d-flex gap-3 align-items-center card-bottom\">\r\n                            <div class=\"rounded-circle d-flex align-items-center justify-content-center\"\r\n                                style=\"width: 40px; height: 30px; background-color: #25d366;\"\r\n                                (click)=\"openWhatsapp(ele?.phone)\">\r\n                                <i class=\"fab fa-whatsapp text-white fs-5\"></i>\r\n                            </div>\r\n                            <!-- <button class=\"btn flex-fill py-2 fw-semibold\"\r\n                            style=\"background-color: #e8e3ff; color: #6b46c1; border: none; border-radius: 25px;font-size: 12px !important;\">\r\n                            BOOK A VISIT\r\n                        </button> -->\r\n                            <button class=\"btn flex-fill py-2 fw-semibold text-white\"\r\n                                style=\"background: linear-gradient(135deg, #a855f7, #ec4899); border: none; border-radius: 25px;font-size: 12px !important;\"\r\n                                (click)=\"viewStore(ele.storeId)\">\r\n                                VIEW STORE\r\n                            </button>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </ng-container>\r\n            <ng-template #loaderScreen>\r\n                <div class=\"row\">\r\n                    <ng-container *ngFor=\"let ele of [1,2,3,4,5,6]\">\r\n                        <ngx-skeleton-loader class=\"col-4\" [theme]=\"{\r\n                width: '100%',\r\n                height: '40vh',\r\n               'border-radius': '12px',\r\n                 }\"></ngx-skeleton-loader>\r\n                    </ng-container>\r\n                </div>\r\n            </ng-template>\r\n        </div>\r\n    </div>\r\n    <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n        <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n    </div>\r\n\r\n    <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n        <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n    </div>\r\n</div>"]}
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmUtbGlzdC5tb2RhbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpbXBvLXVpL3NyYy9saWIvZWNvbW1lcmNlL3NlY3Rpb25zL3N0b3JlLWxpc3Qvc3RvcmUtbGlzdC5tb2RhbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWN0aW9uTW9kZWwsIEJhbm5lclN0eWxlc01vZGVsIH0gZnJvbSBcIi4uLy4uLy4uL3N0eWxlcy9zdHlsZS5tb2RlbFwiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTdG9yZUxpc3RNb2RhbCB7XHJcbiAgICBpZDogc3RyaW5nO1xyXG4gICAgc2VjdGlvblR5cGU6IHN0cmluZztcclxuICAgIHNlY3Rpb25OYW1lOiBzdHJpbmc7XHJcbiAgICBjb250ZW50OiB7fTtcclxuICAgIHN0eWxlczogU3RvcmVMaXN0U3R5bGVNb2RlbDtcclxuICAgIGFjdGlvbjogQWN0aW9uTW9kZWw7XHJcbn1cclxuZXhwb3J0IGludGVyZmFjZSBTdG9yZUxpc3RTdHlsZU1vZGVsIGV4dGVuZHMgQmFubmVyU3R5bGVzTW9kZWx7XHJcbn0gIl19
|
@@ -0,0 +1,109 @@
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
2
|
+
import BaseSection from '../../../sections/BaseSection';
|
3
|
+
import { CommonModule } from '@angular/common';
|
4
|
+
import { AnimationDirective } from '../../../directive/animation-directive';
|
5
|
+
import { BackgroundDirective } from '../../../directive/background-directive';
|
6
|
+
import { CornerDirective } from '../../../directive/corner-directive';
|
7
|
+
import { SimpoComponentModule } from '../../../components/index';
|
8
|
+
import { HoverDirective } from '../../../directive/hover-element-directive';
|
9
|
+
import { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';
|
10
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
11
|
+
import { MatIcon } from '@angular/material/icon';
|
12
|
+
import { ContentFitDirective } from '../../../directive/content-fit-directive';
|
13
|
+
import { SpacingHorizontalDirective } from '../../../directive/spacing-horizontal.directive';
|
14
|
+
import * as i0 from "@angular/core";
|
15
|
+
import * as i1 from "../../../services/rest.service";
|
16
|
+
import * as i2 from "@angular/router";
|
17
|
+
import * as i3 from "@angular/common";
|
18
|
+
import * as i4 from "../../../components/hover-elements/hover-elements.component";
|
19
|
+
import * as i5 from "../../../components/delete-hover-element/delete-hover-element.component";
|
20
|
+
export class StorePageComponent extends BaseSection {
|
21
|
+
constructor(restService, activeRoute) {
|
22
|
+
super();
|
23
|
+
this.restService = restService;
|
24
|
+
this.activeRoute = activeRoute;
|
25
|
+
this.edit = true;
|
26
|
+
}
|
27
|
+
ngOnInit() {
|
28
|
+
this.styles = this.data?.styles;
|
29
|
+
this.activeRoute.queryParams.subscribe(params => {
|
30
|
+
if (params['storeId']) {
|
31
|
+
this.getStoreDetails(params['storeId']);
|
32
|
+
}
|
33
|
+
});
|
34
|
+
}
|
35
|
+
getStoreDetails(storeId) {
|
36
|
+
this.restService.getStoreById(storeId).subscribe((res) => {
|
37
|
+
this.storeData = res?.data?.data[0];
|
38
|
+
}, (err) => {
|
39
|
+
console.error('Error fetching store details:', err);
|
40
|
+
});
|
41
|
+
}
|
42
|
+
getTextColor(bgColor) {
|
43
|
+
if (bgColor) {
|
44
|
+
const threshold = 130; // Adjust this threshold as needed
|
45
|
+
const r = parseInt(bgColor.slice(1, 3), 16);
|
46
|
+
const g = parseInt(bgColor.slice(3, 5), 16);
|
47
|
+
const b = parseInt(bgColor.slice(5, 7), 16);
|
48
|
+
const brightness = (r * 299 + g * 587 + b * 114) / 1000;
|
49
|
+
return brightness > threshold ? '#000000' : '#ffffff';
|
50
|
+
}
|
51
|
+
return "#ffffff;";
|
52
|
+
}
|
53
|
+
getTime(storeHours, type) {
|
54
|
+
const today = new Date();
|
55
|
+
const dayName = today.toLocaleDateString('en-US', { weekday: 'long' }).toUpperCase();
|
56
|
+
for (let ele of storeHours) {
|
57
|
+
if (ele.dayOfWeek == dayName) {
|
58
|
+
if (type == 'OPEN') {
|
59
|
+
return ele.openingTime;
|
60
|
+
}
|
61
|
+
else {
|
62
|
+
return ele.closingTime;
|
63
|
+
}
|
64
|
+
}
|
65
|
+
}
|
66
|
+
}
|
67
|
+
removeUnderScore(text) {
|
68
|
+
return text?.replaceAll('_', ' ');
|
69
|
+
}
|
70
|
+
openWhatsapp(phone) {
|
71
|
+
if (phone) {
|
72
|
+
const whatsappUrl = `https://wa.me/${phone}`;
|
73
|
+
window.open(whatsappUrl, '_blank');
|
74
|
+
}
|
75
|
+
}
|
76
|
+
dialNumber(phone) {
|
77
|
+
window.location.href = `tel:${phone}`;
|
78
|
+
}
|
79
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: StorePageComponent, deps: [{ token: i1.RestService }, { token: i2.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component }); }
|
80
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: StorePageComponent, isStandalone: true, selector: "simpo-store-page", inputs: { data: "data", edit: "edit", customClass: "customClass", delete: "delete", index: "index" }, usesInheritance: true, ngImport: i0, template: "<div class=\"total-container position-relative\" simpoHover (hovering)=\"showEditTabs($event)\" [id]=\"data?.id\">\r\n <div class=\"main-container\" [id]=\"data?.id\" [simpoAnimation]=\"styles?.animation\"\r\n [simpoBackground]=\"styles?.background\" [simpoLayout]=\"styles?.layout\" [spacingHorizontal]=\"styles?.layout\">\r\n <div class=\"w-100 row\">\r\n <div class=\"col-4\">\r\n <img [src]=\"storeData?.images[0]\" alt=\"Image\" class=\"w-100 h-100\">\r\n </div>\r\n <div class=\"col-8 px-3\">\r\n <div class=\"address-container\">\r\n <div class=\"d-flex align-items-start mb-4 p-2 mt-3 store-container\">\r\n <div class=\"flex-grow-1 me-3\">\r\n <h2 class=\"store-name mb-2\">{{storeData?.name}}\r\n </h2>\r\n <p class=\"store-address mb-2\">{{storeData?.addressDetails?.address}}</p>\r\n <a [href]=\"storeData?.addressDetails?.mapUrl\" class=\"view-directions\" target=\"_blank\"\r\n [style.color]=\"data?.styles?.background?.accentColor\">VIEW\r\n DIRECTIONS</a>\r\n </div>\r\n <div class=\"d-flex gap-2\">\r\n <button class=\"btn btn-success rounded d-flex align-items-center justify-content-center p-0\"\r\n style=\" width: 30px !important;height: 33px; background-color: #25d366 !important; border-color: #25d366 !important;\"\r\n (click)=\"openWhatsapp(storeData?.phone)\">\r\n <i class=\"fab fa-whatsapp\"></i>\r\n </button>\r\n <button class=\"btn btn-light rounded d-flex align-items-center justify-content-center p-0\"\r\n style=\"width: 30px !important; height: 33px;\" (click)=\"dialNumber(storeData?.phone)\">\r\n <i class=\"fas fa-phone text-muted\"></i>\r\n </button>\r\n <!-- <button class=\"btn book-visit-btn\">BOOK A VISIT</button> -->\r\n </div>\r\n </div>\r\n <div class=\"mb-4\">\r\n <h3 class=\"mb-3\">Facilities</h3>\r\n <div class=\"d-flex flex-wrap gap-3\">\r\n <div class=\"d-flex align-items-center gap-2 facility-text\">\r\n <i class=\"fas fa-clock text-purple\"></i>\r\n <span class=\"facility-text\"> {{getTime(storeData?.storeHours,'OPEN')}} to\r\n {{getTime(storeData?.storeHours,'CLOSE')}}\r\n </span>\r\n </div>\r\n <div class=\"facility-text align-content-center\"\r\n *ngFor=\"let ele of storeData?.facilities; let i = index\">{{ele | titlecase}}</div>\r\n </div>\r\n </div>\r\n <div>\r\n <h3 class=\"mb-2\">Walk-In Services</h3>\r\n <div class=\"row g-3\">\r\n <div class=\"col-md-3\" *ngFor=\"let ele of storeData?.services; let i = index\">\r\n <div class=\"service-card old-gold h-100 py-2\" *ngIf=\"ele?.isAvailable\">\r\n <p class=\"mb-2 text-hidden\">{{(removeUnderScore(ele?.serviceType) | titlecase)}}</p>\r\n <p class=\"mb-0 text-hidden\">{{ele?.description}}</p>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n </div>\r\n\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n\r\n\r\n </div>", styles: [".hover_effect{position:absolute;width:100%;top:0;left:0;height:100%}.text-hidden{text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.store-container{background:#fff;color:#000;border-radius:12px}.facility-text{background:#fff;color:#000;border-radius:12px;padding:2px 5px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.TitleCasePipe, name: "titlecase" }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: SimpoComponentModule }, { kind: "component", type: i4.HoverElementsComponent, selector: "simpo-hover-elements", inputs: ["data", "index", "editOptions", "isMerged", "isEcommerce"], outputs: ["edit"] }, { kind: "component", type: i5.DeleteHoverElementComponent, selector: "simpo-delete-hover-element", inputs: ["index", "data"], outputs: ["edit"] }, { kind: "directive", type: AnimationDirective, selector: "[simpoAnimation]", inputs: ["simpoAnimation"] }, { kind: "directive", type: BackgroundDirective, selector: "[simpoBackground]", inputs: ["simpoBackground", "scrollValue"] }, { kind: "directive", type: HoverDirective, selector: "[simpoHover]", outputs: ["hovering"] }, { kind: "directive", type: ContentFitDirective, selector: "[simpoLayout]", inputs: ["simpoLayout"] }, { kind: "directive", type: SpacingHorizontalDirective, selector: "[spacingHorizontal]", inputs: ["spacingHorizontal", "isHeader"] }] }); }
|
81
|
+
}
|
82
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: StorePageComponent, decorators: [{
|
83
|
+
type: Component,
|
84
|
+
args: [{ selector: 'simpo-store-page', standalone: true, imports: [
|
85
|
+
CommonModule,
|
86
|
+
FormsModule,
|
87
|
+
ReactiveFormsModule,
|
88
|
+
MatIcon,
|
89
|
+
SimpoComponentModule,
|
90
|
+
AnimationDirective,
|
91
|
+
BackgroundDirective,
|
92
|
+
CornerDirective,
|
93
|
+
HoverDirective,
|
94
|
+
ButtonDirectiveDirective,
|
95
|
+
ContentFitDirective,
|
96
|
+
SpacingHorizontalDirective
|
97
|
+
], template: "<div class=\"total-container position-relative\" simpoHover (hovering)=\"showEditTabs($event)\" [id]=\"data?.id\">\r\n <div class=\"main-container\" [id]=\"data?.id\" [simpoAnimation]=\"styles?.animation\"\r\n [simpoBackground]=\"styles?.background\" [simpoLayout]=\"styles?.layout\" [spacingHorizontal]=\"styles?.layout\">\r\n <div class=\"w-100 row\">\r\n <div class=\"col-4\">\r\n <img [src]=\"storeData?.images[0]\" alt=\"Image\" class=\"w-100 h-100\">\r\n </div>\r\n <div class=\"col-8 px-3\">\r\n <div class=\"address-container\">\r\n <div class=\"d-flex align-items-start mb-4 p-2 mt-3 store-container\">\r\n <div class=\"flex-grow-1 me-3\">\r\n <h2 class=\"store-name mb-2\">{{storeData?.name}}\r\n </h2>\r\n <p class=\"store-address mb-2\">{{storeData?.addressDetails?.address}}</p>\r\n <a [href]=\"storeData?.addressDetails?.mapUrl\" class=\"view-directions\" target=\"_blank\"\r\n [style.color]=\"data?.styles?.background?.accentColor\">VIEW\r\n DIRECTIONS</a>\r\n </div>\r\n <div class=\"d-flex gap-2\">\r\n <button class=\"btn btn-success rounded d-flex align-items-center justify-content-center p-0\"\r\n style=\" width: 30px !important;height: 33px; background-color: #25d366 !important; border-color: #25d366 !important;\"\r\n (click)=\"openWhatsapp(storeData?.phone)\">\r\n <i class=\"fab fa-whatsapp\"></i>\r\n </button>\r\n <button class=\"btn btn-light rounded d-flex align-items-center justify-content-center p-0\"\r\n style=\"width: 30px !important; height: 33px;\" (click)=\"dialNumber(storeData?.phone)\">\r\n <i class=\"fas fa-phone text-muted\"></i>\r\n </button>\r\n <!-- <button class=\"btn book-visit-btn\">BOOK A VISIT</button> -->\r\n </div>\r\n </div>\r\n <div class=\"mb-4\">\r\n <h3 class=\"mb-3\">Facilities</h3>\r\n <div class=\"d-flex flex-wrap gap-3\">\r\n <div class=\"d-flex align-items-center gap-2 facility-text\">\r\n <i class=\"fas fa-clock text-purple\"></i>\r\n <span class=\"facility-text\"> {{getTime(storeData?.storeHours,'OPEN')}} to\r\n {{getTime(storeData?.storeHours,'CLOSE')}}\r\n </span>\r\n </div>\r\n <div class=\"facility-text align-content-center\"\r\n *ngFor=\"let ele of storeData?.facilities; let i = index\">{{ele | titlecase}}</div>\r\n </div>\r\n </div>\r\n <div>\r\n <h3 class=\"mb-2\">Walk-In Services</h3>\r\n <div class=\"row g-3\">\r\n <div class=\"col-md-3\" *ngFor=\"let ele of storeData?.services; let i = index\">\r\n <div class=\"service-card old-gold h-100 py-2\" *ngIf=\"ele?.isAvailable\">\r\n <p class=\"mb-2 text-hidden\">{{(removeUnderScore(ele?.serviceType) | titlecase)}}</p>\r\n <p class=\"mb-0 text-hidden\">{{ele?.description}}</p>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n </div>\r\n\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n\r\n\r\n </div>", styles: [".hover_effect{position:absolute;width:100%;top:0;left:0;height:100%}.text-hidden{text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.store-container{background:#fff;color:#000;border-radius:12px}.facility-text{background:#fff;color:#000;border-radius:12px;padding:2px 5px}\n"] }]
|
98
|
+
}], ctorParameters: () => [{ type: i1.RestService }, { type: i2.ActivatedRoute }], propDecorators: { data: [{
|
99
|
+
type: Input
|
100
|
+
}], edit: [{
|
101
|
+
type: Input
|
102
|
+
}], customClass: [{
|
103
|
+
type: Input
|
104
|
+
}], delete: [{
|
105
|
+
type: Input
|
106
|
+
}], index: [{
|
107
|
+
type: Input
|
108
|
+
}] } });
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"store-page.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/store-page/store-page.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/store-page/store-page.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, NgModule, ViewChild } from '@angular/core';\r\nimport BaseSection from '../../../sections/BaseSection';\r\nimport { StorePageStyleModel, StorePageModal } from './store-page.model';\r\nimport { CommonModule } from '@angular/common';\r\nimport { AnimationDirective } from '../../../directive/animation-directive';\r\nimport { BackgroundDirective } from '../../../directive/background-directive';\r\nimport { CornerDirective } from '../../../directive/corner-directive';\r\nimport { SimpoComponentModule } from '../../../components/index';\r\nimport { HoverDirective } from '../../../directive/hover-element-directive';\r\nimport { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { ContentFitDirective } from '../../../directive/content-fit-directive';\r\nimport { RestService } from '../../../services/rest.service';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { SpacingHorizontalDirective } from '../../../directive/spacing-horizontal.directive';\r\n\r\n@Component({\r\n  selector: 'simpo-store-page',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    MatIcon,\r\n    SimpoComponentModule,\r\n    AnimationDirective,\r\n    BackgroundDirective,\r\n    CornerDirective,\r\n    HoverDirective,\r\n    ButtonDirectiveDirective,\r\n    ContentFitDirective,\r\n    SpacingHorizontalDirective\r\n  ],\r\n  templateUrl: './store-page.component.html',\r\n  styleUrl: './store-page.component.css'\r\n})\r\nexport class StorePageComponent extends BaseSection {\r\n\r\n  @Input() data?: StorePageModal\r\n  @Input() edit?: boolean = true;\r\n  @Input() customClass?: string;\r\n  @Input() delete?: boolean;\r\n  @Input() index?: number;\r\n  styles?: StorePageStyleModel;\r\n\r\n\r\n  constructor(private restService: RestService,\r\n    private activeRoute: ActivatedRoute\r\n  ) {\r\n    super();\r\n  }\r\n  ngOnInit() {\r\n    this.styles = this.data?.styles;\r\n    this.activeRoute.queryParams.subscribe(params => {\r\n      if (params['storeId']) {\r\n        this.getStoreDetails(params['storeId']);\r\n      }\r\n    })\r\n  }\r\n  storeData: any;\r\n  getStoreDetails(storeId: string) {\r\n    this.restService.getStoreById(storeId).subscribe((res: any) => {\r\n      this.storeData = res?.data?.data[0];\r\n    }, (err: any) => {\r\n      console.error('Error fetching store details:', err);\r\n    });\r\n  }\r\n\r\n  getTextColor(bgColor: any) {\r\n    if (bgColor) {\r\n      const threshold = 130; // Adjust this threshold as needed\r\n      const r = parseInt(bgColor.slice(1, 3), 16);\r\n      const g = parseInt(bgColor.slice(3, 5), 16);\r\n      const b = parseInt(bgColor.slice(5, 7), 16);\r\n      const brightness = (r * 299 + g * 587 + b * 114) / 1000;\r\n\r\n      return brightness > threshold ? '#000000' : '#ffffff';\r\n    }\r\n    return \"#ffffff;\"\r\n  }\r\n  getTime(storeHours: any, type: string) {\r\n    const today = new Date();\r\n    const dayName = today.toLocaleDateString('en-US', { weekday: 'long' }).toUpperCase();\r\n    for (let ele of storeHours) {\r\n      if (ele.dayOfWeek == dayName) {\r\n        if (type == 'OPEN') {\r\n          return ele.openingTime\r\n        } else {\r\n          return ele.closingTime\r\n        }\r\n      }\r\n    }\r\n  }\r\n  removeUnderScore(text: string) {\r\n    return text?.replaceAll('_', ' ');\r\n  }\r\n  openWhatsapp(phone: string) {\r\n    if (phone) {\r\n      const whatsappUrl = `https://wa.me/${phone}`;\r\n      window.open(whatsappUrl, '_blank');\r\n    }\r\n  }\r\n  dialNumber(phone: string) {\r\n    window.location.href = `tel:${phone}`;\r\n  }\r\n\r\n}\r\n","<div class=\"total-container position-relative\" simpoHover (hovering)=\"showEditTabs($event)\" [id]=\"data?.id\">\r\n    <div class=\"main-container\" [id]=\"data?.id\" [simpoAnimation]=\"styles?.animation\"\r\n        [simpoBackground]=\"styles?.background\" [simpoLayout]=\"styles?.layout\" [spacingHorizontal]=\"styles?.layout\">\r\n        <div class=\"w-100 row\">\r\n            <div class=\"col-4\">\r\n                <img [src]=\"storeData?.images[0]\" alt=\"Image\" class=\"w-100 h-100\">\r\n            </div>\r\n            <div class=\"col-8 px-3\">\r\n                <div class=\"address-container\">\r\n                    <div class=\"d-flex align-items-start mb-4 p-2 mt-3 store-container\">\r\n                        <div class=\"flex-grow-1 me-3\">\r\n                            <h2 class=\"store-name mb-2\">{{storeData?.name}}\r\n                            </h2>\r\n                            <p class=\"store-address mb-2\">{{storeData?.addressDetails?.address}}</p>\r\n                            <a [href]=\"storeData?.addressDetails?.mapUrl\" class=\"view-directions\" target=\"_blank\"\r\n                                [style.color]=\"data?.styles?.background?.accentColor\">VIEW\r\n                                DIRECTIONS</a>\r\n                        </div>\r\n                        <div class=\"d-flex gap-2\">\r\n                            <button class=\"btn btn-success rounded d-flex align-items-center justify-content-center p-0\"\r\n                                style=\" width: 30px !important;height: 33px; background-color: #25d366 !important; border-color: #25d366 !important;\"\r\n                                (click)=\"openWhatsapp(storeData?.phone)\">\r\n                                <i class=\"fab fa-whatsapp\"></i>\r\n                            </button>\r\n                            <button class=\"btn btn-light rounded d-flex align-items-center justify-content-center p-0\"\r\n                                style=\"width: 30px !important; height: 33px;\" (click)=\"dialNumber(storeData?.phone)\">\r\n                                <i class=\"fas fa-phone text-muted\"></i>\r\n                            </button>\r\n                            <!-- <button class=\"btn book-visit-btn\">BOOK A VISIT</button> -->\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"mb-4\">\r\n                        <h3 class=\"mb-3\">Facilities</h3>\r\n                        <div class=\"d-flex flex-wrap gap-3\">\r\n                            <div class=\"d-flex align-items-center gap-2 facility-text\">\r\n                                <i class=\"fas fa-clock text-purple\"></i>\r\n                                <span class=\"facility-text\"> {{getTime(storeData?.storeHours,'OPEN')}} to\r\n                                    {{getTime(storeData?.storeHours,'CLOSE')}}\r\n                                </span>\r\n                            </div>\r\n                            <div class=\"facility-text align-content-center\"\r\n                                *ngFor=\"let ele of storeData?.facilities; let i = index\">{{ele | titlecase}}</div>\r\n                        </div>\r\n                    </div>\r\n                    <div>\r\n                        <h3 class=\"mb-2\">Walk-In Services</h3>\r\n                        <div class=\"row g-3\">\r\n                            <div class=\"col-md-3\" *ngFor=\"let ele of storeData?.services; let i = index\">\r\n                                <div class=\"service-card old-gold h-100 py-2\" *ngIf=\"ele?.isAvailable\">\r\n                                    <p class=\"mb-2 text-hidden\">{{(removeUnderScore(ele?.serviceType) | titlecase)}}</p>\r\n                                    <p class=\"mb-0 text-hidden\">{{ele?.description}}</p>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n            <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n        </div>\r\n\r\n        <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n            <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n        </div>\r\n\r\n\r\n    </div>"]}
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmUtcGFnZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpbXBvLXVpL3NyYy9saWIvZWNvbW1lcmNlL3NlY3Rpb25zL3N0b3JlLXBhZ2Uvc3RvcmUtcGFnZS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWN0aW9uTW9kZWwsIEJhbm5lclN0eWxlc01vZGVsIH0gZnJvbSBcIi4uLy4uLy4uL3N0eWxlcy9zdHlsZS5tb2RlbFwiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTdG9yZVBhZ2VNb2RhbCB7XHJcbiAgICBpZDogc3RyaW5nO1xyXG4gICAgc2VjdGlvblR5cGU6IHN0cmluZztcclxuICAgIHNlY3Rpb25OYW1lOiBzdHJpbmc7XHJcbiAgICBjb250ZW50OiB7fTtcclxuICAgIHN0eWxlczogU3RvcmVQYWdlU3R5bGVNb2RlbDtcclxuICAgIGFjdGlvbjogQWN0aW9uTW9kZWw7XHJcbn1cclxuZXhwb3J0IGludGVyZmFjZSBTdG9yZVBhZ2VTdHlsZU1vZGVsIGV4dGVuZHMgQmFubmVyU3R5bGVzTW9kZWx7XHJcbn0gIl19
|