@posiwise/resource-module 0.0.143 → 0.0.145

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/esm2022/lib/public/components/base/base-resource.component.mjs +7 -3
  2. package/esm2022/lib/public/components/base/base-top-banner.component.mjs +7 -4
  3. package/esm2022/lib/public/components/reslease-note-card/release-note-card.component.mjs +14 -7
  4. package/esm2022/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.mjs +11 -4
  5. package/esm2022/lib/public/components/resource-integration/resource-integration.component.mjs +16 -8
  6. package/esm2022/lib/public/components/resource-post/related-resources/related-resources.component.mjs +13 -6
  7. package/esm2022/lib/public/components/resource-post/related-resources/resource-cards/resource-cards.component.mjs +11 -4
  8. package/esm2022/lib/public/components/resource-release-notes/resource-release-notes.component.mjs +14 -3
  9. package/esm2022/lib/public/components/resource-vault/resource-vault.component.mjs +3 -3
  10. package/esm2022/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.mjs +11 -4
  11. package/esm2022/lib/public/components/resource-webinars/replay-event-cards/replay-event-cards.component.mjs +12 -4
  12. package/esm2022/lib/public/components/resource-webinars/resource-webinars.component.mjs +12 -4
  13. package/esm2022/lib/public/components/resource-webinars/upcoming-event-cards/upcoming-event-cards.component.mjs +13 -6
  14. package/esm2022/lib/public/components/resources/resource-tags/resource-tags.component.mjs +11 -3
  15. package/esm2022/lib/public/components/resources/vault-section/vault-section.component.mjs +25 -3
  16. package/esm2022/lib/public/components/resources-hub/resources-hub.component.mjs +12 -5
  17. package/fesm2022/posiwise-resource-module.mjs +170 -55
  18. package/fesm2022/posiwise-resource-module.mjs.map +1 -1
  19. package/lib/public/components/base/base-resource.component.d.ts +1 -0
  20. package/lib/public/components/base/base-top-banner.component.d.ts +1 -0
  21. package/lib/public/components/reslease-note-card/release-note-card.component.d.ts +3 -0
  22. package/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.d.ts +3 -0
  23. package/lib/public/components/resource-integration/resource-integration.component.d.ts +3 -0
  24. package/lib/public/components/resource-post/related-resources/related-resources.component.d.ts +3 -0
  25. package/lib/public/components/resource-post/related-resources/resource-cards/resource-cards.component.d.ts +3 -0
  26. package/lib/public/components/resource-release-notes/resource-release-notes.component.d.ts +5 -1
  27. package/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.d.ts +3 -0
  28. package/lib/public/components/resource-webinars/replay-event-cards/replay-event-cards.component.d.ts +3 -0
  29. package/lib/public/components/resource-webinars/resource-webinars.component.d.ts +3 -0
  30. package/lib/public/components/resource-webinars/upcoming-event-cards/upcoming-event-cards.component.d.ts +3 -0
  31. package/lib/public/components/resources/resource-tags/resource-tags.component.d.ts +3 -0
  32. package/lib/public/components/resources/vault-section/vault-section.component.d.ts +10 -3
  33. package/lib/public/components/resources-hub/resources-hub.component.d.ts +3 -0
  34. package/package.json +1 -1
@@ -1,6 +1,7 @@
1
1
  import { Component, Injector } from '@angular/core';
2
2
  import { AppBaseComponent } from '@posiwise/app-base-component';
3
3
  import { AuthService, TagService } from '@posiwise/common-services';
4
+ import { HelperService } from '@posiwise/helper-service';
4
5
  import { ResourceService } from '../../../resource.service';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "../../../resource.service";
@@ -29,9 +30,12 @@ export class BaseResourceComponent extends AppBaseComponent {
29
30
  });
30
31
  this.userService.getUserInfo().subscribe(data => {
31
32
  this.user = data;
33
+ this.initializeComponent();
32
34
  });
33
35
  }
34
- this.initializeComponent();
36
+ else {
37
+ this.initializeComponent();
38
+ }
35
39
  });
36
40
  }
37
41
  initializeComponent() {
@@ -103,7 +107,7 @@ export class BaseResourceComponent extends AppBaseComponent {
103
107
  }
104
108
  /** Helper method to get effective subscription ID */
105
109
  getEffectiveSubscriptionId() {
106
- return this.subscriptionId || this.masterSubscriptionId;
110
+ return HelperService.getEffectiveSubscriptionId(this.user, this.subscriptionId, this.masterSubscriptionId);
107
111
  }
108
112
  // Optional methods that can be overridden
109
113
  getSearchTerm() {
@@ -124,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
124
128
  template: ''
125
129
  }]
126
130
  }], ctorParameters: () => [{ type: i1.ResourceService }, { type: i2.TagService }, { type: i2.AuthService }, { type: i0.Injector }] });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-resource.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/base/base-resource.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAU,MAAM,eAAe,CAAC;AAE5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAGpE,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;;;;AAK5D,MAAM,OAAgB,qBAAsB,SAAQ,gBAAgB;IAYhE,YACuB,eAAgC,EAChC,UAAsB,EACxB,WAAwB,EACzC,QAAkB;QAElB,KAAK,CAAC,QAAQ,CAAC,CAAC;QALG,oBAAe,GAAf,eAAe,CAAiB;QAChC,eAAU,GAAV,UAAU,CAAY;QACxB,gBAAW,GAAX,WAAW,CAAa;QAb7C,yBAAoB,GAAG,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,eAAe,CAAC;QAC1E,UAAK,GAAe,EAAE,CAAC;QACvB,sBAAiB,GAAe,EAAE,CAAC;QAKnC,aAAQ,GAAG,KAAK,CAAC;IAUjB,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,qBAAqB,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;YAC9C,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC;QACnC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YACzC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,GAAG,CAAC;YAC1B,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBAClD,MAAM,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;oBAC1C,IAAI,CAAC,cAAc,GAAG,IAAI,EAAE,cAAc,CAAC;gBAC/C,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;oBAC5C,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;gBACrB,CAAC,CAAC,CAAC;YACP,CAAC;YACD,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC/B,CAAC,CAAC,CAAC;IACP,CAAC;IAES,mBAAmB;QACzB,IAAI,IAAI,CAAC,sBAAsB,EAAE,EAAE,CAAC;YAChC,IAAI,CAAC,OAAO,EAAE,CAAC;QACnB,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,WAAW,EAAE,CAAC;QACvB,CAAC;QAED,IAAI,IAAI,CAAC,sBAAsB,EAAE,EAAE,CAAC;YAChC,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC9B,CAAC;IACL,CAAC;IAES,OAAO;QACb,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,UAAU;aACV,mBAAmB,CAChB,EAAE,MAAM,EAAE,IAAI,CAAC,aAAa,EAAE,EAAE,EAChC,IAAI,CAAC,0BAA0B,EAAE,CACpC;aACA,SAAS,CAAC,QAAQ,CAAC,EAAE;YAClB,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;YAC9C,IAAI,CAAC,WAAW,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;IACX,CAAC;IAES,WAAW;QACjB,IAAI,CAAC,UAAU;aACV,aAAa,CAAC,iBAAiB,EAAE,EAAE,EAAE,IAAI,CAAC,0BAA0B,EAAE,CAAC;aACvE,SAAS,CAAC,QAAQ,CAAC,EAAE;YAClB,IAAI,IAAI,CAAC,sBAAsB,EAAE,EAAE,CAAC;gBAChC,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CACjC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,eAAe,KAAK,IAAI,CAAC,WAAW,EAAE,EAAE,CACtD,CAAC;YACN,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CACjC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,IAAI,CAAC,eAAe,EAAE,CAC7C,CAAC;YACN,CAAC;YACD,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAC1B,CAAC,CAAC;aACD,GAAG,CAAC,GAAG,EAAE;YACN,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACzB,CAAC,CAAC,CAAC;IACX,CAAC;IAES,kBAAkB;QACxB,IAAI,CAAC,UAAU;aACV,aAAa,CAAC,iBAAiB,EAAE,EAAE,EAAE,IAAI,CAAC,0BAA0B,EAAE,CAAC;aACvE,SAAS,CAAC,QAAQ,CAAC,EAAE;YAClB,IAAI,CAAC,uBAAuB,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAC7C,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,cAAc,CACrC,CAAC;YACF,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;IACX,CAAC;IAES,QAAQ,CAAC,IAAY,EAAE,QAAgB;QAC7C,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,WAAW,EAAE,eAAe,EAAE,OAAO,CAAC,CAAC;IAChF,CAAC;IAED,oBAAoB,CAAC,IAAY,EAAE,QAAgB;QAC/C,IAAI,CAAC,UAAU,CACX,IAAI,EACJ,QAAQ,EACR,IAAI,CAAC,uBAAuB,EAAE,eAAe,EAC7C,mBAAmB,CACtB,CAAC;IACN,CAAC;IAED,qFAAqF;IAC7E,UAAU,CACd,IAAY,EACZ,QAAgB,EAChB,aAAa,EACb,cAA6C;QAE7C,IAAI,CAAC,eAAe;aACf,cAAc,CAAC,IAAI,CAAC,0BAA0B,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,aAAa,CAAC;aACpF,SAAS,CAAC,QAAQ,CAAC,EAAE;YAClB,MAAM,aAAa,GAAG,QAAQ,CAAC,KAAK;iBAC/B,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,eAAe,KAAK,aAAa,CAAC,CAAC;iBAC7E,IAAI,CACD,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACL,IAAI,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE,CAC9E;iBACA,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAElB,IAAI,cAAc,KAAK,OAAO,EAAE,CAAC;gBAC7B,IAAI,CAAC,KAAK,GAAG,aAAa,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,iBAAiB,GAAG,aAAa,CAAC;YAC3C,CAAC;QACL,CAAC,CAAC,CAAC;IACX,CAAC;IAED,qDAAqD;IAC3C,0BAA0B;QAChC,OAAO,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,oBAAoB,CAAC;IAC5D,CAAC;IAKD,0CAA0C;IAChC,aAAa;QACnB,OAAO,IAAI,CAAC,eAAe,EAAE,CAAC;IAClC,CAAC;IAES,sBAAsB;QAC5B,OAAO,KAAK,CAAC;IACjB,CAAC;IAES,sBAAsB;QAC5B,OAAO,KAAK,CAAC;IACjB,CAAC;+GA1JiB,qBAAqB;mGAArB,qBAAqB,2EAF7B,EAAE;;4FAEM,qBAAqB;kBAH1C,SAAS;mBAAC;oBACP,QAAQ,EAAE,EAAE;iBACf","sourcesContent":["import { Component, Injector, OnInit } from '@angular/core';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    template: ''\n})\nexport abstract class BaseResourceComponent extends AppBaseComponent implements OnInit {\n    subscriptionId: number;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n    posts: Resource[] = [];\n    testimonialsPosts: Resource[] = [];\n    userLoggedIn: boolean;\n    blogPostTag;\n    tagCategory;\n    blogTestimonialsPostTag;\n    isLoaded = false;\n    user: User;\n\n    constructor(\n        protected readonly resourceService: ResourceService,\n        protected readonly tagService: TagService,\n        private readonly authService: AuthService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        this.getUserSubscriptionId().subscribe(response => {\n            this.subscriptionId = response;\n        });\n        this.authService.getToken$().subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n                });\n            }\n            this.initializeComponent();\n        });\n    }\n\n    protected initializeComponent() {\n        if (this.shouldUseTagCategories()) {\n            this.getTags();\n        } else {\n            this.getPostTags();\n        }\n\n        if (this.shouldLoadTestimonials()) {\n            this.getTestimonialTags();\n        }\n    }\n\n    protected getTags() {\n        this.isLoaded = false;\n        this.tagService\n            .getAllTagCategories(\n                { search: this.getSearchTerm() },\n                this.getEffectiveSubscriptionId()\n            )\n            .subscribe(response => {\n                this.tagCategory = response.tag_categories[0];\n                this.getPostTags();\n            });\n    }\n\n    protected getPostTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())\n            .subscribe(response => {\n                if (this.shouldUseTagCategories()) {\n                    this.blogPostTag = response.tags.find(\n                        tag => tag.tag_category_id === this.tagCategory?.id\n                    );\n                } else {\n                    this.blogPostTag = response.tags.find(\n                        tag => tag.name === this.getResourceType()\n                    );\n                }\n                this.getPosts(1, 100);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    protected getTestimonialTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())\n            .subscribe(response => {\n                this.blogTestimonialsPostTag = response.tags.find(\n                    tag => tag.name === 'Testimonials'\n                );\n                this.getTestimonialsPosts(1, 100);\n            });\n    }\n\n    protected getPosts(page: number, pageSize: number) {\n        this.fetchPosts(page, pageSize, this.blogPostTag?.tag_category_id, 'posts');\n    }\n\n    getTestimonialsPosts(page: number, pageSize: number) {\n        this.fetchPosts(\n            page,\n            pageSize,\n            this.blogTestimonialsPostTag?.tag_category_id,\n            'testimonialsPosts'\n        );\n    }\n\n    /** Shared method to fetch posts with common filtering, sorting, and slicing logic */\n    private fetchPosts(\n        page: number,\n        pageSize: number,\n        tagCategoryId,\n        targetProperty: 'posts' | 'testimonialsPosts'\n    ) {\n        this.resourceService\n            .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', tagCategoryId)\n            .subscribe(response => {\n                const filteredPosts = response.posts\n                    .filter(post => post.tags?.some(tag => tag.tag_category_id === tagCategoryId))\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    )\n                    .slice(0, 12);\n\n                if (targetProperty === 'posts') {\n                    this.posts = filteredPosts;\n                } else {\n                    this.testimonialsPosts = filteredPosts;\n                }\n            });\n    }\n\n    /** Helper method to get effective subscription ID */\n    protected getEffectiveSubscriptionId(): number {\n        return this.subscriptionId || this.masterSubscriptionId;\n    }\n\n    // Abstract methods that each component must implement\n    protected abstract getResourceType(): string;\n\n    // Optional methods that can be overridden\n    protected getSearchTerm(): string {\n        return this.getResourceType();\n    }\n\n    protected shouldUseTagCategories(): boolean {\n        return false;\n    }\n\n    protected shouldLoadTestimonials(): boolean {\n        return false;\n    }\n}\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-resource.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/base/base-resource.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, OnInit } from '@angular/core';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    template: ''\n})\nexport abstract class BaseResourceComponent extends AppBaseComponent implements OnInit {\n    subscriptionId: number;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n    posts: Resource[] = [];\n    testimonialsPosts: Resource[] = [];\n    userLoggedIn: boolean;\n    blogPostTag;\n    tagCategory;\n    blogTestimonialsPostTag;\n    isLoaded = false;\n    user: User;\n    isMasterSubscription;\n\n    constructor(\n        protected readonly resourceService: ResourceService,\n        protected readonly tagService: TagService,\n        private readonly authService: AuthService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        this.getUserSubscriptionId().subscribe(response => {\n            this.subscriptionId = response;\n        });\n        this.authService.getToken$().subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n\n                    this.initializeComponent();\n                });\n            } else {\n                this.initializeComponent();\n            }\n        });\n    }\n\n    protected initializeComponent() {\n        if (this.shouldUseTagCategories()) {\n            this.getTags();\n        } else {\n            this.getPostTags();\n        }\n\n        if (this.shouldLoadTestimonials()) {\n            this.getTestimonialTags();\n        }\n    }\n\n    protected getTags() {\n        this.isLoaded = false;\n        this.tagService\n            .getAllTagCategories(\n                { search: this.getSearchTerm() },\n                this.getEffectiveSubscriptionId()\n            )\n            .subscribe(response => {\n                this.tagCategory = response.tag_categories[0];\n                this.getPostTags();\n            });\n    }\n\n    protected getPostTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())\n            .subscribe(response => {\n                if (this.shouldUseTagCategories()) {\n                    this.blogPostTag = response.tags.find(\n                        tag => tag.tag_category_id === this.tagCategory?.id\n                    );\n                } else {\n                    this.blogPostTag = response.tags.find(\n                        tag => tag.name === this.getResourceType()\n                    );\n                }\n                this.getPosts(1, 100);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    protected getTestimonialTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())\n            .subscribe(response => {\n                this.blogTestimonialsPostTag = response.tags.find(\n                    tag => tag.name === 'Testimonials'\n                );\n                this.getTestimonialsPosts(1, 100);\n            });\n    }\n\n    protected getPosts(page: number, pageSize: number) {\n        this.fetchPosts(page, pageSize, this.blogPostTag?.tag_category_id, 'posts');\n    }\n\n    getTestimonialsPosts(page: number, pageSize: number) {\n        this.fetchPosts(\n            page,\n            pageSize,\n            this.blogTestimonialsPostTag?.tag_category_id,\n            'testimonialsPosts'\n        );\n    }\n\n    /** Shared method to fetch posts with common filtering, sorting, and slicing logic */\n    private fetchPosts(\n        page: number,\n        pageSize: number,\n        tagCategoryId,\n        targetProperty: 'posts' | 'testimonialsPosts'\n    ) {\n        this.resourceService\n            .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', tagCategoryId)\n            .subscribe(response => {\n                const filteredPosts = response.posts\n                    .filter(post => post.tags?.some(tag => tag.tag_category_id === tagCategoryId))\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    )\n                    .slice(0, 12);\n\n                if (targetProperty === 'posts') {\n                    this.posts = filteredPosts;\n                } else {\n                    this.testimonialsPosts = filteredPosts;\n                }\n            });\n    }\n\n    /** Helper method to get effective subscription ID */\n    protected getEffectiveSubscriptionId(): number {\n        return HelperService.getEffectiveSubscriptionId(\n            this.user,\n            this.subscriptionId,\n            this.masterSubscriptionId\n        );\n    }\n\n    // Abstract methods that each component must implement\n    protected abstract getResourceType(): string;\n\n    // Optional methods that can be overridden\n    protected getSearchTerm(): string {\n        return this.getResourceType();\n    }\n\n    protected shouldUseTagCategories(): boolean {\n        return false;\n    }\n\n    protected shouldLoadTestimonials(): boolean {\n        return false;\n    }\n}\n"]}
@@ -2,6 +2,7 @@ import { Component, Injector } from '@angular/core';
2
2
  import { Title } from '@angular/platform-browser';
3
3
  import { AppBaseComponent } from '@posiwise/app-base-component';
4
4
  import { AuthService, TagService } from '@posiwise/common-services';
5
+ import { HelperService } from '@posiwise/helper-service';
5
6
  import { ResourceService } from '../../../resource.service';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "../../../resource.service";
@@ -32,9 +33,12 @@ export class BaseTopBannerComponent extends AppBaseComponent {
32
33
  });
33
34
  this.userService.getUserInfo().subscribe(data => {
34
35
  this.user = data;
36
+ this.getTags();
35
37
  });
36
38
  }
37
- this.getTags();
39
+ else {
40
+ this.getTags();
41
+ }
38
42
  });
39
43
  }
40
44
  getTags() {
@@ -59,11 +63,10 @@ export class BaseTopBannerComponent extends AppBaseComponent {
59
63
  }
60
64
  /** Helper method to get effective subscription ID */
61
65
  getEffectiveSubscriptionId() {
62
- return this.subscriptionId || this.masterSubscriptionId;
66
+ return HelperService.getEffectiveSubscriptionId(this.user, this.subscriptionId, this.masterSubscriptionId);
63
67
  }
64
68
  updateSEOMetadata() {
65
69
  if (this.blogPostTag) {
66
- console.log(this.blogPostTag);
67
70
  // Update page title if meta_title is available
68
71
  if (this.blogPostTag.meta_title) {
69
72
  this.titleService.setTitle(this.blogPostTag.meta_title);
@@ -92,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
92
95
  template: ''
93
96
  }]
94
97
  }], ctorParameters: () => [{ type: i1.ResourceService }, { type: i2.TagService }, { type: i2.AuthService }, { type: i3.Title }, { type: i0.Injector }] });
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-top-banner.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/base/base-top-banner.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, OnInit } from '@angular/core';\nimport { Title } from '@angular/platform-browser';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    template: ''\n})\nexport abstract class BaseTopBannerComponent extends AppBaseComponent implements OnInit {\n    subscriptionId: number;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n    posts: Resource[] = [];\n    testimonialsPosts = [];\n    userLoggedIn: boolean;\n    blogPostTag;\n    tagCategory;\n    blogTestimonialsPostTag;\n    isLoaded = false;\n    user: User;\n\n    constructor(\n        protected readonly resourceService: ResourceService,\n        protected readonly tagService: TagService,\n        private readonly authService: AuthService,\n        private readonly titleService: Title,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        this.getUserSubscriptionId().subscribe(response => {\n            this.subscriptionId = response;\n        });\n        this.authService.getToken$().subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n                });\n            }\n            this.getTags();\n        });\n    }\n\n    protected getTags() {\n        this.isLoaded = false;\n        this.tagService\n            .getAllTagCategories(\n                { search: this.getSearchTerm() },\n                this.getEffectiveSubscriptionId()\n            )\n            .subscribe(response => {\n                this.tagCategory = response.tag_categories[0];\n                this.getPostTags();\n            });\n    }\n\n    private getPostTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())\n            .subscribe(response => {\n                this.blogPostTag = response.tags.find(\n                    tag => tag.tag_category_id === this.tagCategory?.id\n                );\n                this.updateSEOMetadata();\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    /** Helper method to get effective subscription ID */\n    protected getEffectiveSubscriptionId(): number {\n        return this.subscriptionId || this.masterSubscriptionId;\n    }\n\n    protected updateSEOMetadata() {\n        if (this.blogPostTag) {\n            console.log(this.blogPostTag);\n            // Update page title if meta_title is available\n            if (this.blogPostTag.meta_title) {\n                this.titleService.setTitle(this.blogPostTag.meta_title);\n            }\n\n            // Update meta description if meta_description is available\n            if (this.blogPostTag.meta_description) {\n                this.updateMetaDescription(this.blogPostTag.meta_description);\n            }\n        }\n    }\n\n    private updateMetaDescription(description: string) {\n        let metaDescription = document.querySelector('meta[name=\"description\"]');\n        if (!metaDescription) {\n            metaDescription = document.createElement('meta');\n            metaDescription.setAttribute('name', 'description');\n            document.head.appendChild(metaDescription);\n        }\n        metaDescription.setAttribute('content', description);\n    }\n\n    // Abstract method that each component must implement\n    protected abstract getSearchTerm(): string;\n}\n"]}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-top-banner.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/base/base-top-banner.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, OnInit } from '@angular/core';\nimport { Title } from '@angular/platform-browser';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    template: ''\n})\nexport abstract class BaseTopBannerComponent extends AppBaseComponent implements OnInit {\n    subscriptionId: number;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n    posts: Resource[] = [];\n    testimonialsPosts = [];\n    userLoggedIn: boolean;\n    blogPostTag;\n    tagCategory;\n    blogTestimonialsPostTag;\n    isLoaded = false;\n    user: User;\n    isMasterSubscription;\n\n    constructor(\n        protected readonly resourceService: ResourceService,\n        protected readonly tagService: TagService,\n        private readonly authService: AuthService,\n        private readonly titleService: Title,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        this.getUserSubscriptionId().subscribe(response => {\n            this.subscriptionId = response;\n        });\n        this.authService.getToken$().subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n\n                    this.getTags();\n                });\n            } else {\n                this.getTags();\n            }\n        });\n    }\n\n    protected getTags() {\n        this.isLoaded = false;\n        this.tagService\n            .getAllTagCategories(\n                { search: this.getSearchTerm() },\n                this.getEffectiveSubscriptionId()\n            )\n            .subscribe(response => {\n                this.tagCategory = response.tag_categories[0];\n                this.getPostTags();\n            });\n    }\n\n    private getPostTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())\n            .subscribe(response => {\n                this.blogPostTag = response.tags.find(\n                    tag => tag.tag_category_id === this.tagCategory?.id\n                );\n                this.updateSEOMetadata();\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    /** Helper method to get effective subscription ID */\n    protected getEffectiveSubscriptionId(): number {\n        return HelperService.getEffectiveSubscriptionId(\n            this.user,\n            this.subscriptionId,\n            this.masterSubscriptionId\n        );\n    }\n\n    protected updateSEOMetadata() {\n        if (this.blogPostTag) {\n            // Update page title if meta_title is available\n            if (this.blogPostTag.meta_title) {\n                this.titleService.setTitle(this.blogPostTag.meta_title);\n            }\n\n            // Update meta description if meta_description is available\n            if (this.blogPostTag.meta_description) {\n                this.updateMetaDescription(this.blogPostTag.meta_description);\n            }\n        }\n    }\n\n    private updateMetaDescription(description: string) {\n        let metaDescription = document.querySelector('meta[name=\"description\"]');\n        if (!metaDescription) {\n            metaDescription = document.createElement('meta');\n            metaDescription.setAttribute('name', 'description');\n            document.head.appendChild(metaDescription);\n        }\n        metaDescription.setAttribute('content', description);\n    }\n\n    // Abstract method that each component must implement\n    protected abstract getSearchTerm(): string;\n}\n"]}
@@ -38,15 +38,18 @@ export class ResourceNoteCardComponent extends AppBaseComponent {
38
38
  });
39
39
  this.userService.getUserInfo().subscribe(data => {
40
40
  this.user = data;
41
+ this.getTags();
41
42
  });
42
43
  }
44
+ else {
45
+ this.getTags();
46
+ }
43
47
  });
44
- this.getTags();
45
48
  }
46
49
  getTags() {
47
50
  this.isLoaded = false;
48
51
  this.tagService
49
- .getAllTagCategories({ search: 'Release Notes' }, this.subscriptionId ?? this.masterSubscriptionId)
52
+ .getAllTagCategories({ search: 'Release Notes' }, this.getEffectiveSubscriptionId())
50
53
  .subscribe(response => {
51
54
  this.tagCategory = response.tag_categories[0];
52
55
  this.getPostTags();
@@ -54,7 +57,7 @@ export class ResourceNoteCardComponent extends AppBaseComponent {
54
57
  }
55
58
  getPostTags() {
56
59
  this.tagService
57
- .getTagsByType('post_categories', {}, this.subscriptionId ?? this.masterSubscriptionId)
60
+ .getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())
58
61
  .subscribe(response => {
59
62
  this.postTags['product'] = this.findTag(response.tags, 'Product Release Notes', this.tagCategory?.id);
60
63
  this.postTags['press'] = this.findTag(response.tags, 'Press Release Notes', this.tagCategory?.id);
@@ -86,7 +89,7 @@ export class ResourceNoteCardComponent extends AppBaseComponent {
86
89
  getProductReleasePosts(page, pageSize) {
87
90
  this.isLoaded = false;
88
91
  this.resourceService
89
- .getPublicPosts(this.subscriptionId ?? this.masterSubscriptionId, page, pageSize, '', '', this.postTags['product']?.id)
92
+ .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', '', this.postTags['product']?.id)
90
93
  .subscribe(response => {
91
94
  const sortedPosts = response.posts
92
95
  .filter(post => post.showcase === true)
@@ -100,7 +103,7 @@ export class ResourceNoteCardComponent extends AppBaseComponent {
100
103
  getPressReleasePosts(page, pageSize) {
101
104
  this.isLoaded = false;
102
105
  this.resourceService
103
- .getPublicPosts(this.subscriptionId ?? this.masterSubscriptionId, page, pageSize, '', '', this.postTags['press']?.id)
106
+ .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', '', this.postTags['press']?.id)
104
107
  .subscribe(response => {
105
108
  const sortedPosts = response?.posts
106
109
  .filter(post => post.showcase === true)
@@ -124,7 +127,7 @@ export class ResourceNoteCardComponent extends AppBaseComponent {
124
127
  this.editedTitle = this.postTags['press'].title;
125
128
  }
126
129
  saveEditedTitle(type) {
127
- HelperService.updateTagTitle(this.postTags[type], this.editedTitle, this.tagService, this.subscriptionId ?? this.masterSubscriptionId, this.toast).subscribe(() => {
130
+ HelperService.updateTagTitle(this.postTags[type], this.editedTitle, this.tagService, this.getEffectiveSubscriptionId(), this.toast).subscribe(() => {
128
131
  this.postTags[type].title = this.editedTitle;
129
132
  if (type === 'product') {
130
133
  this.isEditingTitle = false;
@@ -134,6 +137,10 @@ export class ResourceNoteCardComponent extends AppBaseComponent {
134
137
  }
135
138
  });
136
139
  }
140
+ /** Helper method to get effective subscription ID */
141
+ getEffectiveSubscriptionId() {
142
+ return HelperService.getEffectiveSubscriptionId(this.user, this.subscriptionId, this.masterSubscriptionId);
143
+ }
137
144
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceNoteCardComponent, deps: [{ token: i0.Injector }, { token: i1.ResourceService }, { token: i2.AuthService }, { token: i2.TagService }], target: i0.ɵɵFactoryTarget.Component }); }
138
145
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ResourceNoteCardComponent, selector: "pw-resource-note-card", inputs: { releaseHeader: "releaseHeader", categoryId: "categoryId", isReleasePress: "isReleasePress", postSlice: "postSlice", resourceTitle: "resourceTitle", tag: "tag" }, usesInheritance: true, ngImport: i0, template: "<section class=\"msp-vault-section bg-white\" *ngIf=\"hasProductReleases()\">\n <div class=\"container\">\n <div 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=\"postTags['product']?.title; else fallback\" [innerHTML]=\"postTags['product']?.title\"></span>\n <ng-template #fallback>Product Release Notes</ng-template>\n <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleEditTitle()\" (keydown.enter)=\"toggleEditTitle()\" (keydown.space)=\"toggleEditTitle()\" title=\"Edit Title\"></i>\n </ng-container>\n\n <ng-template #editTitleBlock>\n <input [(ngModel)]=\"editedTitle\" class=\"form-control d-inline w-auto me-2\" [ngClass]=\"{ 'w-100': isEditingTitle }\" />\n <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle('product')\">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\" *ngIf=\"!postSlice\" routerLink=\"/resources/release-notes\">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=\"releasePosts['product']?.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 gap-4 video-row\" *ngIf=\"hasProductReleases()\">\n <div class=\"resource-blog-card p-4\" *ngFor=\"let post of releasePosts['product']\">\n <pw-resource-edit-card\n *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n [id]=\"post.id\"\n [resourceData]=\"post\"\n (updated)=\"getProductReleasePosts(1, 100)\"></pw-resource-edit-card>\n <p class=\"resource-title\" [innerHTML]=\"post.title\"></p>\n <img *ngIf=\"!post.picture?.url?.includes('default-photo.jpg'); else resourceRocketBox\"\n src=\"{{ post.picture.url }}\"\n class=\"resource-image mt-auto\"\n alt=\"Product Resource Icon\" />\n\n <ng-template #resourceRocketBox>\n <img\n src=\"assets/img/resource/rocket-box.png\"\n class=\"press-release-icon mt-auto\"\n alt=\"Product Resource Default Icon\" />\n </ng-template>\n <ng-template #ctaContent>\n <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now' }}</span>\n <span class=\"arrow\">\u2192</span>\n </ng-template>\n <a *ngIf=\"post?.external_url; else internalLink\"\n class=\"resource-btn mt-3\"\n aria-label=\"Navigate to external url\"\n [href]=\"post.external_url\"\n target=\"_blank\"\n rel=\"noopener noreferrer\">\n <ng-container *ngTemplateOutlet=\"ctaContent\"></ng-container>\n </a>\n\n <ng-template #internalLink>\n <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n <ng-container *ngTemplateOutlet=\"ctaContent\"></ng-container>\n </a>\n </ng-template>\n </div>\n </div>\n </div>\n</section>\n<section class=\"msp-vault-section bg-white\" *ngIf=\"isReleasePress && hasPressReleases()\">\n <div class=\"container\">\n <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\n <h2 class=\"section-heading d-flex align-items-center\" [ngClass]=\"{ 'w-50': isPressEditingTitle }\">\n <ng-container *ngIf=\"!isPressEditingTitle; else editTitleBlock\">\n <span *ngIf=\"postTags['press']?.title; else fallback\" [innerHTML]=\"postTags['press']?.title\"></span>\n <ng-template #fallback>Press Release Notes</ng-template>\n <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleEditPressTitle()\" (keydown.enter)=\"toggleEditPressTitle()\" (keydown.space)=\"toggleEditPressTitle()\" 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': isPressEditingTitle }\" />\n <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle('press')\">Save</button>\n <button class=\"btn btn-sm btn-secondary\" (click)=\"isPressEditingTitle = false\">Cancel</button>\n </ng-template>\n </h2>\n <a *ngIf=\"!postSlice\" class=\"view-all\" routerLink=\"/resources/release-notes\">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=\"releasePosts['press']?.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 gap-4 video-row\" *ngIf=\"hasPressReleases()\">\n <div class=\"resource-blog-card p-4\" *ngFor=\"let post of releasePosts['press']\">\n <pw-resource-edit-card\n*ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n [id]=\"post.id\"\n [resourceData]=\"post\"\n (updated)=\"getPressReleasePosts(1, 100)\"></pw-resource-edit-card>\n <p class=\"resource-title\" [innerHTML]=\"post.title\"></p>\n <img *ngIf=\"!post.picture?.url.includes('default-photo.jpg'); else resourceRocketBox\"\n src=\"{{ post.picture.url }}\"\n class=\"resource-image mt-auto\"\n alt=\"Press Resource Icon\" />\n\n <ng-template #resourceRocketBox>\n <img\n src=\"assets/img/resource/rocket-box.png\"\n class=\"press-release-icon mt-auto\"\n alt=\"Press Resource Default Icon\" />\n </ng-template>\n <a *ngIf=\"post?.external_url; else internalLink\"\n class=\"resource-btn mt-3\"\n aria-label=\"Navigate to external url\"\n [href]=\"post.external_url\"\n target=\"_blank\"\n rel=\"noopener noreferrer\">\n <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now' }}</span>\n <span class=\"arrow\">\u2192</span>\n </a>\n\n <ng-template #internalLink>\n <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now' }}</span>\n <span class=\"arrow\">\u2192</span>\n </a>\n </ng-template>\n </div>\n </div>\n </div>\n</section>\n", styles: [".bold{font-weight:700}.nce-heading{margin-bottom:2rem}.nce-note{margin-top:1rem;font-size:.85rem;color:#555}.nce-divider{border:0;height:40px;width:100%;background:linear-gradient(to bottom,#0000,#00000026);margin:0}.press-release-icon{height:auto!important;margin:0 11px 1.9rem;display:block;align-self:center;width:auto!important;aspect-ratio:0!important;object-fit:cover;margin-top:auto;margin-right:0!important}.msp-vault-section{padding:60px 0;background:#fff;padding-bottom:9rem!important;padding-top:7rem!important;box-shadow:0 4px 32px -14px #40576d4d!important}.msp-vault-section .vault-heading{font-size:3rem;font-weight:300}.msp-vault-section .explore-link{color:#000;font-weight:400;text-decoration:none;font-size:1.5rem}.msp-vault-section .resource-blog-card{display:flex;flex-direction:column;justify-content:space-between;background-color:#fff;border-radius:30px;box-shadow:0 20px 40px #00000014;padding:25px;text-align:center;width:338px;height:auto!important}.msp-vault-section .resource-blog-card h5{font-size:1.5rem;font-weight:400;margin-bottom:.5rem;color:var(--text-color, black)}.msp-vault-section .resource-blog-card p{font-size:1.5rem;color:var(--text-color, black);line-height:2rem}.msp-vault-section .resource-blog-card img{width:100%;border-radius:10px;aspect-ratio:1/1;object-fit:cover;margin-top:auto;margin-right:0!important;max-width:250px!important;align-self:center!important}.msp-vault-section .resource-blog-card iframe{height:210px;border-radius:10px;object-fit:cover;margin-right:0!important;max-width:280px!important}.msp-vault-section .resource-blog-card .resource-btn{background-color:var(--text-color, black);color:#fff;margin-top:auto;padding:10px 24px;border-radius:24px;font-size:1.5rem;font-weight:500;width:100%;max-width:240px;cursor:pointer;transition:background .3s ease;display:flex;justify-content:space-between;align-self:center;align-items:center;text-align:left;text-decoration:none;border:1px solid;box-shadow:none!important;border-color:var(--text-color, black)}.msp-vault-section .resource-blog-card .resource-btn:hover{background:#fff;color:var(--text-color, black)!important}.msp-vault-section .vault-description{text-align:left;max-width:657px;color:#182527;line-height:2.3rem!important;font-size:1.65rem}@media (width <= 1200px){.msp-vault-section .vault-heading{font-size:3.5rem}.msp-vault-section .vault-description{margin-top:1.35rem}.msp-vault-section .resource-btn{margin-left:0!important}}.video-row{gap:5.5rem!important;margin-top:3rem!important}@media (width >= 991px){section.bg-white.text-center.extra-top-padding{position:relative;overflow:hidden}section.bg-white.text-center.extra-top-padding .banner-header{margin-bottom:4rem!important}}.vault-header{text-align:left}@media (width >= 768px) and (width <= 1200px){.container{padding:0 6rem!important}}@media (width <= 768px){.video-row{gap:3rem!important}}@media (width <= 768px){.vault-header{text-align:center!important}.vault-heading{font-size:3rem!important}}@media (width <= 1200px){.container{padding:7rem 3rem 1rem!important}}\n"], dependencies: [{ kind: "directive", type: i3.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: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { 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" }] }); }
139
146
  }
@@ -153,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
153
160
  }], tag: [{
154
161
  type: Input
155
162
  }] } });
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"release-note-card.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/reslease-note-card/release-note-card.component.ts","../../../../../../../../libs/resource-module/src/lib/public/components/reslease-note-card/release-note-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    selector: 'pw-resource-note-card',\n    templateUrl: './release-note-card.component.html',\n    styleUrls: ['../resources/resources-shared.component.scss']\n})\nexport class ResourceNoteCardComponent extends AppBaseComponent implements OnInit {\n    @Input() releaseHeader = false;\n    @Input() categoryId!: string;\n    @Input() isReleasePress = false;\n    @Input() postSlice = false;\n    @Input() resourceTitle!: string;\n    @Input() tag;\n\n    userLoggedIn: boolean;\n    isLoaded = false;\n    subscriptionId;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n\n    postTags: { [key: string]: { id: string; title: string } } = {};\n    releasePosts: { [key: string]: Resource[] } = {};\n\n    tagCategory;\n    isEditingTitle: boolean;\n    isPressEditingTitle: boolean;\n    editedTitle: string;\n    user: User;\n\n    constructor(\n        injector: Injector,\n        private readonly resourceService: ResourceService,\n        private readonly authService: AuthService,\n        private readonly tagService: TagService\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\n        this.authService.getToken$().subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n                });\n            }\n        });\n        this.getTags();\n    }\n\n    private getTags() {\n        this.isLoaded = false;\n        this.tagService\n            .getAllTagCategories(\n                { search: 'Release Notes' },\n                this.subscriptionId ?? this.masterSubscriptionId\n            )\n            .subscribe(response => {\n                this.tagCategory = response.tag_categories[0];\n                this.getPostTags();\n            });\n    }\n\n    private getPostTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.subscriptionId ?? this.masterSubscriptionId)\n            .subscribe(response => {\n                this.postTags['product'] = this.findTag(\n                    response.tags,\n                    'Product Release Notes',\n                    this.tagCategory?.id\n                );\n                this.postTags['press'] = this.findTag(\n                    response.tags,\n                    'Press Release Notes',\n                    this.tagCategory?.id\n                );\n\n                if (this.postTags['product']?.id) {\n                    this.getProductReleasePosts(1, 100);\n                } else {\n                    this.isLoaded = true;\n                    this.releasePosts['product'] = [];\n                }\n\n                if (this.postTags['press']?.id) {\n                    this.getPressReleasePosts(1, 100);\n                } else {\n                    this.isLoaded = true;\n                    this.releasePosts['press'] = [];\n                }\n            });\n    }\n\n    private findTag(tags, name: string, categoryId: number) {\n        return tags.find(tag => tag.name === name && tag.tag_category_id === categoryId);\n    }\n\n    hasPressReleases(): boolean {\n        return this.releasePosts['press']?.length !== 0 && this.isLoaded;\n    }\n    hasProductReleases(): boolean {\n        return this.releasePosts['product']?.length !== 0 && this.isLoaded;\n    }\n\n    getProductReleasePosts(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                '',\n                this.postTags['product']?.id\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.releasePosts['product'] = this.getProcessedPosts(sortedPosts);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    getPressReleasePosts(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                '',\n                this.postTags['press']?.id\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.releasePosts['press'] = this.getProcessedPosts(sortedPosts);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    private getProcessedPosts(posts: Resource[], sliceCount = 3): Resource[] {\n        const cloned = [...posts];\n        return this.postSlice ? cloned.reverse() : cloned.slice(0, sliceCount).reverse();\n    }\n\n    toggleEditTitle() {\n        this.isEditingTitle = true;\n        this.editedTitle = this.postTags['product'].title;\n    }\n\n    toggleEditPressTitle() {\n        this.isPressEditingTitle = true;\n        this.editedTitle = this.postTags['press'].title;\n    }\n\n    saveEditedTitle(type) {\n        HelperService.updateTagTitle(\n            this.postTags[type],\n            this.editedTitle,\n            this.tagService,\n            this.subscriptionId ?? this.masterSubscriptionId,\n            this.toast\n        ).subscribe(() => {\n            this.postTags[type].title = this.editedTitle;\n            if (type === 'product') {\n                this.isEditingTitle = false;\n            } else {\n                this.isPressEditingTitle = false;\n            }\n        });\n    }\n}\n","<section class=\"msp-vault-section bg-white\" *ngIf=\"hasProductReleases()\">\n  <div class=\"container\">\n    <div 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=\"postTags['product']?.title; else fallback\" [innerHTML]=\"postTags['product']?.title\"></span>\n          <ng-template #fallback>Product Release Notes</ng-template>\n          <i  *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleEditTitle()\" (keydown.enter)=\"toggleEditTitle()\" (keydown.space)=\"toggleEditTitle()\" title=\"Edit Title\"></i>\n        </ng-container>\n\n        <ng-template #editTitleBlock>\n          <input [(ngModel)]=\"editedTitle\" class=\"form-control d-inline w-auto me-2\" [ngClass]=\"{ 'w-100': isEditingTitle }\" />\n          <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle('product')\">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\" *ngIf=\"!postSlice\" routerLink=\"/resources/release-notes\">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=\"releasePosts['product']?.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 gap-4 video-row\" *ngIf=\"hasProductReleases()\">\n        <div class=\"resource-blog-card p-4\" *ngFor=\"let post of releasePosts['product']\">\n          <pw-resource-edit-card\n          *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          [id]=\"post.id\"\n          [resourceData]=\"post\"\n          (updated)=\"getProductReleasePosts(1, 100)\"></pw-resource-edit-card>\n          <p class=\"resource-title\" [innerHTML]=\"post.title\"></p>\n          <img *ngIf=\"!post.picture?.url?.includes('default-photo.jpg'); else resourceRocketBox\"\n          src=\"{{ post.picture.url }}\"\n          class=\"resource-image mt-auto\"\n          alt=\"Product Resource Icon\" />\n\n     <ng-template #resourceRocketBox>\n      <img\n      src=\"assets/img/resource/rocket-box.png\"\n      class=\"press-release-icon mt-auto\"\n      alt=\"Product Resource Default Icon\" />\n     </ng-template>\n        <ng-template #ctaContent>\n          <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now' }}</span>\n          <span class=\"arrow\">→</span>\n        </ng-template>\n          <a *ngIf=\"post?.external_url; else internalLink\"\n            class=\"resource-btn mt-3\"\n            aria-label=\"Navigate to external url\"\n            [href]=\"post.external_url\"\n            target=\"_blank\"\n            rel=\"noopener noreferrer\">\n            <ng-container *ngTemplateOutlet=\"ctaContent\"></ng-container>\n          </a>\n\n        <ng-template #internalLink>\n          <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n            <ng-container *ngTemplateOutlet=\"ctaContent\"></ng-container>\n          </a>\n        </ng-template>\n        </div>\n    </div>\n  </div>\n</section>\n<section class=\"msp-vault-section bg-white\" *ngIf=\"isReleasePress && hasPressReleases()\">\n  <div class=\"container\">\n    <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\n      <h2 class=\"section-heading d-flex align-items-center\" [ngClass]=\"{ 'w-50': isPressEditingTitle }\">\n        <ng-container *ngIf=\"!isPressEditingTitle; else editTitleBlock\">\n          <span *ngIf=\"postTags['press']?.title; else fallback\" [innerHTML]=\"postTags['press']?.title\"></span>\n          <ng-template #fallback>Press Release Notes</ng-template>\n          <i  *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleEditPressTitle()\" (keydown.enter)=\"toggleEditPressTitle()\" (keydown.space)=\"toggleEditPressTitle()\" 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': isPressEditingTitle }\" />\n          <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle('press')\">Save</button>\n          <button class=\"btn btn-sm btn-secondary\" (click)=\"isPressEditingTitle = false\">Cancel</button>\n        </ng-template>\n      </h2>\n      <a *ngIf=\"!postSlice\" class=\"view-all\" routerLink=\"/resources/release-notes\">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=\"releasePosts['press']?.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 gap-4 video-row\" *ngIf=\"hasPressReleases()\">\n        <div class=\"resource-blog-card p-4\" *ngFor=\"let post of releasePosts['press']\">\n          <pw-resource-edit-card\n*ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          [id]=\"post.id\"\n          [resourceData]=\"post\"\n          (updated)=\"getPressReleasePosts(1, 100)\"></pw-resource-edit-card>\n          <p class=\"resource-title\" [innerHTML]=\"post.title\"></p>\n          <img *ngIf=\"!post.picture?.url.includes('default-photo.jpg'); else resourceRocketBox\"\n          src=\"{{ post.picture.url }}\"\n          class=\"resource-image mt-auto\"\n          alt=\"Press Resource Icon\" />\n\n     <ng-template #resourceRocketBox>\n      <img\n      src=\"assets/img/resource/rocket-box.png\"\n      class=\"press-release-icon mt-auto\"\n      alt=\"Press Resource Default Icon\" />\n     </ng-template>\n          <a *ngIf=\"post?.external_url; else internalLink\"\n            class=\"resource-btn mt-3\"\n            aria-label=\"Navigate to external url\"\n            [href]=\"post.external_url\"\n            target=\"_blank\"\n            rel=\"noopener noreferrer\">\n            <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n            <span class=\"arrow\">→</span>\n          </a>\n\n        <ng-template #internalLink>\n          <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n            <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n            <span class=\"arrow\">→</span>\n          </a>\n        </ng-template>\n        </div>\n    </div>\n  </div>\n</section>\n"]}
163
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"release-note-card.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/reslease-note-card/release-note-card.component.ts","../../../../../../../../libs/resource-module/src/lib/public/components/reslease-note-card/release-note-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    selector: 'pw-resource-note-card',\n    templateUrl: './release-note-card.component.html',\n    styleUrls: ['../resources/resources-shared.component.scss']\n})\nexport class ResourceNoteCardComponent extends AppBaseComponent implements OnInit {\n    @Input() releaseHeader = false;\n    @Input() categoryId!: string;\n    @Input() isReleasePress = false;\n    @Input() postSlice = false;\n    @Input() resourceTitle!: string;\n    @Input() tag;\n\n    userLoggedIn: boolean;\n    isLoaded = false;\n    subscriptionId;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n\n    postTags: { [key: string]: { id: string; title: string } } = {};\n    releasePosts: { [key: string]: Resource[] } = {};\n\n    tagCategory;\n    isEditingTitle: boolean;\n    isPressEditingTitle: boolean;\n    editedTitle: string;\n    user: User;\n    isMasterSubscription;\n\n    constructor(\n        injector: Injector,\n        private readonly resourceService: ResourceService,\n        private readonly authService: AuthService,\n        private readonly tagService: TagService\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\n        this.authService.getToken$().subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n\n                    this.getTags();\n                });\n            } else {\n                this.getTags();\n            }\n        });\n    }\n\n    private getTags() {\n        this.isLoaded = false;\n        this.tagService\n            .getAllTagCategories({ search: 'Release Notes' }, this.getEffectiveSubscriptionId())\n            .subscribe(response => {\n                this.tagCategory = response.tag_categories[0];\n                this.getPostTags();\n            });\n    }\n\n    private getPostTags() {\n        this.tagService\n            .getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())\n            .subscribe(response => {\n                this.postTags['product'] = this.findTag(\n                    response.tags,\n                    'Product Release Notes',\n                    this.tagCategory?.id\n                );\n                this.postTags['press'] = this.findTag(\n                    response.tags,\n                    'Press Release Notes',\n                    this.tagCategory?.id\n                );\n\n                if (this.postTags['product']?.id) {\n                    this.getProductReleasePosts(1, 100);\n                } else {\n                    this.isLoaded = true;\n                    this.releasePosts['product'] = [];\n                }\n\n                if (this.postTags['press']?.id) {\n                    this.getPressReleasePosts(1, 100);\n                } else {\n                    this.isLoaded = true;\n                    this.releasePosts['press'] = [];\n                }\n            });\n    }\n\n    private findTag(tags, name: string, categoryId: number) {\n        return tags.find(tag => tag.name === name && tag.tag_category_id === categoryId);\n    }\n\n    hasPressReleases(): boolean {\n        return this.releasePosts['press']?.length !== 0 && this.isLoaded;\n    }\n    hasProductReleases(): boolean {\n        return this.releasePosts['product']?.length !== 0 && this.isLoaded;\n    }\n\n    getProductReleasePosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(\n                this.getEffectiveSubscriptionId(),\n                page,\n                pageSize,\n                '',\n                '',\n                this.postTags['product']?.id\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.releasePosts['product'] = this.getProcessedPosts(sortedPosts);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    getPressReleasePosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(\n                this.getEffectiveSubscriptionId(),\n                page,\n                pageSize,\n                '',\n                '',\n                this.postTags['press']?.id\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.releasePosts['press'] = this.getProcessedPosts(sortedPosts);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    private getProcessedPosts(posts: Resource[], sliceCount = 3): Resource[] {\n        const cloned = [...posts];\n        return this.postSlice ? cloned.reverse() : cloned.slice(0, sliceCount).reverse();\n    }\n\n    toggleEditTitle() {\n        this.isEditingTitle = true;\n        this.editedTitle = this.postTags['product'].title;\n    }\n\n    toggleEditPressTitle() {\n        this.isPressEditingTitle = true;\n        this.editedTitle = this.postTags['press'].title;\n    }\n\n    saveEditedTitle(type) {\n        HelperService.updateTagTitle(\n            this.postTags[type],\n            this.editedTitle,\n            this.tagService,\n            this.getEffectiveSubscriptionId(),\n            this.toast\n        ).subscribe(() => {\n            this.postTags[type].title = this.editedTitle;\n            if (type === 'product') {\n                this.isEditingTitle = false;\n            } else {\n                this.isPressEditingTitle = false;\n            }\n        });\n    }\n\n    /** Helper method to get effective subscription ID */\n    private getEffectiveSubscriptionId(): number {\n        return HelperService.getEffectiveSubscriptionId(\n            this.user,\n            this.subscriptionId,\n            this.masterSubscriptionId\n        );\n    }\n}\n","<section class=\"msp-vault-section bg-white\" *ngIf=\"hasProductReleases()\">\n  <div class=\"container\">\n    <div 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=\"postTags['product']?.title; else fallback\" [innerHTML]=\"postTags['product']?.title\"></span>\n          <ng-template #fallback>Product Release Notes</ng-template>\n          <i  *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleEditTitle()\" (keydown.enter)=\"toggleEditTitle()\" (keydown.space)=\"toggleEditTitle()\" title=\"Edit Title\"></i>\n        </ng-container>\n\n        <ng-template #editTitleBlock>\n          <input [(ngModel)]=\"editedTitle\" class=\"form-control d-inline w-auto me-2\" [ngClass]=\"{ 'w-100': isEditingTitle }\" />\n          <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle('product')\">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\" *ngIf=\"!postSlice\" routerLink=\"/resources/release-notes\">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=\"releasePosts['product']?.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 gap-4 video-row\" *ngIf=\"hasProductReleases()\">\n        <div class=\"resource-blog-card p-4\" *ngFor=\"let post of releasePosts['product']\">\n          <pw-resource-edit-card\n          *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          [id]=\"post.id\"\n          [resourceData]=\"post\"\n          (updated)=\"getProductReleasePosts(1, 100)\"></pw-resource-edit-card>\n          <p class=\"resource-title\" [innerHTML]=\"post.title\"></p>\n          <img *ngIf=\"!post.picture?.url?.includes('default-photo.jpg'); else resourceRocketBox\"\n          src=\"{{ post.picture.url }}\"\n          class=\"resource-image mt-auto\"\n          alt=\"Product Resource Icon\" />\n\n     <ng-template #resourceRocketBox>\n      <img\n      src=\"assets/img/resource/rocket-box.png\"\n      class=\"press-release-icon mt-auto\"\n      alt=\"Product Resource Default Icon\" />\n     </ng-template>\n        <ng-template #ctaContent>\n          <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now' }}</span>\n          <span class=\"arrow\">→</span>\n        </ng-template>\n          <a *ngIf=\"post?.external_url; else internalLink\"\n            class=\"resource-btn mt-3\"\n            aria-label=\"Navigate to external url\"\n            [href]=\"post.external_url\"\n            target=\"_blank\"\n            rel=\"noopener noreferrer\">\n            <ng-container *ngTemplateOutlet=\"ctaContent\"></ng-container>\n          </a>\n\n        <ng-template #internalLink>\n          <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n            <ng-container *ngTemplateOutlet=\"ctaContent\"></ng-container>\n          </a>\n        </ng-template>\n        </div>\n    </div>\n  </div>\n</section>\n<section class=\"msp-vault-section bg-white\" *ngIf=\"isReleasePress && hasPressReleases()\">\n  <div class=\"container\">\n    <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\n      <h2 class=\"section-heading d-flex align-items-center\" [ngClass]=\"{ 'w-50': isPressEditingTitle }\">\n        <ng-container *ngIf=\"!isPressEditingTitle; else editTitleBlock\">\n          <span *ngIf=\"postTags['press']?.title; else fallback\" [innerHTML]=\"postTags['press']?.title\"></span>\n          <ng-template #fallback>Press Release Notes</ng-template>\n          <i  *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\" class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\" (click)=\"toggleEditPressTitle()\" (keydown.enter)=\"toggleEditPressTitle()\" (keydown.space)=\"toggleEditPressTitle()\" 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': isPressEditingTitle }\" />\n          <button class=\"btn btn-sm btn-primary me-1\" (click)=\"saveEditedTitle('press')\">Save</button>\n          <button class=\"btn btn-sm btn-secondary\" (click)=\"isPressEditingTitle = false\">Cancel</button>\n        </ng-template>\n      </h2>\n      <a *ngIf=\"!postSlice\" class=\"view-all\" routerLink=\"/resources/release-notes\">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=\"releasePosts['press']?.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 gap-4 video-row\" *ngIf=\"hasPressReleases()\">\n        <div class=\"resource-blog-card p-4\" *ngFor=\"let post of releasePosts['press']\">\n          <pw-resource-edit-card\n*ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          [id]=\"post.id\"\n          [resourceData]=\"post\"\n          (updated)=\"getPressReleasePosts(1, 100)\"></pw-resource-edit-card>\n          <p class=\"resource-title\" [innerHTML]=\"post.title\"></p>\n          <img *ngIf=\"!post.picture?.url.includes('default-photo.jpg'); else resourceRocketBox\"\n          src=\"{{ post.picture.url }}\"\n          class=\"resource-image mt-auto\"\n          alt=\"Press Resource Icon\" />\n\n     <ng-template #resourceRocketBox>\n      <img\n      src=\"assets/img/resource/rocket-box.png\"\n      class=\"press-release-icon mt-auto\"\n      alt=\"Press Resource Default Icon\" />\n     </ng-template>\n          <a *ngIf=\"post?.external_url; else internalLink\"\n            class=\"resource-btn mt-3\"\n            aria-label=\"Navigate to external url\"\n            [href]=\"post.external_url\"\n            target=\"_blank\"\n            rel=\"noopener noreferrer\">\n            <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n            <span class=\"arrow\">→</span>\n          </a>\n\n        <ng-template #internalLink>\n          <a class=\"resource-btn mt-3\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n            <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n            <span class=\"arrow\">→</span>\n          </a>\n        </ng-template>\n        </div>\n    </div>\n  </div>\n</section>\n"]}
@@ -38,15 +38,18 @@ export class CaseStudyCardComponent extends AppBaseComponent {
38
38
  });
39
39
  this.userService.getUserInfo().subscribe(data => {
40
40
  this.user = data;
41
+ this.getPosts(1, 10);
41
42
  });
42
43
  }
43
- this.getPosts(1, 10);
44
+ else {
45
+ this.getPosts(1, 10);
46
+ }
44
47
  });
45
48
  }
46
49
  getPosts(page, pageSize) {
47
50
  this.isLoaded = false;
48
51
  this.resourceService
49
- .getPublicPosts(this.masterSubscriptionId ?? this.subscriptionId, page, pageSize, '', this.categoryId)
52
+ .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', this.categoryId)
50
53
  .subscribe(response => {
51
54
  const sortedPosts = (response.posts ?? [])
52
55
  .filter(post => post.showcase === true)
@@ -62,11 +65,15 @@ export class CaseStudyCardComponent extends AppBaseComponent {
62
65
  this.editedTitle = this.resourceTitle;
63
66
  }
64
67
  saveEditedTitle() {
65
- HelperService.updateTagTitle(this.tag, this.editedTitle, this.tagService, this.subscriptionId ?? this.masterSubscriptionId, this.toast).subscribe(() => {
68
+ HelperService.updateTagTitle(this.tag, this.editedTitle, this.tagService, this.getEffectiveSubscriptionId(), this.toast).subscribe(() => {
66
69
  this.resourceTitle = this.editedTitle;
67
70
  this.isEditingTitle = false;
68
71
  });
69
72
  }
73
+ /** Helper method to get effective subscription ID */
74
+ getEffectiveSubscriptionId() {
75
+ return HelperService.getEffectiveSubscriptionId(this.user, this.subscriptionId, this.masterSubscriptionId);
76
+ }
70
77
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: CaseStudyCardComponent, deps: [{ token: i0.Injector }, { token: i1.ResourceService }, { token: i2.AuthService }, { token: i2.TagService }], target: i0.ɵɵFactoryTarget.Component }); }
71
78
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: CaseStudyCardComponent, selector: "pw-case-studies-card", inputs: { showCaseStudyHeader: "showCaseStudyHeader", categoryId: "categoryId", postSlice: "postSlice", tag: "tag", resourceTitle: "resourceTitle" }, usesInheritance: true, ngImport: i0, template: "<section class=\"msp-vault-section bg-white text-center py-5 extra-top-padding section-outer\" id=\"msp-case-studies\">\n <div class=\"container\">\n <ng-container *ngIf=\"showCaseStudyHeader; else fallbackBlock\">\n <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\n <ng-container *ngTemplateOutlet=\"caseStudyHeaderTemplate\"></ng-container>\n <a class=\"view-all\" routerLink=\"/resources/case-studies\">VIEW ALL ></a>\n </div>\n </ng-container>\n\n <ng-template #fallbackBlock>\n <div class=\"d-md-flex justify-content-between align-items-start\">\n <ng-container *ngTemplateOutlet=\"caseStudyHeaderTemplate\"></ng-container>\n </div>\n </ng-template>\n\n <ng-template #caseStudyHeaderTemplate>\n <h2 class=\"section-heading d-flex align-items-center\" id=\"msp-case-studies\" [ngClass]=\"{ 'w-50': isEditingTitle }\">\n <ng-container *ngIf=\"!isEditingTitle; else editTitleBlock\">\n <span *ngIf=\"resourceTitle; else fallback\">\n <span [innerHTML]=\"resourceTitle\"></span>\n </span>\n <ng-template #fallback>Case Studies</ng-template>\n <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\"\n (click)=\"toggleEditTitle()\"\n (keydown.enter)=\"toggleEditTitle()\"\n (keydown.space)=\"toggleEditTitle()\"\n 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 </ng-template>\n\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\n <div class=\"row d-flex flex-wrap justify-content-center gap-4 video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n <div class=\"testimonial-box\" *ngFor=\"let post of posts\">\n\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\n <div>\n <img *ngIf=\"!post.rectangular_picture.url.includes('default-photo.jpg') \" [src]=\"post.rectangular_picture.url\"\n alt=\"IT Partners Logo\"\n class=\"company-logo mb-3\" />\n\n <p class=\"mb-4 mt-3 testimonial-section\">\n <span [innerHTML]=\"post.title\"></span>\n </p>\n </div>\n\n <!-- BOTTOM AVATAR -->\n <div class=\"avatar-container mt-5\">\n <img [src]=\"post.picture.url\"\n alt=\"User Avatar\"\n *ngIf=\"post.picture.url && !post.picture.url.includes('default-photo.jpg')\"\n class=\"testimonial-avatar\" />\n <a *ngIf=\"post?.external_url; else internalLink\"\n class=\"read-more-btn-overlay\"\n aria-label=\"Navigate to external url\"\n [href]=\"post.external_url\"\n target=\"_blank\"\n rel=\"noopener noreferrer\">\n <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now' }}</span>\n <span class=\"arrow\">\u2192</span>\n </a>\n\n <ng-template #internalLink>\n <a class=\"read-more-btn-overlay\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now' }}</span>\n <span class=\"arrow\">\u2192</span>\n </a>\n </ng-template>\n </div>\n </div>\n </div>\n </div>\n</section>\n", styles: [".msp-vault-section{background:#fff;text-align:center;padding:3rem 0}.section-outer,.container{padding:0 15px}.d-md-flex{display:flex}.justify-content-between{justify-content:space-between}.align-items-start{align-items:flex-start}.vault-heading{font-size:2rem;font-weight:700}.video-row{margin-top:3rem;gap:5.5rem!important}.row{display:flex;flex-wrap:wrap}.col-md-6,.col-lg-4{flex:0 0 auto;width:100%}@media (width >= 768px){.col-md-6,.col-lg-4{width:50%}}@media (width >= 992px){.col-md-6,.col-lg-4{width:33.3333%}}.mb-4{margin-bottom:1.5rem}.testimonial-box{display:flex;flex-direction:column;justify-content:space-between;background:#fff;color:#000;border-radius:20px;box-shadow:0 0 20px #0000001a;text-align:center;width:338px;height:auto;padding:2.5rem 1.5rem;font-size:1.1rem;min-height:421.4px!important}.testimonial-box .testimonial-section{font-size:1.5rem;line-height:2rem;font-weight:400;color:var(--text-color, black)}.testimonial-box .testimonial-section strong{display:block}.testimonial-box .company-logo{width:100%!important;height:auto!important;max-width:150px!important;object-fit:contain;align-self:center}.testimonial-box .avatar-container{margin-top:auto;position:relative;display:inline-block}.testimonial-box .avatar-container .testimonial-avatar{width:60%;aspect-ratio:1/1;height:auto;border-radius:50%;object-fit:fill}.testimonial-box .avatar-container .read-more-btn-overlay{position:absolute;text-decoration:none!important;bottom:0;left:50%;transform:translate(-50%);background-color:var(--text-color, black);color:#fff;width:240px;padding:10px 24px;border-radius:24px;font-size:1.5rem;font-weight:500;cursor:pointer;transition:background .3s ease;display:flex;justify-content:space-between;align-items:center;text-align:left;border:1px solid;box-shadow:none!important;border-color:var(--text-color, black)}.testimonial-box .avatar-container .read-more-btn-overlay:hover{background:#fff;color:var(--text-color, black)!important}.testimonial-box .avatar-container .read-more-btn-overlay .arrow{margin-bottom:.3rem}\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: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { 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" }] }); }
72
79
  }
@@ -84,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
84
91
  }], resourceTitle: [{
85
92
  type: Input
86
93
  }] } });
87
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"case-studies-cards.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/resource-module/src/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.ts","../../../../../../../../../libs/resource-module/src/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../../resource.service';\n\n@Component({\n    selector: 'pw-case-studies-card',\n    templateUrl: './case-studies-cards.component.html',\n    styleUrls: ['./case-studies-cards.component.scss']\n})\nexport class CaseStudyCardComponent extends AppBaseComponent implements OnInit {\n    @Input() showCaseStudyHeader = false;\n    @Input() categoryId!: string;\n    @Input() postSlice = false;\n    @Input() tag;\n    @Input() resourceTitle!: string;\n\n    userLoggedIn: boolean;\n    isLoaded = false;\n    subscriptionId;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n    companyName = this.appConfig.company.name;\n\n    posts: Resource[] = [];\n    user: User;\n\n    isEditingTitle = false;\n    editedTitle: string;\n\n    constructor(\n        injector: Injector,\n        private readonly resourceService: ResourceService,\n        private readonly authService: AuthService,\n        private readonly tagService: TagService\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\n        this.authService.getToken$().subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n                });\n            }\n            this.getPosts(1, 10);\n        });\n    }\n\n    getPosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(\n                this.masterSubscriptionId ?? this.subscriptionId,\n                page,\n                pageSize,\n                '',\n                this.categoryId\n            )\n            .subscribe(response => {\n                const sortedPosts = (response.posts ?? [])\n                    .filter(post => post.showcase === true)\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    );\n                this.posts = this.postSlice ? sortedPosts : [...sortedPosts].slice(0, 3);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    toggleEditTitle() {\n        this.isEditingTitle = true;\n        this.editedTitle = this.resourceTitle;\n    }\n\n    saveEditedTitle() {\n        HelperService.updateTagTitle(\n            this.tag,\n            this.editedTitle,\n            this.tagService,\n            this.subscriptionId ?? this.masterSubscriptionId,\n            this.toast\n        ).subscribe(() => {\n            this.resourceTitle = this.editedTitle;\n            this.isEditingTitle = false;\n        });\n    }\n}\n","<section class=\"msp-vault-section bg-white text-center py-5 extra-top-padding section-outer\" id=\"msp-case-studies\">\n  <div class=\"container\">\n    <ng-container *ngIf=\"showCaseStudyHeader; else fallbackBlock\">\n      <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\n        <ng-container *ngTemplateOutlet=\"caseStudyHeaderTemplate\"></ng-container>\n        <a class=\"view-all\" routerLink=\"/resources/case-studies\">VIEW ALL ></a>\n      </div>\n    </ng-container>\n\n    <ng-template #fallbackBlock>\n      <div class=\"d-md-flex justify-content-between align-items-start\">\n        <ng-container *ngTemplateOutlet=\"caseStudyHeaderTemplate\"></ng-container>\n      </div>\n    </ng-template>\n\n    <ng-template #caseStudyHeaderTemplate>\n      <h2 class=\"section-heading d-flex align-items-center\" id=\"msp-case-studies\" [ngClass]=\"{ 'w-50': isEditingTitle }\">\n        <ng-container *ngIf=\"!isEditingTitle; else editTitleBlock\">\n          <span *ngIf=\"resourceTitle; else fallback\">\n            <span [innerHTML]=\"resourceTitle\"></span>\n          </span>\n          <ng-template #fallback>Case Studies</ng-template>\n          <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n             class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\"\n             (click)=\"toggleEditTitle()\"\n             (keydown.enter)=\"toggleEditTitle()\"\n             (keydown.space)=\"toggleEditTitle()\"\n             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    </ng-template>\n\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\n    <div class=\"row d-flex flex-wrap justify-content-center gap-4 video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n      <div class=\"testimonial-box\" *ngFor=\"let post of posts\">\n\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\n        <div>\n          <img *ngIf=\"!post.rectangular_picture.url.includes('default-photo.jpg') \" [src]=\"post.rectangular_picture.url\"\n          alt=\"IT Partners Logo\"\n          class=\"company-logo mb-3\" />\n\n          <p class=\"mb-4 mt-3 testimonial-section\">\n            <span [innerHTML]=\"post.title\"></span>\n          </p>\n        </div>\n\n        <!-- BOTTOM AVATAR -->\n        <div class=\"avatar-container mt-5\">\n          <img [src]=\"post.picture.url\"\n            alt=\"User Avatar\"\n            *ngIf=\"post.picture.url && !post.picture.url.includes('default-photo.jpg')\"\n            class=\"testimonial-avatar\" />\n            <a *ngIf=\"post?.external_url; else internalLink\"\n            class=\"read-more-btn-overlay\"\n            aria-label=\"Navigate to external url\"\n            [href]=\"post.external_url\"\n            target=\"_blank\"\n            rel=\"noopener noreferrer\">\n            <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n            <span class=\"arrow\">→</span>\n          </a>\n\n        <ng-template #internalLink>\n          <a class=\"read-more-btn-overlay\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n            <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n            <span class=\"arrow\">→</span>\n          </a>\n        </ng-template>\n        </div>\n      </div>\n  </div>\n  </div>\n</section>\n"]}
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"case-studies-cards.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/resource-module/src/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.ts","../../../../../../../../../libs/resource-module/src/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnInit } from '@angular/core';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, TagService } from '@posiwise/common-services';\nimport { Resource, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../../resource.service';\n\n@Component({\n    selector: 'pw-case-studies-card',\n    templateUrl: './case-studies-cards.component.html',\n    styleUrls: ['./case-studies-cards.component.scss']\n})\nexport class CaseStudyCardComponent extends AppBaseComponent implements OnInit {\n    @Input() showCaseStudyHeader = false;\n    @Input() categoryId!: string;\n    @Input() postSlice = false;\n    @Input() tag;\n    @Input() resourceTitle!: string;\n\n    userLoggedIn: boolean;\n    isLoaded = false;\n    subscriptionId;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n    companyName = this.appConfig.company.name;\n\n    posts: Resource[] = [];\n    user: User;\n    isMasterSubscription;\n\n    isEditingTitle = false;\n    editedTitle: string;\n\n    constructor(\n        injector: Injector,\n        private readonly resourceService: ResourceService,\n        private readonly authService: AuthService,\n        private readonly tagService: TagService\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\n        this.authService.getToken$().subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n\n                    this.getPosts(1, 10);\n                });\n            } else {\n                this.getPosts(1, 10);\n            }\n        });\n    }\n\n    getPosts(page: number, pageSize: number): void {\n        this.isLoaded = false;\n        this.resourceService\n            .getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', this.categoryId)\n            .subscribe(response => {\n                const sortedPosts = (response.posts ?? [])\n                    .filter(post => post.showcase === true)\n                    .sort(\n                        (a, b) =>\n                            new Date(b.published_at).getTime() - new Date(a.published_at).getTime()\n                    );\n                this.posts = this.postSlice ? sortedPosts : [...sortedPosts].slice(0, 3);\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    toggleEditTitle() {\n        this.isEditingTitle = true;\n        this.editedTitle = this.resourceTitle;\n    }\n\n    saveEditedTitle() {\n        HelperService.updateTagTitle(\n            this.tag,\n            this.editedTitle,\n            this.tagService,\n            this.getEffectiveSubscriptionId(),\n            this.toast\n        ).subscribe(() => {\n            this.resourceTitle = this.editedTitle;\n            this.isEditingTitle = false;\n        });\n    }\n\n    /** Helper method to get effective subscription ID */\n    private getEffectiveSubscriptionId(): number {\n        return HelperService.getEffectiveSubscriptionId(\n            this.user,\n            this.subscriptionId,\n            this.masterSubscriptionId\n        );\n    }\n}\n","<section class=\"msp-vault-section bg-white text-center py-5 extra-top-padding section-outer\" id=\"msp-case-studies\">\n  <div class=\"container\">\n    <ng-container *ngIf=\"showCaseStudyHeader; else fallbackBlock\">\n      <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\n        <ng-container *ngTemplateOutlet=\"caseStudyHeaderTemplate\"></ng-container>\n        <a class=\"view-all\" routerLink=\"/resources/case-studies\">VIEW ALL ></a>\n      </div>\n    </ng-container>\n\n    <ng-template #fallbackBlock>\n      <div class=\"d-md-flex justify-content-between align-items-start\">\n        <ng-container *ngTemplateOutlet=\"caseStudyHeaderTemplate\"></ng-container>\n      </div>\n    </ng-template>\n\n    <ng-template #caseStudyHeaderTemplate>\n      <h2 class=\"section-heading d-flex align-items-center\" id=\"msp-case-studies\" [ngClass]=\"{ 'w-50': isEditingTitle }\">\n        <ng-container *ngIf=\"!isEditingTitle; else editTitleBlock\">\n          <span *ngIf=\"resourceTitle; else fallback\">\n            <span [innerHTML]=\"resourceTitle\"></span>\n          </span>\n          <ng-template #fallback>Case Studies</ng-template>\n          <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n             class=\"fa fa-edit in-page-edit-icon ms-3 cursor-pointer\"\n             (click)=\"toggleEditTitle()\"\n             (keydown.enter)=\"toggleEditTitle()\"\n             (keydown.space)=\"toggleEditTitle()\"\n             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    </ng-template>\n\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\n    <div class=\"row d-flex flex-wrap justify-content-center gap-4 video-row\" *ngIf=\"posts.length !== 0 && isLoaded\">\n      <div class=\"testimonial-box\" *ngFor=\"let post of posts\">\n\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\n        <div>\n          <img *ngIf=\"!post.rectangular_picture.url.includes('default-photo.jpg') \" [src]=\"post.rectangular_picture.url\"\n          alt=\"IT Partners Logo\"\n          class=\"company-logo mb-3\" />\n\n          <p class=\"mb-4 mt-3 testimonial-section\">\n            <span [innerHTML]=\"post.title\"></span>\n          </p>\n        </div>\n\n        <!-- BOTTOM AVATAR -->\n        <div class=\"avatar-container mt-5\">\n          <img [src]=\"post.picture.url\"\n            alt=\"User Avatar\"\n            *ngIf=\"post.picture.url && !post.picture.url.includes('default-photo.jpg')\"\n            class=\"testimonial-avatar\" />\n            <a *ngIf=\"post?.external_url; else internalLink\"\n            class=\"read-more-btn-overlay\"\n            aria-label=\"Navigate to external url\"\n            [href]=\"post.external_url\"\n            target=\"_blank\"\n            rel=\"noopener noreferrer\">\n            <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n            <span class=\"arrow\">→</span>\n          </a>\n\n        <ng-template #internalLink>\n          <a class=\"read-more-btn-overlay\" aria-label=\"Navigate to resource view\" [routerLink]=\"['/resources/view', post?.slug]\">\n            <span>{{ post?.cta_text && post.cta_text !== 'null' ? post.cta_text : 'Read Now'  }}</span>\n            <span class=\"arrow\">→</span>\n          </a>\n        </ng-template>\n        </div>\n      </div>\n  </div>\n  </div>\n</section>\n"]}