simpo-component-library 3.6.55 → 3.6.56
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/components/payment-details/payment-details.component.mjs +40 -16
- package/esm2022/lib/components/trasport-availability/trasport-availability.component.mjs +36 -0
- package/esm2022/lib/ecommerce/sections/cart/cart.component.mjs +1 -3
- package/esm2022/lib/ecommerce/sections/product-desc/product-desc.component.mjs +6 -3
- package/esm2022/lib/elements/editor-service.service.mjs +13 -4
- package/esm2022/lib/elements/media-selector/media-selector.component.mjs +3 -1
- package/esm2022/lib/sections/registration-form/registration-form.component.mjs +8 -1
- package/esm2022/lib/services/image-upload-service.service.mjs +7 -4
- package/fesm2022/simpo-component-library.mjs +161 -87
- package/fesm2022/simpo-component-library.mjs.map +1 -1
- package/lib/components/payment-details/payment-details.component.d.ts +1 -0
- package/lib/components/trasport-availability/trasport-availability.component.d.ts +14 -0
- package/lib/ecommerce/sections/product-desc/product-desc.component.d.ts +1 -0
- package/lib/elements/editor-service.service.d.ts +4 -1
- package/package.json +1 -1
- package/simpo-component-library-3.6.56.tgz +0 -0
- package/simpo-component-library-3.6.55.tgz +0 -0
@@ -2,12 +2,21 @@ import { Inject, Injectable } from '@angular/core';
|
|
2
2
|
import { API_URL, CMIS_URL } from '../tokens/api-token';
|
3
3
|
import * as i0 from "@angular/core";
|
4
4
|
import * as i1 from "@angular/common/http";
|
5
|
+
import * as i2 from "@angular/material/dialog";
|
5
6
|
export class ElementServiceService {
|
6
7
|
// private BASE_URL: string = "https://dev-api.simpo.ai/";
|
7
|
-
constructor(http, BASE_URL, CMIS_URL) {
|
8
|
+
constructor(http, BASE_URL, CMIS_URL, dialog) {
|
8
9
|
this.http = http;
|
9
10
|
this.BASE_URL = BASE_URL;
|
10
11
|
this.CMIS_URL = CMIS_URL;
|
12
|
+
this.dialog = dialog;
|
13
|
+
}
|
14
|
+
openSocialBrand(componentName, height, width, data) {
|
15
|
+
return this.dialog.open(componentName, {
|
16
|
+
height: height,
|
17
|
+
width: width,
|
18
|
+
data: data,
|
19
|
+
});
|
11
20
|
}
|
12
21
|
getComponentApi(businessType) {
|
13
22
|
return this.http.get(`${this.BASE_URL}admin/master/template/category/all?type=${businessType ? businessType : ''}`);
|
@@ -38,7 +47,7 @@ export class ElementServiceService {
|
|
38
47
|
getVehicleRoutes(stopId, typeId) {
|
39
48
|
return this.http.get(this.CMIS_URL + `crm/vehicle-route/${stopId}/vehicle/${typeId}`);
|
40
49
|
}
|
41
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ElementServiceService, deps: [{ token: i1.HttpClient }, { token: API_URL }, { token: CMIS_URL }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
50
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ElementServiceService, deps: [{ token: i1.HttpClient }, { token: API_URL }, { token: CMIS_URL }, { token: i2.MatDialog }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
42
51
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ElementServiceService, providedIn: 'root' }); }
|
43
52
|
}
|
44
53
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ElementServiceService, decorators: [{
|
@@ -52,5 +61,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
|
|
52
61
|
}] }, { type: undefined, decorators: [{
|
53
62
|
type: Inject,
|
54
63
|
args: [CMIS_URL]
|
55
|
-
}] }] });
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
64
|
+
}] }, { type: i2.MatDialog }] });
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLXNlcnZpY2Uuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpbXBvLXVpL3NyYy9saWIvZWxlbWVudHMvZWRpdG9yLXNlcnZpY2Uuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHFCQUFxQixDQUFDOzs7O0FBTXhELE1BQU0sT0FBTyxxQkFBcUI7SUFFaEMsMERBQTBEO0lBRzFELFlBQW9CLElBQWlCLEVBQTJCLFFBQWdCLEVBQ3RELFFBQWdCLEVBQ25DLE1BQWlCO1FBRkosU0FBSSxHQUFKLElBQUksQ0FBYTtRQUEyQixhQUFRLEdBQVIsUUFBUSxDQUFRO1FBQ3RELGFBQVEsR0FBUixRQUFRLENBQVE7UUFDbkMsV0FBTSxHQUFOLE1BQU0sQ0FBVztJQUN0QixDQUFDO0lBRUgsZUFBZSxDQUFDLGFBQWtCLEVBQUUsTUFBVyxFQUFFLEtBQVUsRUFBQyxJQUFRO1FBQ2xFLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3JDLE1BQU0sRUFBRSxNQUFNO1lBQ2QsS0FBSyxFQUFFLEtBQUs7WUFDWixJQUFJLEVBQUMsSUFBSTtTQUVWLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxlQUFlLENBQUMsWUFBc0M7UUFDcEQsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLDJDQUEyQyxZQUFZLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQTtJQUNySCxDQUFDO0lBRUQsY0FBYyxDQUFDLE9BQVk7UUFDekIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FDbkIsSUFBSSxDQUFDLFFBQVEsR0FBRyw2Q0FBNkMsRUFBRSxPQUFPLENBQ3ZFLENBQUE7SUFDSCxDQUFDO0lBQ0QsZUFBZTtRQUNiLE1BQU0sVUFBVSxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLENBQUE7UUFDckQsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FDbEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxxREFBcUQsVUFBVSxtQkFBbUIsQ0FDbkcsQ0FBQTtJQUNILENBQUM7SUFFRCwyQkFBMkIsQ0FBQyxZQUFpQjtRQUMzQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUNuQixJQUFJLENBQUMsUUFBUSxHQUFHLGtDQUFrQyxFQUNsRCxZQUFZLENBQ2IsQ0FBQztJQUNKLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxVQUFVLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxVQUFVLENBQUM7UUFDdEcsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FDbEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxxRUFBcUUsQ0FDdEYsQ0FBQTtJQUNILENBQUM7SUFFRCxrQkFBa0IsQ0FBQyxJQUFRO1FBQ3pCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUMsc0JBQXNCLEVBQUMsSUFBSSxDQUMxQyxDQUFBO0lBQ0gsQ0FBQztJQUVELFlBQVksQ0FBQyxJQUFRO1FBQ25CLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUMsa0JBQWtCLEVBQUMsSUFBSSxDQUN0QyxDQUFBO0lBQ0gsQ0FBQztJQUVELFdBQVcsQ0FBQyxHQUFPO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUMsYUFBYSxHQUFHLHNDQUFzQyxDQUNyRSxDQUFBO0lBQ0gsQ0FBQztJQUVELGdCQUFnQixDQUFDLE1BQVUsRUFBQyxNQUFVO1FBQ3BDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUMscUJBQXFCLE1BQU0sWUFBWSxNQUFNLEVBQUUsQ0FDOUQsQ0FBQTtJQUNILENBQUM7OEdBdkVVLHFCQUFxQiw0Q0FLZSxPQUFPLGFBQzlDLFFBQVE7a0hBTkwscUJBQXFCLGNBRnBCLE1BQU07OzJGQUVQLHFCQUFxQjtrQkFIakMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7OzBCQU15QyxNQUFNOzJCQUFDLE9BQU87OzBCQUNyRCxNQUFNOzJCQUFDLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQVBJX1VSTCwgQ01JU19VUkwgfSBmcm9tICcuLi90b2tlbnMvYXBpLXRva2VuJztcclxuaW1wb3J0IHsgTWF0RGlhbG9nIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIEVsZW1lbnRTZXJ2aWNlU2VydmljZSB7XHJcblxyXG4gIC8vIHByaXZhdGUgQkFTRV9VUkw6IHN0cmluZyA9IFwiaHR0cHM6Ly9kZXYtYXBpLnNpbXBvLmFpL1wiO1xyXG5cclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBodHRwIDogSHR0cENsaWVudCwgQEluamVjdChBUElfVVJMKSBwcml2YXRlIEJBU0VfVVJMOiBzdHJpbmcsXHJcbiAgQEluamVjdChDTUlTX1VSTCkgcHJpdmF0ZSBDTUlTX1VSTDogc3RyaW5nLFxyXG4gIHB1YmxpYyBkaWFsb2c6IE1hdERpYWxvZ1xyXG4pIHsgfVxyXG5cclxuICBvcGVuU29jaWFsQnJhbmQoY29tcG9uZW50TmFtZTogYW55LCBoZWlnaHQ6IGFueSwgd2lkdGg6IGFueSxkYXRhOmFueSkge1xyXG4gICAgcmV0dXJuIHRoaXMuZGlhbG9nLm9wZW4oY29tcG9uZW50TmFtZSwge1xyXG4gICAgICBoZWlnaHQ6IGhlaWdodCxcclxuICAgICAgd2lkdGg6IHdpZHRoLFxyXG4gICAgICBkYXRhOmRhdGEsXHJcblxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBnZXRDb21wb25lbnRBcGkoYnVzaW5lc3NUeXBlPzogJ1NUQVRJQycgfCAnRV9DT01NRVJDRScpe1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQoYCR7dGhpcy5CQVNFX1VSTH1hZG1pbi9tYXN0ZXIvdGVtcGxhdGUvY2F0ZWdvcnkvYWxsP3R5cGU9JHtidXNpbmVzc1R5cGUgPyBidXNpbmVzc1R5cGUgOiAnJ31gKVxyXG4gIH1cclxuXHJcbiAgcmVnZW5lcmF0ZVRleHQocmVxdWVzdDogYW55KSB7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLnBvc3QoXHJcbiAgICAgIHRoaXMuQkFTRV9VUkwgKyBgYWRtaW4vY29udGVudC9zdWdnZXN0L3YyL3dlYnNpdGUvaW5kaXZpZHVhbGAsIHJlcXVlc3RcclxuICAgIClcclxuICB9XHJcbiAgZ2V0SW1hZ2VMaWJyYXJ5KCkge1xyXG4gICAgY29uc3QgYnVzaW5lc3NJZCA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKCdidXNpbmVzc0lkJylcclxuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0KFxyXG4gICAgICB0aGlzLkJBU0VfVVJMICsgYGFkbWluL2xpYnJhcnkvaW1hZ2UvbGlicmFyeS9saXN0L3BhZ2VkP2J1c2luZXNzSWQ9JHtidXNpbmVzc0lkfSZwYWdlTm89MCZzaXplPTEwYFxyXG4gICAgKVxyXG4gIH1cclxuXHJcbiAgc2F2ZUltYWdlc1RvQnVzaW5lc3NMaWJyYXJ5KG1lZGlhUmVxdWVzdDogYW55KSB7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLnBvc3QoXHJcbiAgICAgIHRoaXMuQkFTRV9VUkwgKyBgYWRtaW4vbGlicmFyeS9pbWFnZS9saWJyYXJ5L3NhdmVgLFxyXG4gICAgICBtZWRpYVJlcXVlc3RcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBnZXRUZW1wbGF0ZSgpIHtcclxuICAgIGxldCB0ZW1wbGF0ZUlkID0gSlNPTi5wYXJzZShKU09OLnBhcnNlKEpTT04uc3RyaW5naWZ5KGxvY2FsU3RvcmFnZS5nZXRJdGVtKCdiRGV0YWlscycpKSkpPy50ZW1wbGF0ZUlkO1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQoXHJcbiAgICAgIHRoaXMuQkFTRV9VUkwgKyBgYnVzaW5lc3MvdjMvd2Vic2l0ZS8xZWZkMWRhMC1lMTdiLTY1ZWMtYjBmYi0zYjcxM2EyZDA0ODkvcGFnZXMvbGlzdGBcclxuICAgIClcclxuICB9XHJcblxyXG4gIGdldEFsbFZlaGljbGVUeXBlcyhkYXRhOmFueSl7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLnB1dChcclxuICAgICAgdGhpcy5DTUlTX1VSTCtgY3JtL2dldC92ZWhpY2xlLXR5cGVgLGRhdGFcclxuICAgIClcclxuICB9XHJcblxyXG4gIGdldEFsbENvbWJvcyhkYXRhOmFueSl7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLnB1dChcclxuICAgICAgdGhpcy5DTUlTX1VSTCtgY3JtL2NvbWJvL2ZpbHRlcmAsZGF0YVxyXG4gICAgKVxyXG4gIH1cclxuXHJcbiAgZ2V0QWxsU3RvcHMoYklkOmFueSl7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldChcclxuICAgICAgdGhpcy5DTUlTX1VSTCtgY3JtL3N0b3BzLyR7YklkfT9wYWdlTm89MCZzaXplPTEwJmlzUGFnaW5hdGlvbj1mYWxzZWBcclxuICAgIClcclxuICB9XHJcblxyXG4gIGdldFZlaGljbGVSb3V0ZXMoc3RvcElkOmFueSx0eXBlSWQ6YW55KXtcclxuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0KFxyXG4gICAgICB0aGlzLkNNSVNfVVJMK2Bjcm0vdmVoaWNsZS1yb3V0ZS8ke3N0b3BJZH0vdmVoaWNsZS8ke3R5cGVJZH1gXHJcbiAgICApXHJcbiAgfVxyXG5cclxufVxyXG4iXX0=
|
@@ -172,8 +172,10 @@ export class MediaSelectorComponent {
|
|
172
172
|
for (let image of this.selectedImage.values()) {
|
173
173
|
if (image.file) {
|
174
174
|
const fileUrl = await this.imageUploadService.uploadFileInAWS(image.file, 'library-media');
|
175
|
+
console.log('fileUrl', fileUrl);
|
175
176
|
image.assets[0].url = fileUrl;
|
176
177
|
}
|
178
|
+
console.log('image', image);
|
177
179
|
request.push(image);
|
178
180
|
}
|
179
181
|
this.editorService.saveImagesToBusinessLibrary({ data: request }).subscribe({
|
@@ -199,4 +201,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
|
|
199
201
|
type: ViewChild,
|
200
202
|
args: [CdkVirtualScrollViewport]
|
201
203
|
}] } });
|
202
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-selector.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/elements/media-selector/media-selector.component.ts","../../../../../../projects/simpo-ui/src/lib/elements/media-selector/media-selector.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,SAAS,EAAiB,MAAM,EAAE,MAAM,eAAe,CAAC;AAC5E,OAAO,EAAE,wBAAwB,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACnF,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAE/E,OAAO,EAAE,YAAY,EAAE,oBAAoB,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAChF,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAgB,MAAM,0BAA0B,CAAC;AAEzE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;;;;;;;;;;;AAWvD,MAAM,OAAO,sBAAsB;IAejC,YAAoB,kBAAsC,EAChD,UAAgD,EACvB,UAAe,EACxC,QAAqB,EACrB,aAAqC;QAJ3B,uBAAkB,GAAlB,kBAAkB,CAAoB;QAChD,eAAU,GAAV,UAAU,CAAsC;QACvB,eAAU,GAAV,UAAU,CAAK;QACxC,aAAQ,GAAR,QAAQ,CAAa;QACrB,kBAAa,GAAb,aAAa,CAAwB;QAhB/C,SAAI,GAAa,CAAC,UAAU,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;QACnD,cAAS,GAAW,UAAU,CAAC;QAC/B,kBAAa,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC;QACpC,WAAM,GAAW,CAAC,CAAC;QACnB,cAAS,GAAY,KAAK,CAAC;QAC3B,mBAAc,GAAU,EAAE,CAAC;QAC3B,iBAAY,GAAU,EAAE,CAAC;QACzB,cAAS,GAAG,EAAE,CAAC;QACf,aAAQ,GAAY,KAAK,CAAC;QAC1B,kBAAa,GAAqB,IAAI,GAAgB,CAAC;QACvD,iBAAY,GAAW,KAAK,CAAC;IAOzB,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,EAAE,QAAQ,IAAI,IAAI,CAAC;QAClD,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,eAAe;QACb,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YAC1D,IAAI,CAAC,YAAY,GAAG,GAAG,EAAE,IAAI,EAAE,OAAO,IAAI,EAAE,CAAC;QAC/C,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,6DAA6D;IAC7D,oBAAoB;QAClB,IAAI,CAAC,aAAa,CAAC,YAAY;aAC5B,IAAI,CACH,SAAS,CAAC,EAAE,CAAC,EAAE,wBAAwB;QACvC,YAAY,CAAC,GAAG,CAAC,EAAE,gCAAgC;QACnD,oBAAoB,EAAE,EAAE,iCAAiC;QACzD,SAAS,CAAC,KAAK,CAAC,EAAE;YAChB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YAChB,OAAO,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,KAAK,IAAI,YAAY,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAC5F,CAAC,CAAC,CACH;aACA,SAAS,CAAC,CAAC,OAAY,EAAE,EAAE;YAC1B,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,OAAO,CAAC;QACxC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,wBAAwB;IACxB,mBAAmB;QACjB,IAAI,CAAC,QAAQ,CAAC,eAAe,EAAE;aAC5B,IAAI,CACH,YAAY,CAAC,GAAG,CAAC,EAAE,+BAA+B;QAClD,oBAAoB,EAAE,CAAC,kCAAkC;SAC1D;aACA,SAAS,CAAC,GAAG,EAAE;YACd,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;YAExD,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,0CAA0C;gBAC5E,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,CAAC;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,yBAAyB;IACzB,cAAc;QACZ,IAAI,IAAI,CAAC,SAAS;YAAE,OAAO,CAAC,8BAA8B;QAE1D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,MAAM,EAAE,CAAC;QAEd,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,IAAI,YAAY,EAAE,IAAI,CAAC,MAAM,CAAC;aAClG,SAAS,CAAC,CAAC,OAAY,EAAE,EAAE;YAC1B,IAAI,CAAC,cAAc,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;YACnE,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,EAAE,GAAG,EAAE;YACN,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,sCAAsC;QAChE,CAAC,CAAC,CAAC;IACP,CAAC;IAED,mBAAmB,CAAC,KAAU;QAC5B,IAAI,CAAC,IAAI,CAAC,QAAQ;YAChB,IAAI,CAAC,aAAa,GAAG,IAAI,GAAa,CAAC;QAEzC,IAAI,WAAW,GAAQ;YACrB,UAAU,EAAE,YAAY,CAAC,OAAO,CAAC,YAAY,CAAC;YAC9C,QAAQ,EAAE,KAAK,CAAC,EAAE;YAClB,MAAM,EAAE,CAAC;oBACP,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG;oBACnB,KAAK,EAAE,KAAK,CAAC,KAAK;oBAClB,MAAM,EAAE,KAAK,CAAC,MAAM;iBACrB,CAAC;YACF,MAAM,EAAE;gBACN,EAAE,EAAE,KAAK,CAAC,IAAI,CAAC,EAAE;gBACjB,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ;gBAC7B,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI;gBACrB,eAAe,EAAE,KAAK,CAAC,IAAI,CAAC,gBAAgB;gBAC5C,YAAY,EAAE,KAAK,CAAC,IAAI,CAAC,aAAa;gBACtC,iBAAiB,EAAE,KAAK,CAAC,IAAI,CAAC,kBAAkB;aACjD;YACD,KAAK,EAAE,UAAU;SAClB,CAAA;QAED,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC;YACrC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACtC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,EAAE,WAAW,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;IAED,qBAAqB,CAAC,KAAU;QAC9B,IAAI,CAAC,IAAI,CAAC,QAAQ;YAChB,IAAI,CAAC,aAAa,GAAG,IAAI,GAAa,CAAC;QAEzC,IAAI,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAC/B,MAAM,eAAe,GAAG,CAAC,GAAG,IAAI,GAAG,IAAI,CAAC,CAAC,aAAa;QAEtD,KAAK,IAAI,IAAI,IAAI,KAAK,EAAE,CAAC;YACvB,IAAI,eAAe,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;gBAChC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gCAAgC,EAAE,OAAO,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAA;gBACjF,SAAS;YACX,CAAC;YAED,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAEhC,MAAM,KAAK,GAAQ;gBACjB,UAAU,EAAE,YAAY,CAAC,OAAO,CAAC,YAAY,CAAC;gBAC9C,QAAQ,EAAE,IAAI,CAAC,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,IAAI;gBACrC,QAAQ,EAAE,IAAI;gBACd,MAAM,EAAE,CAAC;wBACP,KAAK,EAAE,CAAC;wBACR,MAAM,EAAE,CAAC;wBACT,QAAQ,EAAE,EAAE;wBACZ,GAAG,EAAE,EAAE;qBACR,CAAC;gBACF,MAAM,EAAE,IAAI;gBACZ,KAAK,EAAE,QAAQ;gBACf,WAAW,EAAE,IAAI,CAAC,IAAI;gBACtB,cAAc,EAAE,IAAI,CAAC,IAAI;gBACzB,IAAI,EAAE,IAAI;aACX,CAAC;YAEF,MAAM,CAAC,MAAM,GAAG,CAAC,QAAa,EAAE,EAAE;gBAChC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC;YAC/C,CAAC,CAAC;YACF,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAE3B,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC5C,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;YAChD,CAAC;QACH,CAAC;IACH,CAAC;IAED,iBAAiB,CAAC,OAAe;QAC/B,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAED,sBAAsB,CAAC,KAAU;QAC/B,IAAI,CAAC,IAAI,CAAC,QAAQ;YAChB,IAAI,CAAC,aAAa,GAAG,IAAI,GAAa,CAAC;QAEzC,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC3C,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC5C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;IAED,KAAK,CAAC,WAAW;QACf,IAAI,CAAC,YAAY,GAAE,IAAI,CAAC;QACxB,IAAI,OAAO,GAAU,EAAE,CAAC;QAExB,KAAI,IAAI,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC;YAC7C,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,MAAM,OAAO,GACX,MAAM,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAC3C,KAAK,CAAC,IAAI,EACV,eAAe,CAChB,CAAC;gBAEJ,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,OAAO,CAAC;YAChC,CAAC;YAED,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtB,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,2BAA2B,CAAC,EAAC,IAAI,EAAE,OAAO,EAAC,CAAC,CAAC,SAAS,CAAC;YACxE,IAAI,EAAE,GAAG,EAAE;gBACT,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;gBAC/B,IAAI,CAAC,YAAY,GAAE,KAAK,CAAC;YAC3B,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,CAAC,YAAY,GAAC,KAAK,CAAC;YAC1B,CAAC;SACF,CAAC,CAAA;IACJ,CAAC;8GAzMU,sBAAsB,gFAiBvB,eAAe;kGAjBd,sBAAsB,0HACtB,wBAAwB,gDCrBrC,69JA4GA,0qGD5FY,YAAY,+jBAAE,WAAW,sZAAE,mBAAmB,kNAAE,wBAAwB,gJAAE,mBAAmB,4QAAE,eAAe,+YAAE,aAAa;;2FAI5H,sBAAsB;kBAPlC,SAAS;+BACE,sBAAsB,cACpB,IAAI,WACP,CAAC,YAAY,EAAE,WAAW,EAAE,mBAAmB,EAAE,wBAAwB,EAAE,mBAAmB,EAAE,eAAe,EAAE,aAAa,CAAC;;0BAqBrI,MAAM;2BAAC,eAAe;uGAhBY,QAAQ;sBAA5C,SAAS;uBAAC,wBAAwB","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, ViewChild, AfterViewInit, Inject } from '@angular/core';\r\nimport { CdkVirtualScrollViewport, ScrollingModule } from '@angular/cdk/scrolling';\r\nimport { FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { ImageUplaodService } from '../../services/image-upload-service.service';\r\nimport { debounceTime, distinctUntilChanged, startWith, switchMap } from 'rxjs';\r\nimport { LazyLoadImageModule } from 'ng-lazyload-image';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { MatSnackBar } from '@angular/material/snack-bar';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { RestService } from '../../services/rest.service';\r\nimport { ElementServiceService } from '../editor-service.service';\r\n\r\n@Component({\r\n  selector: 'simpo-media-selector',\r\n  standalone: true,\r\n  imports: [CommonModule, FormsModule, ReactiveFormsModule, CdkVirtualScrollViewport, LazyLoadImageModule, ScrollingModule, MatIconModule],\r\n  templateUrl: './media-selector.component.html',\r\n  styleUrl: './media-selector.component.css'\r\n})\r\nexport class MediaSelectorComponent implements AfterViewInit {\r\n  @ViewChild(CdkVirtualScrollViewport) viewport!: CdkVirtualScrollViewport;\r\n\r\n  tabs: string[] = ['Unsplash', 'Upload', 'Library'];\r\n  activeTab: string = 'Unsplash';\r\n  searchControl = new FormControl('');\r\n  pageNo: number = 1;\r\n  isLoading: boolean = false;\r\n  unsplashImages: any[] = [];\r\n  imageLibrary: any[] = [];\r\n  imageSize = 50;\r\n  multiple: boolean = false;\r\n  selectedImage: Map<string, any> = new Map<string, any>;\r\n  buttonLoader: boolean= false;\r\n\r\n  constructor(private imageUploadService: ImageUplaodService,\r\n    public  _dialogRef: MatDialogRef<MediaSelectorComponent>,\r\n    @Inject(MAT_DIALOG_DATA) private dialogData: any,\r\n    private snackBar: MatSnackBar,\r\n    private editorService : ElementServiceService\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    this.multiple = this.dialogData?.multiple ?? true;\r\n    this.searchUnsplashImages();\r\n    this.getImageLibrary();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.setupInfiniteScroll();\r\n  }\r\n\r\n  getImageLibrary() {\r\n    this.editorService.getImageLibrary().subscribe((res: any) => {\r\n      this.imageLibrary = res?.data?.content || [];\r\n    })\r\n  }\r\n\r\n  /** ✅ Search API with debounce to reduce unnecessary calls */\r\n  searchUnsplashImages() {\r\n    this.searchControl.valueChanges\r\n      .pipe(\r\n        startWith(''), // Load images initially\r\n        debounceTime(500), // Wait 500ms after typing stops\r\n        distinctUntilChanged(), // Only call API if value changes\r\n        switchMap(value => {\r\n          this.pageNo = 1;\r\n          return this.imageUploadService.searchPhotosInUnsplash(value || 'Technology', this.pageNo);\r\n        })\r\n      )\r\n      .subscribe((results: any) => {\r\n        this.unsplashImages = results.results;\r\n      });\r\n  }\r\n\r\n  /** ✅ Infinite Scroll */\r\n  setupInfiniteScroll() {\r\n    this.viewport.elementScrolled()\r\n      .pipe(\r\n        debounceTime(200), // ✅ Wait 200ms before checking\r\n        distinctUntilChanged() // ✅ Only trigger if value changes\r\n      )\r\n      .subscribe(() => {\r\n        const end = this.viewport.measureScrollOffset('bottom');\r\n\r\n        if (end < 300 && !this.isLoading) { // ✅ Trigger only when close to the bottom\r\n          this.loadMoreImages();\r\n        }\r\n      });\r\n  }\r\n\r\n  /** ✅ Load More Images */\r\n  loadMoreImages() {\r\n    if (this.isLoading) return; // ✅ Prevent multiple requests\r\n\r\n    this.isLoading = true;\r\n    this.pageNo++;\r\n\r\n    this.imageUploadService.searchPhotosInUnsplash(this.searchControl.value || 'Technology', this.pageNo)\r\n      .subscribe((results: any) => {\r\n        this.unsplashImages = [...this.unsplashImages, ...results.results];\r\n        this.isLoading = false;\r\n      }, () => {\r\n        this.isLoading = false; // ✅ Ensure it's reset even on failure\r\n      });\r\n  }\r\n\r\n  selectUnsplashImage(image: any) {\r\n    if (!this.multiple)\r\n      this.selectedImage = new Map<any, any>;\r\n\r\n    let uploadImage: any = {\r\n      businessId: localStorage.getItem('businessId'),\r\n      uniqueId: image.id,\r\n      assets: [{\r\n        url: image.urls.raw,\r\n        width: image.width,\r\n        height: image.height\r\n      }],\r\n      author: {\r\n        id: image.user.id,\r\n        userName: image.user.username,\r\n        name: image.user.name,\r\n        twitterUserName: image.user.twitter_username,\r\n        portFolioUrl: image.user.portfolio_url,\r\n        instagramUserName: image.user.instagram_username,\r\n      },\r\n      media: \"UNSPLASH\",\r\n    }\r\n\r\n    if (this.selectedImage.has(image.id)) {\r\n      this.selectedImage.delete(image.id);\r\n    } else {\r\n      this.selectedImage.set(image.id, uploadImage);\r\n    }\r\n  }\r\n\r\n  uploadImageFromSystem(event: any) {\r\n    if (!this.multiple)\r\n      this.selectedImage = new Map<any, any>;\r\n\r\n    let files = event.target.files;\r\n    const maximumFileSize = 4 * 1024 * 1024; // Max is 4mb\r\n\r\n    for (let file of files) {\r\n      if (maximumFileSize < file.size) {\r\n        this.snackBar.open('Maximum file size limit is 4MB', 'close', { duration: 1500 })\r\n        continue;\r\n      }\r\n\r\n      const reader = new FileReader();\r\n\r\n      const image: any = {\r\n        businessId: localStorage.getItem('businessId'),\r\n        uniqueId: file.name + '_' + file.size,\r\n        blurHash: null,\r\n        assets: [{\r\n          width: 0,\r\n          height: 0,\r\n          blurhash: '',\r\n          url: '',\r\n        }],\r\n        author: null,\r\n        media: 'DEVICE',\r\n        description: file.name,\r\n        altDescription: file.name,\r\n        file: file,\r\n      };\r\n\r\n      reader.onload = (response: any) => {\r\n        image.assets[0].url = response.target.result;\r\n      };\r\n      reader.readAsDataURL(file);\r\n\r\n      if (!this.selectedImage.has(image.uniqueId)) {\r\n        this.selectedImage.set(image.uniqueId, image);\r\n      }\r\n    }\r\n  }\r\n\r\n  deleteSystemImage(imageId: string) {\r\n    this.selectedImage.delete(imageId);\r\n  }\r\n\r\n  selectFromImageLibrary(image: any) {\r\n    if (!this.multiple)\r\n      this.selectedImage = new Map<any, any>;\r\n\r\n    if (this.selectedImage.has(image.uniqueId)) {\r\n      this.selectedImage.delete(image.uniqueId);\r\n    } else {\r\n      this.selectedImage.set(image.uniqueId, image);\r\n    }\r\n  }\r\n\r\n  async uploadImage() {\r\n    this.buttonLoader =true;\r\n    let request: any[] = [];\r\n\r\n    for(let image of this.selectedImage.values()) {\r\n      if (image.file) {\r\n        const fileUrl: any =\r\n          await this.imageUploadService.uploadFileInAWS(\r\n            image.file,\r\n            'library-media'\r\n          );\r\n\r\n        image.assets[0].url = fileUrl;\r\n      }\r\n\r\n      request.push(image);\r\n    }\r\n    this.editorService.saveImagesToBusinessLibrary({data: request}).subscribe({\r\n      next: () => {\r\n        this._dialogRef.close(request);\r\n        this.buttonLoader= false;\r\n      },\r\n      error: () => {\r\n        this.buttonLoader=false;\r\n      }\r\n    })\r\n  }\r\n}\r\n","<section>\r\n  <div class=\"header d-flex justify-content-between align-items-center\">\r\n    <div class=\"heading\">Upload Image</div>\r\n    <mat-icon (click)=\"_dialogRef.close()\" class=\"d-flex align-items-center justify-content-center f-18 cp\">close</mat-icon>\r\n  </div>\r\n  <div class=\"tabs d-flex align-items-center justify-content-between\">\r\n    <div *ngFor=\"let tab of tabs\" [ngClass]=\"{'selectedTab': activeTab === tab}\" (click)=\"activeTab = tab\">{{tab}}</div>\r\n  </div>\r\n\r\n  <ng-container *ngIf=\"activeTab === 'Unsplash'\">\r\n    <ng-container *ngTemplateOutlet=\"unsplashImagesTemplate\"></ng-container>\r\n  </ng-container>\r\n\r\n  <ng-container *ngIf=\"activeTab === 'Upload'\">\r\n    <ng-container *ngTemplateOutlet=\"uploadImageTemplate\"></ng-container>\r\n  </ng-container>\r\n\r\n  <ng-container *ngIf=\"activeTab === 'Library'\">\r\n    <ng-container *ngTemplateOutlet=\"imageLibraryTemplate\"></ng-container>\r\n  </ng-container>\r\n\r\n  <div class=\"uploadButton d-flex\" *ngIf=\"this.selectedImage.size > 0\">\r\n    <button (click)=\"uploadImage()\" [disabled]=\"buttonLoader\">\r\n      <span *ngIf=\"buttonLoader\" ><i class=\"fas fa-circle-notch fa-spin\"></i>&nbsp;Loading</span>\r\n      <span *ngIf=\"!buttonLoader\" >Upload Image</span></button>\r\n  </div>\r\n</section>\r\n\r\n<ng-template #unsplashImagesTemplate>\r\n\r\n  <div class=\"input-container d-flex align-items-center\">\r\n    <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/314661c1741844234442Vector%20%281%29.png\"\r\n    alt=\"search-bar-icon\">\r\n    <input type=\"text\" placeholder=\"Search images\" [formControl]=\"searchControl\">\r\n  </div>\r\n  <cdk-virtual-scroll-viewport [itemSize]=\"imageSize\" [minBufferPx]=\"800\" [maxBufferPx]=\"1600\"\r\n    class=\"scroll-container\">\r\n    <div class=\"row image-container\">\r\n      <div class=\"col-md-4 col-6\" *cdkVirtualFor=\"let image of unsplashImages\">\r\n        <img [lazyLoad]=\"image.urls.thumb\" [errorImage]=\"'assets/error.jpg'\" (click)=\"selectUnsplashImage(image)\"\r\n          [ngClass]=\"{'selectedImage': selectedImage.has(image.id)}\" alt=\"Image\" class=\"cp\" />\r\n      </div>\r\n    </div>\r\n  </cdk-virtual-scroll-viewport>\r\n\r\n  <p *ngIf=\"isLoading\">Loading more results...</p>\r\n\r\n</ng-template>\r\n\r\n<ng-template #uploadImageTemplate>\r\n  <div>\r\n    <div class=\"image-upload-container\">\r\n      <div class=\"upload-img-container d-flex align-items-center justify-content-center\">\r\n        <img lazy src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/547500c1744698830343upload-one%20%281%29.png\" alt=\"upload-image\" class=\"upload-img\">\r\n      </div>\r\n      <div class=\"text-container text-center\">\r\n        <div class=\"top-text\">Choose a file or drag and drop it here</div>\r\n        <div class=\"middle-text\">JPEG, PNG formats up to 50MB</div>\r\n        <div class=\"upload-btn d-flex align-items-center justify-content-center\">\r\n          <div class=\"uploads cp\"  (click)=\"fileInput.click()\">\r\n            Upload\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <input type=\"file\" style=\"display: none\" (change)=\"uploadImageFromSystem($event)\" [multiple]=\"multiple\"\r\n      accept=\"image/png, image/jpeg, image/jpg, image/gif\" #fileInput />\r\n\r\n    <div class=\"row image-container mt-3 h-30-overflow\">\r\n      <ng-container *ngFor=\"let image of selectedImage | keyvalue\">\r\n        <div class=\"col-md-4 systemImage\" *ngIf=\"image.value.file\">\r\n          <img [src]=\"image.value.assets[0].url\" alt=\"Image\" />\r\n          <mat-icon (click)=\"deleteSystemImage(image.key)\">delete</mat-icon>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #imageLibraryTemplate>\r\n  <div class=\"row image-container mt-3 h-75-overflow\">\r\n    <ng-container *ngIf=\"imageLibrary.length > 0; else emptyScreen\">\r\n      <ng-container *ngFor=\"let image of imageLibrary\">\r\n        <div class=\"col-md-4 col-6\">\r\n          <img [src]=\"image.assets[0].url\" alt=\"Image\" (click)=\"selectFromImageLibrary(image)\" [ngClass]=\"{'selectedImage': selectedImage.has(image.uniqueId)}\"/>\r\n        </div>\r\n      </ng-container>\r\n    </ng-container>\r\n  </div>\r\n  <ng-template #emptyScreen>\r\n    <div class=\"empty-container d-flex justify-content-center align-items-center w-100 flex-column\">\r\n      <div class=\"empty-img-container d-flex justify-content-center align-items-center\">\r\n        <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/935737c1743411798188image%20%287%29.png\" alt=\"\">\r\n      </div>\r\n      <div class=\"empty-main-text\">\r\n        Uh-oh!\r\n      </div>\r\n      <div class=\"sub-text-1\">\r\n        No images here\r\n      </div>\r\n      <div class=\"sub-text-2\">\r\n        I looked left, right… even turned around! Still nothing\r\n      </div>\r\n    </div>\r\n  </ng-template>\r\n</ng-template>\r\n"]}
|
204
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-selector.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/elements/media-selector/media-selector.component.ts","../../../../../../projects/simpo-ui/src/lib/elements/media-selector/media-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, ViewChild, AfterViewInit, Inject } from '@angular/core';\r\nimport { CdkVirtualScrollViewport, ScrollingModule } from '@angular/cdk/scrolling';\r\nimport { FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { ImageUplaodService } from '../../services/image-upload-service.service';\r\nimport { debounceTime, distinctUntilChanged, startWith, switchMap } from 'rxjs';\r\nimport { LazyLoadImageModule } from 'ng-lazyload-image';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { MatSnackBar } from '@angular/material/snack-bar';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { RestService } from '../../services/rest.service';\r\nimport { ElementServiceService } from '../editor-service.service';\r\n\r\n@Component({\r\n  selector: 'simpo-media-selector',\r\n  standalone: true,\r\n  imports: [CommonModule, FormsModule, ReactiveFormsModule, CdkVirtualScrollViewport, LazyLoadImageModule, ScrollingModule, MatIconModule],\r\n  templateUrl: './media-selector.component.html',\r\n  styleUrl: './media-selector.component.css'\r\n})\r\nexport class MediaSelectorComponent implements AfterViewInit {\r\n  @ViewChild(CdkVirtualScrollViewport) viewport!: CdkVirtualScrollViewport;\r\n\r\n  tabs: string[] = ['Unsplash', 'Upload', 'Library'];\r\n  activeTab: string = 'Unsplash';\r\n  searchControl = new FormControl('');\r\n  pageNo: number = 1;\r\n  isLoading: boolean = false;\r\n  unsplashImages: any[] = [];\r\n  imageLibrary: any[] = [];\r\n  imageSize = 50;\r\n  multiple: boolean = false;\r\n  selectedImage: Map<string, any> = new Map<string, any>;\r\n  buttonLoader: boolean= false;\r\n\r\n  constructor(private imageUploadService: ImageUplaodService,\r\n    public  _dialogRef: MatDialogRef<MediaSelectorComponent>,\r\n    @Inject(MAT_DIALOG_DATA) private dialogData: any,\r\n    private snackBar: MatSnackBar,\r\n    private editorService : ElementServiceService\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    this.multiple = this.dialogData?.multiple ?? true;\r\n    this.searchUnsplashImages();\r\n    this.getImageLibrary();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.setupInfiniteScroll();\r\n  }\r\n\r\n  getImageLibrary() {\r\n    this.editorService.getImageLibrary().subscribe((res: any) => {\r\n      this.imageLibrary = res?.data?.content || [];\r\n    })\r\n  }\r\n\r\n  /** ✅ Search API with debounce to reduce unnecessary calls */\r\n  searchUnsplashImages() {\r\n    this.searchControl.valueChanges\r\n      .pipe(\r\n        startWith(''), // Load images initially\r\n        debounceTime(500), // Wait 500ms after typing stops\r\n        distinctUntilChanged(), // Only call API if value changes\r\n        switchMap(value => {\r\n          this.pageNo = 1;\r\n          return this.imageUploadService.searchPhotosInUnsplash(value || 'Technology', this.pageNo);\r\n        })\r\n      )\r\n      .subscribe((results: any) => {\r\n        this.unsplashImages = results.results;\r\n      });\r\n  }\r\n\r\n  /** ✅ Infinite Scroll */\r\n  setupInfiniteScroll() {\r\n    this.viewport.elementScrolled()\r\n      .pipe(\r\n        debounceTime(200), // ✅ Wait 200ms before checking\r\n        distinctUntilChanged() // ✅ Only trigger if value changes\r\n      )\r\n      .subscribe(() => {\r\n        const end = this.viewport.measureScrollOffset('bottom');\r\n\r\n        if (end < 300 && !this.isLoading) { // ✅ Trigger only when close to the bottom\r\n          this.loadMoreImages();\r\n        }\r\n      });\r\n  }\r\n\r\n  /** ✅ Load More Images */\r\n  loadMoreImages() {\r\n    if (this.isLoading) return; // ✅ Prevent multiple requests\r\n\r\n    this.isLoading = true;\r\n    this.pageNo++;\r\n\r\n    this.imageUploadService.searchPhotosInUnsplash(this.searchControl.value || 'Technology', this.pageNo)\r\n      .subscribe((results: any) => {\r\n        this.unsplashImages = [...this.unsplashImages, ...results.results];\r\n        this.isLoading = false;\r\n      }, () => {\r\n        this.isLoading = false; // ✅ Ensure it's reset even on failure\r\n      });\r\n  }\r\n\r\n  selectUnsplashImage(image: any) {\r\n    if (!this.multiple)\r\n      this.selectedImage = new Map<any, any>;\r\n\r\n    let uploadImage: any = {\r\n      businessId: localStorage.getItem('businessId'),\r\n      uniqueId: image.id,\r\n      assets: [{\r\n        url: image.urls.raw,\r\n        width: image.width,\r\n        height: image.height\r\n      }],\r\n      author: {\r\n        id: image.user.id,\r\n        userName: image.user.username,\r\n        name: image.user.name,\r\n        twitterUserName: image.user.twitter_username,\r\n        portFolioUrl: image.user.portfolio_url,\r\n        instagramUserName: image.user.instagram_username,\r\n      },\r\n      media: \"UNSPLASH\",\r\n    }\r\n\r\n    if (this.selectedImage.has(image.id)) {\r\n      this.selectedImage.delete(image.id);\r\n    } else {\r\n      this.selectedImage.set(image.id, uploadImage);\r\n    }\r\n  }\r\n\r\n  uploadImageFromSystem(event: any) {\r\n    if (!this.multiple)\r\n      this.selectedImage = new Map<any, any>;\r\n\r\n    let files = event.target.files;\r\n    const maximumFileSize = 4 * 1024 * 1024; // Max is 4mb\r\n\r\n    for (let file of files) {\r\n      if (maximumFileSize < file.size) {\r\n        this.snackBar.open('Maximum file size limit is 4MB', 'close', { duration: 1500 })\r\n        continue;\r\n      }\r\n\r\n      const reader = new FileReader();\r\n\r\n      const image: any = {\r\n        businessId: localStorage.getItem('businessId'),\r\n        uniqueId: file.name + '_' + file.size,\r\n        blurHash: null,\r\n        assets: [{\r\n          width: 0,\r\n          height: 0,\r\n          blurhash: '',\r\n          url: '',\r\n        }],\r\n        author: null,\r\n        media: 'DEVICE',\r\n        description: file.name,\r\n        altDescription: file.name,\r\n        file: file,\r\n      };\r\n\r\n      reader.onload = (response: any) => {\r\n        image.assets[0].url = response.target.result;\r\n      };\r\n      reader.readAsDataURL(file);\r\n\r\n      if (!this.selectedImage.has(image.uniqueId)) {\r\n        this.selectedImage.set(image.uniqueId, image);\r\n      }\r\n    }\r\n  }\r\n\r\n  deleteSystemImage(imageId: string) {\r\n    this.selectedImage.delete(imageId);\r\n  }\r\n\r\n  selectFromImageLibrary(image: any) {\r\n    if (!this.multiple)\r\n      this.selectedImage = new Map<any, any>;\r\n\r\n    if (this.selectedImage.has(image.uniqueId)) {\r\n      this.selectedImage.delete(image.uniqueId);\r\n    } else {\r\n      this.selectedImage.set(image.uniqueId, image);\r\n    }\r\n  }\r\n\r\n  async uploadImage() {\r\n    this.buttonLoader =true;\r\n    let request: any[] = [];\r\n\r\n    for(let image of this.selectedImage.values()) {\r\n      if (image.file) {\r\n        const fileUrl: any =\r\n          await this.imageUploadService.uploadFileInAWS(\r\n            image.file,\r\n            'library-media'\r\n          );\r\n        console.log('fileUrl', fileUrl);\r\n        image.assets[0].url = fileUrl;\r\n      }\r\n      console.log('image', image);\r\n      request.push(image);\r\n    }\r\n    this.editorService.saveImagesToBusinessLibrary({data: request}).subscribe({\r\n      next: () => {\r\n        this._dialogRef.close(request);\r\n        this.buttonLoader= false;\r\n      },\r\n      error: () => {\r\n        this.buttonLoader=false;\r\n      }\r\n    })\r\n  }\r\n}\r\n","<section>\r\n  <div class=\"header d-flex justify-content-between align-items-center\">\r\n    <div class=\"heading\">Upload Image</div>\r\n    <mat-icon (click)=\"_dialogRef.close()\" class=\"d-flex align-items-center justify-content-center f-18 cp\">close</mat-icon>\r\n  </div>\r\n  <div class=\"tabs d-flex align-items-center justify-content-between\">\r\n    <div *ngFor=\"let tab of tabs\" [ngClass]=\"{'selectedTab': activeTab === tab}\" (click)=\"activeTab = tab\">{{tab}}</div>\r\n  </div>\r\n\r\n  <ng-container *ngIf=\"activeTab === 'Unsplash'\">\r\n    <ng-container *ngTemplateOutlet=\"unsplashImagesTemplate\"></ng-container>\r\n  </ng-container>\r\n\r\n  <ng-container *ngIf=\"activeTab === 'Upload'\">\r\n    <ng-container *ngTemplateOutlet=\"uploadImageTemplate\"></ng-container>\r\n  </ng-container>\r\n\r\n  <ng-container *ngIf=\"activeTab === 'Library'\">\r\n    <ng-container *ngTemplateOutlet=\"imageLibraryTemplate\"></ng-container>\r\n  </ng-container>\r\n\r\n  <div class=\"uploadButton d-flex\" *ngIf=\"this.selectedImage.size > 0\">\r\n    <button (click)=\"uploadImage()\" [disabled]=\"buttonLoader\">\r\n      <span *ngIf=\"buttonLoader\" ><i class=\"fas fa-circle-notch fa-spin\"></i>&nbsp;Loading</span>\r\n      <span *ngIf=\"!buttonLoader\" >Upload Image</span></button>\r\n  </div>\r\n</section>\r\n\r\n<ng-template #unsplashImagesTemplate>\r\n\r\n  <div class=\"input-container d-flex align-items-center\">\r\n    <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/314661c1741844234442Vector%20%281%29.png\"\r\n    alt=\"search-bar-icon\">\r\n    <input type=\"text\" placeholder=\"Search images\" [formControl]=\"searchControl\">\r\n  </div>\r\n  <cdk-virtual-scroll-viewport [itemSize]=\"imageSize\" [minBufferPx]=\"800\" [maxBufferPx]=\"1600\"\r\n    class=\"scroll-container\">\r\n    <div class=\"row image-container\">\r\n      <div class=\"col-md-4 col-6\" *cdkVirtualFor=\"let image of unsplashImages\">\r\n        <img [lazyLoad]=\"image.urls.thumb\" [errorImage]=\"'assets/error.jpg'\" (click)=\"selectUnsplashImage(image)\"\r\n          [ngClass]=\"{'selectedImage': selectedImage.has(image.id)}\" alt=\"Image\" class=\"cp\" />\r\n      </div>\r\n    </div>\r\n  </cdk-virtual-scroll-viewport>\r\n\r\n  <p *ngIf=\"isLoading\">Loading more results...</p>\r\n\r\n</ng-template>\r\n\r\n<ng-template #uploadImageTemplate>\r\n  <div>\r\n    <div class=\"image-upload-container\">\r\n      <div class=\"upload-img-container d-flex align-items-center justify-content-center\">\r\n        <img lazy src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/547500c1744698830343upload-one%20%281%29.png\" alt=\"upload-image\" class=\"upload-img\">\r\n      </div>\r\n      <div class=\"text-container text-center\">\r\n        <div class=\"top-text\">Choose a file or drag and drop it here</div>\r\n        <div class=\"middle-text\">JPEG, PNG formats up to 50MB</div>\r\n        <div class=\"upload-btn d-flex align-items-center justify-content-center\">\r\n          <div class=\"uploads cp\"  (click)=\"fileInput.click()\">\r\n            Upload\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <input type=\"file\" style=\"display: none\" (change)=\"uploadImageFromSystem($event)\" [multiple]=\"multiple\"\r\n      accept=\"image/png, image/jpeg, image/jpg, image/gif\" #fileInput />\r\n\r\n    <div class=\"row image-container mt-3 h-30-overflow\">\r\n      <ng-container *ngFor=\"let image of selectedImage | keyvalue\">\r\n        <div class=\"col-md-4 systemImage\" *ngIf=\"image.value.file\">\r\n          <img [src]=\"image.value.assets[0].url\" alt=\"Image\" />\r\n          <mat-icon (click)=\"deleteSystemImage(image.key)\">delete</mat-icon>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #imageLibraryTemplate>\r\n  <div class=\"row image-container mt-3 h-75-overflow\">\r\n    <ng-container *ngIf=\"imageLibrary.length > 0; else emptyScreen\">\r\n      <ng-container *ngFor=\"let image of imageLibrary\">\r\n        <div class=\"col-md-4 col-6\">\r\n          <img [src]=\"image.assets[0].url\" alt=\"Image\" (click)=\"selectFromImageLibrary(image)\" [ngClass]=\"{'selectedImage': selectedImage.has(image.uniqueId)}\"/>\r\n        </div>\r\n      </ng-container>\r\n    </ng-container>\r\n  </div>\r\n  <ng-template #emptyScreen>\r\n    <div class=\"empty-container d-flex justify-content-center align-items-center w-100 flex-column\">\r\n      <div class=\"empty-img-container d-flex justify-content-center align-items-center\">\r\n        <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/935737c1743411798188image%20%287%29.png\" alt=\"\">\r\n      </div>\r\n      <div class=\"empty-main-text\">\r\n        Uh-oh!\r\n      </div>\r\n      <div class=\"sub-text-1\">\r\n        No images here\r\n      </div>\r\n      <div class=\"sub-text-2\">\r\n        I looked left, right… even turned around! Still nothing\r\n      </div>\r\n    </div>\r\n  </ng-template>\r\n</ng-template>\r\n"]}
|