@posiwise/shared-components 0.0.134 → 0.0.135
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/demo-cards/demo-cards.component.mjs +32 -27
- package/esm2022/lib/resource-header/resource-header.component.mjs +35 -29
- package/fesm2022/posiwise-shared-components.mjs +84 -69
- package/fesm2022/posiwise-shared-components.mjs.map +1 -1
- package/lib/demo-cards/demo-cards.component.d.ts +9 -8
- package/lib/resource-header/resource-header.component.d.ts +9 -8
- package/package.json +1 -1
|
@@ -1,48 +1,46 @@
|
|
|
1
1
|
import { moveItemInArray } from '@angular/cdk/drag-drop';
|
|
2
|
-
import { Component, Injector, TemplateRef, ViewChild } from '@angular/core';
|
|
2
|
+
import { Component, Injector, Input, TemplateRef, ViewChild } from '@angular/core';
|
|
3
3
|
import { DomSanitizer } from '@angular/platform-browser';
|
|
4
4
|
import { AdminService } from '@posiwise/admin-module-utils';
|
|
5
5
|
import { AppBaseComponent } from '@posiwise/app-base-component';
|
|
6
|
-
import { AuthService } from '@posiwise/common-services';
|
|
7
6
|
import { HelperService } from '@posiwise/helper-service';
|
|
8
7
|
import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
|
|
9
8
|
import * as i0 from "@angular/core";
|
|
10
9
|
import * as i1 from "@angular/platform-browser";
|
|
11
10
|
import * as i2 from "@ng-bootstrap/ng-bootstrap";
|
|
12
|
-
import * as i3 from "@posiwise/
|
|
13
|
-
import * as i4 from "@
|
|
14
|
-
import * as i5 from "@angular/
|
|
15
|
-
import * as i6 from "@angular/
|
|
16
|
-
import * as i7 from "@angular/common";
|
|
11
|
+
import * as i3 from "@posiwise/admin-module-utils";
|
|
12
|
+
import * as i4 from "@angular/forms";
|
|
13
|
+
import * as i5 from "@angular/cdk/drag-drop";
|
|
14
|
+
import * as i6 from "@angular/common";
|
|
17
15
|
export class DemoCardsComponent extends AppBaseComponent {
|
|
18
|
-
constructor(sanitizer, modalService,
|
|
16
|
+
constructor(sanitizer, modalService, adminService, injector) {
|
|
19
17
|
super(injector);
|
|
20
18
|
this.sanitizer = sanitizer;
|
|
21
19
|
this.modalService = modalService;
|
|
22
|
-
this.authService = authService;
|
|
23
20
|
this.adminService = adminService;
|
|
24
21
|
this.editingBookingLinks = [];
|
|
25
22
|
this.domainId = this.appConfig?.domain_id;
|
|
26
23
|
}
|
|
27
24
|
ngOnInit() {
|
|
28
|
-
this.
|
|
29
|
-
this.
|
|
30
|
-
|
|
31
|
-
this.
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
});
|
|
35
|
-
this.userService.getUserInfo().subscribe(data => {
|
|
36
|
-
this.user = data;
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
});
|
|
25
|
+
if (this.userLoggedIn) {
|
|
26
|
+
this.localStorage.getItem$('product').subscribe(res => {
|
|
27
|
+
const data = res ? JSON.parse(res) : null;
|
|
28
|
+
this.subscriptionId = data?.subscriptionId;
|
|
29
|
+
});
|
|
30
|
+
}
|
|
40
31
|
this.bookingLinks = (this.appConfig?.pages_config?.book_demo?.items ?? []).map(link => ({
|
|
41
32
|
...link,
|
|
42
33
|
// NOSONAR: Trusted iframe URL content is handled safely here
|
|
43
34
|
url: this.sanitizer.bypassSecurityTrustResourceUrl(link.url) // NOSONAR
|
|
44
35
|
}));
|
|
45
36
|
}
|
|
37
|
+
ngOnChanges(changes) {
|
|
38
|
+
if (changes['user'] || changes['userLoggedIn']) {
|
|
39
|
+
if (this.userLoggedIn && this.user) {
|
|
40
|
+
this.updateCanEditResourcesValue();
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
46
44
|
openEditBookLinks(modal) {
|
|
47
45
|
this.editingBookingLinks = JSON.parse(JSON.stringify(this.appConfig?.pages_config?.book_demo?.items ?? []));
|
|
48
46
|
this.modalService.open(modal, { size: 'lg', centered: true, windowClass: 'modal-holder' });
|
|
@@ -76,17 +74,24 @@ export class DemoCardsComponent extends AppBaseComponent {
|
|
|
76
74
|
modal.close();
|
|
77
75
|
});
|
|
78
76
|
}
|
|
77
|
+
updateCanEditResourcesValue() {
|
|
78
|
+
this.canEditResourcesValue = HelperService.canEditResources(this.user, this.userLoggedIn, this.permissionService);
|
|
79
|
+
}
|
|
79
80
|
canEditResources() {
|
|
80
|
-
return
|
|
81
|
+
return this.canEditResourcesValue;
|
|
81
82
|
}
|
|
82
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DemoCardsComponent, deps: [{ token: i1.DomSanitizer }, { token: i2.NgbModal }, { token: i3.
|
|
83
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: DemoCardsComponent, selector: "pw-demo-card", viewQueries: [{ propertyName: "editBookLinksModal", first: true, predicate: ["editBookLinksModal"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<!-- EDIT ICON -->\n\n<!-- DEMO LINKS -->\n<div class=\"row text-center\">\n <i *ngIf=\"
|
|
83
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DemoCardsComponent, deps: [{ token: i1.DomSanitizer }, { token: i2.NgbModal }, { token: i3.AdminService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
84
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: DemoCardsComponent, selector: "pw-demo-card", inputs: { user: "user", userLoggedIn: "userLoggedIn" }, viewQueries: [{ propertyName: "editBookLinksModal", first: true, predicate: ["editBookLinksModal"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<!-- EDIT ICON -->\n\n<!-- DEMO LINKS -->\n<div class=\"row text-center\">\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon mb-3 cursor-pointer\"\n title=\"Edit Booking Links\"\n (click)=\"openEditBookLinks(editBookLinksModal)\"\n (keydown.enter)=\"openEditBookLinks(editBookLinksModal)\"\n (keydown.space)=\"openEditBookLinks(editBookLinksModal)\">\n </i>\n <div class=\"col-md-6 col-lg-4 mb-5\" *ngFor=\"let link of bookingLinks\">\n <h5 class=\"mb-3\">{{ link?.title }}</h5>\n <iframe [src]=\"link?.url\"\n width=\"100%\"\n title=\"Booking frame\"\n height=\"600\"\n class=\"iframe-no-border\">\n </iframe>\n </div>\n</div>\n\n<!-- MODAL TEMPLATE -->\n<ng-template #editBookLinksModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Edit Book Demo Links</h5>\n <button type=\"button\" class=\"btn-close\" (click)=\"modal.dismiss()\" aria-label=\"Close\"></button>\n </div>\n\n <div class=\"modal-body\">\n <div cdkDropList (cdkDropListDropped)=\"dropBookingLink($event)\">\n <div *ngFor=\"let item of editingBookingLinks; let i = index\" class=\"card p-3 mb-3\" cdkDrag>\n <div class=\"row\">\n <div class=\"col-md-5\">\n <label for=\"demoLinkTitle{{i}}\" class=\"form-label\">Link Title</label>\n <input id=\"demoLinkTitle{{i}}\" class=\"form-control\" [(ngModel)]=\"item.title\" />\n </div>\n <div class=\"col-md-5\">\n <label for=\"demoLinkUrl{{i}}\" class=\"form-label\">Link URL</label>\n <input id=\"demoLinkUrl{{i}}\" class=\"form-control\" [(ngModel)]=\"item.url\" />\n </div>\n <div class=\"col-sm-1 d-flex justify-content-end mt-3\">\n <i\n ngbTooltip=\"Remove\"\n (click)=\"removeBookDemoLink(i)\"\n (keydown.enter)=\"removeBookDemoLink(i)\"\n (keydown.space)=\"removeBookDemoLink(i)\"\n class=\"fa fa-trash in-page-trash-icon delete-icon text-danger\"\n aria-hidden=\"true\"\n ></i>\n </div>\n\n <div class=\"col-sm-1 d-flex justify-content-end mt-3\">\n <i\n class=\"fa fa-bars in-page-bars-icon cursor-move\"\n cdkDragHandle\n ngbTooltip=\"Drag to reorder\"\n aria-hidden=\"true\"\n ></i>\n </div>\n </div>\n\n </div>\n </div>\n\n <button class=\"btn btn-outline-primary mt-3\" (click)=\"addBookingLink()\">\n <i class=\"fa fa-plus me-1\"></i> Add Book Demo Link\n </button>\n </div>\n\n <div class=\"modal-footer\">\n <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n <button class=\"btn btn-primary\" (click)=\"saveBookingLinks(modal)\">Save</button>\n </div>\n</ng-template>\n", styles: [".iframe-no-border{border:0}\n"], dependencies: [{ kind: "directive", type: i2.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "tooltipContext", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { 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.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: "directive", type: i5.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i5.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i5.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
84
85
|
}
|
|
85
86
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DemoCardsComponent, decorators: [{
|
|
86
87
|
type: Component,
|
|
87
|
-
args: [{ selector: 'pw-demo-card', template: "<!-- EDIT ICON -->\n\n<!-- DEMO LINKS -->\n<div class=\"row text-center\">\n <i *ngIf=\"
|
|
88
|
-
}], ctorParameters: () => [{ type: i1.DomSanitizer }, { type: i2.NgbModal }, { type: i3.
|
|
88
|
+
args: [{ selector: 'pw-demo-card', template: "<!-- EDIT ICON -->\n\n<!-- DEMO LINKS -->\n<div class=\"row text-center\">\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon mb-3 cursor-pointer\"\n title=\"Edit Booking Links\"\n (click)=\"openEditBookLinks(editBookLinksModal)\"\n (keydown.enter)=\"openEditBookLinks(editBookLinksModal)\"\n (keydown.space)=\"openEditBookLinks(editBookLinksModal)\">\n </i>\n <div class=\"col-md-6 col-lg-4 mb-5\" *ngFor=\"let link of bookingLinks\">\n <h5 class=\"mb-3\">{{ link?.title }}</h5>\n <iframe [src]=\"link?.url\"\n width=\"100%\"\n title=\"Booking frame\"\n height=\"600\"\n class=\"iframe-no-border\">\n </iframe>\n </div>\n</div>\n\n<!-- MODAL TEMPLATE -->\n<ng-template #editBookLinksModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Edit Book Demo Links</h5>\n <button type=\"button\" class=\"btn-close\" (click)=\"modal.dismiss()\" aria-label=\"Close\"></button>\n </div>\n\n <div class=\"modal-body\">\n <div cdkDropList (cdkDropListDropped)=\"dropBookingLink($event)\">\n <div *ngFor=\"let item of editingBookingLinks; let i = index\" class=\"card p-3 mb-3\" cdkDrag>\n <div class=\"row\">\n <div class=\"col-md-5\">\n <label for=\"demoLinkTitle{{i}}\" class=\"form-label\">Link Title</label>\n <input id=\"demoLinkTitle{{i}}\" class=\"form-control\" [(ngModel)]=\"item.title\" />\n </div>\n <div class=\"col-md-5\">\n <label for=\"demoLinkUrl{{i}}\" class=\"form-label\">Link URL</label>\n <input id=\"demoLinkUrl{{i}}\" class=\"form-control\" [(ngModel)]=\"item.url\" />\n </div>\n <div class=\"col-sm-1 d-flex justify-content-end mt-3\">\n <i\n ngbTooltip=\"Remove\"\n (click)=\"removeBookDemoLink(i)\"\n (keydown.enter)=\"removeBookDemoLink(i)\"\n (keydown.space)=\"removeBookDemoLink(i)\"\n class=\"fa fa-trash in-page-trash-icon delete-icon text-danger\"\n aria-hidden=\"true\"\n ></i>\n </div>\n\n <div class=\"col-sm-1 d-flex justify-content-end mt-3\">\n <i\n class=\"fa fa-bars in-page-bars-icon cursor-move\"\n cdkDragHandle\n ngbTooltip=\"Drag to reorder\"\n aria-hidden=\"true\"\n ></i>\n </div>\n </div>\n\n </div>\n </div>\n\n <button class=\"btn btn-outline-primary mt-3\" (click)=\"addBookingLink()\">\n <i class=\"fa fa-plus me-1\"></i> Add Book Demo Link\n </button>\n </div>\n\n <div class=\"modal-footer\">\n <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n <button class=\"btn btn-primary\" (click)=\"saveBookingLinks(modal)\">Save</button>\n </div>\n</ng-template>\n", styles: [".iframe-no-border{border:0}\n"] }]
|
|
89
|
+
}], ctorParameters: () => [{ type: i1.DomSanitizer }, { type: i2.NgbModal }, { type: i3.AdminService }, { type: i0.Injector }], propDecorators: { user: [{
|
|
90
|
+
type: Input
|
|
91
|
+
}], userLoggedIn: [{
|
|
92
|
+
type: Input
|
|
93
|
+
}], editBookLinksModal: [{
|
|
89
94
|
type: ViewChild,
|
|
90
95
|
args: ['editBookLinksModal', { static: true }]
|
|
91
96
|
}] } });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"demo-cards.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/demo-cards/demo-cards.component.ts","../../../../../../libs/shared-components/src/lib/demo-cards/demo-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { moveItemInArray } from '@angular/cdk/drag-drop';\nimport { Component, Injector, OnInit, TemplateRef, ViewChild } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService } from '@posiwise/common-services';\nimport { User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { CustomUploaderComponent } from '../custom-uploader/custom-uploader.component';\n\n@Component({\n    selector: 'pw-demo-card',\n    templateUrl: './demo-cards.component.html',\n    styleUrls: ['./demo-cards.component.scss']\n})\nexport class DemoCardsComponent extends AppBaseComponent implements OnInit {\n    bookingLinks;\n    editingBookingLinks = [];\n\n    domainId = this.appConfig?.domain_id;\n    subscriptionId: string;\n    userLoggedIn: boolean;\n    user: User;\n\n    @ViewChild('editBookLinksModal', { static: true })\n    editBookLinksModal!: TemplateRef<CustomUploaderComponent>;\n\n    constructor(\n        private readonly sanitizer: DomSanitizer,\n        private readonly modalService: NgbModal,\n        private readonly authService: AuthService,\n        private readonly adminService: AdminService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        this.authService.getToken$().subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n                });\n            }\n        });\n\n        this.bookingLinks = (this.appConfig?.pages_config?.book_demo?.items ?? []).map(link => ({\n            ...link,\n            // NOSONAR: Trusted iframe URL content is handled safely here\n            url: this.sanitizer.bypassSecurityTrustResourceUrl(link.url) // NOSONAR\n        }));\n    }\n\n    openEditBookLinks(modal) {\n        this.editingBookingLinks = JSON.parse(\n            JSON.stringify(this.appConfig?.pages_config?.book_demo?.items ?? [])\n        );\n        this.modalService.open(modal, { size: 'lg', centered: true, windowClass: 'modal-holder' });\n    }\n\n    addBookingLink() {\n        this.editingBookingLinks.push({ title: '', url: '' });\n    }\n\n    removeBookDemoLink(i: number) {\n        this.editingBookingLinks.splice(i, 1);\n    }\n\n    dropBookingLink(event) {\n        moveItemInArray(this.editingBookingLinks, event.previousIndex, event.currentIndex);\n    }\n\n    saveBookingLinks(modal) {\n        this.adminService\n            .updateDomainConfig(this.domainId, {\n                book_demo: {\n                    ...this.appConfig?.pages_config?.book_demo,\n                    items: this.editingBookingLinks\n                },\n                subscription_id: this.subscriptionId\n            })\n            .subscribe(() => {\n                this.toast.success('Booking links updated');\n                this.bookingLinks = this.editingBookingLinks.map(link => ({\n                    ...link,\n                    // NOSONAR: Trusted iframe URL content is handled safely here\n                    url: this.sanitizer.bypassSecurityTrustResourceUrl(link.url) // NOSONAR\n                }));\n                this.appConfig.pages_config.book_demo.items = [...this.editingBookingLinks]; // ✅ Like CTAs\n                modal.close();\n            });\n    }\n    canEditResources(): boolean {\n        return HelperService.canEditResources(this.user, this.userLoggedIn, this.permissionService);\n    }\n}\n","<!-- EDIT ICON -->\n\n<!-- DEMO LINKS -->\n<div class=\"row text-center\">\n  <i *ngIf=\"canEditResources()\"\n    class=\"fa fa-edit in-page-edit-icon mb-3 cursor-pointer\"\n    title=\"Edit Booking Links\"\n    (click)=\"openEditBookLinks(editBookLinksModal)\"\n    (keydown.enter)=\"openEditBookLinks(editBookLinksModal)\"\n    (keydown.space)=\"openEditBookLinks(editBookLinksModal)\">\n  </i>\n  <div class=\"col-md-6 col-lg-4 mb-5\" *ngFor=\"let link of bookingLinks\">\n    <h5 class=\"mb-3\">{{ link?.title }}</h5>\n    <iframe [src]=\"link?.url\"\n      width=\"100%\"\n      title=\"Booking frame\"\n      height=\"600\"\n      class=\"iframe-no-border\">\n    </iframe>\n  </div>\n</div>\n\n<!-- MODAL TEMPLATE -->\n<ng-template #editBookLinksModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Book Demo Links</h5>\n    <button type=\"button\" class=\"btn-close\" (click)=\"modal.dismiss()\" aria-label=\"Close\"></button>\n  </div>\n\n  <div class=\"modal-body\">\n    <div cdkDropList (cdkDropListDropped)=\"dropBookingLink($event)\">\n      <div *ngFor=\"let item of editingBookingLinks; let i = index\" class=\"card p-3 mb-3\" cdkDrag>\n        <div class=\"row\">\n          <div class=\"col-md-5\">\n            <label for=\"demoLinkTitle{{i}}\" class=\"form-label\">Link Title</label>\n            <input id=\"demoLinkTitle{{i}}\" class=\"form-control\" [(ngModel)]=\"item.title\" />\n          </div>\n          <div class=\"col-md-5\">\n            <label for=\"demoLinkUrl{{i}}\" class=\"form-label\">Link URL</label>\n            <input id=\"demoLinkUrl{{i}}\" class=\"form-control\" [(ngModel)]=\"item.url\" />\n          </div>\n          <div class=\"col-sm-1 d-flex justify-content-end mt-3\">\n            <i\n              ngbTooltip=\"Remove\"\n              (click)=\"removeBookDemoLink(i)\"\n              (keydown.enter)=\"removeBookDemoLink(i)\"\n              (keydown.space)=\"removeBookDemoLink(i)\"\n              class=\"fa fa-trash in-page-trash-icon delete-icon text-danger\"\n              aria-hidden=\"true\"\n            ></i>\n          </div>\n\n          <div class=\"col-sm-1 d-flex justify-content-end mt-3\">\n            <i\n              class=\"fa fa-bars in-page-bars-icon cursor-move\"\n              cdkDragHandle\n              ngbTooltip=\"Drag to reorder\"\n              aria-hidden=\"true\"\n            ></i>\n          </div>\n        </div>\n\n      </div>\n    </div>\n\n    <button class=\"btn btn-outline-primary mt-3\" (click)=\"addBookingLink()\">\n      <i class=\"fa fa-plus me-1\"></i> Add Book Demo Link\n    </button>\n  </div>\n\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n    <button class=\"btn btn-primary\" (click)=\"saveBookingLinks(modal)\">Save</button>\n  </div>\n</ng-template>\n"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"demo-cards.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/demo-cards/demo-cards.component.ts","../../../../../../libs/shared-components/src/lib/demo-cards/demo-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { moveItemInArray } from '@angular/cdk/drag-drop';\nimport {\n    Component,\n    Injector,\n    Input,\n    OnChanges,\n    OnInit,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { CustomUploaderComponent } from '../custom-uploader/custom-uploader.component';\n\n@Component({\n    selector: 'pw-demo-card',\n    templateUrl: './demo-cards.component.html',\n    styleUrls: ['./demo-cards.component.scss']\n})\nexport class DemoCardsComponent extends AppBaseComponent implements OnInit, OnChanges {\n    @Input() user: User;\n    @Input() userLoggedIn: boolean;\n\n    bookingLinks;\n    editingBookingLinks = [];\n\n    domainId = this.appConfig?.domain_id;\n    subscriptionId: string;\n\n    canEditResourcesValue;\n\n    @ViewChild('editBookLinksModal', { static: true })\n    editBookLinksModal!: TemplateRef<CustomUploaderComponent>;\n\n    constructor(\n        private readonly sanitizer: DomSanitizer,\n        private readonly modalService: NgbModal,\n        private readonly adminService: AdminService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        if (this.userLoggedIn) {\n            this.localStorage.getItem$('product').subscribe(res => {\n                const data = res ? JSON.parse(res) : null;\n                this.subscriptionId = data?.subscriptionId;\n            });\n        }\n\n        this.bookingLinks = (this.appConfig?.pages_config?.book_demo?.items ?? []).map(link => ({\n            ...link,\n            // NOSONAR: Trusted iframe URL content is handled safely here\n            url: this.sanitizer.bypassSecurityTrustResourceUrl(link.url) // NOSONAR\n        }));\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes['user'] || changes['userLoggedIn']) {\n            if (this.userLoggedIn && this.user) {\n                this.updateCanEditResourcesValue();\n            }\n        }\n    }\n\n    openEditBookLinks(modal) {\n        this.editingBookingLinks = JSON.parse(\n            JSON.stringify(this.appConfig?.pages_config?.book_demo?.items ?? [])\n        );\n        this.modalService.open(modal, { size: 'lg', centered: true, windowClass: 'modal-holder' });\n    }\n\n    addBookingLink() {\n        this.editingBookingLinks.push({ title: '', url: '' });\n    }\n\n    removeBookDemoLink(i: number) {\n        this.editingBookingLinks.splice(i, 1);\n    }\n\n    dropBookingLink(event) {\n        moveItemInArray(this.editingBookingLinks, event.previousIndex, event.currentIndex);\n    }\n\n    saveBookingLinks(modal) {\n        this.adminService\n            .updateDomainConfig(this.domainId, {\n                book_demo: {\n                    ...this.appConfig?.pages_config?.book_demo,\n                    items: this.editingBookingLinks\n                },\n                subscription_id: this.subscriptionId\n            })\n            .subscribe(() => {\n                this.toast.success('Booking links updated');\n                this.bookingLinks = this.editingBookingLinks.map(link => ({\n                    ...link,\n                    // NOSONAR: Trusted iframe URL content is handled safely here\n                    url: this.sanitizer.bypassSecurityTrustResourceUrl(link.url) // NOSONAR\n                }));\n                this.appConfig.pages_config.book_demo.items = [...this.editingBookingLinks]; // ✅ Like CTAs\n                modal.close();\n            });\n    }\n    private updateCanEditResourcesValue(): void {\n        this.canEditResourcesValue = HelperService.canEditResources(\n            this.user,\n            this.userLoggedIn,\n            this.permissionService\n        );\n    }\n\n    canEditResources(): boolean {\n        return this.canEditResourcesValue;\n    }\n}\n","<!-- EDIT ICON -->\n\n<!-- DEMO LINKS -->\n<div class=\"row text-center\">\n  <i *ngIf=\"canEditResourcesValue\"\n    class=\"fa fa-edit in-page-edit-icon mb-3 cursor-pointer\"\n    title=\"Edit Booking Links\"\n    (click)=\"openEditBookLinks(editBookLinksModal)\"\n    (keydown.enter)=\"openEditBookLinks(editBookLinksModal)\"\n    (keydown.space)=\"openEditBookLinks(editBookLinksModal)\">\n  </i>\n  <div class=\"col-md-6 col-lg-4 mb-5\" *ngFor=\"let link of bookingLinks\">\n    <h5 class=\"mb-3\">{{ link?.title }}</h5>\n    <iframe [src]=\"link?.url\"\n      width=\"100%\"\n      title=\"Booking frame\"\n      height=\"600\"\n      class=\"iframe-no-border\">\n    </iframe>\n  </div>\n</div>\n\n<!-- MODAL TEMPLATE -->\n<ng-template #editBookLinksModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Book Demo Links</h5>\n    <button type=\"button\" class=\"btn-close\" (click)=\"modal.dismiss()\" aria-label=\"Close\"></button>\n  </div>\n\n  <div class=\"modal-body\">\n    <div cdkDropList (cdkDropListDropped)=\"dropBookingLink($event)\">\n      <div *ngFor=\"let item of editingBookingLinks; let i = index\" class=\"card p-3 mb-3\" cdkDrag>\n        <div class=\"row\">\n          <div class=\"col-md-5\">\n            <label for=\"demoLinkTitle{{i}}\" class=\"form-label\">Link Title</label>\n            <input id=\"demoLinkTitle{{i}}\" class=\"form-control\" [(ngModel)]=\"item.title\" />\n          </div>\n          <div class=\"col-md-5\">\n            <label for=\"demoLinkUrl{{i}}\" class=\"form-label\">Link URL</label>\n            <input id=\"demoLinkUrl{{i}}\" class=\"form-control\" [(ngModel)]=\"item.url\" />\n          </div>\n          <div class=\"col-sm-1 d-flex justify-content-end mt-3\">\n            <i\n              ngbTooltip=\"Remove\"\n              (click)=\"removeBookDemoLink(i)\"\n              (keydown.enter)=\"removeBookDemoLink(i)\"\n              (keydown.space)=\"removeBookDemoLink(i)\"\n              class=\"fa fa-trash in-page-trash-icon delete-icon text-danger\"\n              aria-hidden=\"true\"\n            ></i>\n          </div>\n\n          <div class=\"col-sm-1 d-flex justify-content-end mt-3\">\n            <i\n              class=\"fa fa-bars in-page-bars-icon cursor-move\"\n              cdkDragHandle\n              ngbTooltip=\"Drag to reorder\"\n              aria-hidden=\"true\"\n            ></i>\n          </div>\n        </div>\n\n      </div>\n    </div>\n\n    <button class=\"btn btn-outline-primary mt-3\" (click)=\"addBookingLink()\">\n      <i class=\"fa fa-plus me-1\"></i> Add Book Demo Link\n    </button>\n  </div>\n\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n    <button class=\"btn btn-primary\" (click)=\"saveBookingLinks(modal)\">Save</button>\n  </div>\n</ng-template>\n"]}
|