@posiwise/resource-module 0.0.143 → 0.0.145

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.
Files changed (34) hide show
  1. package/esm2022/lib/public/components/base/base-resource.component.mjs +7 -3
  2. package/esm2022/lib/public/components/base/base-top-banner.component.mjs +7 -4
  3. package/esm2022/lib/public/components/reslease-note-card/release-note-card.component.mjs +14 -7
  4. package/esm2022/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.mjs +11 -4
  5. package/esm2022/lib/public/components/resource-integration/resource-integration.component.mjs +16 -8
  6. package/esm2022/lib/public/components/resource-post/related-resources/related-resources.component.mjs +13 -6
  7. package/esm2022/lib/public/components/resource-post/related-resources/resource-cards/resource-cards.component.mjs +11 -4
  8. package/esm2022/lib/public/components/resource-release-notes/resource-release-notes.component.mjs +14 -3
  9. package/esm2022/lib/public/components/resource-vault/resource-vault.component.mjs +3 -3
  10. package/esm2022/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.mjs +11 -4
  11. package/esm2022/lib/public/components/resource-webinars/replay-event-cards/replay-event-cards.component.mjs +12 -4
  12. package/esm2022/lib/public/components/resource-webinars/resource-webinars.component.mjs +12 -4
  13. package/esm2022/lib/public/components/resource-webinars/upcoming-event-cards/upcoming-event-cards.component.mjs +13 -6
  14. package/esm2022/lib/public/components/resources/resource-tags/resource-tags.component.mjs +11 -3
  15. package/esm2022/lib/public/components/resources/vault-section/vault-section.component.mjs +25 -3
  16. package/esm2022/lib/public/components/resources-hub/resources-hub.component.mjs +12 -5
  17. package/fesm2022/posiwise-resource-module.mjs +170 -55
  18. package/fesm2022/posiwise-resource-module.mjs.map +1 -1
  19. package/lib/public/components/base/base-resource.component.d.ts +1 -0
  20. package/lib/public/components/base/base-top-banner.component.d.ts +1 -0
  21. package/lib/public/components/reslease-note-card/release-note-card.component.d.ts +3 -0
  22. package/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.d.ts +3 -0
  23. package/lib/public/components/resource-integration/resource-integration.component.d.ts +3 -0
  24. package/lib/public/components/resource-post/related-resources/related-resources.component.d.ts +3 -0
  25. package/lib/public/components/resource-post/related-resources/resource-cards/resource-cards.component.d.ts +3 -0
  26. package/lib/public/components/resource-release-notes/resource-release-notes.component.d.ts +5 -1
  27. package/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.d.ts +3 -0
  28. package/lib/public/components/resource-webinars/replay-event-cards/replay-event-cards.component.d.ts +3 -0
  29. package/lib/public/components/resource-webinars/resource-webinars.component.d.ts +3 -0
  30. package/lib/public/components/resource-webinars/upcoming-event-cards/upcoming-event-cards.component.d.ts +3 -0
  31. package/lib/public/components/resources/resource-tags/resource-tags.component.d.ts +3 -0
  32. package/lib/public/components/resources/vault-section/vault-section.component.d.ts +10 -3
  33. package/lib/public/components/resources-hub/resources-hub.component.d.ts +3 -0
  34. package/package.json +1 -1
@@ -37,15 +37,18 @@ export class ResourceCardComponent extends AppBaseComponent {
37
37
  });
38
38
  this.userService.getUserInfo().subscribe(data => {
39
39
  this.user = data;
40
+ this.getPosts(1, 10);
40
41
  });
41
42
  }
43
+ else {
44
+ this.getPosts(1, 10);
45
+ }
42
46
  });
43
- this.getPosts(1, 10);
44
47
  }
45
48
  getPosts(page, pageSize) {
46
49
  this.isLoaded = false;
47
50
  this.resourceService
48
- .getPublicPosts(this.subscriptionId ?? this.masterSubscriptionId, page, pageSize, '', this.categoryId)
51
+ .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', this.categoryId)
49
52
  .subscribe(response => {
50
53
  const sortedPosts = (response.posts ?? [])
51
54
  .filter(post => post.showcase === true)
@@ -61,11 +64,15 @@ export class ResourceCardComponent extends AppBaseComponent {
61
64
  this.editedTitle = this.resourceTitle;
62
65
  }
63
66
  saveEditedTitle() {
64
- HelperService.updateTagTitle(this.tag, this.editedTitle, this.tagService, this.subscriptionId ?? this.masterSubscriptionId, this.toast).subscribe(() => {
67
+ HelperService.updateTagTitle(this.tag, this.editedTitle, this.tagService, this.getEffectiveSubscriptionId(), this.toast).subscribe(() => {
65
68
  this.resourceTitle = this.editedTitle;
66
69
  this.isEditingTitle = false;
67
70
  });
68
71
  }
72
+ /** Helper method to get effective subscription ID */
73
+ getEffectiveSubscriptionId() {
74
+ return HelperService.getEffectiveSubscriptionId(this.user, this.subscriptionId, this.masterSubscriptionId);
75
+ }
69
76
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceCardComponent, deps: [{ token: i0.Injector }, { token: i1.ResourceService }, { token: i2.AuthService }, { token: i2.TagService }], target: i0.ɵɵFactoryTarget.Component }); }
70
77
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ResourceCardComponent, selector: "pw-resource-cards", inputs: { categoryId: "categoryId", isHeaderVisible: "isHeaderVisible", isRelated: "isRelated", resourceTitle: "resourceTitle", postSlice: "postSlice", header: "header", tag: "tag", resourceLink: "resourceLink" }, usesInheritance: true, ngImport: i0, template: "<section class=\"msp-vault-section bg-white\">\n <div class=\"container\">\n <div class=\"d-flex justify-content-between align-items-center flex-wrap\" *ngIf=\"isHeaderVisible\">\n <h2 class=\"section-heading d-flex align-items-center\" [ngClass]=\"{ 'w-50': isEditingTitle }\">\n <ng-container *ngIf=\"!isEditingTitle; else editTitleBlock\">\n <span *ngIf=\"resourceTitle; else fallback\" [innerHTML]=\"resourceTitle\"></span>\n <ng-template #fallback>Our team\u2019s articles</ng-template>\n <i *ngIf=\"!isRelated && userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleTagEditTitle()\" (keydown.enter)=\"toggleTagEditTitle()\" (keydown.space)=\"toggleTagEditTitle()\" title=\"Edit Title\"></i>\n </ng-container>\n\n <ng-template #editTitleBlock>\n <input [(ngModel)]=\"editedTitle\" class=\"form-control d-inline w-auto me-2\" [ngClass]=\"{ 'w-100': isEditingTitle }\" />\n <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle()\">Save</button>\n <button class=\"btn btn-sm btn-secondary\" (click)=\"isEditingTitle = false\">Cancel</button>\n </ng-template>\n </h2>\n <a class=\"view-all\" [routerLink]=\"resourceLink\">VIEW ALL ></a>\n </div>\n\n <div class=\"w-100 text-center mt-3\" *ngIf=\"!isLoaded\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n <div *ngIf=\"posts.length === 0 && isLoaded\">\n <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n </div>\n\n <div class=\"row d-flex flex-wrap justify-content-center gap-4 video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n <div class=\"resource-blog-card p-4\" *ngFor=\"let post of posts\">\n <pw-resource-edit-card\n *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n [id]=\"post.id\"\n [resourceData]=\"post\"\n (updated)=\"getPosts(1, 100)\"></pw-resource-edit-card>\n <p class=\"resource-title\" [innerHTML]=\"post.title \"></p>\n <a\n [href]=\"post.external_url || ('/resources/view/' + post?.slug)\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n aria-label=\"Navigate to resource\"\n >\n <img\n [src]=\"post.picture.url\"\n class=\"img-fluid my-3 mt-auto\"\n alt=\"Webinar\"\n /></a>\n <a *ngIf=\"post?.external_url; else internalLink\"\n class=\"resource-btn mt-3\"\n [href]=\"post.external_url\"\n aria-label=\"Navigate to external url\"\n target=\"_blank\"\n rel=\"noopener noreferrer\">\n <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now' }}</span>\n <span class=\"arrow\">\u2192</span>\n </a>\n\n <ng-template #internalLink>\n <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [href]=\"'/resources/view/' + post?.slug\" target=\"_blank\">\n <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now' }}</span>\n <span class=\"arrow\">\u2192</span>\n </a>\n </ng-template>\n </div>\n </div>\n </div>\n </section>", styles: [".bold{font-weight:700}.nce-heading{margin-bottom:2rem}.nce-note{margin-top:1rem;font-size:.85rem;color:#555}.nce-divider{border:0;height:40px;width:100%;background:linear-gradient(to bottom,#0000,#00000026);margin:0}.press-release-icon{height:auto!important;margin:0 11px 1.9rem;display:block;align-self:center;width:auto!important;aspect-ratio:0!important;object-fit:cover;margin-top:auto;margin-right:0!important}.msp-vault-section{padding:60px 0;background:#fff;padding-bottom:9rem!important;padding-top:7rem!important;box-shadow:0 4px 32px -14px #40576d4d!important}.msp-vault-section .vault-heading{font-size:3rem;font-weight:300}.msp-vault-section .explore-link{color:#000;font-weight:400;text-decoration:none;font-size:1.5rem}.msp-vault-section .resource-blog-card{display:flex;flex-direction:column;justify-content:space-between;background-color:#fff;border-radius:30px;box-shadow:0 20px 40px #00000014;padding:25px;text-align:center;width:338px;height:auto!important}.msp-vault-section .resource-blog-card h5{font-size:1.5rem;font-weight:400;margin-bottom:.5rem;color:var(--text-color, black)}.msp-vault-section .resource-blog-card p{font-size:1.5rem;color:var(--text-color, black);line-height:2rem}.msp-vault-section .resource-blog-card img{width:100%;border-radius:10px;aspect-ratio:1/1;object-fit:cover;margin-top:auto;margin-right:0!important;max-width:250px!important;align-self:center!important}.msp-vault-section .resource-blog-card iframe{height:210px;border-radius:10px;object-fit:cover;margin-right:0!important;max-width:280px!important}.msp-vault-section .resource-blog-card .resource-btn{background-color:var(--text-color, black);color:#fff;margin-top:auto;padding:10px 24px;border-radius:24px;font-size:1.5rem;font-weight:500;width:100%;max-width:240px;cursor:pointer;transition:background .3s ease;display:flex;justify-content:space-between;align-self:center;align-items:center;text-align:left;text-decoration:none;border:1px solid;box-shadow:none!important;border-color:var(--text-color, black)}.msp-vault-section .resource-blog-card .resource-btn:hover{background:#fff;color:var(--text-color, black)!important}.msp-vault-section .vault-description{text-align:left;max-width:657px;color:#182527;line-height:2.3rem!important;font-size:1.65rem}@media (width <= 1200px){.msp-vault-section .vault-heading{font-size:3.5rem}.msp-vault-section .vault-description{margin-top:1.35rem}.msp-vault-section .resource-btn{margin-left:0!important}}.video-row{gap:5.5rem!important;margin-top:3rem!important}@media (width >= 991px){section.bg-white.text-center.extra-top-padding{position:relative;overflow:hidden}section.bg-white.text-center.extra-top-padding .banner-header{margin-bottom:4rem!important}}.vault-header{text-align:left}@media (width >= 768px) and (width <= 1200px){.container{padding:0 6rem!important}}@media (width <= 768px){.video-row{gap:3rem!important}}@media (width <= 768px){.vault-header{text-align:center!important}.vault-heading{font-size:3rem!important}}@media (width <= 1200px){.container{padding:7rem 3rem 1rem!important}}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "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.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i6.ProgressSpinner, selector: "p-progressSpinner", inputs: ["styleClass", "style", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }, { kind: "component", type: i7.NoDataComponent, selector: "pw-no-data", inputs: ["message", "description", "withImage"] }, { kind: "directive", type: i8.LazyImgDirective, selector: "img" }, { kind: "component", type: i9.ResourceEditCardComponent, selector: "pw-resource-edit-card", inputs: ["id", "resourceData"], outputs: ["updated"] }, { kind: "pipe", type: i10.TranslocoPipe, name: "transloco" }] }); }
71
78
  }
@@ -89,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
89
96
  }], resourceLink: [{
90
97
  type: Input
91
98
  }] } });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-cards.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/resource-module/src/lib/public/components/resource-post/related-resources/resource-cards/resource-cards.component.ts","../../../../../../../../../../libs/resource-module/src/lib/public/components/resource-post/related-resources/resource-cards/resource-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../../../resource.service';\n\n@Component({\n    selector: 'pw-resource-cards',\n    templateUrl: './resource-cards.component.html',\n    styleUrls: ['../../../resources/resources-shared.component.scss']\n})\nexport class ResourceCardComponent extends AppBaseComponent implements OnInit {\n    @Input() categoryId!: string;\n    @Input() isHeaderVisible = true;\n    @Input() isRelated = false;\n    @Input() resourceTitle!: string;\n    @Input() postSlice = false;\n    @Input() header;\n    @Input() tag;\n    @Input() resourceLink;\n\n    userLoggedIn: boolean;\n    isLoaded = false;\n    subscriptionId;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n\n    posts: Resource[] = [];\n\n    isEditingTitle: boolean;\n    editedTitle: string;\n    user: User;\n    constructor(\n        injector: Injector,\n        private readonly resourceService: ResourceService,\n        private readonly authService: AuthService,\n        private readonly tagService: TagService\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\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        this.getPosts(1, 10);\n    }\n\n    getPosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(\n                this.subscriptionId ?? this.masterSubscriptionId,\n                page,\n                pageSize,\n                '',\n                this.categoryId\n            )\n            .subscribe(response => {\n                const sortedPosts = (response.posts ?? [])\n                    .filter(post => post.showcase === true)\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    );\n                this.posts = this.postSlice ? sortedPosts : [...sortedPosts].slice(0, 3);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    toggleTagEditTitle() {\n        this.isEditingTitle = true;\n        this.editedTitle = this.resourceTitle;\n    }\n\n    saveEditedTitle() {\n        HelperService.updateTagTitle(\n            this.tag,\n            this.editedTitle,\n            this.tagService,\n            this.subscriptionId ?? this.masterSubscriptionId,\n            this.toast\n        ).subscribe(() => {\n            this.resourceTitle = this.editedTitle;\n            this.isEditingTitle = false;\n        });\n    }\n}\n","<section class=\"msp-vault-section bg-white\">\n    <div class=\"container\">\n      <div class=\"d-flex justify-content-between align-items-center flex-wrap\" *ngIf=\"isHeaderVisible\">\n        <h2 class=\"section-heading d-flex align-items-center\" [ngClass]=\"{ 'w-50': isEditingTitle }\">\n          <ng-container *ngIf=\"!isEditingTitle; else editTitleBlock\">\n            <span *ngIf=\"resourceTitle; else fallback\" [innerHTML]=\"resourceTitle\"></span>\n            <ng-template #fallback>Our team’s articles</ng-template>\n            <i  *ngIf=\"!isRelated && userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleTagEditTitle()\" (keydown.enter)=\"toggleTagEditTitle()\" (keydown.space)=\"toggleTagEditTitle()\" title=\"Edit Title\"></i>\n          </ng-container>\n\n          <ng-template #editTitleBlock>\n            <input [(ngModel)]=\"editedTitle\" class=\"form-control d-inline w-auto me-2\" [ngClass]=\"{ 'w-100': isEditingTitle }\" />\n            <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle()\">Save</button>\n            <button class=\"btn btn-sm btn-secondary\" (click)=\"isEditingTitle = false\">Cancel</button>\n          </ng-template>\n        </h2>\n        <a class=\"view-all\" [routerLink]=\"resourceLink\">VIEW ALL ></a>\n      </div>\n\n      <div class=\"w-100 text-center mt-3\" *ngIf=\"!isLoaded\">\n        <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n      </div>\n      <div *ngIf=\"posts.length === 0 && isLoaded\">\n        <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n      </div>\n\n      <div class=\"row d-flex flex-wrap justify-content-center gap-4 video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n          <div class=\"resource-blog-card p-4\" *ngFor=\"let post of posts\">\n            <pw-resource-edit-card\n            *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          [id]=\"post.id\"\n          [resourceData]=\"post\"\n          (updated)=\"getPosts(1, 100)\"></pw-resource-edit-card>\n            <p class=\"resource-title\" [innerHTML]=\"post.title \"></p>\n            <a\n            [href]=\"post.external_url || ('/resources/view/' + post?.slug)\"\n            target=\"_blank\"\n            rel=\"noopener noreferrer\"\n            aria-label=\"Navigate to resource\"\n          >\n            <img\n              [src]=\"post.picture.url\"\n              class=\"img-fluid my-3 mt-auto\"\n              alt=\"Webinar\"\n            /></a>\n            <a *ngIf=\"post?.external_url; else internalLink\"\n              class=\"resource-btn mt-3\"\n              [href]=\"post.external_url\"\n              aria-label=\"Navigate to external url\"\n              target=\"_blank\"\n              rel=\"noopener noreferrer\">\n              <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n              <span class=\"arrow\">→</span>\n            </a>\n\n          <ng-template #internalLink>\n            <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [href]=\"'/resources/view/' + post?.slug\" target=\"_blank\">\n              <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n              <span class=\"arrow\">→</span>\n            </a>\n          </ng-template>\n          </div>\n      </div>\n    </div>\n  </section>"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-cards.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/resource-module/src/lib/public/components/resource-post/related-resources/resource-cards/resource-cards.component.ts","../../../../../../../../../../libs/resource-module/src/lib/public/components/resource-post/related-resources/resource-cards/resource-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../../../resource.service';\n\n@Component({\n    selector: 'pw-resource-cards',\n    templateUrl: './resource-cards.component.html',\n    styleUrls: ['../../../resources/resources-shared.component.scss']\n})\nexport class ResourceCardComponent extends AppBaseComponent implements OnInit {\n    @Input() categoryId!: string;\n    @Input() isHeaderVisible = true;\n    @Input() isRelated = false;\n    @Input() resourceTitle!: string;\n    @Input() postSlice = false;\n    @Input() header;\n    @Input() tag;\n    @Input() resourceLink;\n\n    userLoggedIn: boolean;\n    isLoaded = false;\n    subscriptionId;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n\n    posts: Resource[] = [];\n\n    isEditingTitle: boolean;\n    editedTitle: string;\n    user: User;\n    isMasterSubscription;\n    constructor(\n        injector: Injector,\n        private readonly resourceService: ResourceService,\n        private readonly authService: AuthService,\n        private readonly tagService: TagService\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\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                    this.getPosts(1, 10);\n                });\n            } else {\n                this.getPosts(1, 10);\n            }\n        });\n    }\n\n    getPosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', this.categoryId)\n            .subscribe(response => {\n                const sortedPosts = (response.posts ?? [])\n                    .filter(post => post.showcase === true)\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    );\n                this.posts = this.postSlice ? sortedPosts : [...sortedPosts].slice(0, 3);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    toggleTagEditTitle() {\n        this.isEditingTitle = true;\n        this.editedTitle = this.resourceTitle;\n    }\n\n    saveEditedTitle() {\n        HelperService.updateTagTitle(\n            this.tag,\n            this.editedTitle,\n            this.tagService,\n            this.getEffectiveSubscriptionId(),\n            this.toast\n        ).subscribe(() => {\n            this.resourceTitle = this.editedTitle;\n            this.isEditingTitle = false;\n        });\n    }\n\n    /** Helper method to get effective subscription ID */\n    private getEffectiveSubscriptionId(): number {\n        return HelperService.getEffectiveSubscriptionId(\n            this.user,\n            this.subscriptionId,\n            this.masterSubscriptionId\n        );\n    }\n}\n","<section class=\"msp-vault-section bg-white\">\n    <div class=\"container\">\n      <div class=\"d-flex justify-content-between align-items-center flex-wrap\" *ngIf=\"isHeaderVisible\">\n        <h2 class=\"section-heading d-flex align-items-center\" [ngClass]=\"{ 'w-50': isEditingTitle }\">\n          <ng-container *ngIf=\"!isEditingTitle; else editTitleBlock\">\n            <span *ngIf=\"resourceTitle; else fallback\" [innerHTML]=\"resourceTitle\"></span>\n            <ng-template #fallback>Our team’s articles</ng-template>\n            <i  *ngIf=\"!isRelated && userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleTagEditTitle()\" (keydown.enter)=\"toggleTagEditTitle()\" (keydown.space)=\"toggleTagEditTitle()\" title=\"Edit Title\"></i>\n          </ng-container>\n\n          <ng-template #editTitleBlock>\n            <input [(ngModel)]=\"editedTitle\" class=\"form-control d-inline w-auto me-2\" [ngClass]=\"{ 'w-100': isEditingTitle }\" />\n            <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle()\">Save</button>\n            <button class=\"btn btn-sm btn-secondary\" (click)=\"isEditingTitle = false\">Cancel</button>\n          </ng-template>\n        </h2>\n        <a class=\"view-all\" [routerLink]=\"resourceLink\">VIEW ALL ></a>\n      </div>\n\n      <div class=\"w-100 text-center mt-3\" *ngIf=\"!isLoaded\">\n        <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n      </div>\n      <div *ngIf=\"posts.length === 0 && isLoaded\">\n        <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n      </div>\n\n      <div class=\"row d-flex flex-wrap justify-content-center gap-4 video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n          <div class=\"resource-blog-card p-4\" *ngFor=\"let post of posts\">\n            <pw-resource-edit-card\n            *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          [id]=\"post.id\"\n          [resourceData]=\"post\"\n          (updated)=\"getPosts(1, 100)\"></pw-resource-edit-card>\n            <p class=\"resource-title\" [innerHTML]=\"post.title \"></p>\n            <a\n            [href]=\"post.external_url || ('/resources/view/' + post?.slug)\"\n            target=\"_blank\"\n            rel=\"noopener noreferrer\"\n            aria-label=\"Navigate to resource\"\n          >\n            <img\n              [src]=\"post.picture.url\"\n              class=\"img-fluid my-3 mt-auto\"\n              alt=\"Webinar\"\n            /></a>\n            <a *ngIf=\"post?.external_url; else internalLink\"\n              class=\"resource-btn mt-3\"\n              [href]=\"post.external_url\"\n              aria-label=\"Navigate to external url\"\n              target=\"_blank\"\n              rel=\"noopener noreferrer\">\n              <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n              <span class=\"arrow\">→</span>\n            </a>\n\n          <ng-template #internalLink>\n            <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [href]=\"'/resources/view/' + post?.slug\" target=\"_blank\">\n              <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n              <span class=\"arrow\">→</span>\n            </a>\n          </ng-template>\n          </div>\n      </div>\n    </div>\n  </section>"]}
@@ -1,6 +1,7 @@
1
1
  import { Component, Injector } from '@angular/core';
2
2
  import { AppBaseComponent } from '@posiwise/app-base-component';
3
3
  import { AuthService, TagService } from '@posiwise/common-services';
4
+ import { HelperService } from '@posiwise/helper-service';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "@posiwise/common-services";
6
7
  import * as i2 from "@angular/common";
@@ -27,17 +28,27 @@ export class ResourceReleaseNoteComponent extends AppBaseComponent {
27
28
  const data = res ? JSON.parse(res) : null;
28
29
  this.subscriptionId = data?.subscriptionId;
29
30
  });
31
+ this.userService.getUserInfo().subscribe(data => {
32
+ this.user = data;
33
+ this.getPostTags();
34
+ });
35
+ }
36
+ else {
37
+ this.getPostTags();
30
38
  }
31
- this.getPostTags();
32
39
  });
33
40
  }
34
41
  getPostTags() {
35
42
  this.tagService
36
- .getTagsByType('post_categories', {}, this.subscriptionId || this.masterSubscriptionId)
43
+ .getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())
37
44
  .subscribe(response => {
38
45
  this.blogPostTag = response.tags.find(tag => tag.name === 'Product Release Notes');
39
46
  });
40
47
  }
48
+ /** Helper method to get effective subscription ID */
49
+ getEffectiveSubscriptionId() {
50
+ return HelperService.getEffectiveSubscriptionId(this.user, this.subscriptionId, this.masterSubscriptionId);
51
+ }
41
52
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceReleaseNoteComponent, deps: [{ token: i1.AuthService }, { token: i1.TagService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
42
53
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ResourceReleaseNoteComponent, selector: "pw-resource-release-notes", usesInheritance: true, ngImport: i0, template: "<pw-resource-header></pw-resource-header>\n<pw-resource-release-notes-top-banner></pw-resource-release-notes-top-banner>\n\n<pw-resource-note-card [isReleasePress]=\"true\" *ngIf=\"blogPostTag?.tag_category_id\" [tag]=\"blogPostTag\" [categoryId]=\"blogPostTag?.tag_category_id\" [releaseHeader]=\"true\" [resourceTitle]=\"blogPostTag?.title\" [postSlice]=\"true\"></pw-resource-note-card>\n\n<pw-trial-4-contact-us></pw-trial-4-contact-us>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.Trial4ContactUsComponent, selector: "pw-trial-4-contact-us", inputs: ["subscriptionId", "sourceId", "masterSubscriptionId", "experimentName", "microserviceName", "shardName"] }, { kind: "component", type: i4.ResourceHeaderComponent, selector: "pw-resource-header" }, { kind: "component", type: i5.ReleaseTopBannerComponent, selector: "pw-resource-release-notes-top-banner" }, { kind: "component", type: i6.ResourceNoteCardComponent, selector: "pw-resource-note-card", inputs: ["releaseHeader", "categoryId", "isReleasePress", "postSlice", "resourceTitle", "tag"] }] }); }
43
54
  }
@@ -45,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
45
56
  type: Component,
46
57
  args: [{ selector: 'pw-resource-release-notes', template: "<pw-resource-header></pw-resource-header>\n<pw-resource-release-notes-top-banner></pw-resource-release-notes-top-banner>\n\n<pw-resource-note-card [isReleasePress]=\"true\" *ngIf=\"blogPostTag?.tag_category_id\" [tag]=\"blogPostTag\" [categoryId]=\"blogPostTag?.tag_category_id\" [releaseHeader]=\"true\" [resourceTitle]=\"blogPostTag?.title\" [postSlice]=\"true\"></pw-resource-note-card>\n\n<pw-trial-4-contact-us></pw-trial-4-contact-us>\n" }]
47
58
  }], ctorParameters: () => [{ type: i1.AuthService }, { type: i1.TagService }, { type: i0.Injector }] });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzb3VyY2UtcmVsZWFzZS1ub3Rlcy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Jlc291cmNlLW1vZHVsZS9zcmMvbGliL3B1YmxpYy9jb21wb25lbnRzL3Jlc291cmNlLXJlbGVhc2Utbm90ZXMvcmVzb3VyY2UtcmVsZWFzZS1ub3Rlcy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Jlc291cmNlLW1vZHVsZS9zcmMvbGliL3B1YmxpYy9jb21wb25lbnRzL3Jlc291cmNlLXJlbGVhc2Utbm90ZXMvcmVzb3VyY2UtcmVsZWFzZS1ub3Rlcy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUU1RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDOzs7Ozs7OztBQU9wRSxNQUFNLE9BQU8sNEJBQTZCLFNBQVEsZ0JBQWdCO0lBTzlELFlBQ3FCLFdBQXdCLEVBQ3hCLFVBQXNCLEVBQ3ZDLFFBQWtCO1FBRWxCLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUpDLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQ3hCLGVBQVUsR0FBVixVQUFVLENBQVk7UUFQM0MseUJBQW9CLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxtQkFBbUIsQ0FBQyxlQUFlLENBQUM7UUFDMUUsVUFBSyxHQUFlLEVBQUUsQ0FBQztJQVV2QixDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUM5QyxJQUFJLENBQUMsY0FBYyxHQUFHLFFBQVEsQ0FBQztRQUNuQyxDQUFDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxXQUFXLENBQUMsU0FBUyxFQUFFLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ3pDLElBQUksQ0FBQyxZQUFZLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQztZQUMxQixJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztnQkFDcEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFO29CQUNsRCxNQUFNLElBQUksR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztvQkFDMUMsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLEVBQUUsY0FBYyxDQUFDO2dCQUMvQyxDQUFDLENBQUMsQ0FBQztZQUNQLENBQUM7WUFDRCxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDdkIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU8sV0FBVztRQUNmLElBQUksQ0FBQyxVQUFVO2FBQ1YsYUFBYSxDQUFDLGlCQUFpQixFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUMsY0FBYyxJQUFJLElBQUksQ0FBQyxvQkFBb0IsQ0FBQzthQUN0RixTQUFTLENBQUMsUUFBUSxDQUFDLEVBQUU7WUFDbEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEtBQUssdUJBQXVCLENBQUMsQ0FBQztRQUN2RixDQUFDLENBQUMsQ0FBQztJQUNYLENBQUM7K0dBckNRLDRCQUE0QjttR0FBNUIsNEJBQTRCLHdGQ1Z6Qyw0YkFNQTs7NEZESWEsNEJBQTRCO2tCQUp4QyxTQUFTOytCQUNJLDJCQUEyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0b3IsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBBcHBCYXNlQ29tcG9uZW50IH0gZnJvbSAnQHBvc2l3aXNlL2FwcC1iYXNlLWNvbXBvbmVudCc7XG5pbXBvcnQgeyBBdXRoU2VydmljZSwgVGFnU2VydmljZSB9IGZyb20gJ0Bwb3Npd2lzZS9jb21tb24tc2VydmljZXMnO1xuaW1wb3J0IHsgUmVzb3VyY2UgfSBmcm9tICdAcG9zaXdpc2UvY29tbW9uLXV0aWxpdGllcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAncHctcmVzb3VyY2UtcmVsZWFzZS1ub3RlcycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3Jlc291cmNlLXJlbGVhc2Utbm90ZXMuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIFJlc291cmNlUmVsZWFzZU5vdGVDb21wb25lbnQgZXh0ZW5kcyBBcHBCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBzdWJzY3JpcHRpb25JZDogbnVtYmVyO1xuICAgIG1hc3RlclN1YnNjcmlwdGlvbklkID0gdGhpcy5hcHBDb25maWcubWFzdGVyX3N1YnNjcmlwdGlvbi5zdWJzY3JpcHRpb25faWQ7XG4gICAgcG9zdHM6IFJlc291cmNlW10gPSBbXTtcbiAgICB1c2VyTG9nZ2VkSW46IGJvb2xlYW47XG4gICAgYmxvZ1Bvc3RUYWc7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBhdXRoU2VydmljZTogQXV0aFNlcnZpY2UsXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgdGFnU2VydmljZTogVGFnU2VydmljZSxcbiAgICAgICAgaW5qZWN0b3I6IEluamVjdG9yXG4gICAgKSB7XG4gICAgICAgIHN1cGVyKGluamVjdG9yKTtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5nZXRVc2VyU3Vic2NyaXB0aW9uSWQoKS5zdWJzY3JpYmUocmVzcG9uc2UgPT4ge1xuICAgICAgICAgICAgdGhpcy5zdWJzY3JpcHRpb25JZCA9IHJlc3BvbnNlO1xuICAgICAgICB9KTtcbiAgICAgICAgdGhpcy5hdXRoU2VydmljZS5nZXRUb2tlbiQoKS5zdWJzY3JpYmUocmVzID0+IHtcbiAgICAgICAgICAgIHRoaXMudXNlckxvZ2dlZEluID0gISFyZXM7XG4gICAgICAgICAgICBpZiAodGhpcy51c2VyTG9nZ2VkSW4pIHtcbiAgICAgICAgICAgICAgICB0aGlzLmxvY2FsU3RvcmFnZS5nZXRJdGVtJCgncHJvZHVjdCcpLnN1YnNjcmliZShyZXMgPT4ge1xuICAgICAgICAgICAgICAgICAgICBjb25zdCBkYXRhID0gcmVzID8gSlNPTi5wYXJzZShyZXMpIDogbnVsbDtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5zdWJzY3JpcHRpb25JZCA9IGRhdGE/LnN1YnNjcmlwdGlvbklkO1xuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgdGhpcy5nZXRQb3N0VGFncygpO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBwcml2YXRlIGdldFBvc3RUYWdzKCkge1xuICAgICAgICB0aGlzLnRhZ1NlcnZpY2VcbiAgICAgICAgICAgIC5nZXRUYWdzQnlUeXBlKCdwb3N0X2NhdGVnb3JpZXMnLCB7fSwgdGhpcy5zdWJzY3JpcHRpb25JZCB8fCB0aGlzLm1hc3RlclN1YnNjcmlwdGlvbklkKVxuICAgICAgICAgICAgLnN1YnNjcmliZShyZXNwb25zZSA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy5ibG9nUG9zdFRhZyA9IHJlc3BvbnNlLnRhZ3MuZmluZCh0YWcgPT4gdGFnLm5hbWUgPT09ICdQcm9kdWN0IFJlbGVhc2UgTm90ZXMnKTtcbiAgICAgICAgICAgIH0pO1xuICAgIH1cbn1cbiIsIjxwdy1yZXNvdXJjZS1oZWFkZXI+PC9wdy1yZXNvdXJjZS1oZWFkZXI+XG48cHctcmVzb3VyY2UtcmVsZWFzZS1ub3Rlcy10b3AtYmFubmVyPjwvcHctcmVzb3VyY2UtcmVsZWFzZS1ub3Rlcy10b3AtYmFubmVyPlxuXG48cHctcmVzb3VyY2Utbm90ZS1jYXJkIFtpc1JlbGVhc2VQcmVzc109XCJ0cnVlXCIgKm5nSWY9XCJibG9nUG9zdFRhZz8udGFnX2NhdGVnb3J5X2lkXCIgW3RhZ109XCJibG9nUG9zdFRhZ1wiIFtjYXRlZ29yeUlkXT1cImJsb2dQb3N0VGFnPy50YWdfY2F0ZWdvcnlfaWRcIiBbcmVsZWFzZUhlYWRlcl09XCJ0cnVlXCIgW3Jlc291cmNlVGl0bGVdPVwiYmxvZ1Bvc3RUYWc/LnRpdGxlXCIgW3Bvc3RTbGljZV09XCJ0cnVlXCI+PC9wdy1yZXNvdXJjZS1ub3RlLWNhcmQ+XG5cbjxwdy10cmlhbC00LWNvbnRhY3QtdXM+PC9wdy10cmlhbC00LWNvbnRhY3QtdXM+XG4iXX0=
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzb3VyY2UtcmVsZWFzZS1ub3Rlcy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Jlc291cmNlLW1vZHVsZS9zcmMvbGliL3B1YmxpYy9jb21wb25lbnRzL3Jlc291cmNlLXJlbGVhc2Utbm90ZXMvcmVzb3VyY2UtcmVsZWFzZS1ub3Rlcy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Jlc291cmNlLW1vZHVsZS9zcmMvbGliL3B1YmxpYy9jb21wb25lbnRzL3Jlc291cmNlLXJlbGVhc2Utbm90ZXMvcmVzb3VyY2UtcmVsZWFzZS1ub3Rlcy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUU1RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBRXBFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7Ozs7Ozs7QUFNekQsTUFBTSxPQUFPLDRCQUE2QixTQUFRLGdCQUFnQjtJQVM5RCxZQUNxQixXQUF3QixFQUN4QixVQUFzQixFQUN2QyxRQUFrQjtRQUVsQixLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7UUFKQyxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUN4QixlQUFVLEdBQVYsVUFBVSxDQUFZO1FBVDNDLHlCQUFvQixHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsbUJBQW1CLENBQUMsZUFBZSxDQUFDO1FBQzFFLFVBQUssR0FBZSxFQUFFLENBQUM7SUFZdkIsQ0FBQztJQUVELFFBQVE7UUFDSixJQUFJLENBQUMscUJBQXFCLEVBQUUsQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLEVBQUU7WUFDOUMsSUFBSSxDQUFDLGNBQWMsR0FBRyxRQUFRLENBQUM7UUFDbkMsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUN6QyxJQUFJLENBQUMsWUFBWSxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUM7WUFDMUIsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7Z0JBQ3BCLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsRUFBRTtvQkFDbEQsTUFBTSxJQUFJLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7b0JBQzFDLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxFQUFFLGNBQWMsQ0FBQztnQkFDL0MsQ0FBQyxDQUFDLENBQUM7Z0JBQ0gsSUFBSSxDQUFDLFdBQVcsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7b0JBQzVDLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO29CQUNqQixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7Z0JBQ3ZCLENBQUMsQ0FBQyxDQUFDO1lBQ1AsQ0FBQztpQkFBTSxDQUFDO2dCQUNKLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUN2QixDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU8sV0FBVztRQUNmLElBQUksQ0FBQyxVQUFVO2FBQ1YsYUFBYSxDQUFDLGlCQUFpQixFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUMsMEJBQTBCLEVBQUUsQ0FBQzthQUN2RSxTQUFTLENBQUMsUUFBUSxDQUFDLEVBQUU7WUFDbEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEtBQUssdUJBQXVCLENBQUMsQ0FBQztRQUN2RixDQUFDLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFRCxxREFBcUQ7SUFDN0MsMEJBQTBCO1FBQzlCLE9BQU8sYUFBYSxDQUFDLDBCQUEwQixDQUMzQyxJQUFJLENBQUMsSUFBSSxFQUNULElBQUksQ0FBQyxjQUFjLEVBQ25CLElBQUksQ0FBQyxvQkFBb0IsQ0FDNUIsQ0FBQztJQUNOLENBQUM7K0dBckRRLDRCQUE0QjttR0FBNUIsNEJBQTRCLHdGQ1h6Qyw0YkFNQTs7NEZES2EsNEJBQTRCO2tCQUp4QyxTQUFTOytCQUNJLDJCQUEyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0b3IsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBBcHBCYXNlQ29tcG9uZW50IH0gZnJvbSAnQHBvc2l3aXNlL2FwcC1iYXNlLWNvbXBvbmVudCc7XG5pbXBvcnQgeyBBdXRoU2VydmljZSwgVGFnU2VydmljZSB9IGZyb20gJ0Bwb3Npd2lzZS9jb21tb24tc2VydmljZXMnO1xuaW1wb3J0IHsgUmVzb3VyY2UsIFVzZXIgfSBmcm9tICdAcG9zaXdpc2UvY29tbW9uLXV0aWxpdGllcyc7XG5pbXBvcnQgeyBIZWxwZXJTZXJ2aWNlIH0gZnJvbSAnQHBvc2l3aXNlL2hlbHBlci1zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdwdy1yZXNvdXJjZS1yZWxlYXNlLW5vdGVzJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vcmVzb3VyY2UtcmVsZWFzZS1ub3Rlcy5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgUmVzb3VyY2VSZWxlYXNlTm90ZUNvbXBvbmVudCBleHRlbmRzIEFwcEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIHN1YnNjcmlwdGlvbklkOiBudW1iZXI7XG4gICAgbWFzdGVyU3Vic2NyaXB0aW9uSWQgPSB0aGlzLmFwcENvbmZpZy5tYXN0ZXJfc3Vic2NyaXB0aW9uLnN1YnNjcmlwdGlvbl9pZDtcbiAgICBwb3N0czogUmVzb3VyY2VbXSA9IFtdO1xuICAgIHVzZXJMb2dnZWRJbjogYm9vbGVhbjtcbiAgICBibG9nUG9zdFRhZztcbiAgICB1c2VyOiBVc2VyO1xuICAgIGlzTWFzdGVyU3Vic2NyaXB0aW9uO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgYXV0aFNlcnZpY2U6IEF1dGhTZXJ2aWNlLFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IHRhZ1NlcnZpY2U6IFRhZ1NlcnZpY2UsXG4gICAgICAgIGluamVjdG9yOiBJbmplY3RvclxuICAgICkge1xuICAgICAgICBzdXBlcihpbmplY3Rvcik7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMuZ2V0VXNlclN1YnNjcmlwdGlvbklkKCkuc3Vic2NyaWJlKHJlc3BvbnNlID0+IHtcbiAgICAgICAgICAgIHRoaXMuc3Vic2NyaXB0aW9uSWQgPSByZXNwb25zZTtcbiAgICAgICAgfSk7XG4gICAgICAgIHRoaXMuYXV0aFNlcnZpY2UuZ2V0VG9rZW4kKCkuc3Vic2NyaWJlKHJlcyA9PiB7XG4gICAgICAgICAgICB0aGlzLnVzZXJMb2dnZWRJbiA9ICEhcmVzO1xuICAgICAgICAgICAgaWYgKHRoaXMudXNlckxvZ2dlZEluKSB7XG4gICAgICAgICAgICAgICAgdGhpcy5sb2NhbFN0b3JhZ2UuZ2V0SXRlbSQoJ3Byb2R1Y3QnKS5zdWJzY3JpYmUocmVzID0+IHtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgZGF0YSA9IHJlcyA/IEpTT04ucGFyc2UocmVzKSA6IG51bGw7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMuc3Vic2NyaXB0aW9uSWQgPSBkYXRhPy5zdWJzY3JpcHRpb25JZDtcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICB0aGlzLnVzZXJTZXJ2aWNlLmdldFVzZXJJbmZvKCkuc3Vic2NyaWJlKGRhdGEgPT4ge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLnVzZXIgPSBkYXRhO1xuICAgICAgICAgICAgICAgICAgICB0aGlzLmdldFBvc3RUYWdzKCk7XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHRoaXMuZ2V0UG9zdFRhZ3MoKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBnZXRQb3N0VGFncygpIHtcbiAgICAgICAgdGhpcy50YWdTZXJ2aWNlXG4gICAgICAgICAgICAuZ2V0VGFnc0J5VHlwZSgncG9zdF9jYXRlZ29yaWVzJywge30sIHRoaXMuZ2V0RWZmZWN0aXZlU3Vic2NyaXB0aW9uSWQoKSlcbiAgICAgICAgICAgIC5zdWJzY3JpYmUocmVzcG9uc2UgPT4ge1xuICAgICAgICAgICAgICAgIHRoaXMuYmxvZ1Bvc3RUYWcgPSByZXNwb25zZS50YWdzLmZpbmQodGFnID0+IHRhZy5uYW1lID09PSAnUHJvZHVjdCBSZWxlYXNlIE5vdGVzJyk7XG4gICAgICAgICAgICB9KTtcbiAgICB9XG5cbiAgICAvKiogSGVscGVyIG1ldGhvZCB0byBnZXQgZWZmZWN0aXZlIHN1YnNjcmlwdGlvbiBJRCAqL1xuICAgIHByaXZhdGUgZ2V0RWZmZWN0aXZlU3Vic2NyaXB0aW9uSWQoKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuIEhlbHBlclNlcnZpY2UuZ2V0RWZmZWN0aXZlU3Vic2NyaXB0aW9uSWQoXG4gICAgICAgICAgICB0aGlzLnVzZXIsXG4gICAgICAgICAgICB0aGlzLnN1YnNjcmlwdGlvbklkLFxuICAgICAgICAgICAgdGhpcy5tYXN0ZXJTdWJzY3JpcHRpb25JZFxuICAgICAgICApO1xuICAgIH1cbn1cbiIsIjxwdy1yZXNvdXJjZS1oZWFkZXI+PC9wdy1yZXNvdXJjZS1oZWFkZXI+XG48cHctcmVzb3VyY2UtcmVsZWFzZS1ub3Rlcy10b3AtYmFubmVyPjwvcHctcmVzb3VyY2UtcmVsZWFzZS1ub3Rlcy10b3AtYmFubmVyPlxuXG48cHctcmVzb3VyY2Utbm90ZS1jYXJkIFtpc1JlbGVhc2VQcmVzc109XCJ0cnVlXCIgKm5nSWY9XCJibG9nUG9zdFRhZz8udGFnX2NhdGVnb3J5X2lkXCIgW3RhZ109XCJibG9nUG9zdFRhZ1wiIFtjYXRlZ29yeUlkXT1cImJsb2dQb3N0VGFnPy50YWdfY2F0ZWdvcnlfaWRcIiBbcmVsZWFzZUhlYWRlcl09XCJ0cnVlXCIgW3Jlc291cmNlVGl0bGVdPVwiYmxvZ1Bvc3RUYWc/LnRpdGxlXCIgW3Bvc3RTbGljZV09XCJ0cnVlXCI+PC9wdy1yZXNvdXJjZS1ub3RlLWNhcmQ+XG5cbjxwdy10cmlhbC00LWNvbnRhY3QtdXM+PC9wdy10cmlhbC00LWNvbnRhY3QtdXM+XG4iXX0=
@@ -31,7 +31,7 @@ export class ResourceVaultComponent extends BaseResourceComponent {
31
31
  getPosts(page, pageSize) {
32
32
  this.isLoaded = false;
33
33
  this.resourceService
34
- .getPublicPosts(this.subscriptionId ?? this.masterSubscriptionId, page, pageSize, '', this.categoryId)
34
+ .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', this.categoryId)
35
35
  .subscribe(response => {
36
36
  const sortedPosts = (response.posts ?? [])
37
37
  .filter(post => post.showcase === true)
@@ -47,7 +47,7 @@ export class ResourceVaultComponent extends BaseResourceComponent {
47
47
  this.editedTitle = this.resourceTitle;
48
48
  }
49
49
  saveEditedTitle() {
50
- HelperService.updateTagTitle(this.tag, this.editedTitle, this.tagService, this.subscriptionId ?? this.masterSubscriptionId, this.toast).subscribe(() => {
50
+ HelperService.updateTagTitle(this.tag, this.editedTitle, this.tagService, this.getEffectiveSubscriptionId(), this.toast).subscribe(() => {
51
51
  this.resourceTitle = this.editedTitle;
52
52
  this.isEditingTitle = false;
53
53
  });
@@ -69,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
69
69
  }], tag: [{
70
70
  type: Input
71
71
  }] } });
72
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-vault.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/resource-vault/resource-vault.component.ts","../../../../../../../../libs/resource-module/src/lib/public/components/resource-vault/resource-vault.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAEnE,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;;;;;;;;;;;;AAOxE,MAAM,OAAO,sBAAuB,SAAQ,qBAAqB;IAU7D,YACI,eAAgC,EAChC,UAAsB,EACtB,WAAwB,EACxB,QAAkB;QAElB,KAAK,CAAC,eAAe,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;QAfrD,qBAAgB,GAAG,KAAK,CAAC;QACzB,cAAS,GAAG,KAAK,CAAC;QAK3B,mBAAc,GAAG,KAAK,CAAC;IAUvB,CAAC;IAEQ,QAAQ;QACb,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACzB,CAAC;IAES,eAAe;QACrB,OAAO,OAAO,CAAC;IACnB,CAAC;IAEkB,QAAQ,CAAC,IAAY,EAAE,QAAgB;QACtD,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,eAAe;aACf,cAAc,CACX,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,oBAAoB,EAChD,IAAI,EACJ,QAAQ,EACR,EAAE,EACF,IAAI,CAAC,UAAU,CAClB;aACA,SAAS,CAAC,QAAQ,CAAC,EAAE;YAClB,MAAM,WAAW,GAAG,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE,CAAC;iBACrC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC;iBACtC,IAAI,CACD,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACL,IAAI,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE,CAC9E,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC7E,CAAC,CAAC;aACD,GAAG,CAAC,GAAG,EAAE;YACN,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACzB,CAAC,CAAC,CAAC;IACX,CAAC;IAED,eAAe;QACX,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC;IAC1C,CAAC;IAED,eAAe;QACX,aAAa,CAAC,cAAc,CACxB,IAAI,CAAC,GAAG,EACR,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,oBAAoB,EAChD,IAAI,CAAC,KAAK,CACb,CAAC,SAAS,CAAC,GAAG,EAAE;YACb,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC;YACtC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAChC,CAAC,CAAC,CAAC;IACP,CAAC;+GApEQ,sBAAsB;mGAAtB,sBAAsB,iOCbnC,y8GAiEA;;4FDpDa,sBAAsB;kBALlC,SAAS;+BACI,oBAAoB;8JAKrB,gBAAgB;sBAAxB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,GAAG;sBAAX,KAAK","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\n\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../resource.service';\nimport { BaseResourceComponent } from '../base/base-resource.component';\n\n@Component({\n    selector: 'pw-resource--vault',\n    templateUrl: './resource-vault.component.html',\n    styleUrls: ['../resources/resources-shared.component.scss']\n})\nexport class ResourceVaultComponent extends BaseResourceComponent implements OnInit {\n    @Input() showVaultSection = false;\n    @Input() postSlice = false;\n    @Input() categoryId;\n    @Input() resourceTitle;\n    @Input() tag;\n\n    isEditingTitle = false;\n    editedTitle: string;\n\n    constructor(\n        resourceService: ResourceService,\n        tagService: TagService,\n        authService: AuthService,\n        injector: Injector\n    ) {\n        super(resourceService, tagService, authService, injector);\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.getPosts(1, 10);\n    }\n\n    protected getResourceType(): string {\n        return 'Vault';\n    }\n\n    protected override getPosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(\n                this.subscriptionId ?? this.masterSubscriptionId,\n                page,\n                pageSize,\n                '',\n                this.categoryId\n            )\n            .subscribe(response => {\n                const sortedPosts = (response.posts ?? [])\n                    .filter(post => post.showcase === true)\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    );\n                this.posts = this.postSlice ? sortedPosts : [...sortedPosts].slice(0, 3);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    toggleEditTitle() {\n        this.isEditingTitle = true;\n        this.editedTitle = this.resourceTitle;\n    }\n\n    saveEditedTitle() {\n        HelperService.updateTagTitle(\n            this.tag,\n            this.editedTitle,\n            this.tagService,\n            this.subscriptionId ?? this.masterSubscriptionId,\n            this.toast\n        ).subscribe(() => {\n            this.resourceTitle = this.editedTitle;\n            this.isEditingTitle = false;\n        });\n    }\n}\n","<section class=\"msp-vault-section bg-white text-center py-5 extra-top-padding section-outer\">\n  <div class=\"container\">\n    <div *ngIf=\"showVaultSection\" class=\"d-flex justify-content-between align-items-center flex-wrap mb-5\">\n    <h2 class=\"section-heading d-flex align-items-center\" [ngClass]=\"{ 'w-50': isEditingTitle }\">\n      <ng-container *ngIf=\"!isEditingTitle; else editTitleBlock\">\n        <span *ngIf=\"resourceTitle; else fallback\" [innerHTML]=\"resourceTitle\"></span>\n        <ng-template #fallback>Whitepapers &amp; Tools</ng-template>\n        <i  *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleEditTitle()\" (keydown.enter)=\"toggleEditTitle()\" (keydown.space)=\"toggleEditTitle()\" title=\"Edit Title\"></i>\n      </ng-container>\n\n      <ng-template #editTitleBlock>\n        <input [(ngModel)]=\"editedTitle\" class=\"form-control d-inline w-auto me-2\" [ngClass]=\"{ 'w-100': isEditingTitle }\" />\n        <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle()\">Save</button>\n        <button class=\"btn btn-sm btn-secondary\" (click)=\"isEditingTitle = false\">Cancel</button>\n      </ng-template>\n    </h2>\n\n      <a class=\"view-all\" routerLink=\"/resources/white-papers\">VIEW ALL ></a>\n    </div>\n    <div class=\"w-100 text-center mt-3\" *ngIf=\"!isLoaded\">\n      <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n    </div>\n    <div *ngIf=\"posts.length === 0 && isLoaded\">\n      <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n    </div>\n    <div class=\"d-flex mt-2 flex-wrap justify-content-center gap-4 video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n        <div class=\"resource-blog-card text-center p-4\" *ngFor=\"let post of posts\">\n          <pw-resource-edit-card\n*ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          [id]=\"post.id\"\n          [resourceData]=\"post\"\n          (updated)=\"getPosts(1, 100)\"></pw-resource-edit-card>\n          <p class=\"mb-4\" [innerHTML]=\"post.title\"></p>\n                <a\n                [href]=\"post.external_url || ('/resources/view/' + post?.slug)\"\n                target=\"_blank\"\n                rel=\"noopener noreferrer\"\n                aria-label=\"Navigate to resource\"\n              >\n                <img\n                  [src]=\"post.picture.url\"\n                  class=\"img-fluid my-3 mt-auto\"\n                  alt=\"Webinar\"\n                />\n              </a>\n               <a *ngIf=\"post?.external_url; else internalLink\"\n               class=\"resource-btn mt-3\"\n               aria-label=\"Navigate to external url\"\n               [href]=\"post.external_url\"\n               target=\"_blank\"\n               rel=\"noopener noreferrer\">\n               <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n               <span class=\"arrow\">→</span>\n             </a>\n\n           <ng-template #internalLink>\n             <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [href]=\"'/resources/view/' + post?.slug\" target=\"_blank\">\n               <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n               <span class=\"arrow\">→</span>\n             </a>\n           </ng-template>\n        </div>\n    </div>\n  </div>\n</section>\n"]}
72
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-vault.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/resource-vault/resource-vault.component.ts","../../../../../../../../libs/resource-module/src/lib/public/components/resource-vault/resource-vault.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAEnE,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;;;;;;;;;;;;AAOxE,MAAM,OAAO,sBAAuB,SAAQ,qBAAqB;IAU7D,YACI,eAAgC,EAChC,UAAsB,EACtB,WAAwB,EACxB,QAAkB;QAElB,KAAK,CAAC,eAAe,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;QAfrD,qBAAgB,GAAG,KAAK,CAAC;QACzB,cAAS,GAAG,KAAK,CAAC;QAK3B,mBAAc,GAAG,KAAK,CAAC;IAUvB,CAAC;IAEQ,QAAQ;QACb,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACzB,CAAC;IAES,eAAe;QACrB,OAAO,OAAO,CAAC;IACnB,CAAC;IAEkB,QAAQ,CAAC,IAAY,EAAE,QAAgB;QACtD,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,eAAe;aACf,cAAc,CAAC,IAAI,CAAC,0BAA0B,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,CAAC;aACtF,SAAS,CAAC,QAAQ,CAAC,EAAE;YAClB,MAAM,WAAW,GAAG,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE,CAAC;iBACrC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC;iBACtC,IAAI,CACD,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACL,IAAI,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE,CAC9E,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC7E,CAAC,CAAC;aACD,GAAG,CAAC,GAAG,EAAE;YACN,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACzB,CAAC,CAAC,CAAC;IACX,CAAC;IAED,eAAe;QACX,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC;IAC1C,CAAC;IAED,eAAe;QACX,aAAa,CAAC,cAAc,CACxB,IAAI,CAAC,GAAG,EACR,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,0BAA0B,EAAE,EACjC,IAAI,CAAC,KAAK,CACb,CAAC,SAAS,CAAC,GAAG,EAAE;YACb,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC;YACtC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAChC,CAAC,CAAC,CAAC;IACP,CAAC;+GA9DQ,sBAAsB;mGAAtB,sBAAsB,iOCbnC,y8GAiEA;;4FDpDa,sBAAsB;kBALlC,SAAS;+BACI,oBAAoB;8JAKrB,gBAAgB;sBAAxB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,GAAG;sBAAX,KAAK","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\n\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../resource.service';\nimport { BaseResourceComponent } from '../base/base-resource.component';\n\n@Component({\n    selector: 'pw-resource--vault',\n    templateUrl: './resource-vault.component.html',\n    styleUrls: ['../resources/resources-shared.component.scss']\n})\nexport class ResourceVaultComponent extends BaseResourceComponent implements OnInit {\n    @Input() showVaultSection = false;\n    @Input() postSlice = false;\n    @Input() categoryId;\n    @Input() resourceTitle;\n    @Input() tag;\n\n    isEditingTitle = false;\n    editedTitle: string;\n\n    constructor(\n        resourceService: ResourceService,\n        tagService: TagService,\n        authService: AuthService,\n        injector: Injector\n    ) {\n        super(resourceService, tagService, authService, injector);\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.getPosts(1, 10);\n    }\n\n    protected getResourceType(): string {\n        return 'Vault';\n    }\n\n    protected override getPosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', this.categoryId)\n            .subscribe(response => {\n                const sortedPosts = (response.posts ?? [])\n                    .filter(post => post.showcase === true)\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    );\n                this.posts = this.postSlice ? sortedPosts : [...sortedPosts].slice(0, 3);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    toggleEditTitle() {\n        this.isEditingTitle = true;\n        this.editedTitle = this.resourceTitle;\n    }\n\n    saveEditedTitle() {\n        HelperService.updateTagTitle(\n            this.tag,\n            this.editedTitle,\n            this.tagService,\n            this.getEffectiveSubscriptionId(),\n            this.toast\n        ).subscribe(() => {\n            this.resourceTitle = this.editedTitle;\n            this.isEditingTitle = false;\n        });\n    }\n}\n","<section class=\"msp-vault-section bg-white text-center py-5 extra-top-padding section-outer\">\n  <div class=\"container\">\n    <div *ngIf=\"showVaultSection\" class=\"d-flex justify-content-between align-items-center flex-wrap mb-5\">\n    <h2 class=\"section-heading d-flex align-items-center\" [ngClass]=\"{ 'w-50': isEditingTitle }\">\n      <ng-container *ngIf=\"!isEditingTitle; else editTitleBlock\">\n        <span *ngIf=\"resourceTitle; else fallback\" [innerHTML]=\"resourceTitle\"></span>\n        <ng-template #fallback>Whitepapers &amp; Tools</ng-template>\n        <i  *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleEditTitle()\" (keydown.enter)=\"toggleEditTitle()\" (keydown.space)=\"toggleEditTitle()\" title=\"Edit Title\"></i>\n      </ng-container>\n\n      <ng-template #editTitleBlock>\n        <input [(ngModel)]=\"editedTitle\" class=\"form-control d-inline w-auto me-2\" [ngClass]=\"{ 'w-100': isEditingTitle }\" />\n        <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle()\">Save</button>\n        <button class=\"btn btn-sm btn-secondary\" (click)=\"isEditingTitle = false\">Cancel</button>\n      </ng-template>\n    </h2>\n\n      <a class=\"view-all\" routerLink=\"/resources/white-papers\">VIEW ALL ></a>\n    </div>\n    <div class=\"w-100 text-center mt-3\" *ngIf=\"!isLoaded\">\n      <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n    </div>\n    <div *ngIf=\"posts.length === 0 && isLoaded\">\n      <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n    </div>\n    <div class=\"d-flex mt-2 flex-wrap justify-content-center gap-4 video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n        <div class=\"resource-blog-card text-center p-4\" *ngFor=\"let post of posts\">\n          <pw-resource-edit-card\n*ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          [id]=\"post.id\"\n          [resourceData]=\"post\"\n          (updated)=\"getPosts(1, 100)\"></pw-resource-edit-card>\n          <p class=\"mb-4\" [innerHTML]=\"post.title\"></p>\n                <a\n                [href]=\"post.external_url || ('/resources/view/' + post?.slug)\"\n                target=\"_blank\"\n                rel=\"noopener noreferrer\"\n                aria-label=\"Navigate to resource\"\n              >\n                <img\n                  [src]=\"post.picture.url\"\n                  class=\"img-fluid my-3 mt-auto\"\n                  alt=\"Webinar\"\n                />\n              </a>\n               <a *ngIf=\"post?.external_url; else internalLink\"\n               class=\"resource-btn mt-3\"\n               aria-label=\"Navigate to external url\"\n               [href]=\"post.external_url\"\n               target=\"_blank\"\n               rel=\"noopener noreferrer\">\n               <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n               <span class=\"arrow\">→</span>\n             </a>\n\n           <ng-template #internalLink>\n             <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [href]=\"'/resources/view/' + post?.slug\" target=\"_blank\">\n               <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n               <span class=\"arrow\">→</span>\n             </a>\n           </ng-template>\n        </div>\n    </div>\n  </div>\n</section>\n"]}
@@ -41,10 +41,13 @@ export class ResourceVideoCardComponent extends AppBaseComponent {
41
41
  });
42
42
  this.userService.getUserInfo().subscribe(data => {
43
43
  this.user = data;
44
+ this.getPosts(1, 10);
44
45
  });
45
46
  }
47
+ else {
48
+ this.getPosts(1, 10);
49
+ }
46
50
  });
47
- this.getPosts(1, 10);
48
51
  }
49
52
  loadVideo(post) {
50
53
  if (!post.external_url)
@@ -59,7 +62,7 @@ export class ResourceVideoCardComponent extends AppBaseComponent {
59
62
  getPosts(page, pageSize) {
60
63
  this.isLoaded = false;
61
64
  this.resourceService
62
- .getPublicPosts(this.subscriptionId || this.masterSubscriptionId, page, pageSize, '', this.categoryId)
65
+ .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', this.categoryId)
63
66
  .subscribe(response => {
64
67
  const sortedPosts = (response.posts ?? [])
65
68
  .filter(post => post.showcase === true)
@@ -84,11 +87,15 @@ export class ResourceVideoCardComponent extends AppBaseComponent {
84
87
  this.editedTitle = this.resourceTitle;
85
88
  }
86
89
  saveEditedTitle() {
87
- HelperService.updateTagTitle(this.tag, this.editedTitle, this.tagService, this.subscriptionId ?? this.masterSubscriptionId, this.toast).subscribe(() => {
90
+ HelperService.updateTagTitle(this.tag, this.editedTitle, this.tagService, this.getEffectiveSubscriptionId(), this.toast).subscribe(() => {
88
91
  this.resourceTitle = this.editedTitle;
89
92
  this.isEditingTitle = false;
90
93
  });
91
94
  }
95
+ /** Helper method to get effective subscription ID */
96
+ getEffectiveSubscriptionId() {
97
+ return HelperService.getEffectiveSubscriptionId(this.user, this.subscriptionId, this.masterSubscriptionId);
98
+ }
92
99
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceVideoCardComponent, deps: [{ token: i1.DomSanitizer }, { token: i2.ResourceService }, { token: i3.AuthService }, { token: i3.TagService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
93
100
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ResourceVideoCardComponent, selector: "pw-resource-video-card", inputs: { showVideoSection: "showVideoSection", categoryId: "categoryId", tag: "tag", postSlice: "postSlice", resourceTitle: "resourceTitle" }, usesInheritance: true, ngImport: i0, template: "<section class=\"msp-vault-section bg-white text-center py-5 extra-top-padding section-outer\">\n <div class=\"container\">\n <div *ngIf=\"showVideoSection\" class=\"d-flex justify-content-between align-items-center flex-wrap\">\n <h2 class=\"section-heading d-flex align-items-center\" [ngClass]=\"{ 'w-50': isEditingTitle }\">\n <ng-container *ngIf=\"!isEditingTitle; else editTitleBlock\">\n <span *ngIf=\"resourceTitle; else fallback\" [innerHTML]=\"resourceTitle\"></span>\n <ng-template #fallback>On-Demand Videos</ng-template>\n <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleTagEditTitle()\" (keydown.enter)=\"toggleTagEditTitle()\" (keydown.space)=\"toggleTagEditTitle()\" title=\"Edit Title\"></i>\n </ng-container>\n\n <ng-template #editTitleBlock>\n <input [(ngModel)]=\"editedTitle\" class=\"form-control d-inline w-auto me-2\" [ngClass]=\"{ 'w-100': isEditingTitle }\" />\n <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle()\">Save</button>\n <button class=\"btn btn-sm btn-secondary\" (click)=\"isEditingTitle = false\">Cancel</button>\n </ng-template>\n </h2>\n <a class=\"view-all\" routerLink=\"/resources/videos\">VIEW ALL ></a>\n </div>\n <div class=\"w-100 text-center mt-3\" *ngIf=\"!isLoaded\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n <div *ngIf=\"posts.length === 0 && isLoaded\">\n <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n </div>\n <div class=\"row mt-5 d-flex flex-wrap justify-content-center video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n <div class=\"resource-blog-card\" *ngFor=\"let post of posts\">\n <pw-resource-edit-card\n *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n [id]=\"post.id\"\n [resourceData]=\"post\"\n (updated)=\"getPosts(1, 10)\"\n ></pw-resource-edit-card>\n <p [innerHTML]=\"post.title\" class=\"mb-5\"></p>\n <a [href]=\" post.external_url\" target=\"_blank\">\n <img\n [src]=\"post.picture?.url\"\n class=\"img-fluid mb-3\"\n [alt]=\"post.title\" />\n </a>\n\n <a class=\"resource-btn mt-3\" [href]=\" post.external_url\" target=\"_blank\">\n <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Watch now' }}</span>\n <span class=\"arrow\">\u2192</span>\n </a>\n </div>\n </div>\n </div>\n\n</section>\n", styles: [".bold{font-weight:700}.nce-heading{margin-bottom:2rem}.nce-note{margin-top:1rem;font-size:.85rem;color:#555}.nce-divider{border:0;height:40px;width:100%;background:linear-gradient(to bottom,#0000,#00000026);margin:0}.press-release-icon{height:auto!important;margin:0 11px 1.9rem;display:block;align-self:center;width:auto!important;aspect-ratio:0!important;object-fit:cover;margin-top:auto;margin-right:0!important}.msp-vault-section{padding:60px 0;background:#fff;padding-bottom:9rem!important;padding-top:7rem!important;box-shadow:0 4px 32px -14px #40576d4d!important}.msp-vault-section .vault-heading{font-size:3rem;font-weight:300}.msp-vault-section .explore-link{color:#000;font-weight:400;text-decoration:none;font-size:1.5rem}.msp-vault-section .resource-blog-card{display:flex;flex-direction:column;justify-content:space-between;background-color:#fff;border-radius:30px;box-shadow:0 20px 40px #00000014;padding:25px;text-align:center;width:338px;height:auto!important}.msp-vault-section .resource-blog-card h5{font-size:1.5rem;font-weight:400;margin-bottom:.5rem;color:var(--text-color, black)}.msp-vault-section .resource-blog-card p{font-size:1.5rem;color:var(--text-color, black);line-height:2rem}.msp-vault-section .resource-blog-card img{width:100%;border-radius:10px;aspect-ratio:1/1;object-fit:cover;margin-top:auto;margin-right:0!important;max-width:250px!important;align-self:center!important}.msp-vault-section .resource-blog-card iframe{height:210px;border-radius:10px;object-fit:cover;margin-right:0!important;max-width:280px!important}.msp-vault-section .resource-blog-card .resource-btn{background-color:var(--text-color, black);color:#fff;margin-top:auto;padding:10px 24px;border-radius:24px;font-size:1.5rem;font-weight:500;width:100%;max-width:240px;cursor:pointer;transition:background .3s ease;display:flex;justify-content:space-between;align-self:center;align-items:center;text-align:left;text-decoration:none;border:1px solid;box-shadow:none!important;border-color:var(--text-color, black)}.msp-vault-section .resource-blog-card .resource-btn:hover{background:#fff;color:var(--text-color, black)!important}.msp-vault-section .vault-description{text-align:left;max-width:657px;color:#182527;line-height:2.3rem!important;font-size:1.65rem}@media (width <= 1200px){.msp-vault-section .vault-heading{font-size:3.5rem}.msp-vault-section .vault-description{margin-top:1.35rem}.msp-vault-section .resource-btn{margin-left:0!important}}.video-row{gap:5.5rem!important;margin-top:3rem!important}@media (width >= 991px){section.bg-white.text-center.extra-top-padding{position:relative;overflow:hidden}section.bg-white.text-center.extra-top-padding .banner-header{margin-bottom:4rem!important}}.vault-header{text-align:left}@media (width >= 768px) and (width <= 1200px){.container{padding:0 6rem!important}}@media (width <= 768px){.video-row{gap:3rem!important}}@media (width <= 768px){.vault-header{text-align:center!important}.vault-heading{font-size:3rem!important}}@media (width <= 1200px){.container{padding:7rem 3rem 1rem!important}}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i7.ProgressSpinner, selector: "p-progressSpinner", inputs: ["styleClass", "style", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }, { kind: "component", type: i8.NoDataComponent, selector: "pw-no-data", inputs: ["message", "description", "withImage"] }, { kind: "directive", type: i9.LazyImgDirective, selector: "img" }, { kind: "component", type: i10.ResourceEditCardComponent, selector: "pw-resource-edit-card", inputs: ["id", "resourceData"], outputs: ["updated"] }, { kind: "pipe", type: i11.TranslocoPipe, name: "transloco" }] }); }
94
101
  }
@@ -106,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
106
113
  }], resourceTitle: [{
107
114
  type: Input
108
115
  }] } });
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-video-cards.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/resource-module/src/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.ts","../../../../../../../../../libs/resource-module/src/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../../resource.service';\n\n@Component({\n    selector: 'pw-resource-video-card',\n    templateUrl: './resource-video-cards.component.html',\n    styleUrls: ['../../resources/resources-shared.component.scss']\n})\nexport class ResourceVideoCardComponent extends AppBaseComponent implements OnInit {\n    @Input() showVideoSection = false;\n    @Input() categoryId!: string;\n    @Input() tag;\n    @Input() postSlice = false;\n    @Input() resourceTitle!: string;\n\n    subscriptionId: number;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n\n    posts: Resource[] = [];\n\n    isLoaded = false;\n\n    videoStates: { [slug: string]: { loaded: boolean; url: SafeResourceUrl } } = {};\n\n    userLoggedIn: boolean;\n\n    isEditingTitle = false;\n    editedTitle: string;\n    user: User;\n\n    constructor(\n        private readonly sanitizer: DomSanitizer,\n        private readonly resourceService: ResourceService,\n        private readonly authService: AuthService,\n        private readonly tagService: TagService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\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        this.getPosts(1, 10);\n    }\n\n    loadVideo(post): void {\n        if (!post.external_url) return;\n\n        const slug = post.slug;\n        let externalUrl = post.external_url;\n\n        // Append autoplay only when clicked\n        externalUrl += externalUrl.includes('?') ? '&autoplay=1' : '?autoplay=1';\n        // baseUrl is a trusted internal source (e.g. YouTube embed URL)\n        this.videoStates[slug].url = this.sanitizer.bypassSecurityTrustResourceUrl(externalUrl); //NOSONAR\n    }\n\n    getPosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(\n                this.subscriptionId || this.masterSubscriptionId,\n                page,\n                pageSize,\n                '',\n                this.categoryId\n            )\n            .subscribe(response => {\n                const sortedPosts = (response.posts ?? [])\n                    .filter(post => post.showcase === true)\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    );\n                this.posts = this.postSlice ? sortedPosts : [...sortedPosts].slice(0, 3);\n                this.posts.forEach(post => {\n                    if (post.external_url) {\n                        this.videoStates[post.slug] = {\n                            loaded: true,\n                            // baseUrl is a trusted internal source (e.g. YouTube embed URL)\n                            url: this.sanitizer.bypassSecurityTrustResourceUrl(post.external_url) //NOSONAR\n                        };\n                    }\n                });\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    toggleTagEditTitle() {\n        this.isEditingTitle = true;\n        this.editedTitle = this.resourceTitle;\n    }\n\n    saveEditedTitle() {\n        HelperService.updateTagTitle(\n            this.tag,\n            this.editedTitle,\n            this.tagService,\n            this.subscriptionId ?? this.masterSubscriptionId,\n            this.toast\n        ).subscribe(() => {\n            this.resourceTitle = this.editedTitle;\n            this.isEditingTitle = false;\n        });\n    }\n}\n","<section class=\"msp-vault-section bg-white text-center py-5 extra-top-padding section-outer\">\n  <div class=\"container\">\n    <div *ngIf=\"showVideoSection\" class=\"d-flex justify-content-between align-items-center flex-wrap\">\n      <h2 class=\"section-heading d-flex align-items-center\" [ngClass]=\"{ 'w-50': isEditingTitle }\">\n        <ng-container *ngIf=\"!isEditingTitle; else editTitleBlock\">\n          <span *ngIf=\"resourceTitle; else fallback\" [innerHTML]=\"resourceTitle\"></span>\n          <ng-template #fallback>On-Demand Videos</ng-template>\n          <i  *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleTagEditTitle()\" (keydown.enter)=\"toggleTagEditTitle()\" (keydown.space)=\"toggleTagEditTitle()\" title=\"Edit Title\"></i>\n        </ng-container>\n\n        <ng-template #editTitleBlock>\n          <input [(ngModel)]=\"editedTitle\" class=\"form-control d-inline w-auto me-2\" [ngClass]=\"{ 'w-100': isEditingTitle }\" />\n          <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle()\">Save</button>\n          <button class=\"btn btn-sm btn-secondary\" (click)=\"isEditingTitle = false\">Cancel</button>\n        </ng-template>\n      </h2>\n      <a class=\"view-all\" routerLink=\"/resources/videos\">VIEW ALL ></a>\n    </div>\n    <div class=\"w-100 text-center mt-3\" *ngIf=\"!isLoaded\">\n      <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n    </div>\n    <div *ngIf=\"posts.length === 0 && isLoaded\">\n      <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n    </div>\n    <div class=\"row mt-5 d-flex flex-wrap justify-content-center video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n      <div class=\"resource-blog-card\" *ngFor=\"let post of posts\">\n        <pw-resource-edit-card\n          *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n        [id]=\"post.id\"\n        [resourceData]=\"post\"\n        (updated)=\"getPosts(1, 10)\"\n        ></pw-resource-edit-card>\n        <p [innerHTML]=\"post.title\" class=\"mb-5\"></p>\n        <a [href]=\" post.external_url\"  target=\"_blank\">\n          <img\n          [src]=\"post.picture?.url\"\n          class=\"img-fluid mb-3\"\n          [alt]=\"post.title\" />\n        </a>\n\n        <a class=\"resource-btn mt-3\" [href]=\" post.external_url\" target=\"_blank\">\n          <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Watch now'  }}</span>\n          <span class=\"arrow\">→</span>\n        </a>\n      </div>\n    </div>\n  </div>\n\n</section>\n"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-video-cards.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/resource-module/src/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.ts","../../../../../../../../../libs/resource-module/src/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../../resource.service';\n\n@Component({\n    selector: 'pw-resource-video-card',\n    templateUrl: './resource-video-cards.component.html',\n    styleUrls: ['../../resources/resources-shared.component.scss']\n})\nexport class ResourceVideoCardComponent extends AppBaseComponent implements OnInit {\n    @Input() showVideoSection = false;\n    @Input() categoryId!: string;\n    @Input() tag;\n    @Input() postSlice = false;\n    @Input() resourceTitle!: string;\n\n    subscriptionId: number;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n\n    posts: Resource[] = [];\n\n    isLoaded = false;\n\n    videoStates: { [slug: string]: { loaded: boolean; url: SafeResourceUrl } } = {};\n\n    userLoggedIn: boolean;\n\n    isEditingTitle = false;\n    editedTitle: string;\n    user: User;\n    isMasterSubscription;\n\n    constructor(\n        private readonly sanitizer: DomSanitizer,\n        private readonly resourceService: ResourceService,\n        private readonly authService: AuthService,\n        private readonly tagService: TagService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\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                    this.getPosts(1, 10);\n                });\n            } else {\n                this.getPosts(1, 10);\n            }\n        });\n    }\n\n    loadVideo(post): void {\n        if (!post.external_url) return;\n\n        const slug = post.slug;\n        let externalUrl = post.external_url;\n\n        // Append autoplay only when clicked\n        externalUrl += externalUrl.includes('?') ? '&autoplay=1' : '?autoplay=1';\n        // baseUrl is a trusted internal source (e.g. YouTube embed URL)\n        this.videoStates[slug].url = this.sanitizer.bypassSecurityTrustResourceUrl(externalUrl); //NOSONAR\n    }\n\n    getPosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', this.categoryId)\n            .subscribe(response => {\n                const sortedPosts = (response.posts ?? [])\n                    .filter(post => post.showcase === true)\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    );\n                this.posts = this.postSlice ? sortedPosts : [...sortedPosts].slice(0, 3);\n                this.posts.forEach(post => {\n                    if (post.external_url) {\n                        this.videoStates[post.slug] = {\n                            loaded: true,\n                            // baseUrl is a trusted internal source (e.g. YouTube embed URL)\n                            url: this.sanitizer.bypassSecurityTrustResourceUrl(post.external_url) //NOSONAR\n                        };\n                    }\n                });\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    toggleTagEditTitle() {\n        this.isEditingTitle = true;\n        this.editedTitle = this.resourceTitle;\n    }\n\n    saveEditedTitle() {\n        HelperService.updateTagTitle(\n            this.tag,\n            this.editedTitle,\n            this.tagService,\n            this.getEffectiveSubscriptionId(),\n            this.toast\n        ).subscribe(() => {\n            this.resourceTitle = this.editedTitle;\n            this.isEditingTitle = false;\n        });\n    }\n\n    /** Helper method to get effective subscription ID */\n    private getEffectiveSubscriptionId(): number {\n        return HelperService.getEffectiveSubscriptionId(\n            this.user,\n            this.subscriptionId,\n            this.masterSubscriptionId\n        );\n    }\n}\n","<section class=\"msp-vault-section bg-white text-center py-5 extra-top-padding section-outer\">\n  <div class=\"container\">\n    <div *ngIf=\"showVideoSection\" class=\"d-flex justify-content-between align-items-center flex-wrap\">\n      <h2 class=\"section-heading d-flex align-items-center\" [ngClass]=\"{ 'w-50': isEditingTitle }\">\n        <ng-container *ngIf=\"!isEditingTitle; else editTitleBlock\">\n          <span *ngIf=\"resourceTitle; else fallback\" [innerHTML]=\"resourceTitle\"></span>\n          <ng-template #fallback>On-Demand Videos</ng-template>\n          <i  *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleTagEditTitle()\" (keydown.enter)=\"toggleTagEditTitle()\" (keydown.space)=\"toggleTagEditTitle()\" title=\"Edit Title\"></i>\n        </ng-container>\n\n        <ng-template #editTitleBlock>\n          <input [(ngModel)]=\"editedTitle\" class=\"form-control d-inline w-auto me-2\" [ngClass]=\"{ 'w-100': isEditingTitle }\" />\n          <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle()\">Save</button>\n          <button class=\"btn btn-sm btn-secondary\" (click)=\"isEditingTitle = false\">Cancel</button>\n        </ng-template>\n      </h2>\n      <a class=\"view-all\" routerLink=\"/resources/videos\">VIEW ALL ></a>\n    </div>\n    <div class=\"w-100 text-center mt-3\" *ngIf=\"!isLoaded\">\n      <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n    </div>\n    <div *ngIf=\"posts.length === 0 && isLoaded\">\n      <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n    </div>\n    <div class=\"row mt-5 d-flex flex-wrap justify-content-center video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n      <div class=\"resource-blog-card\" *ngFor=\"let post of posts\">\n        <pw-resource-edit-card\n          *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n        [id]=\"post.id\"\n        [resourceData]=\"post\"\n        (updated)=\"getPosts(1, 10)\"\n        ></pw-resource-edit-card>\n        <p [innerHTML]=\"post.title\" class=\"mb-5\"></p>\n        <a [href]=\" post.external_url\"  target=\"_blank\">\n          <img\n          [src]=\"post.picture?.url\"\n          class=\"img-fluid mb-3\"\n          [alt]=\"post.title\" />\n        </a>\n\n        <a class=\"resource-btn mt-3\" [href]=\" post.external_url\" target=\"_blank\">\n          <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Watch now'  }}</span>\n          <span class=\"arrow\">→</span>\n        </a>\n      </div>\n    </div>\n  </div>\n\n</section>\n"]}
@@ -1,6 +1,7 @@
1
1
  import { Component, Injector, Input } from '@angular/core';
2
2
  import { AppBaseComponent } from '@posiwise/app-base-component';
3
3
  import { AuthService, TagService } from '@posiwise/common-services';
4
+ import { HelperService } from '@posiwise/helper-service';
4
5
  import { ResourceService } from '../../../../resource.service';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "../../../../resource.service";
@@ -33,14 +34,17 @@ export class ReplayEventCardComponent extends AppBaseComponent {
33
34
  });
34
35
  this.userService.getUserInfo().subscribe(data => {
35
36
  this.user = data;
37
+ this.getPostTags();
36
38
  });
37
39
  }
40
+ else {
41
+ this.getPostTags();
42
+ }
38
43
  });
39
- this.getPostTags();
40
44
  }
41
45
  getPostTags() {
42
46
  this.tagService
43
- .getTagsByType('post_categories', {}, this.subscriptionId ?? this.masterSubscriptionId)
47
+ .getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())
44
48
  .subscribe(response => {
45
49
  this.blogPostTag = response.tags.find(tag => tag.name === 'Events');
46
50
  if (this.blogPostTag?.tag_category_id) {
@@ -54,7 +58,7 @@ export class ReplayEventCardComponent extends AppBaseComponent {
54
58
  getPosts(page, pageSize) {
55
59
  this.isLoaded = false;
56
60
  this.resourceService
57
- .getPublicPosts(this.subscriptionId ?? this.masterSubscriptionId, page, pageSize, '', this.blogPostTag?.tag_category_id)
61
+ .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', this.blogPostTag?.tag_category_id)
58
62
  .subscribe(response => {
59
63
  const now = new Date().getTime();
60
64
  const sortedPosts = (response.posts ?? [])
@@ -66,6 +70,10 @@ export class ReplayEventCardComponent extends AppBaseComponent {
66
70
  this.isLoaded = true;
67
71
  });
68
72
  }
73
+ /** Helper method to get effective subscription ID */
74
+ getEffectiveSubscriptionId() {
75
+ return HelperService.getEffectiveSubscriptionId(this.user, this.subscriptionId, this.masterSubscriptionId);
76
+ }
69
77
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ReplayEventCardComponent, deps: [{ token: i1.ResourceService }, { token: i2.AuthService }, { token: i2.TagService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
70
78
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ReplayEventCardComponent, selector: "pw-replay-event-card", inputs: { showEventContent: "showEventContent", categoryId: "categoryId", resourceTitle: "resourceTitle" }, usesInheritance: true, ngImport: i0, template: "<section class=\"msp-vault-section bg-white text-center py-5 extra-top-padding section-outer\">\n <div class=\"container\">\n <div class=\"d-md-flex justify-content-between align-items-start\">\n <div class=\"vault-header\">\n <h2 class=\"vault-heading\" *ngIf=\"resourceTitle; else fallback\">{{resourceTitle}} Replays</h2>\n <ng-template #fallback><h2 class=\"vault-heading\">Events &amp; Webinars Replays</h2></ng-template>\n </div>\n </div>\n\n <div class=\"w-100 text-center mt-3\" *ngIf=\"!isLoaded\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n <div *ngIf=\"posts.length === 0 && isLoaded\">\n <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n </div>\n\n <div class=\"row mt-5 d-flex flex-wrap justify-content-center gap-4 video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n <div class=\"resource-blog-card vault-card text-center p-4\" *ngFor=\"let post of posts\">\n <pw-resource-edit-card\n *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n [id]=\"post.id\"\n [resourceData]=\"post\"\n (updated)=\"getPosts(1, 100)\"></pw-resource-edit-card>\n <h5 class=\"badge-title fw-bold\">REPLAY:</h5>\n\n <p class=\"event-title mb-4\" [innerHtml]=\"post?.title\"></p>\n <img\n [src]=\"post.picture.url\"\n class=\"img-fluid my-3 mt-auto\"\n alt=\"Webinar\" />\n <a *ngIf=\"post?.external_url; else internalLink\"\n class=\"resource-btn mt-3\"\n [href]=\"post.external_url\"\n aria-label=\"Navigate to external url\"\n target=\"_blank\"\n rel=\"noopener noreferrer\">\n <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now' }}</span>\n <span class=\"arrow\">\u2192</span>\n </a>\n\n <ng-template #internalLink>\n <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now' }}</span>\n <span class=\"arrow\">\u2192</span>\n </a>\n </ng-template>\n </div>\n </div>\n </div>\n</section>\n", styles: [".bold{font-weight:700}.nce-heading{margin-bottom:2rem}.nce-note{margin-top:1rem;font-size:.85rem;color:#555}.nce-divider{border:0;height:40px;width:100%;background:linear-gradient(to bottom,#0000,#00000026);margin:0}.press-release-icon{height:auto!important;margin:0 11px 1.9rem;display:block;align-self:center;width:auto!important;aspect-ratio:0!important;object-fit:cover;margin-top:auto;margin-right:0!important}.msp-vault-section{padding:60px 0;background:#fff;padding-bottom:9rem!important;padding-top:7rem!important;box-shadow:0 4px 32px -14px #40576d4d!important}.msp-vault-section .vault-heading{font-size:3rem;font-weight:300}.msp-vault-section .explore-link{color:#000;font-weight:400;text-decoration:none;font-size:1.5rem}.msp-vault-section .resource-blog-card{display:flex;flex-direction:column;justify-content:space-between;background-color:#fff;border-radius:30px;box-shadow:0 20px 40px #00000014;padding:25px;text-align:center;width:338px;height:auto!important}.msp-vault-section .resource-blog-card h5{font-size:1.5rem;font-weight:400;margin-bottom:.5rem;color:var(--text-color, black)}.msp-vault-section .resource-blog-card p{font-size:1.5rem;color:var(--text-color, black);line-height:2rem}.msp-vault-section .resource-blog-card img{width:100%;border-radius:10px;aspect-ratio:1/1;object-fit:cover;margin-top:auto;margin-right:0!important;max-width:250px!important;align-self:center!important}.msp-vault-section .resource-blog-card iframe{height:210px;border-radius:10px;object-fit:cover;margin-right:0!important;max-width:280px!important}.msp-vault-section .resource-blog-card .resource-btn{background-color:var(--text-color, black);color:#fff;margin-top:auto;padding:10px 24px;border-radius:24px;font-size:1.5rem;font-weight:500;width:100%;max-width:240px;cursor:pointer;transition:background .3s ease;display:flex;justify-content:space-between;align-self:center;align-items:center;text-align:left;text-decoration:none;border:1px solid;box-shadow:none!important;border-color:var(--text-color, black)}.msp-vault-section .resource-blog-card .resource-btn:hover{background:#fff;color:var(--text-color, black)!important}.msp-vault-section .vault-description{text-align:left;max-width:657px;color:#182527;line-height:2.3rem!important;font-size:1.65rem}@media (width <= 1200px){.msp-vault-section .vault-heading{font-size:3.5rem}.msp-vault-section .vault-description{margin-top:1.35rem}.msp-vault-section .resource-btn{margin-left:0!important}}.video-row{gap:5.5rem!important;margin-top:3rem!important}@media (width >= 991px){section.bg-white.text-center.extra-top-padding{position:relative;overflow:hidden}section.bg-white.text-center.extra-top-padding .banner-header{margin-bottom:4rem!important}}.vault-header{text-align:left}@media (width >= 768px) and (width <= 1200px){.container{padding:0 6rem!important}}@media (width <= 768px){.video-row{gap:3rem!important}}@media (width <= 768px){.vault-header{text-align:center!important}.vault-heading{font-size:3rem!important}}@media (width <= 1200px){.container{padding:7rem 3rem 1rem!important}}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i5.ProgressSpinner, selector: "p-progressSpinner", inputs: ["styleClass", "style", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }, { kind: "component", type: i6.NoDataComponent, selector: "pw-no-data", inputs: ["message", "description", "withImage"] }, { kind: "directive", type: i7.LazyImgDirective, selector: "img" }, { kind: "component", type: i8.ResourceEditCardComponent, selector: "pw-resource-edit-card", inputs: ["id", "resourceData"], outputs: ["updated"] }, { kind: "pipe", type: i9.TranslocoPipe, name: "transloco" }] }); }
71
79
  }
@@ -79,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
79
87
  }], resourceTitle: [{
80
88
  type: Input
81
89
  }] } });
82
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"replay-event-cards.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/resource-module/src/lib/public/components/resource-webinars/replay-event-cards/replay-event-cards.component.ts","../../../../../../../../../libs/resource-module/src/lib/public/components/resource-webinars/replay-event-cards/replay-event-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\n\nimport { ResourceService } from '../../../../resource.service';\n\n@Component({\n    selector: 'pw-replay-event-card',\n    templateUrl: './replay-event-cards.component.html',\n    styleUrls: ['../../resources/resources-shared.component.scss']\n})\nexport class ReplayEventCardComponent extends AppBaseComponent implements OnInit {\n    @Input() showEventContent = false;\n    @Input() categoryId!: string;\n    @Input() resourceTitle!: string;\n    userLoggedIn: boolean;\n    subscriptionId;\n\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n\n    posts: Resource[] = [];\n\n    isLoaded = false;\n    blogPostTag;\n\n    user: User;\n\n    constructor(\n        private readonly resourceService: ResourceService,\n        private readonly authService: AuthService,\n        private readonly tagService: TagService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\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        this.getPostTags();\n    }\n\n    private getPostTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.subscriptionId ?? this.masterSubscriptionId)\n            .subscribe(response => {\n                this.blogPostTag = response.tags.find(tag => tag.name === 'Events');\n                if (this.blogPostTag?.tag_category_id) {\n                    this.getPosts(1, 100);\n                } else {\n                    this.isLoaded = true;\n                }\n            });\n    }\n\n    getPosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(\n                this.subscriptionId ?? this.masterSubscriptionId,\n                page,\n                pageSize,\n                '',\n                this.blogPostTag?.tag_category_id\n            )\n            .subscribe(response => {\n                const now = new Date().getTime();\n                const sortedPosts = (response.posts ?? [])\n                    .filter(post => post.showcase === true && new Date(post?.when).getTime() < now)\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    );\n                this.posts = sortedPosts;\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n}\n","<section class=\"msp-vault-section bg-white text-center py-5 extra-top-padding section-outer\">\n  <div class=\"container\">\n    <div class=\"d-md-flex justify-content-between align-items-start\">\n      <div class=\"vault-header\">\n        <h2 class=\"vault-heading\" *ngIf=\"resourceTitle; else fallback\">{{resourceTitle}} Replays</h2>\n        <ng-template #fallback><h2 class=\"vault-heading\">Events &amp; Webinars Replays</h2></ng-template>\n      </div>\n    </div>\n\n    <div class=\"w-100 text-center mt-3\" *ngIf=\"!isLoaded\">\n      <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n    </div>\n    <div *ngIf=\"posts.length === 0 && isLoaded\">\n      <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n    </div>\n\n    <div class=\"row mt-5 d-flex flex-wrap justify-content-center gap-4 video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n      <div class=\"resource-blog-card vault-card text-center p-4\" *ngFor=\"let post of posts\">\n        <pw-resource-edit-card\n          *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          [id]=\"post.id\"\n          [resourceData]=\"post\"\n          (updated)=\"getPosts(1, 100)\"></pw-resource-edit-card>\n        <h5 class=\"badge-title fw-bold\">REPLAY:</h5>\n\n        <p class=\"event-title mb-4\" [innerHtml]=\"post?.title\"></p>\n        <img\n             [src]=\"post.picture.url\"\n             class=\"img-fluid my-3 mt-auto\"\n             alt=\"Webinar\" />\n             <a *ngIf=\"post?.external_url; else internalLink\"\n             class=\"resource-btn mt-3\"\n             [href]=\"post.external_url\"\n             aria-label=\"Navigate to external url\"\n             target=\"_blank\"\n             rel=\"noopener noreferrer\">\n             <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n             <span class=\"arrow\">→</span>\n           </a>\n\n         <ng-template #internalLink>\n           <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n             <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n             <span class=\"arrow\">→</span>\n           </a>\n         </ng-template>\n      </div>\n  </div>\n  </div>\n</section>\n"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"replay-event-cards.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/resource-module/src/lib/public/components/resource-webinars/replay-event-cards/replay-event-cards.component.ts","../../../../../../../../../libs/resource-module/src/lib/public/components/resource-webinars/replay-event-cards/replay-event-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../../resource.service';\n\n@Component({\n    selector: 'pw-replay-event-card',\n    templateUrl: './replay-event-cards.component.html',\n    styleUrls: ['../../resources/resources-shared.component.scss']\n})\nexport class ReplayEventCardComponent extends AppBaseComponent implements OnInit {\n    @Input() showEventContent = false;\n    @Input() categoryId!: string;\n    @Input() resourceTitle!: string;\n    userLoggedIn: boolean;\n    subscriptionId;\n\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n\n    posts: Resource[] = [];\n\n    isLoaded = false;\n    blogPostTag;\n\n    user: User;\n    isMasterSubscription;\n\n    constructor(\n        private readonly resourceService: ResourceService,\n        private readonly authService: AuthService,\n        private readonly tagService: TagService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\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                    this.getPostTags();\n                });\n            } else {\n                this.getPostTags();\n            }\n        });\n    }\n\n    private getPostTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())\n            .subscribe(response => {\n                this.blogPostTag = response.tags.find(tag => tag.name === 'Events');\n                if (this.blogPostTag?.tag_category_id) {\n                    this.getPosts(1, 100);\n                } else {\n                    this.isLoaded = true;\n                }\n            });\n    }\n\n    getPosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(\n                this.getEffectiveSubscriptionId(),\n                page,\n                pageSize,\n                '',\n                this.blogPostTag?.tag_category_id\n            )\n            .subscribe(response => {\n                const now = new Date().getTime();\n                const sortedPosts = (response.posts ?? [])\n                    .filter(post => post.showcase === true && new Date(post?.when).getTime() < now)\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    );\n                this.posts = sortedPosts;\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    /** Helper method to get effective subscription ID */\n    private getEffectiveSubscriptionId(): number {\n        return HelperService.getEffectiveSubscriptionId(\n            this.user,\n            this.subscriptionId,\n            this.masterSubscriptionId\n        );\n    }\n}\n","<section class=\"msp-vault-section bg-white text-center py-5 extra-top-padding section-outer\">\n  <div class=\"container\">\n    <div class=\"d-md-flex justify-content-between align-items-start\">\n      <div class=\"vault-header\">\n        <h2 class=\"vault-heading\" *ngIf=\"resourceTitle; else fallback\">{{resourceTitle}} Replays</h2>\n        <ng-template #fallback><h2 class=\"vault-heading\">Events &amp; Webinars Replays</h2></ng-template>\n      </div>\n    </div>\n\n    <div class=\"w-100 text-center mt-3\" *ngIf=\"!isLoaded\">\n      <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n    </div>\n    <div *ngIf=\"posts.length === 0 && isLoaded\">\n      <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n    </div>\n\n    <div class=\"row mt-5 d-flex flex-wrap justify-content-center gap-4 video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n      <div class=\"resource-blog-card vault-card text-center p-4\" *ngFor=\"let post of posts\">\n        <pw-resource-edit-card\n          *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          [id]=\"post.id\"\n          [resourceData]=\"post\"\n          (updated)=\"getPosts(1, 100)\"></pw-resource-edit-card>\n        <h5 class=\"badge-title fw-bold\">REPLAY:</h5>\n\n        <p class=\"event-title mb-4\" [innerHtml]=\"post?.title\"></p>\n        <img\n             [src]=\"post.picture.url\"\n             class=\"img-fluid my-3 mt-auto\"\n             alt=\"Webinar\" />\n             <a *ngIf=\"post?.external_url; else internalLink\"\n             class=\"resource-btn mt-3\"\n             [href]=\"post.external_url\"\n             aria-label=\"Navigate to external url\"\n             target=\"_blank\"\n             rel=\"noopener noreferrer\">\n             <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n             <span class=\"arrow\">→</span>\n           </a>\n\n         <ng-template #internalLink>\n           <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n             <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n             <span class=\"arrow\">→</span>\n           </a>\n         </ng-template>\n      </div>\n  </div>\n  </div>\n</section>\n"]}