@posiwise/resource-module 0.0.102 → 0.0.103

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.
@@ -57,9 +57,17 @@ export class ResourceNoteCardComponent extends AppBaseComponent {
57
57
  if (this.blogPostTag?.id) {
58
58
  this.getProductReleasePosts(1, 100);
59
59
  }
60
+ else {
61
+ this.isLoaded = true;
62
+ this.productReleasePosts = [];
63
+ }
60
64
  if (this.blogPressTag?.id) {
61
65
  this.getPressReleasePosts(1, 100);
62
66
  }
67
+ else {
68
+ this.isLoaded = true;
69
+ this.productReleasePosts = [];
70
+ }
63
71
  });
64
72
  }
65
73
  getProductReleasePosts(page, pageSize) {
@@ -72,7 +80,10 @@ export class ResourceNoteCardComponent extends AppBaseComponent {
72
80
  this.productReleasePosts = this.postSlice
73
81
  ? sortedPosts.reverse()
74
82
  : sortedPosts.slice(0, 3).reverse();
83
+ }).add(() => {
84
+ this.isLoaded = true;
75
85
  });
86
+ ;
76
87
  }
77
88
  getPressReleasePosts(page, pageSize) {
78
89
  this.resourceService
@@ -106,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
106
117
  }], resourceTitle: [{
107
118
  type: Input
108
119
  }] } });
109
- //# 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 { TagService } from '@posiwise/common-services';\nimport { TOKEN_KEY } from '@posiwise/common-utilities';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    selector: 'pw-resource-note-card',\n    templateUrl: './release-note-card.component.html',\n    styleUrls: ['../resource-post/related-resources/related-resources.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\n    userLoggedIn: boolean;\n    isLoaded = false;\n    subscriptionId;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n\n    pressReleasePosts = [];\n    productReleasePosts = [];\n    tagCategory;\n    resourcePostTag;\n    blogPostTag;\n    blogPressTag;\n\n    constructor(\n        injector: Injector,\n        private readonly resourceService: ResourceService,\n        private readonly tagService: TagService\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\n        this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n            }\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.blogPostTag = response.tags.find(\n                    tag =>\n                        tag.name === 'Product Release Notes' &&\n                        tag.tag_category_id === this.tagCategory?.id\n                );\n                this.blogPressTag = response.tags.find(\n                    tag =>\n                        tag.name === 'Press Release Notes' &&\n                        tag.tag_category_id === this.tagCategory?.id\n                );\n                if (this.blogPostTag?.id) {\n                    this.getProductReleasePosts(1, 100);\n                }\n\n                if (this.blogPressTag?.id) {\n                    this.getPressReleasePosts(1, 100);\n                }\n            });\n    }\n\n    getProductReleasePosts(page: number, pageSize: number) {\n        this.resourceService\n            .getPublicPosts(\n                this.subscriptionId || this.masterSubscriptionId,\n                page,\n                pageSize,\n                '',\n                '',\n                this.blogPostTag?.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.productReleasePosts = this.postSlice\n                    ? sortedPosts.reverse()\n                    : sortedPosts.slice(0, 3).reverse();\n            });\n    }\n\n    getPressReleasePosts(page: number, pageSize: number) {\n        this.resourceService\n            .getPublicPosts(\n                this.subscriptionId || this.masterSubscriptionId,\n                page,\n                pageSize,\n                '',\n                '',\n                this.blogPressTag?.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.pressReleasePosts = this.postSlice\n                    ? sortedPosts.reverse()\n                    : sortedPosts.slice(0, 3).reverse();\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n}\n","<section class=\"resource-section bg-white\">\n  <div class=\"container\">\n    <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\n      <h2 class=\"section-heading\" [innerHTML]=\"blogPostTag?.title || 'Product Release Notes'\"></h2>\n      <a class=\"view-all\" *ngIf=\"!this.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=\"productReleasePosts.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=\"productReleasePosts.length !== 0 && isLoaded\">\n        <div class=\"resource-card p-4\" *ngFor=\"let post of productReleasePosts\">\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-4\"\n          alt=\"\" />\n\n     <ng-template #resourceRocketBox>\n      <img\n      src=\"assets/img/resource/rocket-box.png\"\n      class=\"release-icon mt-4\"\n      alt=\"\" />\n     </ng-template>\n          <a *ngIf=\"post?.external_url; else internalLink\"\n            class=\"read-now-btn\"\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-now-btn\" [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<section class=\"resource-section bg-white\" *ngIf=\"isReleasePress\">\n  <div class=\"container\">\n    <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\n      <h2 class=\"section-heading\" [innerHTML]=\"blogPressTag?.title || 'Press Release Notes'\"></h2>\n      <a *ngIf=\"!this.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=\"pressReleasePosts.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=\"pressReleasePosts.length !== 0 && isLoaded\">\n        <div class=\"resource-card p-4\" *ngFor=\"let post of pressReleasePosts\">\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-4\"\n          alt=\"\" />\n\n     <ng-template #resourceRocketBox>\n      <img\n      src=\"assets/img/resource/rocket-box.png\"\n      class=\"release-icon mt-4\"\n      alt=\"\" />\n     </ng-template>\n          <a *ngIf=\"post?.external_url; else internalLink\"\n            class=\"read-now-btn\"\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-now-btn\" [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"]}
120
+ //# 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 { TagService } from '@posiwise/common-services';\nimport { TOKEN_KEY } from '@posiwise/common-utilities';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    selector: 'pw-resource-note-card',\n    templateUrl: './release-note-card.component.html',\n    styleUrls: ['../resource-post/related-resources/related-resources.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\n    userLoggedIn: boolean;\n    isLoaded = false;\n    subscriptionId;\n    masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n\n    pressReleasePosts = [];\n    productReleasePosts = [];\n    tagCategory;\n    resourcePostTag;\n    blogPostTag;\n    blogPressTag;\n\n    constructor(\n        injector: Injector,\n        private readonly resourceService: ResourceService,\n        private readonly tagService: TagService\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\n        this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n            }\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.blogPostTag = response.tags.find(\n                    tag =>\n                        tag.name === 'Product Release Notes' &&\n                        tag.tag_category_id === this.tagCategory?.id\n                );\n                this.blogPressTag = response.tags.find(\n                    tag =>\n                        tag.name === 'Press Release Notes' &&\n                        tag.tag_category_id === this.tagCategory?.id\n                );\n                if (this.blogPostTag?.id) {\n                    this.getProductReleasePosts(1, 100);\n                } else {\n                    this.isLoaded = true;\n                    this.productReleasePosts = []\n                }\n\n                if (this.blogPressTag?.id) {\n                    this.getPressReleasePosts(1, 100);\n                } else {\n                    this.isLoaded = true;\n                    this.productReleasePosts = []\n                }\n            });\n    }\n\n    getProductReleasePosts(page: number, pageSize: number) {\n        this.resourceService\n            .getPublicPosts(\n                this.subscriptionId || this.masterSubscriptionId,\n                page,\n                pageSize,\n                '',\n                '',\n                this.blogPostTag?.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.productReleasePosts = this.postSlice\n                    ? sortedPosts.reverse()\n                    : sortedPosts.slice(0, 3).reverse();\n            }).add(() => {\n                this.isLoaded = true;\n            });;\n    }\n\n    getPressReleasePosts(page: number, pageSize: number) {\n        this.resourceService\n            .getPublicPosts(\n                this.subscriptionId || this.masterSubscriptionId,\n                page,\n                pageSize,\n                '',\n                '',\n                this.blogPressTag?.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.pressReleasePosts = this.postSlice\n                    ? sortedPosts.reverse()\n                    : sortedPosts.slice(0, 3).reverse();\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n}\n","<section class=\"resource-section bg-white\">\n  <div class=\"container\">\n    <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\n      <h2 class=\"section-heading\" [innerHTML]=\"blogPostTag?.title || 'Product Release Notes'\"></h2>\n      <a class=\"view-all\" *ngIf=\"!this.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=\"productReleasePosts.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=\"productReleasePosts.length !== 0 && isLoaded\">\n        <div class=\"resource-card p-4\" *ngFor=\"let post of productReleasePosts\">\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-4\"\n          alt=\"\" />\n\n     <ng-template #resourceRocketBox>\n      <img\n      src=\"assets/img/resource/rocket-box.png\"\n      class=\"release-icon mt-4\"\n      alt=\"\" />\n     </ng-template>\n          <a *ngIf=\"post?.external_url; else internalLink\"\n            class=\"read-now-btn\"\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-now-btn\" [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<section class=\"resource-section bg-white\" *ngIf=\"isReleasePress\">\n  <div class=\"container\">\n    <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\n      <h2 class=\"section-heading\" [innerHTML]=\"blogPressTag?.title || 'Press Release Notes'\"></h2>\n      <a *ngIf=\"!this.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=\"pressReleasePosts.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=\"pressReleasePosts.length !== 0 && isLoaded\">\n        <div class=\"resource-card p-4\" *ngFor=\"let post of pressReleasePosts\">\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-4\"\n          alt=\"\" />\n\n     <ng-template #resourceRocketBox>\n      <img\n      src=\"assets/img/resource/rocket-box.png\"\n      class=\"release-icon mt-4\"\n      alt=\"\" />\n     </ng-template>\n          <a *ngIf=\"post?.external_url; else internalLink\"\n            class=\"read-now-btn\"\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-now-btn\" [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"]}
@@ -154,9 +154,17 @@ class ResourceNoteCardComponent extends AppBaseComponent {
154
154
  if (this.blogPostTag?.id) {
155
155
  this.getProductReleasePosts(1, 100);
156
156
  }
157
+ else {
158
+ this.isLoaded = true;
159
+ this.productReleasePosts = [];
160
+ }
157
161
  if (this.blogPressTag?.id) {
158
162
  this.getPressReleasePosts(1, 100);
159
163
  }
164
+ else {
165
+ this.isLoaded = true;
166
+ this.productReleasePosts = [];
167
+ }
160
168
  });
161
169
  }
162
170
  getProductReleasePosts(page, pageSize) {
@@ -169,7 +177,10 @@ class ResourceNoteCardComponent extends AppBaseComponent {
169
177
  this.productReleasePosts = this.postSlice
170
178
  ? sortedPosts.reverse()
171
179
  : sortedPosts.slice(0, 3).reverse();
180
+ }).add(() => {
181
+ this.isLoaded = true;
172
182
  });
183
+ ;
173
184
  }
174
185
  getPressReleasePosts(page, pageSize) {
175
186
  this.resourceService