@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.
Files changed (174) hide show
  1. package/README.md +24 -0
  2. package/assets/images/Buffer-512.webp +0 -0
  3. package/assets/images/announcement.svg +25 -0
  4. package/assets/images/back-img.png +0 -0
  5. package/assets/images/bookmarks.png +0 -0
  6. package/assets/images/card-icon.png +0 -0
  7. package/assets/images/close.png +0 -0
  8. package/assets/images/delete.svg +13 -0
  9. package/assets/images/down-arrow.png +0 -0
  10. package/assets/images/down-chevron.png +0 -0
  11. package/assets/images/down.svg +12 -0
  12. package/assets/images/edit.svg +11 -0
  13. package/assets/images/empty.svg +37 -0
  14. package/assets/images/eye-icon.png +0 -0
  15. package/assets/images/general discussion.svg +15 -0
  16. package/assets/images/import-export-arrows.png +0 -0
  17. package/assets/images/loader-icon.svg +6 -0
  18. package/assets/images/profits.png +0 -0
  19. package/assets/images/search-icon.png +0 -0
  20. package/assets/images/select-bookmarks.png +0 -0
  21. package/assets/images/select-down-arrow.png +0 -0
  22. package/assets/images/select-profits.png +0 -0
  23. package/assets/images/select-up-arrow.png +0 -0
  24. package/assets/images/up-arrow.png +0 -0
  25. package/assets/images/up-chevron.png +0 -0
  26. package/assets/images/up.svg +12 -0
  27. package/assets/images/views.svg +9 -0
  28. package/assets/images/votes.svg +14 -0
  29. package/assets/styles/global.scss +283 -0
  30. package/esm2022/jeraldj-discussions-ui.mjs +5 -0
  31. package/esm2022/lib/common/constants.json +630 -0
  32. package/esm2022/lib/components/components.module.mjs +105 -0
  33. package/esm2022/lib/components/discuss-all/discuss-all.component.mjs +269 -0
  34. package/esm2022/lib/components/discuss-category/discuss-category.component.mjs +152 -0
  35. package/esm2022/lib/components/discuss-home/discuss-home.component.mjs +142 -0
  36. package/esm2022/lib/components/discuss-start/discuss-start.component.mjs +199 -0
  37. package/esm2022/lib/components/discuss-tags/discuss-tags.component.mjs +93 -0
  38. package/esm2022/lib/components/discussion-details/discussion-details.component.mjs +459 -0
  39. package/esm2022/lib/components/lib-entry/lib-entry.component.mjs +96 -0
  40. package/esm2022/lib/components/my-discussion/my-discussion.component.mjs +234 -0
  41. package/esm2022/lib/components/side-pannel/side-pannel.component.mjs +79 -0
  42. package/esm2022/lib/components/tag-all-discussion/tag-all-discussion.component.mjs +151 -0
  43. package/esm2022/lib/components/trending-tags/trending-tags.component.mjs +62 -0
  44. package/esm2022/lib/config/url.config.mjs +32 -0
  45. package/esm2022/lib/discussion-events.service.mjs +27 -0
  46. package/esm2022/lib/discussion-routing/discussion-routing.module.mjs +80 -0
  47. package/esm2022/lib/discussion-ui.module.mjs +41 -0
  48. package/esm2022/lib/elements/app-loader/app-loader.component.mjs +36 -0
  49. package/esm2022/lib/elements/avatar-photo/avatar-photo.component.mjs +81 -0
  50. package/esm2022/lib/elements/category-card/category-card.component.mjs +17 -0
  51. package/esm2022/lib/elements/discuss-card/discuss-card.component.mjs +45 -0
  52. package/esm2022/lib/elements/elements.module.mjs +69 -0
  53. package/esm2022/lib/elements/load-alert/load-alert.component.mjs +34 -0
  54. package/esm2022/lib/elements/post-reply/post-reply.component.mjs +69 -0
  55. package/esm2022/lib/elements/related-discussion/related-discussion.component.mjs +61 -0
  56. package/esm2022/lib/elements/sliders/sliders.component.mjs +76 -0
  57. package/esm2022/lib/events.service.mjs +31 -0
  58. package/esm2022/lib/models/discuss.model.mjs +16 -0
  59. package/esm2022/lib/models/discussion-config.model.mjs +2 -0
  60. package/esm2022/lib/navigation-service.service.mjs +39 -0
  61. package/esm2022/lib/pipes/pipe-filter/pipe-filter.pipe.mjs +20 -0
  62. package/esm2022/lib/pipes/pipe-list-filter/pipe-list-filter.pipe.mjs +22 -0
  63. package/esm2022/lib/pipes/pipe-relative-time/pipe-relative-time.pipe.mjs +41 -0
  64. package/esm2022/lib/pipes/pipes.module.mjs +24 -0
  65. package/esm2022/lib/pipes/sort-by/sort-by.pipe.mjs +34 -0
  66. package/esm2022/lib/pipes/split-initials/split-initials.pipe.mjs +23 -0
  67. package/esm2022/lib/router-service.service.mjs +21 -0
  68. package/esm2022/lib/services/abstract-config.service.mjs +3 -0
  69. package/esm2022/lib/services/config.service.mjs +76 -0
  70. package/esm2022/lib/services/discuss-utils.service.mjs +36 -0
  71. package/esm2022/lib/services/discussion.service.mjs +254 -0
  72. package/esm2022/lib/telemetry-utils.service.mjs +103 -0
  73. package/esm2022/lib/wrapper/base-wrapper/base-wrapper.component.mjs +41 -0
  74. package/esm2022/lib/wrapper/category-widget/category-widget.component.mjs +37 -0
  75. package/esm2022/lib/wrapper/tags-widget/tags-widget.component.mjs +33 -0
  76. package/esm2022/lib/wrapper-navigate.service.mjs +23 -0
  77. package/esm2022/public-api.mjs +29 -0
  78. package/fesm2022/jeraldj-discussions-ui.mjs +3929 -0
  79. package/fesm2022/jeraldj-discussions-ui.mjs.map +1 -0
  80. package/index.d.ts +6 -0
  81. package/jeraldj-discussions-ui.d.ts.map +1 -0
  82. package/lib/components/components.module.d.ts +24 -0
  83. package/lib/components/components.module.d.ts.map +1 -0
  84. package/lib/components/discuss-all/discuss-all.component.d.ts +61 -0
  85. package/lib/components/discuss-all/discuss-all.component.d.ts.map +1 -0
  86. package/lib/components/discuss-category/discuss-category.component.d.ts +45 -0
  87. package/lib/components/discuss-category/discuss-category.component.d.ts.map +1 -0
  88. package/lib/components/discuss-home/discuss-home.component.d.ts +59 -0
  89. package/lib/components/discuss-home/discuss-home.component.d.ts.map +1 -0
  90. package/lib/components/discuss-start/discuss-start.component.d.ts +50 -0
  91. package/lib/components/discuss-start/discuss-start.component.d.ts.map +1 -0
  92. package/lib/components/discuss-tags/discuss-tags.component.d.ts +41 -0
  93. package/lib/components/discuss-tags/discuss-tags.component.d.ts.map +1 -0
  94. package/lib/components/discussion-details/discussion-details.component.d.ts +112 -0
  95. package/lib/components/discussion-details/discussion-details.component.d.ts.map +1 -0
  96. package/lib/components/lib-entry/lib-entry.component.d.ts +42 -0
  97. package/lib/components/lib-entry/lib-entry.component.d.ts.map +1 -0
  98. package/lib/components/my-discussion/my-discussion.component.d.ts +54 -0
  99. package/lib/components/my-discussion/my-discussion.component.d.ts.map +1 -0
  100. package/lib/components/side-pannel/side-pannel.component.d.ts +34 -0
  101. package/lib/components/side-pannel/side-pannel.component.d.ts.map +1 -0
  102. package/lib/components/tag-all-discussion/tag-all-discussion.component.d.ts +53 -0
  103. package/lib/components/tag-all-discussion/tag-all-discussion.component.d.ts.map +1 -0
  104. package/lib/components/trending-tags/trending-tags.component.d.ts +26 -0
  105. package/lib/components/trending-tags/trending-tags.component.d.ts.map +1 -0
  106. package/lib/config/url.config.d.ts +29 -0
  107. package/lib/config/url.config.d.ts.map +1 -0
  108. package/lib/discussion-events.service.d.ts +12 -0
  109. package/lib/discussion-events.service.d.ts.map +1 -0
  110. package/lib/discussion-routing/discussion-routing.module.d.ts +9 -0
  111. package/lib/discussion-routing/discussion-routing.module.d.ts.map +1 -0
  112. package/lib/discussion-ui.module.d.ts +16 -0
  113. package/lib/discussion-ui.module.d.ts.map +1 -0
  114. package/lib/elements/app-loader/app-loader.component.d.ts +17 -0
  115. package/lib/elements/app-loader/app-loader.component.d.ts.map +1 -0
  116. package/lib/elements/avatar-photo/avatar-photo.component.d.ts +19 -0
  117. package/lib/elements/avatar-photo/avatar-photo.component.d.ts.map +1 -0
  118. package/lib/elements/category-card/category-card.component.d.ts +10 -0
  119. package/lib/elements/category-card/category-card.component.d.ts.map +1 -0
  120. package/lib/elements/discuss-card/discuss-card.component.d.ts +17 -0
  121. package/lib/elements/discuss-card/discuss-card.component.d.ts.map +1 -0
  122. package/lib/elements/elements.module.d.ts +18 -0
  123. package/lib/elements/elements.module.d.ts.map +1 -0
  124. package/lib/elements/load-alert/load-alert.component.d.ts +15 -0
  125. package/lib/elements/load-alert/load-alert.component.d.ts.map +1 -0
  126. package/lib/elements/post-reply/post-reply.component.d.ts +22 -0
  127. package/lib/elements/post-reply/post-reply.component.d.ts.map +1 -0
  128. package/lib/elements/related-discussion/related-discussion.component.d.ts +26 -0
  129. package/lib/elements/related-discussion/related-discussion.component.d.ts.map +1 -0
  130. package/lib/elements/sliders/sliders.component.d.ts +18 -0
  131. package/lib/elements/sliders/sliders.component.d.ts.map +1 -0
  132. package/lib/events.service.d.ts +18 -0
  133. package/lib/events.service.d.ts.map +1 -0
  134. package/lib/models/discuss.model.d.ts +298 -0
  135. package/lib/models/discuss.model.d.ts.map +1 -0
  136. package/lib/models/discussion-config.model.d.ts +42 -0
  137. package/lib/models/discussion-config.model.d.ts.map +1 -0
  138. package/lib/navigation-service.service.d.ts +22 -0
  139. package/lib/navigation-service.service.d.ts.map +1 -0
  140. package/lib/pipes/pipe-filter/pipe-filter.pipe.d.ts +8 -0
  141. package/lib/pipes/pipe-filter/pipe-filter.pipe.d.ts.map +1 -0
  142. package/lib/pipes/pipe-list-filter/pipe-list-filter.pipe.d.ts +8 -0
  143. package/lib/pipes/pipe-list-filter/pipe-list-filter.pipe.d.ts.map +1 -0
  144. package/lib/pipes/pipe-relative-time/pipe-relative-time.pipe.d.ts +8 -0
  145. package/lib/pipes/pipe-relative-time/pipe-relative-time.pipe.d.ts.map +1 -0
  146. package/lib/pipes/pipes.module.d.ts +13 -0
  147. package/lib/pipes/pipes.module.d.ts.map +1 -0
  148. package/lib/pipes/sort-by/sort-by.pipe.d.ts +8 -0
  149. package/lib/pipes/sort-by/sort-by.pipe.d.ts.map +1 -0
  150. package/lib/pipes/split-initials/split-initials.pipe.d.ts +8 -0
  151. package/lib/pipes/split-initials/split-initials.pipe.d.ts.map +1 -0
  152. package/lib/router-service.service.d.ts +10 -0
  153. package/lib/router-service.service.d.ts.map +1 -0
  154. package/lib/services/abstract-config.service.d.ts +4 -0
  155. package/lib/services/abstract-config.service.d.ts.map +1 -0
  156. package/lib/services/config.service.d.ts +36 -0
  157. package/lib/services/config.service.d.ts.map +1 -0
  158. package/lib/services/discuss-utils.service.d.ts +14 -0
  159. package/lib/services/discuss-utils.service.d.ts.map +1 -0
  160. package/lib/services/discussion.service.d.ts +76 -0
  161. package/lib/services/discussion.service.d.ts.map +1 -0
  162. package/lib/telemetry-utils.service.d.ts +20 -0
  163. package/lib/telemetry-utils.service.d.ts.map +1 -0
  164. package/lib/wrapper/base-wrapper/base-wrapper.component.d.ts +22 -0
  165. package/lib/wrapper/base-wrapper/base-wrapper.component.d.ts.map +1 -0
  166. package/lib/wrapper/category-widget/category-widget.component.d.ts +23 -0
  167. package/lib/wrapper/category-widget/category-widget.component.d.ts.map +1 -0
  168. package/lib/wrapper/tags-widget/tags-widget.component.d.ts +17 -0
  169. package/lib/wrapper/tags-widget/tags-widget.component.d.ts.map +1 -0
  170. package/lib/wrapper-navigate.service.d.ts +11 -0
  171. package/lib/wrapper-navigate.service.d.ts.map +1 -0
  172. package/package.json +44 -0
  173. package/public-api.d.ts +26 -0
  174. package/public-api.d.ts.map +1 -0
@@ -0,0 +1,152 @@
1
+ import { Component, Input, Output, EventEmitter } from '@angular/core';
2
+ import { CONTEXT_PROPS } from '../../services/discussion.service';
3
+ import { NSDiscussData } from './../../models/discuss.model';
4
+ import * as CONSTANTS from './../../common/constants.json';
5
+ /* tslint:disable */
6
+ import * as _ from 'lodash';
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 "../../navigation-service.service";
13
+ import * as i6 from "@angular/common";
14
+ import * as i7 from "../../elements/category-card/category-card.component";
15
+ import * as i8 from "../../elements/app-loader/app-loader.component";
16
+ import * as i9 from "../discuss-start/discuss-start.component";
17
+ /* tslint:enable */
18
+ export class DiscussCategoryComponent {
19
+ constructor(discussService, configService, router, activatedRoute, telemetryUtils, navigationService) {
20
+ this.discussService = discussService;
21
+ this.configService = configService;
22
+ this.router = router;
23
+ this.activatedRoute = activatedRoute;
24
+ this.telemetryUtils = telemetryUtils;
25
+ this.navigationService = navigationService;
26
+ this.categories = [];
27
+ this.stateChange = new EventEmitter();
28
+ this.pageId = 0;
29
+ this.isTopicCreator = false;
30
+ this.showStartDiscussionModal = false;
31
+ this.showLoader = false;
32
+ }
33
+ ngOnInit() {
34
+ /** It will look for the queryParams, if back button is clicked,
35
+ * the queryParams will change and it will fetch the categories
36
+ * if there is no queryParams available, then it will fetch the default categories of the forumIds
37
+ */
38
+ this.telemetryUtils.setContext([]);
39
+ this.telemetryUtils.logImpression(NSDiscussData.IPageName.CATEGORY);
40
+ this.forumIds = this.categoryIds ? this.categoryIds : this.discussService.forumIds;
41
+ this.paramsSubscription = this.activatedRoute.queryParams.subscribe((params) => {
42
+ if (_.get(params, 'cid')) {
43
+ this.navigateToDiscussionPage(_.get(params, 'cid'));
44
+ }
45
+ else {
46
+ this.categories = [];
47
+ if (this.forumIds.length) {
48
+ this.fetchAllAvailableCategories(this.forumIds);
49
+ }
50
+ else {
51
+ this.fetchAllCategories();
52
+ }
53
+ }
54
+ });
55
+ }
56
+ fetchAllAvailableCategories(ids) {
57
+ this.showLoader = true;
58
+ ids.forEach((cid) => {
59
+ this.fetchCategory(cid).subscribe(data => {
60
+ this.showLoader = false;
61
+ this.categories.push(data);
62
+ }, error => {
63
+ // TODO: Toast error
64
+ // error code check
65
+ this.discussService.showTrafficAlert(error);
66
+ console.log('issue fetching category', error);
67
+ this.showLoader = false;
68
+ });
69
+ });
70
+ }
71
+ fetchAllCategories() {
72
+ this.showLoader = true;
73
+ this.discussService.fetchAllCategories().subscribe(data => {
74
+ this.showLoader = false;
75
+ this.categories = data;
76
+ }, error => {
77
+ // TODO: Toast error
78
+ // error code check
79
+ this.discussService.showTrafficAlert(error);
80
+ console.log('issue fetching category', error);
81
+ this.showLoader = false;
82
+ });
83
+ }
84
+ fetchCategory(cid) {
85
+ return this.discussService.fetchSingleCategoryDetails(cid);
86
+ }
87
+ /**
88
+ * It will fetch the children for each category click.
89
+ * if there is no children available the it will redirect to the topic list page
90
+ */
91
+ navigateToDiscussionPage(cid, slug) {
92
+ this.showLoader = true;
93
+ this.telemetryUtils.uppendContext({ id: cid, type: 'Category' });
94
+ this.discussService.fetchSingleCategoryDetails(cid).subscribe(response => {
95
+ this.showLoader = false;
96
+ this.categoryId = _.get(response, 'cid');
97
+ this.isTopicCreator = _.get(response, 'privileges.topics:create') === true ? true : false;
98
+ this.showStartDiscussionModal = false;
99
+ let input;
100
+ if (_.get(response, 'children').length > 0) {
101
+ this.router.navigate([], { relativeTo: this.activatedRoute.parent, queryParams: { cid: this.categoryId } });
102
+ // input = { data: { url: '', queryParams: { cid: this.categoryId } }, action: this.categoryAction}
103
+ // this.navigationService.navigate(input)
104
+ _.get(response, 'children').forEach(subCategoryData => {
105
+ this.categories.push(subCategoryData);
106
+ });
107
+ }
108
+ else {
109
+ this.discussService.setContext(CONTEXT_PROPS.cid, this.categoryId);
110
+ this.configService.setCategoryid(this.categoryId);
111
+ let routerSlug = this.configService.getConfig().routerSlug ? this.configService.getConfig().routerSlug : '';
112
+ input = { data: { url: `${routerSlug}${CONSTANTS.ROUTES.CATEGORY}${this.categoryId}`, queryParams: {} }, action: CONSTANTS.CATEGORY_HOME, };
113
+ this.navigationService.navigate(input);
114
+ this.stateChange.emit({ action: this.categoryAction, categoryId: this.categoryId });
115
+ }
116
+ }, error => {
117
+ // error code check
118
+ this.discussService.showTrafficAlert(error);
119
+ this.showLoader = false;
120
+ // TODO: Toast error
121
+ console.log('issue fetching category', error);
122
+ });
123
+ }
124
+ startDiscussion() {
125
+ this.showStartDiscussionModal = true;
126
+ }
127
+ closeModal(event) {
128
+ this.showStartDiscussionModal = false;
129
+ }
130
+ logTelemetry(event) {
131
+ this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.CATEGORY);
132
+ }
133
+ ;
134
+ ngOnDestroy() {
135
+ if (this.paramsSubscription) {
136
+ this.paramsSubscription.unsubscribe();
137
+ }
138
+ }
139
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussCategoryComponent, deps: [{ token: i1.DiscussionService }, { token: i2.ConfigService }, { token: i3.Router }, { token: i3.ActivatedRoute }, { token: i4.TelemetryUtilsService }, { token: i5.NavigationServiceService }], target: i0.ɵɵFactoryTarget.Component }); }
140
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DiscussCategoryComponent, selector: "lib-discuss-category", inputs: { categoryIds: "categoryIds", categoryAction: "categoryAction" }, outputs: { stateChange: "stateChange" }, ngImport: i0, template: "<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n <button (click)=\"startDiscussion();logTelemetry($event)\" *ngIf=\"isTopicCreator\" class=\"df-btn df-btn-primary df-btn-normal mb-16\" id=\"start-discussion\">Start Discussion</button>\n <div class=\"discuss-category-cards\">\n <ng-container *ngFor=\"let data of categories\">\n <div (click)=\"navigateToDiscussionPage(data?.cid, data?.slug);logTelemetry($event)\" class=\"categories-card-content\" id=\"category-card\">\n <lib-category-card [category]=\"data\" ></lib-category-card>\n </div>\n </ng-container>\n </div>\n\n <lib-discuss-start (close)=\"closeModal($event)\" [categoryId]=\"categoryId\" *ngIf=\"showStartDiscussionModal\" ></lib-discuss-start>\n", styles: [".discuss-category-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(292px,1fr));grid-gap:1.5rem;margin-bottom:1.5rem;cursor:pointer;position:relative;z-index:unset}@media (max-width: 700px){.discuss-category-cards{grid-template-columns:1fr}}\n"], dependencies: [{ kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i7.CategoryCardComponent, selector: "lib-category-card", inputs: ["category"] }, { kind: "component", type: i8.AppLoaderComponent, selector: "lib-app-loader", inputs: ["data"] }, { kind: "component", type: i9.DiscussStartComponent, selector: "lib-discuss-start", inputs: ["categoryId", "topicData", "mode"], outputs: ["close"] }] }); }
141
+ }
142
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussCategoryComponent, decorators: [{
143
+ type: Component,
144
+ args: [{ selector: 'lib-discuss-category', template: "<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n <button (click)=\"startDiscussion();logTelemetry($event)\" *ngIf=\"isTopicCreator\" class=\"df-btn df-btn-primary df-btn-normal mb-16\" id=\"start-discussion\">Start Discussion</button>\n <div class=\"discuss-category-cards\">\n <ng-container *ngFor=\"let data of categories\">\n <div (click)=\"navigateToDiscussionPage(data?.cid, data?.slug);logTelemetry($event)\" class=\"categories-card-content\" id=\"category-card\">\n <lib-category-card [category]=\"data\" ></lib-category-card>\n </div>\n </ng-container>\n </div>\n\n <lib-discuss-start (close)=\"closeModal($event)\" [categoryId]=\"categoryId\" *ngIf=\"showStartDiscussionModal\" ></lib-discuss-start>\n", styles: [".discuss-category-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(292px,1fr));grid-gap:1.5rem;margin-bottom:1.5rem;cursor:pointer;position:relative;z-index:unset}@media (max-width: 700px){.discuss-category-cards{grid-template-columns:1fr}}\n"] }]
145
+ }], ctorParameters: function () { return [{ type: i1.DiscussionService }, { type: i2.ConfigService }, { type: i3.Router }, { type: i3.ActivatedRoute }, { type: i4.TelemetryUtilsService }, { type: i5.NavigationServiceService }]; }, propDecorators: { categoryIds: [{
146
+ type: Input
147
+ }], categoryAction: [{
148
+ type: Input
149
+ }], stateChange: [{
150
+ type: Output
151
+ }] } });
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"discuss-category.component.js","sourceRoot":"","sources":["../../../../../../projects/discussion-ui/src/lib/components/discuss-category/discuss-category.component.ts","../../../../../../projects/discussion-ui/src/lib/components/discuss-category/discuss-category.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Subscription } from 'rxjs';\nimport { Component, OnInit, OnDestroy, Input, Output, EventEmitter } from '@angular/core';\nimport { DiscussionService, CONTEXT_PROPS } from '../../services/discussion.service';\nimport { NSDiscussData } from './../../models/discuss.model';\nimport { Router, ActivatedRoute } from '@angular/router';\nimport { TelemetryUtilsService } from './../../telemetry-utils.service';\n\nimport * as CONSTANTS from './../../common/constants.json';\n/* tslint:disable */\nimport * as _ from 'lodash'\nimport { ConfigService } from '../../services/config.service';\nimport { NavigationServiceService } from '../../navigation-service.service';\n/* tslint:enable */\n\n@Component({\n  selector: 'lib-discuss-category',\n  templateUrl: './discuss-category.component.html',\n  styleUrls: ['./discuss-category.component.css']\n})\nexport class DiscussCategoryComponent implements OnInit, OnDestroy {\n\n  categories: NSDiscussData.ICategorie[] = [];\n\n  forumIds: any;\n  @Input() categoryIds;\n  @Input() categoryAction;\n  @Output() stateChange: EventEmitter<any> = new EventEmitter();\n\n  pageId = 0;\n\n  isTopicCreator = false;\n\n  showStartDiscussionModal = false;\n\n  categoryId: any;\n\n  paramsSubscription: Subscription;\n\n  showLoader = false;\n\n  constructor(\n    public discussService: DiscussionService,\n    public configService: ConfigService,\n    public router: Router,\n    public activatedRoute: ActivatedRoute,\n    private telemetryUtils: TelemetryUtilsService,\n    private navigationService: NavigationServiceService\n  ) { }\n\n  ngOnInit() {\n    /** It will look for the queryParams, if back button is clicked,\n     * the queryParams will change and it will fetch the categories\n     * if there is no queryParams available, then it will fetch the default categories of the forumIds\n     */\n    this.telemetryUtils.setContext([]);\n    this.telemetryUtils.logImpression(NSDiscussData.IPageName.CATEGORY);\n    this.forumIds = this.categoryIds ? this.categoryIds : this.discussService.forumIds;\n    this.paramsSubscription = this.activatedRoute.queryParams.subscribe((params) => {\n      if (_.get(params, 'cid')) {\n        this.navigateToDiscussionPage(_.get(params, 'cid'));\n      } else {\n        this.categories = [];\n        if (this.forumIds.length) {\n          this.fetchAllAvailableCategories(this.forumIds);\n        } else {\n          this.fetchAllCategories();\n        }\n      }\n    });\n  }\n\n  fetchAllAvailableCategories(ids) {\n    this.showLoader = true;\n    ids.forEach((cid) => {\n      this.fetchCategory(cid).subscribe(data => {\n        this.showLoader = false;\n        this.categories.push(data);\n      }, error => {\n        // TODO: Toast error\n        // error code check\n        this.discussService.showTrafficAlert(error);\n        console.log('issue fetching category', error);\n        this.showLoader = false;\n      });\n    });\n  }\n\n  fetchAllCategories() {\n    this.showLoader = true;\n    this.discussService.fetchAllCategories().subscribe(data => {\n      this.showLoader = false;\n      this.categories = data\n    }, error => {\n      // TODO: Toast error\n      // error code check\n      this.discussService.showTrafficAlert(error);\n      console.log('issue fetching category', error);\n      this.showLoader = false;\n    });\n  }\n\n  fetchCategory(cid) {\n    return this.discussService.fetchSingleCategoryDetails(cid);\n  }\n\n  /**\n   * It will fetch the children for each category click.\n   * if there is no children available the it will redirect to the topic list page\n   */\n  navigateToDiscussionPage(cid, slug?) {\n    this.showLoader = true;\n    this.telemetryUtils.uppendContext({ id: cid, type: 'Category' });\n    this.discussService.fetchSingleCategoryDetails(cid).subscribe(response => {\n      this.showLoader = false;\n      this.categoryId = _.get(response, 'cid');\n      this.isTopicCreator = _.get(response, 'privileges.topics:create') === true ? true : false;\n      this.showStartDiscussionModal = false;\n      let input\n      if (_.get(response, 'children').length > 0) {\n        this.router.navigate([], { relativeTo: this.activatedRoute.parent, queryParams: { cid: this.categoryId } });\n\n        // input = { data: { url: '', queryParams: { cid: this.categoryId } }, action: this.categoryAction}\n        // this.navigationService.navigate(input)\n\n        _.get(response, 'children').forEach(subCategoryData => {\n          this.categories.push(subCategoryData);\n        });\n      } else {\n        this.discussService.setContext(CONTEXT_PROPS.cid, this.categoryId);\n        this.configService.setCategoryid(this.categoryId)\n\n        let routerSlug = this.configService.getConfig().routerSlug ? this.configService.getConfig().routerSlug : ''\n        input = { data: { url: `${routerSlug}${CONSTANTS.ROUTES.CATEGORY}${this.categoryId}`, queryParams: {} }, action: CONSTANTS.CATEGORY_HOME, }\n        this.navigationService.navigate(input)\n        this.stateChange.emit({ action: this.categoryAction, categoryId: this.categoryId })\n      }\n    }, error => {\n      // error code check\n      this.discussService.showTrafficAlert(error);\n      this.showLoader = false;\n      // TODO: Toast error\n      console.log('issue fetching category', error);\n    });\n  }\n\n  startDiscussion() {\n    this.showStartDiscussionModal = true;\n  }\n\n  closeModal(event) {\n    this.showStartDiscussionModal = false;\n  }\n\n  logTelemetry(event) {\n    this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.CATEGORY);\n  };\n\n  ngOnDestroy() {\n    if (this.paramsSubscription) {\n      this.paramsSubscription.unsubscribe();\n    }\n  }\n}\n","<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n <button (click)=\"startDiscussion();logTelemetry($event)\" *ngIf=\"isTopicCreator\" class=\"df-btn df-btn-primary df-btn-normal mb-16\" id=\"start-discussion\">Start Discussion</button>\n  <div class=\"discuss-category-cards\">\n    <ng-container  *ngFor=\"let data of categories\">\n      <div (click)=\"navigateToDiscussionPage(data?.cid, data?.slug);logTelemetry($event)\" class=\"categories-card-content\" id=\"category-card\">\n      <lib-category-card [category]=\"data\" ></lib-category-card>\n      </div>\n    </ng-container>\n  </div>\n\n  <lib-discuss-start (close)=\"closeModal($event)\" [categoryId]=\"categoryId\" *ngIf=\"showStartDiscussionModal\" ></lib-discuss-start>\n"]}
@@ -0,0 +1,142 @@
1
+ import { CONTEXT_PROPS } from './../../services/discussion.service';
2
+ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
3
+ import * as CONSTANTS from './../../common/constants.json';
4
+ /* tslint:disable */
5
+ import * as _ from 'lodash';
6
+ import { NSDiscussData } from '../../models/discuss.model';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/router";
9
+ import * as i2 from "../../services/discussion.service";
10
+ import * as i3 from "../../services/config.service";
11
+ import * as i4 from "./../../telemetry-utils.service";
12
+ import * as i5 from "../../navigation-service.service";
13
+ import * as i6 from "@angular/common";
14
+ import * as i7 from "../../elements/discuss-card/discuss-card.component";
15
+ import * as i8 from "../../elements/app-loader/app-loader.component";
16
+ import * as i9 from "ngx-infinite-scroll";
17
+ import * as i10 from "../discuss-start/discuss-start.component";
18
+ /* tslint:enable */
19
+ export class DiscussHomeComponent {
20
+ constructor(router, route, discussionService, configService, telemetryUtils, navigationService) {
21
+ this.router = router;
22
+ this.route = route;
23
+ this.discussionService = discussionService;
24
+ this.configService = configService;
25
+ this.telemetryUtils = telemetryUtils;
26
+ this.navigationService = navigationService;
27
+ this.stateChange = new EventEmitter();
28
+ this.discussionList = [];
29
+ this.showStartDiscussionModal = false;
30
+ // categoryId: string;
31
+ this.isTopicCreator = false;
32
+ this.showLoader = false;
33
+ this.currentActivePage = 1;
34
+ this.pagination = Object.create({});
35
+ // Input parameters for infinite scroll
36
+ this.InfiniteScrollConfig = {
37
+ modalScrollDistance: 2,
38
+ modalScrollThrottle: 50
39
+ };
40
+ // Input parameters for infinite scroll
41
+ this.modalScrollDistance = -12;
42
+ this.modalScrollThrottle = 500;
43
+ this.scrollUpDistance = 5;
44
+ this.currentPage = 0;
45
+ }
46
+ ngOnInit() {
47
+ this.telemetryUtils.logImpression(NSDiscussData.IPageName.HOME);
48
+ this.route.params.subscribe(params => {
49
+ this.configService.setCategoryId.subscribe((categoryIds) => {
50
+ this.routeParams = categoryIds;
51
+ // categoryIds = this.discussionService.getContext(CONTEXT_PROPS.cid)
52
+ categoryIds = this.categoryId ? this.categoryId : categoryIds;
53
+ this.getDiscussionList(categoryIds);
54
+ });
55
+ this.routeParams = params;
56
+ this.categoryId = this.discussionService.getContext(CONTEXT_PROPS.cid);
57
+ // this.getDiscussionList(_.get(this.routeParams, 'slug'));
58
+ });
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
+ navigateToDiscussionDetails(discussionData) {
70
+ const matchedTopic = _.find(this.telemetryUtils.getContext(), { type: 'Topic' });
71
+ if (matchedTopic) {
72
+ this.telemetryUtils.deleteContext(matchedTopic);
73
+ }
74
+ this.telemetryUtils.uppendContext({
75
+ id: _.get(discussionData, 'tid'),
76
+ type: 'Topic'
77
+ });
78
+ let routerSlug = this.configService.getConfig().routerSlug ? this.configService.getConfig().routerSlug : '';
79
+ let input = { data: { url: `${routerSlug}${CONSTANTS.ROUTES.TOPIC}${_.trim(_.get(discussionData, 'slug'))}`, queryParams: {}, tid: discussionData.tid, title: discussionData.title }, action: CONSTANTS.CATEGORY_DETAILS };
80
+ this.navigationService.navigate(input);
81
+ this.stateChange.emit({ tid: discussionData.tid, title: discussionData.title, action: this.categoryHomeAction });
82
+ }
83
+ /**
84
+ * @description - To get all the topics
85
+ * @param - required cid as a slug
86
+ */
87
+ getDiscussionList(slug) {
88
+ this.showLoader = true;
89
+ const scrollIndex = this.pagination.currentPage ? this.pagination.currentPage : 1;
90
+ this.discussionService.getContextBasedTopic(slug, scrollIndex).subscribe(data => {
91
+ this.pagination = data.pagination;
92
+ this.showLoader = false;
93
+ this.isTopicCreator = _.get(data, 'privileges.topics:create') === true ? true : false;
94
+ this.discussionList = [...this.discussionList, ...(_.union(_.get(data, 'topics'), _.get(data, 'children')))];
95
+ }, error => {
96
+ this.showLoader = false;
97
+ // error code check
98
+ this.discussionService.showTrafficAlert(error);
99
+ // TODO: Toaster
100
+ console.log('error fetching topic list', error);
101
+ });
102
+ }
103
+ startDiscussion() {
104
+ this.showStartDiscussionModal = true;
105
+ }
106
+ logTelemetry(event) {
107
+ this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.HOME);
108
+ }
109
+ closeModal(event) {
110
+ if (_.get(event, 'message') === 'success') {
111
+ this.discussionList = [];
112
+ this.pagination.currentPage = this.pagination.first.page;
113
+ this.getDiscussionList(_.get(this.routeParams, 'slug'));
114
+ }
115
+ this.showStartDiscussionModal = false;
116
+ }
117
+ /**
118
+ * @description - call the topic get api when scrolled down
119
+ */
120
+ onModalScrollDown() {
121
+ if (this.pagination.currentPage !== this.pagination.pageCount) {
122
+ this.pagination.currentPage = this.pagination.next.page;
123
+ this.getDiscussionList(_.get(this.routeParams, 'slug'));
124
+ }
125
+ }
126
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussHomeComponent, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }, { token: i2.DiscussionService }, { token: i3.ConfigService }, { token: i4.TelemetryUtilsService }, { token: i5.NavigationServiceService }], target: i0.ɵɵFactoryTarget.Component }); }
127
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DiscussHomeComponent, selector: "lib-discuss-home", inputs: { categoryId: "categoryId", categoryHomeAction: "categoryHomeAction" }, outputs: { stateChange: "stateChange" }, viewQueries: [{ propertyName: "elementView", first: true, predicate: ["scrollContainerHeight"], descendants: true }], ngImport: i0, template: "<button *ngIf=\"isTopicCreator\" (click)=\"startDiscussion();logTelemetry($event)\" role=\"link\" tabindex=\"0\"\n class=\"df-btn df-btn-normal df-btn-primary df-start-btn\" data-toggle=\"modal\" data-target=\"#myModal\" data-backdrop=\"static\" data-keyboard=\"false\"\n id=\"start-discussion\">Start Discussion</button>\n<div *ngIf=\"discussionList && discussionList.length > 0\" class=\"topic-list-container\" id=\"topic-scroll\" #scrollContainerHeight>\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 <div *ngFor=\"let discussionData of discussionList\"\n (click)=\"navigateToDiscussionDetails(discussionData);logTelemetry($event)\" id=\"topic-card\">\n <lib-discuss-card [discussionData]=\"discussionData\"></lib-discuss-card>\n </div>\n </div>\n</div>\n<ng-container *ngIf=\"!(discussionList && discussionList.length > 0)\">\n <div class=\"no-card-content\" id=\"topic-card\" 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<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n<lib-discuss-start [categoryId]=\"categoryId\" (close)=\"closeModal($event)\" *ngIf=\"showStartDiscussionModal\">\n</lib-discuss-start>", styles: [".df-start-btn{margin-bottom:1rem}\n"], dependencies: [{ kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i7.DiscussCardComponent, selector: "lib-discuss-card", inputs: ["discussionData"] }, { kind: "component", type: i8.AppLoaderComponent, selector: "lib-app-loader", inputs: ["data"] }, { kind: "directive", type: i9.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { kind: "component", type: i10.DiscussStartComponent, selector: "lib-discuss-start", inputs: ["categoryId", "topicData", "mode"], outputs: ["close"] }] }); }
128
+ }
129
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussHomeComponent, decorators: [{
130
+ type: Component,
131
+ args: [{ selector: 'lib-discuss-home', template: "<button *ngIf=\"isTopicCreator\" (click)=\"startDiscussion();logTelemetry($event)\" role=\"link\" tabindex=\"0\"\n class=\"df-btn df-btn-normal df-btn-primary df-start-btn\" data-toggle=\"modal\" data-target=\"#myModal\" data-backdrop=\"static\" data-keyboard=\"false\"\n id=\"start-discussion\">Start Discussion</button>\n<div *ngIf=\"discussionList && discussionList.length > 0\" class=\"topic-list-container\" id=\"topic-scroll\" #scrollContainerHeight>\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 <div *ngFor=\"let discussionData of discussionList\"\n (click)=\"navigateToDiscussionDetails(discussionData);logTelemetry($event)\" id=\"topic-card\">\n <lib-discuss-card [discussionData]=\"discussionData\"></lib-discuss-card>\n </div>\n </div>\n</div>\n<ng-container *ngIf=\"!(discussionList && discussionList.length > 0)\">\n <div class=\"no-card-content\" id=\"topic-card\" 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<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n<lib-discuss-start [categoryId]=\"categoryId\" (close)=\"closeModal($event)\" *ngIf=\"showStartDiscussionModal\">\n</lib-discuss-start>", styles: [".df-start-btn{margin-bottom:1rem}\n"] }]
132
+ }], ctorParameters: function () { return [{ type: i1.Router }, { type: i1.ActivatedRoute }, { type: i2.DiscussionService }, { type: i3.ConfigService }, { type: i4.TelemetryUtilsService }, { type: i5.NavigationServiceService }]; }, propDecorators: { categoryId: [{
133
+ type: Input
134
+ }], categoryHomeAction: [{
135
+ type: Input
136
+ }], stateChange: [{
137
+ type: Output
138
+ }], elementView: [{
139
+ type: ViewChild,
140
+ args: ['scrollContainerHeight']
141
+ }] } });
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"discuss-home.component.js","sourceRoot":"","sources":["../../../../../../projects/discussion-ui/src/lib/components/discuss-home/discuss-home.component.ts","../../../../../../projects/discussion-ui/src/lib/components/discuss-home/discuss-home.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CONTEXT_PROPS } from './../../services/discussion.service';\nimport { Component, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { Router, ActivatedRoute } from '@angular/router';\nimport { DiscussionService } from '../../services/discussion.service';\nimport { TelemetryUtilsService } from './../../telemetry-utils.service';\nimport * as CONSTANTS from './../../common/constants.json';\n/* tslint:disable */\nimport * as _ from 'lodash'\nimport { NSDiscussData } from '../../models/discuss.model';\nimport { ConfigService } from '../../services/config.service';\nimport { NavigationServiceService } from '../../navigation-service.service';\n/* tslint:enable */\n\n@Component({\n  selector: 'lib-discuss-home',\n  templateUrl: './discuss-home.component.html',\n  styleUrls: ['./discuss-home.component.css']\n})\nexport class DiscussHomeComponent implements OnInit {\n  @Input() categoryId;\n  @Input() categoryHomeAction;\n  @Output() stateChange: EventEmitter<any> = new EventEmitter();\n\n  @ViewChild('scrollContainerHeight') elementView: ElementRef;\n  discussionList = [];\n  routeParams: any;\n  showStartDiscussionModal = false;\n  // categoryId: string;\n  isTopicCreator = false;\n  showLoader = false;\n  currentActivePage: number = 1;\n  pagination = Object.create({});\n\n  // Input parameters for infinite scroll\n  InfiniteScrollConfig = {\n    modalScrollDistance: 2,\n    modalScrollThrottle: 50\n  };\n\n  // Input parameters for infinite scroll\n  modalScrollDistance = -12;\n  modalScrollThrottle = 500;\n  scrollUpDistance = 5;\n\n  currentPage = 0;\n  pageSize: number;\n  totalTopics: number;\n  title: any;\n\n  constructor(\n    public router: Router,\n    private route: ActivatedRoute,\n    private discussionService: DiscussionService,\n    private configService: ConfigService,\n    private telemetryUtils: TelemetryUtilsService,\n    private navigationService: NavigationServiceService) { }\n\n  ngOnInit() {\n    this.telemetryUtils.logImpression(NSDiscussData.IPageName.HOME);\n    this.route.params.subscribe(params => {\n      this.configService.setCategoryId.subscribe((categoryIds: string) => {\n        this.routeParams = categoryIds;\n        // categoryIds = this.discussionService.getContext(CONTEXT_PROPS.cid)\n        categoryIds = this.categoryId ? this.categoryId : categoryIds\n        this.getDiscussionList(categoryIds);\n      })\n      this.routeParams = params;\n      this.categoryId = this.discussionService.getContext(CONTEXT_PROPS.cid);\n      // this.getDiscussionList(_.get(this.routeParams, 'slug'));\n    });\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  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    let routerSlug = this.configService.getConfig().routerSlug ? this.configService.getConfig().routerSlug : ''\n    let input = { data: { url: `${routerSlug}${CONSTANTS.ROUTES.TOPIC}${_.trim(_.get(discussionData, 'slug'))}`, queryParams: {}, tid: discussionData.tid, title: discussionData.title }, action: CONSTANTS.CATEGORY_DETAILS }\n    this.navigationService.navigate(input)\n    this.stateChange.emit({ tid: discussionData.tid, title: discussionData.title, action: this.categoryHomeAction })\n  }\n  /**\n   * @description - To get all the topics\n   * @param - required cid as a slug\n   */\n  getDiscussionList(slug: string) {\n    this.showLoader = true;\n    const scrollIndex = this.pagination.currentPage ? this.pagination.currentPage : 1;\n    this.discussionService.getContextBasedTopic(slug, scrollIndex).subscribe(data => {\n      this.pagination = data.pagination;\n      this.showLoader = false;\n      this.isTopicCreator = _.get(data, 'privileges.topics:create') === true ? true : false;\n      this.discussionList = [...this.discussionList, ...(_.union(_.get(data, 'topics'), _.get(data, 'children')))];\n    }, error => {\n      this.showLoader = false;\n      // error code check\n      this.discussionService.showTrafficAlert(error);\n      // TODO: Toaster\n      console.log('error fetching topic list', error);\n    });\n  }\n\n  startDiscussion() {\n    this.showStartDiscussionModal = true;\n  }\n\n  logTelemetry(event) {\n    this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.HOME);\n  }\n\n  closeModal(event) {\n    if (_.get(event, 'message') === 'success') {\n      this.discussionList = [];\n      this.pagination.currentPage = this.pagination.first.page;\n      this.getDiscussionList(_.get(this.routeParams, 'slug'));\n    }\n    this.showStartDiscussionModal = false;\n  }\n\n  /**\n   * @description - call the topic get api when scrolled down\n   */\n  onModalScrollDown() {\n    if (this.pagination.currentPage !== this.pagination.pageCount) {\n      this.pagination.currentPage = this.pagination.next.page;\n      this.getDiscussionList(_.get(this.routeParams, 'slug'));\n    }\n  }\n}","<button *ngIf=\"isTopicCreator\" (click)=\"startDiscussion();logTelemetry($event)\" role=\"link\" tabindex=\"0\"\n    class=\"df-btn df-btn-normal df-btn-primary df-start-btn\" data-toggle=\"modal\" data-target=\"#myModal\" data-backdrop=\"static\" data-keyboard=\"false\"\n    id=\"start-discussion\">Start Discussion</button>\n<div *ngIf=\"discussionList && discussionList.length > 0\" class=\"topic-list-container\" id=\"topic-scroll\" #scrollContainerHeight>\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        <div *ngFor=\"let discussionData of discussionList\"\n            (click)=\"navigateToDiscussionDetails(discussionData);logTelemetry($event)\" id=\"topic-card\">\n            <lib-discuss-card [discussionData]=\"discussionData\"></lib-discuss-card>\n        </div>\n    </div>\n</div>\n<ng-container *ngIf=\"!(discussionList && discussionList.length > 0)\">\n    <div class=\"no-card-content\" id=\"topic-card\" 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<lib-app-loader *ngIf=\"showLoader\"></lib-app-loader>\n<lib-discuss-start [categoryId]=\"categoryId\" (close)=\"closeModal($event)\" *ngIf=\"showStartDiscussionModal\">\n</lib-discuss-start>"]}