@posiwise/shared-components 0.0.102 → 0.0.104

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.
@@ -3,21 +3,26 @@ import { Component, Inject, Injector, Input } from '@angular/core';
3
3
  import { AdminService } from '@posiwise/admin-module-utils';
4
4
  import { AppBaseComponent } from '@posiwise/app-base-component';
5
5
  import { PermissionService } from '@posiwise/common-services';
6
+ import { DomSanitizer } from '@angular/platform-browser';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "@posiwise/admin-module-utils";
8
- import * as i2 from "@angular/common";
9
- import * as i3 from "@ng-bootstrap/ng-bootstrap";
10
- import * as i4 from "../header/header.component";
9
+ import * as i2 from "@angular/platform-browser";
10
+ import * as i3 from "primeng/progressspinner";
11
+ import * as i4 from "@angular/common";
12
+ import * as i5 from "@ng-bootstrap/ng-bootstrap";
13
+ import * as i6 from "../header/header.component";
11
14
  export class PrivacyAndTosComponent extends AppBaseComponent {
12
- constructor(adminService, injector, document) {
15
+ constructor(adminService, injector, document, sanitizer) {
13
16
  super(injector);
14
17
  this.adminService = adminService;
15
18
  this.document = document;
19
+ this.sanitizer = sanitizer;
16
20
  this.tabId = 'privacy-policy';
17
21
  }
18
22
  ngOnInit() {
19
23
  this.privacyAndTos = this.appConfig?.main_tos_id;
20
24
  this.product = this.route.snapshot.queryParamMap.get('product');
25
+ this.isLoaded = false;
21
26
  this.route.params.subscribe(data => {
22
27
  this.id = data['Id'];
23
28
  if (this.id) {
@@ -57,20 +62,36 @@ export class PrivacyAndTosComponent extends AppBaseComponent {
57
62
  });
58
63
  }
59
64
  getTosDetails(id) {
60
- this.adminService.getTosDetails(id).subscribe(response => {
65
+ this.adminService
66
+ .getTosDetails(id)
67
+ .subscribe(response => {
61
68
  this.data = response;
69
+ let privacyData;
70
+ if (response && response?.privacy) {
71
+ const parser = new DOMParser();
72
+ const doc = parser.parseFromString(response?.privacy, 'text/html');
73
+ // Remove all button elements
74
+ const buttons = doc.querySelectorAll('button');
75
+ buttons.forEach(button => button.remove());
76
+ // Return sanitized HTML
77
+ privacyData = this.sanitizer.bypassSecurityTrustHtml(doc.body.innerHTML);
78
+ }
79
+ this.data = { ...response, privacy: privacyData };
80
+ })
81
+ .add(() => {
82
+ this.isLoaded = true;
62
83
  });
63
84
  }
64
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PrivacyAndTosComponent, deps: [{ token: i1.AdminService }, { token: i0.Injector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
65
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PrivacyAndTosComponent, selector: "pw-privacy-and-tos", inputs: { productId: "productId" }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"isPublic\">\n <pw-header [landing]=\"false\"></pw-header>\n</ng-container>\n\n<div class=\"col-12 d-flex\"\n *ngIf=\"!isPublic\">\n <a href=\"javascript:void(0)\"\n (click)=\"back()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h3 class=\"mt-3\">{{ productName }}</h3>\n</div>\n\n<div [ngClass]=\"{ 'container pw-tab overflow-hidden': isPublic }\">\n <div [ngClass]=\"{ dashboard: isPublic }\">\n <div [ngClass]=\"{ 'dashboard-body': isPublic }\">\n <div [ngClass]=\"{ 'mt-5': isPublic }\">\n <h3 *ngIf=\"isPublic\">{{ product }}</h3>\n <ul ngbNav\n #nav=\"ngbNav\"\n [(activeId)]=\"tabId\"\n class=\"nav-tabs\">\n <li [ngbNavItem]=\"'privacy-policy'\">\n <a ngbNavLink>Privacy policy</a>\n <ng-template ngbNavContent>\n <div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body pt-1\">\n <div class=\"row\">\n <div class=\"col-12 terms-of-service\">\n <h3>Privacy policy</h3>\n <div class=\"clearfix\"></div>\n <p [innerHTML]=\"data?.privacy\"></p>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n </li>\n <li [ngbNavItem]=\"'terms-of-service'\">\n <a ngbNavLink>Terms of Services</a>\n <ng-template ngbNavContent>\n <div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body pt-1\">\n <div class=\"row\">\n <div class=\"col-12 terms-of-service\">\n <h3>Terms of Services</h3>\n <div class=\"clearfix\"></div>\n <p [innerHTML]=\"data?.tos\"></p>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n </li>\n </ul>\n <div [ngbNavOutlet]=\"nav\"></div>\n </div>\n </div>\n </div>\n</div>\n", styles: ["::ng-deep .terms-of-service ul{list-style:disc!important;padding-left:40px!important}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgbNavContent, selector: "ng-template[ngbNavContent]" }, { kind: "directive", type: i3.NgbNav, selector: "[ngbNav]", inputs: ["activeId", "animation", "destroyOnHide", "orientation", "roles", "keyboard"], outputs: ["activeIdChange", "shown", "hidden", "navChange"], exportAs: ["ngbNav"] }, { kind: "directive", type: i3.NgbNavItem, selector: "[ngbNavItem]", inputs: ["destroyOnHide", "disabled", "domId", "ngbNavItem"], outputs: ["shown", "hidden"], exportAs: ["ngbNavItem"] }, { kind: "directive", type: i3.NgbNavItemRole, selector: "[ngbNavItem]:not(ng-container)" }, { kind: "directive", type: i3.NgbNavLink, selector: "a[ngbNavLink]" }, { kind: "directive", type: i3.NgbNavLinkBase, selector: "[ngbNavLink]" }, { kind: "component", type: i3.NgbNavOutlet, selector: "[ngbNavOutlet]", inputs: ["paneRole", "ngbNavOutlet"] }, { kind: "component", type: i4.HeaderComponent, selector: "pw-header", inputs: ["landing"] }] }); }
85
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PrivacyAndTosComponent, deps: [{ token: i1.AdminService }, { token: i0.Injector }, { token: DOCUMENT }, { token: i2.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
86
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PrivacyAndTosComponent, selector: "pw-privacy-and-tos", inputs: { productId: "productId" }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"isPublic\">\n <pw-header [landing]=\"false\"></pw-header>\n</ng-container>\n\n<div class=\"col-12 d-flex\"\n *ngIf=\"!isPublic\">\n <a href=\"javascript:void(0)\"\n (click)=\"back()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h3 class=\"mt-3\">{{ productName }}</h3>\n</div>\n\n\n\n\n<div [ngClass]=\"{ 'container pw-tab overflow-hidden': isPublic }\" >\n <div [ngClass]=\"{ dashboard: isPublic }\">\n <div [ngClass]=\"{ 'dashboard-body': isPublic }\">\n <div [ngClass]=\"{ 'mt-5': isPublic }\">\n <h3 *ngIf=\"isPublic\">{{ product }}</h3>\n <div>\n\n <ul ngbNav\n #nav=\"ngbNav\"\n [(activeId)]=\"tabId\"\n class=\"nav-tabs\">\n <li [ngbNavItem]=\"'privacy-policy'\">\n <a ngbNavLink>Privacy policy</a>\n <ng-template ngbNavContent>\n <div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body pt-1\">\n <div class=\"row\">\n <div class=\"col-12 terms-of-service\">\n <h3>Privacy policy</h3>\n <div class=\"clearfix\"></div>\n <p [innerHTML]=\"data?.privacy\"></p>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n </li>\n <li [ngbNavItem]=\"'terms-of-service'\">\n <a ngbNavLink>Terms of Services</a>\n <ng-template ngbNavContent>\n <div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body pt-1\">\n <div class=\"row\">\n <div class=\"col-12 terms-of-service\">\n <h3>Terms of Services</h3>\n <div class=\"clearfix\"></div>\n <p [innerHTML]=\"data?.tos\"></p>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n </li>\n </ul>\n </div>\n <div class=\"w-100 text-center p-2 mt-5\" *ngIf=\"!isLoaded\">\n <p-progressSpinner strokeWidth=\"2\"></p-progressSpinner>\n </div>\n <div [ngbNavOutlet]=\"nav\" *ngIf=\"isLoaded\"></div>\n </div>\n </div>\n </div>\n</div>\n", styles: ["::ng-deep .terms-of-service ul{list-style:disc!important;padding-left:40px!important}\n"], dependencies: [{ kind: "component", type: i3.ProgressSpinner, selector: "p-progressSpinner", inputs: ["styleClass", "style", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgbNavContent, selector: "ng-template[ngbNavContent]" }, { kind: "directive", type: i5.NgbNav, selector: "[ngbNav]", inputs: ["activeId", "animation", "destroyOnHide", "orientation", "roles", "keyboard"], outputs: ["activeIdChange", "shown", "hidden", "navChange"], exportAs: ["ngbNav"] }, { kind: "directive", type: i5.NgbNavItem, selector: "[ngbNavItem]", inputs: ["destroyOnHide", "disabled", "domId", "ngbNavItem"], outputs: ["shown", "hidden"], exportAs: ["ngbNavItem"] }, { kind: "directive", type: i5.NgbNavItemRole, selector: "[ngbNavItem]:not(ng-container)" }, { kind: "directive", type: i5.NgbNavLink, selector: "a[ngbNavLink]" }, { kind: "directive", type: i5.NgbNavLinkBase, selector: "[ngbNavLink]" }, { kind: "component", type: i5.NgbNavOutlet, selector: "[ngbNavOutlet]", inputs: ["paneRole", "ngbNavOutlet"] }, { kind: "component", type: i6.HeaderComponent, selector: "pw-header", inputs: ["landing"] }] }); }
66
87
  }
67
88
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PrivacyAndTosComponent, decorators: [{
68
89
  type: Component,
69
- args: [{ selector: 'pw-privacy-and-tos', template: "<ng-container *ngIf=\"isPublic\">\n <pw-header [landing]=\"false\"></pw-header>\n</ng-container>\n\n<div class=\"col-12 d-flex\"\n *ngIf=\"!isPublic\">\n <a href=\"javascript:void(0)\"\n (click)=\"back()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h3 class=\"mt-3\">{{ productName }}</h3>\n</div>\n\n<div [ngClass]=\"{ 'container pw-tab overflow-hidden': isPublic }\">\n <div [ngClass]=\"{ dashboard: isPublic }\">\n <div [ngClass]=\"{ 'dashboard-body': isPublic }\">\n <div [ngClass]=\"{ 'mt-5': isPublic }\">\n <h3 *ngIf=\"isPublic\">{{ product }}</h3>\n <ul ngbNav\n #nav=\"ngbNav\"\n [(activeId)]=\"tabId\"\n class=\"nav-tabs\">\n <li [ngbNavItem]=\"'privacy-policy'\">\n <a ngbNavLink>Privacy policy</a>\n <ng-template ngbNavContent>\n <div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body pt-1\">\n <div class=\"row\">\n <div class=\"col-12 terms-of-service\">\n <h3>Privacy policy</h3>\n <div class=\"clearfix\"></div>\n <p [innerHTML]=\"data?.privacy\"></p>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n </li>\n <li [ngbNavItem]=\"'terms-of-service'\">\n <a ngbNavLink>Terms of Services</a>\n <ng-template ngbNavContent>\n <div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body pt-1\">\n <div class=\"row\">\n <div class=\"col-12 terms-of-service\">\n <h3>Terms of Services</h3>\n <div class=\"clearfix\"></div>\n <p [innerHTML]=\"data?.tos\"></p>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n </li>\n </ul>\n <div [ngbNavOutlet]=\"nav\"></div>\n </div>\n </div>\n </div>\n</div>\n", styles: ["::ng-deep .terms-of-service ul{list-style:disc!important;padding-left:40px!important}\n"] }]
90
+ args: [{ selector: 'pw-privacy-and-tos', template: "<ng-container *ngIf=\"isPublic\">\n <pw-header [landing]=\"false\"></pw-header>\n</ng-container>\n\n<div class=\"col-12 d-flex\"\n *ngIf=\"!isPublic\">\n <a href=\"javascript:void(0)\"\n (click)=\"back()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h3 class=\"mt-3\">{{ productName }}</h3>\n</div>\n\n\n\n\n<div [ngClass]=\"{ 'container pw-tab overflow-hidden': isPublic }\" >\n <div [ngClass]=\"{ dashboard: isPublic }\">\n <div [ngClass]=\"{ 'dashboard-body': isPublic }\">\n <div [ngClass]=\"{ 'mt-5': isPublic }\">\n <h3 *ngIf=\"isPublic\">{{ product }}</h3>\n <div>\n\n <ul ngbNav\n #nav=\"ngbNav\"\n [(activeId)]=\"tabId\"\n class=\"nav-tabs\">\n <li [ngbNavItem]=\"'privacy-policy'\">\n <a ngbNavLink>Privacy policy</a>\n <ng-template ngbNavContent>\n <div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body pt-1\">\n <div class=\"row\">\n <div class=\"col-12 terms-of-service\">\n <h3>Privacy policy</h3>\n <div class=\"clearfix\"></div>\n <p [innerHTML]=\"data?.privacy\"></p>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n </li>\n <li [ngbNavItem]=\"'terms-of-service'\">\n <a ngbNavLink>Terms of Services</a>\n <ng-template ngbNavContent>\n <div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body pt-1\">\n <div class=\"row\">\n <div class=\"col-12 terms-of-service\">\n <h3>Terms of Services</h3>\n <div class=\"clearfix\"></div>\n <p [innerHTML]=\"data?.tos\"></p>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n </li>\n </ul>\n </div>\n <div class=\"w-100 text-center p-2 mt-5\" *ngIf=\"!isLoaded\">\n <p-progressSpinner strokeWidth=\"2\"></p-progressSpinner>\n </div>\n <div [ngbNavOutlet]=\"nav\" *ngIf=\"isLoaded\"></div>\n </div>\n </div>\n </div>\n</div>\n", styles: ["::ng-deep .terms-of-service ul{list-style:disc!important;padding-left:40px!important}\n"] }]
70
91
  }], ctorParameters: () => [{ type: i1.AdminService }, { type: i0.Injector }, { type: Document, decorators: [{
71
92
  type: Inject,
72
93
  args: [DOCUMENT]
73
- }] }], propDecorators: { productId: [{
94
+ }] }, { type: i2.DomSanitizer }], propDecorators: { productId: [{
74
95
  type: Input
75
96
  }] } });
76
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"privacy-and-tos.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/privacy-and-tos/privacy-and-tos.component.ts","../../../../../../libs/shared-components/src/lib/privacy-and-tos/privacy-and-tos.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { Component, Inject, Injector, Input, OnInit } from '@angular/core';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { User } from '@posiwise/common-utilities';\nimport { PermissionService } from '@posiwise/common-services';\n\n@Component({\n    selector: 'pw-privacy-and-tos',\n    templateUrl: './privacy-and-tos.component.html',\n    styleUrls: ['./privacy-and-tos.component.scss']\n})\nexport class PrivacyAndTosComponent extends AppBaseComponent implements OnInit {\n    @Input() productId: number;\n\n    isPublic: boolean;\n\n    id: string;\n\n    data: object;\n\n    user: User;\n\n    subscribedSubscriptions: { products: { id: number }[] }[];\n\n    product: string;\n\n    tabId = 'privacy-policy';\n\n    productName: string;\n\n    private privacyAndTos: number;\n\n    constructor(\n        private adminService: AdminService,\n        injector: Injector,\n        @Inject(DOCUMENT) private document: Document\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        this.privacyAndTos = this.appConfig?.main_tos_id;\n        this.product = this.route.snapshot.queryParamMap.get('product');\n        this.route.params.subscribe(data => {\n            this.id = data['Id'];\n            if (this.id) {\n                const id = this.id === 'details' ? this.privacyAndTos : this.id;\n                this.getTosDetails(Number(id));\n                this.isPublic = true;\n            } else if (this.productId) {\n                this.getSubscribedProduct(this.productId);\n            } else {\n                this.route.params.subscribe(id => {\n                    this.tabId = id['data'] || 'privacy-policy';\n                    this.getSubscribedProduct();\n                });\n            }\n        });\n    }\n\n    private getSubscribedProduct(id?) {\n        this.userStore().subscribe(user => {\n            this.user = user;\n            if (user) {\n                this.userService.getUserSubscriptions(user.id).subscribe(response => {\n                    this.subscribedSubscriptions = response.subscriptions;\n                    const productId = id || PermissionService.selectedProduct.id;\n                    const products = [];\n                    this.subscribedSubscriptions.forEach(subscribe => {\n                        const requiredProduct = subscribe?.products.find(x => x?.id === productId);\n                        if (requiredProduct) {\n                            products.push(requiredProduct);\n                        }\n                    });\n                    this.productName = products[0]?.name;\n                    this.getTosDetails(products[0].product_privacy_service_id);\n                });\n            }\n        });\n    }\n\n    private getTosDetails(id: number) {\n        this.adminService.getTosDetails(id).subscribe(response => {\n            this.data = response;\n        });\n    }\n}\n","<ng-container *ngIf=\"isPublic\">\n  <pw-header [landing]=\"false\"></pw-header>\n</ng-container>\n\n<div class=\"col-12 d-flex\"\n  *ngIf=\"!isPublic\">\n  <a href=\"javascript:void(0)\"\n    (click)=\"back()\"\n    class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n  <h3 class=\"mt-3\">{{ productName }}</h3>\n</div>\n\n<div [ngClass]=\"{ 'container pw-tab overflow-hidden': isPublic }\">\n  <div [ngClass]=\"{ dashboard: isPublic }\">\n    <div [ngClass]=\"{ 'dashboard-body': isPublic }\">\n      <div [ngClass]=\"{ 'mt-5': isPublic }\">\n        <h3 *ngIf=\"isPublic\">{{ product }}</h3>\n        <ul ngbNav\n          #nav=\"ngbNav\"\n          [(activeId)]=\"tabId\"\n          class=\"nav-tabs\">\n          <li [ngbNavItem]=\"'privacy-policy'\">\n            <a ngbNavLink>Privacy policy</a>\n            <ng-template ngbNavContent>\n              <div class=\"container-fluid pw-tab overflow-hidden\">\n                <div class=\"dashboard\">\n                  <div class=\"dashboard-body pt-1\">\n                    <div class=\"row\">\n                      <div class=\"col-12 terms-of-service\">\n                        <h3>Privacy policy</h3>\n                        <div class=\"clearfix\"></div>\n                        <p [innerHTML]=\"data?.privacy\"></p>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n              </div>\n            </ng-template>\n          </li>\n          <li [ngbNavItem]=\"'terms-of-service'\">\n            <a ngbNavLink>Terms of Services</a>\n            <ng-template ngbNavContent>\n              <div class=\"container-fluid pw-tab overflow-hidden\">\n                <div class=\"dashboard\">\n                  <div class=\"dashboard-body pt-1\">\n                    <div class=\"row\">\n                      <div class=\"col-12 terms-of-service\">\n                        <h3>Terms of Services</h3>\n                        <div class=\"clearfix\"></div>\n                        <p [innerHTML]=\"data?.tos\"></p>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n              </div>\n            </ng-template>\n          </li>\n        </ul>\n        <div [ngbNavOutlet]=\"nav\"></div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"privacy-and-tos.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/privacy-and-tos/privacy-and-tos.component.ts","../../../../../../libs/shared-components/src/lib/privacy-and-tos/privacy-and-tos.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAE3E,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAEhE,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;;;;;;;;AAOzD,MAAM,OAAO,sBAAuB,SAAQ,gBAAgB;IAsBxD,YACY,YAA0B,EAClC,QAAkB,EACQ,QAAkB,EACpC,SAAuB;QAE/B,KAAK,CAAC,QAAQ,CAAC,CAAC;QALR,iBAAY,GAAZ,YAAY,CAAc;QAER,aAAQ,GAAR,QAAQ,CAAU;QACpC,cAAS,GAAT,SAAS,CAAc;QAXnC,UAAK,GAAG,gBAAgB,CAAC;IAczB,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC;QACjD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAChE,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YAC/B,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;YACrB,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;gBACV,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;gBAChE,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC/B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACzB,CAAC;iBAAM,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;gBACxB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC9C,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE;oBAC7B,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,gBAAgB,CAAC;oBAC5C,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAChC,CAAC,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,oBAAoB,CAAC,EAAG;QAC5B,IAAI,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YAC9B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,IAAI,EAAE,CAAC;gBACP,IAAI,CAAC,WAAW,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;oBAChE,IAAI,CAAC,uBAAuB,GAAG,QAAQ,CAAC,aAAa,CAAC;oBACtD,MAAM,SAAS,GAAG,EAAE,IAAI,iBAAiB,CAAC,eAAe,CAAC,EAAE,CAAC;oBAC7D,MAAM,QAAQ,GAAG,EAAE,CAAC;oBACpB,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;wBAC7C,MAAM,eAAe,GAAG,SAAS,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,KAAK,SAAS,CAAC,CAAC;wBAC3E,IAAI,eAAe,EAAE,CAAC;4BAClB,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;wBACnC,CAAC;oBACL,CAAC,CAAC,CAAC;oBACH,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC;oBACrC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAC;gBAC/D,CAAC,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,aAAa,CAAC,EAAU;QAC5B,IAAI,CAAC,YAAY;aACZ,aAAa,CAAC,EAAE,CAAC;aACjB,SAAS,CAAC,QAAQ,CAAC,EAAE;YAClB,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;YACrB,IAAI,WAAW,CAAC;YAChB,IAAI,QAAQ,IAAI,QAAQ,EAAE,OAAO,EAAE,CAAC;gBAChC,MAAM,MAAM,GAAG,IAAI,SAAS,EAAE,CAAC;gBAC/B,MAAM,GAAG,GAAG,MAAM,CAAC,eAAe,CAAC,QAAQ,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;gBAEnE,6BAA6B;gBAC7B,MAAM,OAAO,GAAG,GAAG,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;gBAC/C,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;gBAE3C,wBAAwB;gBACxB,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC7E,CAAC;YAED,IAAI,CAAC,IAAI,GAAG,EAAE,GAAG,QAAQ,EAAE,OAAO,EAAE,WAAW,EAAE,CAAC;QACtD,CAAC,CAAC;aACD,GAAG,CAAC,GAAG,EAAE;YACN,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACzB,CAAC,CAAC,CAAC;IACX,CAAC;+GAhGQ,sBAAsB,sEAyBnB,QAAQ;mGAzBX,sBAAsB,qHCdnC,kmFAwEA;;4FD1Da,sBAAsB;kBALlC,SAAS;+BACI,oBAAoB;;0BA6BzB,MAAM;2BAAC,QAAQ;oEAxBX,SAAS;sBAAjB,KAAK","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { Component, Inject, Injector, Input, OnInit } from '@angular/core';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { User } from '@posiwise/common-utilities';\nimport { PermissionService } from '@posiwise/common-services';\nimport { DomSanitizer } from '@angular/platform-browser';\n\n@Component({\n    selector: 'pw-privacy-and-tos',\n    templateUrl: './privacy-and-tos.component.html',\n    styleUrls: ['./privacy-and-tos.component.scss']\n})\nexport class PrivacyAndTosComponent extends AppBaseComponent implements OnInit {\n    @Input() productId: number;\n\n    isPublic: boolean;\n\n    id: string;\n\n    data: { privacy: '' };\n\n    user: User;\n\n    subscribedSubscriptions: { products: { id: number }[] }[];\n\n    product: string;\n\n    tabId = 'privacy-policy';\n\n    productName: string;\n\n    private privacyAndTos: number;\n    isLoaded: boolean;\n\n    constructor(\n        private adminService: AdminService,\n        injector: Injector,\n        @Inject(DOCUMENT) private document: Document,\n        private sanitizer: DomSanitizer\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        this.privacyAndTos = this.appConfig?.main_tos_id;\n        this.product = this.route.snapshot.queryParamMap.get('product');\n        this.isLoaded = false;\n        this.route.params.subscribe(data => {\n            this.id = data['Id'];\n            if (this.id) {\n                const id = this.id === 'details' ? this.privacyAndTos : this.id;\n                this.getTosDetails(Number(id));\n                this.isPublic = true;\n            } else if (this.productId) {\n                this.getSubscribedProduct(this.productId);\n            } else {\n                this.route.params.subscribe(id => {\n                    this.tabId = id['data'] || 'privacy-policy';\n                    this.getSubscribedProduct();\n                });\n            }\n        });\n    }\n\n    private getSubscribedProduct(id?) {\n        this.userStore().subscribe(user => {\n            this.user = user;\n            if (user) {\n                this.userService.getUserSubscriptions(user.id).subscribe(response => {\n                    this.subscribedSubscriptions = response.subscriptions;\n                    const productId = id || PermissionService.selectedProduct.id;\n                    const products = [];\n                    this.subscribedSubscriptions.forEach(subscribe => {\n                        const requiredProduct = subscribe?.products.find(x => x?.id === productId);\n                        if (requiredProduct) {\n                            products.push(requiredProduct);\n                        }\n                    });\n                    this.productName = products[0]?.name;\n                    this.getTosDetails(products[0].product_privacy_service_id);\n                });\n            }\n        });\n    }\n\n    private getTosDetails(id: number) {\n        this.adminService\n            .getTosDetails(id)\n            .subscribe(response => {\n                this.data = response;\n                let privacyData;\n                if (response && response?.privacy) {\n                    const parser = new DOMParser();\n                    const doc = parser.parseFromString(response?.privacy, 'text/html');\n\n                    // Remove all button elements\n                    const buttons = doc.querySelectorAll('button');\n                    buttons.forEach(button => button.remove());\n\n                    // Return sanitized HTML\n                    privacyData = this.sanitizer.bypassSecurityTrustHtml(doc.body.innerHTML);\n                }\n\n                this.data = { ...response, privacy: privacyData };\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n}\n","<ng-container *ngIf=\"isPublic\">\n  <pw-header [landing]=\"false\"></pw-header>\n</ng-container>\n\n<div class=\"col-12 d-flex\"\n  *ngIf=\"!isPublic\">\n  <a href=\"javascript:void(0)\"\n    (click)=\"back()\"\n    class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n  <h3 class=\"mt-3\">{{ productName }}</h3>\n</div>\n\n\n\n\n<div [ngClass]=\"{ 'container pw-tab overflow-hidden': isPublic }\" >\n  <div [ngClass]=\"{ dashboard: isPublic }\">\n    <div [ngClass]=\"{ 'dashboard-body': isPublic }\">\n      <div [ngClass]=\"{ 'mt-5': isPublic }\">\n        <h3 *ngIf=\"isPublic\">{{ product }}</h3>\n        <div>\n\n          <ul ngbNav\n            #nav=\"ngbNav\"\n            [(activeId)]=\"tabId\"\n            class=\"nav-tabs\">\n            <li [ngbNavItem]=\"'privacy-policy'\">\n              <a ngbNavLink>Privacy policy</a>\n              <ng-template ngbNavContent>\n                <div class=\"container-fluid pw-tab overflow-hidden\">\n                  <div class=\"dashboard\">\n                    <div class=\"dashboard-body pt-1\">\n                      <div class=\"row\">\n                        <div class=\"col-12 terms-of-service\">\n                          <h3>Privacy policy</h3>\n                          <div class=\"clearfix\"></div>\n                          <p [innerHTML]=\"data?.privacy\"></p>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n              </ng-template>\n            </li>\n            <li [ngbNavItem]=\"'terms-of-service'\">\n              <a ngbNavLink>Terms of Services</a>\n              <ng-template ngbNavContent>\n                <div class=\"container-fluid pw-tab overflow-hidden\">\n                  <div class=\"dashboard\">\n                    <div class=\"dashboard-body pt-1\">\n                      <div class=\"row\">\n                        <div class=\"col-12 terms-of-service\">\n                          <h3>Terms of Services</h3>\n                          <div class=\"clearfix\"></div>\n                          <p [innerHTML]=\"data?.tos\"></p>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n              </ng-template>\n            </li>\n          </ul>\n        </div>\n        <div class=\"w-100 text-center p-2 mt-5\" *ngIf=\"!isLoaded\">\n          <p-progressSpinner strokeWidth=\"2\"></p-progressSpinner>\n        </div>\n        <div [ngbNavOutlet]=\"nav\" *ngIf=\"isLoaded\"></div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}