@posiwise/resource-module 0.0.129 → 0.0.130

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.
@@ -55,7 +55,6 @@ export class ResourceIntegrationComponent extends AppBaseComponent {
55
55
  this.domainId = this.appConfig.domain_id;
56
56
  }
57
57
  ngOnInit() {
58
- console.log(this.guideData);
59
58
  this.companyName = this.appConfig.company.name;
60
59
  document.documentElement.style.setProperty('--text-color', this.textColor);
61
60
  this.getUserSubscriptionId().subscribe(response => {
@@ -205,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
205
204
  type: ViewChild,
206
205
  args: ['editIntegrationsModal']
207
206
  }] } });
208
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-integration.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/resource-integration/resource-integration.component.ts","../../../../../../../../libs/resource-module/src/lib/public/components/resource-integration/resource-integration.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport { Component, Injector, OnInit, TemplateRef, ViewChild } from '@angular/core';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { TagService } from '@posiwise/common-services';\nimport { CompanyData, Resource, TOKEN_KEY, User } from '@posiwise/common-utilities';\nimport { CustomUploaderComponent } from '@posiwise/shared-components';\n\nimport { forkJoin } from 'rxjs';\n\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    selector: 'pw-resource-integration',\n    templateUrl: './resource-integration.component.html',\n    styleUrls: [\n        './resource-integration.component.scss',\n        '../resources/resources-shared.component.scss'\n    ]\n})\nexport class ResourceIntegrationComponent extends AppBaseComponent implements OnInit {\n    @ViewChild('editIntegrationsModal') editIntegrationsModal: TemplateRef<CustomUploaderComponent>;\n    editingIntegrations;\n    distributorsData = CompanyData?.distributorsData;\n    vendorsData = CompanyData?.vendorsData;\n\n    textColor = this.appConfig?.color_codes?.text;\n\n    subscriptionId: number;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n    posts: Resource[] = [];\n    distributerPosts = [];\n    userLoggedIn: boolean;\n    blogPostTag;\n    isLoaded = false;\n    resourcePostTag;\n    blogPostVendorTag;\n\n    integrations = this.appConfig?.pages_config?.integrations;\n\n    releaseNotesLink = '/resources/product-release-notes';\n    q1NotesLink = '/resources/product-release-q1-2025';\n    q3NotesLink = '/resources/product-release-q3-2024';\n    q4NotesLink = '/resources/product-release-q4-2024';\n    companyName;\n\n    videoWebinarLoaded = false;\n    videoDemoLoaded = false;\n    youtubeVideoId = 'R7Vk219zbhA';\n    videoTitle = 'CloudOlive Overview';\n    sanitizedMicrosoftVideoUrl: SafeResourceUrl;\n    sanitizedKesyaVideoUrl: SafeResourceUrl;\n    integrationCountDisplay: number;\n    contactUsUrl = this.appConfig?.pages_config?.contact_us?.url;\n    tagCategory;\n    totalPosts: number;\n\n    guideData = this.appConfig?.pages_config?.guides;\n    editingGuides = { items: [] };\n    user: User;\n    domainId = this.appConfig.domain_id;\n\n    constructor(\n        private readonly sanitizer: DomSanitizer,\n        private readonly resourceService: ResourceService,\n        private readonly modalService: NgbModal,\n        private readonly tagService: TagService,\n        private readonly adminService: AdminService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        console.log(this.guideData);\n        this.companyName = this.appConfig.company.name;\n\n        document.documentElement.style.setProperty('--text-color', this.textColor);\n        this.getUserSubscriptionId().subscribe(response => {\n            this.subscriptionId = response;\n        });\n        this.localStorage.getItem$(TOKEN_KEY).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            this.getTags();\n        });\n    }\n\n    private getTags() {\n        this.isLoaded = false;\n        this.tagService\n            .getAllTagCategories(\n                { search: 'Integrations' },\n                this.subscriptionId || this.masterSubscriptionId\n            )\n            .subscribe(response => {\n                this.tagCategory = response.tag_categories[0];\n                this.getPostTags();\n            });\n    }\n\n    openEditIntegrationsModal(modalRef) {\n        this.editingIntegrations = JSON.parse(JSON.stringify(this.integrations));\n        this.modalService.open(modalRef, {\n            size: 'lg',\n            centered: true,\n            windowClass: 'modal-holder'\n        });\n    }\n\n    private getPostTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.subscriptionId || this.masterSubscriptionId)\n            .subscribe(response => {\n                this.resourcePostTag = response.tags.find(\n                    tag => tag.name === 'Product Release Notes'\n                );\n                this.blogPostTag = response.tags.find(\n                    tag =>\n                        tag.name === 'Integrated Distributors' &&\n                        tag.tag_category_id === this.tagCategory?.id\n                );\n                this.blogPostVendorTag = response.tags.find(\n                    tag =>\n                        tag.name === 'Integrated Vendors' &&\n                        tag.tag_category_id === this.tagCategory?.id\n                );\n\n                // use forkJoin to fetch both sets of posts in parallel\n                forkJoin({\n                    vendorResponse: this.resourceService.getPublicPosts(\n                        this.subscriptionId || this.masterSubscriptionId,\n                        1,\n                        100,\n                        '',\n                        '',\n                        this.blogPostVendorTag?.id\n                    ),\n                    distributorResponse: this.resourceService.getPublicPosts(\n                        this.subscriptionId || this.masterSubscriptionId,\n                        1,\n                        100,\n                        '',\n                        '',\n                        this.blogPostTag?.id\n                    )\n                }).subscribe(({ vendorResponse, distributorResponse }) => {\n                    this.posts = vendorResponse.posts\n                        .filter(post => post.showcase === true)\n                        .sort(\n                            (a, b) =>\n                                new Date(b.published_at).getTime() -\n                                new Date(a.published_at).getTime()\n                        );\n\n                    this.distributerPosts = distributorResponse.posts\n                        .filter(post => post.showcase === true)\n                        .sort(\n                            (a, b) =>\n                                new Date(b.published_at).getTime() -\n                                new Date(a.published_at).getTime()\n                        );\n\n                    const vendorCount = vendorResponse?.object_count ?? 0;\n                    const distributorCount = distributorResponse?.object_count ?? 0;\n                    const total = vendorCount + distributorCount;\n\n                    this.integrationCountDisplay = total === 0 ? 0 : Math.ceil(total / 10) * 10;\n                    this.isLoaded = true;\n                });\n            });\n    }\n\n    loadMicrosoftVideo(videoUrl) {\n        window.open(videoUrl, '_blank');\n    }\n\n    loadKeseyaVideo(): void {\n        const baseUrl = `https://www.youtube.com/embed/${this.youtubeVideoId}?autoplay=1`;\n        // baseUrl is a trusted internal source (e.g. YouTube embed URL)\n        this.sanitizedKesyaVideoUrl = this.sanitizer.bypassSecurityTrustResourceUrl(baseUrl); // NOSONAR\n        this.videoWebinarLoaded = true;\n    }\n\n    addIntegrationItem() {\n        this.editingIntegrations.items.push({\n            title: '',\n            description: '',\n            blog_url: '',\n            image_url: '',\n            video_url: ''\n        });\n    }\n\n    removeIntegrationItem(index: number) {\n        this.editingIntegrations.items.splice(index, 1);\n    }\n\n    dropIntegrationItems(event) {\n        moveItemInArray(this.editingIntegrations.items, event.previousIndex, event.currentIndex);\n    }\n\n    saveIntegrations(modalRef) {\n        const updatedIntegrations = {\n            ...this.editingIntegrations\n        };\n\n        this.adminService\n            .updateDomainConfig(this.domainId, {\n                integrations: updatedIntegrations,\n                subscription_id: this.subscriptionId\n            })\n            .subscribe(() => {\n                this.integrations = updatedIntegrations;\n                this.toast.success('Integrations updated');\n                modalRef.close();\n            });\n    }\n\n    saveGuides(modalRef) {\n        const updatedGuides = {\n            ...this.editingGuides\n        };\n\n        this.adminService\n            .updateDomainConfig(this.domainId, {\n                guides: updatedGuides,\n                subscription_id: this.subscriptionId\n            })\n            .subscribe(() => {\n                this.guideData = updatedGuides;\n                this.toast.success('Guides updated');\n                modalRef.close();\n            });\n    }\n\n    openGuidesModal(template) {\n        this.editingGuides = JSON.parse(JSON.stringify(this.guideData ?? { items: [] }));\n        this.modalService.open(template, { size: 'xl' });\n    }\n\n    addGuide() {\n        this.editingGuides.items.push({\n            title: '',\n            button_text: '',\n            image_url: '',\n            guide_url: '',\n            description: ''\n        });\n    }\n\n    removeGuide(index: number) {\n        this.editingGuides.items.splice(index, 1);\n    }\n\n    dropGuides(event: CdkDragDrop<string[]>) {\n        moveItemInArray(this.editingGuides.items, event.previousIndex, event.currentIndex);\n    }\n}\n","<pw-resource-header></pw-resource-header>\n<pw-integration-top-banner></pw-integration-top-banner>\n<div class=\"bg-white\">\n  <section class=\"cloudolive-guide-section bg-white py-5 section-outer\">\n    <div class=\"container sec-container\">\n      <div  *ngIf=\"isLoaded && integrationCountDisplay > 0\">\n        <h1 class=\"int-title mb-0\">{{ integrationCountDisplay }}+ integrations (& counting)</h1>\n        <p class=\"int-text\"> Search the current list of {{companyName}} vendor and distributor integrations below. <br />\n        </p>\n      </div>\n      <pw-resource-company-card *ngIf=\"isLoaded\" [header]=\"'integrated vendors'\"\n        (getPosts)=\"getPostTags()\"\n        [integrationCountDisplay]=\"integrationCountDisplay\"\n        [data]=\"posts\"></pw-resource-company-card>\n        <div class=\"w-100 text-center mt-3\"\n        *ngIf=\"!isLoaded\">\n        <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n      </div>\n      <div *ngIf=\"integrationCountDisplay === 0 && isLoaded\">\n        <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n      </div>\n      <div class=\"text-center pt-3 mt-4\" *ngIf=\"isLoaded && integrationCountDisplay > 0\">\n        <p class=\"see-span\"> Don’t see what you’re after? <a [href]=\"contactUsUrl\"\n            target=\"_blank\"\n            class=\"int-span team-span\">Speak with our team to request a connection >\n          </a>\n        </p>\n      </div>\n    </div>\n\n  </section>\n  <section class=\"cloudolive-guide-section bg-white py-5 section-outer\">\n    <div class=\"container\">\n      <pw-resource-company-card [header]=\"'integrated Distributors'\"\n      [integrationCountDisplay]=\"integrationCountDisplay\"\n      *ngIf=\"isLoaded\"\n        [vendor]=\"true\"\n        (getPosts)=\"getPostTags()\"\n        [data]=\"distributerPosts\"></pw-resource-company-card>\n        <div class=\"w-100 text-center mt-3\"\n      *ngIf=\"!isLoaded\">\n      <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n    </div>\n        <div *ngIf=\"integrationCountDisplay === 0 && isLoaded\">\n          <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n        </div>\n    </div>\n\n  </section>\n  <section class=\"cloudolive-guide-section bg-white py-5 section-outer\" *ngIf=\"integrations\">\n    <div class=\"container\">\n\n      <div class=\"how-it-works-wrapper\">\n        <div class=\"d-flex\">\n          <h1 class=\"it-works-title mb-0\">{{integrations?.title || 'How it works'}}</h1>\n          <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          class=\"fa fa-edit in-page-edit-icon text-black ms-4 mt-3 cursor-pointer\"\n          (click)=\"openEditIntegrationsModal(editIntegrationsModal)\"\n          title=\"Edit Integrations Section\"></i>\n        </div>\n        <p class=\"pb-20\" [innerHTML]=\"integrations?.description || 'View short example videos to understand how these integrations can work for you:'\"></p>\n        <div class=\"row section-row\">\n          <ng-container *ngIf=\"integrations?.items?.length > 0; else noIntegrations\">\n            <ng-container *ngFor=\"let integration of integrations?.items\">\n              <div\n                class=\"col-md-6\"\n                *ngIf=\"integration?.image_url || integration?.title || integration?.description\"\n              >\n              <ng-container *ngIf=\"integration?.video_url && integration?.video_url.includes('https'); else noVideo\">\n                <div class=\"d-flex justify-content-center\">\n                  <img\n                    *ngIf=\"integration?.video_url\"\n                    [src]=\"integration?.image_url\"\n                    (click)=\"loadMicrosoftVideo(integration?.video_url)\"\n                    (keydown.enter)=\"loadMicrosoftVideo(integration?.video_url)\"\n                    class=\"how-it-works-img\"\n                    alt=\"Integration Video Thumbnail\"\n                  />\n                </div>\n              </ng-container>\n\n              <ng-template #noVideo>\n                <div class=\"d-flex justify-content-center\">\n                  <div class=\"w-100\">\n                    <pw-no-data [withImage]=\"true\" [message]=\"'No video found' | transloco\">\n                    </pw-no-data>\n                  </div>\n                </div>\n              </ng-template>\n              </div>\n            </ng-container>\n          </ng-container>\n          <ng-template #noIntegrations>\n            <div class=\"w-100 text-center\">\n              <pw-no-data [withImage]=\"true\" [message]=\"'Integration.NoDataMessage' | transloco\"></pw-no-data>\n            </div>\n          </ng-template>\n\n        </div>\n      </div>\n    </div>\n\n  </section>\n <section class=\"cloudolive-guide-section bg-white py-5 section-outer\">\n   <div class=\"container\">\n      <div class=\"row align-items-start\">\n       <div class=\"col-md-6 text-md-start text-center\">\n        <div class=\"d-flex\">\n          <h1 class=\"guide-title mb-3\">{{guideData?.items[0]?.title || '--UPDATE ME ON THE ADMIN/DOMAINS MODULE--'}}</h1>\n          <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          class=\"fa fa-edit in-page-edit-icon text-black ms-4 mt-3 cursor-pointer\"\n          (click)=\"openGuidesModal(guidesEditModal)\"\n          title=\"Edit Integrations Section\"></i>\n        </div>\n          <p class=\"guide-subtext\"\n          [innerHTML]=\"guideData?.items[0]?.description || '--UPDATE ME ON THE ADMIN/DOMAINS MODULE--'\">\n       </p>\n          <a class=\"vault-btn\"\n            [href]=\"guideData?.items[0]?.guide_url\"\n            target=\"_blank\"\n            rel=\"noopener noreferrer\">\n            {{guideData?.items[0]?.button_text || 'View the guide'}}\n          </a>\n\n        </div>\n\n       <div class=\"col-md-6 text-center\">\n        <ng-container *ngIf=\"guideData?.items[0]?.image_url && !guideData?.items[0].image_url.includes('default-photo.jpg'); else noDataTemplate\">\n          <img\n            [src]=\"guideData?.items[0].image_url\"\n            alt=\"Guide\"\n            class=\"guide-img\" />\n        </ng-container>\n\n        <ng-template #noDataTemplate>\n          <div>\n            <pw-no-data [withImage]=\"true\" [message]=\"'--ADD ME ON THE ADMIN/DOMAINS MODULE--' | transloco\" />\n          </div>\n        </ng-template>\n       </div>\n     </div>\n </div>\n </section>\n</div>\n\n<pw-resource-note-card *ngIf=\"resourcePostTag?.tag_category_id\" [categoryId]=\"resourcePostTag?.tag_category_id\" [tag]=\"resourcePostTag\" [releaseHeader]=\"true\" [resourceTitle]=\"resourcePostTag?.title\"></pw-resource-note-card>\n\n<pw-trial-4-contact-us></pw-trial-4-contact-us>\n\n\n\n<ng-template #editIntegrationsModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Integrations Section</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n\n  <div class=\"modal-body\">\n    <div class=\"mb-3\">\n      <label class=\"form-label\">Title</label>\n      <input class=\"form-control\" [(ngModel)]=\"editingIntegrations.title\" />\n    </div>\n\n    <div class=\"mb-3\">\n      <label class=\"form-label\">Description</label>\n      <textarea class=\"form-control\" rows=\"3\" [(ngModel)]=\"editingIntegrations.description\"></textarea>\n    </div>\n\n    <div cdkDropList (cdkDropListDropped)=\"dropIntegrationItems($event)\">\n      <div *ngFor=\"let integration of editingIntegrations.items; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n        <div class=\"d-flex justify-content-between align-items-center mb-2\">\n          <label class=\"form-label mb-0\">Integration Item</label>\n          <i class=\"fa fa-bars cursor-move in-page-bars-icon\" cdkDragHandle></i>\n        </div>\n\n        <div class=\"row\">\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Title</label>\n            <input class=\"form-control\" [(ngModel)]=\"integration.title\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Description</label>\n            <input class=\"form-control\" [(ngModel)]=\"integration.description\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Blog URL</label>\n            <input class=\"form-control\" [(ngModel)]=\"integration.blog_url\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Image URL</label>\n            <input class=\"form-control\" [(ngModel)]=\"integration.image_url\" />\n          </div>\n          <div class=\"col-md-12 mb-2\">\n            <label class=\"form-label\">Video URL</label>\n            <input class=\"form-control\" [(ngModel)]=\"integration.video_url\" />\n          </div>\n        </div>\n\n        <div class=\"d-flex justify-content-end\">\n          <i class=\"fa fa-trash text-danger cursor-pointer\" (click)=\"removeIntegrationItem(i)\"></i>\n        </div>\n      </div>\n    </div>\n\n    <button class=\"btn btn-outline-primary btn-sm\" (click)=\"addIntegrationItem()\">+ Add Integration</button>\n  </div>\n\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n    <button class=\"btn btn-primary\" (click)=\"saveIntegrations(modal)\">Save</button>\n  </div>\n</ng-template>\n\n\n\n<ng-template #guidesEditModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Guides</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n\n  <div class=\"modal-body\">\n    <h4 class=\"mb-3\">Guides Section</h4>\n\n    <div cdkDropList (cdkDropListDropped)=\"dropGuides($event)\">\n      <div *ngFor=\"let guide of editingGuides.items; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n        <div class=\"row\">\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Title</label>\n            <input class=\"form-control\" [(ngModel)]=\"guide.title\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Button Text</label>\n            <input class=\"form-control\" [(ngModel)]=\"guide.button_text\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Image URL</label>\n            <input class=\"form-control\" [(ngModel)]=\"guide.image_url\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Guide URL</label>\n            <input class=\"form-control\" [(ngModel)]=\"guide.guide_url\" />\n          </div>\n          <div class=\"col-12 mb-2\">\n            <label class=\"form-label\">Description</label>\n            <textarea class=\"form-control\" rows=\"3\" [(ngModel)]=\"guide.description\"></textarea>\n          </div>\n          <div class=\"d-flex justify-content-between align-items-center mt-2\">\n            <i class=\"fa fa-trash text-danger cursor-pointer\" (click)=\"removeGuide(i)\"></i>\n            <i class=\"fa fa-bars cursor-move\" cdkDragHandle></i>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <button class=\"btn btn-primary mt-2\" (click)=\"addGuide()\">+ Add Guide</button>\n  </div>\n\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n    <button class=\"btn btn-primary\" (click)=\"saveGuides(modal)\">Save</button>\n  </div>\n</ng-template>\n"]}
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-integration.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/resource-integration/resource-integration.component.ts","../../../../../../../../libs/resource-module/src/lib/public/components/resource-integration/resource-integration.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport { Component, Injector, OnInit, TemplateRef, ViewChild } from '@angular/core';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { TagService } from '@posiwise/common-services';\nimport { CompanyData, Resource, TOKEN_KEY, User } from '@posiwise/common-utilities';\nimport { CustomUploaderComponent } from '@posiwise/shared-components';\n\nimport { forkJoin } from 'rxjs';\n\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    selector: 'pw-resource-integration',\n    templateUrl: './resource-integration.component.html',\n    styleUrls: [\n        './resource-integration.component.scss',\n        '../resources/resources-shared.component.scss'\n    ]\n})\nexport class ResourceIntegrationComponent extends AppBaseComponent implements OnInit {\n    @ViewChild('editIntegrationsModal') editIntegrationsModal: TemplateRef<CustomUploaderComponent>;\n    editingIntegrations;\n    distributorsData = CompanyData?.distributorsData;\n    vendorsData = CompanyData?.vendorsData;\n\n    textColor = this.appConfig?.color_codes?.text;\n\n    subscriptionId: number;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n    posts: Resource[] = [];\n    distributerPosts = [];\n    userLoggedIn: boolean;\n    blogPostTag;\n    isLoaded = false;\n    resourcePostTag;\n    blogPostVendorTag;\n\n    integrations = this.appConfig?.pages_config?.integrations;\n\n    releaseNotesLink = '/resources/product-release-notes';\n    q1NotesLink = '/resources/product-release-q1-2025';\n    q3NotesLink = '/resources/product-release-q3-2024';\n    q4NotesLink = '/resources/product-release-q4-2024';\n    companyName;\n\n    videoWebinarLoaded = false;\n    videoDemoLoaded = false;\n    youtubeVideoId = 'R7Vk219zbhA';\n    videoTitle = 'CloudOlive Overview';\n    sanitizedMicrosoftVideoUrl: SafeResourceUrl;\n    sanitizedKesyaVideoUrl: SafeResourceUrl;\n    integrationCountDisplay: number;\n    contactUsUrl = this.appConfig?.pages_config?.contact_us?.url;\n    tagCategory;\n    totalPosts: number;\n\n    guideData = this.appConfig?.pages_config?.guides;\n    editingGuides = { items: [] };\n    user: User;\n    domainId = this.appConfig.domain_id;\n\n    constructor(\n        private readonly sanitizer: DomSanitizer,\n        private readonly resourceService: ResourceService,\n        private readonly modalService: NgbModal,\n        private readonly tagService: TagService,\n        private readonly adminService: AdminService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        this.companyName = this.appConfig.company.name;\n\n        document.documentElement.style.setProperty('--text-color', this.textColor);\n        this.getUserSubscriptionId().subscribe(response => {\n            this.subscriptionId = response;\n        });\n        this.localStorage.getItem$(TOKEN_KEY).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            this.getTags();\n        });\n    }\n\n    private getTags() {\n        this.isLoaded = false;\n        this.tagService\n            .getAllTagCategories(\n                { search: 'Integrations' },\n                this.subscriptionId || this.masterSubscriptionId\n            )\n            .subscribe(response => {\n                this.tagCategory = response.tag_categories[0];\n                this.getPostTags();\n            });\n    }\n\n    openEditIntegrationsModal(modalRef) {\n        this.editingIntegrations = JSON.parse(JSON.stringify(this.integrations));\n        this.modalService.open(modalRef, {\n            size: 'lg',\n            centered: true,\n            windowClass: 'modal-holder'\n        });\n    }\n\n    private getPostTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.subscriptionId || this.masterSubscriptionId)\n            .subscribe(response => {\n                this.resourcePostTag = response.tags.find(\n                    tag => tag.name === 'Product Release Notes'\n                );\n                this.blogPostTag = response.tags.find(\n                    tag =>\n                        tag.name === 'Integrated Distributors' &&\n                        tag.tag_category_id === this.tagCategory?.id\n                );\n                this.blogPostVendorTag = response.tags.find(\n                    tag =>\n                        tag.name === 'Integrated Vendors' &&\n                        tag.tag_category_id === this.tagCategory?.id\n                );\n\n                // use forkJoin to fetch both sets of posts in parallel\n                forkJoin({\n                    vendorResponse: this.resourceService.getPublicPosts(\n                        this.subscriptionId || this.masterSubscriptionId,\n                        1,\n                        100,\n                        '',\n                        '',\n                        this.blogPostVendorTag?.id\n                    ),\n                    distributorResponse: this.resourceService.getPublicPosts(\n                        this.subscriptionId || this.masterSubscriptionId,\n                        1,\n                        100,\n                        '',\n                        '',\n                        this.blogPostTag?.id\n                    )\n                }).subscribe(({ vendorResponse, distributorResponse }) => {\n                    this.posts = vendorResponse.posts\n                        .filter(post => post.showcase === true)\n                        .sort(\n                            (a, b) =>\n                                new Date(b.published_at).getTime() -\n                                new Date(a.published_at).getTime()\n                        );\n\n                    this.distributerPosts = distributorResponse.posts\n                        .filter(post => post.showcase === true)\n                        .sort(\n                            (a, b) =>\n                                new Date(b.published_at).getTime() -\n                                new Date(a.published_at).getTime()\n                        );\n\n                    const vendorCount = vendorResponse?.object_count ?? 0;\n                    const distributorCount = distributorResponse?.object_count ?? 0;\n                    const total = vendorCount + distributorCount;\n\n                    this.integrationCountDisplay = total === 0 ? 0 : Math.ceil(total / 10) * 10;\n                    this.isLoaded = true;\n                });\n            });\n    }\n\n    loadMicrosoftVideo(videoUrl) {\n        window.open(videoUrl, '_blank');\n    }\n\n    loadKeseyaVideo(): void {\n        const baseUrl = `https://www.youtube.com/embed/${this.youtubeVideoId}?autoplay=1`;\n        // baseUrl is a trusted internal source (e.g. YouTube embed URL)\n        this.sanitizedKesyaVideoUrl = this.sanitizer.bypassSecurityTrustResourceUrl(baseUrl); // NOSONAR\n        this.videoWebinarLoaded = true;\n    }\n\n    addIntegrationItem() {\n        this.editingIntegrations.items.push({\n            title: '',\n            description: '',\n            blog_url: '',\n            image_url: '',\n            video_url: ''\n        });\n    }\n\n    removeIntegrationItem(index: number) {\n        this.editingIntegrations.items.splice(index, 1);\n    }\n\n    dropIntegrationItems(event) {\n        moveItemInArray(this.editingIntegrations.items, event.previousIndex, event.currentIndex);\n    }\n\n    saveIntegrations(modalRef) {\n        const updatedIntegrations = {\n            ...this.editingIntegrations\n        };\n\n        this.adminService\n            .updateDomainConfig(this.domainId, {\n                integrations: updatedIntegrations,\n                subscription_id: this.subscriptionId\n            })\n            .subscribe(() => {\n                this.integrations = updatedIntegrations;\n                this.toast.success('Integrations updated');\n                modalRef.close();\n            });\n    }\n\n    saveGuides(modalRef) {\n        const updatedGuides = {\n            ...this.editingGuides\n        };\n\n        this.adminService\n            .updateDomainConfig(this.domainId, {\n                guides: updatedGuides,\n                subscription_id: this.subscriptionId\n            })\n            .subscribe(() => {\n                this.guideData = updatedGuides;\n                this.toast.success('Guides updated');\n                modalRef.close();\n            });\n    }\n\n    openGuidesModal(template) {\n        this.editingGuides = JSON.parse(JSON.stringify(this.guideData ?? { items: [] }));\n        this.modalService.open(template, { size: 'xl' });\n    }\n\n    addGuide() {\n        this.editingGuides.items.push({\n            title: '',\n            button_text: '',\n            image_url: '',\n            guide_url: '',\n            description: ''\n        });\n    }\n\n    removeGuide(index: number) {\n        this.editingGuides.items.splice(index, 1);\n    }\n\n    dropGuides(event: CdkDragDrop<string[]>) {\n        moveItemInArray(this.editingGuides.items, event.previousIndex, event.currentIndex);\n    }\n}\n","<pw-resource-header></pw-resource-header>\n<pw-integration-top-banner></pw-integration-top-banner>\n<div class=\"bg-white\">\n  <section class=\"cloudolive-guide-section bg-white py-5 section-outer\">\n    <div class=\"container sec-container\">\n      <div  *ngIf=\"isLoaded && integrationCountDisplay > 0\">\n        <h1 class=\"int-title mb-0\">{{ integrationCountDisplay }}+ integrations (& counting)</h1>\n        <p class=\"int-text\"> Search the current list of {{companyName}} vendor and distributor integrations below. <br />\n        </p>\n      </div>\n      <pw-resource-company-card *ngIf=\"isLoaded\" [header]=\"'integrated vendors'\"\n        (getPosts)=\"getPostTags()\"\n        [integrationCountDisplay]=\"integrationCountDisplay\"\n        [data]=\"posts\"></pw-resource-company-card>\n        <div class=\"w-100 text-center mt-3\"\n        *ngIf=\"!isLoaded\">\n        <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n      </div>\n      <div *ngIf=\"integrationCountDisplay === 0 && isLoaded\">\n        <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n      </div>\n      <div class=\"text-center pt-3 mt-4\" *ngIf=\"isLoaded && integrationCountDisplay > 0\">\n        <p class=\"see-span\"> Don’t see what you’re after? <a [href]=\"contactUsUrl\"\n            target=\"_blank\"\n            class=\"int-span team-span\">Speak with our team to request a connection >\n          </a>\n        </p>\n      </div>\n    </div>\n\n  </section>\n  <section class=\"cloudolive-guide-section bg-white py-5 section-outer\">\n    <div class=\"container\">\n      <pw-resource-company-card [header]=\"'integrated Distributors'\"\n      [integrationCountDisplay]=\"integrationCountDisplay\"\n      *ngIf=\"isLoaded\"\n        [vendor]=\"true\"\n        (getPosts)=\"getPostTags()\"\n        [data]=\"distributerPosts\"></pw-resource-company-card>\n        <div class=\"w-100 text-center mt-3\"\n      *ngIf=\"!isLoaded\">\n      <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n    </div>\n        <div *ngIf=\"integrationCountDisplay === 0 && isLoaded\">\n          <pw-no-data [withImage]=\"true\" [message]=\"'Resource.NoDataMessage' | transloco\"/>\n        </div>\n    </div>\n\n  </section>\n  <section class=\"cloudolive-guide-section bg-white py-5 section-outer\" *ngIf=\"integrations\">\n    <div class=\"container\">\n\n      <div class=\"how-it-works-wrapper\">\n        <div class=\"d-flex\">\n          <h1 class=\"it-works-title mb-0\">{{integrations?.title || 'How it works'}}</h1>\n          <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          class=\"fa fa-edit in-page-edit-icon text-black ms-4 mt-3 cursor-pointer\"\n          (click)=\"openEditIntegrationsModal(editIntegrationsModal)\"\n          title=\"Edit Integrations Section\"></i>\n        </div>\n        <p class=\"pb-20\" [innerHTML]=\"integrations?.description || 'View short example videos to understand how these integrations can work for you:'\"></p>\n        <div class=\"row section-row\">\n          <ng-container *ngIf=\"integrations?.items?.length > 0; else noIntegrations\">\n            <ng-container *ngFor=\"let integration of integrations?.items\">\n              <div\n                class=\"col-md-6\"\n                *ngIf=\"integration?.image_url || integration?.title || integration?.description\"\n              >\n              <ng-container *ngIf=\"integration?.video_url && integration?.video_url.includes('https'); else noVideo\">\n                <div class=\"d-flex justify-content-center\">\n                  <img\n                    *ngIf=\"integration?.video_url\"\n                    [src]=\"integration?.image_url\"\n                    (click)=\"loadMicrosoftVideo(integration?.video_url)\"\n                    (keydown.enter)=\"loadMicrosoftVideo(integration?.video_url)\"\n                    class=\"how-it-works-img\"\n                    alt=\"Integration Video Thumbnail\"\n                  />\n                </div>\n              </ng-container>\n\n              <ng-template #noVideo>\n                <div class=\"d-flex justify-content-center\">\n                  <div class=\"w-100\">\n                    <pw-no-data [withImage]=\"true\" [message]=\"'No video found' | transloco\">\n                    </pw-no-data>\n                  </div>\n                </div>\n              </ng-template>\n              </div>\n            </ng-container>\n          </ng-container>\n          <ng-template #noIntegrations>\n            <div class=\"w-100 text-center\">\n              <pw-no-data [withImage]=\"true\" [message]=\"'Integration.NoDataMessage' | transloco\"></pw-no-data>\n            </div>\n          </ng-template>\n\n        </div>\n      </div>\n    </div>\n\n  </section>\n <section class=\"cloudolive-guide-section bg-white py-5 section-outer\">\n   <div class=\"container\">\n      <div class=\"row align-items-start\">\n       <div class=\"col-md-6 text-md-start text-center\">\n        <div class=\"d-flex\">\n          <h1 class=\"guide-title mb-3\">{{guideData?.items[0]?.title || '--UPDATE ME ON THE ADMIN/DOMAINS MODULE--'}}</h1>\n          <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          class=\"fa fa-edit in-page-edit-icon text-black ms-4 mt-3 cursor-pointer\"\n          (click)=\"openGuidesModal(guidesEditModal)\"\n          title=\"Edit Integrations Section\"></i>\n        </div>\n          <p class=\"guide-subtext\"\n          [innerHTML]=\"guideData?.items[0]?.description || '--UPDATE ME ON THE ADMIN/DOMAINS MODULE--'\">\n       </p>\n          <a class=\"vault-btn\"\n            [href]=\"guideData?.items[0]?.guide_url\"\n            target=\"_blank\"\n            rel=\"noopener noreferrer\">\n            {{guideData?.items[0]?.button_text || 'View the guide'}}\n          </a>\n\n        </div>\n\n       <div class=\"col-md-6 text-center\">\n        <ng-container *ngIf=\"guideData?.items[0]?.image_url && !guideData?.items[0].image_url.includes('default-photo.jpg'); else noDataTemplate\">\n          <img\n            [src]=\"guideData?.items[0].image_url\"\n            alt=\"Guide\"\n            class=\"guide-img\" />\n        </ng-container>\n\n        <ng-template #noDataTemplate>\n          <div>\n            <pw-no-data [withImage]=\"true\" [message]=\"'--ADD ME ON THE ADMIN/DOMAINS MODULE--' | transloco\" />\n          </div>\n        </ng-template>\n       </div>\n     </div>\n </div>\n </section>\n</div>\n\n<pw-resource-note-card *ngIf=\"resourcePostTag?.tag_category_id\" [categoryId]=\"resourcePostTag?.tag_category_id\" [tag]=\"resourcePostTag\" [releaseHeader]=\"true\" [resourceTitle]=\"resourcePostTag?.title\"></pw-resource-note-card>\n\n<pw-trial-4-contact-us></pw-trial-4-contact-us>\n\n\n\n<ng-template #editIntegrationsModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Integrations Section</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n\n  <div class=\"modal-body\">\n    <div class=\"mb-3\">\n      <label class=\"form-label\">Title</label>\n      <input class=\"form-control\" [(ngModel)]=\"editingIntegrations.title\" />\n    </div>\n\n    <div class=\"mb-3\">\n      <label class=\"form-label\">Description</label>\n      <textarea class=\"form-control\" rows=\"3\" [(ngModel)]=\"editingIntegrations.description\"></textarea>\n    </div>\n\n    <div cdkDropList (cdkDropListDropped)=\"dropIntegrationItems($event)\">\n      <div *ngFor=\"let integration of editingIntegrations.items; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n        <div class=\"d-flex justify-content-between align-items-center mb-2\">\n          <label class=\"form-label mb-0\">Integration Item</label>\n          <i class=\"fa fa-bars cursor-move in-page-bars-icon\" cdkDragHandle></i>\n        </div>\n\n        <div class=\"row\">\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Title</label>\n            <input class=\"form-control\" [(ngModel)]=\"integration.title\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Description</label>\n            <input class=\"form-control\" [(ngModel)]=\"integration.description\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Blog URL</label>\n            <input class=\"form-control\" [(ngModel)]=\"integration.blog_url\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Image URL</label>\n            <input class=\"form-control\" [(ngModel)]=\"integration.image_url\" />\n          </div>\n          <div class=\"col-md-12 mb-2\">\n            <label class=\"form-label\">Video URL</label>\n            <input class=\"form-control\" [(ngModel)]=\"integration.video_url\" />\n          </div>\n        </div>\n\n        <div class=\"d-flex justify-content-end\">\n          <i class=\"fa fa-trash text-danger cursor-pointer\" (click)=\"removeIntegrationItem(i)\"></i>\n        </div>\n      </div>\n    </div>\n\n    <button class=\"btn btn-outline-primary btn-sm\" (click)=\"addIntegrationItem()\">+ Add Integration</button>\n  </div>\n\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n    <button class=\"btn btn-primary\" (click)=\"saveIntegrations(modal)\">Save</button>\n  </div>\n</ng-template>\n\n\n\n<ng-template #guidesEditModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Guides</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n\n  <div class=\"modal-body\">\n    <h4 class=\"mb-3\">Guides Section</h4>\n\n    <div cdkDropList (cdkDropListDropped)=\"dropGuides($event)\">\n      <div *ngFor=\"let guide of editingGuides.items; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n        <div class=\"row\">\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Title</label>\n            <input class=\"form-control\" [(ngModel)]=\"guide.title\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Button Text</label>\n            <input class=\"form-control\" [(ngModel)]=\"guide.button_text\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Image URL</label>\n            <input class=\"form-control\" [(ngModel)]=\"guide.image_url\" />\n          </div>\n          <div class=\"col-md-6 mb-2\">\n            <label class=\"form-label\">Guide URL</label>\n            <input class=\"form-control\" [(ngModel)]=\"guide.guide_url\" />\n          </div>\n          <div class=\"col-12 mb-2\">\n            <label class=\"form-label\">Description</label>\n            <textarea class=\"form-control\" rows=\"3\" [(ngModel)]=\"guide.description\"></textarea>\n          </div>\n          <div class=\"d-flex justify-content-between align-items-center mt-2\">\n            <i class=\"fa fa-trash text-danger cursor-pointer\" (click)=\"removeGuide(i)\"></i>\n            <i class=\"fa fa-bars cursor-move\" cdkDragHandle></i>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <button class=\"btn btn-primary mt-2\" (click)=\"addGuide()\">+ Add Guide</button>\n  </div>\n\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n    <button class=\"btn btn-primary\" (click)=\"saveGuides(modal)\">Save</button>\n  </div>\n</ng-template>\n"]}
@@ -56,7 +56,6 @@ export class RelatedResourcesComponent extends AppBaseComponent {
56
56
  this.slug = params['slug'] ?? '';
57
57
  this.getBlogItem(this.slug);
58
58
  });
59
- console.log(this.linkedInUrl, this.appConfig);
60
59
  this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {
61
60
  this.userLoggedIn = !!res;
62
61
  if (this.userLoggedIn) {
@@ -89,7 +88,6 @@ export class RelatedResourcesComponent extends AppBaseComponent {
89
88
  }
90
89
  const date = new Date(response?.when);
91
90
  const formatted = date.toISOString().split('T')[0];
92
- console.log(formatted); //
93
91
  this.postComments = response.entity_comments;
94
92
  this.post = { ...response, body: blogBody, when: formatted };
95
93
  });
@@ -99,15 +97,10 @@ export class RelatedResourcesComponent extends AppBaseComponent {
99
97
  data.related_entity_id = this.post?.id;
100
98
  data.related_entity_type = 'Post';
101
99
  data.user_id = this.user?.id;
102
- this.resourceService
103
- .postComments(data)
104
- .subscribe(() => {
100
+ this.resourceService.postComments(data).subscribe(() => {
105
101
  this.getBlogItem(this.slug);
106
102
  this.commentForm.reset();
107
103
  this.toastr.success(this.translation.translate('Resource.Posts.CommentAdded'));
108
- })
109
- .add(() => {
110
- console.log('In this');
111
104
  });
112
105
  }
113
106
  trackByComment(_index, item) {
@@ -120,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
120
113
  type: Component,
121
114
  args: [{ selector: 'pw-related-resources', template: "\n\n<section class=\"resource-body-section\">\n <div class=\"container\">\n <div class=\"ql-snow body-quill\"\n >\n <div class=\"ql-editor body post-body-text\"\n [innerHTML]=\"post?.body\">\n </div>\n </div>\n <section class=\"nce-offer-section\">\n\n <div class=\"row mt-5 mb-4 response-row\">\n <div class=\"col-12\">\n <form\n class=\"p-fluid mb-5\"\n [formGroup]=\"commentForm\"\n (ngSubmit)=\"onComment()\"\n *ngIf=\"userLoggedIn; else userLoggedOut\"\n >\n <div class=\"card shadow-sm border-0 p-4\">\n <div class=\"field\">\n <label for=\"comment\" class=\"font-bold text-lg mb-4 comment-label\">\uD83D\uDCAC Leave a comment</label>\n <textarea\n pInputTextarea\n formControlName=\"comment\"\n rows=\"6\"\n autoResize=\"true\"\n class=\"p-inputtext p-component p-inputtextarea\"\n placeholder=\"What's on your mind?\"\n ></textarea>\n <small\n class=\"text-danger\"\n *ngIf=\"commentForm.get('comment')?.invalid && commentForm.get('comment')?.touched\"\n >Please enter comment</small\n >\n </div>\n <div class=\"text-end mt-3\">\n <button type=\"submit\"\n [buttonBusy]=\"buttonBusy\"\n class=\"sign-btn sign-header-btn\">\n {{ 'Button.Submit' | transloco }}\n </button>\n </div>\n </div>\n </form>\n <ng-template #userLoggedOut>\n <p class=\"text-center pt-3 pb-3 user-not-logged-in text-muted shadow-sm mb-5\">\n <a [routerLink]=\"['/login']\" class=\"text-primary fw-bold\">Log in</a> to leave a comment!\n </p>\n </ng-template>\n </div>\n </div>\n\n <div class=\"row mt-5 comment-row\">\n <div class=\"col-12\" *ngFor=\"let comment of postComments; trackBy: trackByComment\">\n <div class=\"card border-0 shadow-sm p-3 mb-3\">\n <div class=\"d-flex align-items-start\">\n <img\n [src]=\"comment?.author?.avatar?.[0]?.url || 'assets/img/icons/male.png'\"\n alt=\"avatar\"\n class=\"rounded-circle me-3\"\n width=\"50\"\n height=\"50\"\n (error)=\"handleImageError($event, 'assets/img/icons/male.png')\"\n />\n <div class=\"flex-grow-1\">\n <div class=\"fw-bold text-dark\">\n {{ comment.user?.first_name || '' }} {{ comment.user?.last_name || '' }}\n </div>\n <div class=\"text-muted small mb-2\">{{ comment.created_at | date: 'dd MMM yyyy, h:mm a' }}</div>\n <div class=\"text-body\">\n {{ comment.comment }}\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n\n </section>\n </div>\n <hr class=\"nce-divider\" />\n</section>\n\n<section class=\"nce-book-section\" *ngIf=\"hasValidDemoLinks\">\n <div class=\"container\">\n\n <p class=\"nce-contact\">\n Any questions, get in touch <a href=\"mailto:{{ company_email }}\">here</a>,\n <a [href]=\"linkedInUrl\" target=\"_blank\">connect on LinkedIn</a>, or book a meeting below:\n </p>\n </div>\n <pw-book-a-demo [isBlog]=\"true\"></pw-book-a-demo>\n <hr class=\"nce-divider\" />\n</section>\n\n\n<pw-resource-cards *ngIf=\"blogPostTag?.tag_category_id\" [tag]=\"blogPostTag\" [categoryId]=\"blogPostTag?.tag_category_id\" [resourceTitle]=\"blogPostTag?.title\" [isHeaderVisible]=\"true\" resourceLink=\"/resources/blogs\" [isRelated]=\"true\" [resourceTitle]=\"'Other resources you may be interested in:'\"></pw-resource-cards>\n", styles: [".video-row{gap:5.5rem!important;margin-top:3rem!important}::ng-deep .resource-section{box-shadow:0 4px 32px -14px #40576d4d!important}.release-icon{height:auto;margin:0 11px 1.9rem;display:block;align-self:center}@media (width >= 768px) and (width <= 1200px){.resource-title{font-size:1.4rem!important}}textarea{font-size:1.4rem!important}@media (width <= 768px){.resource-title{font-size:1.2rem!important}.container{padding:7rem 3rem 1rem!important}}@media (width >= 768px) and (width <= 1200px){.container{padding:1rem 3rem!important}}@media (width <= 1200px){.msp-vault-section .vault-heading{font-size:3.5rem}.msp-vault-section .vault-description{margin-top:1.35rem}.msp-vault-section .vault-card{width:100%!important}.msp-vault-section .vault-btn{margin-left:0!important;width:100%!important}}@media (width >= 991px){::ng-deep .trial-meeting-section:before{top:600px!important}::ng-deep .dashboard{margin-bottom:1rem!important}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}section.bg-white.text-center.extra-top-padding:before,section.bg-white.text-center.extra-top-padding:after{content:\"\";position:absolute;background:url(/assets/img/logos/background-banner.png) no-repeat;background-size:contain;width:160px;height:450px;z-index:0;opacity:.8}section.bg-white.text-center.extra-top-padding:before{top:500px;left:0}section.bg-white.text-center.extra-top-padding:after{top:90px;right:0}}.vault-header{text-align:left}@media (width >= 768px) and (width <= 1200px){.container{padding:0 6rem!important}}@media (width <= 1200px){.resource-card{width:100%!important}.release-notes-section{padding:7rem 0!important}}@media (width >= 768px) and (width <= 1200px){.nce-hero-section{padding:0 6rem!important}.cards-row{justify-content:center}}.resource-body-section{background-color:#fff}.resource-body-section .container{padding:0 1.5rem;padding-bottom:4rem!important;padding-top:7rem!important;max-width:850px;margin:0 auto;text-align:left}.user-not-logged-in{background:#f7f7f7;border:1px solid rgb(238,238,238);font-weight:400}.user-not-logged-in a{color:var(--first)!important;text-decoration:none;font-weight:500}.nce-book-section{background:#fff;padding-top:7rem;padding-bottom:0}.nce-book-section .container{max-width:850px;margin:0 auto;padding:0 1.5rem;text-align:left}.nce-book-section .nce-contact{line-height:1.6;font-size:1.5rem}.nce-book-section .nce-contact a{text-decoration:underline;color:#000;margin:0 .2rem}.nce-book-section .nce-contact a:hover{color:var(--first)!important}.nce-offer-section{background:#fff;padding-top:2rem}.nce-offer-section .container{max-width:850px;margin:0 auto;padding:0 1.5rem;text-align:left}.nce-offer-section .nce-title{font-size:2rem;font-weight:700;color:#000;margin-bottom:.25em!important}.nce-offer-section .nce-title strong{font-weight:700}.nce-offer-section .nce-description{font-size:1.5rem;line-height:1.8rem;color:#333;margin-bottom:1.5rem}.nce-offer-section .nce-offer-list{font-size:1.1rem;line-height:1.5rem;margin-bottom:2.5rem;margin-top:2.5rem}.nce-offer-section .nce-offer-list p{font-size:1.5rem;margin:.5rem 0;font-weight:400}.nce-offer-section .nce-signup{margin-bottom:2.5rem}.nce-offer-section .nce-signup .signup-link{font-size:1.5rem;font-weight:400;text-decoration:underline;color:#000}@media (width <= 768px){.nce-offer-section .nce-book-section{padding-top:5rem!important}.nce-offer-section .container{text-align:left}.nce-offer-section .nce-title{font-size:1.5rem}.nce-offer-section .nce-description,.nce-offer-section .nce-offer-list,.nce-offer-section .nce-signup,.nce-offer-section .signup-link,.nce-offer-section .nce-contact,.nce-offer-section .nce-offer-list p{font-size:1.2rem!important}}.nce-offer-intro{font-size:1.5rem;font-weight:400}.outer-section-fadeout{position:absolute;top:139rem;height:40px;width:100%;background:linear-gradient(to bottom,#fff0,#f8f9fa)}.body-divider{border:0;height:40px;width:100%;background:linear-gradient(to bottom,#0000,#00000026);margin:0}@media (width <= 768px){.nce-book-section{padding-top:5rem!important}.nce-contact{font-size:1.2rem!important}}::ng-deep .body-quill{border-width:0!important;max-width:900px;display:block;margin-left:auto;margin-right:auto}::ng-deep .p-inputtextarea{border-radius:.5rem;border-color:#ced4da;font-size:1rem}.card{background-color:#fff;border-radius:12px}.comment-row{gap:2rem;padding-bottom:5rem;max-width:1000px;display:block;margin-left:auto;margin-right:auto}.comment-label{font-size:1.5rem!important}.response-row{max-width:1000px;display:block;margin-left:auto;margin-right:auto;margin-top:6rem!important}\n"] }]
122
115
  }], ctorParameters: () => [{ type: i1.ResourceService }, { type: i0.Injector }, { type: i2.DomSanitizer }, { type: i3.TagService }, { type: i3.CustomToastService }] });
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"related-resources.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/resource-module/src/lib/public/components/resource-post/related-resources/related-resources.component.ts","../../../../../../../../../libs/resource-module/src/lib/public/components/resource-post/related-resources/related-resources.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, OnInit } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { CustomToastService, TagService } from '@posiwise/common-services';\nimport { TOKEN_KEY, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../../resource.service';\nimport { ResourceBlog } from '../../../../shared/models/resource.model';\n\n@Component({\n    selector: 'pw-related-resources',\n    templateUrl: './related-resources.component.html',\n    styleUrls: ['./related-resources.component.scss']\n})\nexport class RelatedResourcesComponent extends AppBaseComponent implements OnInit {\n    resourceCards = [\n        {\n            title: 'BLOG: Here’s why you should QA your distributor invoices',\n            image: '/assets/img/resource/resource-qa.png',\n            alt: 'QA distributor invoices',\n            url: '/resources/view/here-s-why-you-should-be-seeking-independent-qa-of-all-distributor-inv'\n        },\n        {\n            title: 'BLOG: 4 instant hacks to uplift your MSP’s monthly billing',\n            image: '/assets/img/resource/resource-hacks.png',\n            alt: 'Monthly billing hacks',\n            url: '/resources/view/4-instant-hacks-to-uplift-your-msp-s-monthly-billing'\n        },\n        {\n            title: 'BLOG: The trivial detail that will either future-proof or sabotage your PSA.',\n            image: '/assets/img/resource/resource-psa.png',\n            alt: 'PSA future-proof',\n            url: '/resources/view/the-trivial-detail-that-will-either-future-proof-or-sabotage-your-psa'\n        }\n    ];\n\n    post;\n    masterSubscriptionId;\n    slug;\n\n    postComments = [];\n    commentForm;\n\n    userLoggedIn: boolean;\n\n    demoLinks = this.appConfig?.pages_config?.book_demo?.items;\n\n    user: User;\n    blogPostTag;\n    subscriptionId;\n    linkedInUrl = this.appConfig?.social?.linkedin_url;\n    company_email = this.appConfig.company.email;\n\n    constructor(\n        private readonly resourceService: ResourceService,\n        injector: Injector,\n        private readonly sanitizer: DomSanitizer,\n        private readonly tagService: TagService,\n        private readonly toastr: CustomToastService\n    ) {\n        super(injector);\n        this.commentForm = ResourceBlog.getResourcePostsForm();\n    }\n\n    ngOnInit(): void {\n        this.masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n        this.route.params.subscribe(params => {\n            this.slug = params['slug'] ?? '';\n            this.getBlogItem(this.slug);\n        });\n        console.log(this.linkedInUrl, this.appConfig);\n        this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n                });\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n            }\n            this.getPostTags();\n        });\n    }\n\n    get hasValidDemoLinks(): boolean {\n        return (\n            Array.isArray(this.demoLinks) && this.demoLinks.some(link => link?.title ?? link?.url)\n        );\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 === 'Blog Posts');\n            });\n    }\n\n    private getBlogItem(slug: string) {\n        this.resourceService.getPostBySlug(slug).subscribe(response => {\n            let blogBody;\n            if (response?.body) {\n                blogBody = HelperService.sanitizeQuillBody(response.body, this.sanitizer);\n            }\n            const date = new Date(response?.when);\n            const formatted = date.toISOString().split('T')[0];\n            console.log(formatted); //\n            this.postComments = response.entity_comments;\n            this.post = { ...response, body: blogBody, when: formatted };\n        });\n    }\n\n    onComment() {\n        const data = { ...this.commentForm.value };\n        data.related_entity_id = this.post?.id;\n        data.related_entity_type = 'Post';\n        data.user_id = this.user?.id;\n        this.resourceService\n            .postComments(data)\n            .subscribe(() => {\n                this.getBlogItem(this.slug);\n                this.commentForm.reset();\n                this.toastr.success(this.translation.translate('Resource.Posts.CommentAdded'));\n            })\n            .add(() => {\n                console.log('In this');\n            });\n    }\n\n    trackByComment(_index: number, item: { id: number }) {\n        return item.id;\n    }\n}\n","\n\n<section class=\"resource-body-section\">\n  <div class=\"container\">\n    <div class=\"ql-snow body-quill\"\n    >\n    <div class=\"ql-editor body post-body-text\"\n      [innerHTML]=\"post?.body\">\n    </div>\n  </div>\n  <section class=\"nce-offer-section\">\n\n      <div class=\"row mt-5 mb-4 response-row\">\n        <div class=\"col-12\">\n          <form\n            class=\"p-fluid mb-5\"\n            [formGroup]=\"commentForm\"\n            (ngSubmit)=\"onComment()\"\n            *ngIf=\"userLoggedIn; else userLoggedOut\"\n          >\n            <div class=\"card shadow-sm border-0 p-4\">\n              <div class=\"field\">\n                <label for=\"comment\" class=\"font-bold text-lg mb-4 comment-label\">💬 Leave a comment</label>\n                <textarea\n                  pInputTextarea\n                  formControlName=\"comment\"\n                  rows=\"6\"\n                  autoResize=\"true\"\n                  class=\"p-inputtext p-component p-inputtextarea\"\n                  placeholder=\"What's on your mind?\"\n                ></textarea>\n                <small\n                  class=\"text-danger\"\n                  *ngIf=\"commentForm.get('comment')?.invalid && commentForm.get('comment')?.touched\"\n                  >Please enter comment</small\n                >\n              </div>\n              <div class=\"text-end mt-3\">\n                <button type=\"submit\"\n                [buttonBusy]=\"buttonBusy\"\n                class=\"sign-btn sign-header-btn\">\n                {{ 'Button.Submit' | transloco }}\n              </button>\n              </div>\n            </div>\n          </form>\n          <ng-template #userLoggedOut>\n            <p class=\"text-center pt-3 pb-3 user-not-logged-in text-muted shadow-sm mb-5\">\n              <a [routerLink]=\"['/login']\" class=\"text-primary fw-bold\">Log in</a> to leave a comment!\n            </p>\n          </ng-template>\n        </div>\n      </div>\n\n      <div class=\"row mt-5 comment-row\">\n        <div class=\"col-12\" *ngFor=\"let comment of postComments; trackBy: trackByComment\">\n          <div class=\"card border-0 shadow-sm p-3 mb-3\">\n            <div class=\"d-flex align-items-start\">\n              <img\n                [src]=\"comment?.author?.avatar?.[0]?.url || 'assets/img/icons/male.png'\"\n                alt=\"avatar\"\n                class=\"rounded-circle me-3\"\n                width=\"50\"\n                height=\"50\"\n                (error)=\"handleImageError($event, 'assets/img/icons/male.png')\"\n              />\n              <div class=\"flex-grow-1\">\n                <div class=\"fw-bold text-dark\">\n                  {{ comment.user?.first_name || '' }} {{ comment.user?.last_name || '' }}\n                </div>\n                <div class=\"text-muted small mb-2\">{{ comment.created_at | date: 'dd MMM yyyy, h:mm a' }}</div>\n                <div class=\"text-body\">\n                  {{ comment.comment }}\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n\n\n  </section>\n  </div>\n  <hr class=\"nce-divider\" />\n</section>\n\n<section class=\"nce-book-section\" *ngIf=\"hasValidDemoLinks\">\n  <div class=\"container\">\n\n    <p class=\"nce-contact\">\n      Any questions, get in touch <a href=\"mailto:{{ company_email }}\">here</a>,\n      <a [href]=\"linkedInUrl\" target=\"_blank\">connect on LinkedIn</a>, or book a meeting below:\n    </p>\n  </div>\n  <pw-book-a-demo [isBlog]=\"true\"></pw-book-a-demo>\n  <hr class=\"nce-divider\" />\n</section>\n\n\n<pw-resource-cards *ngIf=\"blogPostTag?.tag_category_id\" [tag]=\"blogPostTag\" [categoryId]=\"blogPostTag?.tag_category_id\" [resourceTitle]=\"blogPostTag?.title\" [isHeaderVisible]=\"true\" resourceLink=\"/resources/blogs\" [isRelated]=\"true\" [resourceTitle]=\"'Other resources you may be interested in:'\"></pw-resource-cards>\n"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"related-resources.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/resource-module/src/lib/public/components/resource-post/related-resources/related-resources.component.ts","../../../../../../../../../libs/resource-module/src/lib/public/components/resource-post/related-resources/related-resources.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, OnInit } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { CustomToastService, TagService } from '@posiwise/common-services';\nimport { TOKEN_KEY, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../../resource.service';\nimport { ResourceBlog } from '../../../../shared/models/resource.model';\n\n@Component({\n    selector: 'pw-related-resources',\n    templateUrl: './related-resources.component.html',\n    styleUrls: ['./related-resources.component.scss']\n})\nexport class RelatedResourcesComponent extends AppBaseComponent implements OnInit {\n    resourceCards = [\n        {\n            title: 'BLOG: Here’s why you should QA your distributor invoices',\n            image: '/assets/img/resource/resource-qa.png',\n            alt: 'QA distributor invoices',\n            url: '/resources/view/here-s-why-you-should-be-seeking-independent-qa-of-all-distributor-inv'\n        },\n        {\n            title: 'BLOG: 4 instant hacks to uplift your MSP’s monthly billing',\n            image: '/assets/img/resource/resource-hacks.png',\n            alt: 'Monthly billing hacks',\n            url: '/resources/view/4-instant-hacks-to-uplift-your-msp-s-monthly-billing'\n        },\n        {\n            title: 'BLOG: The trivial detail that will either future-proof or sabotage your PSA.',\n            image: '/assets/img/resource/resource-psa.png',\n            alt: 'PSA future-proof',\n            url: '/resources/view/the-trivial-detail-that-will-either-future-proof-or-sabotage-your-psa'\n        }\n    ];\n\n    post;\n    masterSubscriptionId;\n    slug;\n\n    postComments = [];\n    commentForm;\n\n    userLoggedIn: boolean;\n\n    demoLinks = this.appConfig?.pages_config?.book_demo?.items;\n\n    user: User;\n    blogPostTag;\n    subscriptionId;\n    linkedInUrl = this.appConfig?.social?.linkedin_url;\n    company_email = this.appConfig.company.email;\n\n    constructor(\n        private readonly resourceService: ResourceService,\n        injector: Injector,\n        private readonly sanitizer: DomSanitizer,\n        private readonly tagService: TagService,\n        private readonly toastr: CustomToastService\n    ) {\n        super(injector);\n        this.commentForm = ResourceBlog.getResourcePostsForm();\n    }\n\n    ngOnInit(): void {\n        this.masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n        this.route.params.subscribe(params => {\n            this.slug = params['slug'] ?? '';\n            this.getBlogItem(this.slug);\n        });\n        this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n                });\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n            }\n            this.getPostTags();\n        });\n    }\n\n    get hasValidDemoLinks(): boolean {\n        return (\n            Array.isArray(this.demoLinks) && this.demoLinks.some(link => link?.title ?? link?.url)\n        );\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 === 'Blog Posts');\n            });\n    }\n\n    private getBlogItem(slug: string) {\n        this.resourceService.getPostBySlug(slug).subscribe(response => {\n            let blogBody;\n            if (response?.body) {\n                blogBody = HelperService.sanitizeQuillBody(response.body, this.sanitizer);\n            }\n            const date = new Date(response?.when);\n            const formatted = date.toISOString().split('T')[0];\n            this.postComments = response.entity_comments;\n            this.post = { ...response, body: blogBody, when: formatted };\n        });\n    }\n\n    onComment() {\n        const data = { ...this.commentForm.value };\n        data.related_entity_id = this.post?.id;\n        data.related_entity_type = 'Post';\n        data.user_id = this.user?.id;\n        this.resourceService.postComments(data).subscribe(() => {\n            this.getBlogItem(this.slug);\n            this.commentForm.reset();\n            this.toastr.success(this.translation.translate('Resource.Posts.CommentAdded'));\n        });\n    }\n\n    trackByComment(_index: number, item: { id: number }) {\n        return item.id;\n    }\n}\n","\n\n<section class=\"resource-body-section\">\n  <div class=\"container\">\n    <div class=\"ql-snow body-quill\"\n    >\n    <div class=\"ql-editor body post-body-text\"\n      [innerHTML]=\"post?.body\">\n    </div>\n  </div>\n  <section class=\"nce-offer-section\">\n\n      <div class=\"row mt-5 mb-4 response-row\">\n        <div class=\"col-12\">\n          <form\n            class=\"p-fluid mb-5\"\n            [formGroup]=\"commentForm\"\n            (ngSubmit)=\"onComment()\"\n            *ngIf=\"userLoggedIn; else userLoggedOut\"\n          >\n            <div class=\"card shadow-sm border-0 p-4\">\n              <div class=\"field\">\n                <label for=\"comment\" class=\"font-bold text-lg mb-4 comment-label\">💬 Leave a comment</label>\n                <textarea\n                  pInputTextarea\n                  formControlName=\"comment\"\n                  rows=\"6\"\n                  autoResize=\"true\"\n                  class=\"p-inputtext p-component p-inputtextarea\"\n                  placeholder=\"What's on your mind?\"\n                ></textarea>\n                <small\n                  class=\"text-danger\"\n                  *ngIf=\"commentForm.get('comment')?.invalid && commentForm.get('comment')?.touched\"\n                  >Please enter comment</small\n                >\n              </div>\n              <div class=\"text-end mt-3\">\n                <button type=\"submit\"\n                [buttonBusy]=\"buttonBusy\"\n                class=\"sign-btn sign-header-btn\">\n                {{ 'Button.Submit' | transloco }}\n              </button>\n              </div>\n            </div>\n          </form>\n          <ng-template #userLoggedOut>\n            <p class=\"text-center pt-3 pb-3 user-not-logged-in text-muted shadow-sm mb-5\">\n              <a [routerLink]=\"['/login']\" class=\"text-primary fw-bold\">Log in</a> to leave a comment!\n            </p>\n          </ng-template>\n        </div>\n      </div>\n\n      <div class=\"row mt-5 comment-row\">\n        <div class=\"col-12\" *ngFor=\"let comment of postComments; trackBy: trackByComment\">\n          <div class=\"card border-0 shadow-sm p-3 mb-3\">\n            <div class=\"d-flex align-items-start\">\n              <img\n                [src]=\"comment?.author?.avatar?.[0]?.url || 'assets/img/icons/male.png'\"\n                alt=\"avatar\"\n                class=\"rounded-circle me-3\"\n                width=\"50\"\n                height=\"50\"\n                (error)=\"handleImageError($event, 'assets/img/icons/male.png')\"\n              />\n              <div class=\"flex-grow-1\">\n                <div class=\"fw-bold text-dark\">\n                  {{ comment.user?.first_name || '' }} {{ comment.user?.last_name || '' }}\n                </div>\n                <div class=\"text-muted small mb-2\">{{ comment.created_at | date: 'dd MMM yyyy, h:mm a' }}</div>\n                <div class=\"text-body\">\n                  {{ comment.comment }}\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n\n\n  </section>\n  </div>\n  <hr class=\"nce-divider\" />\n</section>\n\n<section class=\"nce-book-section\" *ngIf=\"hasValidDemoLinks\">\n  <div class=\"container\">\n\n    <p class=\"nce-contact\">\n      Any questions, get in touch <a href=\"mailto:{{ company_email }}\">here</a>,\n      <a [href]=\"linkedInUrl\" target=\"_blank\">connect on LinkedIn</a>, or book a meeting below:\n    </p>\n  </div>\n  <pw-book-a-demo [isBlog]=\"true\"></pw-book-a-demo>\n  <hr class=\"nce-divider\" />\n</section>\n\n\n<pw-resource-cards *ngIf=\"blogPostTag?.tag_category_id\" [tag]=\"blogPostTag\" [categoryId]=\"blogPostTag?.tag_category_id\" [resourceTitle]=\"blogPostTag?.title\" [isHeaderVisible]=\"true\" resourceLink=\"/resources/blogs\" [isRelated]=\"true\" [resourceTitle]=\"'Other resources you may be interested in:'\"></pw-resource-cards>\n"]}
@@ -67,11 +67,11 @@ export class ResourceCardComponent extends AppBaseComponent {
67
67
  });
68
68
  }
69
69
  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.TagService }], target: i0.ɵɵFactoryTarget.Component }); }
70
- 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()\" 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 <h5 class=\"badge-title fw-bold\">REPLAY:</h5>\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:1rem 3rem!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" }] }); }
70
+ 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()\" 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:1rem 3rem!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
71
  }
72
72
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceCardComponent, decorators: [{
73
73
  type: Component,
74
- args: [{ selector: 'pw-resource-cards', 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()\" 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 <h5 class=\"badge-title fw-bold\">REPLAY:</h5>\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:1rem 3rem!important}}\n"] }]
74
+ args: [{ selector: 'pw-resource-cards', 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()\" 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:1rem 3rem!important}}\n"] }]
75
75
  }], ctorParameters: () => [{ type: i0.Injector }, { type: i1.ResourceService }, { type: i2.TagService }], propDecorators: { categoryId: [{
76
76
  type: Input
77
77
  }], isHeaderVisible: [{
@@ -89,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
89
89
  }], resourceLink: [{
90
90
  type: Input
91
91
  }] } });
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 { TagService } from '@posiwise/common-services';\nimport { Resource, TOKEN_KEY, 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 tagService: TagService\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\n        this.localStorage.getItem$(TOKEN_KEY).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()\" 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        <h5 class=\"badge-title fw-bold\">REPLAY:</h5>\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>"]}
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 { TagService } from '@posiwise/common-services';\nimport { Resource, TOKEN_KEY, 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 tagService: TagService\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\n        this.localStorage.getItem$(TOKEN_KEY).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()\" 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>"]}
@@ -58,7 +58,6 @@ export class ResourceVideoCardComponent extends AppBaseComponent {
58
58
  }
59
59
  getPosts(page, pageSize) {
60
60
  this.isLoaded = false;
61
- console.log('pop', this.categoryId);
62
61
  this.resourceService
63
62
  .getPublicPosts(this.subscriptionId || this.masterSubscriptionId, page, pageSize, '', this.categoryId)
64
63
  .subscribe(response => {
@@ -107,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
107
106
  }], resourceTitle: [{
108
107
  type: Input
109
108
  }] } });
110
- //# 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 { TagService } from '@posiwise/common-services';\nimport { Resource, TOKEN_KEY, 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 tagService: TagService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\n        this.localStorage.getItem$(TOKEN_KEY).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        console.log('pop', this.categoryId);\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()\" 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"]}
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 { TagService } from '@posiwise/common-services';\nimport { Resource, TOKEN_KEY, 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 tagService: TagService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\n        this.localStorage.getItem$(TOKEN_KEY).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()\" 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"]}