@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,96 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { NSDiscussData } from './../../models/discuss.model';
|
|
3
|
+
/* tslint:disable */
|
|
4
|
+
import * as _ from 'lodash';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/router";
|
|
7
|
+
import * as i2 from "./../../services/discussion.service";
|
|
8
|
+
import * as i3 from "../../services/config.service";
|
|
9
|
+
import * as i4 from "@angular/common";
|
|
10
|
+
import * as i5 from "../../navigation-service.service";
|
|
11
|
+
import * as i6 from "./../../discussion-events.service";
|
|
12
|
+
import * as i7 from "./../../telemetry-utils.service";
|
|
13
|
+
import * as i8 from "../side-pannel/side-pannel.component";
|
|
14
|
+
import * as i9 from "../../elements/load-alert/load-alert.component";
|
|
15
|
+
/* tslint:enable */
|
|
16
|
+
export class LibEntryComponent {
|
|
17
|
+
constructor(activatedRoute, discussionService, configService, location, navigationServiceService, discussionEventService, telemetryUtils) {
|
|
18
|
+
this.activatedRoute = activatedRoute;
|
|
19
|
+
this.discussionService = discussionService;
|
|
20
|
+
this.configService = configService;
|
|
21
|
+
this.location = location;
|
|
22
|
+
this.navigationServiceService = navigationServiceService;
|
|
23
|
+
this.discussionEventService = discussionEventService;
|
|
24
|
+
this.telemetryUtils = telemetryUtils;
|
|
25
|
+
this.headerOption = true;
|
|
26
|
+
this.currentRoute = 'all-discussions';
|
|
27
|
+
this.showLoaderAlert = false;
|
|
28
|
+
this.bannerSubscription = this.activatedRoute.data.subscribe(data => {
|
|
29
|
+
if (data && data.pageData) {
|
|
30
|
+
this.banner = data.pageData.data.banner || [];
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
ngOnInit() {
|
|
35
|
+
/**
|
|
36
|
+
* calling the initservice to tell navigationservice to use the router service
|
|
37
|
+
* because this component is invoke only in router approach
|
|
38
|
+
*/
|
|
39
|
+
this.navigationServiceService.initService('routerService');
|
|
40
|
+
this.histtoryStartIndex = window.history.length - 1;
|
|
41
|
+
this.configService.setConfig(this.activatedRoute);
|
|
42
|
+
// this.activatedRoute.data.subscribe((data) => {
|
|
43
|
+
this.data = this.configService.getConfig();
|
|
44
|
+
if (!this.data) {
|
|
45
|
+
// fallback for query params
|
|
46
|
+
this.configService.setConfigFromParams(this.activatedRoute);
|
|
47
|
+
this.data = this.configService.getConfig();
|
|
48
|
+
}
|
|
49
|
+
this.discussionService.userId = _.get(this.data, 'userId');
|
|
50
|
+
const rawCategories = _.get(this.data, 'categories');
|
|
51
|
+
this.discussionService.forumIds = _.get(rawCategories, 'result');
|
|
52
|
+
this.discussionService.initializeUserDetails(this.discussionService.userId);
|
|
53
|
+
this.handleLoaderAlert();
|
|
54
|
+
}
|
|
55
|
+
handleLoaderAlert() {
|
|
56
|
+
this.subscription = this.discussionService.alertEvent.subscribe(() => {
|
|
57
|
+
this.showLoaderAlert = true;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
goBack() {
|
|
61
|
+
const eventAction = {
|
|
62
|
+
action: 'DF_BACK'
|
|
63
|
+
};
|
|
64
|
+
this.discussionEventService.emitTelemetry(eventAction);
|
|
65
|
+
this.location.back();
|
|
66
|
+
}
|
|
67
|
+
close(event) {
|
|
68
|
+
this.showLoaderAlert = false;
|
|
69
|
+
const eventAction = {
|
|
70
|
+
action: 'DF_CLOSE'
|
|
71
|
+
};
|
|
72
|
+
this.discussionEventService.emitTelemetry(eventAction);
|
|
73
|
+
this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.LIB_ENTRY);
|
|
74
|
+
window.history.go(-(window.history.length - this.histtoryStartIndex));
|
|
75
|
+
}
|
|
76
|
+
closeLoadAlert() {
|
|
77
|
+
this.showLoaderAlert = false;
|
|
78
|
+
}
|
|
79
|
+
ngOnDestroy() {
|
|
80
|
+
this.subscription.unsubscribe();
|
|
81
|
+
}
|
|
82
|
+
onScrollTopActive(event) {
|
|
83
|
+
window.scroll({
|
|
84
|
+
top: 0,
|
|
85
|
+
left: 0,
|
|
86
|
+
behavior: 'smooth'
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LibEntryComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.DiscussionService }, { token: i3.ConfigService }, { token: i4.Location }, { token: i5.NavigationServiceService }, { token: i6.DiscussionEventsService }, { token: i7.TelemetryUtilsService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
90
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: LibEntryComponent, selector: "lib-lib-entry", host: { classAttribute: "flex-1 main_discuss_lib" }, ngImport: i0, template: "<div class=\"sbt-inside-page-container ui container\">\n <div class=\"df-header\">\n <button type=\"button\" class=\"df-btn df-btn-normal df-btn-primary df-back-btn\" tabindex=\"0\" autofocus\n role=\"button\" (click)=\"goBack()\">\n <img src=\"./assets/discussion-ui/images/back-img.png\" alt=\"back icon\" />\n Back\n </button>\n <button (click)=\"close($event)\" class=\"df-btn df-btn-normal df-btn-danger df-close-btn\" tabindex=\"0\"\n id=\"close-discussion-forum\" type=\"button\" autofocus>\n Close\n <img src=\"./assets/discussion-ui/images/close.png\" alt=\"close icon\" />\n </button>\n </div>\n\n <div class=\"discussion-forum-content\">\n <div class=\"discuss-left-panel\">\n <lib-side-pannel></lib-side-pannel>\n </div>\n <div class=\"discuss-right-panel\">\n <router-outlet (activate)=\"onScrollTopActive($event)\"></router-outlet>\n </div>\n </div>\n</div>\n\n<lib-load-alert *ngIf=\"showLoaderAlert\" (exit)=\"close($event)\" (close)=\"closeLoadAlert()\"></lib-load-alert>", styles: ["::ng-deep:root{--df-header-bg:var(--df-common-bg)}.df-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--df-header-bg);margin-bottom:1rem}.df-header .df-back-btn{display:flex;align-items:center}.df-header .df-back-btn img{width:1rem;height:1rem;margin-right:.25rem;filter:invert(1)}.df-header .df-close-btn img{width:.5rem;height:.5rem;margin-left:.25rem;filter:invert(1)}.discussion-forum-content{display:grid;grid-template-columns:1fr 4fr;grid-gap:1.5rem}@media (max-width: 768px){.discussion-forum-content{grid-template-columns:1fr}}.ui.container{display:block;max-width:100%!important}@media only screen and (max-width: 767px){.ui.container{width:auto!important;margin-left:1em!important;margin-right:1em!important}}@media only screen and (max-width: 1800px) and (min-width: 768px){.ui.container{width:90%;margin-left:auto!important;margin-right:auto!important}}\n"], dependencies: [{ kind: "component", type: i8.SidePannelComponent, selector: "lib-side-pannel" }, { kind: "directive", type: i1.RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "component", type: i9.LoadAlertComponent, selector: "lib-load-alert", outputs: ["close", "exit"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
91
|
+
}
|
|
92
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LibEntryComponent, decorators: [{
|
|
93
|
+
type: Component,
|
|
94
|
+
args: [{ selector: 'lib-lib-entry', host: { class: 'flex-1 main_discuss_lib', }, template: "<div class=\"sbt-inside-page-container ui container\">\n <div class=\"df-header\">\n <button type=\"button\" class=\"df-btn df-btn-normal df-btn-primary df-back-btn\" tabindex=\"0\" autofocus\n role=\"button\" (click)=\"goBack()\">\n <img src=\"./assets/discussion-ui/images/back-img.png\" alt=\"back icon\" />\n Back\n </button>\n <button (click)=\"close($event)\" class=\"df-btn df-btn-normal df-btn-danger df-close-btn\" tabindex=\"0\"\n id=\"close-discussion-forum\" type=\"button\" autofocus>\n Close\n <img src=\"./assets/discussion-ui/images/close.png\" alt=\"close icon\" />\n </button>\n </div>\n\n <div class=\"discussion-forum-content\">\n <div class=\"discuss-left-panel\">\n <lib-side-pannel></lib-side-pannel>\n </div>\n <div class=\"discuss-right-panel\">\n <router-outlet (activate)=\"onScrollTopActive($event)\"></router-outlet>\n </div>\n </div>\n</div>\n\n<lib-load-alert *ngIf=\"showLoaderAlert\" (exit)=\"close($event)\" (close)=\"closeLoadAlert()\"></lib-load-alert>", styles: ["::ng-deep:root{--df-header-bg:var(--df-common-bg)}.df-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--df-header-bg);margin-bottom:1rem}.df-header .df-back-btn{display:flex;align-items:center}.df-header .df-back-btn img{width:1rem;height:1rem;margin-right:.25rem;filter:invert(1)}.df-header .df-close-btn img{width:.5rem;height:.5rem;margin-left:.25rem;filter:invert(1)}.discussion-forum-content{display:grid;grid-template-columns:1fr 4fr;grid-gap:1.5rem}@media (max-width: 768px){.discussion-forum-content{grid-template-columns:1fr}}.ui.container{display:block;max-width:100%!important}@media only screen and (max-width: 767px){.ui.container{width:auto!important;margin-left:1em!important;margin-right:1em!important}}@media only screen and (max-width: 1800px) and (min-width: 768px){.ui.container{width:90%;margin-left:auto!important;margin-right:auto!important}}\n"] }]
|
|
95
|
+
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.DiscussionService }, { type: i3.ConfigService }, { type: i4.Location }, { type: i5.NavigationServiceService }, { type: i6.DiscussionEventsService }, { type: i7.TelemetryUtilsService }]; } });
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-entry.component.js","sourceRoot":"","sources":["../../../../../../projects/discussion-ui/src/lib/components/lib-entry/lib-entry.component.ts","../../../../../../projects/discussion-ui/src/lib/components/lib-entry/lib-entry.component.html"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAqB,MAAM,eAAe,CAAC;AAI7D,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAE7D,oBAAoB;AACpB,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAA;;;;;;;;;;;AAO3B,mBAAmB;AASnB,MAAM,OAAO,iBAAiB;IAc5B,YACS,cAA8B,EAC7B,iBAAoC,EACpC,aAA4B,EAC5B,QAAkB,EAClB,wBAAkD,EAClD,sBAA+C,EAC/C,cAAqC;QANtC,mBAAc,GAAd,cAAc,CAAgB;QAC7B,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,kBAAa,GAAb,aAAa,CAAe;QAC5B,aAAQ,GAAR,QAAQ,CAAU;QAClB,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,2BAAsB,GAAtB,sBAAsB,CAAyB;QAC/C,mBAAc,GAAd,cAAc,CAAuB;QAlB/C,iBAAY,GAAG,IAAI,CAAC;QAIpB,iBAAY,GAAG,iBAAiB,CAAA;QAIhC,oBAAe,GAAG,KAAK,CAAC;QActB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YAClE,IAAI,IAAI,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACzB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAA;aAC9C;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,QAAQ;QACN;;;WAGG;QACH,IAAI,CAAC,wBAAwB,CAAC,WAAW,CAAC,eAAe,CAAC,CAAA;QAC1D,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,GAAC,CAAC,CAAC;QAClD,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAClD,iDAAiD;QACjD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;QAC3C,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;YACd,4BAA4B;YAC5B,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAC5D,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;SAC5C;QACD,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QAC3D,MAAM,aAAa,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;QACrD,IAAI,CAAC,iBAAiB,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;QACjE,IAAI,CAAC,iBAAiB,CAAC,qBAAqB,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAC5E,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC1B,CAAC;IAEF,iBAAiB;QAEf,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,EAAE;YACnE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC9B,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,MAAM;QACJ,MAAM,WAAW,GAAG;YAClB,MAAM,EAAE,SAAS;SAClB,CAAC;QACF,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QACvD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,MAAM,WAAW,GAAG;YAClB,MAAM,EAAE,UAAU;SACnB,CAAC;QACF,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QACvD,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,KAAK,EAAE,aAAa,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAC1E,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAE,CAAC,CAAC;IACzE,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAA;IACjC,CAAC;IAED,iBAAiB,CAAC,KAAK;QACrB,MAAM,CAAC,MAAM,CAAC;YACZ,GAAG,EAAE,CAAC;YACN,IAAI,EAAE,CAAC;YACP,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;IACL,CAAC;+GA7FU,iBAAiB;mGAAjB,iBAAiB,0GCzB9B,0nCAwB2G;;4FDC9F,iBAAiB;kBAR7B,SAAS;+BACE,eAAe,QAInB,EAAE,KAAK,EAAE,yBAAyB,GAAE","sourcesContent":["import { DiscussionService } from './../../services/discussion.service';\nimport { ActivatedRoute } from '@angular/router';\nimport { Component, OnDestroy, OnInit } from '@angular/core';\nimport { Location } from '@angular/common';\nimport { DiscussionEventsService } from './../../discussion-events.service';\nimport { TelemetryUtilsService } from './../../telemetry-utils.service';\nimport { NSDiscussData } from './../../models/discuss.model';\n\n/* tslint:disable */\nimport * as _ from 'lodash'\nimport { IdiscussionConfig } from '../../models/discussion-config.model';\nimport { ConfigService } from '../../services/config.service';\nimport { Inject } from '@angular/core';\nimport { NavigationServiceService } from '../../navigation-service.service';\nimport { AbstractConfigService } from '../../services/abstract-config.service';\nimport { Subscription } from 'rxjs';\n/* tslint:enable */\n@Component({\n  selector: 'lib-lib-entry',\n  templateUrl: './lib-entry.component.html',\n  styleUrls: ['./lib-entry.component.scss'],\n  /* tslint:disable */\n  host: { class: 'flex-1 main_discuss_lib',},\n  /* tslint:enable */\n})\nexport class LibEntryComponent implements OnInit, OnDestroy {\n\n  data: IdiscussionConfig;\n  headerOption = true;\n  banner: any\n  private bannerSubscription: any\n  bannerOption: boolean;\n  currentRoute = 'all-discussions'\n  pageKey: string;\n  config: any;\n  histtoryStartIndex: number;\n  showLoaderAlert = false;\n  subscription: Subscription\n\n  constructor(\n    public activatedRoute: ActivatedRoute,\n    private discussionService: DiscussionService,\n    private configService: ConfigService,\n    private location: Location,\n    private navigationServiceService: NavigationServiceService,\n    private discussionEventService: DiscussionEventsService,\n    private telemetryUtils: TelemetryUtilsService,\n    // @Inject('configService') protected configService: AbstractConfigService\n\n  ) {\n    this.bannerSubscription = this.activatedRoute.data.subscribe(data => {\n      if (data && data.pageData) {\n        this.banner = data.pageData.data.banner || []\n      }\n    })\n  }\n\n  ngOnInit() {\n    /**\n     * calling the initservice to tell navigationservice to use the router service\n     * because this component is invoke only in router approach \n     */\n    this.navigationServiceService.initService('routerService')\n    this.histtoryStartIndex = window.history.length-1;\n    this.configService.setConfig(this.activatedRoute);\n    // this.activatedRoute.data.subscribe((data) => {\n    this.data = this.configService.getConfig();\n    if (!this.data) {\n      // fallback for query params\n      this.configService.setConfigFromParams(this.activatedRoute);\n      this.data = this.configService.getConfig();\n    }\n    this.discussionService.userId = _.get(this.data, 'userId');\n    const rawCategories = _.get(this.data, 'categories');\n    this.discussionService.forumIds = _.get(rawCategories, 'result');\n    this.discussionService.initializeUserDetails(this.discussionService.userId);\n    this.handleLoaderAlert();\n   }\n\n  handleLoaderAlert(){\n\n    this.subscription = this.discussionService.alertEvent.subscribe(() => {\n      this.showLoaderAlert = true;\n    })\n  }\n\n  goBack() {\n    const eventAction = {\n      action: 'DF_BACK'\n    };\n    this.discussionEventService.emitTelemetry(eventAction);\n    this.location.back();\n  }\n\n  close(event) {\n    this.showLoaderAlert = false;\n    const eventAction = {\n      action: 'DF_CLOSE'\n    };\n    this.discussionEventService.emitTelemetry(eventAction);\n    this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.LIB_ENTRY);\n    window.history.go(-(window.history.length - this.histtoryStartIndex ));\n  }\n\n  closeLoadAlert(){\n    this.showLoaderAlert = false;\n  }\n\n  ngOnDestroy(){\n    this.subscription.unsubscribe()\n  }\n\n  onScrollTopActive(event) {\n    window.scroll({\n      top: 0, \n      left: 0, \n      behavior: 'smooth'\n    });\n  }\n\n}\n","<div class=\"sbt-inside-page-container ui container\">\n    <div class=\"df-header\">\n        <button type=\"button\" class=\"df-btn df-btn-normal df-btn-primary df-back-btn\" tabindex=\"0\" autofocus\n            role=\"button\" (click)=\"goBack()\">\n            <img src=\"./assets/discussion-ui/images/back-img.png\" alt=\"back icon\" />\n            Back\n        </button>\n        <button (click)=\"close($event)\" class=\"df-btn df-btn-normal df-btn-danger df-close-btn\" tabindex=\"0\"\n            id=\"close-discussion-forum\" type=\"button\" autofocus>\n            Close\n            <img src=\"./assets/discussion-ui/images/close.png\" alt=\"close icon\" />\n        </button>\n    </div>\n\n    <div class=\"discussion-forum-content\">\n        <div class=\"discuss-left-panel\">\n            <lib-side-pannel></lib-side-pannel>\n        </div>\n        <div class=\"discuss-right-panel\">\n            <router-outlet (activate)=\"onScrollTopActive($event)\"></router-outlet>\n        </div>\n    </div>\n</div>\n\n<lib-load-alert *ngIf=\"showLoaderAlert\" (exit)=\"close($event)\" (close)=\"closeLoadAlert()\"></lib-load-alert>"]}
|
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
import { Component, ViewChild } from '@angular/core';
|
|
2
|
+
import { NSDiscussData } from './../../models/discuss.model';
|
|
3
|
+
import * as CONSTANTS from '../../common/constants.json';
|
|
4
|
+
/* tslint:disable */
|
|
5
|
+
import * as _ from 'lodash';
|
|
6
|
+
import { combineLatest } from 'rxjs';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "./../../services/discussion.service";
|
|
9
|
+
import * as i2 from "../../services/config.service";
|
|
10
|
+
import * as i3 from "@angular/router";
|
|
11
|
+
import * as i4 from "./../../telemetry-utils.service";
|
|
12
|
+
import * as i5 from "@angular/common";
|
|
13
|
+
import * as i6 from "../../elements/discuss-card/discuss-card.component";
|
|
14
|
+
import * as i7 from "../../elements/app-loader/app-loader.component";
|
|
15
|
+
import * as i8 from "ngx-infinite-scroll";
|
|
16
|
+
import * as i9 from "../../pipes/split-initials/split-initials.pipe";
|
|
17
|
+
/* tslint:enable */
|
|
18
|
+
export class MyDiscussionComponent {
|
|
19
|
+
constructor(discussService, configService, router, telemetryUtils) {
|
|
20
|
+
this.discussService = discussService;
|
|
21
|
+
this.configService = configService;
|
|
22
|
+
this.router = router;
|
|
23
|
+
this.telemetryUtils = telemetryUtils;
|
|
24
|
+
this.discussionList = []; // this is for posts
|
|
25
|
+
this.currentFilter = 'timestamp';
|
|
26
|
+
this.userInitial = '';
|
|
27
|
+
this.showLoader = false;
|
|
28
|
+
this.pagination = Object.create({});
|
|
29
|
+
// Input parameters for infinite scroll
|
|
30
|
+
this.InfiniteScrollConfig = {
|
|
31
|
+
modalScrollDistance: 2,
|
|
32
|
+
modalScrollThrottle: 50
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
/** To fetch user details */
|
|
36
|
+
fetchUserProfile(userName) {
|
|
37
|
+
this.discussService.fetchUserProfile(userName).subscribe(response => {
|
|
38
|
+
this.showLoader = false;
|
|
39
|
+
console.log(response);
|
|
40
|
+
this.data = response;
|
|
41
|
+
if (_.get(this.data, 'posts')) {
|
|
42
|
+
this.discussionList = _.get(this.data, 'posts').filter(p => (p.isMainPost === true));
|
|
43
|
+
}
|
|
44
|
+
// if (this.configSvc.userProfile) {
|
|
45
|
+
// localStorage.setItem(this.configSvc.userProfile.userId, this.profilePhoto);
|
|
46
|
+
// }
|
|
47
|
+
}, error => {
|
|
48
|
+
this.showLoader = false;
|
|
49
|
+
// error code check
|
|
50
|
+
this.discussService.showTrafficAlert(error);
|
|
51
|
+
// TODO: Toaster
|
|
52
|
+
console.log('error fetching user details');
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
ngOnInit() {
|
|
56
|
+
this.telemetryUtils.setContext([]);
|
|
57
|
+
this.telemetryUtils.logImpression(NSDiscussData.IPageName.MY_DISCUSSION);
|
|
58
|
+
this.filter(this.currentFilter, false);
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* @description - set the scroll container height
|
|
62
|
+
*/
|
|
63
|
+
ngAfterViewChecked() {
|
|
64
|
+
if (this.elementView && this.elementView.nativeElement && !this.elementView.nativeElement.style.height) {
|
|
65
|
+
// the number 10 is just a random value to reduce the height of the parent container to the infinite scroll
|
|
66
|
+
this.elementView.nativeElement.style.height = (this.elementView.nativeElement.clientHeight - 10) + 'px';
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* @param {string|'timestamp'|'best'|'saved'|'watched'|'upvoted'|'downvoted'} key
|
|
71
|
+
* @param {boolean} resetpagination - its used to reset the pagination value based on the filter data
|
|
72
|
+
*/
|
|
73
|
+
filter(key, resetpagination) {
|
|
74
|
+
this.currentFilter = key;
|
|
75
|
+
if (key) {
|
|
76
|
+
// reset the currentpage value to 1 and reset the discussionList data based on the respective api response when the filter is changed
|
|
77
|
+
if (resetpagination) {
|
|
78
|
+
this.discussionList = [];
|
|
79
|
+
this.pagination.currentPage = 1;
|
|
80
|
+
}
|
|
81
|
+
// setting the current page index
|
|
82
|
+
const scrollIndex = this.pagination.currentPage ? this.pagination.currentPage : 1;
|
|
83
|
+
this.showLoader = true;
|
|
84
|
+
switch (key) {
|
|
85
|
+
case 'timestamp':
|
|
86
|
+
this.getRecentTopics(scrollIndex);
|
|
87
|
+
break;
|
|
88
|
+
case 'best':
|
|
89
|
+
// this.discussionList = _.uniqBy(this.data.bestPosts, 'tid');
|
|
90
|
+
this.discussService.fetchBestPost(scrollIndex).subscribe(result => {
|
|
91
|
+
if (result) {
|
|
92
|
+
const bestPost = result['posts'].filter(p => (p.isMainPost === true));
|
|
93
|
+
this.discussionList = [...this.discussionList, ...bestPost];
|
|
94
|
+
this.pagination = _.get(result, 'pagination');
|
|
95
|
+
this.showLoader = false;
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
this.showLoader = false;
|
|
99
|
+
this.discussionList = [];
|
|
100
|
+
}
|
|
101
|
+
}, error => {
|
|
102
|
+
// error code check
|
|
103
|
+
this.discussService.showTrafficAlert(error);
|
|
104
|
+
});
|
|
105
|
+
break;
|
|
106
|
+
case 'saved':
|
|
107
|
+
this.discussService.fetchSaved(scrollIndex).subscribe(response => {
|
|
108
|
+
if (response) {
|
|
109
|
+
// this.discussionList = _.uniqBy(response['posts'], 'tid');
|
|
110
|
+
this.discussionList = [...this.discussionList, ...response['posts']];
|
|
111
|
+
this.pagination = _.get(response, 'pagination');
|
|
112
|
+
this.showLoader = false;
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
this.showLoader = false;
|
|
116
|
+
this.discussionList = [];
|
|
117
|
+
}
|
|
118
|
+
},
|
|
119
|
+
// tslint:disable-next-line
|
|
120
|
+
(error) => {
|
|
121
|
+
// error code check
|
|
122
|
+
this.discussService.showTrafficAlert(error);
|
|
123
|
+
this.discussionList = [];
|
|
124
|
+
});
|
|
125
|
+
break;
|
|
126
|
+
case 'watched':
|
|
127
|
+
this.showLoader = false;
|
|
128
|
+
this.discussionList = [];
|
|
129
|
+
break;
|
|
130
|
+
case 'upvoted':
|
|
131
|
+
this.discussService.fetchUpvoted(scrollIndex).subscribe(response => {
|
|
132
|
+
if (response) {
|
|
133
|
+
// this.discussionList = _.uniqBy(response['posts'], 'tid');
|
|
134
|
+
const upvoted = response['posts'].filter(p => (p.isMainPost === true));
|
|
135
|
+
this.pagination = _.get(response, 'pagination');
|
|
136
|
+
this.discussionList = [...this.discussionList, ...upvoted];
|
|
137
|
+
this.showLoader = false;
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
this.showLoader = false;
|
|
141
|
+
this.discussionList = [];
|
|
142
|
+
}
|
|
143
|
+
},
|
|
144
|
+
// tslint:disable-next-line
|
|
145
|
+
(error) => {
|
|
146
|
+
this.discussionList = [];
|
|
147
|
+
// error code check
|
|
148
|
+
this.discussService.showTrafficAlert(error);
|
|
149
|
+
});
|
|
150
|
+
break;
|
|
151
|
+
case 'downvoted':
|
|
152
|
+
this.discussService.fetchDownvoted(scrollIndex).subscribe(response => {
|
|
153
|
+
if (response) {
|
|
154
|
+
// this.discussionList = _.uniqBy(response['posts'], 'tid');
|
|
155
|
+
const downvoted = response['posts'].filter(p => (p.isMainPost === true));
|
|
156
|
+
this.discussionList = [...this.discussionList, ...downvoted];
|
|
157
|
+
this.pagination = _.get(response, 'pagination');
|
|
158
|
+
this.showLoader = false;
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
this.showLoader = false;
|
|
162
|
+
this.discussionList = [];
|
|
163
|
+
}
|
|
164
|
+
},
|
|
165
|
+
// tslint:disable-next-line
|
|
166
|
+
(error) => {
|
|
167
|
+
this.discussionList = [];
|
|
168
|
+
// error code check
|
|
169
|
+
this.discussService.showTrafficAlert(error);
|
|
170
|
+
});
|
|
171
|
+
break;
|
|
172
|
+
default:
|
|
173
|
+
// this.discussionList = _.uniqBy(this.data.latestPosts, 'tid');
|
|
174
|
+
this.pagination = _.get(this.data, 'pagination');
|
|
175
|
+
this.discussionList = _.get(this.data, 'latestPosts');
|
|
176
|
+
break;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
navigateToDiscussionDetails(discussionData) {
|
|
181
|
+
console.log('discussionData', discussionData);
|
|
182
|
+
const slug = _.get(discussionData, 'slug') || _.get(discussionData, 'topic.slug');
|
|
183
|
+
this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TOPIC}${slug}`]);
|
|
184
|
+
}
|
|
185
|
+
logTelemetry(event) {
|
|
186
|
+
this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.MY_DISCUSSION);
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* @description - getting the recent post data
|
|
190
|
+
* @param {number} scrollIndex
|
|
191
|
+
*/
|
|
192
|
+
getRecentTopics(scrollIndex) {
|
|
193
|
+
const userId = this.discussService.userId;
|
|
194
|
+
// const userSlug = this.discussService.userDetails.userslug;
|
|
195
|
+
combineLatest([
|
|
196
|
+
this.discussService.fetchUserProfile(userId),
|
|
197
|
+
this.discussService.fetchRecentPost(scrollIndex)
|
|
198
|
+
]).subscribe(result => {
|
|
199
|
+
console.log('getRecentTopics', result);
|
|
200
|
+
this.showLoader = false;
|
|
201
|
+
this.data = _.merge(result[0], result[1]);
|
|
202
|
+
this.discussionList = [...this.discussionList, ...(_.get(this.data, 'posts'))];
|
|
203
|
+
this.discussionList = this.discussionList.filter(p => (p.isMainPost === true));
|
|
204
|
+
this.pagination = _.get(this.data, 'pagination');
|
|
205
|
+
}, error => {
|
|
206
|
+
this.showLoader = false;
|
|
207
|
+
console.log(error);
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
/**
|
|
211
|
+
* @description - call the topic get api when scrolled down and setting the limit of API Call
|
|
212
|
+
*/
|
|
213
|
+
onModalScrollDown() {
|
|
214
|
+
if (this.pagination.currentPage !== this.pagination.pageCount) {
|
|
215
|
+
this.pagination.currentPage = this.pagination.next.page;
|
|
216
|
+
const resetpagination = false;
|
|
217
|
+
// using settimeout to avoid the function call before getting the pagination response from api,
|
|
218
|
+
// because the api is called twice with the same page index
|
|
219
|
+
setTimeout(() => {
|
|
220
|
+
this.filter(this.currentFilter, resetpagination);
|
|
221
|
+
}, 800);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MyDiscussionComponent, deps: [{ token: i1.DiscussionService }, { token: i2.ConfigService }, { token: i3.Router }, { token: i4.TelemetryUtilsService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
225
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MyDiscussionComponent, selector: "lib-my-discussion", viewQueries: [{ propertyName: "elementView", first: true, predicate: ["scrollContainerHeight"], descendants: true }], ngImport: i0, template: "<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n\n<div class=\"profileCard\">\n <div class=\"profile-card-content\">\n <div class=\"profile-header-image\">\n <div class=\"box-text\">\n <span class=\"box-label\"></span>{{ data?.username | splitInitials }}\n </div>\n </div>\n <div>\n <div class=\"profile-label name\" [innerHTML]=\"data?.username\"></div>\n <div class=\"profile-label department\">{{ department }}</div>\n <div class=\"profile-label location\">{{ location }}</div>\n <div class=\"profile-label email\">{{ data?.email || data?.username }}</div>\n <ng-container>\n <div class=\"my-discuss-topics\">\n <div class=\"my-discuss-topics__content\">\n <div class=\"my-discuss-label\">\n <span class=\"number\">{{ data?.topiccount || 0 }}</span>\n Discussions\n </div>\n <div class=\"post-count-area my-discuss-label\">\n <span class=\"number\">{{ data?.postcount || 0 }}</span>\n Posts\n </div>\n </div>\n <div class=\"text-right\">\n <!-- Enable lated when other user can visit your profile -->\n <!-- <span class=\"noocoments\" mat-card-subtitle>Last online {{data?.lastonline | pipeRelativeTime}}</span> -->\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n</div>\n\n<ng-container>\n <div class=\"recent-tabs\">\n <div class=\"tabs-content\">\n <div class=\"tabs-filter\">\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n 'tabs-active': currentFilter === 'timestamp',\n 'ws-mat-accent-border font-medium': currentFilter !== 'timestamp'\n }\" (click)=\"filter('timestamp', true); logTelemetry($event)\" id=\"recent-post\">\n Recent posts\n </a>\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n 'tabs-active': currentFilter === 'best',\n 'ws-mat-accent-border font-medium': currentFilter !== 'best'\n }\" (click)=\"filter('best', true); logTelemetry($event)\" id=\"best-post\">\n Best posts\n </a>\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n 'tabs-active': currentFilter === 'saved',\n 'ws-mat-accent-border font-medium': currentFilter !== 'saved'\n }\" (click)=\"filter('saved', true); logTelemetry($event)\" id=\"saved-post\">\n Saved posts\n </a>\n <!-- <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option \" [ngClass]=\"{'ws-mat-accent-border-active' : currentFilter === 'watched',\n 'ws-mat-accent-border font-medium':currentFilter !== 'watched'}\" mat-button\n (click)=\"filter('watched')\">\n Watched </a> -->\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n 'tabs-active': currentFilter === 'upvoted',\n 'ws-mat-accent-border font-medium': currentFilter !== 'upvoted'\n }\" (click)=\"filter('upvoted', true); logTelemetry($event)\" id=\"upvoted-post\">\n Upvoted\n </a>\n\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n 'tabs-active': currentFilter === 'downvoted',\n 'ws-mat-accent-border font-medium': currentFilter !== 'downvoted'\n }\" (click)=\"filter('downvoted', true); logTelemetry($event)\" id=\"downvoted-post\">\n Downvoted\n </a>\n </div>\n </div>\n </div>\n</ng-container>\n\n<div *ngIf=\"discussionList && discussionList.length > 0\" class=\"topic-list-container\" id=\"topic-scroll\"\n #scrollContainerHeight>\n <!--infinite scroll-->\n <div [infiniteScrollContainer]=\"'.topic-list-container'\" infinite-scroll class=\"infinite-scroll\"\n [scrollWindow]=\"false\" [infiniteScrollDistance]=\"InfiniteScrollConfig.modalScrollDistance\" [fromRoot]=\"true\"\n [infiniteScrollThrottle]=\"InfiniteScrollConfig.modalScrollThrottle\" (scrolled)=\"onModalScrollDown()\">\n <ng-container *ngFor=\"let data of discussionList\">\n <div (click)=\"navigateToDiscussionDetails(data); logTelemetry($event)\" id=\"discuss-card\">\n <lib-discuss-card [discussionData]=\"data\"></lib-discuss-card>\n </div>\n </ng-container>\n </div>\n</div>\n\n<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n<ng-container *ngIf=\"!(discussionList && discussionList.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>", styles: ["::ng-deep:root{--df-box-text:var(--white);--df-profile-bg: var(--primary-400)}.profileCard{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}.profileCard .profile-card-content{display:flex;flex-wrap:wrap}.profileCard .profile-card-content .profile-header-image{display:flex;justify-content:center;align-items:center;width:100%;border-radius:.25rem;max-width:9.5rem;height:8.4375rem;border:.0625rem solid var(--gray-100);margin-right:1.5rem;background:var(--df-profile-bg);text-align:center}.profileCard .profile-card-content .profile-header-image .box-text{font-size:4rem;color:var(--df-box-text);text-transform:uppercase}.profileCard .profile-card-content .profile-header-image .box-text .box-label{color:var(--white);font-size:1rem;line-height:.75rem;letter-spacing:.2625px;text-transform:uppercase}.profileCard .profile-card-content .profile-label{font-weight:700;margin-bottom:.5rem;font-size:.875rem}.profileCard .profile-card-content .name{font-size:1rem}.profileCard .profile-card-content .my-discuss-topics{font-size:.875rem;margin:1rem 0;font-weight:600}.profileCard .profile-card-content .my-discuss-topics__content{display:flex}.profileCard .profile-card-content .my-discuss-topics__content .my-discussion-label{margin:0 .5rem}.profileCard .profile-card-content .my-discuss-topics__content .my-discussion-label .number{color:var(--primary-300)}.profileCard .profile-card-content .my-discuss-topics__content .post-count-area{margin-left:2rem}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.DiscussCardComponent, selector: "lib-discuss-card", inputs: ["discussionData"] }, { kind: "component", type: i7.AppLoaderComponent, selector: "lib-app-loader", inputs: ["data"] }, { kind: "directive", type: i8.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { kind: "pipe", type: i9.SplitInitialsPipe, name: "splitInitials" }] }); }
|
|
226
|
+
}
|
|
227
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MyDiscussionComponent, decorators: [{
|
|
228
|
+
type: Component,
|
|
229
|
+
args: [{ selector: 'lib-my-discussion', template: "<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n\n<div class=\"profileCard\">\n <div class=\"profile-card-content\">\n <div class=\"profile-header-image\">\n <div class=\"box-text\">\n <span class=\"box-label\"></span>{{ data?.username | splitInitials }}\n </div>\n </div>\n <div>\n <div class=\"profile-label name\" [innerHTML]=\"data?.username\"></div>\n <div class=\"profile-label department\">{{ department }}</div>\n <div class=\"profile-label location\">{{ location }}</div>\n <div class=\"profile-label email\">{{ data?.email || data?.username }}</div>\n <ng-container>\n <div class=\"my-discuss-topics\">\n <div class=\"my-discuss-topics__content\">\n <div class=\"my-discuss-label\">\n <span class=\"number\">{{ data?.topiccount || 0 }}</span>\n Discussions\n </div>\n <div class=\"post-count-area my-discuss-label\">\n <span class=\"number\">{{ data?.postcount || 0 }}</span>\n Posts\n </div>\n </div>\n <div class=\"text-right\">\n <!-- Enable lated when other user can visit your profile -->\n <!-- <span class=\"noocoments\" mat-card-subtitle>Last online {{data?.lastonline | pipeRelativeTime}}</span> -->\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n</div>\n\n<ng-container>\n <div class=\"recent-tabs\">\n <div class=\"tabs-content\">\n <div class=\"tabs-filter\">\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n 'tabs-active': currentFilter === 'timestamp',\n 'ws-mat-accent-border font-medium': currentFilter !== 'timestamp'\n }\" (click)=\"filter('timestamp', true); logTelemetry($event)\" id=\"recent-post\">\n Recent posts\n </a>\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n 'tabs-active': currentFilter === 'best',\n 'ws-mat-accent-border font-medium': currentFilter !== 'best'\n }\" (click)=\"filter('best', true); logTelemetry($event)\" id=\"best-post\">\n Best posts\n </a>\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n 'tabs-active': currentFilter === 'saved',\n 'ws-mat-accent-border font-medium': currentFilter !== 'saved'\n }\" (click)=\"filter('saved', true); logTelemetry($event)\" id=\"saved-post\">\n Saved posts\n </a>\n <!-- <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option \" [ngClass]=\"{'ws-mat-accent-border-active' : currentFilter === 'watched',\n 'ws-mat-accent-border font-medium':currentFilter !== 'watched'}\" mat-button\n (click)=\"filter('watched')\">\n Watched </a> -->\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n 'tabs-active': currentFilter === 'upvoted',\n 'ws-mat-accent-border font-medium': currentFilter !== 'upvoted'\n }\" (click)=\"filter('upvoted', true); logTelemetry($event)\" id=\"upvoted-post\">\n Upvoted\n </a>\n\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n 'tabs-active': currentFilter === 'downvoted',\n 'ws-mat-accent-border font-medium': currentFilter !== 'downvoted'\n }\" (click)=\"filter('downvoted', true); logTelemetry($event)\" id=\"downvoted-post\">\n Downvoted\n </a>\n </div>\n </div>\n </div>\n</ng-container>\n\n<div *ngIf=\"discussionList && discussionList.length > 0\" class=\"topic-list-container\" id=\"topic-scroll\"\n #scrollContainerHeight>\n <!--infinite scroll-->\n <div [infiniteScrollContainer]=\"'.topic-list-container'\" infinite-scroll class=\"infinite-scroll\"\n [scrollWindow]=\"false\" [infiniteScrollDistance]=\"InfiniteScrollConfig.modalScrollDistance\" [fromRoot]=\"true\"\n [infiniteScrollThrottle]=\"InfiniteScrollConfig.modalScrollThrottle\" (scrolled)=\"onModalScrollDown()\">\n <ng-container *ngFor=\"let data of discussionList\">\n <div (click)=\"navigateToDiscussionDetails(data); logTelemetry($event)\" id=\"discuss-card\">\n <lib-discuss-card [discussionData]=\"data\"></lib-discuss-card>\n </div>\n </ng-container>\n </div>\n</div>\n\n<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n<ng-container *ngIf=\"!(discussionList && discussionList.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>", styles: ["::ng-deep:root{--df-box-text:var(--white);--df-profile-bg: var(--primary-400)}.profileCard{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}.profileCard .profile-card-content{display:flex;flex-wrap:wrap}.profileCard .profile-card-content .profile-header-image{display:flex;justify-content:center;align-items:center;width:100%;border-radius:.25rem;max-width:9.5rem;height:8.4375rem;border:.0625rem solid var(--gray-100);margin-right:1.5rem;background:var(--df-profile-bg);text-align:center}.profileCard .profile-card-content .profile-header-image .box-text{font-size:4rem;color:var(--df-box-text);text-transform:uppercase}.profileCard .profile-card-content .profile-header-image .box-text .box-label{color:var(--white);font-size:1rem;line-height:.75rem;letter-spacing:.2625px;text-transform:uppercase}.profileCard .profile-card-content .profile-label{font-weight:700;margin-bottom:.5rem;font-size:.875rem}.profileCard .profile-card-content .name{font-size:1rem}.profileCard .profile-card-content .my-discuss-topics{font-size:.875rem;margin:1rem 0;font-weight:600}.profileCard .profile-card-content .my-discuss-topics__content{display:flex}.profileCard .profile-card-content .my-discuss-topics__content .my-discussion-label{margin:0 .5rem}.profileCard .profile-card-content .my-discuss-topics__content .my-discussion-label .number{color:var(--primary-300)}.profileCard .profile-card-content .my-discuss-topics__content .post-count-area{margin-left:2rem}\n"] }]
|
|
230
|
+
}], ctorParameters: function () { return [{ type: i1.DiscussionService }, { type: i2.ConfigService }, { type: i3.Router }, { type: i4.TelemetryUtilsService }]; }, propDecorators: { elementView: [{
|
|
231
|
+
type: ViewChild,
|
|
232
|
+
args: ['scrollContainerHeight']
|
|
233
|
+
}] } });
|
|
234
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"my-discussion.component.js","sourceRoot":"","sources":["../../../../../../projects/discussion-ui/src/lib/components/my-discussion/my-discussion.component.ts","../../../../../../projects/discussion-ui/src/lib/components/my-discussion/my-discussion.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DiscussionService } from './../../services/discussion.service';\nimport { Component, ElementRef, OnInit, ViewChild } from '@angular/core';\nimport { TelemetryUtilsService } from './../../telemetry-utils.service';\nimport { NSDiscussData } from './../../models/discuss.model';\nimport { Router } from '@angular/router';\nimport * as CONSTANTS from '../../common/constants.json';\n/* tslint:disable */\nimport * as _ from 'lodash'\nimport { ConfigService } from '../../services/config.service';\nimport { combineLatest } from 'rxjs';\n/* tslint:enable */\n\n@Component({\n  selector: 'lib-my-discussion',\n  templateUrl: './my-discussion.component.html',\n  styleUrls: ['./my-discussion.component.scss']\n})\nexport class MyDiscussionComponent implements OnInit {\n\n  @ViewChild('scrollContainerHeight') elementView: ElementRef;\n  data; // this is for user\n  discussionList = []; // this is for posts\n  currentFilter = 'timestamp';\n  department!: string | null;\n  location!: string | null;\n  profilePhoto!: string;\n  userInitial = '';\n  showLoader = false;\n  pagination = Object.create({});\n  recentFilter;\n\n  // Input parameters for infinite scroll\n  InfiniteScrollConfig = {\n    modalScrollDistance: 2,\n    modalScrollThrottle: 50\n  };\n\n  constructor(\n    private discussService: DiscussionService,\n    private configService: ConfigService,\n    public router: Router,\n    private telemetryUtils: TelemetryUtilsService) { }\n\n  /** To fetch user details */\n  fetchUserProfile(userName) {\n    this.discussService.fetchUserProfile(userName).subscribe(response => {\n      this.showLoader = false;\n      console.log(response);\n      this.data = response;\n      if (_.get(this.data, 'posts')) {\n        this.discussionList = _.get(this.data, 'posts').filter(p => (p.isMainPost === true));\n      }\n      // if (this.configSvc.userProfile) {\n      //   localStorage.setItem(this.configSvc.userProfile.userId, this.profilePhoto);\n      // }\n    }, error => {\n      this.showLoader = false;\n      // error code check\n      this.discussService.showTrafficAlert(error);\n      // TODO: Toaster\n      console.log('error fetching user details');\n    });\n  }\n\n  ngOnInit() {\n    this.telemetryUtils.setContext([]);\n    this.telemetryUtils.logImpression(NSDiscussData.IPageName.MY_DISCUSSION);\n    this.filter(this.currentFilter, false);\n  }\n\n  /**\n   * @description - set the scroll container height\n   */\n  ngAfterViewChecked() {\n    if (this.elementView && this.elementView.nativeElement && !this.elementView.nativeElement.style.height) {\n      // the number 10 is just a random value to reduce the height of the parent container to the infinite scroll\n      this.elementView.nativeElement.style.height = (this.elementView.nativeElement.clientHeight - 10) + 'px';\n    }\n  }\n  \n  /**\n   * @param  {string|'timestamp'|'best'|'saved'|'watched'|'upvoted'|'downvoted'} key\n   * @param  {boolean} resetpagination - its used to reset the pagination value based on the filter data\n   */\n  filter(key: string | 'timestamp' | 'best' | 'saved' | 'watched' | 'upvoted' | 'downvoted', resetpagination: boolean) {\n    this.currentFilter = key;\n    if (key) {\n      // reset the currentpage value to 1 and reset the discussionList data based on the respective api response when the filter is changed\n      if (resetpagination) {\n        this.discussionList = []\n        this.pagination.currentPage = 1;\n      }\n      // setting the current page index \n      const scrollIndex = this.pagination.currentPage ? this.pagination.currentPage : 1;\n      this.showLoader = true;\n      switch (key) {\n        case 'timestamp':\n          this.getRecentTopics(scrollIndex);\n          break;\n        case 'best':\n          // this.discussionList = _.uniqBy(this.data.bestPosts, 'tid');\n          this.discussService.fetchBestPost(scrollIndex).subscribe(result => {\n            if (result) {\n              const bestPost = result['posts'].filter(p => (p.isMainPost === true));\n              this.discussionList = [...this.discussionList, ...bestPost];\n              this.pagination = _.get(result, 'pagination');\n              this.showLoader = false;\n            } else {\n              this.showLoader = false;\n              this.discussionList = [];\n            }\n          }, error => {\n            // error code check\n            this.discussService.showTrafficAlert(error);\n          });\n          break;\n        case 'saved':\n          this.discussService.fetchSaved(scrollIndex).subscribe(response => {\n            if (response) {\n              // this.discussionList = _.uniqBy(response['posts'], 'tid');\n              this.discussionList = [...this.discussionList, ...response['posts']];\n              this.pagination = _.get(response, 'pagination');\n              this.showLoader = false;\n            } else {\n              this.showLoader = false;\n              this.discussionList = [];\n            }\n          },\n            // tslint:disable-next-line\n            (error) => {\n              // error code check\n              this.discussService.showTrafficAlert(error);\n              this.discussionList = [];\n            })\n          break;\n        case 'watched':\n          this.showLoader = false;\n          this.discussionList = [];\n          break;\n        case 'upvoted':\n          this.discussService.fetchUpvoted(scrollIndex).subscribe(response => {\n            if (response) {\n              // this.discussionList = _.uniqBy(response['posts'], 'tid');\n              const upvoted = response['posts'].filter(p => (p.isMainPost === true));\n              this.pagination = _.get(response, 'pagination');\n              this.discussionList = [...this.discussionList, ...upvoted];\n              this.showLoader = false;\n            } else {\n              this.showLoader = false;\n              this.discussionList = [];\n            }\n          },\n            // tslint:disable-next-line\n            (error) => {\n              this.discussionList = [];\n              // error code check\n              this.discussService.showTrafficAlert(error);\n            });\n\n          break;\n        case 'downvoted':\n          this.discussService.fetchDownvoted(scrollIndex).subscribe(response => {\n            if (response) {\n              // this.discussionList = _.uniqBy(response['posts'], 'tid');\n              const downvoted = response['posts'].filter(p => (p.isMainPost === true));\n              this.discussionList = [...this.discussionList, ...downvoted];\n              this.pagination = _.get(response, 'pagination');\n              this.showLoader = false;\n            } else {\n              this.showLoader = false;\n              this.discussionList = [];\n            }\n          },\n            // tslint:disable-next-line\n            (error) => {\n              this.discussionList = [];\n              // error code check\n              this.discussService.showTrafficAlert(error);\n            });\n          break;\n        default:\n          // this.discussionList = _.uniqBy(this.data.latestPosts, 'tid');\n          this.pagination = _.get(this.data, 'pagination');\n          this.discussionList = _.get(this.data, 'latestPosts');\n          break;\n      }\n    }\n  }\n\n  navigateToDiscussionDetails(discussionData) {\n    console.log('discussionData', discussionData);\n    const slug = _.get(discussionData, 'slug') || _.get(discussionData, 'topic.slug')\n    this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TOPIC}${slug}`]);\n  }\n\n  logTelemetry(event) {\n    this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.MY_DISCUSSION);\n  }\n\n  /**\n   * @description - getting the recent post data\n   * @param  {number} scrollIndex\n   */\n  getRecentTopics(scrollIndex: number) {\n    const userId = this.discussService.userId;\n    // const userSlug = this.discussService.userDetails.userslug;\n    combineLatest([\n      this.discussService.fetchUserProfile(userId),\n      this.discussService.fetchRecentPost(scrollIndex)\n    ]).subscribe(result => {\n      console.log('getRecentTopics', result)\n      this.showLoader = false;\n      this.data = _.merge(result[0], result[1]);\n      this.discussionList = [...this.discussionList, ...(_.get(this.data, 'posts'))];\n      this.discussionList = this.discussionList.filter(p => (p.isMainPost === true));\n      this.pagination = _.get(this.data, 'pagination');\n    }, error => {\n      this.showLoader = false;\n      console.log(error);\n    });\n  }\n  \n  /**\n   * @description - call the topic get api when scrolled down and setting the limit of API Call\n   */\n  onModalScrollDown() {\n    if (this.pagination.currentPage !== this.pagination.pageCount) {\n        this.pagination.currentPage = this.pagination.next.page;\n        const resetpagination = false;\n        // using settimeout to avoid the function call before getting the pagination response from api, \n        // because the api is called twice with the same page index\n        setTimeout(() => {\n          this.filter(this.currentFilter, resetpagination)\n        }, 800); \n    }\n  }\n}\n","<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n\n<div class=\"profileCard\">\n  <div class=\"profile-card-content\">\n    <div class=\"profile-header-image\">\n      <div class=\"box-text\">\n        <span class=\"box-label\"></span>{{ data?.username | splitInitials }}\n      </div>\n    </div>\n    <div>\n      <div class=\"profile-label name\" [innerHTML]=\"data?.username\"></div>\n      <div class=\"profile-label department\">{{ department }}</div>\n      <div class=\"profile-label location\">{{ location }}</div>\n      <div class=\"profile-label email\">{{ data?.email || data?.username }}</div>\n      <ng-container>\n        <div class=\"my-discuss-topics\">\n          <div class=\"my-discuss-topics__content\">\n            <div class=\"my-discuss-label\">\n              <span class=\"number\">{{ data?.topiccount || 0 }}</span>\n              Discussions\n            </div>\n            <div class=\"post-count-area my-discuss-label\">\n              <span class=\"number\">{{ data?.postcount || 0 }}</span>\n              Posts\n            </div>\n          </div>\n          <div class=\"text-right\">\n            <!-- Enable lated when other user can visit your profile -->\n            <!-- <span class=\"noocoments\" mat-card-subtitle>Last online {{data?.lastonline | pipeRelativeTime}}</span> -->\n          </div>\n        </div>\n      </ng-container>\n    </div>\n  </div>\n</div>\n\n<ng-container>\n  <div class=\"recent-tabs\">\n    <div class=\"tabs-content\">\n      <div class=\"tabs-filter\">\n        <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n            'tabs-active': currentFilter === 'timestamp',\n            'ws-mat-accent-border font-medium': currentFilter !== 'timestamp'\n          }\" (click)=\"filter('timestamp', true); logTelemetry($event)\" id=\"recent-post\">\n          Recent posts\n        </a>\n        <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n            'tabs-active': currentFilter === 'best',\n            'ws-mat-accent-border font-medium': currentFilter !== 'best'\n          }\" (click)=\"filter('best', true); logTelemetry($event)\" id=\"best-post\">\n          Best posts\n        </a>\n        <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n            'tabs-active': currentFilter === 'saved',\n            'ws-mat-accent-border font-medium': currentFilter !== 'saved'\n          }\" (click)=\"filter('saved', true); logTelemetry($event)\" id=\"saved-post\">\n          Saved posts\n        </a>\n        <!-- <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option \" [ngClass]=\"{'ws-mat-accent-border-active' : currentFilter === 'watched',\n                                            'ws-mat-accent-border font-medium':currentFilter !== 'watched'}\" mat-button\n            (click)=\"filter('watched')\">\n            Watched </a> -->\n        <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n            'tabs-active': currentFilter === 'upvoted',\n            'ws-mat-accent-border font-medium': currentFilter !== 'upvoted'\n          }\" (click)=\"filter('upvoted', true); logTelemetry($event)\" id=\"upvoted-post\">\n          Upvoted\n        </a>\n\n        <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{\n            'tabs-active': currentFilter === 'downvoted',\n            'ws-mat-accent-border font-medium': currentFilter !== 'downvoted'\n          }\" (click)=\"filter('downvoted', true); logTelemetry($event)\" id=\"downvoted-post\">\n          Downvoted\n        </a>\n      </div>\n    </div>\n  </div>\n</ng-container>\n\n<div *ngIf=\"discussionList && discussionList.length > 0\" class=\"topic-list-container\" id=\"topic-scroll\"\n  #scrollContainerHeight>\n  <!--infinite scroll-->\n  <div [infiniteScrollContainer]=\"'.topic-list-container'\" infinite-scroll class=\"infinite-scroll\"\n    [scrollWindow]=\"false\" [infiniteScrollDistance]=\"InfiniteScrollConfig.modalScrollDistance\" [fromRoot]=\"true\"\n    [infiniteScrollThrottle]=\"InfiniteScrollConfig.modalScrollThrottle\" (scrolled)=\"onModalScrollDown()\">\n    <ng-container *ngFor=\"let data of discussionList\">\n      <div (click)=\"navigateToDiscussionDetails(data); logTelemetry($event)\" id=\"discuss-card\">\n        <lib-discuss-card [discussionData]=\"data\"></lib-discuss-card>\n      </div>\n    </ng-container>\n  </div>\n</div>\n\n<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n<ng-container *ngIf=\"!(discussionList && discussionList.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>"]}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { NSDiscussData } from './../../models/discuss.model';
|
|
2
|
+
import { Component } from '@angular/core';
|
|
3
|
+
import * as CONSTANTS from './../../common/constants.json';
|
|
4
|
+
/* tslint:disable */
|
|
5
|
+
import * as _ from 'lodash';
|
|
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 "./../../telemetry-utils.service";
|
|
10
|
+
import * as i4 from "../../services/config.service";
|
|
11
|
+
import * as i5 from "@angular/common";
|
|
12
|
+
/* tslint:enable */
|
|
13
|
+
export class SidePannelComponent {
|
|
14
|
+
constructor(router, discussService, activatedRoute, telemetryUtils, configService) {
|
|
15
|
+
this.router = router;
|
|
16
|
+
this.discussService = discussService;
|
|
17
|
+
this.activatedRoute = activatedRoute;
|
|
18
|
+
this.telemetryUtils = telemetryUtils;
|
|
19
|
+
this.configService = configService;
|
|
20
|
+
this.defaultPage = 'categories';
|
|
21
|
+
this.menu = [];
|
|
22
|
+
this.showSideMenu = true;
|
|
23
|
+
}
|
|
24
|
+
ngOnInit() {
|
|
25
|
+
// TODO: loader or spinner
|
|
26
|
+
this.telemetryUtils.setContext([]);
|
|
27
|
+
this.hideSidePanel = document.body.classList.contains('widget');
|
|
28
|
+
this.telemetryUtils.logImpression(NSDiscussData.IPageName.HOME);
|
|
29
|
+
this.data = this.configService.getConfig();
|
|
30
|
+
const menuArr = _.get(this.data, 'menuOptions') && _.get(this.data, 'menuOptions').length > 0
|
|
31
|
+
? this.data.menuOptions : CONSTANTS.MENUOPTIONS;
|
|
32
|
+
// })
|
|
33
|
+
for (let i = 0; i < menuArr.length; i++) {
|
|
34
|
+
if (menuArr[i].enable) {
|
|
35
|
+
this.menu.push(menuArr[i]);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
isActive(selectedItem) {
|
|
40
|
+
this.landingPage = this.data.defaultLandingPage ? this.data.defaultLandingPage : 'categories';
|
|
41
|
+
if (this.router.url.indexOf(`/${selectedItem}`) > -1 || this.selectedTab === selectedItem) {
|
|
42
|
+
if (!this.selectedTab) {
|
|
43
|
+
this.selectedTab = selectedItem;
|
|
44
|
+
}
|
|
45
|
+
return true;
|
|
46
|
+
}
|
|
47
|
+
else if (selectedItem === this.landingPage && !this.selectedTab) {
|
|
48
|
+
return true;
|
|
49
|
+
}
|
|
50
|
+
return false;
|
|
51
|
+
}
|
|
52
|
+
navigate(pageName, event) {
|
|
53
|
+
this.selectedTab = pageName;
|
|
54
|
+
this.telemetryUtils.setContext([]);
|
|
55
|
+
if (event) {
|
|
56
|
+
this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.HOME);
|
|
57
|
+
}
|
|
58
|
+
this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.DISCUSSION}${pageName}`], { queryParamsHandling: "merge" });
|
|
59
|
+
this.closeNav();
|
|
60
|
+
}
|
|
61
|
+
ngOnDestroy() {
|
|
62
|
+
if (this.paramsSubscription) {
|
|
63
|
+
this.paramsSubscription.unsubscribe();
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
showMenuButton() {
|
|
67
|
+
this.showSideMenu = this.showSideMenu ? false : true;
|
|
68
|
+
}
|
|
69
|
+
closeNav() {
|
|
70
|
+
this.showSideMenu = this.showSideMenu ? false : true;
|
|
71
|
+
}
|
|
72
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SidePannelComponent, deps: [{ token: i1.Router }, { token: i2.DiscussionService }, { token: i1.ActivatedRoute }, { token: i3.TelemetryUtilsService }, { token: i4.ConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
73
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SidePannelComponent, selector: "lib-side-pannel", ngImport: i0, template: "<ul class=\"sb-sidebar-menu pl-0\" *ngIf=\"!hideSidePanel\">\n <!-- <li class=\"df-sidebar-menu-list\" *ngIf=\"false\" (click)=\"navigate('home', $event)\" id=\"all-discussions\"><a>All discussions</a></li> -->\n <li *ngFor='let d of menu' class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': isActive(d.route)}\"\n (click)=\"navigate(d.route, $event)\" id=\"d.route\"><a>{{d.label}}</a></li>\n <!-- <li class=\"df-sidebar-menu-list\" id=\"leader-board\"><a>Leaderboard</a></li> -->\n</ul>\n\n<!-- for mobile-view -->\n<button type=\"button\" class=\"open-btn\" (click)=\"showMenuButton()\">\u2630</button> \n<div class=\"overlay-sidebar\" *ngIf=\"!showSideMenu\">\n <div class=\"overlay-sidebar__menu\">\n <a href=\"javascript:void(0)\" class=\"close-btn\" (click)=\"closeNav()\">×</a>\n <div class=\"overlay-sidebar__menu__content\">\n <ul class=\"sb-sidebar-menu-mob pl-0\">\n <li *ngFor='let d of menu' class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': isActive(d.route)}\"\n (click)=\"navigate(d.route, $event)\" id=\"d.route\"><a>{{d.label}}</a></li>\n <!-- <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" *ngIf=\"false\" (click)=\"navigate('home', $event)\" id=\"all-discussions\"><a>All discussions</a></li>\n <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': selectedTab === 'categories'}\" (click)=\"navigate('categories', $event)\" id=\"discussion-categories\"><a>Categories</a></li>\n <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\"[ngClass]=\"{'menu-active': selectedTab === 'tags'}\" (click)=\"navigate('tags', $event)\" id=\"discussion-tags\"><a>Tags</a></li>\n <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': selectedTab === 'my-discussion'}\" (click)=\"navigate('my-discussion', $event)\" id=\"my-discussion\"><a>My discussions</a></li> -->\n </ul>\n </div>\n </div>\n</div>", styles: ["::ng-deep:root{--df-sidebar-menu-text: var(--gray-600);--df-sidebar-menu-active-text: var(--primary);--df-sidebar-menu-bl:var(--primary);--df-sidebar-menu-active-bg: var(--df-common-bg);--open-btn-bg: var(--white);--open-btn-color: var(--gray-800);--df-overlay-sidebar-bg:var(--black);--df-overlay-sidebar-bg-menu:#f5f6fa}.sb-sidebar-menu{list-style-type:none;margin-bottom:0;height:100%;display:inline}.df-sidebar-menu-list{margin-bottom:.5rem;padding:.75rem 1rem;font-size:14px;color:var(--df-sidebar-menu-text);border-left:.125rem solid transparent;cursor:pointer}.df-sidebar-menu-list.menu-active,.df-sidebar-menu-list:hover{background-color:var(--df-sidebar-menu-active-bg);font-weight:700;border-left:.1875rem solid var(--df-sidebar-menu-bl);color:var(--df-sidebar-menu-active-text);border-bottom:0px}.sb-sidebar-menu-mob{list-style-type:none;margin-bottom:0;height:100%;display:inline}.open-btn,.overlay-sidebar{display:none}@media (max-width: 768px){.sb-sidebar-menu{display:none}.open-btn{display:inline;border:none;cursor:pointer;height:2.5rem;width:2.5rem;border-radius:1rem;font-size:1.375rem;background-color:var(--open-btn-bg);box-shadow:3px 3px 2px #0000001a;color:var(--open-btn-color)}.overlay-sidebar{height:100vh;width:100%;overflow:hidden;background:#0006;inset:0;position:absolute;display:inline;z-index:3;transition-duration:.4s;transition-timing-function:cubic-bezier(.25,.8,.25,1);transition-property:background-color,visibility}.overlay-sidebar__menu{position:relative;top:0;height:100%;width:15rem;right:0;z-index:100000;overflow-y:auto;overflow-x:hidden;background-color:var(--df-overlay-sidebar-bg-menu);box-shadow:0 8px 10px -5px #0003,0 16px 24px 2px #00000024,0 6px 30px 5px #000}.overlay-sidebar__menu .close-btn{font-size:2.5rem;display:flex;justify-content:flex-end;padding-right:1rem;cursor:pointer}.overlay-sidebar__menu__content{padding:0 1rem;height:100%}}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
74
|
+
}
|
|
75
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SidePannelComponent, decorators: [{
|
|
76
|
+
type: Component,
|
|
77
|
+
args: [{ selector: 'lib-side-pannel', template: "<ul class=\"sb-sidebar-menu pl-0\" *ngIf=\"!hideSidePanel\">\n <!-- <li class=\"df-sidebar-menu-list\" *ngIf=\"false\" (click)=\"navigate('home', $event)\" id=\"all-discussions\"><a>All discussions</a></li> -->\n <li *ngFor='let d of menu' class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': isActive(d.route)}\"\n (click)=\"navigate(d.route, $event)\" id=\"d.route\"><a>{{d.label}}</a></li>\n <!-- <li class=\"df-sidebar-menu-list\" id=\"leader-board\"><a>Leaderboard</a></li> -->\n</ul>\n\n<!-- for mobile-view -->\n<button type=\"button\" class=\"open-btn\" (click)=\"showMenuButton()\">\u2630</button> \n<div class=\"overlay-sidebar\" *ngIf=\"!showSideMenu\">\n <div class=\"overlay-sidebar__menu\">\n <a href=\"javascript:void(0)\" class=\"close-btn\" (click)=\"closeNav()\">×</a>\n <div class=\"overlay-sidebar__menu__content\">\n <ul class=\"sb-sidebar-menu-mob pl-0\">\n <li *ngFor='let d of menu' class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': isActive(d.route)}\"\n (click)=\"navigate(d.route, $event)\" id=\"d.route\"><a>{{d.label}}</a></li>\n <!-- <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" *ngIf=\"false\" (click)=\"navigate('home', $event)\" id=\"all-discussions\"><a>All discussions</a></li>\n <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': selectedTab === 'categories'}\" (click)=\"navigate('categories', $event)\" id=\"discussion-categories\"><a>Categories</a></li>\n <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\"[ngClass]=\"{'menu-active': selectedTab === 'tags'}\" (click)=\"navigate('tags', $event)\" id=\"discussion-tags\"><a>Tags</a></li>\n <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': selectedTab === 'my-discussion'}\" (click)=\"navigate('my-discussion', $event)\" id=\"my-discussion\"><a>My discussions</a></li> -->\n </ul>\n </div>\n </div>\n</div>", styles: ["::ng-deep:root{--df-sidebar-menu-text: var(--gray-600);--df-sidebar-menu-active-text: var(--primary);--df-sidebar-menu-bl:var(--primary);--df-sidebar-menu-active-bg: var(--df-common-bg);--open-btn-bg: var(--white);--open-btn-color: var(--gray-800);--df-overlay-sidebar-bg:var(--black);--df-overlay-sidebar-bg-menu:#f5f6fa}.sb-sidebar-menu{list-style-type:none;margin-bottom:0;height:100%;display:inline}.df-sidebar-menu-list{margin-bottom:.5rem;padding:.75rem 1rem;font-size:14px;color:var(--df-sidebar-menu-text);border-left:.125rem solid transparent;cursor:pointer}.df-sidebar-menu-list.menu-active,.df-sidebar-menu-list:hover{background-color:var(--df-sidebar-menu-active-bg);font-weight:700;border-left:.1875rem solid var(--df-sidebar-menu-bl);color:var(--df-sidebar-menu-active-text);border-bottom:0px}.sb-sidebar-menu-mob{list-style-type:none;margin-bottom:0;height:100%;display:inline}.open-btn,.overlay-sidebar{display:none}@media (max-width: 768px){.sb-sidebar-menu{display:none}.open-btn{display:inline;border:none;cursor:pointer;height:2.5rem;width:2.5rem;border-radius:1rem;font-size:1.375rem;background-color:var(--open-btn-bg);box-shadow:3px 3px 2px #0000001a;color:var(--open-btn-color)}.overlay-sidebar{height:100vh;width:100%;overflow:hidden;background:#0006;inset:0;position:absolute;display:inline;z-index:3;transition-duration:.4s;transition-timing-function:cubic-bezier(.25,.8,.25,1);transition-property:background-color,visibility}.overlay-sidebar__menu{position:relative;top:0;height:100%;width:15rem;right:0;z-index:100000;overflow-y:auto;overflow-x:hidden;background-color:var(--df-overlay-sidebar-bg-menu);box-shadow:0 8px 10px -5px #0003,0 16px 24px 2px #00000024,0 6px 30px 5px #000}.overlay-sidebar__menu .close-btn{font-size:2.5rem;display:flex;justify-content:flex-end;padding-right:1rem;cursor:pointer}.overlay-sidebar__menu__content{padding:0 1rem;height:100%}}\n"] }]
|
|
78
|
+
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.DiscussionService }, { type: i1.ActivatedRoute }, { type: i3.TelemetryUtilsService }, { type: i4.ConfigService }]; } });
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-pannel.component.js","sourceRoot":"","sources":["../../../../../../projects/discussion-ui/src/lib/components/side-pannel/side-pannel.component.ts","../../../../../../projects/discussion-ui/src/lib/components/side-pannel/side-pannel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NSDiscussData } from './../../models/discuss.model';\nimport { TelemetryUtilsService } from './../../telemetry-utils.service';\nimport { DiscussionService } from './../../services/discussion.service';\nimport { Component, OnInit, OnDestroy } from '@angular/core';\nimport { Router, ActivatedRoute } from '@angular/router';\nimport { Subscription } from 'rxjs';\nimport * as CONSTANTS from './../../common/constants.json';\n\n/* tslint:disable */\nimport * as _ from 'lodash'\nimport { first } from 'rxjs/operators';\nimport { ConfigService } from '../../services/config.service';\nimport { IdiscussionConfig, IMenuOptions } from '../../models/discussion-config.model';\n/* tslint:enable */\n\n@Component({\n  selector: 'lib-side-pannel',\n  templateUrl: './side-pannel.component.html',\n  styleUrls: ['./side-pannel.component.scss']\n})\nexport class SidePannelComponent implements OnInit, OnDestroy {\n\n  paramsSubscription: Subscription;\n\n  userName: string;\n\n  defaultPage = 'categories';\n\n  data: IdiscussionConfig;\n  hideSidePanel: boolean;\n  menu: Array<IMenuOptions> = [];\n  selectedTab: string;\n  showSideMenu: Boolean = true;\n  landingPage: string\n\n  constructor(\n    public router: Router,\n    public discussService: DiscussionService,\n    public activatedRoute: ActivatedRoute,\n    private telemetryUtils: TelemetryUtilsService,\n    private configService: ConfigService\n  ) { }\n\n  ngOnInit() {\n    // TODO: loader or spinner\n    this.telemetryUtils.setContext([]);\n    this.hideSidePanel = document.body.classList.contains('widget');\n    this.telemetryUtils.logImpression(NSDiscussData.IPageName.HOME);\n    this.data = this.configService.getConfig();\n    const menuArr = _.get(this.data, 'menuOptions') && _.get(this.data, 'menuOptions').length > 0\n      ? this.data.menuOptions : CONSTANTS.MENUOPTIONS;\n    // })\n    for (let i = 0; i < menuArr.length; i++) {\n      if (menuArr[i].enable) {\n        this.menu.push(menuArr[i]);\n      }\n    }\n\n  }\n\n  isActive(selectedItem) {\n    this.landingPage = this.data.defaultLandingPage ? this.data.defaultLandingPage : 'categories'\n    if (this.router.url.indexOf(`/${selectedItem}`) > -1 || this.selectedTab === selectedItem) {\n      if (!this.selectedTab) {\n        this.selectedTab = selectedItem\n      }\n      return true\n    } else if (selectedItem === this.landingPage && !this.selectedTab) {\n      return true\n    }\n    return false\n  }\n\n  navigate(pageName: string, event?) {\n    this.selectedTab = pageName;\n    this.telemetryUtils.setContext([]);\n    if (event) {\n      this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.HOME);\n    }\n    this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.DISCUSSION}${pageName}`], { queryParamsHandling: \"merge\" });\n    this.closeNav();\n  }\n\n  ngOnDestroy() {\n    if (this.paramsSubscription) {\n      this.paramsSubscription.unsubscribe();\n    }\n  }\n\n  showMenuButton() {\n    this.showSideMenu = this.showSideMenu ? false : true;\n  }\n\n  closeNav() {\n    this.showSideMenu = this.showSideMenu ? false : true;\n  }\n\n}\n","<ul class=\"sb-sidebar-menu pl-0\" *ngIf=\"!hideSidePanel\">\n  <!-- <li class=\"df-sidebar-menu-list\" *ngIf=\"false\" (click)=\"navigate('home', $event)\" id=\"all-discussions\"><a>All discussions</a></li> -->\n  <li *ngFor='let d of menu' class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': isActive(d.route)}\"\n    (click)=\"navigate(d.route, $event)\" id=\"d.route\"><a>{{d.label}}</a></li>\n    <!-- <li class=\"df-sidebar-menu-list\" id=\"leader-board\"><a>Leaderboard</a></li> -->\n</ul>\n\n<!-- for mobile-view -->\n<button type=\"button\" class=\"open-btn\" (click)=\"showMenuButton()\">☰</button> \n<div class=\"overlay-sidebar\" *ngIf=\"!showSideMenu\">\n  <div class=\"overlay-sidebar__menu\">\n      <a href=\"javascript:void(0)\" class=\"close-btn\" (click)=\"closeNav()\">&times;</a>\n      <div class=\"overlay-sidebar__menu__content\">\n        <ul class=\"sb-sidebar-menu-mob pl-0\">\n          <li *ngFor='let d of menu' class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': isActive(d.route)}\"\n          (click)=\"navigate(d.route, $event)\" id=\"d.route\"><a>{{d.label}}</a></li>\n          <!-- <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" *ngIf=\"false\" (click)=\"navigate('home', $event)\" id=\"all-discussions\"><a>All discussions</a></li>\n          <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': selectedTab === 'categories'}\" (click)=\"navigate('categories', $event)\" id=\"discussion-categories\"><a>Categories</a></li>\n          <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\"[ngClass]=\"{'menu-active': selectedTab === 'tags'}\" (click)=\"navigate('tags', $event)\" id=\"discussion-tags\"><a>Tags</a></li>\n          <li class=\"df-sidebar-menu-list\" tabindex=\"0\" role=\"link\" [ngClass]=\"{'menu-active': selectedTab === 'my-discussion'}\" (click)=\"navigate('my-discussion', $event)\" id=\"my-discussion\"><a>My discussions</a></li> -->\n      </ul>\n      </div>\n  </div>\n</div>"]}
|