@posiwise/resource-module 0.0.134 → 0.0.136
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.
- package/esm2022/lib/public/components/base/base-resource.component.mjs +127 -0
- package/esm2022/lib/public/components/base/base-top-banner.component.mjs +69 -0
- package/esm2022/lib/public/components/reslease-note-card/release-note-card.component.mjs +9 -9
- package/esm2022/lib/public/components/resource-blogs/resource-blog-top-banner/resource-blog-top-banner.component.mjs +12 -53
- package/esm2022/lib/public/components/resource-blogs/resource-blog.component.mjs +10 -45
- package/esm2022/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.mjs +9 -9
- package/esm2022/lib/public/components/resource-case-studies/resource-case-studies.component.mjs +18 -68
- package/esm2022/lib/public/components/resource-company-card/resource-company-card.component.mjs +15 -13
- package/esm2022/lib/public/components/resource-edit-card/resource-edit-card.component.mjs +15 -15
- package/esm2022/lib/public/components/resource-integration/integration-top-banner/integration-top-banner.component.mjs +12 -54
- package/esm2022/lib/public/components/resource-integration/resource-integration.component.mjs +10 -9
- package/esm2022/lib/public/components/resource-post/related-resources/related-resources.component.mjs +7 -7
- package/esm2022/lib/public/components/resource-post/related-resources/resource-cards/resource-cards.component.mjs +9 -9
- package/esm2022/lib/public/components/resource-post/resource-post-details/resource-post-details.component.mjs +8 -7
- package/esm2022/lib/public/components/resource-release-notes/resource-release-notes-top-banner/resource-release-notes-top-banner.component.mjs +12 -53
- package/esm2022/lib/public/components/resource-release-notes/resource-release-notes.component.mjs +14 -17
- package/esm2022/lib/public/components/resource-top-banner-edit/resource-top-banner-edit.component.mjs +16 -16
- package/esm2022/lib/public/components/resource-vault/resource-vault.component.mjs +14 -28
- package/esm2022/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.mjs +9 -9
- package/esm2022/lib/public/components/resource-videos/resource-videos-top-banner/resource-videos-top-banner.component.mjs +12 -53
- package/esm2022/lib/public/components/resource-videos/resource-videos.component.mjs +10 -45
- package/esm2022/lib/public/components/resource-webinars/replay-event-cards/replay-event-cards.component.mjs +7 -7
- package/esm2022/lib/public/components/resource-webinars/resource-webinars.component.mjs +9 -9
- package/esm2022/lib/public/components/resource-webinars/upcoming-event-cards/upcoming-event-cards.component.mjs +9 -9
- package/esm2022/lib/public/components/resources/resource-tags/resource-tags.component.mjs +9 -9
- package/esm2022/lib/public/components/resources/vault-section/vault-section.component.mjs +20 -18
- package/esm2022/lib/public/components/resources-hub/resources-hub.component.mjs +9 -9
- package/esm2022/lib/public/components/resources-read/resources-read.component.mjs +7 -7
- package/esm2022/lib/public/components/white-papers/white-papers-top-banner/white-papers-top-banner.component.mjs +12 -53
- package/esm2022/lib/public/components/white-papers/white-papers.component.mjs +10 -45
- package/fesm2022/posiwise-resource-module.mjs +425 -591
- package/fesm2022/posiwise-resource-module.mjs.map +1 -1
- package/lib/public/components/base/base-resource.component.d.ts +39 -0
- package/lib/public/components/base/base-top-banner.component.d.ts +30 -0
- package/lib/public/components/reslease-note-card/release-note-card.component.d.ts +3 -2
- package/lib/public/components/resource-blogs/resource-blog-top-banner/resource-blog-top-banner.component.d.ts +6 -21
- package/lib/public/components/resource-blogs/resource-blog.component.d.ts +6 -16
- package/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.d.ts +3 -2
- package/lib/public/components/resource-case-studies/resource-case-studies.component.d.ts +9 -23
- package/lib/public/components/resource-company-card/resource-company-card.component.d.ts +4 -2
- package/lib/public/components/resource-edit-card/resource-edit-card.component.d.ts +7 -6
- package/lib/public/components/resource-integration/integration-top-banner/integration-top-banner.component.d.ts +6 -22
- package/lib/public/components/resource-integration/resource-integration.component.d.ts +3 -2
- package/lib/public/components/resource-post/related-resources/related-resources.component.d.ts +3 -2
- package/lib/public/components/resource-post/related-resources/resource-cards/resource-cards.component.d.ts +3 -2
- package/lib/public/components/resource-post/resource-post-details/resource-post-details.component.d.ts +3 -2
- package/lib/public/components/resource-release-notes/resource-release-notes-top-banner/resource-release-notes-top-banner.component.d.ts +6 -21
- package/lib/public/components/resource-release-notes/resource-release-notes.component.d.ts +3 -4
- package/lib/public/components/resource-top-banner-edit/resource-top-banner-edit.component.d.ts +6 -5
- package/lib/public/components/resource-vault/resource-vault.component.d.ts +6 -14
- package/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.d.ts +3 -2
- package/lib/public/components/resource-videos/resource-videos-top-banner/resource-videos-top-banner.component.d.ts +6 -21
- package/lib/public/components/resource-videos/resource-videos.component.d.ts +6 -16
- package/lib/public/components/resource-webinars/replay-event-cards/replay-event-cards.component.d.ts +3 -2
- package/lib/public/components/resource-webinars/resource-webinars.component.d.ts +3 -2
- package/lib/public/components/resource-webinars/upcoming-event-cards/upcoming-event-cards.component.d.ts +3 -2
- package/lib/public/components/resources/resource-tags/resource-tags.component.d.ts +3 -2
- package/lib/public/components/resources/vault-section/vault-section.component.d.ts +3 -1
- package/lib/public/components/resources-hub/resources-hub.component.d.ts +3 -2
- package/lib/public/components/resources-read/resources-read.component.d.ts +3 -2
- package/lib/public/components/white-papers/white-papers-top-banner/white-papers-top-banner.component.d.ts +6 -21
- package/lib/public/components/white-papers/white-papers.component.d.ts +6 -16
- package/package.json +1 -1
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { Component, Injector } from '@angular/core';
|
|
2
|
+
import { AppBaseComponent } from '@posiwise/app-base-component';
|
|
3
|
+
import { AuthService, TagService } from '@posiwise/common-services';
|
|
4
|
+
import { ResourceService } from '../../../resource.service';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../../resource.service";
|
|
7
|
+
import * as i2 from "@posiwise/common-services";
|
|
8
|
+
export class BaseResourceComponent extends AppBaseComponent {
|
|
9
|
+
constructor(resourceService, tagService, authService, injector) {
|
|
10
|
+
super(injector);
|
|
11
|
+
this.resourceService = resourceService;
|
|
12
|
+
this.tagService = tagService;
|
|
13
|
+
this.authService = authService;
|
|
14
|
+
this.masterSubscriptionId = this.appConfig.master_subscription.subscription_id;
|
|
15
|
+
this.posts = [];
|
|
16
|
+
this.testimonialsPosts = [];
|
|
17
|
+
this.isLoaded = false;
|
|
18
|
+
}
|
|
19
|
+
ngOnInit() {
|
|
20
|
+
this.getUserSubscriptionId().subscribe(response => {
|
|
21
|
+
this.subscriptionId = response;
|
|
22
|
+
});
|
|
23
|
+
this.authService.getToken$().subscribe(res => {
|
|
24
|
+
this.userLoggedIn = !!res;
|
|
25
|
+
if (this.userLoggedIn) {
|
|
26
|
+
this.localStorage.getItem$('product').subscribe(res => {
|
|
27
|
+
const data = res ? JSON.parse(res) : null;
|
|
28
|
+
this.subscriptionId = data?.subscriptionId;
|
|
29
|
+
});
|
|
30
|
+
this.userService.getUserInfo().subscribe(data => {
|
|
31
|
+
this.user = data;
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
this.initializeComponent();
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
initializeComponent() {
|
|
38
|
+
if (this.shouldUseTagCategories()) {
|
|
39
|
+
this.getTags();
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
this.getPostTags();
|
|
43
|
+
}
|
|
44
|
+
if (this.shouldLoadTestimonials()) {
|
|
45
|
+
this.getTestimonialTags();
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
getTags() {
|
|
49
|
+
this.isLoaded = false;
|
|
50
|
+
this.tagService
|
|
51
|
+
.getAllTagCategories({ search: this.getSearchTerm() }, this.getEffectiveSubscriptionId())
|
|
52
|
+
.subscribe(response => {
|
|
53
|
+
this.tagCategory = response.tag_categories[0];
|
|
54
|
+
this.getPostTags();
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
getPostTags() {
|
|
58
|
+
this.tagService
|
|
59
|
+
.getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())
|
|
60
|
+
.subscribe(response => {
|
|
61
|
+
if (this.shouldUseTagCategories()) {
|
|
62
|
+
this.blogPostTag = response.tags.find(tag => tag.tag_category_id === this.tagCategory?.id);
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
this.blogPostTag = response.tags.find(tag => tag.name === this.getResourceType());
|
|
66
|
+
}
|
|
67
|
+
this.getPosts(1, 100);
|
|
68
|
+
})
|
|
69
|
+
.add(() => {
|
|
70
|
+
this.isLoaded = true;
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
getTestimonialTags() {
|
|
74
|
+
this.tagService
|
|
75
|
+
.getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())
|
|
76
|
+
.subscribe(response => {
|
|
77
|
+
this.blogTestimonialsPostTag = response.tags.find(tag => tag.name === 'Testimonials');
|
|
78
|
+
this.getTestimonialsPosts(1, 100);
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
getPosts(page, pageSize) {
|
|
82
|
+
this.fetchPosts(page, pageSize, this.blogPostTag?.tag_category_id, 'posts');
|
|
83
|
+
}
|
|
84
|
+
getTestimonialsPosts(page, pageSize) {
|
|
85
|
+
this.fetchPosts(page, pageSize, this.blogTestimonialsPostTag?.tag_category_id, 'testimonialsPosts');
|
|
86
|
+
}
|
|
87
|
+
/** Shared method to fetch posts with common filtering, sorting, and slicing logic */
|
|
88
|
+
fetchPosts(page, pageSize, tagCategoryId, targetProperty) {
|
|
89
|
+
this.resourceService
|
|
90
|
+
.getPublicPosts(this.getEffectiveSubscriptionId(), page, pageSize, '', tagCategoryId)
|
|
91
|
+
.subscribe(response => {
|
|
92
|
+
const filteredPosts = response.posts
|
|
93
|
+
.filter(post => post.tags?.some(tag => tag.tag_category_id === tagCategoryId))
|
|
94
|
+
.sort((a, b) => new Date(b.published_at).getTime() - new Date(a.published_at).getTime())
|
|
95
|
+
.slice(0, 12);
|
|
96
|
+
if (targetProperty === 'posts') {
|
|
97
|
+
this.posts = filteredPosts;
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
this.testimonialsPosts = filteredPosts;
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
/** Helper method to get effective subscription ID */
|
|
105
|
+
getEffectiveSubscriptionId() {
|
|
106
|
+
return this.subscriptionId || this.masterSubscriptionId;
|
|
107
|
+
}
|
|
108
|
+
// Optional methods that can be overridden
|
|
109
|
+
getSearchTerm() {
|
|
110
|
+
return this.getResourceType();
|
|
111
|
+
}
|
|
112
|
+
shouldUseTagCategories() {
|
|
113
|
+
return false;
|
|
114
|
+
}
|
|
115
|
+
shouldLoadTestimonials() {
|
|
116
|
+
return false;
|
|
117
|
+
}
|
|
118
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: BaseResourceComponent, deps: [{ token: i1.ResourceService }, { token: i2.TagService }, { token: i2.AuthService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
119
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: BaseResourceComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: '', isInline: true }); }
|
|
120
|
+
}
|
|
121
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: BaseResourceComponent, decorators: [{
|
|
122
|
+
type: Component,
|
|
123
|
+
args: [{
|
|
124
|
+
template: ''
|
|
125
|
+
}]
|
|
126
|
+
}], 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"]}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { Component, Injector } from '@angular/core';
|
|
2
|
+
import { AppBaseComponent } from '@posiwise/app-base-component';
|
|
3
|
+
import { AuthService, TagService } from '@posiwise/common-services';
|
|
4
|
+
import { ResourceService } from '../../../resource.service';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../../resource.service";
|
|
7
|
+
import * as i2 from "@posiwise/common-services";
|
|
8
|
+
export class BaseTopBannerComponent extends AppBaseComponent {
|
|
9
|
+
constructor(resourceService, tagService, authService, injector) {
|
|
10
|
+
super(injector);
|
|
11
|
+
this.resourceService = resourceService;
|
|
12
|
+
this.tagService = tagService;
|
|
13
|
+
this.authService = authService;
|
|
14
|
+
this.masterSubscriptionId = this.appConfig.master_subscription.subscription_id;
|
|
15
|
+
this.posts = [];
|
|
16
|
+
this.testimonialsPosts = [];
|
|
17
|
+
this.isLoaded = false;
|
|
18
|
+
}
|
|
19
|
+
ngOnInit() {
|
|
20
|
+
this.getUserSubscriptionId().subscribe(response => {
|
|
21
|
+
this.subscriptionId = response;
|
|
22
|
+
});
|
|
23
|
+
this.authService.getToken$().subscribe(res => {
|
|
24
|
+
this.userLoggedIn = !!res;
|
|
25
|
+
if (this.userLoggedIn) {
|
|
26
|
+
this.localStorage.getItem$('product').subscribe(res => {
|
|
27
|
+
const data = res ? JSON.parse(res) : null;
|
|
28
|
+
this.subscriptionId = data?.subscriptionId;
|
|
29
|
+
});
|
|
30
|
+
this.userService.getUserInfo().subscribe(data => {
|
|
31
|
+
this.user = data;
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
this.getTags();
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
getTags() {
|
|
38
|
+
this.isLoaded = false;
|
|
39
|
+
this.tagService
|
|
40
|
+
.getAllTagCategories({ search: this.getSearchTerm() }, this.getEffectiveSubscriptionId())
|
|
41
|
+
.subscribe(response => {
|
|
42
|
+
this.tagCategory = response.tag_categories[0];
|
|
43
|
+
this.getPostTags();
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
getPostTags() {
|
|
47
|
+
this.tagService
|
|
48
|
+
.getTagsByType('post_categories', {}, this.getEffectiveSubscriptionId())
|
|
49
|
+
.subscribe(response => {
|
|
50
|
+
this.blogPostTag = response.tags.find(tag => tag.tag_category_id === this.tagCategory?.id);
|
|
51
|
+
})
|
|
52
|
+
.add(() => {
|
|
53
|
+
this.isLoaded = true;
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
/** Helper method to get effective subscription ID */
|
|
57
|
+
getEffectiveSubscriptionId() {
|
|
58
|
+
return this.subscriptionId || this.masterSubscriptionId;
|
|
59
|
+
}
|
|
60
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: BaseTopBannerComponent, deps: [{ token: i1.ResourceService }, { token: i2.TagService }, { token: i2.AuthService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
61
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: BaseTopBannerComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: '', isInline: true }); }
|
|
62
|
+
}
|
|
63
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: BaseTopBannerComponent, decorators: [{
|
|
64
|
+
type: Component,
|
|
65
|
+
args: [{
|
|
66
|
+
template: ''
|
|
67
|
+
}]
|
|
68
|
+
}], ctorParameters: () => [{ type: i1.ResourceService }, { type: i2.TagService }, { type: i2.AuthService }, { type: i0.Injector }] });
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS10b3AtYmFubmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcmVzb3VyY2UtbW9kdWxlL3NyYy9saWIvcHVibGljL2NvbXBvbmVudHMvYmFzZS9iYXNlLXRvcC1iYW5uZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBRTVELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxXQUFXLEVBQUUsVUFBVSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFHcEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJCQUEyQixDQUFDOzs7O0FBSzVELE1BQU0sT0FBZ0Isc0JBQXVCLFNBQVEsZ0JBQWdCO0lBWWpFLFlBQ3VCLGVBQWdDLEVBQ2hDLFVBQXNCLEVBQ3hCLFdBQXdCLEVBQ3pDLFFBQWtCO1FBRWxCLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUxHLG9CQUFlLEdBQWYsZUFBZSxDQUFpQjtRQUNoQyxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQ3hCLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBYjdDLHlCQUFvQixHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsbUJBQW1CLENBQUMsZUFBZSxDQUFDO1FBQzFFLFVBQUssR0FBZSxFQUFFLENBQUM7UUFDdkIsc0JBQWlCLEdBQUcsRUFBRSxDQUFDO1FBS3ZCLGFBQVEsR0FBRyxLQUFLLENBQUM7SUFVakIsQ0FBQztJQUVELFFBQVE7UUFDSixJQUFJLENBQUMscUJBQXFCLEVBQUUsQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLEVBQUU7WUFDOUMsSUFBSSxDQUFDLGNBQWMsR0FBRyxRQUFRLENBQUM7UUFDbkMsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUN6QyxJQUFJLENBQUMsWUFBWSxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUM7WUFDMUIsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7Z0JBQ3BCLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsRUFBRTtvQkFDbEQsTUFBTSxJQUFJLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7b0JBQzFDLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxFQUFFLGNBQWMsQ0FBQztnQkFDL0MsQ0FBQyxDQUFDLENBQUM7Z0JBQ0gsSUFBSSxDQUFDLFdBQVcsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7b0JBQzVDLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO2dCQUNyQixDQUFDLENBQUMsQ0FBQztZQUNQLENBQUM7WUFDRCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDbkIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRVMsT0FBTztRQUNiLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ3RCLElBQUksQ0FBQyxVQUFVO2FBQ1YsbUJBQW1CLENBQ2hCLEVBQUUsTUFBTSxFQUFFLElBQUksQ0FBQyxhQUFhLEVBQUUsRUFBRSxFQUNoQyxJQUFJLENBQUMsMEJBQTBCLEVBQUUsQ0FDcEM7YUFDQSxTQUFTLENBQUMsUUFBUSxDQUFDLEVBQUU7WUFDbEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzlDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUN2QixDQUFDLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFTyxXQUFXO1FBQ2YsSUFBSSxDQUFDLFVBQVU7YUFDVixhQUFhLENBQUMsaUJBQWlCLEVBQUUsRUFBRSxFQUFFLElBQUksQ0FBQywwQkFBMEIsRUFBRSxDQUFDO2FBQ3ZFLFNBQVMsQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUNsQixJQUFJLENBQUMsV0FBVyxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUNqQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxlQUFlLEtBQUssSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLENBQ3RELENBQUM7UUFDTixDQUFDLENBQUM7YUFDRCxHQUFHLENBQUMsR0FBRyxFQUFFO1lBQ04sSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUM7UUFDekIsQ0FBQyxDQUFDLENBQUM7SUFDWCxDQUFDO0lBRUQscURBQXFEO0lBQzNDLDBCQUEwQjtRQUNoQyxPQUFPLElBQUksQ0FBQyxjQUFjLElBQUksSUFBSSxDQUFDLG9CQUFvQixDQUFDO0lBQzVELENBQUM7K0dBckVpQixzQkFBc0I7bUdBQXRCLHNCQUFzQiwyRUFGOUIsRUFBRTs7NEZBRU0sc0JBQXNCO2tCQUgzQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxFQUFFO2lCQUNmIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3RvciwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEFwcEJhc2VDb21wb25lbnQgfSBmcm9tICdAcG9zaXdpc2UvYXBwLWJhc2UtY29tcG9uZW50JztcbmltcG9ydCB7IEF1dGhTZXJ2aWNlLCBUYWdTZXJ2aWNlIH0gZnJvbSAnQHBvc2l3aXNlL2NvbW1vbi1zZXJ2aWNlcyc7XG5pbXBvcnQgeyBSZXNvdXJjZSwgVXNlciB9IGZyb20gJ0Bwb3Npd2lzZS9jb21tb24tdXRpbGl0aWVzJztcblxuaW1wb3J0IHsgUmVzb3VyY2VTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vcmVzb3VyY2Uuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHRlbXBsYXRlOiAnJ1xufSlcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlVG9wQmFubmVyQ29tcG9uZW50IGV4dGVuZHMgQXBwQmFzZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgc3Vic2NyaXB0aW9uSWQ6IG51bWJlcjtcbiAgICBtYXN0ZXJTdWJzY3JpcHRpb25JZCA9IHRoaXMuYXBwQ29uZmlnLm1hc3Rlcl9zdWJzY3JpcHRpb24uc3Vic2NyaXB0aW9uX2lkO1xuICAgIHBvc3RzOiBSZXNvdXJjZVtdID0gW107XG4gICAgdGVzdGltb25pYWxzUG9zdHMgPSBbXTtcbiAgICB1c2VyTG9nZ2VkSW46IGJvb2xlYW47XG4gICAgYmxvZ1Bvc3RUYWc7XG4gICAgdGFnQ2F0ZWdvcnk7XG4gICAgYmxvZ1Rlc3RpbW9uaWFsc1Bvc3RUYWc7XG4gICAgaXNMb2FkZWQgPSBmYWxzZTtcbiAgICB1c2VyOiBVc2VyO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByb3RlY3RlZCByZWFkb25seSByZXNvdXJjZVNlcnZpY2U6IFJlc291cmNlU2VydmljZSxcbiAgICAgICAgcHJvdGVjdGVkIHJlYWRvbmx5IHRhZ1NlcnZpY2U6IFRhZ1NlcnZpY2UsXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgYXV0aFNlcnZpY2U6IEF1dGhTZXJ2aWNlLFxuICAgICAgICBpbmplY3RvcjogSW5qZWN0b3JcbiAgICApIHtcbiAgICAgICAgc3VwZXIoaW5qZWN0b3IpO1xuICAgIH1cblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLmdldFVzZXJTdWJzY3JpcHRpb25JZCgpLnN1YnNjcmliZShyZXNwb25zZSA9PiB7XG4gICAgICAgICAgICB0aGlzLnN1YnNjcmlwdGlvbklkID0gcmVzcG9uc2U7XG4gICAgICAgIH0pO1xuICAgICAgICB0aGlzLmF1dGhTZXJ2aWNlLmdldFRva2VuJCgpLnN1YnNjcmliZShyZXMgPT4ge1xuICAgICAgICAgICAgdGhpcy51c2VyTG9nZ2VkSW4gPSAhIXJlcztcbiAgICAgICAgICAgIGlmICh0aGlzLnVzZXJMb2dnZWRJbikge1xuICAgICAgICAgICAgICAgIHRoaXMubG9jYWxTdG9yYWdlLmdldEl0ZW0kKCdwcm9kdWN0Jykuc3Vic2NyaWJlKHJlcyA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IGRhdGEgPSByZXMgPyBKU09OLnBhcnNlKHJlcykgOiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB0aGlzLnN1YnNjcmlwdGlvbklkID0gZGF0YT8uc3Vic2NyaXB0aW9uSWQ7XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgdGhpcy51c2VyU2VydmljZS5nZXRVc2VySW5mbygpLnN1YnNjcmliZShkYXRhID0+IHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy51c2VyID0gZGF0YTtcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHRoaXMuZ2V0VGFncygpO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgZ2V0VGFncygpIHtcbiAgICAgICAgdGhpcy5pc0xvYWRlZCA9IGZhbHNlO1xuICAgICAgICB0aGlzLnRhZ1NlcnZpY2VcbiAgICAgICAgICAgIC5nZXRBbGxUYWdDYXRlZ29yaWVzKFxuICAgICAgICAgICAgICAgIHsgc2VhcmNoOiB0aGlzLmdldFNlYXJjaFRlcm0oKSB9LFxuICAgICAgICAgICAgICAgIHRoaXMuZ2V0RWZmZWN0aXZlU3Vic2NyaXB0aW9uSWQoKVxuICAgICAgICAgICAgKVxuICAgICAgICAgICAgLnN1YnNjcmliZShyZXNwb25zZSA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy50YWdDYXRlZ29yeSA9IHJlc3BvbnNlLnRhZ19jYXRlZ29yaWVzWzBdO1xuICAgICAgICAgICAgICAgIHRoaXMuZ2V0UG9zdFRhZ3MoKTtcbiAgICAgICAgICAgIH0pO1xuICAgIH1cblxuICAgIHByaXZhdGUgZ2V0UG9zdFRhZ3MoKSB7XG4gICAgICAgIHRoaXMudGFnU2VydmljZVxuICAgICAgICAgICAgLmdldFRhZ3NCeVR5cGUoJ3Bvc3RfY2F0ZWdvcmllcycsIHt9LCB0aGlzLmdldEVmZmVjdGl2ZVN1YnNjcmlwdGlvbklkKCkpXG4gICAgICAgICAgICAuc3Vic2NyaWJlKHJlc3BvbnNlID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLmJsb2dQb3N0VGFnID0gcmVzcG9uc2UudGFncy5maW5kKFxuICAgICAgICAgICAgICAgICAgICB0YWcgPT4gdGFnLnRhZ19jYXRlZ29yeV9pZCA9PT0gdGhpcy50YWdDYXRlZ29yeT8uaWRcbiAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSlcbiAgICAgICAgICAgIC5hZGQoKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRoaXMuaXNMb2FkZWQgPSB0cnVlO1xuICAgICAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgLyoqIEhlbHBlciBtZXRob2QgdG8gZ2V0IGVmZmVjdGl2ZSBzdWJzY3JpcHRpb24gSUQgKi9cbiAgICBwcm90ZWN0ZWQgZ2V0RWZmZWN0aXZlU3Vic2NyaXB0aW9uSWQoKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc3Vic2NyaXB0aW9uSWQgfHwgdGhpcy5tYXN0ZXJTdWJzY3JpcHRpb25JZDtcbiAgICB9XG4gICAgLy8gQWJzdHJhY3QgbWV0aG9kIHRoYXQgZWFjaCBjb21wb25lbnQgbXVzdCBpbXBsZW1lbnRcbiAgICBwcm90ZWN0ZWQgYWJzdHJhY3QgZ2V0U2VhcmNoVGVybSgpOiBzdHJpbmc7XG59XG4iXX0=
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { Component, Injector, Input } from '@angular/core';
|
|
2
2
|
import { AppBaseComponent } from '@posiwise/app-base-component';
|
|
3
|
-
import { TagService } from '@posiwise/common-services';
|
|
4
|
-
import { TOKEN_KEY } from '@posiwise/common-utilities';
|
|
3
|
+
import { AuthService, TagService } from '@posiwise/common-services';
|
|
5
4
|
import { HelperService } from '@posiwise/helper-service';
|
|
6
5
|
import { ResourceService } from '../../../resource.service';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
@@ -16,9 +15,10 @@ import * as i8 from "@posiwise/directives";
|
|
|
16
15
|
import * as i9 from "../resource-edit-card/resource-edit-card.component";
|
|
17
16
|
import * as i10 from "@jsverse/transloco";
|
|
18
17
|
export class ResourceNoteCardComponent extends AppBaseComponent {
|
|
19
|
-
constructor(injector, resourceService, tagService) {
|
|
18
|
+
constructor(injector, resourceService, authService, tagService) {
|
|
20
19
|
super(injector);
|
|
21
20
|
this.resourceService = resourceService;
|
|
21
|
+
this.authService = authService;
|
|
22
22
|
this.tagService = tagService;
|
|
23
23
|
this.releaseHeader = false;
|
|
24
24
|
this.isReleasePress = false;
|
|
@@ -29,7 +29,7 @@ export class ResourceNoteCardComponent extends AppBaseComponent {
|
|
|
29
29
|
this.releasePosts = {};
|
|
30
30
|
}
|
|
31
31
|
ngOnInit() {
|
|
32
|
-
this.
|
|
32
|
+
this.authService.getToken$().subscribe(res => {
|
|
33
33
|
this.userLoggedIn = !!res;
|
|
34
34
|
if (this.userLoggedIn) {
|
|
35
35
|
this.localStorage.getItem$('product').subscribe(res => {
|
|
@@ -134,13 +134,13 @@ export class ResourceNoteCardComponent extends AppBaseComponent {
|
|
|
134
134
|
}
|
|
135
135
|
});
|
|
136
136
|
}
|
|
137
|
-
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.TagService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
138
|
-
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\">\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()\" 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\">\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()\" 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" }] }); }
|
|
137
|
+
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
|
+
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\">\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\">\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
139
|
}
|
|
140
140
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceNoteCardComponent, decorators: [{
|
|
141
141
|
type: Component,
|
|
142
|
-
args: [{ selector: 'pw-resource-note-card', template: "<section class=\"msp-vault-section bg-white\">\n <div class=\"container\">\n <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\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()\" 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\">\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()\" 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"] }]
|
|
143
|
-
}], ctorParameters: () => [{ type: i0.Injector }, { type: i1.ResourceService }, { type: i2.TagService }], propDecorators: { releaseHeader: [{
|
|
142
|
+
args: [{ selector: 'pw-resource-note-card', template: "<section class=\"msp-vault-section bg-white\">\n <div class=\"container\">\n <div class=\"d-flex justify-content-between align-items-center flex-wrap\">\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\">\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"] }]
|
|
143
|
+
}], ctorParameters: () => [{ type: i0.Injector }, { type: i1.ResourceService }, { type: i2.AuthService }, { type: i2.TagService }], propDecorators: { releaseHeader: [{
|
|
144
144
|
type: Input
|
|
145
145
|
}], categoryId: [{
|
|
146
146
|
type: Input
|
|
@@ -153,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
153
153
|
}], tag: [{
|
|
154
154
|
type: Input
|
|
155
155
|
}] } });
|
|
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 { TagService } from '@posiwise/common-services';\nimport { Resource, TOKEN_KEY, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    selector: 'pw-resource-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 tagService: TagService\n    ) {\n        super(injector);\n    }\n\n    ngOnInit(): void {\n        this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n                });\n            }\n        });\n        this.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\">\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()\" 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\">\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()\" 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"]}
|
|
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\">\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\">\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"]}
|