@jeraldj/discussions-ui 8.0.3-v16
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 +24 -0
- package/assets/images/Buffer-512.webp +0 -0
- package/assets/images/announcement.svg +25 -0
- package/assets/images/back-img.png +0 -0
- package/assets/images/bookmarks.png +0 -0
- package/assets/images/card-icon.png +0 -0
- package/assets/images/close.png +0 -0
- package/assets/images/delete.svg +13 -0
- package/assets/images/down-arrow.png +0 -0
- package/assets/images/down-chevron.png +0 -0
- package/assets/images/down.svg +12 -0
- package/assets/images/edit.svg +11 -0
- package/assets/images/empty.svg +37 -0
- package/assets/images/eye-icon.png +0 -0
- package/assets/images/general discussion.svg +15 -0
- package/assets/images/import-export-arrows.png +0 -0
- package/assets/images/loader-icon.svg +6 -0
- package/assets/images/profits.png +0 -0
- package/assets/images/search-icon.png +0 -0
- package/assets/images/select-bookmarks.png +0 -0
- package/assets/images/select-down-arrow.png +0 -0
- package/assets/images/select-profits.png +0 -0
- package/assets/images/select-up-arrow.png +0 -0
- package/assets/images/up-arrow.png +0 -0
- package/assets/images/up-chevron.png +0 -0
- package/assets/images/up.svg +12 -0
- package/assets/images/views.svg +9 -0
- package/assets/images/votes.svg +14 -0
- package/assets/styles/global.scss +283 -0
- package/esm2022/jeraldj-discussions-ui.mjs +5 -0
- package/esm2022/lib/common/constants.json +630 -0
- package/esm2022/lib/components/components.module.mjs +105 -0
- package/esm2022/lib/components/discuss-all/discuss-all.component.mjs +269 -0
- package/esm2022/lib/components/discuss-category/discuss-category.component.mjs +152 -0
- package/esm2022/lib/components/discuss-home/discuss-home.component.mjs +142 -0
- package/esm2022/lib/components/discuss-start/discuss-start.component.mjs +199 -0
- package/esm2022/lib/components/discuss-tags/discuss-tags.component.mjs +93 -0
- package/esm2022/lib/components/discussion-details/discussion-details.component.mjs +459 -0
- package/esm2022/lib/components/lib-entry/lib-entry.component.mjs +96 -0
- package/esm2022/lib/components/my-discussion/my-discussion.component.mjs +234 -0
- package/esm2022/lib/components/side-pannel/side-pannel.component.mjs +79 -0
- package/esm2022/lib/components/tag-all-discussion/tag-all-discussion.component.mjs +151 -0
- package/esm2022/lib/components/trending-tags/trending-tags.component.mjs +62 -0
- package/esm2022/lib/config/url.config.mjs +32 -0
- package/esm2022/lib/discussion-events.service.mjs +27 -0
- package/esm2022/lib/discussion-routing/discussion-routing.module.mjs +80 -0
- package/esm2022/lib/discussion-ui.module.mjs +41 -0
- package/esm2022/lib/elements/app-loader/app-loader.component.mjs +36 -0
- package/esm2022/lib/elements/avatar-photo/avatar-photo.component.mjs +81 -0
- package/esm2022/lib/elements/category-card/category-card.component.mjs +17 -0
- package/esm2022/lib/elements/discuss-card/discuss-card.component.mjs +45 -0
- package/esm2022/lib/elements/elements.module.mjs +69 -0
- package/esm2022/lib/elements/load-alert/load-alert.component.mjs +34 -0
- package/esm2022/lib/elements/post-reply/post-reply.component.mjs +69 -0
- package/esm2022/lib/elements/related-discussion/related-discussion.component.mjs +61 -0
- package/esm2022/lib/elements/sliders/sliders.component.mjs +76 -0
- package/esm2022/lib/events.service.mjs +31 -0
- package/esm2022/lib/models/discuss.model.mjs +16 -0
- package/esm2022/lib/models/discussion-config.model.mjs +2 -0
- package/esm2022/lib/navigation-service.service.mjs +39 -0
- package/esm2022/lib/pipes/pipe-filter/pipe-filter.pipe.mjs +20 -0
- package/esm2022/lib/pipes/pipe-list-filter/pipe-list-filter.pipe.mjs +22 -0
- package/esm2022/lib/pipes/pipe-relative-time/pipe-relative-time.pipe.mjs +41 -0
- package/esm2022/lib/pipes/pipes.module.mjs +24 -0
- package/esm2022/lib/pipes/sort-by/sort-by.pipe.mjs +34 -0
- package/esm2022/lib/pipes/split-initials/split-initials.pipe.mjs +23 -0
- package/esm2022/lib/router-service.service.mjs +21 -0
- package/esm2022/lib/services/abstract-config.service.mjs +3 -0
- package/esm2022/lib/services/config.service.mjs +76 -0
- package/esm2022/lib/services/discuss-utils.service.mjs +36 -0
- package/esm2022/lib/services/discussion.service.mjs +254 -0
- package/esm2022/lib/telemetry-utils.service.mjs +103 -0
- package/esm2022/lib/wrapper/base-wrapper/base-wrapper.component.mjs +41 -0
- package/esm2022/lib/wrapper/category-widget/category-widget.component.mjs +37 -0
- package/esm2022/lib/wrapper/tags-widget/tags-widget.component.mjs +33 -0
- package/esm2022/lib/wrapper-navigate.service.mjs +23 -0
- package/esm2022/public-api.mjs +29 -0
- package/fesm2022/jeraldj-discussions-ui.mjs +3929 -0
- package/fesm2022/jeraldj-discussions-ui.mjs.map +1 -0
- package/index.d.ts +6 -0
- package/jeraldj-discussions-ui.d.ts.map +1 -0
- package/lib/components/components.module.d.ts +24 -0
- package/lib/components/components.module.d.ts.map +1 -0
- package/lib/components/discuss-all/discuss-all.component.d.ts +61 -0
- package/lib/components/discuss-all/discuss-all.component.d.ts.map +1 -0
- package/lib/components/discuss-category/discuss-category.component.d.ts +45 -0
- package/lib/components/discuss-category/discuss-category.component.d.ts.map +1 -0
- package/lib/components/discuss-home/discuss-home.component.d.ts +59 -0
- package/lib/components/discuss-home/discuss-home.component.d.ts.map +1 -0
- package/lib/components/discuss-start/discuss-start.component.d.ts +50 -0
- package/lib/components/discuss-start/discuss-start.component.d.ts.map +1 -0
- package/lib/components/discuss-tags/discuss-tags.component.d.ts +41 -0
- package/lib/components/discuss-tags/discuss-tags.component.d.ts.map +1 -0
- package/lib/components/discussion-details/discussion-details.component.d.ts +112 -0
- package/lib/components/discussion-details/discussion-details.component.d.ts.map +1 -0
- package/lib/components/lib-entry/lib-entry.component.d.ts +42 -0
- package/lib/components/lib-entry/lib-entry.component.d.ts.map +1 -0
- package/lib/components/my-discussion/my-discussion.component.d.ts +54 -0
- package/lib/components/my-discussion/my-discussion.component.d.ts.map +1 -0
- package/lib/components/side-pannel/side-pannel.component.d.ts +34 -0
- package/lib/components/side-pannel/side-pannel.component.d.ts.map +1 -0
- package/lib/components/tag-all-discussion/tag-all-discussion.component.d.ts +53 -0
- package/lib/components/tag-all-discussion/tag-all-discussion.component.d.ts.map +1 -0
- package/lib/components/trending-tags/trending-tags.component.d.ts +26 -0
- package/lib/components/trending-tags/trending-tags.component.d.ts.map +1 -0
- package/lib/config/url.config.d.ts +29 -0
- package/lib/config/url.config.d.ts.map +1 -0
- package/lib/discussion-events.service.d.ts +12 -0
- package/lib/discussion-events.service.d.ts.map +1 -0
- package/lib/discussion-routing/discussion-routing.module.d.ts +9 -0
- package/lib/discussion-routing/discussion-routing.module.d.ts.map +1 -0
- package/lib/discussion-ui.module.d.ts +16 -0
- package/lib/discussion-ui.module.d.ts.map +1 -0
- package/lib/elements/app-loader/app-loader.component.d.ts +17 -0
- package/lib/elements/app-loader/app-loader.component.d.ts.map +1 -0
- package/lib/elements/avatar-photo/avatar-photo.component.d.ts +19 -0
- package/lib/elements/avatar-photo/avatar-photo.component.d.ts.map +1 -0
- package/lib/elements/category-card/category-card.component.d.ts +10 -0
- package/lib/elements/category-card/category-card.component.d.ts.map +1 -0
- package/lib/elements/discuss-card/discuss-card.component.d.ts +17 -0
- package/lib/elements/discuss-card/discuss-card.component.d.ts.map +1 -0
- package/lib/elements/elements.module.d.ts +18 -0
- package/lib/elements/elements.module.d.ts.map +1 -0
- package/lib/elements/load-alert/load-alert.component.d.ts +15 -0
- package/lib/elements/load-alert/load-alert.component.d.ts.map +1 -0
- package/lib/elements/post-reply/post-reply.component.d.ts +22 -0
- package/lib/elements/post-reply/post-reply.component.d.ts.map +1 -0
- package/lib/elements/related-discussion/related-discussion.component.d.ts +26 -0
- package/lib/elements/related-discussion/related-discussion.component.d.ts.map +1 -0
- package/lib/elements/sliders/sliders.component.d.ts +18 -0
- package/lib/elements/sliders/sliders.component.d.ts.map +1 -0
- package/lib/events.service.d.ts +18 -0
- package/lib/events.service.d.ts.map +1 -0
- package/lib/models/discuss.model.d.ts +298 -0
- package/lib/models/discuss.model.d.ts.map +1 -0
- package/lib/models/discussion-config.model.d.ts +42 -0
- package/lib/models/discussion-config.model.d.ts.map +1 -0
- package/lib/navigation-service.service.d.ts +22 -0
- package/lib/navigation-service.service.d.ts.map +1 -0
- package/lib/pipes/pipe-filter/pipe-filter.pipe.d.ts +8 -0
- package/lib/pipes/pipe-filter/pipe-filter.pipe.d.ts.map +1 -0
- package/lib/pipes/pipe-list-filter/pipe-list-filter.pipe.d.ts +8 -0
- package/lib/pipes/pipe-list-filter/pipe-list-filter.pipe.d.ts.map +1 -0
- package/lib/pipes/pipe-relative-time/pipe-relative-time.pipe.d.ts +8 -0
- package/lib/pipes/pipe-relative-time/pipe-relative-time.pipe.d.ts.map +1 -0
- package/lib/pipes/pipes.module.d.ts +13 -0
- package/lib/pipes/pipes.module.d.ts.map +1 -0
- package/lib/pipes/sort-by/sort-by.pipe.d.ts +8 -0
- package/lib/pipes/sort-by/sort-by.pipe.d.ts.map +1 -0
- package/lib/pipes/split-initials/split-initials.pipe.d.ts +8 -0
- package/lib/pipes/split-initials/split-initials.pipe.d.ts.map +1 -0
- package/lib/router-service.service.d.ts +10 -0
- package/lib/router-service.service.d.ts.map +1 -0
- package/lib/services/abstract-config.service.d.ts +4 -0
- package/lib/services/abstract-config.service.d.ts.map +1 -0
- package/lib/services/config.service.d.ts +36 -0
- package/lib/services/config.service.d.ts.map +1 -0
- package/lib/services/discuss-utils.service.d.ts +14 -0
- package/lib/services/discuss-utils.service.d.ts.map +1 -0
- package/lib/services/discussion.service.d.ts +76 -0
- package/lib/services/discussion.service.d.ts.map +1 -0
- package/lib/telemetry-utils.service.d.ts +20 -0
- package/lib/telemetry-utils.service.d.ts.map +1 -0
- package/lib/wrapper/base-wrapper/base-wrapper.component.d.ts +22 -0
- package/lib/wrapper/base-wrapper/base-wrapper.component.d.ts.map +1 -0
- package/lib/wrapper/category-widget/category-widget.component.d.ts +23 -0
- package/lib/wrapper/category-widget/category-widget.component.d.ts.map +1 -0
- package/lib/wrapper/tags-widget/tags-widget.component.d.ts +17 -0
- package/lib/wrapper/tags-widget/tags-widget.component.d.ts.map +1 -0
- package/lib/wrapper-navigate.service.d.ts +11 -0
- package/lib/wrapper-navigate.service.d.ts.map +1 -0
- package/package.json +44 -0
- package/public-api.d.ts +26 -0
- package/public-api.d.ts.map +1 -0
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { Component, Input, EventEmitter, Output } from '@angular/core';
|
|
2
|
+
import { NSDiscussData } from '../../models/discuss.model';
|
|
3
|
+
/* tslint:disable */
|
|
4
|
+
import _ from 'lodash';
|
|
5
|
+
import * as CONSTANTS from './../../common/constants.json';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/router";
|
|
8
|
+
import * as i2 from "../../services/discussion.service";
|
|
9
|
+
import * as i3 from "../../services/config.service";
|
|
10
|
+
import * as i4 from "./../../telemetry-utils.service";
|
|
11
|
+
import * as i5 from "../../services/discuss-utils.service";
|
|
12
|
+
import * as i6 from "../../navigation-service.service";
|
|
13
|
+
import * as i7 from "@angular/common";
|
|
14
|
+
import * as i8 from "../../elements/discuss-card/discuss-card.component";
|
|
15
|
+
import * as i9 from "../../elements/app-loader/app-loader.component";
|
|
16
|
+
export class TagAllDiscussionComponent {
|
|
17
|
+
constructor(route, router, discussService, activatedRoute, configService, telemetryUtils, discussUtils, navigationService) {
|
|
18
|
+
this.route = route;
|
|
19
|
+
this.router = router;
|
|
20
|
+
this.discussService = discussService;
|
|
21
|
+
this.activatedRoute = activatedRoute;
|
|
22
|
+
this.configService = configService;
|
|
23
|
+
this.telemetryUtils = telemetryUtils;
|
|
24
|
+
this.discussUtils = discussUtils;
|
|
25
|
+
this.navigationService = navigationService;
|
|
26
|
+
this.stateChange = new EventEmitter();
|
|
27
|
+
this.fetchSingleCategoryLoader = false;
|
|
28
|
+
this.defaultError = 'Something went wrong, Please try again after sometime!';
|
|
29
|
+
this.pager = {};
|
|
30
|
+
this.fetchNewData = false;
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
// debugger
|
|
34
|
+
this.cIds = this.widgetcIds ? this.widgetcIds : this.configService.getCategories();
|
|
35
|
+
if (this.widgetTagName) {
|
|
36
|
+
this.tagName = this.widgetTagName;
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
this.activatedRoute.queryParams.subscribe((params) => {
|
|
40
|
+
this.tagName = params.tagname ? params.tagname : this.tagName;
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
// To check wheather any contexts are there or not from the config service
|
|
44
|
+
if (this.configService.hasContext() || this.widgetcIds) {
|
|
45
|
+
this.fetchContextBasedTagDetails(this.tagName, this.cIds, this.currentActivePage);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
this.fetchSingleTagDetails(this.tagName, this.currentActivePage);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
/**Method to fetch the tag based discussion */
|
|
52
|
+
fetchSingleTagDetails(tagname, page) {
|
|
53
|
+
this.fetchSingleCategoryLoader = true;
|
|
54
|
+
this.discussService.getTagBasedDiscussion(tagname).subscribe((data) => {
|
|
55
|
+
this.similarPosts = data.topics;
|
|
56
|
+
this.paginationData = data.pagination;
|
|
57
|
+
this.fetchSingleCategoryLoader = false;
|
|
58
|
+
this.setPagination();
|
|
59
|
+
}, (err) => {
|
|
60
|
+
console.error('Error in fetching single tag details', err);
|
|
61
|
+
// this.openSnackbar(err.error.message.split('|')[1] || this.defaultError)
|
|
62
|
+
this.fetchSingleCategoryLoader = false;
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
/** Method to fetch the context based discussions */
|
|
66
|
+
fetchContextBasedTagDetails(tagname, cid, page) {
|
|
67
|
+
this.fetchSingleCategoryLoader = true;
|
|
68
|
+
const req = {
|
|
69
|
+
cid: cid.result,
|
|
70
|
+
tag: tagname
|
|
71
|
+
};
|
|
72
|
+
this.discussService.getContextBasedTagDiscussion(req).subscribe((data) => {
|
|
73
|
+
this.similarPosts = data.result;
|
|
74
|
+
// this.paginationData = data.pagination
|
|
75
|
+
this.fetchSingleCategoryLoader = false;
|
|
76
|
+
this.setPagination();
|
|
77
|
+
}, (err) => {
|
|
78
|
+
console.error('Error in fetching context based tag details', err);
|
|
79
|
+
// this.openSnackbar(err.error.message.split('|')[1] || this.defaultError)
|
|
80
|
+
this.fetchSingleCategoryLoader = false;
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
// TODO : for pagination
|
|
84
|
+
// getNextData(tagname: string, page: any) {
|
|
85
|
+
// return this.discussService.fetchNextTagD(tagname, page).subscribe(
|
|
86
|
+
// (data: any) => {
|
|
87
|
+
// this.paginationData = data.pagination
|
|
88
|
+
// this.setPagination()
|
|
89
|
+
// this.similarPosts = _.get(data, 'topics')
|
|
90
|
+
// })
|
|
91
|
+
// }
|
|
92
|
+
setPagination() {
|
|
93
|
+
this.pager = {
|
|
94
|
+
startIndex: this.paginationData.first.page,
|
|
95
|
+
endIndex: this.paginationData.last.page,
|
|
96
|
+
pages: this.paginationData.pages,
|
|
97
|
+
currentPage: this.paginationData.currentPage,
|
|
98
|
+
totalPage: this.paginationData.pageCount,
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
navigateWithPage(page) {
|
|
102
|
+
if (page !== this.currentActivePage) {
|
|
103
|
+
this.fetchNewData = true;
|
|
104
|
+
this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TAG}tag-discussions`], { queryParams: { page, tagname: this.queryParam }, queryParamsHandling: "merge" });
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
/** Method to navigate to the dicussion detail page on click of tag related discussion */
|
|
108
|
+
navigateToDiscussionDetails(discussionData) {
|
|
109
|
+
const matchedTopic = _.find(this.telemetryUtils.getContext(), { type: 'Topic' });
|
|
110
|
+
if (matchedTopic) {
|
|
111
|
+
this.telemetryUtils.deleteContext(matchedTopic);
|
|
112
|
+
}
|
|
113
|
+
this.telemetryUtils.uppendContext({
|
|
114
|
+
id: _.get(discussionData, 'tid'),
|
|
115
|
+
type: 'Topic'
|
|
116
|
+
});
|
|
117
|
+
let slug = _.trim(_.get(discussionData, 'slug'));
|
|
118
|
+
let input = { data: { url: `${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TOPIC}${slug}`, queryParams: {} }, action: CONSTANTS.CATEGORY_DETAILS, };
|
|
119
|
+
this.navigationService.navigate(input);
|
|
120
|
+
this.stateChange.emit({ action: CONSTANTS.CATEGORY_DETAILS, title: discussionData.title, tid: discussionData.tid });
|
|
121
|
+
// this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TOPIC}${_.trim(_.get(discussionData, 'slug'))}`], { queryParamsHandling: "merge" });
|
|
122
|
+
}
|
|
123
|
+
logTelemetry(event) {
|
|
124
|
+
this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.HOME);
|
|
125
|
+
}
|
|
126
|
+
// TODO: add refershdata function
|
|
127
|
+
// refreshData(tagname: string, page: any) {
|
|
128
|
+
// if (this.fetchNewData) {
|
|
129
|
+
// // this.getNextData(tagname, page)
|
|
130
|
+
// }
|
|
131
|
+
// }
|
|
132
|
+
// for tag color
|
|
133
|
+
getBgColor(tagTitle) {
|
|
134
|
+
const bgColor = this.discussUtils.stringToColor(tagTitle.toLowerCase());
|
|
135
|
+
const color = this.discussUtils.getContrast();
|
|
136
|
+
return { color, 'background-color': bgColor };
|
|
137
|
+
}
|
|
138
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TagAllDiscussionComponent, deps: [{ token: i1.ActivatedRoute }, { token: i1.Router }, { token: i2.DiscussionService }, { token: i1.ActivatedRoute }, { token: i3.ConfigService }, { token: i4.TelemetryUtilsService }, { token: i5.DiscussUtilsService }, { token: i6.NavigationServiceService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
139
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TagAllDiscussionComponent, selector: "lib-tag-all-discussion", inputs: { widgetTagName: "widgetTagName", widgetcIds: "widgetcIds" }, outputs: { stateChange: "stateChange" }, ngImport: i0, template: "<div class=\"main-div\">\n <div class=\"flex flex-1 margin-top-xl\">\n <h2 class=\"margin-remove-bottom tagtitle\" [ngStyle]=\"getBgColor(tagName)\">{{tagName}}</h2>\n </div>\n <div>\n <span> </span>\n </div>\n <div class=\"flex flex-1 custom\">\n <div class=\"flex flex-1 flex-column margin-fix\">\n <lib-app-loader *ngIf=\"fetchSingleCategoryLoader\"></lib-app-loader>\n\n <ng-container *ngIf=\"similarPosts && similarPosts.length > 0\">\n <div (click)=\"navigateToDiscussionDetails(data);logTelemetry($event)\"\n *ngFor=\"let data of similarPosts\" id=\"discuss-card\">\n <lib-discuss-card [discussionData]=\"data\"></lib-discuss-card>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!(similarPosts && similarPosts.length > 0)\">\n <div class=\"no-card-content\" tabindex=\"0\"> \n <div class=\"no-data-label\">No Data</div>\n <div>\n <span> </span>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n <!-- <div class=\"flex flex-1 flex-column margin-top-xl margin-bottom-xl pagination-container\">\n <ws-app-pagination [pager]=\"pager\" (changePage)=\"navigateWithPage($event)\"></ws-app-pagination>\n </div> -->\n</div>", styles: [".flex.flex-5{flex-direction:column}.tagtitle{margin:0 .25rem;padding:.25rem 1rem;min-width:3.125rem;justify-content:center;border-radius:1.25rem .25rem .25rem 1.25rem}\n"], dependencies: [{ kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i8.DiscussCardComponent, selector: "lib-discuss-card", inputs: ["discussionData"] }, { kind: "component", type: i9.AppLoaderComponent, selector: "lib-app-loader", inputs: ["data"] }] }); }
|
|
140
|
+
}
|
|
141
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TagAllDiscussionComponent, decorators: [{
|
|
142
|
+
type: Component,
|
|
143
|
+
args: [{ selector: 'lib-tag-all-discussion', template: "<div class=\"main-div\">\n <div class=\"flex flex-1 margin-top-xl\">\n <h2 class=\"margin-remove-bottom tagtitle\" [ngStyle]=\"getBgColor(tagName)\">{{tagName}}</h2>\n </div>\n <div>\n <span> </span>\n </div>\n <div class=\"flex flex-1 custom\">\n <div class=\"flex flex-1 flex-column margin-fix\">\n <lib-app-loader *ngIf=\"fetchSingleCategoryLoader\"></lib-app-loader>\n\n <ng-container *ngIf=\"similarPosts && similarPosts.length > 0\">\n <div (click)=\"navigateToDiscussionDetails(data);logTelemetry($event)\"\n *ngFor=\"let data of similarPosts\" id=\"discuss-card\">\n <lib-discuss-card [discussionData]=\"data\"></lib-discuss-card>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!(similarPosts && similarPosts.length > 0)\">\n <div class=\"no-card-content\" tabindex=\"0\"> \n <div class=\"no-data-label\">No Data</div>\n <div>\n <span> </span>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n <!-- <div class=\"flex flex-1 flex-column margin-top-xl margin-bottom-xl pagination-container\">\n <ws-app-pagination [pager]=\"pager\" (changePage)=\"navigateWithPage($event)\"></ws-app-pagination>\n </div> -->\n</div>", styles: [".flex.flex-5{flex-direction:column}.tagtitle{margin:0 .25rem;padding:.25rem 1rem;min-width:3.125rem;justify-content:center;border-radius:1.25rem .25rem .25rem 1.25rem}\n"] }]
|
|
144
|
+
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i1.Router }, { type: i2.DiscussionService }, { type: i1.ActivatedRoute }, { type: i3.ConfigService }, { type: i4.TelemetryUtilsService }, { type: i5.DiscussUtilsService }, { type: i6.NavigationServiceService }]; }, propDecorators: { widgetTagName: [{
|
|
145
|
+
type: Input
|
|
146
|
+
}], widgetcIds: [{
|
|
147
|
+
type: Input
|
|
148
|
+
}], stateChange: [{
|
|
149
|
+
type: Output
|
|
150
|
+
}] } });
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tag-all-discussion.component.js","sourceRoot":"","sources":["../../../../../../projects/discussion-ui/src/lib/components/tag-all-discussion/tag-all-discussion.component.ts","../../../../../../projects/discussion-ui/src/lib/components/tag-all-discussion/tag-all-discussion.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, EventEmitter, Output } from '@angular/core'\nimport { NSDiscussData } from '../../models/discuss.model'\nimport { Router, ActivatedRoute } from '@angular/router'\nimport { DiscussionService } from '../../services/discussion.service';\n/* tslint:disable */\nimport _ from 'lodash'\nimport { Subscriber, Subscription } from 'rxjs';\nimport { ConfigService } from '../../services/config.service';\nimport * as CONSTANTS from './../../common/constants.json';\nimport { DiscussUtilsService } from '../../services/discuss-utils.service';\nimport { TelemetryUtilsService } from './../../telemetry-utils.service';\nimport { NavigationServiceService } from '../../navigation-service.service';\n\n@Component({\n  selector: 'lib-tag-all-discussion',\n  templateUrl: './tag-all-discussion.component.html',\n  styleUrls: ['./tag-all-discussion.component.scss']\n})\nexport class TagAllDiscussionComponent implements OnInit {\n  @Input() widgetTagName: any;\n  @Input() widgetcIds: any;\n\n  @Output() stateChange: EventEmitter<any> = new EventEmitter();\n\n  routeParams: any;\n  tagName!: any\n  similarPosts :any[]\n  queryParam: any\n  fetchSingleCategoryLoader = false\n  currentActivePage: 1\n  defaultError = 'Something went wrong, Please try again after sometime!'\n  pager = {}\n  paginationData!: any\n  fetchNewData = false\n  paramsSubscription: Subscription;\n  getParams: any;\n  cIds: any;\n\n  constructor(\n    private route: ActivatedRoute,\n    private router: Router,\n    private discussService: DiscussionService, \n    public activatedRoute: ActivatedRoute,\n    private configService: ConfigService,\n    private telemetryUtils: TelemetryUtilsService,\n    private discussUtils: DiscussUtilsService,\n    private navigationService: NavigationServiceService\n  ) { }\n\n  ngOnInit() {\n    // debugger\n    this.cIds = this.widgetcIds? this.widgetcIds: this.configService.getCategories()\n\n    if(this.widgetTagName)\n    {\n      this.tagName = this.widgetTagName;\n    }\n    else\n    {\n      this.activatedRoute.queryParams.subscribe((params) => {\n        this.tagName = params.tagname ? params.tagname: this.tagName\n      })\n    }\n    \n    // To check wheather any contexts are there or not from the config service\n    if (this.configService.hasContext() || this.widgetcIds) {\n      this.fetchContextBasedTagDetails(this.tagName, this.cIds, this.currentActivePage)\n    } else {\n      this.fetchSingleTagDetails(this.tagName, this.currentActivePage)\n    }\n\n  }\n\n  /**Method to fetch the tag based discussion */\n  fetchSingleTagDetails(tagname: string, page?: any) {\n    this.fetchSingleCategoryLoader = true\n    this.discussService.getTagBasedDiscussion(tagname).subscribe(\n      (data: NSDiscussData.IDiscussionData) => {\n        this.similarPosts = data.topics\n        this.paginationData = data.pagination\n        this.fetchSingleCategoryLoader = false\n        this.setPagination()\n      },\n      (err: any) => {\n        console.error('Error in fetching single tag details', err)\n        // this.openSnackbar(err.error.message.split('|')[1] || this.defaultError)\n        this.fetchSingleCategoryLoader = false\n      })\n  }\n\n  /** Method to fetch the context based discussions */\n  fetchContextBasedTagDetails(tagname: string, cid: any, page?: any) {\n    this.fetchSingleCategoryLoader = true\n    const req = {\n      cid: cid.result,\n      tag: tagname\n    };\n\n    this.discussService.getContextBasedTagDiscussion(req).subscribe(\n      (data: NSDiscussData.IDiscussionData) => {\n        this.similarPosts = data.result\n        // this.paginationData = data.pagination\n        this.fetchSingleCategoryLoader = false\n        this.setPagination()\n      },\n      (err: any) => {\n        console.error('Error in fetching context based tag details', err)\n        // this.openSnackbar(err.error.message.split('|')[1] || this.defaultError)\n        this.fetchSingleCategoryLoader = false\n      })\n  }\n\n\n  // TODO : for pagination\n  // getNextData(tagname: string, page: any) {\n  //   return this.discussService.fetchNextTagD(tagname, page).subscribe(\n  //     (data: any) => {\n  //       this.paginationData = data.pagination\n  //       this.setPagination()\n  //       this.similarPosts = _.get(data, 'topics')\n  //     })\n  // }\n\n  setPagination() {\n    this.pager = {\n      startIndex: this.paginationData.first.page,\n      endIndex: this.paginationData.last.page,\n      pages: this.paginationData.pages,\n      currentPage: this.paginationData.currentPage,\n      totalPage: this.paginationData.pageCount,\n    }\n  }\n\n  navigateWithPage(page: any) {\n    if (page !== this.currentActivePage) {\n      this.fetchNewData = true\n      this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TAG}tag-discussions`], { queryParams: { page, tagname: this.queryParam },  queryParamsHandling: \"merge\"  });\n    }\n  }\n\n  /** Method to navigate to the dicussion detail page on click of tag related discussion */\n  navigateToDiscussionDetails(discussionData) {\n    const matchedTopic = _.find(this.telemetryUtils.getContext(), { type: 'Topic' });\n    if (matchedTopic) {\n      this.telemetryUtils.deleteContext(matchedTopic);\n    }\n\n    this.telemetryUtils.uppendContext({\n      id: _.get(discussionData, 'tid'),\n      type: 'Topic'\n    });\n\n    let slug = _.trim(_.get(discussionData, 'slug'))\n    let input = { data: { url: `${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TOPIC}${slug}`, queryParams: {} }, action: CONSTANTS.CATEGORY_DETAILS, }\n    this.navigationService.navigate(input)\n    this.stateChange.emit({ action: CONSTANTS.CATEGORY_DETAILS, title: discussionData.title, tid: discussionData.tid })\n\n    // this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TOPIC}${_.trim(_.get(discussionData, 'slug'))}`], { queryParamsHandling: \"merge\" });\n  }\n\n  logTelemetry(event) {\n    this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.HOME);\n  }\n\n  // TODO: add refershdata function\n  // refreshData(tagname: string, page: any) {\n  //   if (this.fetchNewData) {\n  //     // this.getNextData(tagname, page)\n  //   }\n  // }\n\n  // for tag color\n  public getBgColor(tagTitle: any) {\n    const bgColor = this.discussUtils.stringToColor(tagTitle.toLowerCase());\n    const color = this.discussUtils.getContrast();\n    return { color, 'background-color': bgColor };\n  }\n\n}\n","<div class=\"main-div\">\n    <div class=\"flex flex-1 margin-top-xl\">\n        <h2 class=\"margin-remove-bottom tagtitle\" [ngStyle]=\"getBgColor(tagName)\">{{tagName}}</h2>\n    </div>\n    <div>\n        <span>&nbsp;</span>\n    </div>\n    <div class=\"flex flex-1 custom\">\n        <div class=\"flex flex-1 flex-column margin-fix\">\n            <lib-app-loader *ngIf=\"fetchSingleCategoryLoader\"></lib-app-loader>\n\n            <ng-container *ngIf=\"similarPosts && similarPosts.length > 0\">\n                <div (click)=\"navigateToDiscussionDetails(data);logTelemetry($event)\"\n                    *ngFor=\"let data of similarPosts\" id=\"discuss-card\">\n                    <lib-discuss-card [discussionData]=\"data\"></lib-discuss-card>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"!(similarPosts && similarPosts.length > 0)\">\n                <div class=\"no-card-content\" tabindex=\"0\"> \n                    <div class=\"no-data-label\">No Data</div>\n                    <div>\n                        <span>&nbsp;</span>\n                    </div>\n                </div>\n            </ng-container>\n        </div>\n    </div>\n    <!-- <div class=\"flex flex-1 flex-column margin-top-xl margin-bottom-xl pagination-container\">\n        <ws-app-pagination [pager]=\"pager\" (changePage)=\"navigateWithPage($event)\"></ws-app-pagination>\n    </div> -->\n</div>"]}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { Component, Input, EventEmitter, Output } from '@angular/core';
|
|
2
|
+
/* tslint:disable */
|
|
3
|
+
import _ from 'lodash';
|
|
4
|
+
import * as CONSTANTS from './../../common/constants.json';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/router";
|
|
7
|
+
import * as i2 from "../../services/config.service";
|
|
8
|
+
import * as i3 from "../../navigation-service.service";
|
|
9
|
+
import * as i4 from "@angular/common";
|
|
10
|
+
/* tslint:enable */
|
|
11
|
+
export class TrendingTagsComponent {
|
|
12
|
+
constructor(router, configService, navigationService) {
|
|
13
|
+
this.router = router;
|
|
14
|
+
this.configService = configService;
|
|
15
|
+
this.navigationService = navigationService;
|
|
16
|
+
this.stateChange = new EventEmitter();
|
|
17
|
+
this.max = 0;
|
|
18
|
+
}
|
|
19
|
+
ngOnInit() {
|
|
20
|
+
// debugger
|
|
21
|
+
this.max = _.get(_.maxBy(this.tags, 'score'), 'score') || 0;
|
|
22
|
+
this.trandingTags = _.chain(this.tags).orderBy('score', 'desc').take(5).value();
|
|
23
|
+
}
|
|
24
|
+
ngOnChanges(data) {
|
|
25
|
+
// debugger
|
|
26
|
+
// this.tableData!.columns = data.tableData.currentValue.columns
|
|
27
|
+
this.tags = _.get(data, 'tags.currentValue');
|
|
28
|
+
this.max = _.get(_.maxBy(this.tags, 'score'), 'score') || 0;
|
|
29
|
+
this.trandingTags = _.chain(this.tags).orderBy('score', 'desc').take(5).value();
|
|
30
|
+
}
|
|
31
|
+
// TODO: To enable trending tags click and navigate to tags detals page
|
|
32
|
+
getAllDiscussions(tag) {
|
|
33
|
+
// debugger
|
|
34
|
+
this.queryParam = tag.value;
|
|
35
|
+
const tagdata = {
|
|
36
|
+
tagname: ''
|
|
37
|
+
};
|
|
38
|
+
tagdata.tagname = tag.value;
|
|
39
|
+
this.queryParam = tagdata;
|
|
40
|
+
const routerSlug = this.configService.getConfig().routerSlug ? this.configService.getConfig().routerSlug : '';
|
|
41
|
+
const input = { data: { url: `${routerSlug}${CONSTANTS.ROUTES.TAG}tag-discussions`,
|
|
42
|
+
queryParams: this.queryParam, tagName: this.queryParam.tagName }, action: 'tagsAll' };
|
|
43
|
+
this.navigationService.navigate(input);
|
|
44
|
+
this.stateChange.emit({ action: CONSTANTS.TAG_ALL_DISCUSS, title: tag.value, tid: 'sd' });
|
|
45
|
+
// tslint:disable-next-line: max-line-length
|
|
46
|
+
// this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TAG}tag-discussions`], { queryParams: this.queryParam });
|
|
47
|
+
}
|
|
48
|
+
css() {
|
|
49
|
+
// return 'linear - gradient(to left, #00ff00 " + 80 + " %, #ff0000 20 %)"
|
|
50
|
+
}
|
|
51
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TrendingTagsComponent, deps: [{ token: i1.Router }, { token: i2.ConfigService }, { token: i3.NavigationServiceService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
52
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TrendingTagsComponent, selector: "lib-discuss-trending-tags", inputs: { tags: "tags" }, outputs: { stateChange: "stateChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"margin-left-l right_tag_inner_box\">\n <span class=\"mat-subheading-2\" role=\"link\" tabindex=\"0\" aria-label=\"Trending tags\">Trending tags</span>\n <ng-container *ngIf=\"trandingTags && trandingTags.length > 0\">\n <div *ngFor=\"let tag of trandingTags\" class=\"tag ws-mat-primary-lite-background-important cursor-pointer\" role=\"link\" tabindex=\"0\"\n [attr.aria-label]=\"tag.value\"\n [ngStyle]=\"{'background-image':'linear-gradient(to right, #ECECEC, #ECECEC ' + ((tag.score / max) *100 ) + '%, #FFF 24px)'}\" (click)=\"getAllDiscussions(tag)\">\n <span class=\"margin-left-m mat-caption\">{{tag.value}}</span>\n <span class=\"custom-margin margin-right-m mat-subheading-2\">{{tag.score}}</span>\n </div>\n </ng-container>\n </div>\n\n <div class=\"update_box margin-left-l\"> \n <span class=\"mat-subheading-2\" role=\"link\" tabindex=\"0\" aria-label=\"Updates\">Updates</span>\n <div class=\"update_inner_box flex flex-col items-center justify-center\">\n\n <div class=\"mat-card flex flex-col update_card margin-bottom-s\">\n <div class=\"flex fex-1 items-center justify-start card_head\">\n <p class=\"mat-subheading-1 blue_heading\">1 Upvote on your question</p>\n </div>\n <div class=\"flex fex-1 items-center justify-start card_body\">\n <p class=\"mat-body-2\">What is the most reliable and useful source for COVID related ..</p>\n </div>\n </div>\n\n <div class=\"mat-card flex flex-col update_card margin-bottom-s\">\n <div class=\"flex fex-1 items-center justify-start card_head\">\n <p class=\"mat-subheading-1 blue_heading\">@sundaramraj answered your question</p>\n </div>\n <div class=\"flex fex-1 items-center justify-start card_body\">\n <p class=\"mat-body-2\">I think the solution to such a problem would be to extensively..</p>\n </div>\n </div>\n\n <div class=\"mat-card flex flex-col update_card margin-bottom-s\">\n <div class=\"flex fex-1 items-center justify-start card_head\">\n <p class=\"mat-subheading-1 blue_heading\">1 Upvote on your question</p>\n </div>\n <div class=\"flex fex-1 items-center justify-start card_body\">\n <p class=\"mat-body-2\">What is the most reliable and useful source for COVID related ..</p>\n </div>\n </div>\n\n <div class=\"flex flex-col items-center update_btn_box\">\n <a class=\"all_update_link flex mat-subheading-2 justify-center\">ALL UPDATES</a>\n </div>\n\n </div>\n </div>", styles: [":root{font-size:16px;--blue: #024f9d;--green: #008840;--black: #000000;--white: #ffffff;--red:#ff4558;--primary: var(--blue);--secondary: #008840;--tertiary: #e55a28;--gray-hs: 0, 0%;--gray: hsl(var(--gray-hs), 20%);--gray-0: hsl(var(--gray-hs), 95%);--gray-100: hsl(var(--gray-hs), 80%);--gray-200: hsl(var(--gray-hs), 60%);--gray-300: hsl(var(--gray-hs), 59%);--gray-400: hsl(var(--gray-hs), 40%);--gray-800: var(--gray);--primary-hs: 210, 97%;--primary: hsl(var(--primary-hs), 31%);--primary-0: hsl(var(--primary-hs), 98%);--primary-100: hsl(var(--primary-hs), 88%);--primary-200: hsl(var(--primary-hs), 78%);--primary-250: hsl(var(--primary-hs), 73%);--primary-300: hsl(var(--primary-hs), 68%);--primary-400: var(--primary);--primary-600: hsl(var(--primary), 48%);--primary-800: hsl(var(--primary-hs), 38%);--secondary-hs: 148, 100%;--secondary: hsl(var(--secondary-hs), 27%);--secondary-0: hsl(var(--secondary-hs), 94%);--secondary-100: hsl(var(--secondary-hs), 39%);--secondary-200: hsl(var(--secondary-hs), 38%);--secondary-400: var(--secondary);--tertiary-hs:16,78%;--tertiary:hsl(var(--tertiary-hs), 53%);--tertiary-0:hsl(var(--tertiary-hs), 92%);--tertiary-100: hsl(var(--tertiary-hs), 56%);--tertiary-400: var(--tertiary);--red-0: #fbccd1;--red-100: #ff6979;--red-400: var(--red);--df-e9e8d9:#e9e8d9;--df-333:#333;--text-color:var(--df-333);--df-background:var(--white);--df-common-bg:var(--white);--df-body-bg: var(--primary-0);--df-theme-bg: var(--df-background);--df-text: var(--text-color);--df-card-bg: var(--df-background);--df-btn-default-color: var(--white);--df-field-control-bg: var(--df-background);--df-cancel-btn-bg:var(--df-background);--df-tab-bg: var(--df-background);--df-tab-text: var(--primary);--df-tab-bg-active: var(--primary);--df-tab-text-active: var(--white)}.recent-tabs{transition:box-shadow .28s cubic-bezier(.4,0,.2,1);display:block;position:relative;box-shadow:none!important;border-radius:unset;background:inherit!important;z-index:unset;padding-bottom:.5rem}.recent-tabs .tabs-content{display:flex;flex:1 1 0%;flex-direction:column}.recent-tabs .tabs-content .tabs-filter{display:flex;flex:1 1 0%;flex-wrap:wrap}.recent-tabs .tabs-content .tabs-filter .filter-option{background:var(--df-tab-bg);padding:.5rem 1rem;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;font-size:.875rem;font-weight:700;margin-right:.75rem;margin-top:.5rem;transition:all ease .3s;display:flex;align-items:center;cursor:pointer;white-space:nowrap;text-decoration:none;color:var(--df-tab-text)}.recent-tabs .tabs-content .tabs-filter .filter-option:first-child{margin-left:0}.recent-tabs .tabs-content .tabs-filter .filter-option:hover,.recent-tabs .tabs-content .tabs-filter .filter-option.tabs-active{color:var(--df-btn-default-color);text-decoration:none;background-color:var(--df-tab-bg-active)}.tags{display:flex;flex:1;flex-direction:row;flex-wrap:wrap;position:relative;z-index:2}@media (max-width: 768px){.tags{z-index:unset}}.tags .tag{font-size:.75rem;display:flex;width:auto;min-width:max-content;max-height:2rem;justify-content:space-between;align-items:center;text-transform:lowercase;margin:.5rem 1rem .5rem 0;padding:.5rem 1rem;border-radius:1.5rem;cursor:pointer}.df-cancel-btn{background-color:var(--white);color:var(--primary-400);border-color:var(--primary-400);margin:0 .5rem}.df-cancel-btn:hover,.df-cancel-btn:active{color:var(--primary-800);background-color:var(--primary-100)}.topic-list-container{overflow-y:auto;overflow-x:hidden;height:calc(100vh - 150px)!important}#topic-scroll::-webkit-scrollbar-track{box-shadow:inset 0 0 6px #0000004d;background-color:#ccc}#topic-scroll::-webkit-scrollbar{width:8px}#topic-scroll::-webkit-scrollbar-thumb{background:gray}.no-card-content{cursor:pointer;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;background:var(--df-card-bg);color:var(--df-text);flex:1;height:auto;margin-bottom:0;transition:box-shadow .28s cubic-bezier(.4,0,.2,1);display:block;position:relative;padding:1rem;border-radius:.25rem;width:auto}.no-card-content .no-data-label{font-size:1.25rem;font-weight:700}.df-btn{white-space:nowrap;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;outline:0;display:inline-block;border:0;cursor:pointer;min-width:4rem;border-radius:.125rem;position:relative;line-height:1;text-transform:inherit;text-decoration:none}.df-btn-normal{height:2rem;padding:.5rem 1rem;font-size:.75rem}.df-btn-primary{background-color:var(--primary-400)}.df-btn-secondary{background-color:var(--secondary-200)}.df-btn-tertiary{background-color:var(--tertiary-100)}.df-btn-danger{background-color:var(--red-100)}.df-btn-danger:hover{background-color:var(--red-400)}.df-btn-primary,.df-btn-secondary,.df-btn-tertiary,.df-btn-danger{color:var(--df-btn-default-color)}.df-btn-primary.active,.df-btn-primary:active,.df-btn-primary:hover{background-color:var(--primary-800)}.df-btn-secondary.active,.df-btn-secondary:active,.df-btn-secondary:hover{background-color:var(--secondary-400)}.df-btn-tertiary.active,.df-btn-tertiary:active,.df-btn-tertiary:hover{background-color:var(--tertiary-400)}.tag{display:flex;width:17.25rem;height:2rem;border-radius:.25rem;justify-content:space-between;margin:.5rem 0;align-items:center;box-sizing:border-box}.custom-margin{margin-top:auto!important;margin-bottom:auto!important}@media (max-width: 768px){.right_tag_inner_box{width:100%;margin-left:0!important}}.update_box{box-sizing:border-box;margin-top:2rem;display:none}.update_box .update_inner_box{box-sizing:border-box;margin-top:1rem}.update_box .update_inner_box .update_card{box-sizing:border-box}.update_box .update_inner_box .update_card .card_head p.blue_heading{color:var(--primary);margin-bottom:.5rem}.update_box .update_inner_box .update_btn_box{width:100%;margin-top:.5rem}.update_box .update_inner_box .update_btn_box a.all_update_link{width:100%;padding:.5rem 0;text-align:center;color:var(--primary);border-radius:.25rem;border:.0625rem solid var(--black)}\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: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
|
|
53
|
+
}
|
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TrendingTagsComponent, decorators: [{
|
|
55
|
+
type: Component,
|
|
56
|
+
args: [{ selector: 'lib-discuss-trending-tags', template: "<div class=\"margin-left-l right_tag_inner_box\">\n <span class=\"mat-subheading-2\" role=\"link\" tabindex=\"0\" aria-label=\"Trending tags\">Trending tags</span>\n <ng-container *ngIf=\"trandingTags && trandingTags.length > 0\">\n <div *ngFor=\"let tag of trandingTags\" class=\"tag ws-mat-primary-lite-background-important cursor-pointer\" role=\"link\" tabindex=\"0\"\n [attr.aria-label]=\"tag.value\"\n [ngStyle]=\"{'background-image':'linear-gradient(to right, #ECECEC, #ECECEC ' + ((tag.score / max) *100 ) + '%, #FFF 24px)'}\" (click)=\"getAllDiscussions(tag)\">\n <span class=\"margin-left-m mat-caption\">{{tag.value}}</span>\n <span class=\"custom-margin margin-right-m mat-subheading-2\">{{tag.score}}</span>\n </div>\n </ng-container>\n </div>\n\n <div class=\"update_box margin-left-l\"> \n <span class=\"mat-subheading-2\" role=\"link\" tabindex=\"0\" aria-label=\"Updates\">Updates</span>\n <div class=\"update_inner_box flex flex-col items-center justify-center\">\n\n <div class=\"mat-card flex flex-col update_card margin-bottom-s\">\n <div class=\"flex fex-1 items-center justify-start card_head\">\n <p class=\"mat-subheading-1 blue_heading\">1 Upvote on your question</p>\n </div>\n <div class=\"flex fex-1 items-center justify-start card_body\">\n <p class=\"mat-body-2\">What is the most reliable and useful source for COVID related ..</p>\n </div>\n </div>\n\n <div class=\"mat-card flex flex-col update_card margin-bottom-s\">\n <div class=\"flex fex-1 items-center justify-start card_head\">\n <p class=\"mat-subheading-1 blue_heading\">@sundaramraj answered your question</p>\n </div>\n <div class=\"flex fex-1 items-center justify-start card_body\">\n <p class=\"mat-body-2\">I think the solution to such a problem would be to extensively..</p>\n </div>\n </div>\n\n <div class=\"mat-card flex flex-col update_card margin-bottom-s\">\n <div class=\"flex fex-1 items-center justify-start card_head\">\n <p class=\"mat-subheading-1 blue_heading\">1 Upvote on your question</p>\n </div>\n <div class=\"flex fex-1 items-center justify-start card_body\">\n <p class=\"mat-body-2\">What is the most reliable and useful source for COVID related ..</p>\n </div>\n </div>\n\n <div class=\"flex flex-col items-center update_btn_box\">\n <a class=\"all_update_link flex mat-subheading-2 justify-center\">ALL UPDATES</a>\n </div>\n\n </div>\n </div>", styles: [":root{font-size:16px;--blue: #024f9d;--green: #008840;--black: #000000;--white: #ffffff;--red:#ff4558;--primary: var(--blue);--secondary: #008840;--tertiary: #e55a28;--gray-hs: 0, 0%;--gray: hsl(var(--gray-hs), 20%);--gray-0: hsl(var(--gray-hs), 95%);--gray-100: hsl(var(--gray-hs), 80%);--gray-200: hsl(var(--gray-hs), 60%);--gray-300: hsl(var(--gray-hs), 59%);--gray-400: hsl(var(--gray-hs), 40%);--gray-800: var(--gray);--primary-hs: 210, 97%;--primary: hsl(var(--primary-hs), 31%);--primary-0: hsl(var(--primary-hs), 98%);--primary-100: hsl(var(--primary-hs), 88%);--primary-200: hsl(var(--primary-hs), 78%);--primary-250: hsl(var(--primary-hs), 73%);--primary-300: hsl(var(--primary-hs), 68%);--primary-400: var(--primary);--primary-600: hsl(var(--primary), 48%);--primary-800: hsl(var(--primary-hs), 38%);--secondary-hs: 148, 100%;--secondary: hsl(var(--secondary-hs), 27%);--secondary-0: hsl(var(--secondary-hs), 94%);--secondary-100: hsl(var(--secondary-hs), 39%);--secondary-200: hsl(var(--secondary-hs), 38%);--secondary-400: var(--secondary);--tertiary-hs:16,78%;--tertiary:hsl(var(--tertiary-hs), 53%);--tertiary-0:hsl(var(--tertiary-hs), 92%);--tertiary-100: hsl(var(--tertiary-hs), 56%);--tertiary-400: var(--tertiary);--red-0: #fbccd1;--red-100: #ff6979;--red-400: var(--red);--df-e9e8d9:#e9e8d9;--df-333:#333;--text-color:var(--df-333);--df-background:var(--white);--df-common-bg:var(--white);--df-body-bg: var(--primary-0);--df-theme-bg: var(--df-background);--df-text: var(--text-color);--df-card-bg: var(--df-background);--df-btn-default-color: var(--white);--df-field-control-bg: var(--df-background);--df-cancel-btn-bg:var(--df-background);--df-tab-bg: var(--df-background);--df-tab-text: var(--primary);--df-tab-bg-active: var(--primary);--df-tab-text-active: var(--white)}.recent-tabs{transition:box-shadow .28s cubic-bezier(.4,0,.2,1);display:block;position:relative;box-shadow:none!important;border-radius:unset;background:inherit!important;z-index:unset;padding-bottom:.5rem}.recent-tabs .tabs-content{display:flex;flex:1 1 0%;flex-direction:column}.recent-tabs .tabs-content .tabs-filter{display:flex;flex:1 1 0%;flex-wrap:wrap}.recent-tabs .tabs-content .tabs-filter .filter-option{background:var(--df-tab-bg);padding:.5rem 1rem;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;font-size:.875rem;font-weight:700;margin-right:.75rem;margin-top:.5rem;transition:all ease .3s;display:flex;align-items:center;cursor:pointer;white-space:nowrap;text-decoration:none;color:var(--df-tab-text)}.recent-tabs .tabs-content .tabs-filter .filter-option:first-child{margin-left:0}.recent-tabs .tabs-content .tabs-filter .filter-option:hover,.recent-tabs .tabs-content .tabs-filter .filter-option.tabs-active{color:var(--df-btn-default-color);text-decoration:none;background-color:var(--df-tab-bg-active)}.tags{display:flex;flex:1;flex-direction:row;flex-wrap:wrap;position:relative;z-index:2}@media (max-width: 768px){.tags{z-index:unset}}.tags .tag{font-size:.75rem;display:flex;width:auto;min-width:max-content;max-height:2rem;justify-content:space-between;align-items:center;text-transform:lowercase;margin:.5rem 1rem .5rem 0;padding:.5rem 1rem;border-radius:1.5rem;cursor:pointer}.df-cancel-btn{background-color:var(--white);color:var(--primary-400);border-color:var(--primary-400);margin:0 .5rem}.df-cancel-btn:hover,.df-cancel-btn:active{color:var(--primary-800);background-color:var(--primary-100)}.topic-list-container{overflow-y:auto;overflow-x:hidden;height:calc(100vh - 150px)!important}#topic-scroll::-webkit-scrollbar-track{box-shadow:inset 0 0 6px #0000004d;background-color:#ccc}#topic-scroll::-webkit-scrollbar{width:8px}#topic-scroll::-webkit-scrollbar-thumb{background:gray}.no-card-content{cursor:pointer;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;background:var(--df-card-bg);color:var(--df-text);flex:1;height:auto;margin-bottom:0;transition:box-shadow .28s cubic-bezier(.4,0,.2,1);display:block;position:relative;padding:1rem;border-radius:.25rem;width:auto}.no-card-content .no-data-label{font-size:1.25rem;font-weight:700}.df-btn{white-space:nowrap;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;outline:0;display:inline-block;border:0;cursor:pointer;min-width:4rem;border-radius:.125rem;position:relative;line-height:1;text-transform:inherit;text-decoration:none}.df-btn-normal{height:2rem;padding:.5rem 1rem;font-size:.75rem}.df-btn-primary{background-color:var(--primary-400)}.df-btn-secondary{background-color:var(--secondary-200)}.df-btn-tertiary{background-color:var(--tertiary-100)}.df-btn-danger{background-color:var(--red-100)}.df-btn-danger:hover{background-color:var(--red-400)}.df-btn-primary,.df-btn-secondary,.df-btn-tertiary,.df-btn-danger{color:var(--df-btn-default-color)}.df-btn-primary.active,.df-btn-primary:active,.df-btn-primary:hover{background-color:var(--primary-800)}.df-btn-secondary.active,.df-btn-secondary:active,.df-btn-secondary:hover{background-color:var(--secondary-400)}.df-btn-tertiary.active,.df-btn-tertiary:active,.df-btn-tertiary:hover{background-color:var(--tertiary-400)}.tag{display:flex;width:17.25rem;height:2rem;border-radius:.25rem;justify-content:space-between;margin:.5rem 0;align-items:center;box-sizing:border-box}.custom-margin{margin-top:auto!important;margin-bottom:auto!important}@media (max-width: 768px){.right_tag_inner_box{width:100%;margin-left:0!important}}.update_box{box-sizing:border-box;margin-top:2rem;display:none}.update_box .update_inner_box{box-sizing:border-box;margin-top:1rem}.update_box .update_inner_box .update_card{box-sizing:border-box}.update_box .update_inner_box .update_card .card_head p.blue_heading{color:var(--primary);margin-bottom:.5rem}.update_box .update_inner_box .update_btn_box{width:100%;margin-top:.5rem}.update_box .update_inner_box .update_btn_box a.all_update_link{width:100%;padding:.5rem 0;text-align:center;color:var(--primary);border-radius:.25rem;border:.0625rem solid var(--black)}\n"] }]
|
|
57
|
+
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.ConfigService }, { type: i3.NavigationServiceService }]; }, propDecorators: { tags: [{
|
|
58
|
+
type: Input
|
|
59
|
+
}], stateChange: [{
|
|
60
|
+
type: Output
|
|
61
|
+
}] } });
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trending-tags.component.js","sourceRoot":"","sources":["../../../../../../projects/discussion-ui/src/lib/components/trending-tags/trending-tags.component.ts","../../../../../../projects/discussion-ui/src/lib/components/trending-tags/trending-tags.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, OnInit, SimpleChanges, EventEmitter, Output } from '@angular/core';\nimport { NSDiscussData } from '../../models/discuss.model';\n/* tslint:disable */\nimport _ from 'lodash'\nimport { Router } from '@angular/router';\nimport { ConfigService } from '../../services/config.service';\nimport * as CONSTANTS from './../../common/constants.json';\nimport { NavigationServiceService } from '../../navigation-service.service'\n\n/* tslint:enable */\n@Component({\n  selector: 'lib-discuss-trending-tags',\n  templateUrl: './trending-tags.component.html',\n  styleUrls: ['./trending-tags.component.scss'],\n})\nexport class TrendingTagsComponent implements OnInit, OnChanges {\n  @Input() tags!: NSDiscussData.ITag[];\n  @Output() stateChange: EventEmitter<any> = new EventEmitter();\n\n  max = 0;\n  trandingTags!: NSDiscussData.ITag[];\n  queryParam: any;\n  constructor(\n    public router: Router,\n    private configService: ConfigService,\n    private navigationService: NavigationServiceService\n  ) {\n\n  }\n  ngOnInit(): void {\n    // debugger\n    this.max = _.get(_.maxBy(this.tags, 'score'), 'score') || 0;\n    this.trandingTags = _.chain(this.tags).orderBy('score', 'desc').take(5).value();\n  }\n\n  ngOnChanges(data: SimpleChanges) {\n    // debugger\n    // this.tableData!.columns = data.tableData.currentValue.columns\n    this.tags = _.get(data, 'tags.currentValue')\n    this.max = _.get(_.maxBy(this.tags, 'score'), 'score') || 0;\n    this.trandingTags = _.chain(this.tags).orderBy('score', 'desc').take(5).value();\n  }\n\n  // TODO: To enable trending tags click and navigate to tags detals page\n  getAllDiscussions(tag: { value: any }) {\n    // debugger\n    this.queryParam = tag.value;\n    const tagdata = {\n      tagname: ''\n    };\n    tagdata.tagname = tag.value;\n    this.queryParam = tagdata;\n    const routerSlug = this.configService.getConfig().routerSlug ? this.configService.getConfig().routerSlug : '';\n    const input = { data: { url: `${routerSlug}${CONSTANTS.ROUTES.TAG}tag-discussions`,\n    queryParams: this.queryParam, tagName: this.queryParam.tagName }, action: 'tagsAll'};\n    this.navigationService.navigate(input);\n    this.stateChange.emit({ action: CONSTANTS.TAG_ALL_DISCUSS, title: tag.value, tid: 'sd' });\n\n    // tslint:disable-next-line: max-line-length\n    // this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TAG}tag-discussions`], { queryParams: this.queryParam });\n  }\n\n  css() {\n    // return 'linear - gradient(to left, #00ff00 \" + 80 + \" %, #ff0000 20 %)\"\n  }\n}","<div class=\"margin-left-l right_tag_inner_box\">\n    <span class=\"mat-subheading-2\" role=\"link\" tabindex=\"0\" aria-label=\"Trending tags\">Trending tags</span>\n    <ng-container *ngIf=\"trandingTags && trandingTags.length > 0\">\n      <div *ngFor=\"let tag of trandingTags\" class=\"tag ws-mat-primary-lite-background-important cursor-pointer\" role=\"link\" tabindex=\"0\"\n        [attr.aria-label]=\"tag.value\"\n        [ngStyle]=\"{'background-image':'linear-gradient(to right, #ECECEC, #ECECEC ' + ((tag.score / max) *100 ) + '%, #FFF 24px)'}\" (click)=\"getAllDiscussions(tag)\">\n        <span class=\"margin-left-m mat-caption\">{{tag.value}}</span>\n        <span class=\"custom-margin margin-right-m mat-subheading-2\">{{tag.score}}</span>\n      </div>\n    </ng-container>\n  </div>\n\n  <div class=\"update_box margin-left-l\"> \n    <span class=\"mat-subheading-2\" role=\"link\" tabindex=\"0\" aria-label=\"Updates\">Updates</span>\n    <div class=\"update_inner_box flex flex-col items-center justify-center\">\n\n      <div class=\"mat-card flex flex-col update_card margin-bottom-s\">\n        <div class=\"flex fex-1 items-center justify-start card_head\">\n          <p class=\"mat-subheading-1 blue_heading\">1 Upvote on your question</p>\n        </div>\n        <div class=\"flex fex-1 items-center justify-start card_body\">\n          <p class=\"mat-body-2\">What is the most reliable and useful source for COVID related ..</p>\n        </div>\n      </div>\n\n      <div class=\"mat-card flex flex-col update_card margin-bottom-s\">\n        <div class=\"flex fex-1 items-center justify-start card_head\">\n          <p class=\"mat-subheading-1 blue_heading\">@sundaramraj answered your question</p>\n        </div>\n        <div class=\"flex fex-1 items-center justify-start card_body\">\n          <p class=\"mat-body-2\">I think the solution to such a problem would be to extensively..</p>\n        </div>\n      </div>\n\n      <div class=\"mat-card flex flex-col update_card margin-bottom-s\">\n        <div class=\"flex fex-1 items-center justify-start card_head\">\n          <p class=\"mat-subheading-1 blue_heading\">1 Upvote on your question</p>\n        </div>\n        <div class=\"flex fex-1 items-center justify-start card_body\">\n          <p class=\"mat-body-2\">What is the most reliable and useful source for COVID related ..</p>\n        </div>\n      </div>\n\n      <div class=\"flex flex-col items-center update_btn_box\">\n        <a class=\"all_update_link flex mat-subheading-2 justify-center\">ALL UPDATES</a>\n      </div>\n\n    </div>\n  </div>"]}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export const urlConfig = {
|
|
2
|
+
// endpoint configs...!
|
|
3
|
+
host: 'http://localhost:3002',
|
|
4
|
+
// host: 'https://dev.sunbirded.org',
|
|
5
|
+
apiSlug: '/discussion',
|
|
6
|
+
apiBasePath: () => `${urlConfig.host}${urlConfig.apiSlug}`,
|
|
7
|
+
// URLs...!
|
|
8
|
+
getAllCategories: () => `${urlConfig.apiBasePath()}/categories`,
|
|
9
|
+
getSingleCategoryDetails: (cid) => `${urlConfig.apiBasePath()}/category/${cid}`,
|
|
10
|
+
getAllTags: () => `${urlConfig.apiBasePath()}/tags`,
|
|
11
|
+
getTagBasedDiscussion: (tag) => `${urlConfig.apiBasePath()}/tags/${tag}`,
|
|
12
|
+
createPost: () => `${urlConfig.apiBasePath()}/v3/topics`,
|
|
13
|
+
votePost: (pid) => `${urlConfig.apiBasePath()}/v3/posts/${pid}/vote`,
|
|
14
|
+
replyPost: (tid) => `${urlConfig.apiBasePath()}/v3/topics/${tid}`,
|
|
15
|
+
bookmarkPost: (pid) => `${urlConfig.apiBasePath()}/v3/posts/${pid}/bookmark`,
|
|
16
|
+
recentPost: () => `${urlConfig.apiBasePath()}/recent`,
|
|
17
|
+
popularPost: () => `${urlConfig.apiBasePath()}/popular`,
|
|
18
|
+
unread: () => `${urlConfig.apiBasePath()}/topics/unread/total`,
|
|
19
|
+
getTopic: () => `${urlConfig.apiBasePath()}/topic`,
|
|
20
|
+
profile: () => `${urlConfig.apiBasePath()}/users/me`,
|
|
21
|
+
fetchProfile: (slug) => `${urlConfig.apiBasePath()}/users/${slug}/about`,
|
|
22
|
+
listUpVote: (slug) => `${urlConfig.apiBasePath()}/user/${slug}/upvoted`,
|
|
23
|
+
listDownVoted: (slug) => `${urlConfig.apiBasePath()}/user/${slug}/downvoted`,
|
|
24
|
+
listSaved: (slug) => `${urlConfig.apiBasePath()}/user/${slug}/bookmarks`,
|
|
25
|
+
fetchNetworkProfile: `user/profileDetails/getUserRegistry`,
|
|
26
|
+
userDetails: (username) => `${urlConfig.apiBasePath()}/user/${username}`,
|
|
27
|
+
getContextBasedTopics: (slug) => `${urlConfig.apiBasePath()}/category/${slug}`,
|
|
28
|
+
registerUser: () => `${urlConfig.apiBasePath()}/user/v1/create`,
|
|
29
|
+
getContextBasedDiscussion: () => `${urlConfig.apiBasePath()}/category/list`,
|
|
30
|
+
getContextBasedTagDiscussion: () => `${urlConfig.apiBasePath()}/tags/list`
|
|
31
|
+
};
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXJsLmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rpc2N1c3Npb24tdWkvc3JjL2xpYi9jb25maWcvdXJsLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUc7SUFDckIsdUJBQXVCO0lBQ3ZCLElBQUksRUFBRSx1QkFBdUI7SUFDN0IscUNBQXFDO0lBQ3JDLE9BQU8sRUFBRSxhQUFhO0lBQ3RCLFdBQVcsRUFBRSxHQUFHLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxJQUFJLEdBQUcsU0FBUyxDQUFDLE9BQU8sRUFBRTtJQUUxRCxXQUFXO0lBQ1gsZ0JBQWdCLEVBQUUsR0FBRyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsV0FBVyxFQUFFLGFBQWE7SUFDL0Qsd0JBQXdCLEVBQUUsQ0FBQyxHQUFXLEVBQUUsRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDLFdBQVcsRUFBRSxhQUFhLEdBQUcsRUFBRTtJQUN2RixVQUFVLEVBQUUsR0FBRyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsV0FBVyxFQUFFLE9BQU87SUFDbkQscUJBQXFCLEVBQUUsQ0FBQyxHQUFXLEVBQUUsRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDLFdBQVcsRUFBRSxTQUFTLEdBQUcsRUFBRTtJQUNoRixVQUFVLEVBQUUsR0FBRyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsV0FBVyxFQUFFLFlBQVk7SUFDeEQsUUFBUSxFQUFFLENBQUMsR0FBVyxFQUFFLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxXQUFXLEVBQUUsYUFBYSxHQUFHLE9BQU87SUFDNUUsU0FBUyxFQUFFLENBQUMsR0FBVyxFQUFFLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxXQUFXLEVBQUUsY0FBYyxHQUFHLEVBQUU7SUFDekUsWUFBWSxFQUFFLENBQUMsR0FBVyxFQUFFLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxXQUFXLEVBQUUsYUFBYSxHQUFHLFdBQVc7SUFDcEYsVUFBVSxFQUFFLEdBQUcsRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDLFdBQVcsRUFBRSxTQUFTO0lBQ3JELFdBQVcsRUFBRSxHQUFHLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxXQUFXLEVBQUUsVUFBVTtJQUN2RCxNQUFNLEVBQUUsR0FBRyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsV0FBVyxFQUFFLHNCQUFzQjtJQUM5RCxRQUFRLEVBQUUsR0FBRyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsV0FBVyxFQUFFLFFBQVE7SUFDbEQsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDLFdBQVcsRUFBRSxXQUFXO0lBQ3BELFlBQVksRUFBRSxDQUFDLElBQVksRUFBRSxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsV0FBVyxFQUFFLFVBQVUsSUFBSSxRQUFRO0lBQ2hGLFVBQVUsRUFBRSxDQUFDLElBQVksRUFBRSxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsV0FBVyxFQUFFLFNBQVMsSUFBSSxVQUFVO0lBQy9FLGFBQWEsRUFBRSxDQUFDLElBQVksRUFBRSxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsV0FBVyxFQUFFLFNBQVMsSUFBSSxZQUFZO0lBQ3BGLFNBQVMsRUFBRSxDQUFDLElBQVksRUFBRSxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsV0FBVyxFQUFFLFNBQVMsSUFBSSxZQUFZO0lBQ2hGLG1CQUFtQixFQUFFLHFDQUFxQztJQUMxRCxXQUFXLEVBQUUsQ0FBQyxRQUFnQixFQUFFLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxXQUFXLEVBQUUsU0FBUyxRQUFRLEVBQUU7SUFDaEYscUJBQXFCLEVBQUUsQ0FBQyxJQUFZLEVBQUUsRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDLFdBQVcsRUFBRSxhQUFhLElBQUksRUFBRTtJQUN0RixZQUFZLEVBQUUsR0FBRyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsV0FBVyxFQUFFLGlCQUFpQjtJQUMvRCx5QkFBeUIsRUFBRSxHQUFHLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxXQUFXLEVBQUUsZ0JBQWdCO0lBQzNFLDRCQUE0QixFQUFFLEdBQUcsRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDLFdBQVcsRUFBRSxZQUFZO0NBQzdFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgdXJsQ29uZmlnID0ge1xuICAgIC8vIGVuZHBvaW50IGNvbmZpZ3MuLi4hXG4gICAgaG9zdDogJ2h0dHA6Ly9sb2NhbGhvc3Q6MzAwMicsXG4gICAgLy8gaG9zdDogJ2h0dHBzOi8vZGV2LnN1bmJpcmRlZC5vcmcnLFxuICAgIGFwaVNsdWc6ICcvZGlzY3Vzc2lvbicsXG4gICAgYXBpQmFzZVBhdGg6ICgpID0+IGAke3VybENvbmZpZy5ob3N0fSR7dXJsQ29uZmlnLmFwaVNsdWd9YCxcblxuICAgIC8vIFVSTHMuLi4hXG4gICAgZ2V0QWxsQ2F0ZWdvcmllczogKCkgPT4gYCR7dXJsQ29uZmlnLmFwaUJhc2VQYXRoKCl9L2NhdGVnb3JpZXNgLFxuICAgIGdldFNpbmdsZUNhdGVnb3J5RGV0YWlsczogKGNpZDogbnVtYmVyKSA9PiBgJHt1cmxDb25maWcuYXBpQmFzZVBhdGgoKX0vY2F0ZWdvcnkvJHtjaWR9YCxcbiAgICBnZXRBbGxUYWdzOiAoKSA9PiBgJHt1cmxDb25maWcuYXBpQmFzZVBhdGgoKX0vdGFnc2AsXG4gICAgZ2V0VGFnQmFzZWREaXNjdXNzaW9uOiAodGFnOiBzdHJpbmcpID0+IGAke3VybENvbmZpZy5hcGlCYXNlUGF0aCgpfS90YWdzLyR7dGFnfWAsXG4gICAgY3JlYXRlUG9zdDogKCkgPT4gYCR7dXJsQ29uZmlnLmFwaUJhc2VQYXRoKCl9L3YzL3RvcGljc2AsXG4gICAgdm90ZVBvc3Q6IChwaWQ6IG51bWJlcikgPT4gYCR7dXJsQ29uZmlnLmFwaUJhc2VQYXRoKCl9L3YzL3Bvc3RzLyR7cGlkfS92b3RlYCxcbiAgICByZXBseVBvc3Q6ICh0aWQ6IG51bWJlcikgPT4gYCR7dXJsQ29uZmlnLmFwaUJhc2VQYXRoKCl9L3YzL3RvcGljcy8ke3RpZH1gLFxuICAgIGJvb2ttYXJrUG9zdDogKHBpZDogbnVtYmVyKSA9PiBgJHt1cmxDb25maWcuYXBpQmFzZVBhdGgoKX0vdjMvcG9zdHMvJHtwaWR9L2Jvb2ttYXJrYCxcbiAgICByZWNlbnRQb3N0OiAoKSA9PiBgJHt1cmxDb25maWcuYXBpQmFzZVBhdGgoKX0vcmVjZW50YCxcbiAgICBwb3B1bGFyUG9zdDogKCkgPT4gYCR7dXJsQ29uZmlnLmFwaUJhc2VQYXRoKCl9L3BvcHVsYXJgLFxuICAgIHVucmVhZDogKCkgPT4gYCR7dXJsQ29uZmlnLmFwaUJhc2VQYXRoKCl9L3RvcGljcy91bnJlYWQvdG90YWxgLFxuICAgIGdldFRvcGljOiAoKSA9PiBgJHt1cmxDb25maWcuYXBpQmFzZVBhdGgoKX0vdG9waWNgLFxuICAgIHByb2ZpbGU6ICgpID0+IGAke3VybENvbmZpZy5hcGlCYXNlUGF0aCgpfS91c2Vycy9tZWAsXG4gICAgZmV0Y2hQcm9maWxlOiAoc2x1Zzogc3RyaW5nKSA9PiBgJHt1cmxDb25maWcuYXBpQmFzZVBhdGgoKX0vdXNlcnMvJHtzbHVnfS9hYm91dGAsXG4gICAgbGlzdFVwVm90ZTogKHNsdWc6IHN0cmluZykgPT4gYCR7dXJsQ29uZmlnLmFwaUJhc2VQYXRoKCl9L3VzZXIvJHtzbHVnfS91cHZvdGVkYCxcbiAgICBsaXN0RG93blZvdGVkOiAoc2x1Zzogc3RyaW5nKSA9PiBgJHt1cmxDb25maWcuYXBpQmFzZVBhdGgoKX0vdXNlci8ke3NsdWd9L2Rvd252b3RlZGAsXG4gICAgbGlzdFNhdmVkOiAoc2x1Zzogc3RyaW5nKSA9PiBgJHt1cmxDb25maWcuYXBpQmFzZVBhdGgoKX0vdXNlci8ke3NsdWd9L2Jvb2ttYXJrc2AsXG4gICAgZmV0Y2hOZXR3b3JrUHJvZmlsZTogYHVzZXIvcHJvZmlsZURldGFpbHMvZ2V0VXNlclJlZ2lzdHJ5YCxcbiAgICB1c2VyRGV0YWlsczogKHVzZXJuYW1lOiBzdHJpbmcpID0+IGAke3VybENvbmZpZy5hcGlCYXNlUGF0aCgpfS91c2VyLyR7dXNlcm5hbWV9YCxcbiAgICBnZXRDb250ZXh0QmFzZWRUb3BpY3M6IChzbHVnOiBzdHJpbmcpID0+IGAke3VybENvbmZpZy5hcGlCYXNlUGF0aCgpfS9jYXRlZ29yeS8ke3NsdWd9YCxcbiAgICByZWdpc3RlclVzZXI6ICgpID0+IGAke3VybENvbmZpZy5hcGlCYXNlUGF0aCgpfS91c2VyL3YxL2NyZWF0ZWAsXG4gICAgZ2V0Q29udGV4dEJhc2VkRGlzY3Vzc2lvbjogKCkgPT4gYCR7dXJsQ29uZmlnLmFwaUJhc2VQYXRoKCl9L2NhdGVnb3J5L2xpc3RgLFxuICAgIGdldENvbnRleHRCYXNlZFRhZ0Rpc2N1c3Npb246ICgpID0+IGAke3VybENvbmZpZy5hcGlCYXNlUGF0aCgpfS90YWdzL2xpc3RgXG59O1xuIl19
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Injectable, EventEmitter } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
/* tslint:disable */
|
|
4
|
+
import * as _ from 'lodash';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
/* tslint:enable */
|
|
7
|
+
export class DiscussionEventsService {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.telemetryEvent = new Subject();
|
|
10
|
+
this.actionEvent = new EventEmitter();
|
|
11
|
+
}
|
|
12
|
+
emitTelemetry(event) {
|
|
13
|
+
console.log('Lib Event', event);
|
|
14
|
+
if (!_.isEmpty(event)) {
|
|
15
|
+
this.telemetryEvent.next(event);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussionEventsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
19
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussionEventsService, providedIn: 'root' }); }
|
|
20
|
+
}
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussionEventsService, decorators: [{
|
|
22
|
+
type: Injectable,
|
|
23
|
+
args: [{
|
|
24
|
+
providedIn: 'root'
|
|
25
|
+
}]
|
|
26
|
+
}], ctorParameters: function () { return []; } });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzY3Vzc2lvbi1ldmVudHMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2Rpc2N1c3Npb24tdWkvc3JjL2xpYi9kaXNjdXNzaW9uLWV2ZW50cy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDL0Isb0JBQW9CO0FBQ3BCLE9BQU8sS0FBSyxDQUFDLE1BQU0sUUFBUSxDQUFBOztBQUMzQixtQkFBbUI7QUFJbkIsTUFBTSxPQUFPLHVCQUF1QjtJQUtsQztRQUhPLG1CQUFjLEdBQUcsSUFBSSxPQUFPLEVBQU8sQ0FBQztRQUNwQyxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7SUFFN0IsQ0FBQztJQUVqQixhQUFhLENBQUMsS0FBSztRQUNqQixPQUFPLENBQUMsR0FBRyxDQUFDLFdBQVcsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNoQyxJQUFJLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNyQixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUNqQztJQUNILENBQUM7K0dBWlUsdUJBQXVCO21IQUF2Qix1QkFBdUIsY0FGdEIsTUFBTTs7NEZBRVAsdUJBQXVCO2tCQUhuQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIEV2ZW50RW1pdHRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuLyogdHNsaW50OmRpc2FibGUgKi9cbmltcG9ydCAqIGFzIF8gZnJvbSAnbG9kYXNoJ1xuLyogdHNsaW50OmVuYWJsZSAqL1xuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgRGlzY3Vzc2lvbkV2ZW50c1NlcnZpY2Uge1xuXG4gIHB1YmxpYyB0ZWxlbWV0cnlFdmVudCA9IG5ldyBTdWJqZWN0PGFueT4oKTtcbiAgcHVibGljIGFjdGlvbkV2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cblxuICBlbWl0VGVsZW1ldHJ5KGV2ZW50KSB7XG4gICAgY29uc29sZS5sb2coJ0xpYiBFdmVudCcsIGV2ZW50KTtcbiAgICBpZiAoIV8uaXNFbXB0eShldmVudCkpIHtcbiAgICAgIHRoaXMudGVsZW1ldHJ5RXZlbnQubmV4dChldmVudCk7XG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { DiscussionDetailsComponent } from './../components/discussion-details/discussion-details.component';
|
|
2
|
+
import { MyDiscussionComponent } from './../components/my-discussion/my-discussion.component';
|
|
3
|
+
import { DiscussTagsComponent } from './../components/discuss-tags/discuss-tags.component';
|
|
4
|
+
import { DiscussCategoryComponent } from './../components/discuss-category/discuss-category.component';
|
|
5
|
+
import { LibEntryComponent } from './../components/lib-entry/lib-entry.component';
|
|
6
|
+
import { NgModule } from '@angular/core';
|
|
7
|
+
import { CommonModule } from '@angular/common';
|
|
8
|
+
import { RouterModule } from '@angular/router';
|
|
9
|
+
import { DiscussHomeComponent } from './../components/discuss-home/discuss-home.component';
|
|
10
|
+
import { DiscussAllComponent } from './../components/discuss-all/discuss-all.component';
|
|
11
|
+
import { TagAllDiscussionComponent } from './../components/tag-all-discussion/tag-all-discussion.component';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "@angular/router";
|
|
14
|
+
const routes = [
|
|
15
|
+
{
|
|
16
|
+
path: '',
|
|
17
|
+
component: LibEntryComponent,
|
|
18
|
+
children: [
|
|
19
|
+
{
|
|
20
|
+
path: '',
|
|
21
|
+
pathMatch: 'full',
|
|
22
|
+
component: DiscussCategoryComponent
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
path: 'all-discussions',
|
|
26
|
+
pathMatch: 'full',
|
|
27
|
+
component: DiscussAllComponent
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
path: 'categories',
|
|
31
|
+
pathMatch: 'full',
|
|
32
|
+
component: DiscussCategoryComponent
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
path: 'tags',
|
|
36
|
+
pathMatch: 'full',
|
|
37
|
+
component: DiscussTagsComponent
|
|
38
|
+
},
|
|
39
|
+
// TODO: ADD LATER
|
|
40
|
+
{
|
|
41
|
+
path: 'tags/tag-discussions',
|
|
42
|
+
pathMatch: 'full',
|
|
43
|
+
component: TagAllDiscussionComponent
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
path: 'my-discussion',
|
|
47
|
+
pathMatch: 'full',
|
|
48
|
+
component: MyDiscussionComponent
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
path: 'category/:slug',
|
|
52
|
+
pathMatch: 'full',
|
|
53
|
+
component: DiscussHomeComponent
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
path: 'topic/:topicId/:slug',
|
|
57
|
+
pathMatch: 'full',
|
|
58
|
+
component: DiscussionDetailsComponent
|
|
59
|
+
}
|
|
60
|
+
]
|
|
61
|
+
},
|
|
62
|
+
];
|
|
63
|
+
export class DiscussionRoutingModule {
|
|
64
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussionRoutingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
65
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: DiscussionRoutingModule, imports: [i1.RouterModule, CommonModule], exports: [RouterModule] }); }
|
|
66
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussionRoutingModule, imports: [RouterModule.forChild(routes),
|
|
67
|
+
CommonModule, RouterModule] }); }
|
|
68
|
+
}
|
|
69
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussionRoutingModule, decorators: [{
|
|
70
|
+
type: NgModule,
|
|
71
|
+
args: [{
|
|
72
|
+
declarations: [],
|
|
73
|
+
imports: [
|
|
74
|
+
RouterModule.forChild(routes),
|
|
75
|
+
CommonModule
|
|
76
|
+
],
|
|
77
|
+
exports: [RouterModule]
|
|
78
|
+
}]
|
|
79
|
+
}] });
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzY3Vzc2lvbi1yb3V0aW5nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rpc2N1c3Npb24tdWkvc3JjL2xpYi9kaXNjdXNzaW9uLXJvdXRpbmcvZGlzY3Vzc2lvbi1yb3V0aW5nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxpRUFBaUUsQ0FBQztBQUM3RyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx1REFBdUQsQ0FBQztBQUM5RixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxREFBcUQsQ0FBQztBQUMzRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw2REFBNkQsQ0FBQztBQUN2RyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUNsRixPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsWUFBWSxFQUFVLE1BQU0saUJBQWlCLENBQUM7QUFDdkQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0scURBQXFELENBQUM7QUFDM0YsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sbURBQW1ELENBQUM7QUFDeEYsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0saUVBQWlFLENBQUM7OztBQUc1RyxNQUFNLE1BQU0sR0FBVztJQUNyQjtRQUNFLElBQUksRUFBRSxFQUFFO1FBQ1IsU0FBUyxFQUFFLGlCQUFpQjtRQUM1QixRQUFRLEVBQUU7WUFDUjtnQkFDRSxJQUFJLEVBQUUsRUFBRTtnQkFDUixTQUFTLEVBQUUsTUFBTTtnQkFDakIsU0FBUyxFQUFFLHdCQUF3QjthQUNwQztZQUNEO2dCQUNFLElBQUksRUFBRSxpQkFBaUI7Z0JBQ3ZCLFNBQVMsRUFBRSxNQUFNO2dCQUNqQixTQUFTLEVBQUUsbUJBQW1CO2FBQy9CO1lBQ0Q7Z0JBQ0UsSUFBSSxFQUFFLFlBQVk7Z0JBQ2xCLFNBQVMsRUFBRSxNQUFNO2dCQUNqQixTQUFTLEVBQUUsd0JBQXdCO2FBQ3BDO1lBQ0Q7Z0JBQ0UsSUFBSSxFQUFFLE1BQU07Z0JBQ1osU0FBUyxFQUFFLE1BQU07Z0JBQ2pCLFNBQVMsRUFBRSxvQkFBb0I7YUFDaEM7WUFDRCxrQkFBa0I7WUFDbEI7Z0JBQ0UsSUFBSSxFQUFFLHNCQUFzQjtnQkFDNUIsU0FBUyxFQUFFLE1BQU07Z0JBQ2pCLFNBQVMsRUFBRSx5QkFBeUI7YUFDckM7WUFDRDtnQkFDRSxJQUFJLEVBQUUsZUFBZTtnQkFDckIsU0FBUyxFQUFFLE1BQU07Z0JBQ2pCLFNBQVMsRUFBRSxxQkFBcUI7YUFDakM7WUFDRDtnQkFDRSxJQUFJLEVBQUUsZ0JBQWdCO2dCQUN0QixTQUFTLEVBQUUsTUFBTTtnQkFDakIsU0FBUyxFQUFFLG9CQUFvQjthQUNoQztZQUNEO2dCQUNFLElBQUksRUFBRSxzQkFBc0I7Z0JBQzVCLFNBQVMsRUFBRSxNQUFNO2dCQUNqQixTQUFTLEVBQUUsMEJBQTBCO2FBQ3RDO1NBQ0Y7S0FDRjtDQUNGLENBQUM7QUFVRixNQUFNLE9BQU8sdUJBQXVCOytHQUF2Qix1QkFBdUI7Z0hBQXZCLHVCQUF1Qiw2QkFKaEMsWUFBWSxhQUVKLFlBQVk7Z0hBRVgsdUJBQXVCLFlBTGhDLFlBQVksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDO1lBQzdCLFlBQVksRUFFSixZQUFZOzs0RkFFWCx1QkFBdUI7a0JBUm5DLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLEVBQUU7b0JBQ2hCLE9BQU8sRUFBRTt3QkFDUCxZQUFZLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQzt3QkFDN0IsWUFBWTtxQkFDYjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7aUJBQ3hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlzY3Vzc2lvbkRldGFpbHNDb21wb25lbnQgfSBmcm9tICcuLy4uL2NvbXBvbmVudHMvZGlzY3Vzc2lvbi1kZXRhaWxzL2Rpc2N1c3Npb24tZGV0YWlscy5jb21wb25lbnQnO1xuaW1wb3J0IHsgTXlEaXNjdXNzaW9uQ29tcG9uZW50IH0gZnJvbSAnLi8uLi9jb21wb25lbnRzL215LWRpc2N1c3Npb24vbXktZGlzY3Vzc2lvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGlzY3Vzc1RhZ3NDb21wb25lbnQgfSBmcm9tICcuLy4uL2NvbXBvbmVudHMvZGlzY3Vzcy10YWdzL2Rpc2N1c3MtdGFncy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGlzY3Vzc0NhdGVnb3J5Q29tcG9uZW50IH0gZnJvbSAnLi8uLi9jb21wb25lbnRzL2Rpc2N1c3MtY2F0ZWdvcnkvZGlzY3Vzcy1jYXRlZ29yeS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTGliRW50cnlDb21wb25lbnQgfSBmcm9tICcuLy4uL2NvbXBvbmVudHMvbGliLWVudHJ5L2xpYi1lbnRyeS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBSb3V0ZXJNb2R1bGUsIFJvdXRlcyB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBEaXNjdXNzSG9tZUNvbXBvbmVudCB9IGZyb20gJy4vLi4vY29tcG9uZW50cy9kaXNjdXNzLWhvbWUvZGlzY3Vzcy1ob21lLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEaXNjdXNzQWxsQ29tcG9uZW50IH0gZnJvbSAnLi8uLi9jb21wb25lbnRzL2Rpc2N1c3MtYWxsL2Rpc2N1c3MtYWxsLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUYWdBbGxEaXNjdXNzaW9uQ29tcG9uZW50IH0gZnJvbSAnLi8uLi9jb21wb25lbnRzL3RhZy1hbGwtZGlzY3Vzc2lvbi90YWctYWxsLWRpc2N1c3Npb24uY29tcG9uZW50JztcblxuXG5jb25zdCByb3V0ZXM6IFJvdXRlcyA9IFtcbiAge1xuICAgIHBhdGg6ICcnLFxuICAgIGNvbXBvbmVudDogTGliRW50cnlDb21wb25lbnQsXG4gICAgY2hpbGRyZW46IFtcbiAgICAgIHtcbiAgICAgICAgcGF0aDogJycsXG4gICAgICAgIHBhdGhNYXRjaDogJ2Z1bGwnLFxuICAgICAgICBjb21wb25lbnQ6IERpc2N1c3NDYXRlZ29yeUNvbXBvbmVudFxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgcGF0aDogJ2FsbC1kaXNjdXNzaW9ucycsXG4gICAgICAgIHBhdGhNYXRjaDogJ2Z1bGwnLFxuICAgICAgICBjb21wb25lbnQ6IERpc2N1c3NBbGxDb21wb25lbnRcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIHBhdGg6ICdjYXRlZ29yaWVzJyxcbiAgICAgICAgcGF0aE1hdGNoOiAnZnVsbCcsXG4gICAgICAgIGNvbXBvbmVudDogRGlzY3Vzc0NhdGVnb3J5Q29tcG9uZW50XG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBwYXRoOiAndGFncycsXG4gICAgICAgIHBhdGhNYXRjaDogJ2Z1bGwnLFxuICAgICAgICBjb21wb25lbnQ6IERpc2N1c3NUYWdzQ29tcG9uZW50XG4gICAgICB9LFxuICAgICAgLy8gVE9ETzogQUREIExBVEVSXG4gICAgICB7XG4gICAgICAgIHBhdGg6ICd0YWdzL3RhZy1kaXNjdXNzaW9ucycsXG4gICAgICAgIHBhdGhNYXRjaDogJ2Z1bGwnLFxuICAgICAgICBjb21wb25lbnQ6IFRhZ0FsbERpc2N1c3Npb25Db21wb25lbnRcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIHBhdGg6ICdteS1kaXNjdXNzaW9uJyxcbiAgICAgICAgcGF0aE1hdGNoOiAnZnVsbCcsXG4gICAgICAgIGNvbXBvbmVudDogTXlEaXNjdXNzaW9uQ29tcG9uZW50XG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBwYXRoOiAnY2F0ZWdvcnkvOnNsdWcnLFxuICAgICAgICBwYXRoTWF0Y2g6ICdmdWxsJyxcbiAgICAgICAgY29tcG9uZW50OiBEaXNjdXNzSG9tZUNvbXBvbmVudFxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgcGF0aDogJ3RvcGljLzp0b3BpY0lkLzpzbHVnJyxcbiAgICAgICAgcGF0aE1hdGNoOiAnZnVsbCcsXG4gICAgICAgIGNvbXBvbmVudDogRGlzY3Vzc2lvbkRldGFpbHNDb21wb25lbnRcbiAgICAgIH1cbiAgICBdXG4gIH0sXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtdLFxuICBpbXBvcnRzOiBbXG4gICAgUm91dGVyTW9kdWxlLmZvckNoaWxkKHJvdXRlcyksXG4gICAgQ29tbW9uTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtSb3V0ZXJNb2R1bGVdXG59KVxuZXhwb3J0IGNsYXNzIERpc2N1c3Npb25Sb3V0aW5nTW9kdWxlIHsgfVxuIl19
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { TelemetryUtilsService } from './telemetry-utils.service';
|
|
2
|
+
import { ElementsModule } from './elements/elements.module';
|
|
3
|
+
import { LibEntryComponent } from './components/lib-entry/lib-entry.component';
|
|
4
|
+
import { ComponentsModule } from './components/components.module';
|
|
5
|
+
import { DiscussionRoutingModule } from './discussion-routing/discussion-routing.module';
|
|
6
|
+
import { CategoryWidgetComponent } from './wrapper/category-widget/category-widget.component';
|
|
7
|
+
import { NgModule } from '@angular/core';
|
|
8
|
+
import { DiscussionEventsService } from './discussion-events.service';
|
|
9
|
+
import { BaseWrapperComponent } from './wrapper/base-wrapper/base-wrapper.component';
|
|
10
|
+
import { TagsWidgetComponent } from './wrapper/tags-widget/tags-widget.component';
|
|
11
|
+
import { CommonModule } from '@angular/common';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
export function provideCsModule() {
|
|
14
|
+
return window['CsModule'];
|
|
15
|
+
}
|
|
16
|
+
export class DiscussionUiModule {
|
|
17
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussionUiModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
18
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: DiscussionUiModule, declarations: [LibEntryComponent, CategoryWidgetComponent, BaseWrapperComponent, TagsWidgetComponent], imports: [ComponentsModule,
|
|
19
|
+
DiscussionRoutingModule,
|
|
20
|
+
ElementsModule,
|
|
21
|
+
CommonModule], exports: [ComponentsModule, CategoryWidgetComponent, BaseWrapperComponent, TagsWidgetComponent] }); }
|
|
22
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussionUiModule, providers: [DiscussionEventsService, TelemetryUtilsService, { provide: 'CsModule', useFactory: provideCsModule }], imports: [ComponentsModule,
|
|
23
|
+
DiscussionRoutingModule,
|
|
24
|
+
ElementsModule,
|
|
25
|
+
CommonModule, ComponentsModule] }); }
|
|
26
|
+
}
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussionUiModule, decorators: [{
|
|
28
|
+
type: NgModule,
|
|
29
|
+
args: [{
|
|
30
|
+
declarations: [LibEntryComponent, CategoryWidgetComponent, BaseWrapperComponent, TagsWidgetComponent],
|
|
31
|
+
imports: [
|
|
32
|
+
ComponentsModule,
|
|
33
|
+
DiscussionRoutingModule,
|
|
34
|
+
ElementsModule,
|
|
35
|
+
CommonModule,
|
|
36
|
+
],
|
|
37
|
+
exports: [ComponentsModule, CategoryWidgetComponent, BaseWrapperComponent, TagsWidgetComponent],
|
|
38
|
+
providers: [DiscussionEventsService, TelemetryUtilsService, { provide: 'CsModule', useFactory: provideCsModule }]
|
|
39
|
+
}]
|
|
40
|
+
}] });
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzY3Vzc2lvbi11aS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9kaXNjdXNzaW9uLXVpL3NyYy9saWIvZGlzY3Vzc2lvbi11aS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzVELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQy9FLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3pGLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBRTlGLE9BQU8sRUFBd0IsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9ELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3RFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ3JGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFFL0MsTUFBTSxVQUFVLGVBQWU7SUFDN0IsT0FBTyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7QUFDNUIsQ0FBQztBQVlELE1BQU0sT0FBTyxrQkFBa0I7K0dBQWxCLGtCQUFrQjtnSEFBbEIsa0JBQWtCLGlCQVZiLGlCQUFpQixFQUFFLHVCQUF1QixFQUFFLG9CQUFvQixFQUFFLG1CQUFtQixhQUVuRyxnQkFBZ0I7WUFDaEIsdUJBQXVCO1lBQ3ZCLGNBQWM7WUFDZCxZQUFZLGFBRUgsZ0JBQWdCLEVBQUcsdUJBQXVCLEVBQUUsb0JBQW9CLEVBQUUsbUJBQW1CO2dIQUdyRixrQkFBa0IsYUFGbEIsQ0FBRSx1QkFBdUIsRUFBRSxxQkFBcUIsRUFBQyxFQUFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBQyxDQUFFLFlBTjlHLGdCQUFnQjtZQUNoQix1QkFBdUI7WUFDdkIsY0FBYztZQUNkLFlBQVksRUFFSCxnQkFBZ0I7OzRGQUdoQixrQkFBa0I7a0JBWDlCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQUUsb0JBQW9CLEVBQUUsbUJBQW1CLENBQUM7b0JBQ3RHLE9BQU8sRUFBRTt3QkFDUCxnQkFBZ0I7d0JBQ2hCLHVCQUF1Qjt3QkFDdkIsY0FBYzt3QkFDZCxZQUFZO3FCQUNiO29CQUNELE9BQU8sRUFBRSxDQUFFLGdCQUFnQixFQUFHLHVCQUF1QixFQUFFLG9CQUFvQixFQUFFLG1CQUFtQixDQUFFO29CQUNsRyxTQUFTLEVBQUUsQ0FBRSx1QkFBdUIsRUFBRSxxQkFBcUIsRUFBQyxFQUFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBQyxDQUFFO2lCQUNqSCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbGVtZXRyeVV0aWxzU2VydmljZSB9IGZyb20gJy4vdGVsZW1ldHJ5LXV0aWxzLnNlcnZpY2UnO1xuaW1wb3J0IHsgRWxlbWVudHNNb2R1bGUgfSBmcm9tICcuL2VsZW1lbnRzL2VsZW1lbnRzLm1vZHVsZSc7XG5pbXBvcnQgeyBMaWJFbnRyeUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9saWItZW50cnkvbGliLWVudHJ5LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb21wb25lbnRzTW9kdWxlIH0gZnJvbSAnLi9jb21wb25lbnRzL2NvbXBvbmVudHMubW9kdWxlJztcbmltcG9ydCB7IERpc2N1c3Npb25Sb3V0aW5nTW9kdWxlIH0gZnJvbSAnLi9kaXNjdXNzaW9uLXJvdXRpbmcvZGlzY3Vzc2lvbi1yb3V0aW5nLm1vZHVsZSc7XG5pbXBvcnQgeyBDYXRlZ29yeVdpZGdldENvbXBvbmVudCB9IGZyb20gJy4vd3JhcHBlci9jYXRlZ29yeS13aWRnZXQvY2F0ZWdvcnktd2lkZ2V0LmNvbXBvbmVudCc7XG5cbmltcG9ydCB7ICBNb2R1bGVXaXRoUHJvdmlkZXJzLCBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBEaXNjdXNzaW9uRXZlbnRzU2VydmljZSB9IGZyb20gJy4vZGlzY3Vzc2lvbi1ldmVudHMuc2VydmljZSc7XG5pbXBvcnQgeyBCYXNlV3JhcHBlckNvbXBvbmVudCB9IGZyb20gJy4vd3JhcHBlci9iYXNlLXdyYXBwZXIvYmFzZS13cmFwcGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUYWdzV2lkZ2V0Q29tcG9uZW50IH0gZnJvbSAnLi93cmFwcGVyL3RhZ3Mtd2lkZ2V0L3RhZ3Mtd2lkZ2V0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZUNzTW9kdWxlKCl7XG4gIHJldHVybiB3aW5kb3dbJ0NzTW9kdWxlJ107XG59XG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFsgTGliRW50cnlDb21wb25lbnQsIENhdGVnb3J5V2lkZ2V0Q29tcG9uZW50LCBCYXNlV3JhcHBlckNvbXBvbmVudCwgVGFnc1dpZGdldENvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21wb25lbnRzTW9kdWxlLFxuICAgIERpc2N1c3Npb25Sb3V0aW5nTW9kdWxlLFxuICAgIEVsZW1lbnRzTW9kdWxlLFxuICAgIENvbW1vbk1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogWyBDb21wb25lbnRzTW9kdWxlICwgQ2F0ZWdvcnlXaWRnZXRDb21wb25lbnQsIEJhc2VXcmFwcGVyQ29tcG9uZW50LCBUYWdzV2lkZ2V0Q29tcG9uZW50IF0sXG4gIHByb3ZpZGVyczogWyBEaXNjdXNzaW9uRXZlbnRzU2VydmljZSwgVGVsZW1ldHJ5VXRpbHNTZXJ2aWNlLHtwcm92aWRlOiAnQ3NNb2R1bGUnLCB1c2VGYWN0b3J5OiBwcm92aWRlQ3NNb2R1bGV9IF1cbn0pXG5leHBvcnQgY2xhc3MgRGlzY3Vzc2lvblVpTW9kdWxlIHsgXG59XG4iXX0=
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
/* tslint:disable */
|
|
3
|
+
import * as _ from 'lodash';
|
|
4
|
+
import { timer } from 'rxjs';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../services/discussion.service";
|
|
7
|
+
/* tslint:enable */
|
|
8
|
+
export class AppLoaderComponent {
|
|
9
|
+
constructor(discussionService) {
|
|
10
|
+
this.discussionService = discussionService;
|
|
11
|
+
}
|
|
12
|
+
ngOnInit() {
|
|
13
|
+
this.headerMessage = 'Please wait';
|
|
14
|
+
this.loaderMessage = 'We are fetching details';
|
|
15
|
+
if (this.data) {
|
|
16
|
+
this.headerMessage = _.get(this.data, 'headerMessage') || this.headerMessage;
|
|
17
|
+
this.loaderMessage = _.get(this.data, 'loaderMessage') || this.loaderMessage;
|
|
18
|
+
}
|
|
19
|
+
this.countDown = timer(10000)
|
|
20
|
+
.subscribe(() => {
|
|
21
|
+
this.discussionService.alertEvent.next();
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
ngOnDestroy() {
|
|
25
|
+
this.countDown.unsubscribe();
|
|
26
|
+
}
|
|
27
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AppLoaderComponent, deps: [{ token: i1.DiscussionService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
28
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AppLoaderComponent, selector: "lib-app-loader", inputs: { data: "data" }, ngImport: i0, template: "<ng-container>\n <div class=\"dt-app-loader-container\">\n <img src=\"./assets/discussion-ui/images/loader-icon.svg\" width=\"50px\">\n <div class=\"loader-content\">\n <div class=\"loader-label\">\n {{headerMessage}}\n </div>\n <p>{{loaderMessage}}</p>\n </div>\n </div>\n</ng-container>", styles: [".dt-app-loader-container{background:var(--gray-100);width:94%!important;margin:1rem auto;border-radius:1.5rem;border:0px;display:flex;padding:1rem}\\200b .loader-content{margin:0 1rem;font-size:.875rem}\\200b .loader-label{font-weight:700;margin-bottom:.25rem}\n"] }); }
|
|
29
|
+
}
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AppLoaderComponent, decorators: [{
|
|
31
|
+
type: Component,
|
|
32
|
+
args: [{ selector: 'lib-app-loader', template: "<ng-container>\n <div class=\"dt-app-loader-container\">\n <img src=\"./assets/discussion-ui/images/loader-icon.svg\" width=\"50px\">\n <div class=\"loader-content\">\n <div class=\"loader-label\">\n {{headerMessage}}\n </div>\n <p>{{loaderMessage}}</p>\n </div>\n </div>\n</ng-container>", styles: [".dt-app-loader-container{background:var(--gray-100);width:94%!important;margin:1rem auto;border-radius:1.5rem;border:0px;display:flex;padding:1rem}\\200b .loader-content{margin:0 1rem;font-size:.875rem}\\200b .loader-label{font-weight:700;margin-bottom:.25rem}\n"] }]
|
|
33
|
+
}], ctorParameters: function () { return [{ type: i1.DiscussionService }]; }, propDecorators: { data: [{
|
|
34
|
+
type: Input
|
|
35
|
+
}] } });
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLWxvYWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kaXNjdXNzaW9uLXVpL3NyYy9saWIvZWxlbWVudHMvYXBwLWxvYWRlci9hcHAtbG9hZGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rpc2N1c3Npb24tdWkvc3JjL2xpYi9lbGVtZW50cy9hcHAtbG9hZGVyL2FwcC1sb2FkZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxLQUFLLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFFcEUsb0JBQW9CO0FBQ3BCLE9BQU8sS0FBSyxDQUFDLE1BQU0sUUFBUSxDQUFBO0FBQzNCLE9BQU8sRUFBZ0IsS0FBSyxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7QUFFM0MsbUJBQW1CO0FBT25CLE1BQU0sT0FBTyxrQkFBa0I7SUFPN0IsWUFDVSxpQkFBb0M7UUFBcEMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtJQUMxQyxDQUFDO0lBRUwsUUFBUTtRQUNOLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO1FBQ25DLElBQUksQ0FBQyxhQUFhLEdBQUcseUJBQXlCLENBQUM7UUFDL0MsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ2IsSUFBSSxDQUFDLGFBQWEsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsZUFBZSxDQUFDLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQztZQUM3RSxJQUFJLENBQUMsYUFBYSxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxlQUFlLENBQUMsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDO1NBQzlFO1FBQ0QsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDO2FBQzFCLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFBO1FBQzFDLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsU0FBUyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQy9CLENBQUM7K0dBMUJVLGtCQUFrQjttR0FBbEIsa0JBQWtCLGdGQ2IvQiw2VUFVZTs7NEZER0Ysa0JBQWtCO2tCQUw5QixTQUFTOytCQUNFLGdCQUFnQjt3R0FNakIsSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIElucHV0LCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyogdHNsaW50OmRpc2FibGUgKi9cbmltcG9ydCAqIGFzIF8gZnJvbSAnbG9kYXNoJ1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9uLCB0aW1lciB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRGlzY3Vzc2lvblNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9kaXNjdXNzaW9uLnNlcnZpY2UnO1xuLyogdHNsaW50OmVuYWJsZSAqL1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdsaWItYXBwLWxvYWRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9hcHAtbG9hZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYXBwLWxvYWRlci5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQXBwTG9hZGVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuXG4gIEBJbnB1dCgpIGRhdGE7XG4gIGhlYWRlck1lc3NhZ2U6IHN0cmluZztcbiAgbG9hZGVyTWVzc2FnZTogc3RyaW5nO1xuICBjb3VudERvd246U3Vic2NyaXB0aW9uO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgZGlzY3Vzc2lvblNlcnZpY2U6IERpc2N1c3Npb25TZXJ2aWNlXG4gICkgeyB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5oZWFkZXJNZXNzYWdlID0gJ1BsZWFzZSB3YWl0JztcbiAgICB0aGlzLmxvYWRlck1lc3NhZ2UgPSAnV2UgYXJlIGZldGNoaW5nIGRldGFpbHMnO1xuICAgIGlmICh0aGlzLmRhdGEpIHtcbiAgICAgIHRoaXMuaGVhZGVyTWVzc2FnZSA9IF8uZ2V0KHRoaXMuZGF0YSwgJ2hlYWRlck1lc3NhZ2UnKSB8fCB0aGlzLmhlYWRlck1lc3NhZ2U7XG4gICAgICB0aGlzLmxvYWRlck1lc3NhZ2UgPSBfLmdldCh0aGlzLmRhdGEsICdsb2FkZXJNZXNzYWdlJykgfHwgdGhpcy5sb2FkZXJNZXNzYWdlO1xuICAgIH1cbiAgICB0aGlzLmNvdW50RG93biA9IHRpbWVyKDEwMDAwKVxuICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgIHRoaXMuZGlzY3Vzc2lvblNlcnZpY2UuYWxlcnRFdmVudC5uZXh0KClcbiAgICAgIH0pO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKXtcbiAgICB0aGlzLmNvdW50RG93bi51bnN1YnNjcmliZSgpO1xuICB9XG59XG5cbiIsIjxuZy1jb250YWluZXI+XG4gIDxkaXYgY2xhc3M9XCJkdC1hcHAtbG9hZGVyLWNvbnRhaW5lclwiPlxuICAgIDxpbWcgc3JjPVwiLi9hc3NldHMvZGlzY3Vzc2lvbi11aS9pbWFnZXMvbG9hZGVyLWljb24uc3ZnXCIgd2lkdGg9XCI1MHB4XCI+XG4gICAgPGRpdiBjbGFzcz1cImxvYWRlci1jb250ZW50XCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJsb2FkZXItbGFiZWxcIj5cbiAgICAgICAgICB7e2hlYWRlck1lc3NhZ2V9fVxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPHA+e3tsb2FkZXJNZXNzYWdlfX08L3A+XG4gICAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L25nLWNvbnRhaW5lcj4iXX0=
|