@posiwise/resource-module 0.0.92
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/README.md +7 -0
- package/esm2022/index.mjs +6 -0
- package/esm2022/lib/public/components/resources-list/resources-list.component.mjs +129 -0
- package/esm2022/lib/public/components/resources-read/resources-read.component.mjs +125 -0
- package/esm2022/lib/public/resource-public.module.mjs +74 -0
- package/esm2022/lib/public/resource-public.routing.module.mjs +38 -0
- package/esm2022/lib/resource.module.mjs +15 -0
- package/esm2022/lib/resource.service.mjs +65 -0
- package/esm2022/lib/shared/models/resource.model.mjs +12 -0
- package/esm2022/posiwise-resource-module.mjs +5 -0
- package/fesm2022/posiwise-resource-module.mjs +427 -0
- package/fesm2022/posiwise-resource-module.mjs.map +1 -0
- package/index.d.ts +4 -0
- package/lib/public/components/resources-list/resources-list.component.d.ts +34 -0
- package/lib/public/components/resources-read/resources-read.component.d.ts +43 -0
- package/lib/public/resource-public.module.d.ts +21 -0
- package/lib/public/resource-public.routing.module.d.ts +7 -0
- package/lib/resource.module.d.ts +7 -0
- package/lib/resource.service.d.ts +21 -0
- package/lib/shared/models/resource.model.d.ts +3 -0
- package/package.json +28 -0
package/README.md
ADDED
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export * from './lib/resource.module';
|
|
2
|
+
// Public
|
|
3
|
+
export * from './lib/public/components/resources-read/resources-read.component';
|
|
4
|
+
export * from './lib/public/components/resources-list/resources-list.component';
|
|
5
|
+
export * from './lib/public/resource-public.module';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3Jlc291cmNlLW1vZHVsZS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQztBQUV0QyxTQUFTO0FBQ1QsY0FBYyxpRUFBaUUsQ0FBQztBQUNoRixjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMscUNBQXFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9yZXNvdXJjZS5tb2R1bGUnO1xuXG4vLyBQdWJsaWNcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B1YmxpYy9jb21wb25lbnRzL3Jlc291cmNlcy1yZWFkL3Jlc291cmNlcy1yZWFkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdWJsaWMvY29tcG9uZW50cy9yZXNvdXJjZXMtbGlzdC9yZXNvdXJjZXMtbGlzdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHVibGljL3Jlc291cmNlLXB1YmxpYy5tb2R1bGUnO1xuIl19
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { Component, Injector, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { AppBaseComponent } from '@posiwise/app-base-component';
|
|
3
|
+
import { TagService } from '@posiwise/common-services';
|
|
4
|
+
import { TOKEN_KEY } from '@posiwise/common-utilities';
|
|
5
|
+
import { forkJoin } from 'rxjs';
|
|
6
|
+
import { ResourceService } from '../../../resource.service';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../../../resource.service";
|
|
9
|
+
import * as i2 from "@posiwise/common-services";
|
|
10
|
+
import * as i3 from "@angular/common";
|
|
11
|
+
import * as i4 from "@angular/router";
|
|
12
|
+
import * as i5 from "primeng/progressspinner";
|
|
13
|
+
import * as i6 from "@posiwise/shared-components";
|
|
14
|
+
import * as i7 from "@angular/forms";
|
|
15
|
+
import * as i8 from "@posiwise/directives";
|
|
16
|
+
import * as i9 from "@posiwise/pipes";
|
|
17
|
+
export class ResourceListComponent extends AppBaseComponent {
|
|
18
|
+
constructor(resourceService, tagService, injector) {
|
|
19
|
+
super(injector);
|
|
20
|
+
this.resourceService = resourceService;
|
|
21
|
+
this.tagService = tagService;
|
|
22
|
+
this.delayTimeout = null;
|
|
23
|
+
this.data = [];
|
|
24
|
+
this.posts = [];
|
|
25
|
+
this.tags = [];
|
|
26
|
+
this.searchTextItems = '';
|
|
27
|
+
this.searchInput = false;
|
|
28
|
+
this.loading = true;
|
|
29
|
+
this.loaded = false;
|
|
30
|
+
}
|
|
31
|
+
ngOnInit() {
|
|
32
|
+
this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {
|
|
33
|
+
this.userLoggedIn = !!res;
|
|
34
|
+
if (this.userLoggedIn) {
|
|
35
|
+
this.localStorage.getItem$('product').subscribe(res => {
|
|
36
|
+
const data = res ? JSON.parse(res) : null;
|
|
37
|
+
this.subscriptionId = data?.subscriptionId;
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
this.masterSubscriptionId = this.appConfig.master_subscription.subscription_id;
|
|
42
|
+
this.getPostsAndTags();
|
|
43
|
+
this.readingTime = 0;
|
|
44
|
+
}
|
|
45
|
+
getPostsAndTags() {
|
|
46
|
+
this.loading = true;
|
|
47
|
+
this.loaded = false;
|
|
48
|
+
forkJoin({
|
|
49
|
+
resPosts: this.resourceService.getPublicPosts(this.masterSubscriptionId, 1, 100, this.searchTextItems),
|
|
50
|
+
resTags: this.tagService.getTagsByType('post_categories', {}, this.subscriptionId || this.masterSubscriptionId)
|
|
51
|
+
})
|
|
52
|
+
.subscribe(res => {
|
|
53
|
+
// posts
|
|
54
|
+
this.posts = res?.resPosts?.posts;
|
|
55
|
+
this.data = res?.resPosts?.posts;
|
|
56
|
+
this.totalRecords = this.posts?.length;
|
|
57
|
+
// tags
|
|
58
|
+
this.tags = res?.resTags?.tags;
|
|
59
|
+
})
|
|
60
|
+
.add(() => {
|
|
61
|
+
this.loading = false;
|
|
62
|
+
this.loaded = true;
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
getPosts(page, pageSize) {
|
|
66
|
+
this.loading = true;
|
|
67
|
+
this.loaded = false;
|
|
68
|
+
this.resourceService
|
|
69
|
+
.getPublicPosts(this.masterSubscriptionId, page, pageSize, this.searchTextItems)
|
|
70
|
+
.subscribe(response => {
|
|
71
|
+
this.posts = response.posts;
|
|
72
|
+
this.data = response.posts;
|
|
73
|
+
this.totalRecords = this.posts?.length;
|
|
74
|
+
})
|
|
75
|
+
.add(() => {
|
|
76
|
+
this.loading = false;
|
|
77
|
+
this.loaded = true;
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
showSearch(close) {
|
|
81
|
+
this.searchInput = !this.searchInput;
|
|
82
|
+
if (close) {
|
|
83
|
+
this.searchTextItems = '';
|
|
84
|
+
this.getPosts(1, 100);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
onSearch(seconds) {
|
|
88
|
+
let delay = 0;
|
|
89
|
+
delay = seconds * 1000;
|
|
90
|
+
clearTimeout(this.delayTimeout);
|
|
91
|
+
// wait for timeout before get posts
|
|
92
|
+
const delayTimeout = setTimeout(() => {
|
|
93
|
+
this.getPosts(1, 100);
|
|
94
|
+
}, delay);
|
|
95
|
+
this.delayTimeout = delayTimeout;
|
|
96
|
+
}
|
|
97
|
+
tagPost(selectedTag) {
|
|
98
|
+
let filtered;
|
|
99
|
+
this.data = [];
|
|
100
|
+
this.posts.forEach(element => {
|
|
101
|
+
if (element.tags.length > 0) {
|
|
102
|
+
filtered = element.tags.filter(tag => tag.id === selectedTag.id);
|
|
103
|
+
if (filtered.length > 0) {
|
|
104
|
+
this.data.push(element);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
thisPostReadingTime(text) {
|
|
110
|
+
if (text) {
|
|
111
|
+
const wordsPerMinute = 200;
|
|
112
|
+
const noOfWords = text.split(/\s/g).length;
|
|
113
|
+
const minutes = noOfWords / wordsPerMinute;
|
|
114
|
+
const readTime = Math.ceil(minutes);
|
|
115
|
+
return `${readTime} minute read`;
|
|
116
|
+
}
|
|
117
|
+
return '';
|
|
118
|
+
}
|
|
119
|
+
ngOnDestroy() {
|
|
120
|
+
super.ngOnDestroy();
|
|
121
|
+
}
|
|
122
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceListComponent, deps: [{ token: i1.ResourceService }, { token: i2.TagService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
123
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ResourceListComponent, selector: "pw-posts-list", usesInheritance: true, ngImport: i0, template: "<pw-header/>\n<div class=\"all-posts py-5\">\n <div class=\"row mt-5 mb-4 px-2\">\n <div class=\"col-md-9\">\n <ul class=\"tags\">\n <li (keydown.enter)=\"getPosts(1, 100)\" (click)=\"getPosts(1, 100)\">All Resources</li>\n <li *ngFor=\"let tag of tags\"\n (keydown.enter)=\"tagPost(tag)\"\n (click)=\"tagPost(tag)\">{{ tag.name }}</li>\n </ul>\n </div>\n <div class=\"col-md-3\">\n <div class=\"search\"\n *ngIf=\"searchInput; else searchIcon\">\n <input type=\"text\"\n class=\"w-100\"\n placeholder=\"search...\"\n [(ngModel)]=\"searchTextItems\"\n (keydown.enter)=\"onSearch(0.5)\" />\n <i class=\"fa fa-times\" (click)=\"showSearch('close')\" (keydown.enter)=\"showSearch('close')\" aria-hidden=\"true\"></i>\n </div>\n <ng-template #searchIcon>\n <i\n class=\"fa fa-search w-100 text-end\"\n (click)=\"showSearch('open')\"\n (keydown.enter)=\"showSearch('open')\"\n aria-hidden=\"true\"\n ></i>\n </ng-template>\n </div>\n </div>\n <ng-container *ngIf=\"loading && !loaded\">\n <div class=\"w-100 text-center mt-3\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n </ng-container>\n <ng-container *ngIf=\"posts?.length && !loading\">\n <div class=\"blog-list\">\n <div class=\"row mt-4 ms-1 me-1 blog-listing\"\n *ngFor=\"let post of data\">\n <div class=\"col-md-6 col-sm-12 col-xs-12 my-auto\"\n [routerLink]=\"['/resource', post.slug]\">\n <div class=\"list-blog-image\">\n <img [src]=\"post.picture?.url\"\n alt=\"Post List\"\n class=\"img-fluid\" />\n </div>\n </div>\n <div class=\"col-md-6 col-sm-12 col-xs-12 px-4 position-relative\">\n <div class=\"mt-4\">\n <div class=\"author mb-3 d-flex\">\n <div class=\"avatar-image\">\n <a [attr.disabled]=\"!userLoggedIn\"\n [routerLink]=\"['/members', post?.author?.slug]\">\n <img *ngIf=\"post.author?.avatar\"\n [src]=\"post.author?.avatar[0]?.url\"\n alt=\"Author\" />\n <img *ngIf=\"!post.author?.avatar\"\n src=\"/assets/img/icons/male.png\"\n alt=\"Author\"\n class=\"default-user-image\" />\n </a>\n </div>\n\n <div class=\"author-name ps-2\">\n <a [attr.disabled]=\"!userLoggedIn\"\n [routerLink]=\"['/members', post?.author?.slug]\"\n class=\"name\">\n {{ post.author.first_name }}\n <i class=\"fas fa-crown\" aria-hidden=\"true\"></i></a>\n <ul>\n <li>\n <a href=\"javascript:void(0);\">\n {{ post.published_at | date: 'dd/MM/yyyy' }}\n </a>\n </li>\n <li>.</li>\n <li>\n <a href=\"javascript:void(0);\">{{ thisPostReadingTime(post.body) }}\n </a>\n </li>\n </ul>\n </div>\n <div class=\"share-post\">\n <div class=\"dropdown\">\n <a href=\"#\"\n aria-label=\"Post Menu\"\n id=\"dropdownMenuLink\"\n data-bs-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n (keydown.enter)=\"$event.preventDefault(); $event.target.click()\"\n (keydown.space)=\"$event.preventDefault(); $event.target.click()\"\n aria-expanded=\"false\">\n <i class=\"fas fa-ellipsis-v\" aria-hidden=\"true\"></i>\n </a>\n <div class=\"dropdown-menu\"\n aria-labelledby=\"dropdownMenuLink\">\n <a class=\"dropdown-item\"\n href=\"http://www.facebook.com/\"\n rel=\"noopener noreferrer\"\n target=\"_blank\">\n <i class=\"fas fa-share\" aria-hidden=\"true\"></i> Share Post\n </a>\n </div>\n </div>\n </div>\n </div>\n <h4 [routerLink]=\"['/resource', post.slug]\"\n class=\"title my-3\">{{ post.title }}</h4>\n <p [routerLink]=\"['/resource', post.slug]\"\n class=\"body mb-5 pb-3 post-body-text\">\n {{ post.body | removeHtml: 'quill' | textTruncate: 200 }}\n </p>\n <div class=\"blog-view py-3 blog-list-write-view\">\n <ul class=\"d-flex\">\n <li>{{ post.view !== null ? post.view : '0' }} View</li>\n <li><a [routerLink]=\"['/resource', post.slug]\">Write Comment</a></li>\n <li>\n <a [routerLink]=\"['/resource', post.slug]\" aria-label=\"Blog\"><i class=\"far fa-heart\" aria-hidden=\"true\"></i></a>\n </li>\n </ul>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"!posts?.length && loaded\">\n <p>No blog posts available</p>\n </ng-container>\n</div>\n", styles: [":root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}body{background:#fff}.blog-listing{border:1px solid rgb(238,238,238);cursor:pointer}.all-posts{margin:5em auto 0;max-width:980px;padding:14px 20px;width:100%}ul.tags{display:inline-flex;font-size:16px;font-weight:400}ul.tags li{color:#337ab7;cursor:pointer;font-weight:600;margin-right:20px}ul.tags li:hover{color:#000}.search{position:relative}.search input{border:0;border-bottom:1px solid rgb(213,206,206)}.search i{position:absolute;right:5px}.blog-list .blog-listing h4{color:#000;font:28px/1.3 Roboto,sans-serif;transition:all .5s}.blog-list .blog-listing h4:hover{color:#0045c7}.blog-list .blog-listing p.body{color:#b3b3b3;font:16px/1.4 Roboto,sans-serif;transition:all .5s}.blog-list .blog-listing p.body:hover{color:#0045c7}.blog-list .blog-listing p.body p{color:inherit;font:inherit;transition:inherit}.blog-list .blog-listing p.body p:hover{color:#0045c7}.blog-list .blog-listing .list-blog-image img{padding:25px}.blog-list .blog-listing .author .avatar-image{border:1px solid rgb(0,0,0);border-radius:50px;height:50px;clip-path:circle(50% at 50% 50%);width:50px}.blog-list .blog-listing .author .avatar-image img{left:50%;position:relative;top:50%;transform:translate(-50%,-50%)}.blog-list .blog-listing .author .avatar-image .default-user-image{width:50px}.blog-list .blog-listing .author .author-name p.name{color:#000;font:14px/1 Roboto,sans-serif;margin:0;transition:all .5s}.blog-list .blog-listing .author .author-name p.name:hover{color:#0045c7}.blog-list .blog-listing .author .author-name p.name i{color:#000}.blog-list .blog-listing .author .author-name ul li{display:inline-block;padding-right:10px;vertical-align:middle}.blog-list .blog-listing .author .author-name ul li a{color:#b3b3b3;font:12px/1 Roboto,sans-serif}.blog-list .blog-listing .author .share-post{flex-grow:3;position:relative;text-align:right}.blog-list .blog-listing .author .share-post i{color:var(--first)}.blog-list .blog-listing .author .share-post .dropdown-menu{border:0 0;box-shadow:0 3px 8px #0003;left:auto!important;right:0;top:20px!important;transform:translate(0)!important}.blog-list .blog-listing .blog-view{border-top:1px solid rgb(238,238,238)}.blog-list .blog-listing .blog-view ul li{color:#b3b3b3;font:12px/1 Roboto,sans-serif;padding-right:14px}.blog-list .blog-listing .blog-view ul li a{color:inherit;font:inherit;transition:all .5s}.blog-list .blog-listing .blog-view ul li a:hover{color:#0045c7}.blog-list .blog-listing .blog-view ul li:last-child{flex-grow:3;padding-right:0;text-align:right}.blog-list .blog-listing .blog-view ul li:last-child i{color:#e84a43;font-size:14px}@media only screen and (max-width: 1024px){.cust-mt{padding:14px 5px}.cust-mt .blog-list .blog-listing h4{font:20px/1.3 Roboto,sans-serif}.cust-mt .blog-list .blog-listing p.body{font:.9rem/1.3 Roboto,sans-serif}.cust-mt .blog-list .blog-listing p.body p{font:inherit}.cust-mt .blog-list .blog-listing .blog-image{height:300px}}@media only screen and (max-width: 767px){.blog-list .blog-listing{height:auto;max-height:none;overflow:visible}.blog-list .blog-listing .blog-view{padding-bottom:1rem}}@media (min-width: 768px){.blog-list-write-view{position:absolute}.blog-view{bottom:0;width:92%}}.post-body-text:hover{color:var(--titles)!important}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i5.ProgressSpinner, selector: "p-progressSpinner", inputs: ["styleClass", "style", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }, { kind: "component", type: i6.HeaderComponent, selector: "pw-header", inputs: ["landing"] }, { kind: "directive", type: i7.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: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i8.LazyImgDirective, selector: "img" }, { kind: "pipe", type: i3.DatePipe, name: "date" }, { kind: "pipe", type: i9.RemoveHtmlPipe, name: "removeHtml" }, { kind: "pipe", type: i9.TextTruncatePipe, name: "textTruncate" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
124
|
+
}
|
|
125
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceListComponent, decorators: [{
|
|
126
|
+
type: Component,
|
|
127
|
+
args: [{ selector: 'pw-posts-list', encapsulation: ViewEncapsulation.None, template: "<pw-header/>\n<div class=\"all-posts py-5\">\n <div class=\"row mt-5 mb-4 px-2\">\n <div class=\"col-md-9\">\n <ul class=\"tags\">\n <li (keydown.enter)=\"getPosts(1, 100)\" (click)=\"getPosts(1, 100)\">All Resources</li>\n <li *ngFor=\"let tag of tags\"\n (keydown.enter)=\"tagPost(tag)\"\n (click)=\"tagPost(tag)\">{{ tag.name }}</li>\n </ul>\n </div>\n <div class=\"col-md-3\">\n <div class=\"search\"\n *ngIf=\"searchInput; else searchIcon\">\n <input type=\"text\"\n class=\"w-100\"\n placeholder=\"search...\"\n [(ngModel)]=\"searchTextItems\"\n (keydown.enter)=\"onSearch(0.5)\" />\n <i class=\"fa fa-times\" (click)=\"showSearch('close')\" (keydown.enter)=\"showSearch('close')\" aria-hidden=\"true\"></i>\n </div>\n <ng-template #searchIcon>\n <i\n class=\"fa fa-search w-100 text-end\"\n (click)=\"showSearch('open')\"\n (keydown.enter)=\"showSearch('open')\"\n aria-hidden=\"true\"\n ></i>\n </ng-template>\n </div>\n </div>\n <ng-container *ngIf=\"loading && !loaded\">\n <div class=\"w-100 text-center mt-3\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n </ng-container>\n <ng-container *ngIf=\"posts?.length && !loading\">\n <div class=\"blog-list\">\n <div class=\"row mt-4 ms-1 me-1 blog-listing\"\n *ngFor=\"let post of data\">\n <div class=\"col-md-6 col-sm-12 col-xs-12 my-auto\"\n [routerLink]=\"['/resource', post.slug]\">\n <div class=\"list-blog-image\">\n <img [src]=\"post.picture?.url\"\n alt=\"Post List\"\n class=\"img-fluid\" />\n </div>\n </div>\n <div class=\"col-md-6 col-sm-12 col-xs-12 px-4 position-relative\">\n <div class=\"mt-4\">\n <div class=\"author mb-3 d-flex\">\n <div class=\"avatar-image\">\n <a [attr.disabled]=\"!userLoggedIn\"\n [routerLink]=\"['/members', post?.author?.slug]\">\n <img *ngIf=\"post.author?.avatar\"\n [src]=\"post.author?.avatar[0]?.url\"\n alt=\"Author\" />\n <img *ngIf=\"!post.author?.avatar\"\n src=\"/assets/img/icons/male.png\"\n alt=\"Author\"\n class=\"default-user-image\" />\n </a>\n </div>\n\n <div class=\"author-name ps-2\">\n <a [attr.disabled]=\"!userLoggedIn\"\n [routerLink]=\"['/members', post?.author?.slug]\"\n class=\"name\">\n {{ post.author.first_name }}\n <i class=\"fas fa-crown\" aria-hidden=\"true\"></i></a>\n <ul>\n <li>\n <a href=\"javascript:void(0);\">\n {{ post.published_at | date: 'dd/MM/yyyy' }}\n </a>\n </li>\n <li>.</li>\n <li>\n <a href=\"javascript:void(0);\">{{ thisPostReadingTime(post.body) }}\n </a>\n </li>\n </ul>\n </div>\n <div class=\"share-post\">\n <div class=\"dropdown\">\n <a href=\"#\"\n aria-label=\"Post Menu\"\n id=\"dropdownMenuLink\"\n data-bs-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n (keydown.enter)=\"$event.preventDefault(); $event.target.click()\"\n (keydown.space)=\"$event.preventDefault(); $event.target.click()\"\n aria-expanded=\"false\">\n <i class=\"fas fa-ellipsis-v\" aria-hidden=\"true\"></i>\n </a>\n <div class=\"dropdown-menu\"\n aria-labelledby=\"dropdownMenuLink\">\n <a class=\"dropdown-item\"\n href=\"http://www.facebook.com/\"\n rel=\"noopener noreferrer\"\n target=\"_blank\">\n <i class=\"fas fa-share\" aria-hidden=\"true\"></i> Share Post\n </a>\n </div>\n </div>\n </div>\n </div>\n <h4 [routerLink]=\"['/resource', post.slug]\"\n class=\"title my-3\">{{ post.title }}</h4>\n <p [routerLink]=\"['/resource', post.slug]\"\n class=\"body mb-5 pb-3 post-body-text\">\n {{ post.body | removeHtml: 'quill' | textTruncate: 200 }}\n </p>\n <div class=\"blog-view py-3 blog-list-write-view\">\n <ul class=\"d-flex\">\n <li>{{ post.view !== null ? post.view : '0' }} View</li>\n <li><a [routerLink]=\"['/resource', post.slug]\">Write Comment</a></li>\n <li>\n <a [routerLink]=\"['/resource', post.slug]\" aria-label=\"Blog\"><i class=\"far fa-heart\" aria-hidden=\"true\"></i></a>\n </li>\n </ul>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"!posts?.length && loaded\">\n <p>No blog posts available</p>\n </ng-container>\n</div>\n", styles: [":root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}body{background:#fff}.blog-listing{border:1px solid rgb(238,238,238);cursor:pointer}.all-posts{margin:5em auto 0;max-width:980px;padding:14px 20px;width:100%}ul.tags{display:inline-flex;font-size:16px;font-weight:400}ul.tags li{color:#337ab7;cursor:pointer;font-weight:600;margin-right:20px}ul.tags li:hover{color:#000}.search{position:relative}.search input{border:0;border-bottom:1px solid rgb(213,206,206)}.search i{position:absolute;right:5px}.blog-list .blog-listing h4{color:#000;font:28px/1.3 Roboto,sans-serif;transition:all .5s}.blog-list .blog-listing h4:hover{color:#0045c7}.blog-list .blog-listing p.body{color:#b3b3b3;font:16px/1.4 Roboto,sans-serif;transition:all .5s}.blog-list .blog-listing p.body:hover{color:#0045c7}.blog-list .blog-listing p.body p{color:inherit;font:inherit;transition:inherit}.blog-list .blog-listing p.body p:hover{color:#0045c7}.blog-list .blog-listing .list-blog-image img{padding:25px}.blog-list .blog-listing .author .avatar-image{border:1px solid rgb(0,0,0);border-radius:50px;height:50px;clip-path:circle(50% at 50% 50%);width:50px}.blog-list .blog-listing .author .avatar-image img{left:50%;position:relative;top:50%;transform:translate(-50%,-50%)}.blog-list .blog-listing .author .avatar-image .default-user-image{width:50px}.blog-list .blog-listing .author .author-name p.name{color:#000;font:14px/1 Roboto,sans-serif;margin:0;transition:all .5s}.blog-list .blog-listing .author .author-name p.name:hover{color:#0045c7}.blog-list .blog-listing .author .author-name p.name i{color:#000}.blog-list .blog-listing .author .author-name ul li{display:inline-block;padding-right:10px;vertical-align:middle}.blog-list .blog-listing .author .author-name ul li a{color:#b3b3b3;font:12px/1 Roboto,sans-serif}.blog-list .blog-listing .author .share-post{flex-grow:3;position:relative;text-align:right}.blog-list .blog-listing .author .share-post i{color:var(--first)}.blog-list .blog-listing .author .share-post .dropdown-menu{border:0 0;box-shadow:0 3px 8px #0003;left:auto!important;right:0;top:20px!important;transform:translate(0)!important}.blog-list .blog-listing .blog-view{border-top:1px solid rgb(238,238,238)}.blog-list .blog-listing .blog-view ul li{color:#b3b3b3;font:12px/1 Roboto,sans-serif;padding-right:14px}.blog-list .blog-listing .blog-view ul li a{color:inherit;font:inherit;transition:all .5s}.blog-list .blog-listing .blog-view ul li a:hover{color:#0045c7}.blog-list .blog-listing .blog-view ul li:last-child{flex-grow:3;padding-right:0;text-align:right}.blog-list .blog-listing .blog-view ul li:last-child i{color:#e84a43;font-size:14px}@media only screen and (max-width: 1024px){.cust-mt{padding:14px 5px}.cust-mt .blog-list .blog-listing h4{font:20px/1.3 Roboto,sans-serif}.cust-mt .blog-list .blog-listing p.body{font:.9rem/1.3 Roboto,sans-serif}.cust-mt .blog-list .blog-listing p.body p{font:inherit}.cust-mt .blog-list .blog-listing .blog-image{height:300px}}@media only screen and (max-width: 767px){.blog-list .blog-listing{height:auto;max-height:none;overflow:visible}.blog-list .blog-listing .blog-view{padding-bottom:1rem}}@media (min-width: 768px){.blog-list-write-view{position:absolute}.blog-view{bottom:0;width:92%}}.post-body-text:hover{color:var(--titles)!important}\n"] }]
|
|
128
|
+
}], ctorParameters: () => [{ type: i1.ResourceService }, { type: i2.TagService }, { type: i0.Injector }] });
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resources-list.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/resources-list/resources-list.component.ts","../../../../../../../../libs/resource-module/src/lib/public/components/resources-list/resources-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\n\nimport { Resource, Tag } from '@posiwise/admin-module';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { TagService } from '@posiwise/common-services';\nimport { TOKEN_KEY } from '@posiwise/common-utilities';\n\nimport { forkJoin } from 'rxjs';\n\nimport { ResourceService } from '../../../resource.service';\n\n@Component({\n    selector: 'pw-posts-list',\n    templateUrl: './resources-list.component.html',\n    styleUrls: ['./resources-list.component.scss'],\n    encapsulation: ViewEncapsulation.None\n})\nexport class ResourceListComponent extends AppBaseComponent implements OnInit, OnDestroy {\n    private delayTimeout: ReturnType<typeof setTimeout> | null = null;\n\n    data = [];\n\n    posts: Resource[] = [];\n    tags: Tag[] = [];\n\n    searchTextItems = '';\n    searchInput = false;\n\n    readingTime: number;\n\n    totalRecords: number;\n\n    loading = true;\n    loaded = false;\n\n    masterSubscriptionId: number;\n    subscriptionId;\n    userLoggedIn: boolean;\n\n    constructor(\n        private readonly resourceService: ResourceService,\n        private readonly tagService: TagService,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.subscriptionId = data?.subscriptionId;\n                });\n            }\n        });\n        this.masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n        this.getPostsAndTags();\n        this.readingTime = 0;\n    }\n\n    getPostsAndTags() {\n        this.loading = true;\n        this.loaded = false;\n        forkJoin({\n            resPosts: this.resourceService.getPublicPosts(\n                this.masterSubscriptionId,\n                1,\n                100,\n                this.searchTextItems\n            ),\n            resTags: this.tagService.getTagsByType(\n                'post_categories',\n                {},\n                this.subscriptionId || this.masterSubscriptionId\n            )\n        })\n            .subscribe(res => {\n                // posts\n                this.posts = res?.resPosts?.posts;\n                this.data = res?.resPosts?.posts;\n                this.totalRecords = this.posts?.length;\n                // tags\n                this.tags = res?.resTags?.tags;\n            })\n            .add(() => {\n                this.loading = false;\n                this.loaded = true;\n            });\n    }\n\n    getPosts(page: number, pageSize: number) {\n        this.loading = true;\n        this.loaded = false;\n        this.resourceService\n            .getPublicPosts(this.masterSubscriptionId, page, pageSize, this.searchTextItems)\n            .subscribe(response => {\n                this.posts = response.posts;\n                this.data = response.posts;\n                this.totalRecords = this.posts?.length;\n            })\n            .add(() => {\n                this.loading = false;\n                this.loaded = true;\n            });\n    }\n\n    showSearch(close: string) {\n        this.searchInput = !this.searchInput;\n        if (close) {\n            this.searchTextItems = '';\n            this.getPosts(1, 100);\n        }\n    }\n\n    onSearch(seconds: number) {\n        let delay = 0;\n        delay = seconds * 1000;\n        clearTimeout(this.delayTimeout);\n        // wait for timeout before get posts\n        const delayTimeout = setTimeout(() => {\n            this.getPosts(1, 100);\n        }, delay);\n\n        this.delayTimeout = delayTimeout;\n    }\n\n    tagPost(selectedTag) {\n        let filtered;\n        this.data = [];\n        this.posts.forEach(element => {\n            if (element.tags.length > 0) {\n                filtered = element.tags.filter(tag => tag.id === selectedTag.id);\n                if (filtered.length > 0) {\n                    this.data.push(element);\n                }\n            }\n        });\n    }\n\n    thisPostReadingTime(text: string): string {\n        if (text) {\n            const wordsPerMinute = 200;\n            const noOfWords = text.split(/\\s/g).length;\n            const minutes = noOfWords / wordsPerMinute;\n            const readTime = Math.ceil(minutes);\n\n            return `${readTime} minute read`;\n        }\n\n        return '';\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<pw-header/>\n<div class=\"all-posts py-5\">\n  <div class=\"row mt-5 mb-4 px-2\">\n    <div class=\"col-md-9\">\n      <ul class=\"tags\">\n        <li (keydown.enter)=\"getPosts(1, 100)\" (click)=\"getPosts(1, 100)\">All Resources</li>\n        <li *ngFor=\"let tag of tags\"\n          (keydown.enter)=\"tagPost(tag)\"\n          (click)=\"tagPost(tag)\">{{ tag.name }}</li>\n      </ul>\n    </div>\n    <div class=\"col-md-3\">\n      <div class=\"search\"\n        *ngIf=\"searchInput; else searchIcon\">\n        <input type=\"text\"\n          class=\"w-100\"\n          placeholder=\"search...\"\n          [(ngModel)]=\"searchTextItems\"\n          (keydown.enter)=\"onSearch(0.5)\" />\n        <i class=\"fa fa-times\" (click)=\"showSearch('close')\" (keydown.enter)=\"showSearch('close')\"  aria-hidden=\"true\"></i>\n      </div>\n      <ng-template #searchIcon>\n        <i\n                    class=\"fa fa-search w-100 text-end\"\n                    (click)=\"showSearch('open')\"\n                    (keydown.enter)=\"showSearch('open')\"\n                    aria-hidden=\"true\"\n                ></i>\n      </ng-template>\n    </div>\n  </div>\n  <ng-container *ngIf=\"loading && !loaded\">\n    <div class=\"w-100 text-center mt-3\">\n      <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n    </div>\n  </ng-container>\n  <ng-container *ngIf=\"posts?.length && !loading\">\n    <div class=\"blog-list\">\n      <div class=\"row mt-4 ms-1 me-1 blog-listing\"\n        *ngFor=\"let post of data\">\n        <div class=\"col-md-6 col-sm-12 col-xs-12 my-auto\"\n          [routerLink]=\"['/resource', post.slug]\">\n          <div class=\"list-blog-image\">\n            <img [src]=\"post.picture?.url\"\n              alt=\"Post List\"\n              class=\"img-fluid\" />\n          </div>\n        </div>\n        <div class=\"col-md-6 col-sm-12 col-xs-12 px-4 position-relative\">\n          <div class=\"mt-4\">\n            <div class=\"author mb-3 d-flex\">\n              <div class=\"avatar-image\">\n                <a [attr.disabled]=\"!userLoggedIn\"\n                  [routerLink]=\"['/members', post?.author?.slug]\">\n                  <img *ngIf=\"post.author?.avatar\"\n                    [src]=\"post.author?.avatar[0]?.url\"\n                    alt=\"Author\" />\n                  <img *ngIf=\"!post.author?.avatar\"\n                    src=\"/assets/img/icons/male.png\"\n                    alt=\"Author\"\n                    class=\"default-user-image\" />\n                </a>\n              </div>\n\n              <div class=\"author-name ps-2\">\n                <a [attr.disabled]=\"!userLoggedIn\"\n                  [routerLink]=\"['/members', post?.author?.slug]\"\n                  class=\"name\">\n                  {{ post.author.first_name }}\n                  <i class=\"fas fa-crown\" aria-hidden=\"true\"></i></a>\n                <ul>\n                  <li>\n                    <a href=\"javascript:void(0);\">\n                      {{ post.published_at | date: 'dd/MM/yyyy' }}\n                    </a>\n                  </li>\n                  <li>.</li>\n                  <li>\n                    <a href=\"javascript:void(0);\">{{ thisPostReadingTime(post.body) }}\n                    </a>\n                  </li>\n                </ul>\n              </div>\n              <div class=\"share-post\">\n                <div class=\"dropdown\">\n                  <a href=\"#\"\n                    aria-label=\"Post Menu\"\n                    id=\"dropdownMenuLink\"\n                    data-bs-toggle=\"dropdown\"\n                    aria-haspopup=\"true\"\n                    (keydown.enter)=\"$event.preventDefault(); $event.target.click()\"\n                    (keydown.space)=\"$event.preventDefault(); $event.target.click()\"\n                    aria-expanded=\"false\">\n                    <i class=\"fas fa-ellipsis-v\" aria-hidden=\"true\"></i>\n                  </a>\n                  <div class=\"dropdown-menu\"\n                    aria-labelledby=\"dropdownMenuLink\">\n                    <a class=\"dropdown-item\"\n                      href=\"http://www.facebook.com/\"\n                      rel=\"noopener noreferrer\"\n                      target=\"_blank\">\n                      <i class=\"fas fa-share\" aria-hidden=\"true\"></i> Share Post\n                    </a>\n                  </div>\n                </div>\n              </div>\n            </div>\n            <h4 [routerLink]=\"['/resource', post.slug]\"\n              class=\"title my-3\">{{ post.title }}</h4>\n            <p [routerLink]=\"['/resource', post.slug]\"\n              class=\"body mb-5 pb-3 post-body-text\">\n              {{ post.body | removeHtml: 'quill' | textTruncate: 200 }}\n            </p>\n            <div class=\"blog-view py-3 blog-list-write-view\">\n              <ul class=\"d-flex\">\n                <li>{{ post.view !== null ? post.view : '0' }} View</li>\n                <li><a [routerLink]=\"['/resource', post.slug]\">Write Comment</a></li>\n                <li>\n                  <a [routerLink]=\"['/resource', post.slug]\" aria-label=\"Blog\"><i class=\"far fa-heart\" aria-hidden=\"true\"></i></a>\n                </li>\n              </ul>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"!posts?.length && loaded\">\n    <p>No blog posts available</p>\n  </ng-container>\n</div>\n"]}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { Component, Injector, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
3
|
+
import { AppBaseComponent } from '@posiwise/app-base-component';
|
|
4
|
+
import { CustomToastService } from '@posiwise/common-services';
|
|
5
|
+
import { TOKEN_KEY } from '@posiwise/common-utilities';
|
|
6
|
+
import { HelperService } from '@posiwise/helper-service';
|
|
7
|
+
import { ResourceService } from '../../../resource.service';
|
|
8
|
+
import { ResourceBlog } from '../../../shared/models/resource.model';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "../../../resource.service";
|
|
11
|
+
import * as i2 from "@posiwise/common-services";
|
|
12
|
+
import * as i3 from "@angular/platform-browser";
|
|
13
|
+
import * as i4 from "@angular/common";
|
|
14
|
+
import * as i5 from "@angular/router";
|
|
15
|
+
import * as i6 from "@posiwise/shared-components";
|
|
16
|
+
import * as i7 from "ngx-sharebuttons/buttons";
|
|
17
|
+
import * as i8 from "@angular/forms";
|
|
18
|
+
import * as i9 from "@posiwise/directives";
|
|
19
|
+
import * as i10 from "@jsverse/transloco";
|
|
20
|
+
export class ResourceReadComponent extends AppBaseComponent {
|
|
21
|
+
constructor(resourceService, toastr, injector, sanitizer) {
|
|
22
|
+
super(injector);
|
|
23
|
+
this.resourceService = resourceService;
|
|
24
|
+
this.toastr = toastr;
|
|
25
|
+
this.sanitizer = sanitizer;
|
|
26
|
+
this.recentPosts = [];
|
|
27
|
+
this.postComments = [];
|
|
28
|
+
this.userLoggedIn = false;
|
|
29
|
+
this.buttonBusy = false;
|
|
30
|
+
this.commentForm = ResourceBlog.getResourcePostsForm();
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
this.masterSubscriptionId = this.appConfig.master_subscription.subscription_id;
|
|
34
|
+
this.route.params.subscribe(params => {
|
|
35
|
+
this.slug = params['slug'] || '';
|
|
36
|
+
this.getBlogItem(this.slug);
|
|
37
|
+
});
|
|
38
|
+
this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {
|
|
39
|
+
this.userLoggedIn = !!res;
|
|
40
|
+
if (this.userLoggedIn) {
|
|
41
|
+
this.userService.getUserInfo().subscribe(data => {
|
|
42
|
+
this.user = data;
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
readingTime(text) {
|
|
48
|
+
if (text) {
|
|
49
|
+
const textContent = text.toString();
|
|
50
|
+
const wordsPerMinute = 200;
|
|
51
|
+
const noOfWords = textContent.split(/\s/g).length;
|
|
52
|
+
const minutes = noOfWords / wordsPerMinute;
|
|
53
|
+
const readTime = Math.ceil(minutes);
|
|
54
|
+
return `${readTime} minute read`;
|
|
55
|
+
}
|
|
56
|
+
return '';
|
|
57
|
+
}
|
|
58
|
+
handleImageError(event, fallbackPath) {
|
|
59
|
+
HelperService.handleImageFallbackPath(event, fallbackPath);
|
|
60
|
+
}
|
|
61
|
+
getBlogItem(slug) {
|
|
62
|
+
this.resourceService.getPostBySlug(slug).subscribe(response => {
|
|
63
|
+
let blogBody;
|
|
64
|
+
if (response?.body) {
|
|
65
|
+
blogBody = HelperService.sanitizeQuillBody(response.body, this.sanitizer);
|
|
66
|
+
}
|
|
67
|
+
this.post = { ...response, body: blogBody };
|
|
68
|
+
this.postComments = response.entity_comments;
|
|
69
|
+
this.getPosts(1, 4);
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
getPosts(page, pageSize) {
|
|
73
|
+
this.resourceService
|
|
74
|
+
.getPublicPosts(this.masterSubscriptionId, page, pageSize, '')
|
|
75
|
+
.subscribe(response => {
|
|
76
|
+
this.recentPosts = response.posts.filter(post => post.slug !== this.post.slug);
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
onComment() {
|
|
80
|
+
this.buttonBusy = true;
|
|
81
|
+
const data = { ...this.commentForm.value };
|
|
82
|
+
data.related_entity_id = this.post?.id;
|
|
83
|
+
data.related_entity_type = 'Post';
|
|
84
|
+
data.user_id = this.user?.id;
|
|
85
|
+
this.resourceService
|
|
86
|
+
.postComments(data)
|
|
87
|
+
.subscribe(() => {
|
|
88
|
+
this.getBlogItem(this.slug);
|
|
89
|
+
this.commentForm.reset();
|
|
90
|
+
this.toastr.success(this.translation.translate('Resource.Posts.CommentAdded'));
|
|
91
|
+
})
|
|
92
|
+
.add(() => {
|
|
93
|
+
this.buttonBusy = false;
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
tagPost(selectedTag) {
|
|
97
|
+
this.recentPosts = this.recentPosts.filter(element => {
|
|
98
|
+
let filtered;
|
|
99
|
+
if (element.tags?.length) {
|
|
100
|
+
filtered = element.tags.filter(tag => tag.tag_category_id === selectedTag.tag_category_id);
|
|
101
|
+
return { element, filtered };
|
|
102
|
+
}
|
|
103
|
+
return {};
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
trackByTagId(_index, item) {
|
|
107
|
+
return item.id;
|
|
108
|
+
}
|
|
109
|
+
trackByRecentPost(_index, item) {
|
|
110
|
+
return item.id;
|
|
111
|
+
}
|
|
112
|
+
trackByComment(_index, item) {
|
|
113
|
+
return item.id;
|
|
114
|
+
}
|
|
115
|
+
ngOnDestroy() {
|
|
116
|
+
super.ngOnDestroy();
|
|
117
|
+
}
|
|
118
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceReadComponent, deps: [{ token: i1.ResourceService }, { token: i2.CustomToastService }, { token: i0.Injector }, { token: i3.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
119
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ResourceReadComponent, selector: "pw-post-read", usesInheritance: true, ngImport: i0, template: "<pw-header/>\n<div class=\"read-post mt-5 pt-5\">\n <div class=\"show-blog\">\n <div class=\"row\">\n <!-- content -->\n <div class=\"col-12\">\n <ul class=\"d-flex align-items-center mb-4 position-relative\">\n <li>\n <a href=\"javascript:void(0);\">\n <div class=\"avatar-image\">\n <a [attr.disabled]=\"!userLoggedIn\"\n [routerLink]=\"['/members', post?.author?.slug]\">\n <img *ngIf=\"post?.author?.avatar\"\n [src]=\"post?.author?.avatar[0].url\"\n alt=\"author\" />\n <img *ngIf=\"!post?.author?.avatar\"\n height=\"45\"\n width=\"45\"\n src=\"/assets/img/icons/male.png\"\n alt=\"author\" /></a>\n </div>\n </a>\n </li>\n <li>\n <a [attr.disabled]=\"!userLoggedIn\"\n [routerLink]=\"['/members', post?.author?.slug]\"\n class=\"name\">\n {{ post?.author?.first_name }}\n <i class=\"fas fa-crown\" aria-hidden=\"true\"></i></a>\n </li>\n <li>\n <a class=\"text-dark\"\n href=\"javascript:void(0);\">{{\n post?.author.published_at\n }}</a>\n </li>\n <li>.</li>\n <li>\n <a class=\"text-dark\"\n href=\"javascript:void(0);\">\n {{ readingTime(post?.body) }}\n </a>\n </li>\n <li class=\"social-media\">\n <div class=\"share-post\">\n <div class=\"dropdown\">\n <a href=\"#\"\n id=\"dropdownMenuLink2\"\n data-bs-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n aria-label=\"Menu\"\n (keydown.enter)=\"$event.preventDefault(); $event.target.click()\"\n (keydown.space)=\"$event.preventDefault(); $event.target.click()\"\n aria-expanded=\"false\">\n <i class=\"fas fa-ellipsis-v\" aria-hidden=\"true\"></i>\n </a>\n\n <div class=\"dropdown-menu\"\n aria-labelledby=\"dropdownMenuLink2\">\n <a data-bs-toggle=\"modal\"\n data-bs-target=\"#exampleModal\"\n class=\"dropdown-item\"\n href=\"javascript:void(0);\">\n <i class=\"fas fa-share\" aria-hidden=\"true\"></i> Share Post\n </a>\n </div>\n </div>\n </div>\n </li>\n </ul>\n <h2 class=\"mb-3\">{{ post?.title }}</h2>\n <div class=\"ql-snow body-quill\"\n >\n <div class=\"ql-editor body post-body-text\"\n [innerHTML]=\"post?.body\">\n </div>\n </div>\n\n <ul class=\"bottom-social-icons d-flex justify-content-between mt-5 border-top border-bottom py-3\">\n <li class=\"social-media-blog-page\">\n <div class=\"share-post\">\n <div class=\"dropdown\">\n <a href=\"#\"\n aria-label=\"Menu\"\n (keydown.enter)=\"$event.preventDefault(); $event.target.click()\"\n (keydown.space)=\"$event.preventDefault(); $event.target.click()\"\n id=\"dropdownMenuLink\"\n data-bs-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\">\n <i class=\"fas fa-ellipsis-v\" aria-hidden=\"true\"></i>\n </a>\n\n <div class=\"dropdown-menu\"\n aria-labelledby=\"dropdownMenuLink\">\n <a data-bs-toggle=\"modal\"\n data-bs-target=\"#exampleModal\"\n class=\"dropdown-item\"\n href=\"javascript:void(0);\">\n <i class=\"fas fa-share\" aria-hidden=\"true\"></i> Share Post\n </a>\n </div>\n </div>\n </div>\n </li>\n <li>\n <ul>\n <li *ngFor=\"let tag of post?.tags; trackBy: trackByTagId\"\n (keydown.enter)=\"tagPost(tag)\"\n (click)=\"tagPost(tag)\">\n {{ tag.name }}\n </li>\n </ul>\n </li>\n </ul>\n <ul class=\"d-flex justify-content-between mt-3 views\">\n <li>\n <span>{{ post?.view || 0 }} views</span>\n </li>\n <li><i class=\"far fa-heart\" aria-hidden=\"true\"></i></li>\n </ul>\n </div>\n <!--content end -->\n </div>\n <!-- modal for share buttons -->\n <div class=\"modal fade\"\n id=\"exampleModal\"\n tabindex=\"-1\"\n aria-labelledby=\"exampleModalLabel\">\n <div class=\"modal-dialog modal-dialog-centered\" >\n <div class=\"modal-content\">\n <div class=\"modal-header\">\n <h5 class=\"modal-title\"\n id=\"exampleModalLabel\">Share the post</h5>\n <button type=\"button\"\n class=\"btn-close float-end\"\n data-dismiss=\"modal\"\n aria-label=\"Close\">\n <span>×</span>\n </button>\n </div>\n <div class=\"modal-body\">\n <share-buttons theme=\"material-dark\"\n show=\"7\"></share-buttons>\n </div>\n <div class=\"modal-footer\">\n <button type=\"button\"\n class=\"btn btn-primary\"\n data-dismiss=\"modal\">\n Close\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- recent posts -->\n <div class=\"related-posts mt-5\">\n <ul class=\"d-flex justify-content-between\">\n <li>\n <h5>Recent Resources</h5>\n </li>\n <li><a [routerLink]=\"['/resource']\">See All</a></li>\n </ul>\n <div class=\"row mt-4\">\n <div class=\"col-sm-6 col-md-6 col-lg-4 col-xs-12 mb-2\"\n *ngFor=\"let recentPost of recentPosts; trackBy: trackByRecentPost\">\n <div class=\"recent-post\"\n [routerLink]=\"['/resource', recentPost.slug]\">\n <div class=\"blog-image\">\n <img [src]=\"recentPost.picture.url\"\n alt=\"Resource\" />\n </div>\n <h5 class=\"pt-4 blog-title ps-3 pe-3\">{{ recentPost?.title }}</h5>\n <div class=\"blog-view pt-3 ps-3 pe-3\">\n <p>{{ recentPost.view !== null ? recentPost.view : '0' }} View</p>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"row mt-5 mb-4\">\n <div class=\"col-12\">\n <form class=\"comments-sec\"\n [formGroup]=\"commentForm\"\n (ngSubmit)=\"onComment()\"\n *ngIf=\"userLoggedIn; else userLoggedOut\">\n <div class=\"col-12 pt-4\">\n <!-- Comment Massage -->\n <pw-input-container label=\"Write a response\"\n name=\"comment\"\n errorMsg=\"Please enter comment\">\n <textarea type=\"text\"\n class=\"form-control\"\n formControlName=\"comment\"></textarea>\n </pw-input-container>\n\n <div class=\"text-end mt-4\">\n <button type=\"submit\"\n [buttonBusy]=\"buttonBusy\"\n class=\"btn btn-primary\">\n {{ 'Button.Submit' | transloco }}\n </button>\n </div>\n </div>\n </form>\n <ng-template #userLoggedOut>\n <p class=\"text-center pt-3 pb-3 userNotLoggedIn\">\n <a [routerLink]=\"['/login']\">Log in</a>\n to leave a comment!\n </p>\n </ng-template>\n </div>\n </div>\n <div class=\"row mt-5 mb-5\">\n <div class=\"col-12\"\n *ngFor=\"let comment of postComments; trackBy: trackByComment\">\n <div class=\"comment-post mt-2\">\n <img *ngIf=\"comment?.user?.avatar\"\n [src]=\"comment.user?.avatar[0]?.url\"\n alt=\"avatar\"\n width=\"45\"\n height=\"45\"\n class=\"rounded-circle me-3 mb-2\"\n (error)=\"handleImageError($event, 'assets/img/icons/male.png')\" />\n <img *ngIf=\"!comment?.user?.avatar\"\n alt=\"avatar\"\n width=\"45\"\n height=\"45\"\n class=\"rounded-circle me-3 mb-2\"\n src=\"assets/img/icons/male.png\" />\n <small>{{ comment.user?.first_name ? comment.user?.first_name : '' }}\n {{ comment.user?.last_name ? comment.user?.last_name : '' }}\n </small>\n <p>{{ comment.comment }}</p>\n <p class=\"text-end comment-date\">{{ comment.created_at | date: 'dd/MM/yyyy' }}</p>\n </div>\n </div>\n </div>\n</div>\n", styles: [":root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}.show-blog,.recent-post{border:1px solid rgb(238,238,238)}.recent-post .blog-image{height:250px;min-height:250px}.recent-post .blog-image img{height:100%;width:100%}.recent-post .blog-title{display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:300px}.recent-post .blog-view{border-top:1px solid rgb(238,238,238)}body{background:#fff}form.comments-sec{background-color:#f7f7f7;border:1px solid rgb(238,238,238)}form.comments-sec .no-padding{padding:0}form.comments-sec button{font-size:16px;margin-bottom:20px;margin-right:20px;padding:10px 25px;text-transform:uppercase}form.comments-sec label{background-color:#eee;color:gray;display:inline-block;margin:0;padding:15px;width:100%}form.comments-sec .mb-3{margin:0;padding:20px}form.comments-sec .mb-3 textarea{border:1px solid rgb(238,238,238);height:150px}.userNotLoggedIn{background:#f7f7f7;border:1px solid rgb(238,238,238);font-weight:400}.userNotLoggedIn a{color:#4444bc!important}.comment-post{background:#f7f7f7;border:1px solid rgb(238,238,238);padding:20px}.comment-post .comment-date{color:#777;font-size:14px;font-style:italic;margin:0}share-buttons{background-color:#eee;margin-bottom:10px}.read-post{margin:0 auto 20px;max-width:940px;padding-top:20px}.read-post .show-blog{padding:5rem 5rem 3rem}.read-post .show-blog ul li{display:inline-block;padding-right:10px}.read-post .show-blog ul li a{font:13px/1 Roboto,sans-serif}.read-post .show-blog ul li a .avatar-image{border-radius:50px;height:50px;overflow:hidden;width:50px}.read-post .show-blog ul li a .avatar-image i{color:#000}.read-post .show-blog ul li a .avatar-image i,.read-post .show-blog ul li a .avatar-image img{left:50%;position:relative;top:50%;transform:translate(-50%,-50%)}.read-post .show-blog ul li p.name{color:#000;font:14px/1 Roboto,sans-serif;margin:0;transition:all .5s}.read-post .show-blog ul li p.name:hover{color:#0045c7}.read-post .show-blog ul li p.name i{color:#000}.read-post .show-blog ul.views li:nth-child(2) i{color:#e84a43;font-size:14px}.read-post .show-blog ul.bottom-social-icons li:first-child ul li{padding-right:35px}.read-post .show-blog ul.bottom-social-icons li:first-child ul li i{color:#000}.read-post .show-blog ul.bottom-social-icons li:nth-child(2){padding:0}.read-post .show-blog ul.bottom-social-icons li:nth-child(2) ul li{padding-left:30px}.read-post .show-blog ul.bottom-social-icons li:nth-child(2) ul li a{color:#000}.read-post .show-blog .social-media{position:absolute;right:0;top:50%;transform:translateY(-50%)}.read-post .show-blog .social-media .share-post{flex-grow:3;position:relative;text-align:right}.read-post .show-blog .social-media .share-post i{color:var(--first)}.read-post .show-blog .social-media .share-post .dropdown-menu{border:0 none;box-shadow:0 3px 8px #0003;left:auto!important;right:0;top:20px!important;transform:translate(0)!important}.read-post .show-blog .body p img{max-width:100%}.social-media-blog-page a{color:#000}@media only screen and (max-width: 1024px){.read-post{padding:1rem}.read-post .show-blog{padding:.5rem}.read-post .show-blog h2{font-size:30px}}@media only screen and (max-width: 767px){.read-post,.read-post .show-blog{padding:.5rem}.read-post .show-blog ul{flex-wrap:wrap}.read-post .show-blog ul.bottom-social-icons li{width:100%}.read-post .show-blog ul.bottom-social-icons li ul{display:flex;justify-content:space-around;margin:10px 0}.read-post .show-blog ul.bottom-social-icons li ul li{padding:0!important;text-align:center;width:33.333%}.read-post .show-blog ul li{font:12px/1 Roboto,sans-serif;padding-right:5px}.read-post .show-blog ul li a{font:11px/1 Roboto,sans-serif}.read-post .show-blog ul li p.name{font:12px/1 Roboto,sans-serif}.read-post .show-blog h2{font-size:26px}.read-post .show-blog .body p{font-size:.8rem}}.subscribe-btn{background-color:var(--first);color:#fff}.subscribe-btn:hover{background-color:#fff;color:var(--first)}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i6.InputContainerComponent, selector: "pw-input-container", inputs: ["name", "label", "labelClass", "tooltipPosition", "required", "errorMsg", "isReadOnly", "showTooltip", "tooltipText", "showTriangle", "afterLabel", "showAfterLabel", "showTriangleText", "isLeftTooltip"] }, { kind: "component", type: i6.HeaderComponent, selector: "pw-header", inputs: ["landing"] }, { kind: "component", type: i7.ShareButtons, selector: "share-buttons", inputs: ["theme", "include", "exclude", "show", "url", "title", "description", "image", "tags", "redirectUrl", "autoSetMeta", "showIcon", "showText", "disabled"], outputs: ["opened", "closed"] }, { kind: "directive", type: i8.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i8.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: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i8.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i8.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i9.ButtonBusyDirective, selector: "[buttonBusy]", inputs: ["buttonBusy", "busyText"] }, { kind: "directive", type: i9.LazyImgDirective, selector: "img" }, { kind: "pipe", type: i4.DatePipe, name: "date" }, { kind: "pipe", type: i10.TranslocoPipe, name: "transloco" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
120
|
+
}
|
|
121
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceReadComponent, decorators: [{
|
|
122
|
+
type: Component,
|
|
123
|
+
args: [{ selector: 'pw-post-read', encapsulation: ViewEncapsulation.None, template: "<pw-header/>\n<div class=\"read-post mt-5 pt-5\">\n <div class=\"show-blog\">\n <div class=\"row\">\n <!-- content -->\n <div class=\"col-12\">\n <ul class=\"d-flex align-items-center mb-4 position-relative\">\n <li>\n <a href=\"javascript:void(0);\">\n <div class=\"avatar-image\">\n <a [attr.disabled]=\"!userLoggedIn\"\n [routerLink]=\"['/members', post?.author?.slug]\">\n <img *ngIf=\"post?.author?.avatar\"\n [src]=\"post?.author?.avatar[0].url\"\n alt=\"author\" />\n <img *ngIf=\"!post?.author?.avatar\"\n height=\"45\"\n width=\"45\"\n src=\"/assets/img/icons/male.png\"\n alt=\"author\" /></a>\n </div>\n </a>\n </li>\n <li>\n <a [attr.disabled]=\"!userLoggedIn\"\n [routerLink]=\"['/members', post?.author?.slug]\"\n class=\"name\">\n {{ post?.author?.first_name }}\n <i class=\"fas fa-crown\" aria-hidden=\"true\"></i></a>\n </li>\n <li>\n <a class=\"text-dark\"\n href=\"javascript:void(0);\">{{\n post?.author.published_at\n }}</a>\n </li>\n <li>.</li>\n <li>\n <a class=\"text-dark\"\n href=\"javascript:void(0);\">\n {{ readingTime(post?.body) }}\n </a>\n </li>\n <li class=\"social-media\">\n <div class=\"share-post\">\n <div class=\"dropdown\">\n <a href=\"#\"\n id=\"dropdownMenuLink2\"\n data-bs-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n aria-label=\"Menu\"\n (keydown.enter)=\"$event.preventDefault(); $event.target.click()\"\n (keydown.space)=\"$event.preventDefault(); $event.target.click()\"\n aria-expanded=\"false\">\n <i class=\"fas fa-ellipsis-v\" aria-hidden=\"true\"></i>\n </a>\n\n <div class=\"dropdown-menu\"\n aria-labelledby=\"dropdownMenuLink2\">\n <a data-bs-toggle=\"modal\"\n data-bs-target=\"#exampleModal\"\n class=\"dropdown-item\"\n href=\"javascript:void(0);\">\n <i class=\"fas fa-share\" aria-hidden=\"true\"></i> Share Post\n </a>\n </div>\n </div>\n </div>\n </li>\n </ul>\n <h2 class=\"mb-3\">{{ post?.title }}</h2>\n <div class=\"ql-snow body-quill\"\n >\n <div class=\"ql-editor body post-body-text\"\n [innerHTML]=\"post?.body\">\n </div>\n </div>\n\n <ul class=\"bottom-social-icons d-flex justify-content-between mt-5 border-top border-bottom py-3\">\n <li class=\"social-media-blog-page\">\n <div class=\"share-post\">\n <div class=\"dropdown\">\n <a href=\"#\"\n aria-label=\"Menu\"\n (keydown.enter)=\"$event.preventDefault(); $event.target.click()\"\n (keydown.space)=\"$event.preventDefault(); $event.target.click()\"\n id=\"dropdownMenuLink\"\n data-bs-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\">\n <i class=\"fas fa-ellipsis-v\" aria-hidden=\"true\"></i>\n </a>\n\n <div class=\"dropdown-menu\"\n aria-labelledby=\"dropdownMenuLink\">\n <a data-bs-toggle=\"modal\"\n data-bs-target=\"#exampleModal\"\n class=\"dropdown-item\"\n href=\"javascript:void(0);\">\n <i class=\"fas fa-share\" aria-hidden=\"true\"></i> Share Post\n </a>\n </div>\n </div>\n </div>\n </li>\n <li>\n <ul>\n <li *ngFor=\"let tag of post?.tags; trackBy: trackByTagId\"\n (keydown.enter)=\"tagPost(tag)\"\n (click)=\"tagPost(tag)\">\n {{ tag.name }}\n </li>\n </ul>\n </li>\n </ul>\n <ul class=\"d-flex justify-content-between mt-3 views\">\n <li>\n <span>{{ post?.view || 0 }} views</span>\n </li>\n <li><i class=\"far fa-heart\" aria-hidden=\"true\"></i></li>\n </ul>\n </div>\n <!--content end -->\n </div>\n <!-- modal for share buttons -->\n <div class=\"modal fade\"\n id=\"exampleModal\"\n tabindex=\"-1\"\n aria-labelledby=\"exampleModalLabel\">\n <div class=\"modal-dialog modal-dialog-centered\" >\n <div class=\"modal-content\">\n <div class=\"modal-header\">\n <h5 class=\"modal-title\"\n id=\"exampleModalLabel\">Share the post</h5>\n <button type=\"button\"\n class=\"btn-close float-end\"\n data-dismiss=\"modal\"\n aria-label=\"Close\">\n <span>×</span>\n </button>\n </div>\n <div class=\"modal-body\">\n <share-buttons theme=\"material-dark\"\n show=\"7\"></share-buttons>\n </div>\n <div class=\"modal-footer\">\n <button type=\"button\"\n class=\"btn btn-primary\"\n data-dismiss=\"modal\">\n Close\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- recent posts -->\n <div class=\"related-posts mt-5\">\n <ul class=\"d-flex justify-content-between\">\n <li>\n <h5>Recent Resources</h5>\n </li>\n <li><a [routerLink]=\"['/resource']\">See All</a></li>\n </ul>\n <div class=\"row mt-4\">\n <div class=\"col-sm-6 col-md-6 col-lg-4 col-xs-12 mb-2\"\n *ngFor=\"let recentPost of recentPosts; trackBy: trackByRecentPost\">\n <div class=\"recent-post\"\n [routerLink]=\"['/resource', recentPost.slug]\">\n <div class=\"blog-image\">\n <img [src]=\"recentPost.picture.url\"\n alt=\"Resource\" />\n </div>\n <h5 class=\"pt-4 blog-title ps-3 pe-3\">{{ recentPost?.title }}</h5>\n <div class=\"blog-view pt-3 ps-3 pe-3\">\n <p>{{ recentPost.view !== null ? recentPost.view : '0' }} View</p>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"row mt-5 mb-4\">\n <div class=\"col-12\">\n <form class=\"comments-sec\"\n [formGroup]=\"commentForm\"\n (ngSubmit)=\"onComment()\"\n *ngIf=\"userLoggedIn; else userLoggedOut\">\n <div class=\"col-12 pt-4\">\n <!-- Comment Massage -->\n <pw-input-container label=\"Write a response\"\n name=\"comment\"\n errorMsg=\"Please enter comment\">\n <textarea type=\"text\"\n class=\"form-control\"\n formControlName=\"comment\"></textarea>\n </pw-input-container>\n\n <div class=\"text-end mt-4\">\n <button type=\"submit\"\n [buttonBusy]=\"buttonBusy\"\n class=\"btn btn-primary\">\n {{ 'Button.Submit' | transloco }}\n </button>\n </div>\n </div>\n </form>\n <ng-template #userLoggedOut>\n <p class=\"text-center pt-3 pb-3 userNotLoggedIn\">\n <a [routerLink]=\"['/login']\">Log in</a>\n to leave a comment!\n </p>\n </ng-template>\n </div>\n </div>\n <div class=\"row mt-5 mb-5\">\n <div class=\"col-12\"\n *ngFor=\"let comment of postComments; trackBy: trackByComment\">\n <div class=\"comment-post mt-2\">\n <img *ngIf=\"comment?.user?.avatar\"\n [src]=\"comment.user?.avatar[0]?.url\"\n alt=\"avatar\"\n width=\"45\"\n height=\"45\"\n class=\"rounded-circle me-3 mb-2\"\n (error)=\"handleImageError($event, 'assets/img/icons/male.png')\" />\n <img *ngIf=\"!comment?.user?.avatar\"\n alt=\"avatar\"\n width=\"45\"\n height=\"45\"\n class=\"rounded-circle me-3 mb-2\"\n src=\"assets/img/icons/male.png\" />\n <small>{{ comment.user?.first_name ? comment.user?.first_name : '' }}\n {{ comment.user?.last_name ? comment.user?.last_name : '' }}\n </small>\n <p>{{ comment.comment }}</p>\n <p class=\"text-end comment-date\">{{ comment.created_at | date: 'dd/MM/yyyy' }}</p>\n </div>\n </div>\n </div>\n</div>\n", styles: [":root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}.show-blog,.recent-post{border:1px solid rgb(238,238,238)}.recent-post .blog-image{height:250px;min-height:250px}.recent-post .blog-image img{height:100%;width:100%}.recent-post .blog-title{display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:300px}.recent-post .blog-view{border-top:1px solid rgb(238,238,238)}body{background:#fff}form.comments-sec{background-color:#f7f7f7;border:1px solid rgb(238,238,238)}form.comments-sec .no-padding{padding:0}form.comments-sec button{font-size:16px;margin-bottom:20px;margin-right:20px;padding:10px 25px;text-transform:uppercase}form.comments-sec label{background-color:#eee;color:gray;display:inline-block;margin:0;padding:15px;width:100%}form.comments-sec .mb-3{margin:0;padding:20px}form.comments-sec .mb-3 textarea{border:1px solid rgb(238,238,238);height:150px}.userNotLoggedIn{background:#f7f7f7;border:1px solid rgb(238,238,238);font-weight:400}.userNotLoggedIn a{color:#4444bc!important}.comment-post{background:#f7f7f7;border:1px solid rgb(238,238,238);padding:20px}.comment-post .comment-date{color:#777;font-size:14px;font-style:italic;margin:0}share-buttons{background-color:#eee;margin-bottom:10px}.read-post{margin:0 auto 20px;max-width:940px;padding-top:20px}.read-post .show-blog{padding:5rem 5rem 3rem}.read-post .show-blog ul li{display:inline-block;padding-right:10px}.read-post .show-blog ul li a{font:13px/1 Roboto,sans-serif}.read-post .show-blog ul li a .avatar-image{border-radius:50px;height:50px;overflow:hidden;width:50px}.read-post .show-blog ul li a .avatar-image i{color:#000}.read-post .show-blog ul li a .avatar-image i,.read-post .show-blog ul li a .avatar-image img{left:50%;position:relative;top:50%;transform:translate(-50%,-50%)}.read-post .show-blog ul li p.name{color:#000;font:14px/1 Roboto,sans-serif;margin:0;transition:all .5s}.read-post .show-blog ul li p.name:hover{color:#0045c7}.read-post .show-blog ul li p.name i{color:#000}.read-post .show-blog ul.views li:nth-child(2) i{color:#e84a43;font-size:14px}.read-post .show-blog ul.bottom-social-icons li:first-child ul li{padding-right:35px}.read-post .show-blog ul.bottom-social-icons li:first-child ul li i{color:#000}.read-post .show-blog ul.bottom-social-icons li:nth-child(2){padding:0}.read-post .show-blog ul.bottom-social-icons li:nth-child(2) ul li{padding-left:30px}.read-post .show-blog ul.bottom-social-icons li:nth-child(2) ul li a{color:#000}.read-post .show-blog .social-media{position:absolute;right:0;top:50%;transform:translateY(-50%)}.read-post .show-blog .social-media .share-post{flex-grow:3;position:relative;text-align:right}.read-post .show-blog .social-media .share-post i{color:var(--first)}.read-post .show-blog .social-media .share-post .dropdown-menu{border:0 none;box-shadow:0 3px 8px #0003;left:auto!important;right:0;top:20px!important;transform:translate(0)!important}.read-post .show-blog .body p img{max-width:100%}.social-media-blog-page a{color:#000}@media only screen and (max-width: 1024px){.read-post{padding:1rem}.read-post .show-blog{padding:.5rem}.read-post .show-blog h2{font-size:30px}}@media only screen and (max-width: 767px){.read-post,.read-post .show-blog{padding:.5rem}.read-post .show-blog ul{flex-wrap:wrap}.read-post .show-blog ul.bottom-social-icons li{width:100%}.read-post .show-blog ul.bottom-social-icons li ul{display:flex;justify-content:space-around;margin:10px 0}.read-post .show-blog ul.bottom-social-icons li ul li{padding:0!important;text-align:center;width:33.333%}.read-post .show-blog ul li{font:12px/1 Roboto,sans-serif;padding-right:5px}.read-post .show-blog ul li a{font:11px/1 Roboto,sans-serif}.read-post .show-blog ul li p.name{font:12px/1 Roboto,sans-serif}.read-post .show-blog h2{font-size:26px}.read-post .show-blog .body p{font-size:.8rem}}.subscribe-btn{background-color:var(--first);color:#fff}.subscribe-btn:hover{background-color:#fff;color:var(--first)}\n"] }]
|
|
124
|
+
}], ctorParameters: () => [{ type: i1.ResourceService }, { type: i2.CustomToastService }, { type: i0.Injector }, { type: i3.DomSanitizer }] });
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resources-read.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/resources-read/resources-read.component.ts","../../../../../../../../libs/resource-module/src/lib/public/components/resources-read/resources-read.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAqB,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAE1F,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAGzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAQ,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,uCAAuC,CAAC;;;;;;;;;;;;AAQrE,MAAM,OAAO,qBAAsB,SAAQ,gBAAgB;IAcvD,YACqB,eAAgC,EAChC,MAA0B,EAC3C,QAAkB,EACD,SAAuB;QAExC,KAAK,CAAC,QAAQ,CAAC,CAAC;QALC,oBAAe,GAAf,eAAe,CAAiB;QAChC,WAAM,GAAN,MAAM,CAAoB;QAE1B,cAAS,GAAT,SAAS,CAAc;QAf5C,gBAAW,GAAiB,EAAE,CAAC;QAC/B,iBAAY,GAAsB,EAAE,CAAC;QAOrC,iBAAY,GAAG,KAAK,CAAC;QACrB,eAAU,GAAG,KAAK,CAAC;QASf,IAAI,CAAC,WAAW,GAAG,YAAY,CAAC,oBAAoB,EAAE,CAAC;IAC3D,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,eAAe,CAAC;QAC/E,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACjC,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAClD,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,GAAG,CAAC;YAC1B,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpB,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;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,IAAY;QACpB,IAAI,IAAI,EAAE,CAAC;YACP,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;YACpC,MAAM,cAAc,GAAG,GAAG,CAAC;YAC3B,MAAM,SAAS,GAAG,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC;YAClD,MAAM,OAAO,GAAG,SAAS,GAAG,cAAc,CAAC;YAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAEpC,OAAO,GAAG,QAAQ,cAAc,CAAC;QACrC,CAAC;QAED,OAAO,EAAE,CAAC;IACd,CAAC;IAED,gBAAgB,CAAC,KAAY,EAAE,YAAY;QACvC,aAAa,CAAC,uBAAuB,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;IAC/D,CAAC;IAEO,WAAW,CAAC,IAAY;QAC5B,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;YAC1D,IAAI,QAAQ,CAAC;YACb,IAAI,QAAQ,EAAE,IAAI,EAAE,CAAC;gBACjB,QAAQ,GAAG,aAAa,CAAC,iBAAiB,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;YAC9E,CAAC;YACD,IAAI,CAAC,IAAI,GAAG,EAAE,GAAG,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;YAC5C,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,eAAe,CAAC;YAC7C,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,QAAQ,CAAC,IAAY,EAAE,QAAgB;QAC3C,IAAI,CAAC,eAAe;aACf,cAAc,CAAC,IAAI,CAAC,oBAAoB,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,CAAC;aAC7D,SAAS,CAAC,QAAQ,CAAC,EAAE;YAClB,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnF,CAAC,CAAC,CAAC;IACX,CAAC;IAED,SAAS;QACL,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,MAAM,IAAI,GAAG,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QAC3C,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;QACvC,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC;QAClC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;QAC7B,IAAI,CAAC,eAAe;aACf,YAAY,CAAC,IAAI,CAAC;aAClB,SAAS,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC5B,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,6BAA6B,CAAC,CAAC,CAAC;QACnF,CAAC,CAAC;aACD,GAAG,CAAC,GAAG,EAAE;YACN,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QAC5B,CAAC,CAAC,CAAC;IACX,CAAC;IAED,OAAO,CAAC,WAAW;QACf,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;YACjD,IAAI,QAAQ,CAAC;YACb,IAAI,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC;gBACvB,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAC1B,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,eAAe,KAAK,WAAW,CAAC,eAAe,CAC7D,CAAC;gBAEF,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;YACjC,CAAC;YAED,OAAO,EAAE,CAAC;QACd,CAAC,CAAC,CAAC;IACP,CAAC;IAED,YAAY,CAAC,MAAc,EAAE,IAAoB;QAC7C,OAAO,IAAI,CAAC,EAAE,CAAC;IACnB,CAAC;IAED,iBAAiB,CAAC,MAAc,EAAE,IAAoB;QAClD,OAAO,IAAI,CAAC,EAAE,CAAC;IACnB,CAAC;IAED,cAAc,CAAC,MAAc,EAAE,IAAoB;QAC/C,OAAO,IAAI,CAAC,EAAE,CAAC;IACnB,CAAC;IAEQ,WAAW;QAChB,KAAK,CAAC,WAAW,EAAE,CAAC;IACxB,CAAC;+GA7HQ,qBAAqB;mGAArB,qBAAqB,2ECnBlC,2zRAgPA;;4FD7Na,qBAAqB;kBANjC,SAAS;+BACI,cAAc,iBAGT,iBAAiB,CAAC,IAAI","sourcesContent":["import { Component, Injector, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\nimport { UntypedFormGroup } from '@angular/forms';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nimport { RecentPost, Resource, ResourceComment } from '@posiwise/admin-module';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { CustomToastService } from '@posiwise/common-services';\nimport { TOKEN_KEY, User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { ResourceService } from '../../../resource.service';\nimport { ResourceBlog } from '../../../shared/models/resource.model';\n\n@Component({\n    selector: 'pw-post-read',\n    templateUrl: './resources-read.component.html',\n    styleUrls: ['./resources-read.component.scss'],\n    encapsulation: ViewEncapsulation.None\n})\nexport class ResourceReadComponent extends AppBaseComponent implements OnInit, OnDestroy {\n    post: Resource;\n    user: User;\n    recentPosts: RecentPost[] = [];\n    postComments: ResourceComment[] = [];\n\n    slug: string;\n    masterSubscriptionId: number;\n\n    commentForm: UntypedFormGroup;\n\n    userLoggedIn = false;\n    buttonBusy = false;\n\n    constructor(\n        private readonly resourceService: ResourceService,\n        private readonly toastr: CustomToastService,\n        injector: Injector,\n        private readonly sanitizer: DomSanitizer\n    ) {\n        super(injector);\n        this.commentForm = ResourceBlog.getResourcePostsForm();\n    }\n\n    ngOnInit() {\n        this.masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n        this.route.params.subscribe(params => {\n            this.slug = params['slug'] || '';\n            this.getBlogItem(this.slug);\n        });\n        this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n                });\n            }\n        });\n    }\n\n    readingTime(text: string) {\n        if (text) {\n            const textContent = text.toString();\n            const wordsPerMinute = 200;\n            const noOfWords = textContent.split(/\\s/g).length;\n            const minutes = noOfWords / wordsPerMinute;\n            const readTime = Math.ceil(minutes);\n\n            return `${readTime} minute read`;\n        }\n\n        return '';\n    }\n\n    handleImageError(event: Event, fallbackPath): void {\n        HelperService.handleImageFallbackPath(event, fallbackPath);\n    }\n\n    private getBlogItem(slug: string) {\n        this.resourceService.getPostBySlug(slug).subscribe(response => {\n            let blogBody;\n            if (response?.body) {\n                blogBody = HelperService.sanitizeQuillBody(response.body, this.sanitizer);\n            }\n            this.post = { ...response, body: blogBody };\n            this.postComments = response.entity_comments;\n            this.getPosts(1, 4);\n        });\n    }\n\n    private getPosts(page: number, pageSize: number) {\n        this.resourceService\n            .getPublicPosts(this.masterSubscriptionId, page, pageSize, '')\n            .subscribe(response => {\n                this.recentPosts = response.posts.filter(post => post.slug !== this.post.slug);\n            });\n    }\n\n    onComment() {\n        this.buttonBusy = true;\n        const data = { ...this.commentForm.value };\n        data.related_entity_id = this.post?.id;\n        data.related_entity_type = 'Post';\n        data.user_id = this.user?.id;\n        this.resourceService\n            .postComments(data)\n            .subscribe(() => {\n                this.getBlogItem(this.slug);\n                this.commentForm.reset();\n                this.toastr.success(this.translation.translate('Resource.Posts.CommentAdded'));\n            })\n            .add(() => {\n                this.buttonBusy = false;\n            });\n    }\n\n    tagPost(selectedTag) {\n        this.recentPosts = this.recentPosts.filter(element => {\n            let filtered;\n            if (element.tags?.length) {\n                filtered = element.tags.filter(\n                    tag => tag.tag_category_id === selectedTag.tag_category_id\n                );\n\n                return { element, filtered };\n            }\n\n            return {};\n        });\n    }\n\n    trackByTagId(_index: number, item: { id: number }) {\n        return item.id;\n    }\n\n    trackByRecentPost(_index: number, item: { id: number }) {\n        return item.id;\n    }\n\n    trackByComment(_index: number, item: { id: number }) {\n        return item.id;\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<pw-header/>\n<div class=\"read-post mt-5 pt-5\">\n  <div class=\"show-blog\">\n    <div class=\"row\">\n      <!-- content -->\n      <div class=\"col-12\">\n        <ul class=\"d-flex align-items-center mb-4 position-relative\">\n          <li>\n            <a href=\"javascript:void(0);\">\n              <div class=\"avatar-image\">\n                <a [attr.disabled]=\"!userLoggedIn\"\n                  [routerLink]=\"['/members', post?.author?.slug]\">\n                  <img *ngIf=\"post?.author?.avatar\"\n                    [src]=\"post?.author?.avatar[0].url\"\n                    alt=\"author\" />\n                  <img *ngIf=\"!post?.author?.avatar\"\n                    height=\"45\"\n                    width=\"45\"\n                    src=\"/assets/img/icons/male.png\"\n                    alt=\"author\" /></a>\n              </div>\n            </a>\n          </li>\n          <li>\n            <a [attr.disabled]=\"!userLoggedIn\"\n              [routerLink]=\"['/members', post?.author?.slug]\"\n              class=\"name\">\n              {{ post?.author?.first_name }}\n              <i class=\"fas fa-crown\" aria-hidden=\"true\"></i></a>\n          </li>\n          <li>\n            <a class=\"text-dark\"\n              href=\"javascript:void(0);\">{{\n                            post?.author.published_at\n                        }}</a>\n          </li>\n          <li>.</li>\n          <li>\n            <a class=\"text-dark\"\n              href=\"javascript:void(0);\">\n              {{ readingTime(post?.body) }}\n            </a>\n          </li>\n          <li class=\"social-media\">\n            <div class=\"share-post\">\n              <div class=\"dropdown\">\n                <a href=\"#\"\n                  id=\"dropdownMenuLink2\"\n                  data-bs-toggle=\"dropdown\"\n                  aria-haspopup=\"true\"\n                  aria-label=\"Menu\"\n                  (keydown.enter)=\"$event.preventDefault(); $event.target.click()\"\n                  (keydown.space)=\"$event.preventDefault(); $event.target.click()\"\n                  aria-expanded=\"false\">\n                  <i class=\"fas fa-ellipsis-v\" aria-hidden=\"true\"></i>\n                </a>\n\n                <div class=\"dropdown-menu\"\n                  aria-labelledby=\"dropdownMenuLink2\">\n                  <a data-bs-toggle=\"modal\"\n                    data-bs-target=\"#exampleModal\"\n                    class=\"dropdown-item\"\n                    href=\"javascript:void(0);\">\n                    <i class=\"fas fa-share\" aria-hidden=\"true\"></i> Share Post\n                  </a>\n                </div>\n              </div>\n            </div>\n          </li>\n        </ul>\n        <h2 class=\"mb-3\">{{ post?.title }}</h2>\n        <div class=\"ql-snow body-quill\"\n                    >\n                    <div class=\"ql-editor body post-body-text\"\n                      [innerHTML]=\"post?.body\">\n                    </div>\n                  </div>\n\n        <ul class=\"bottom-social-icons d-flex justify-content-between mt-5 border-top border-bottom py-3\">\n          <li class=\"social-media-blog-page\">\n            <div class=\"share-post\">\n              <div class=\"dropdown\">\n                <a href=\"#\"\n                  aria-label=\"Menu\"\n                  (keydown.enter)=\"$event.preventDefault(); $event.target.click()\"\n                  (keydown.space)=\"$event.preventDefault(); $event.target.click()\"\n                  id=\"dropdownMenuLink\"\n                  data-bs-toggle=\"dropdown\"\n                  aria-haspopup=\"true\"\n                  aria-expanded=\"false\">\n                  <i class=\"fas fa-ellipsis-v\" aria-hidden=\"true\"></i>\n                </a>\n\n                <div class=\"dropdown-menu\"\n                  aria-labelledby=\"dropdownMenuLink\">\n                  <a data-bs-toggle=\"modal\"\n                    data-bs-target=\"#exampleModal\"\n                    class=\"dropdown-item\"\n                    href=\"javascript:void(0);\">\n                    <i class=\"fas fa-share\" aria-hidden=\"true\"></i> Share Post\n                  </a>\n                </div>\n              </div>\n            </div>\n          </li>\n          <li>\n            <ul>\n              <li *ngFor=\"let tag of post?.tags; trackBy: trackByTagId\"\n                (keydown.enter)=\"tagPost(tag)\"\n                (click)=\"tagPost(tag)\">\n                {{ tag.name }}\n              </li>\n            </ul>\n          </li>\n        </ul>\n        <ul class=\"d-flex justify-content-between mt-3 views\">\n          <li>\n            <span>{{ post?.view || 0 }} views</span>\n          </li>\n          <li><i class=\"far fa-heart\" aria-hidden=\"true\"></i></li>\n        </ul>\n      </div>\n      <!--content end -->\n    </div>\n    <!-- modal for share buttons -->\n    <div class=\"modal fade\"\n      id=\"exampleModal\"\n      tabindex=\"-1\"\n      aria-labelledby=\"exampleModalLabel\">\n      <div class=\"modal-dialog modal-dialog-centered\" >\n        <div class=\"modal-content\">\n          <div class=\"modal-header\">\n            <h5 class=\"modal-title\"\n              id=\"exampleModalLabel\">Share the post</h5>\n            <button type=\"button\"\n              class=\"btn-close float-end\"\n              data-dismiss=\"modal\"\n              aria-label=\"Close\">\n              <span>&times;</span>\n            </button>\n          </div>\n          <div class=\"modal-body\">\n            <share-buttons theme=\"material-dark\"\n              show=\"7\"></share-buttons>\n          </div>\n          <div class=\"modal-footer\">\n            <button type=\"button\"\n              class=\"btn btn-primary\"\n              data-dismiss=\"modal\">\n              Close\n            </button>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n  <!-- recent posts -->\n  <div class=\"related-posts mt-5\">\n    <ul class=\"d-flex justify-content-between\">\n      <li>\n        <h5>Recent Resources</h5>\n      </li>\n      <li><a [routerLink]=\"['/resource']\">See All</a></li>\n    </ul>\n    <div class=\"row mt-4\">\n      <div class=\"col-sm-6 col-md-6 col-lg-4 col-xs-12 mb-2\"\n        *ngFor=\"let recentPost of recentPosts; trackBy: trackByRecentPost\">\n        <div class=\"recent-post\"\n          [routerLink]=\"['/resource', recentPost.slug]\">\n          <div class=\"blog-image\">\n            <img [src]=\"recentPost.picture.url\"\n              alt=\"Resource\" />\n          </div>\n          <h5 class=\"pt-4 blog-title ps-3 pe-3\">{{ recentPost?.title }}</h5>\n          <div class=\"blog-view pt-3 ps-3 pe-3\">\n            <p>{{ recentPost.view !== null ? recentPost.view : '0' }} View</p>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div class=\"row mt-5 mb-4\">\n    <div class=\"col-12\">\n      <form class=\"comments-sec\"\n        [formGroup]=\"commentForm\"\n        (ngSubmit)=\"onComment()\"\n        *ngIf=\"userLoggedIn; else userLoggedOut\">\n        <div class=\"col-12 pt-4\">\n          <!-- Comment Massage -->\n          <pw-input-container label=\"Write a response\"\n            name=\"comment\"\n            errorMsg=\"Please enter comment\">\n            <textarea type=\"text\"\n              class=\"form-control\"\n              formControlName=\"comment\"></textarea>\n          </pw-input-container>\n\n          <div class=\"text-end mt-4\">\n            <button type=\"submit\"\n            [buttonBusy]=\"buttonBusy\"\n            class=\"btn btn-primary\">\n            {{ 'Button.Submit' | transloco }}\n          </button>\n          </div>\n        </div>\n      </form>\n      <ng-template #userLoggedOut>\n        <p class=\"text-center pt-3 pb-3 userNotLoggedIn\">\n          <a [routerLink]=\"['/login']\">Log in</a>\n          to leave a comment!\n        </p>\n      </ng-template>\n    </div>\n  </div>\n  <div class=\"row mt-5 mb-5\">\n    <div class=\"col-12\"\n      *ngFor=\"let comment of postComments; trackBy: trackByComment\">\n      <div class=\"comment-post mt-2\">\n        <img *ngIf=\"comment?.user?.avatar\"\n          [src]=\"comment.user?.avatar[0]?.url\"\n          alt=\"avatar\"\n          width=\"45\"\n          height=\"45\"\n          class=\"rounded-circle me-3 mb-2\"\n          (error)=\"handleImageError($event, 'assets/img/icons/male.png')\" />\n        <img *ngIf=\"!comment?.user?.avatar\"\n          alt=\"avatar\"\n          width=\"45\"\n          height=\"45\"\n          class=\"rounded-circle me-3 mb-2\"\n          src=\"assets/img/icons/male.png\" />\n        <small>{{ comment.user?.first_name ? comment.user?.first_name : '' }}\n          {{ comment.user?.last_name ? comment.user?.last_name : '' }}\n        </small>\n        <p>{{ comment.comment }}</p>\n        <p class=\"text-end comment-date\">{{ comment.created_at | date: 'dd/MM/yyyy' }}</p>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { CUSTOM_ELEMENTS_SCHEMA, NgModule } from '@angular/core';
|
|
3
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { GoogleAnalyticsService } from '@posiwise/common-services';
|
|
5
|
+
import { CoreTranslocoModule } from '@posiwise/core-transloco';
|
|
6
|
+
import { DirectivesModule } from '@posiwise/directives';
|
|
7
|
+
import { PipesModule } from '@posiwise/pipes';
|
|
8
|
+
import { PublicModule } from '@posiwise/public-modules';
|
|
9
|
+
import { SharedComponentsModule } from '@posiwise/shared-components';
|
|
10
|
+
import { QuillModule } from 'ngx-quill';
|
|
11
|
+
import { ShareButtonsModule } from 'ngx-sharebuttons/buttons';
|
|
12
|
+
import { ShareIconsModule } from 'ngx-sharebuttons/icons';
|
|
13
|
+
import { NgxUploaderModule } from 'ngx-uploader';
|
|
14
|
+
import { TranslocoModule } from '@jsverse/transloco';
|
|
15
|
+
import { ResourceService } from '../resource.service';
|
|
16
|
+
import { ResourceListComponent } from './components/resources-list/resources-list.component';
|
|
17
|
+
import { ResourceReadComponent } from './components/resources-read/resources-read.component';
|
|
18
|
+
import { BlogPublicRoutingModule } from './resource-public.routing.module';
|
|
19
|
+
import * as i0 from "@angular/core";
|
|
20
|
+
import * as i1 from "ngx-quill";
|
|
21
|
+
export class ResourcePublicModule {
|
|
22
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourcePublicModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
23
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: ResourcePublicModule, declarations: [ResourceListComponent, ResourceReadComponent], imports: [CommonModule,
|
|
24
|
+
PipesModule,
|
|
25
|
+
SharedComponentsModule,
|
|
26
|
+
NgxUploaderModule,
|
|
27
|
+
BlogPublicRoutingModule,
|
|
28
|
+
ShareButtonsModule,
|
|
29
|
+
ShareIconsModule, i1.QuillModule, FormsModule,
|
|
30
|
+
PublicModule,
|
|
31
|
+
CoreTranslocoModule,
|
|
32
|
+
TranslocoModule,
|
|
33
|
+
ReactiveFormsModule,
|
|
34
|
+
DirectivesModule] }); }
|
|
35
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourcePublicModule, providers: [ResourceService, GoogleAnalyticsService], imports: [CommonModule,
|
|
36
|
+
PipesModule,
|
|
37
|
+
SharedComponentsModule,
|
|
38
|
+
NgxUploaderModule,
|
|
39
|
+
BlogPublicRoutingModule,
|
|
40
|
+
ShareButtonsModule,
|
|
41
|
+
ShareIconsModule,
|
|
42
|
+
QuillModule.forRoot(),
|
|
43
|
+
FormsModule,
|
|
44
|
+
PublicModule,
|
|
45
|
+
CoreTranslocoModule,
|
|
46
|
+
TranslocoModule,
|
|
47
|
+
ReactiveFormsModule,
|
|
48
|
+
DirectivesModule] }); }
|
|
49
|
+
}
|
|
50
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourcePublicModule, decorators: [{
|
|
51
|
+
type: NgModule,
|
|
52
|
+
args: [{
|
|
53
|
+
declarations: [ResourceListComponent, ResourceReadComponent],
|
|
54
|
+
imports: [
|
|
55
|
+
CommonModule,
|
|
56
|
+
PipesModule,
|
|
57
|
+
SharedComponentsModule,
|
|
58
|
+
NgxUploaderModule,
|
|
59
|
+
BlogPublicRoutingModule,
|
|
60
|
+
ShareButtonsModule,
|
|
61
|
+
ShareIconsModule,
|
|
62
|
+
QuillModule.forRoot(),
|
|
63
|
+
FormsModule,
|
|
64
|
+
PublicModule,
|
|
65
|
+
CoreTranslocoModule,
|
|
66
|
+
TranslocoModule,
|
|
67
|
+
ReactiveFormsModule,
|
|
68
|
+
DirectivesModule
|
|
69
|
+
],
|
|
70
|
+
providers: [ResourceService, GoogleAnalyticsService],
|
|
71
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA]
|
|
72
|
+
}]
|
|
73
|
+
}] });
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzb3VyY2UtcHVibGljLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcmVzb3VyY2UtbW9kdWxlL3NyYy9saWIvcHVibGljL3Jlc291cmNlLXB1YmxpYy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakUsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRWxFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ25FLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM5QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDeEQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFFckUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUN4QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUMxRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFakQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXJELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUV0RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUM3RixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUM3RixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQzs7O0FBdUIzRSxNQUFNLE9BQU8sb0JBQW9COytHQUFwQixvQkFBb0I7Z0hBQXBCLG9CQUFvQixpQkFwQmQscUJBQXFCLEVBQUUscUJBQXFCLGFBRXZELFlBQVk7WUFDWixXQUFXO1lBQ1gsc0JBQXNCO1lBQ3RCLGlCQUFpQjtZQUNqQix1QkFBdUI7WUFDdkIsa0JBQWtCO1lBQ2xCLGdCQUFnQixrQkFFaEIsV0FBVztZQUNYLFlBQVk7WUFDWixtQkFBbUI7WUFDbkIsZUFBZTtZQUNmLG1CQUFtQjtZQUNuQixnQkFBZ0I7Z0hBS1gsb0JBQW9CLGFBSGxCLENBQUMsZUFBZSxFQUFFLHNCQUFzQixDQUFDLFlBZmhELFlBQVk7WUFDWixXQUFXO1lBQ1gsc0JBQXNCO1lBQ3RCLGlCQUFpQjtZQUNqQix1QkFBdUI7WUFDdkIsa0JBQWtCO1lBQ2xCLGdCQUFnQjtZQUNoQixXQUFXLENBQUMsT0FBTyxFQUFFO1lBQ3JCLFdBQVc7WUFDWCxZQUFZO1lBQ1osbUJBQW1CO1lBQ25CLGVBQWU7WUFDZixtQkFBbUI7WUFDbkIsZ0JBQWdCOzs0RkFLWCxvQkFBb0I7a0JBckJoQyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLHFCQUFxQixFQUFFLHFCQUFxQixDQUFDO29CQUM1RCxPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixXQUFXO3dCQUNYLHNCQUFzQjt3QkFDdEIsaUJBQWlCO3dCQUNqQix1QkFBdUI7d0JBQ3ZCLGtCQUFrQjt3QkFDbEIsZ0JBQWdCO3dCQUNoQixXQUFXLENBQUMsT0FBTyxFQUFFO3dCQUNyQixXQUFXO3dCQUNYLFlBQVk7d0JBQ1osbUJBQW1CO3dCQUNuQixlQUFlO3dCQUNmLG1CQUFtQjt3QkFDbkIsZ0JBQWdCO3FCQUNuQjtvQkFDRCxTQUFTLEVBQUUsQ0FBQyxlQUFlLEVBQUUsc0JBQXNCLENBQUM7b0JBQ3BELE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2lCQUNwQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7IEdvb2dsZUFuYWx5dGljc1NlcnZpY2UgfSBmcm9tICdAcG9zaXdpc2UvY29tbW9uLXNlcnZpY2VzJztcbmltcG9ydCB7IENvcmVUcmFuc2xvY29Nb2R1bGUgfSBmcm9tICdAcG9zaXdpc2UvY29yZS10cmFuc2xvY28nO1xuaW1wb3J0IHsgRGlyZWN0aXZlc01vZHVsZSB9IGZyb20gJ0Bwb3Npd2lzZS9kaXJlY3RpdmVzJztcbmltcG9ydCB7IFBpcGVzTW9kdWxlIH0gZnJvbSAnQHBvc2l3aXNlL3BpcGVzJztcbmltcG9ydCB7IFB1YmxpY01vZHVsZSB9IGZyb20gJ0Bwb3Npd2lzZS9wdWJsaWMtbW9kdWxlcyc7XG5pbXBvcnQgeyBTaGFyZWRDb21wb25lbnRzTW9kdWxlIH0gZnJvbSAnQHBvc2l3aXNlL3NoYXJlZC1jb21wb25lbnRzJztcblxuaW1wb3J0IHsgUXVpbGxNb2R1bGUgfSBmcm9tICduZ3gtcXVpbGwnO1xuaW1wb3J0IHsgU2hhcmVCdXR0b25zTW9kdWxlIH0gZnJvbSAnbmd4LXNoYXJlYnV0dG9ucy9idXR0b25zJztcbmltcG9ydCB7IFNoYXJlSWNvbnNNb2R1bGUgfSBmcm9tICduZ3gtc2hhcmVidXR0b25zL2ljb25zJztcbmltcG9ydCB7IE5neFVwbG9hZGVyTW9kdWxlIH0gZnJvbSAnbmd4LXVwbG9hZGVyJztcblxuaW1wb3J0IHsgVHJhbnNsb2NvTW9kdWxlIH0gZnJvbSAnQGpzdmVyc2UvdHJhbnNsb2NvJztcblxuaW1wb3J0IHsgUmVzb3VyY2VTZXJ2aWNlIH0gZnJvbSAnLi4vcmVzb3VyY2Uuc2VydmljZSc7XG5cbmltcG9ydCB7IFJlc291cmNlTGlzdENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9yZXNvdXJjZXMtbGlzdC9yZXNvdXJjZXMtbGlzdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgUmVzb3VyY2VSZWFkQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3Jlc291cmNlcy1yZWFkL3Jlc291cmNlcy1yZWFkLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCbG9nUHVibGljUm91dGluZ01vZHVsZSB9IGZyb20gJy4vcmVzb3VyY2UtcHVibGljLnJvdXRpbmcubW9kdWxlJztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtSZXNvdXJjZUxpc3RDb21wb25lbnQsIFJlc291cmNlUmVhZENvbXBvbmVudF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIFBpcGVzTW9kdWxlLFxuICAgICAgICBTaGFyZWRDb21wb25lbnRzTW9kdWxlLFxuICAgICAgICBOZ3hVcGxvYWRlck1vZHVsZSxcbiAgICAgICAgQmxvZ1B1YmxpY1JvdXRpbmdNb2R1bGUsXG4gICAgICAgIFNoYXJlQnV0dG9uc01vZHVsZSxcbiAgICAgICAgU2hhcmVJY29uc01vZHVsZSxcbiAgICAgICAgUXVpbGxNb2R1bGUuZm9yUm9vdCgpLFxuICAgICAgICBGb3Jtc01vZHVsZSxcbiAgICAgICAgUHVibGljTW9kdWxlLFxuICAgICAgICBDb3JlVHJhbnNsb2NvTW9kdWxlLFxuICAgICAgICBUcmFuc2xvY29Nb2R1bGUsXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgICAgIERpcmVjdGl2ZXNNb2R1bGVcbiAgICBdLFxuICAgIHByb3ZpZGVyczogW1Jlc291cmNlU2VydmljZSwgR29vZ2xlQW5hbHl0aWNzU2VydmljZV0sXG4gICAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdXG59KVxuZXhwb3J0IGNsYXNzIFJlc291cmNlUHVibGljTW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { RouterModule } from '@angular/router';
|
|
3
|
+
import { ResourceListComponent } from './components/resources-list/resources-list.component';
|
|
4
|
+
import { ResourceReadComponent } from './components/resources-read/resources-read.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/router";
|
|
7
|
+
// These are the private routes. The public routes and modules needs to be defined in public.routes.ts
|
|
8
|
+
const routes = [
|
|
9
|
+
{
|
|
10
|
+
path: '',
|
|
11
|
+
component: ResourceListComponent,
|
|
12
|
+
data: {
|
|
13
|
+
title: 'Resource Posts Admin',
|
|
14
|
+
permission: 'Pages.Blog'
|
|
15
|
+
}
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
path: ':slug',
|
|
19
|
+
component: ResourceReadComponent,
|
|
20
|
+
data: {
|
|
21
|
+
title: 'Resource Post Admin',
|
|
22
|
+
permission: 'Pages.Blog'
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
];
|
|
26
|
+
export class BlogPublicRoutingModule {
|
|
27
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: BlogPublicRoutingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
28
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: BlogPublicRoutingModule, imports: [i1.RouterModule], exports: [RouterModule] }); }
|
|
29
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: BlogPublicRoutingModule, imports: [RouterModule.forChild(routes), RouterModule] }); }
|
|
30
|
+
}
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: BlogPublicRoutingModule, decorators: [{
|
|
32
|
+
type: NgModule,
|
|
33
|
+
args: [{
|
|
34
|
+
imports: [RouterModule.forChild(routes)],
|
|
35
|
+
exports: [RouterModule]
|
|
36
|
+
}]
|
|
37
|
+
}] });
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzb3VyY2UtcHVibGljLnJvdXRpbmcubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9yZXNvdXJjZS1tb2R1bGUvc3JjL2xpYi9wdWJsaWMvcmVzb3VyY2UtcHVibGljLnJvdXRpbmcubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBVSxNQUFNLGlCQUFpQixDQUFDO0FBRXZELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHNEQUFzRCxDQUFDO0FBQzdGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHNEQUFzRCxDQUFDOzs7QUFFN0Ysc0dBQXNHO0FBQ3RHLE1BQU0sTUFBTSxHQUFXO0lBQ25CO1FBQ0ksSUFBSSxFQUFFLEVBQUU7UUFDUixTQUFTLEVBQUUscUJBQXFCO1FBQ2hDLElBQUksRUFBRTtZQUNGLEtBQUssRUFBRSxzQkFBc0I7WUFDN0IsVUFBVSxFQUFFLFlBQVk7U0FDM0I7S0FDSjtJQUNEO1FBQ0ksSUFBSSxFQUFFLE9BQU87UUFDYixTQUFTLEVBQUUscUJBQXFCO1FBQ2hDLElBQUksRUFBRTtZQUNGLEtBQUssRUFBRSxxQkFBcUI7WUFDNUIsVUFBVSxFQUFFLFlBQVk7U0FDM0I7S0FDSjtDQUNKLENBQUM7QUFNRixNQUFNLE9BQU8sdUJBQXVCOytHQUF2Qix1QkFBdUI7Z0hBQXZCLHVCQUF1Qix3Q0FGdEIsWUFBWTtnSEFFYix1QkFBdUIsWUFIdEIsWUFBWSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFDN0IsWUFBWTs7NEZBRWIsdUJBQXVCO2tCQUpuQyxRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUM7b0JBQ3hDLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztpQkFDMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUm91dGVyTW9kdWxlLCBSb3V0ZXMgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuXG5pbXBvcnQgeyBSZXNvdXJjZUxpc3RDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvcmVzb3VyY2VzLWxpc3QvcmVzb3VyY2VzLWxpc3QuY29tcG9uZW50JztcbmltcG9ydCB7IFJlc291cmNlUmVhZENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9yZXNvdXJjZXMtcmVhZC9yZXNvdXJjZXMtcmVhZC5jb21wb25lbnQnO1xuXG4vLyBUaGVzZSBhcmUgdGhlIHByaXZhdGUgcm91dGVzLiBUaGUgcHVibGljIHJvdXRlcyBhbmQgbW9kdWxlcyBuZWVkcyB0byBiZSBkZWZpbmVkIGluIHB1YmxpYy5yb3V0ZXMudHNcbmNvbnN0IHJvdXRlczogUm91dGVzID0gW1xuICAgIHtcbiAgICAgICAgcGF0aDogJycsXG4gICAgICAgIGNvbXBvbmVudDogUmVzb3VyY2VMaXN0Q29tcG9uZW50LFxuICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgICB0aXRsZTogJ1Jlc291cmNlIFBvc3RzIEFkbWluJyxcbiAgICAgICAgICAgIHBlcm1pc3Npb246ICdQYWdlcy5CbG9nJ1xuICAgICAgICB9XG4gICAgfSxcbiAgICB7XG4gICAgICAgIHBhdGg6ICc6c2x1ZycsXG4gICAgICAgIGNvbXBvbmVudDogUmVzb3VyY2VSZWFkQ29tcG9uZW50LFxuICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgICB0aXRsZTogJ1Jlc291cmNlIFBvc3QgQWRtaW4nLFxuICAgICAgICAgICAgcGVybWlzc2lvbjogJ1BhZ2VzLkJsb2cnXG4gICAgICAgIH1cbiAgICB9XG5dO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtSb3V0ZXJNb2R1bGUuZm9yQ2hpbGQocm91dGVzKV0sXG4gICAgZXhwb3J0czogW1JvdXRlck1vZHVsZV1cbn0pXG5leHBvcnQgY2xhc3MgQmxvZ1B1YmxpY1JvdXRpbmdNb2R1bGUge31cbiJdfQ==
|