@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,105 @@
|
|
|
1
|
+
import { PipesModule } from './../pipes/pipes.module';
|
|
2
|
+
import { DiscussionService } from './../services/discussion.service';
|
|
3
|
+
import { ConfigService } from './../services/config.service';
|
|
4
|
+
import { HttpClientModule } from '@angular/common/http';
|
|
5
|
+
import { ElementsModule } from './../elements/elements.module';
|
|
6
|
+
import { NgModule } from '@angular/core';
|
|
7
|
+
import { CommonModule } from '@angular/common';
|
|
8
|
+
import { SidePannelComponent } from './side-pannel/side-pannel.component';
|
|
9
|
+
import { DiscussHomeComponent } from './discuss-home/discuss-home.component';
|
|
10
|
+
import { DiscussCategoryComponent } from './discuss-category/discuss-category.component';
|
|
11
|
+
import { DiscussTagsComponent } from './discuss-tags/discuss-tags.component';
|
|
12
|
+
import { MyDiscussionComponent } from './my-discussion/my-discussion.component';
|
|
13
|
+
import { DiscussionDetailsComponent } from './discussion-details/discussion-details.component';
|
|
14
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
15
|
+
import { DiscussStartComponent } from './discuss-start/discuss-start.component';
|
|
16
|
+
import { TagInputModule } from 'ngx-chips';
|
|
17
|
+
import { DiscussAllComponent } from './discuss-all/discuss-all.component';
|
|
18
|
+
import { TagAllDiscussionComponent } from './tag-all-discussion/tag-all-discussion.component';
|
|
19
|
+
import { InfiniteScrollModule } from 'ngx-infinite-scroll';
|
|
20
|
+
import { TrendingTagsComponent } from './trending-tags/trending-tags.component';
|
|
21
|
+
import * as i0 from "@angular/core";
|
|
22
|
+
export class ComponentsModule {
|
|
23
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
24
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, declarations: [SidePannelComponent,
|
|
25
|
+
DiscussHomeComponent,
|
|
26
|
+
DiscussCategoryComponent,
|
|
27
|
+
DiscussTagsComponent,
|
|
28
|
+
MyDiscussionComponent,
|
|
29
|
+
DiscussionDetailsComponent,
|
|
30
|
+
DiscussStartComponent,
|
|
31
|
+
DiscussAllComponent,
|
|
32
|
+
TagAllDiscussionComponent,
|
|
33
|
+
TrendingTagsComponent], imports: [CommonModule,
|
|
34
|
+
HttpClientModule,
|
|
35
|
+
ElementsModule,
|
|
36
|
+
FormsModule,
|
|
37
|
+
ReactiveFormsModule,
|
|
38
|
+
TagInputModule,
|
|
39
|
+
PipesModule,
|
|
40
|
+
InfiniteScrollModule], exports: [SidePannelComponent,
|
|
41
|
+
DiscussHomeComponent,
|
|
42
|
+
DiscussCategoryComponent,
|
|
43
|
+
DiscussTagsComponent,
|
|
44
|
+
MyDiscussionComponent,
|
|
45
|
+
DiscussionDetailsComponent,
|
|
46
|
+
DiscussStartComponent,
|
|
47
|
+
// TODO: Add this components
|
|
48
|
+
DiscussAllComponent,
|
|
49
|
+
TagAllDiscussionComponent,
|
|
50
|
+
TrendingTagsComponent] }); }
|
|
51
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, providers: [
|
|
52
|
+
DiscussionService, ConfigService
|
|
53
|
+
], imports: [CommonModule,
|
|
54
|
+
HttpClientModule,
|
|
55
|
+
ElementsModule,
|
|
56
|
+
FormsModule,
|
|
57
|
+
ReactiveFormsModule,
|
|
58
|
+
TagInputModule,
|
|
59
|
+
PipesModule,
|
|
60
|
+
InfiniteScrollModule] }); }
|
|
61
|
+
}
|
|
62
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, decorators: [{
|
|
63
|
+
type: NgModule,
|
|
64
|
+
args: [{
|
|
65
|
+
declarations: [
|
|
66
|
+
SidePannelComponent,
|
|
67
|
+
DiscussHomeComponent,
|
|
68
|
+
DiscussCategoryComponent,
|
|
69
|
+
DiscussTagsComponent,
|
|
70
|
+
MyDiscussionComponent,
|
|
71
|
+
DiscussionDetailsComponent,
|
|
72
|
+
DiscussStartComponent,
|
|
73
|
+
DiscussAllComponent,
|
|
74
|
+
TagAllDiscussionComponent,
|
|
75
|
+
TrendingTagsComponent,
|
|
76
|
+
],
|
|
77
|
+
imports: [
|
|
78
|
+
CommonModule,
|
|
79
|
+
HttpClientModule,
|
|
80
|
+
ElementsModule,
|
|
81
|
+
FormsModule,
|
|
82
|
+
ReactiveFormsModule,
|
|
83
|
+
TagInputModule,
|
|
84
|
+
PipesModule,
|
|
85
|
+
InfiniteScrollModule
|
|
86
|
+
],
|
|
87
|
+
exports: [
|
|
88
|
+
SidePannelComponent,
|
|
89
|
+
DiscussHomeComponent,
|
|
90
|
+
DiscussCategoryComponent,
|
|
91
|
+
DiscussTagsComponent,
|
|
92
|
+
MyDiscussionComponent,
|
|
93
|
+
DiscussionDetailsComponent,
|
|
94
|
+
DiscussStartComponent,
|
|
95
|
+
// TODO: Add this components
|
|
96
|
+
DiscussAllComponent,
|
|
97
|
+
TagAllDiscussionComponent,
|
|
98
|
+
TrendingTagsComponent,
|
|
99
|
+
],
|
|
100
|
+
providers: [
|
|
101
|
+
DiscussionService, ConfigService
|
|
102
|
+
]
|
|
103
|
+
}]
|
|
104
|
+
}] });
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kaXNjdXNzaW9uLXVpL3NyYy9saWIvY29tcG9uZW50cy9jb21wb25lbnRzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDckUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQzdELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUN6RixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNoRixPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUMvRixPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDaEYsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUMzQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUM5RixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQzs7QUF5Q2hGLE1BQU0sT0FBTyxnQkFBZ0I7K0dBQWhCLGdCQUFnQjtnSEFBaEIsZ0JBQWdCLGlCQXRDekIsbUJBQW1CO1lBQ25CLG9CQUFvQjtZQUNwQix3QkFBd0I7WUFDeEIsb0JBQW9CO1lBQ3BCLHFCQUFxQjtZQUNyQiwwQkFBMEI7WUFDMUIscUJBQXFCO1lBQ3JCLG1CQUFtQjtZQUNuQix5QkFBeUI7WUFDekIscUJBQXFCLGFBR3JCLFlBQVk7WUFDWixnQkFBZ0I7WUFDaEIsY0FBYztZQUNkLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsY0FBYztZQUNkLFdBQVc7WUFDWCxvQkFBb0IsYUFHcEIsbUJBQW1CO1lBQ25CLG9CQUFvQjtZQUNwQix3QkFBd0I7WUFDeEIsb0JBQW9CO1lBQ3BCLHFCQUFxQjtZQUNyQiwwQkFBMEI7WUFDMUIscUJBQXFCO1lBQ3JCLDRCQUE0QjtZQUMzQixtQkFBbUI7WUFDcEIseUJBQXlCO1lBQ3pCLHFCQUFxQjtnSEFNWixnQkFBZ0IsYUFKaEI7WUFDVCxpQkFBaUIsRUFBRSxhQUFhO1NBQ2pDLFlBeEJDLFlBQVk7WUFDWixnQkFBZ0I7WUFDaEIsY0FBYztZQUNkLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsY0FBYztZQUNkLFdBQVc7WUFDWCxvQkFBb0I7OzRGQW1CWCxnQkFBZ0I7a0JBeEM1QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixtQkFBbUI7d0JBQ25CLG9CQUFvQjt3QkFDcEIsd0JBQXdCO3dCQUN4QixvQkFBb0I7d0JBQ3BCLHFCQUFxQjt3QkFDckIsMEJBQTBCO3dCQUMxQixxQkFBcUI7d0JBQ3JCLG1CQUFtQjt3QkFDbkIseUJBQXlCO3dCQUN6QixxQkFBcUI7cUJBQ3RCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsY0FBYzt3QkFDZCxXQUFXO3dCQUNYLG1CQUFtQjt3QkFDbkIsY0FBYzt3QkFDZCxXQUFXO3dCQUNYLG9CQUFvQjtxQkFDckI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLG1CQUFtQjt3QkFDbkIsb0JBQW9CO3dCQUNwQix3QkFBd0I7d0JBQ3hCLG9CQUFvQjt3QkFDcEIscUJBQXFCO3dCQUNyQiwwQkFBMEI7d0JBQzFCLHFCQUFxQjt3QkFDckIsNEJBQTRCO3dCQUMzQixtQkFBbUI7d0JBQ3BCLHlCQUF5Qjt3QkFDekIscUJBQXFCO3FCQUN0QjtvQkFDRCxTQUFTLEVBQUU7d0JBQ1QsaUJBQWlCLEVBQUUsYUFBYTtxQkFDakM7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlc01vZHVsZSB9IGZyb20gJy4vLi4vcGlwZXMvcGlwZXMubW9kdWxlJztcbmltcG9ydCB7IERpc2N1c3Npb25TZXJ2aWNlIH0gZnJvbSAnLi8uLi9zZXJ2aWNlcy9kaXNjdXNzaW9uLnNlcnZpY2UnO1xuaW1wb3J0IHsgQ29uZmlnU2VydmljZSB9IGZyb20gJy4vLi4vc2VydmljZXMvY29uZmlnLnNlcnZpY2UnO1xuaW1wb3J0IHsgSHR0cENsaWVudE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IEVsZW1lbnRzTW9kdWxlIH0gZnJvbSAnLi8uLi9lbGVtZW50cy9lbGVtZW50cy5tb2R1bGUnO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBTaWRlUGFubmVsQ29tcG9uZW50IH0gZnJvbSAnLi9zaWRlLXBhbm5lbC9zaWRlLXBhbm5lbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGlzY3Vzc0hvbWVDb21wb25lbnQgfSBmcm9tICcuL2Rpc2N1c3MtaG9tZS9kaXNjdXNzLWhvbWUuY29tcG9uZW50JztcbmltcG9ydCB7IERpc2N1c3NDYXRlZ29yeUNvbXBvbmVudCB9IGZyb20gJy4vZGlzY3Vzcy1jYXRlZ29yeS9kaXNjdXNzLWNhdGVnb3J5LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEaXNjdXNzVGFnc0NvbXBvbmVudCB9IGZyb20gJy4vZGlzY3Vzcy10YWdzL2Rpc2N1c3MtdGFncy5jb21wb25lbnQnO1xuaW1wb3J0IHsgTXlEaXNjdXNzaW9uQ29tcG9uZW50IH0gZnJvbSAnLi9teS1kaXNjdXNzaW9uL215LWRpc2N1c3Npb24uY29tcG9uZW50JztcbmltcG9ydCB7IERpc2N1c3Npb25EZXRhaWxzQ29tcG9uZW50IH0gZnJvbSAnLi9kaXNjdXNzaW9uLWRldGFpbHMvZGlzY3Vzc2lvbi1kZXRhaWxzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IERpc2N1c3NTdGFydENvbXBvbmVudCB9IGZyb20gJy4vZGlzY3Vzcy1zdGFydC9kaXNjdXNzLXN0YXJ0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUYWdJbnB1dE1vZHVsZSB9IGZyb20gJ25neC1jaGlwcyc7XG5pbXBvcnQgeyBEaXNjdXNzQWxsQ29tcG9uZW50IH0gZnJvbSAnLi9kaXNjdXNzLWFsbC9kaXNjdXNzLWFsbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGFnQWxsRGlzY3Vzc2lvbkNvbXBvbmVudCB9IGZyb20gJy4vdGFnLWFsbC1kaXNjdXNzaW9uL3RhZy1hbGwtZGlzY3Vzc2lvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5maW5pdGVTY3JvbGxNb2R1bGUgfSBmcm9tICduZ3gtaW5maW5pdGUtc2Nyb2xsJztcbmltcG9ydCB7IFRyZW5kaW5nVGFnc0NvbXBvbmVudCB9IGZyb20gJy4vdHJlbmRpbmctdGFncy90cmVuZGluZy10YWdzLmNvbXBvbmVudCc7XG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBTaWRlUGFubmVsQ29tcG9uZW50LFxuICAgIERpc2N1c3NIb21lQ29tcG9uZW50LFxuICAgIERpc2N1c3NDYXRlZ29yeUNvbXBvbmVudCxcbiAgICBEaXNjdXNzVGFnc0NvbXBvbmVudCxcbiAgICBNeURpc2N1c3Npb25Db21wb25lbnQsXG4gICAgRGlzY3Vzc2lvbkRldGFpbHNDb21wb25lbnQsXG4gICAgRGlzY3Vzc1N0YXJ0Q29tcG9uZW50LFxuICAgIERpc2N1c3NBbGxDb21wb25lbnQsXG4gICAgVGFnQWxsRGlzY3Vzc2lvbkNvbXBvbmVudCxcbiAgICBUcmVuZGluZ1RhZ3NDb21wb25lbnQsXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgSHR0cENsaWVudE1vZHVsZSxcbiAgICBFbGVtZW50c01vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgIFRhZ0lucHV0TW9kdWxlLFxuICAgIFBpcGVzTW9kdWxlLFxuICAgIEluZmluaXRlU2Nyb2xsTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBTaWRlUGFubmVsQ29tcG9uZW50LFxuICAgIERpc2N1c3NIb21lQ29tcG9uZW50LFxuICAgIERpc2N1c3NDYXRlZ29yeUNvbXBvbmVudCxcbiAgICBEaXNjdXNzVGFnc0NvbXBvbmVudCxcbiAgICBNeURpc2N1c3Npb25Db21wb25lbnQsXG4gICAgRGlzY3Vzc2lvbkRldGFpbHNDb21wb25lbnQsXG4gICAgRGlzY3Vzc1N0YXJ0Q29tcG9uZW50LFxuICAgIC8vIFRPRE86IEFkZCB0aGlzIGNvbXBvbmVudHNcbiAgICAgRGlzY3Vzc0FsbENvbXBvbmVudCxcbiAgICBUYWdBbGxEaXNjdXNzaW9uQ29tcG9uZW50LFxuICAgIFRyZW5kaW5nVGFnc0NvbXBvbmVudCxcbiAgXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAgRGlzY3Vzc2lvblNlcnZpY2UsIENvbmZpZ1NlcnZpY2VcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBDb21wb25lbnRzTW9kdWxlIHsgfVxuIl19
|
|
@@ -0,0 +1,269 @@
|
|
|
1
|
+
import { CONTEXT_PROPS } from './../../services/discussion.service';
|
|
2
|
+
import { Component, EventEmitter, Input, Output } 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 "../discuss-start/discuss-start.component";
|
|
16
|
+
import * as i9 from "../trending-tags/trending-tags.component";
|
|
17
|
+
// import { BsModalService, BsModalRef } from 'ngx-bootstrap/modal';
|
|
18
|
+
/* tslint:enable */
|
|
19
|
+
export class DiscussAllComponent {
|
|
20
|
+
constructor(router, route, discussionService, configService, activatedRoute, telemetryUtils, navigationService
|
|
21
|
+
// private modalService: BsModalService
|
|
22
|
+
) {
|
|
23
|
+
this.router = router;
|
|
24
|
+
this.route = route;
|
|
25
|
+
this.discussionService = discussionService;
|
|
26
|
+
this.configService = configService;
|
|
27
|
+
this.activatedRoute = activatedRoute;
|
|
28
|
+
this.telemetryUtils = telemetryUtils;
|
|
29
|
+
this.navigationService = navigationService;
|
|
30
|
+
this.stateChange = new EventEmitter();
|
|
31
|
+
this.showStartDiscussionModal = false;
|
|
32
|
+
this.isTopicCreator = false;
|
|
33
|
+
this.showLoader = false;
|
|
34
|
+
this.currentFilter = 'recent';
|
|
35
|
+
this.currentActivePage = 1;
|
|
36
|
+
this.cIds = [];
|
|
37
|
+
this.sticky = false;
|
|
38
|
+
}
|
|
39
|
+
ngOnInit() {
|
|
40
|
+
this.telemetryUtils.logImpression(NSDiscussData.IPageName.HOME);
|
|
41
|
+
if (this.context) {
|
|
42
|
+
this.isWidget = true;
|
|
43
|
+
this.getForumIds();
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
this.cIds = this.configService.getCategories().result;
|
|
47
|
+
this.loadDiscussionData();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
async getForumIds() {
|
|
51
|
+
let body = {
|
|
52
|
+
"identifier": this.context.contextIdArr,
|
|
53
|
+
"type": this.context.contextType
|
|
54
|
+
};
|
|
55
|
+
let resp = await this.discussionService.getForumIds(body);
|
|
56
|
+
if (resp.result.length > 0) {
|
|
57
|
+
resp.result.forEach(forum => {
|
|
58
|
+
this.cIds.push(forum.cid);
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
this.discussionService.createForum(this.context.categoryObj).subscribe(((data) => {
|
|
63
|
+
data.result.forEach(forum => {
|
|
64
|
+
this.cIds.push(forum.newCid);
|
|
65
|
+
});
|
|
66
|
+
}));
|
|
67
|
+
}
|
|
68
|
+
this.loadDiscussionData();
|
|
69
|
+
}
|
|
70
|
+
loadDiscussionData() {
|
|
71
|
+
// debugger
|
|
72
|
+
// this.cIds = this.context ? this.context.categories : this.configService.getCategories()
|
|
73
|
+
this.categoryId = this.discussionService.getContext(CONTEXT_PROPS.cid);
|
|
74
|
+
if (this.configService.hasContext() || this.context) {
|
|
75
|
+
this.getContextBasedDiscussion(this.cIds);
|
|
76
|
+
// This is to show context based trending tags
|
|
77
|
+
this.getContextBasedTags(this.cIds);
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
// this.currentActivePage = 1
|
|
81
|
+
this.refreshData();
|
|
82
|
+
// This is to show trending tags
|
|
83
|
+
this.fetchAllTags();
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
navigateToDiscussionDetails(discussionData) {
|
|
87
|
+
const matchedTopic = _.find(this.telemetryUtils.getContext(), { type: 'Topic' });
|
|
88
|
+
if (matchedTopic) {
|
|
89
|
+
this.telemetryUtils.deleteContext(matchedTopic);
|
|
90
|
+
}
|
|
91
|
+
this.telemetryUtils.uppendContext({
|
|
92
|
+
id: _.get(discussionData, 'tid'),
|
|
93
|
+
type: 'Topic'
|
|
94
|
+
});
|
|
95
|
+
const slug = _.trim(_.get(discussionData, 'slug'));
|
|
96
|
+
// tslint:disable-next-line: max-line-length
|
|
97
|
+
const input = { data: { url: `${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TOPIC}${slug}`, queryParams: {} }, action: CONSTANTS.CATEGORY_DETAILS, };
|
|
98
|
+
this.navigationService.navigate(input);
|
|
99
|
+
this.stateChange.emit({ action: CONSTANTS.CATEGORY_DETAILS, title: discussionData.title, tid: discussionData.tid });
|
|
100
|
+
// this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TOPIC}${slug}`], { queryParamsHandling: "merge" });
|
|
101
|
+
}
|
|
102
|
+
acceptData(singleTagDetails) {
|
|
103
|
+
// debugger
|
|
104
|
+
if (this.context) {
|
|
105
|
+
singleTagDetails.cIds = this.cIds;
|
|
106
|
+
}
|
|
107
|
+
this.stateChange.emit(singleTagDetails);
|
|
108
|
+
}
|
|
109
|
+
getDiscussionList(slug) {
|
|
110
|
+
this.showLoader = true;
|
|
111
|
+
// TODO : this.currentActivePage shoulb be dynamic when pagination will be implemented
|
|
112
|
+
this.discussionService.getContextBasedTopic(slug, this.currentActivePage).subscribe(data => {
|
|
113
|
+
this.showLoader = false;
|
|
114
|
+
this.isTopicCreator = _.get(data, 'privileges.topics:create') === true ? true : false;
|
|
115
|
+
this.discussionList = _.union(_.get(data, 'topics'), _.get(data, 'children'));
|
|
116
|
+
}, error => {
|
|
117
|
+
this.showLoader = false;
|
|
118
|
+
// TODO: Toaster
|
|
119
|
+
console.log('error fetching topic list', error);
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
filter(key) {
|
|
123
|
+
if (key) {
|
|
124
|
+
this.currentFilter = key;
|
|
125
|
+
switch (key) {
|
|
126
|
+
case 'recent':
|
|
127
|
+
this.cIds.length ? this.getContextData(this.cIds.result) : this.fillrecent();
|
|
128
|
+
break;
|
|
129
|
+
case 'popular':
|
|
130
|
+
this.cIds.length ? this.getContextData(this.cIds.result) : this.fillPopular();
|
|
131
|
+
break;
|
|
132
|
+
default:
|
|
133
|
+
break;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
fillrecent(_page) {
|
|
138
|
+
this.getRecentData();
|
|
139
|
+
}
|
|
140
|
+
fillPopular(page) {
|
|
141
|
+
this.showLoader = true;
|
|
142
|
+
return this.discussionService.fetchPopularD(page).subscribe((response) => {
|
|
143
|
+
this.showLoader = false;
|
|
144
|
+
this.discussionList = [];
|
|
145
|
+
_.filter(response.topics, (topic) => {
|
|
146
|
+
if (topic.user.uid !== 0 && topic.cid !== 1) {
|
|
147
|
+
this.discussionList.push(topic);
|
|
148
|
+
}
|
|
149
|
+
});
|
|
150
|
+
// this.discussionList = _.get(response, 'topics')
|
|
151
|
+
}, error => {
|
|
152
|
+
this.showLoader = false;
|
|
153
|
+
// TODO: Toaster
|
|
154
|
+
console.log('error fetching topic list', error);
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
getContextBasedDiscussion(cid) {
|
|
158
|
+
this.currentFilter === 'recent' ? this.getContextData(cid) : this.getContextData(cid);
|
|
159
|
+
}
|
|
160
|
+
refreshData(page) {
|
|
161
|
+
this.currentFilter === 'recent' ? this.getRecentData() : this.fillPopular(page);
|
|
162
|
+
}
|
|
163
|
+
getRecentData() {
|
|
164
|
+
this.showLoader = true;
|
|
165
|
+
return this.discussionService.fetchRecentPost().subscribe((data) => {
|
|
166
|
+
this.showLoader = false;
|
|
167
|
+
this.discussionList = [];
|
|
168
|
+
_.filter(data.topics, (topic) => {
|
|
169
|
+
if (topic.user.uid !== 0 && topic.cid !== 1) {
|
|
170
|
+
this.discussionList.push(topic);
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
this.discussionList = _.get(data, 'posts');
|
|
174
|
+
}, error => {
|
|
175
|
+
this.showLoader = false;
|
|
176
|
+
// TODO: Toaster
|
|
177
|
+
console.log('error fetching topic list', error);
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
getContextData(cid) {
|
|
181
|
+
this.showLoader = true;
|
|
182
|
+
const req = {
|
|
183
|
+
// request: {
|
|
184
|
+
cids: cid
|
|
185
|
+
// }
|
|
186
|
+
};
|
|
187
|
+
return this.discussionService.getContextBasedDiscussion(req).subscribe((data) => {
|
|
188
|
+
this.showLoader = false;
|
|
189
|
+
let result = data.result;
|
|
190
|
+
let res = result.filter((elem) => {
|
|
191
|
+
return (elem.statusCode !== 404);
|
|
192
|
+
});
|
|
193
|
+
this.allTopics = _.map(res, (topic) => topic.topics);
|
|
194
|
+
this.discussionList = _.flatten(this.allTopics);
|
|
195
|
+
}, error => {
|
|
196
|
+
this.showLoader = false;
|
|
197
|
+
// TODO: Toaster
|
|
198
|
+
console.log('error fetching topic list', error);
|
|
199
|
+
});
|
|
200
|
+
}
|
|
201
|
+
fetchAllTags() {
|
|
202
|
+
this.showLoader = true;
|
|
203
|
+
this.discussionService.fetchAllTag().subscribe(data => {
|
|
204
|
+
this.showLoader = false;
|
|
205
|
+
this.trendingTags = _.get(data, 'tags');
|
|
206
|
+
}, error => {
|
|
207
|
+
this.showLoader = false;
|
|
208
|
+
// TODO: toaster
|
|
209
|
+
console.log('error fetching tags');
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
getContextBasedTags(cid) {
|
|
213
|
+
const req = {
|
|
214
|
+
cids: cid
|
|
215
|
+
};
|
|
216
|
+
this.showLoader = true;
|
|
217
|
+
this.discussionService.contextBasedTags(req).subscribe(data => {
|
|
218
|
+
this.showLoader = false;
|
|
219
|
+
this.trendingTags = _.get(data, 'result');
|
|
220
|
+
}, error => {
|
|
221
|
+
this.showLoader = false;
|
|
222
|
+
// TODO: toaster
|
|
223
|
+
console.log('error fetching tags');
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
// startDiscussion(template: TemplateRef<any>) {
|
|
227
|
+
// this.modalRef = this.modalService.show(template);
|
|
228
|
+
// this.showStartDiscussionModal = true;
|
|
229
|
+
// this.bsModalRef = this.modalService.show(DiscussStartComponent);
|
|
230
|
+
// this.bsModalRef.content.onClose().subscribe(
|
|
231
|
+
// console.log('completed')
|
|
232
|
+
// );
|
|
233
|
+
// }
|
|
234
|
+
startDiscussion() {
|
|
235
|
+
debugger;
|
|
236
|
+
this.showStartDiscussionModal = true;
|
|
237
|
+
if (this.context) {
|
|
238
|
+
this.startDiscussionCategoryId = this.cIds;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
logTelemetry(event) {
|
|
242
|
+
this.telemetryUtils.logInteract(event, NSDiscussData.IPageName.HOME);
|
|
243
|
+
}
|
|
244
|
+
closeModal(event) {
|
|
245
|
+
if (_.get(event, 'message') === 'success') {
|
|
246
|
+
if (this.context) {
|
|
247
|
+
this.getContextBasedDiscussion(this.cIds);
|
|
248
|
+
}
|
|
249
|
+
else {
|
|
250
|
+
this.refreshData();
|
|
251
|
+
}
|
|
252
|
+
// this.getDiscussionList(_.get(this.routeParams, 'slug'));
|
|
253
|
+
}
|
|
254
|
+
this.showStartDiscussionModal = false;
|
|
255
|
+
}
|
|
256
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussAllComponent, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }, { token: i2.DiscussionService }, { token: i3.ConfigService }, { token: i1.ActivatedRoute }, { token: i4.TelemetryUtilsService }, { token: i5.NavigationServiceService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
257
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DiscussAllComponent, selector: "lib-discuss-all", inputs: { context: "context", categoryAction: "categoryAction" }, outputs: { stateChange: "stateChange" }, ngImport: i0, template: "<div class=\"main-div\">\n\n <!-- <button (click)=\"startDiscussion();logTelemetry($event)\" class=\"df-btn df-btn-normal df-btn-primary\" data-toggle=\"modal\"\n data-target=\"#myModal\" id=\"start-discussion\">Start Discussion</button> -->\n\n\n <div class=\"flex flex-1 custom discussion_outer_box\">\n <div class=\"flex flex-3 flex-column discussion_main_box\">\n <div (click)=\"startDiscussion();logTelemetry($event)\" data-toggle=\"modal\"\n data-target=\"#myModal\" id=\"start-discussion\">\n <a href=\"javascript:void(0)\" class=\"flex flex-1 cursor-pointer margin-fix height-48\" i18n-aria-label role=\"link\">\n <div\n class=\"flex flex-1 items-center border discuss border-solid discuss-border ws-mat-primary-background-op100 \">\n <div class=\"w-full discuss truncate\">\n <span class=\"overflow ml-4 start-btn-hint mb-0 mat-body-1\">Ask a question or post an idea</span>\n </div>\n <div class=\"discuss-home text-white flex items-center justify-center cursor-pointer mat-subheading-2\">\n Start discussion\n </div>\n </div>\n <!-- <div class=\"text-box\">Ask a question or post an idea</div> \n <div class=\"buton\">start discussion</div> -->\n </a>\n </div>\n\n <ng-container>\n <div class=\"flex flex-1 flex-row margin-fix tab_margin\">\n <div class=\"flex flex-1 filter max-height-60\">\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{'tabs-active' : currentFilter === 'recent',\n ' font-medium':currentFilter !== 'recent'}\" mat-button (click)=\"filter('recent')\" role=\"button\">Recent</a>\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{'tabs-active' : currentFilter === 'popular',\n ' font-medium':currentFilter !== 'popular'}\" mat-button (click)=\"filter('popular')\" role=\"button\">Popular</a>\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option watching_link\" mat-button role=\"button\">Watching</a>\n </div>\n <div class=\"flex items-center\">\n <a class=\"all_category_link mat-subheading-2 margin-remove\">All categories </a>\n </div>\n </div>\n </ng-container>\n <!-- <lib-app-loader *ngIf=\"showLoader\"></lib-app-loader> -->\n\n\n <ng-container *ngIf=\"discussionList && discussionList.length > 0\">\n <div (click)=\"navigateToDiscussionDetails(data);logTelemetry($event)\"\n *ngFor=\"let data of discussionList\" id=\"discuss-card\">\n <lib-discuss-card [discussionData]=\"data\"></lib-discuss-card>\n </div>\n </ng-container>\n\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>\n <!-- <div class=\"flex flex-1 flex-column margin-fix pagination-container\">\n <ws-app-pagination [pager]=\"pager\" (changePage)=\"navigateWithPage($event)\"></ws-app-pagination>\n </div> -->\n </div>\n <div *ngIf=\"!isWidget\" class=\"flex flex-1 right_tag_box\" #stickyMenu [class.sticky]=\"sticky\">\n <lib-discuss-trending-tags [tags]=\"trendingTags\" (stateChange)=\"acceptData($event)\"></lib-discuss-trending-tags>\n </div>\n </div>\n\n <lib-discuss-start (close)=\"closeModal($event)\" *ngIf=\"showStartDiscussionModal\" [categoryId]=\"startDiscussionCategoryId\">\n </lib-discuss-start>\n</div>", styles: [".fade:not(.show){opacity:1!important}.buton{display:flex;border:.0625rem solid;flex:1;background:var(--red);align-content:center;text-align:center}.sticky{position:fixed;top:0;overflow:hidden;z-index:10;width:100%}.text-box{display:flex;border:.0625rem solid;flex:3;align-content:center;text-align:center}.overflow{overflow:hidden}.font-medium{font-weight:500!important}.discuss-border{border-radius:.25rem;border:.0625rem solid var(--gray-200);flex:1}.discuss .mat-form-field-wrapper{padding-bottom:0}.discuss .mat-form-field-wrapper .mat-form-field-infix{border-top-width:.25rem!important;padding:0;padding-bottom:.25rem}.discuss-home{background:var(--primary) 0% 0% no-repeat padding-box;border-radius:0px .25rem .25rem 0px;padding:.875rem 2rem;min-width:-moz-fit-content;min-width:fit-content;margin:0 1rem 1rem}.flex-3{flex:3}.filter .filter-option{border-radius:0;border-bottom-width:.125rem;border-top-width:0;border-left-width:0;border-right-width:0;border-bottom:.0625rem solid var(--black)}.filter .filter-option.tabs-active{border-bottom:.1875rem solid var(--blue)}.start-btn-hint{display:block;margin-bottom:0;padding:1rem}.tab_margin{margin-bottom:1rem!important}a.all_category_link{color:var(--primary);display:none}.watching_link{display:none}@media (max-width: 768px){.main-div{display:block!important;width:100%!important;padding:0!important}.discussion_outer_box{display:block!important}.discussion_main_box,.right_tag_box{width:100%;display:block!important;float:none}}\n"], dependencies: [{ kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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.DiscussStartComponent, selector: "lib-discuss-start", inputs: ["categoryId", "topicData", "mode"], outputs: ["close"] }, { kind: "component", type: i9.TrendingTagsComponent, selector: "lib-discuss-trending-tags", inputs: ["tags"], outputs: ["stateChange"] }] }); }
|
|
258
|
+
}
|
|
259
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DiscussAllComponent, decorators: [{
|
|
260
|
+
type: Component,
|
|
261
|
+
args: [{ selector: 'lib-discuss-all', template: "<div class=\"main-div\">\n\n <!-- <button (click)=\"startDiscussion();logTelemetry($event)\" class=\"df-btn df-btn-normal df-btn-primary\" data-toggle=\"modal\"\n data-target=\"#myModal\" id=\"start-discussion\">Start Discussion</button> -->\n\n\n <div class=\"flex flex-1 custom discussion_outer_box\">\n <div class=\"flex flex-3 flex-column discussion_main_box\">\n <div (click)=\"startDiscussion();logTelemetry($event)\" data-toggle=\"modal\"\n data-target=\"#myModal\" id=\"start-discussion\">\n <a href=\"javascript:void(0)\" class=\"flex flex-1 cursor-pointer margin-fix height-48\" i18n-aria-label role=\"link\">\n <div\n class=\"flex flex-1 items-center border discuss border-solid discuss-border ws-mat-primary-background-op100 \">\n <div class=\"w-full discuss truncate\">\n <span class=\"overflow ml-4 start-btn-hint mb-0 mat-body-1\">Ask a question or post an idea</span>\n </div>\n <div class=\"discuss-home text-white flex items-center justify-center cursor-pointer mat-subheading-2\">\n Start discussion\n </div>\n </div>\n <!-- <div class=\"text-box\">Ask a question or post an idea</div> \n <div class=\"buton\">start discussion</div> -->\n </a>\n </div>\n\n <ng-container>\n <div class=\"flex flex-1 flex-row margin-fix tab_margin\">\n <div class=\"flex flex-1 filter max-height-60\">\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{'tabs-active' : currentFilter === 'recent',\n ' font-medium':currentFilter !== 'recent'}\" mat-button (click)=\"filter('recent')\" role=\"button\">Recent</a>\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{'tabs-active' : currentFilter === 'popular',\n ' font-medium':currentFilter !== 'popular'}\" mat-button (click)=\"filter('popular')\" role=\"button\">Popular</a>\n <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option watching_link\" mat-button role=\"button\">Watching</a>\n </div>\n <div class=\"flex items-center\">\n <a class=\"all_category_link mat-subheading-2 margin-remove\">All categories </a>\n </div>\n </div>\n </ng-container>\n <!-- <lib-app-loader *ngIf=\"showLoader\"></lib-app-loader> -->\n\n\n <ng-container *ngIf=\"discussionList && discussionList.length > 0\">\n <div (click)=\"navigateToDiscussionDetails(data);logTelemetry($event)\"\n *ngFor=\"let data of discussionList\" id=\"discuss-card\">\n <lib-discuss-card [discussionData]=\"data\"></lib-discuss-card>\n </div>\n </ng-container>\n\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>\n <!-- <div class=\"flex flex-1 flex-column margin-fix pagination-container\">\n <ws-app-pagination [pager]=\"pager\" (changePage)=\"navigateWithPage($event)\"></ws-app-pagination>\n </div> -->\n </div>\n <div *ngIf=\"!isWidget\" class=\"flex flex-1 right_tag_box\" #stickyMenu [class.sticky]=\"sticky\">\n <lib-discuss-trending-tags [tags]=\"trendingTags\" (stateChange)=\"acceptData($event)\"></lib-discuss-trending-tags>\n </div>\n </div>\n\n <lib-discuss-start (close)=\"closeModal($event)\" *ngIf=\"showStartDiscussionModal\" [categoryId]=\"startDiscussionCategoryId\">\n </lib-discuss-start>\n</div>", styles: [".fade:not(.show){opacity:1!important}.buton{display:flex;border:.0625rem solid;flex:1;background:var(--red);align-content:center;text-align:center}.sticky{position:fixed;top:0;overflow:hidden;z-index:10;width:100%}.text-box{display:flex;border:.0625rem solid;flex:3;align-content:center;text-align:center}.overflow{overflow:hidden}.font-medium{font-weight:500!important}.discuss-border{border-radius:.25rem;border:.0625rem solid var(--gray-200);flex:1}.discuss .mat-form-field-wrapper{padding-bottom:0}.discuss .mat-form-field-wrapper .mat-form-field-infix{border-top-width:.25rem!important;padding:0;padding-bottom:.25rem}.discuss-home{background:var(--primary) 0% 0% no-repeat padding-box;border-radius:0px .25rem .25rem 0px;padding:.875rem 2rem;min-width:-moz-fit-content;min-width:fit-content;margin:0 1rem 1rem}.flex-3{flex:3}.filter .filter-option{border-radius:0;border-bottom-width:.125rem;border-top-width:0;border-left-width:0;border-right-width:0;border-bottom:.0625rem solid var(--black)}.filter .filter-option.tabs-active{border-bottom:.1875rem solid var(--blue)}.start-btn-hint{display:block;margin-bottom:0;padding:1rem}.tab_margin{margin-bottom:1rem!important}a.all_category_link{color:var(--primary);display:none}.watching_link{display:none}@media (max-width: 768px){.main-div{display:block!important;width:100%!important;padding:0!important}.discussion_outer_box{display:block!important}.discussion_main_box,.right_tag_box{width:100%;display:block!important;float:none}}\n"] }]
|
|
262
|
+
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i1.ActivatedRoute }, { type: i2.DiscussionService }, { type: i3.ConfigService }, { type: i1.ActivatedRoute }, { type: i4.TelemetryUtilsService }, { type: i5.NavigationServiceService }]; }, propDecorators: { context: [{
|
|
263
|
+
type: Input
|
|
264
|
+
}], categoryAction: [{
|
|
265
|
+
type: Input
|
|
266
|
+
}], stateChange: [{
|
|
267
|
+
type: Output
|
|
268
|
+
}] } });
|
|
269
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"discuss-all.component.js","sourceRoot":"","sources":["../../../../../../projects/discussion-ui/src/lib/components/discuss-all/discuss-all.component.ts","../../../../../../projects/discussion-ui/src/lib/components/discuss-all/discuss-all.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CONTEXT_PROPS } from './../../services/discussion.service';\nimport { Component, EventEmitter, Input, OnInit, Output, TemplateRef } from '@angular/core';\nimport { Router, ActivatedRoute } from '@angular/router';\nimport { DiscussionService } from '../../services/discussion.service';\nimport { ConfigService } from '../../services/config.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 { DiscussStartComponent } from '../discuss-start/discuss-start.component';\nimport { Subscription } from 'rxjs';\nimport { NavigationServiceService } from '../../navigation-service.service';\n// import { BsModalService, BsModalRef } from 'ngx-bootstrap/modal';\n\n/* tslint:enable */\n\n@Component({\n  selector: 'lib-discuss-all',\n  templateUrl: './discuss-all.component.html',\n  styleUrls: ['./discuss-all.component.scss']\n})\nexport class DiscussAllComponent implements OnInit {\n\n  @Input() context: any\n  @Input() categoryAction;\n\n  @Output() stateChange: EventEmitter<any> = new EventEmitter();\n\n  discussionList: any[];\n  routeParams: any;\n  showStartDiscussionModal = false;\n  categoryId: string;\n  isTopicCreator = false;\n  showLoader = false;\n  currentFilter = 'recent'\n  currentActivePage: number = 1;\n  fetchNewData: false;\n  // modalRef: BsModalRef;\n  paramsSubscription: Subscription;\n  getParams: any;\n  cIds: any = [];\n  allTopics: any;\n  trendingTags!: NSDiscussData.ITag[];\n  sticky = false;\n  data\n  startDiscussionCategoryId: any;\n  isWidget: boolean;\n\n  constructor(\n    public router: Router,\n    private route: ActivatedRoute,\n    private discussionService: DiscussionService,\n    private configService: ConfigService,\n    public activatedRoute: ActivatedRoute,\n    private telemetryUtils: TelemetryUtilsService,\n    private navigationService: NavigationServiceService\n    // private modalService: BsModalService\n  ) { }\n\n  ngOnInit() {\n    this.telemetryUtils.logImpression(NSDiscussData.IPageName.HOME);\n    if (this.context) {\n      this.isWidget  = true\n      this.getForumIds()\n    } else {\n      this.cIds = this.configService.getCategories().result\n      this.loadDiscussionData()\n    }\n  }\n\n  async getForumIds() {\n    let body = {\n      \"identifier\":\n        this.context.contextIdArr\n      ,\n      \"type\": this.context.contextType\n    }\n    let resp = await this.discussionService.getForumIds(body)\n    if (resp.result.length > 0) {\n      resp.result.forEach(forum => {\n        this.cIds.push(forum.cid)\n      });\n    } else {\n      this.discussionService.createForum(this.context.categoryObj).subscribe(((data: any) => {\n        data.result.forEach(forum => {\n          this.cIds.push(forum.newCid)\n        });\n      }))\n\n    }\n    this.loadDiscussionData()\n  }\n\n  loadDiscussionData() {\n    // debugger\n    // this.cIds = this.context ? this.context.categories : this.configService.getCategories()\n    this.categoryId = this.discussionService.getContext(CONTEXT_PROPS.cid);\n    if (this.configService.hasContext() || this.context) {\n      this.getContextBasedDiscussion(this.cIds)\n      // This is to show context based trending tags\n      this.getContextBasedTags(this.cIds);\n    } else {\n      // this.currentActivePage = 1\n      this.refreshData();\n      // This is to show trending tags\n      this.fetchAllTags();\n    }\n  }\n\n  navigateToDiscussionDetails(discussionData) {\n\n    const matchedTopic = _.find(this.telemetryUtils.getContext(), { type: 'Topic' });\n    if (matchedTopic) {\n      this.telemetryUtils.deleteContext(matchedTopic);\n    }\n\n    this.telemetryUtils.uppendContext({\n      id: _.get(discussionData, 'tid'),\n      type: 'Topic'\n    });\n\n    const slug = _.trim(_.get(discussionData, 'slug'));\n    // tslint:disable-next-line: max-line-length\n    const input = { data: { url: `${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TOPIC}${slug}`, queryParams: {} }, action: CONSTANTS.CATEGORY_DETAILS, }\n    this.navigationService.navigate(input);\n    this.stateChange.emit({ action: CONSTANTS.CATEGORY_DETAILS, title: discussionData.title, tid: discussionData.tid });\n\n    // this.router.navigate([`${this.configService.getRouterSlug()}${CONSTANTS.ROUTES.TOPIC}${slug}`], { queryParamsHandling: \"merge\" });\n  }\n\n  acceptData(singleTagDetails) {\n    // debugger\n    if(this.context){\n    singleTagDetails.cIds =  this.cIds;\n    }\n    this.stateChange.emit(singleTagDetails);\n  }\n\n  getDiscussionList(slug: string) {\n    this.showLoader = true;\n    // TODO : this.currentActivePage shoulb be dynamic when pagination will be implemented\n    this.discussionService.getContextBasedTopic(slug, this.currentActivePage).subscribe(data => {\n      this.showLoader = false;\n      this.isTopicCreator = _.get(data, 'privileges.topics:create') === true ? true : false;\n      this.discussionList = _.union(_.get(data, 'topics'), _.get(data, 'children'));\n    }, error => {\n      this.showLoader = false;\n      // TODO: Toaster\n      console.log('error fetching topic list', error);\n    });\n  }\n\n  filter(key: string | 'recent' | 'popular') {\n    if (key) {\n      this.currentFilter = key;\n      switch (key) {\n        case 'recent':\n          this.cIds.length ? this.getContextData(this.cIds.result) : this.fillrecent()\n          break;\n        case 'popular':\n          this.cIds.length ? this.getContextData(this.cIds.result) : this.fillPopular()\n          break;\n        default:\n          break;\n      }\n    }\n  }\n\n  fillrecent(_page?: any) {\n    this.getRecentData();\n  }\n\n  fillPopular(page?: any) {\n    this.showLoader = true;\n    return this.discussionService.fetchPopularD(page).subscribe((response: any) => {\n      this.showLoader = false;\n      this.discussionList = [];\n      _.filter(response.topics, (topic) => {\n        if (topic.user.uid !== 0 && topic.cid !== 1 ) {\n          this.discussionList.push(topic);\n        }\n      });\n      // this.discussionList = _.get(response, 'topics')\n    }, error => {\n      this.showLoader = false;\n      // TODO: Toaster\n      console.log('error fetching topic list', error);\n    });\n  }\n\n  getContextBasedDiscussion(cid: any) {\n    this.currentFilter === 'recent' ? this.getContextData(cid) : this.getContextData(cid)\n  }\n\n  refreshData(page?: any) {\n    this.currentFilter === 'recent' ? this.getRecentData() : this.fillPopular(page)\n  }\n\n  getRecentData() {\n    this.showLoader = true;\n    return this.discussionService.fetchRecentPost().subscribe(\n      (data: any) => {\n        this.showLoader = false;\n        this.discussionList = [];\n        _.filter(data.topics, (topic) => {\n          if (topic.user.uid !== 0 && topic.cid !== 1) {\n            this.discussionList.push(topic);\n          }\n        });\n        this.discussionList = _.get(data, 'posts');\n      }, error => {\n        this.showLoader = false;\n        // TODO: Toaster\n        console.log('error fetching topic list', error);\n      });\n  }\n\n  getContextData(cid: any) {\n    this.showLoader = true;\n    const req = {\n      // request: {\n      cids: cid\n      // }\n    };\n    return this.discussionService.getContextBasedDiscussion(req).subscribe(\n      (data: any) => {\n        this.showLoader = false;\n        let result = data.result\n        let res = result.filter((elem) => {\n          return (elem.statusCode !== 404)\n        })\n        this.allTopics = _.map(res, (topic) => topic.topics);\n        this.discussionList = _.flatten(this.allTopics)\n      }, error => {\n        this.showLoader = false;\n        // TODO: Toaster\n        console.log('error fetching topic list', error);\n      });\n  }\n\n  fetchAllTags() {\n    this.showLoader = true;\n    this.discussionService.fetchAllTag().subscribe(data => {\n      this.showLoader = false;\n      this.trendingTags = _.get(data, 'tags');\n    }, error => {\n      this.showLoader = false;\n      // TODO: toaster\n      console.log('error fetching tags');\n    });\n  }\n\n  getContextBasedTags(cid: any) {\n    const req = {\n      cids: cid\n    }\n    this.showLoader = true;\n    this.discussionService.contextBasedTags(req).subscribe(data => {\n      this.showLoader = false;\n      this.trendingTags = _.get(data, 'result');\n    }, error => {\n      this.showLoader = false;\n      // TODO: toaster\n      console.log('error fetching tags');\n    });\n  }\n\n  // startDiscussion(template: TemplateRef<any>) {\n  //   this.modalRef = this.modalService.show(template);\n\n  // this.showStartDiscussionModal = true;\n  // this.bsModalRef = this.modalService.show(DiscussStartComponent);\n\n  // this.bsModalRef.content.onClose().subscribe(\n  //   console.log('completed')\n  // );\n  // }\n\n  startDiscussion() {\n    debugger\n    this.showStartDiscussionModal = true;\n    if (this.context) {\n      this.startDiscussionCategoryId = this.cIds;\n    }\n\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      if (this.context) {\n        this.getContextBasedDiscussion(this.cIds)\n      } else {\n        this.refreshData()\n      }\n      // this.getDiscussionList(_.get(this.routeParams, 'slug'));\n    }\n    this.showStartDiscussionModal = false;\n  }\n}","<div class=\"main-div\">\n\n    <!-- <button (click)=\"startDiscussion();logTelemetry($event)\" class=\"df-btn df-btn-normal df-btn-primary\" data-toggle=\"modal\"\n        data-target=\"#myModal\" id=\"start-discussion\">Start Discussion</button> -->\n\n\n    <div class=\"flex flex-1 custom discussion_outer_box\">\n        <div class=\"flex flex-3 flex-column discussion_main_box\">\n            <div (click)=\"startDiscussion();logTelemetry($event)\" data-toggle=\"modal\"\n            data-target=\"#myModal\" id=\"start-discussion\">\n                <a href=\"javascript:void(0)\" class=\"flex flex-1 cursor-pointer margin-fix height-48\" i18n-aria-label role=\"link\">\n                  <div\n                    class=\"flex flex-1 items-center border discuss border-solid discuss-border ws-mat-primary-background-op100 \">\n                    <div class=\"w-full discuss truncate\">\n                      <span class=\"overflow ml-4 start-btn-hint mb-0 mat-body-1\">Ask a question or post an idea</span>\n                    </div>\n                    <div class=\"discuss-home text-white flex items-center justify-center cursor-pointer mat-subheading-2\">\n                      Start discussion\n                    </div>\n                  </div>\n                  <!-- <div class=\"text-box\">Ask a question or post an idea</div> \n              <div class=\"buton\">start discussion</div> -->\n                </a>\n              </div>\n\n            <ng-container>\n                <div class=\"flex flex-1 flex-row margin-fix tab_margin\">\n                    <div class=\"flex flex-1 filter max-height-60\">\n                        <a href=\"javascript:void(0)\" role=\"link\" class=\"filter-option\" [ngClass]=\"{'tabs-active' : currentFilter === 'recent',\n          ' font-medium':currentFilter !== 'recent'}\" mat-button (click)=\"filter('recent')\" role=\"button\">Recent</a>\n                        <a href=\"javascript:void(0)\"  role=\"link\" class=\"filter-option\" [ngClass]=\"{'tabs-active' : currentFilter === 'popular',\n          ' font-medium':currentFilter !== 'popular'}\" mat-button (click)=\"filter('popular')\" role=\"button\">Popular</a>\n                        <a href=\"javascript:void(0)\"  role=\"link\" class=\"filter-option watching_link\"  mat-button role=\"button\">Watching</a>\n                    </div>\n                    <div class=\"flex items-center\">\n                        <a class=\"all_category_link mat-subheading-2 margin-remove\">All categories </a>\n                    </div>\n                </div>\n            </ng-container>\n            <!-- <lib-app-loader *ngIf=\"showLoader\"></lib-app-loader> -->\n\n\n            <ng-container *ngIf=\"discussionList  && discussionList.length > 0\">\n                <div (click)=\"navigateToDiscussionDetails(data);logTelemetry($event)\"\n                    *ngFor=\"let data of discussionList\" id=\"discuss-card\">\n                    <lib-discuss-card [discussionData]=\"data\"></lib-discuss-card>\n                </div>\n            </ng-container>\n\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>\n            <!-- <div class=\"flex flex-1 flex-column margin-fix pagination-container\">\n            <ws-app-pagination [pager]=\"pager\" (changePage)=\"navigateWithPage($event)\"></ws-app-pagination>\n        </div> -->\n        </div>\n        <div *ngIf=\"!isWidget\" class=\"flex flex-1 right_tag_box\" #stickyMenu [class.sticky]=\"sticky\">\n            <lib-discuss-trending-tags [tags]=\"trendingTags\" (stateChange)=\"acceptData($event)\"></lib-discuss-trending-tags>\n        </div>\n    </div>\n\n    <lib-discuss-start (close)=\"closeModal($event)\" *ngIf=\"showStartDiscussionModal\" [categoryId]=\"startDiscussionCategoryId\">\n    </lib-discuss-start>\n</div>"]}
|