@sunbird-cb/toc 0.0.3-2.1 → 0.0.3-mauritius

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 (22) hide show
  1. package/esm2022/lib/_collection/_common/content-toc/app-toc-about/app-toc-about.component.mjs +16 -6
  2. package/esm2022/lib/_collection/_common/content-toc/content-toc.component.mjs +11 -7
  3. package/esm2022/lib/_collection/_common/content-toc/karma-points/karma-points.component.mjs +47 -3
  4. package/esm2022/lib/_collection/sliders-dynamic/sliders-dynamic.component.mjs +6 -3
  5. package/esm2022/lib/_services/viewer-route-util.mjs +2 -2
  6. package/esm2022/lib/components/app-toc-cios-home/app-toc-cios-home.component.mjs +4 -3
  7. package/esm2022/lib/components/app-toc-home/app-toc-home.component.mjs +7 -6
  8. package/esm2022/lib/components/app-toc-home-v2/app-toc-home-v2.component.mjs +42 -34
  9. package/esm2022/lib/components/public-survey-form/public-survey-form.component.mjs +5 -3
  10. package/fesm2022/sunbird-cb-toc.mjs +131 -58
  11. package/fesm2022/sunbird-cb-toc.mjs.map +1 -1
  12. package/lib/_collection/_common/content-toc/app-toc-about/app-toc-about.component.d.ts +5 -3
  13. package/lib/_collection/_common/content-toc/content-toc.component.d.ts +5 -3
  14. package/lib/_collection/_common/content-toc/karma-points/karma-points.component.d.ts +3 -1
  15. package/lib/_collection/sliders-dynamic/sliders-dynamic.component.d.ts +2 -1
  16. package/lib/components/app-toc-cios-home/app-toc-cios-home.component.d.ts +1 -0
  17. package/lib/components/app-toc-home/app-toc-home.component.d.ts +3 -2
  18. package/lib/components/app-toc-home-v2/app-toc-home-v2.component.d.ts +3 -2
  19. package/lib/components/public-survey-form/public-survey-form.component.d.ts +1 -0
  20. package/package.json +2 -2
  21. package/sunbird-cb-toc-0.0.3-mauritius.tgz +0 -0
  22. package/sunbird-cb-toc-0.0.32.1.tgz +0 -0
@@ -147,6 +147,7 @@ export class KarmaPointsComponent {
147
147
  }
148
148
  }
149
149
  }
150
+ this.addBadgeSlide();
150
151
  }
151
152
  getKPData(btnType) {
152
153
  this.data?.forEach((item) => {
@@ -161,6 +162,47 @@ export class KarmaPointsComponent {
161
162
  }
162
163
  });
163
164
  }
165
+ addBadgeSlide() {
166
+ const badgeDetails = this.baseContentReadData?.badgeDetails_v1;
167
+ if (!badgeDetails || !badgeDetails.length) {
168
+ return;
169
+ }
170
+ const badge = badgeDetails[0];
171
+ if (!badge.badgeEarningDateEnabled) {
172
+ return;
173
+ }
174
+ const badgeTime = badge.badgeEarningDateTime;
175
+ const currentTime = Date.now();
176
+ const badgeDateIST = new Date(badgeTime).toLocaleString('en-IN', {
177
+ timeZone: 'Asia/Kolkata',
178
+ });
179
+ console.log('Badge IST Time:', badgeDateIST);
180
+ const isEligibleslide = this?.content?.completionPercentage == undefined || this?.content?.completionPercentage < 100;
181
+ const badgeSlide = {
182
+ displayButton: 'Quick Learner Badge',
183
+ textBeforeIcon: this.content.courseCategory == "Curated Program" ? badge?.criteria == "partialRandomCompletion" ? `By partially completing this program, earn Quick learner Badge (Any ${badge?.requiredCourseCompletions} course needed)` : 'By completing this course earn Quick learner Badge' : 'By completing this course earn Quick learner Badge',
184
+ points: '',
185
+ textAfterPoints: '',
186
+ toolTipText: 'quickLearnerBadgeTip',
187
+ };
188
+ const badgeExists = this.kpArray.find((item) => item.displayButton === 'Quick Learner Badge');
189
+ if (isEligibleslide) {
190
+ if (badge?.badgeEarningDateEnabled === true) {
191
+ if (badgeTime > currentTime) {
192
+ if (!badgeExists) {
193
+ this.kpArray.push(badgeSlide);
194
+ this.constructNudgeData();
195
+ }
196
+ }
197
+ }
198
+ else {
199
+ if (!badgeExists) {
200
+ this.kpArray.push(badgeSlide);
201
+ this.constructNudgeData();
202
+ }
203
+ }
204
+ }
205
+ }
164
206
  onClickOfClaim() {
165
207
  this.clickClaimKarmaPoints.emit('claim');
166
208
  this.btnCategory = '';
@@ -191,11 +233,11 @@ export class KarmaPointsComponent {
191
233
  return this.langTranslations.translateLabelWithoutspace(label, type, '');
192
234
  }
193
235
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: KarmaPointsComponent, deps: [{ token: i1.TranslateService }, { token: i2.MultilingualTranslationsService }], target: i0.ɵɵFactoryTarget.Component }); }
194
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: KarmaPointsComponent, selector: "ws-widget-karma-points", inputs: { content: "content", data: "data", pCategory: "pCategory", condition: "condition", btnCategory: "btnCategory" }, outputs: { clickClaimKarmaPoints: "clickClaimKarmaPoints" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"!disableKarmaPoints\">\n <ws-widget-sliders-dynamic [widgetData]=\"karmaPointsSlider\"></ws-widget-sliders-dynamic>\n\n <ng-container *ngIf=\"btnCategory === 'claim'\">\n <button class=\"flex flex-wrap gap-1 claim-button\" (click)=\"onClickOfClaim()\" >\n <img src=\"/assets/icons/home/karma-badge.svg\" width=\"28px\" class=\"mr-2\" alt=\"karma-points image\" />\n <div *ngIf=\"btnKPData?.textBeforeIcon\">{{ btnKPData.textBeforeIcon }}</div>\n <div *ngIf=\"btnKPData.points\">{{ btnKPData.points }} {{ translateLabels(btnKPData.textAfterPoints, 'appKarmapointsPanel') }}</div>\n <div *ngIf=\"btnKPData?.textAfterIcon\">{{ translateLabels(btnKPData.textAfterIcon, 'appKarmapointsPanel') }}</div>\n </button>\n </ng-container> \n</ng-container>", styles: [".claim-button{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:2px;text-align:center;color:#fff!important;border-radius:64px;padding:8px 0;background-color:#ef951e;cursor:pointer;border:none;font-weight:700;width:100%;font-size:14px;margin:16px auto 0;max-width:344px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.SlidersDynamicComponent, selector: "ws-widget-sliders-dynamic", inputs: ["widgetData"] }] }); }
236
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: KarmaPointsComponent, selector: "ws-widget-karma-points", inputs: { content: "content", data: "data", pCategory: "pCategory", condition: "condition", baseContentReadData: "baseContentReadData", btnCategory: "btnCategory" }, outputs: { clickClaimKarmaPoints: "clickClaimKarmaPoints" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"!disableKarmaPoints\">\n <ws-widget-sliders-dynamic [widgetData]=\"karmaPointsSlider\" [baseContentReadData] = \"baseContentReadData\"></ws-widget-sliders-dynamic>\n\n <ng-container *ngIf=\"btnCategory === 'claim'\">\n <button class=\"flex flex-wrap gap-1 claim-button\" (click)=\"onClickOfClaim()\" >\n <img src=\"/assets/icons/home/karma-badge.svg\" width=\"28px\" class=\"mr-2\" alt=\"karma-points image\" />\n <div *ngIf=\"btnKPData?.textBeforeIcon\">{{ btnKPData.textBeforeIcon }}</div>\n <div *ngIf=\"btnKPData.points\">{{ btnKPData.points }} {{ translateLabels(btnKPData.textAfterPoints, 'appKarmapointsPanel') }}</div>\n <div *ngIf=\"btnKPData?.textAfterIcon\">{{ translateLabels(btnKPData.textAfterIcon, 'appKarmapointsPanel') }}</div>\n </button>\n </ng-container> \n</ng-container>", styles: [".claim-button{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:2px;text-align:center;color:#fff!important;border-radius:64px;padding:8px 0;background-color:#ef951e;cursor:pointer;border:none;font-weight:700;width:100%;font-size:14px;margin:16px auto 0;max-width:344px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.SlidersDynamicComponent, selector: "ws-widget-sliders-dynamic", inputs: ["widgetData", "baseContentReadData"] }] }); }
195
237
  }
196
238
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: KarmaPointsComponent, decorators: [{
197
239
  type: Component,
198
- args: [{ selector: 'ws-widget-karma-points', template: "<ng-container *ngIf=\"!disableKarmaPoints\">\n <ws-widget-sliders-dynamic [widgetData]=\"karmaPointsSlider\"></ws-widget-sliders-dynamic>\n\n <ng-container *ngIf=\"btnCategory === 'claim'\">\n <button class=\"flex flex-wrap gap-1 claim-button\" (click)=\"onClickOfClaim()\" >\n <img src=\"/assets/icons/home/karma-badge.svg\" width=\"28px\" class=\"mr-2\" alt=\"karma-points image\" />\n <div *ngIf=\"btnKPData?.textBeforeIcon\">{{ btnKPData.textBeforeIcon }}</div>\n <div *ngIf=\"btnKPData.points\">{{ btnKPData.points }} {{ translateLabels(btnKPData.textAfterPoints, 'appKarmapointsPanel') }}</div>\n <div *ngIf=\"btnKPData?.textAfterIcon\">{{ translateLabels(btnKPData.textAfterIcon, 'appKarmapointsPanel') }}</div>\n </button>\n </ng-container> \n</ng-container>", styles: [".claim-button{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:2px;text-align:center;color:#fff!important;border-radius:64px;padding:8px 0;background-color:#ef951e;cursor:pointer;border:none;font-weight:700;width:100%;font-size:14px;margin:16px auto 0;max-width:344px}\n"] }]
240
+ args: [{ selector: 'ws-widget-karma-points', template: "<ng-container *ngIf=\"!disableKarmaPoints\">\n <ws-widget-sliders-dynamic [widgetData]=\"karmaPointsSlider\" [baseContentReadData] = \"baseContentReadData\"></ws-widget-sliders-dynamic>\n\n <ng-container *ngIf=\"btnCategory === 'claim'\">\n <button class=\"flex flex-wrap gap-1 claim-button\" (click)=\"onClickOfClaim()\" >\n <img src=\"/assets/icons/home/karma-badge.svg\" width=\"28px\" class=\"mr-2\" alt=\"karma-points image\" />\n <div *ngIf=\"btnKPData?.textBeforeIcon\">{{ btnKPData.textBeforeIcon }}</div>\n <div *ngIf=\"btnKPData.points\">{{ btnKPData.points }} {{ translateLabels(btnKPData.textAfterPoints, 'appKarmapointsPanel') }}</div>\n <div *ngIf=\"btnKPData?.textAfterIcon\">{{ translateLabels(btnKPData.textAfterIcon, 'appKarmapointsPanel') }}</div>\n </button>\n </ng-container> \n</ng-container>", styles: [".claim-button{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:2px;text-align:center;color:#fff!important;border-radius:64px;padding:8px 0;background-color:#ef951e;cursor:pointer;border:none;font-weight:700;width:100%;font-size:14px;margin:16px auto 0;max-width:344px}\n"] }]
199
241
  }], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: i2.MultilingualTranslationsService }]; }, propDecorators: { content: [{
200
242
  type: Input
201
243
  }], data: [{
@@ -204,9 +246,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
204
246
  type: Input
205
247
  }], condition: [{
206
248
  type: Input
249
+ }], baseContentReadData: [{
250
+ type: Input
207
251
  }], clickClaimKarmaPoints: [{
208
252
  type: Output
209
253
  }], btnCategory: [{
210
254
  type: Input
211
255
  }] } });
212
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"karma-points.component.js","sourceRoot":"","sources":["../../../../../../../../../library/sunbird-cb/toc/src/lib/_collection/_common/content-toc/karma-points/karma-points.component.ts","../../../../../../../../../library/sunbird-cb/toc/src/lib/_collection/_common/content-toc/karma-points/karma-points.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, OnChanges, SimpleChanges } from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\n\nimport { MultilingualTranslationsService, NsContent } from '@sunbird-cb/utils-v2'\n\n@Component({\n  selector: 'ws-widget-karma-points',\n  templateUrl: './karma-points.component.html',\n  styleUrls: ['./karma-points.component.scss'],\n})\n\nexport class KarmaPointsComponent implements OnInit, OnChanges {\n  kpArray: any[] = []\n  constructor(\n    private translate: TranslateService,\n    private langTranslations: MultilingualTranslationsService\n  ) {\n    if (localStorage.getItem('websiteLanguage')) {\n      this.translate.setDefaultLang('en')\n      const lang = localStorage.getItem('websiteLanguage')!\n      this.translate.use(lang)\n    }\n  }\n\n  @Input() content: NsContent.IContent | null = null\n  @Input() data: any = []\n  @Input() pCategory = ''\n  @Input() condition: any\n  @Output() clickClaimKarmaPoints = new EventEmitter<string>()\n  kpData: any\n  @Input() btnCategory = ''\n  karmaPointsSlider: any\n  btnKPData: any\n  disableKarmaPoints = false\n\n  ngOnInit() {\n    this.constructNudgeData()\n\n    if (this.content && this.content.courseCategory === NsContent.ECourseCategory.CASE_STUDY) {\n      this.disableKarmaPoints = true\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.condition = changes.condition && changes.condition.currentValue || null\n    if (!this.condition) { return }\n    if (this.condition && !this.condition.event) {\n      // For TOC karma points\n      if (!this.condition.isPostAssessment && (this.condition.content && this.condition.content.hasOwnProperty('completionPercentage')\n        && !this.condition.content.completionPercentage\n        || (this.condition.content && this.condition.content.completionPercentage < 100))\n        && !this.condition.certData) {\n        if (this.condition.isAcbpClaim) {\n          this.getKPData('ACBP')\n        }\n\n        if (this.condition.content.primaryCategory === this.condition.primaryCategory.COURSE) {\n          if (!this.condition.isAcbpClaim && !this.condition.monthlyCapExceed) {\n            this.getKPData('Resume')\n          } else if ( this.content.courseCategory === 'Learning Pathway' ) {\n            this.getKPData('Resume')\n          \n          }\n        }\n      }\n\n      if (this.condition && !this.condition.isPostAssessment\n        && ((this.condition.content && this.condition.content.completionPercentage === 100)\n          || this.condition.certData)) {\n        if (this.condition.isAcbpCourse && this.condition.isAcbpClaim && !this.condition.isClaimed) {\n          this.getKPData('ACBP CLAIM')\n          this.btnCategory = 'claim'\n        }\n\n        if (this.condition.content.primaryCategory === this.condition.primaryCategory.COURSE) {\n          if (this.condition && !this.condition.isAcbpCourse && !this.condition.monthlyCapExceed) {\n            this.getKPData('Start again')\n          }\n\n          if (!this.condition.isAcbpCourse && this.condition.monthlyCapExceed && !this.condition.isCompletedThisMonth) {\n            this.getKPData('Start again')\n          }\n        }\n      }\n\n      if (this.condition && this.condition.isPostAssessment\n        && this.condition.showTakeAssessment\n        && this.condition.showTakeAssessment.post_assessment) {\n        this.getKPData('Take Assessment')\n      }\n\n      if (this.condition && (this.condition.content\n        && this.condition.content.primaryCategory) !== this.condition.primaryCategory.RESOURCE\n        && !this.condition.enrollBtnLoading) {\n        if (this.condition.isAcbpCourse) {\n          this.getKPData('ACBP')\n        }\n\n        if (!this.condition.isAcbpCourse && !this.condition.monthlyCapExceed &&\n          this.condition.userEnrollmentList && !this.condition.userEnrollmentList.length) {\n          this.getKPData('Enroll')\n        }\n      }\n\n      if (this.condition && !this.condition.isPostAssessment\n        && (this.condition.content && this.condition.content.hasOwnProperty('completionPercentage')\n          && !this.condition.content.completionPercentage\n          || (this.condition.content && this.condition.content.completionPercentage < 100))) {\n\n        if (this.condition.isAcbpClaim) {\n          this.getKPData('ACBP')\n        }\n\n        if (this.condition.content.primaryCategory === this.condition.primaryCategory.COURSE) {\n          if (!this.condition.isAcbpClaim && !this.condition.monthlyCapExceed) {\n            this.getKPData('Resume')\n          }\n        }\n      }\n\n      if (this.condition && !this.condition.isPostAssessment\n        && (this.condition.content && this.condition.content.completionPercentage === 100)) {\n        if (this.condition.isAcbpCourse && this.condition.isAcbpClaim && !this.condition.isClaimed) {\n          this.getKPData('ACBP CLAIM')\n          this.btnCategory = 'claim'\n        }\n\n        if (this.condition.content.primaryCategory === this.condition.primaryCategory.COURSE) {\n          if (!this.condition.isAcbpCourse && !this.condition.monthlyCapExceed) {\n            this.getKPData('Start again')\n          }\n\n          if (!this.condition.isAcbpCourse && this.condition.monthlyCapExceed && !this.condition.isCompletedThisMonth) {\n            this.getKPData('Start again')\n          }\n        }\n      }\n      if (this.condition && this.condition.isPostAssessment && this.condition.showTakeAssessment\n        && this.condition.showTakeAssessment.post_assessment) {\n        this.getKPData('Take Assessment')\n      }\n\n      if (this.condition && this.condition.resumeData) {\n        if (!this.condition.userRating) {\n          this.getKPData('Rate this course')\n        }\n\n        if (this.condition.userRating) {\n          this.getKPData('Edit rating')\n        }\n      }\n    } else {\n      // For event karma points\n      if (this.condition && !this.condition.completedAfterExpiry) {\n        if (this.condition && this.condition.isEnrolled) {\n          if (this.condition.currentEvent) {\n            this.getKPData('Complete')\n          }\n\n          if (this.condition.pastEvent && this.condition.enrolledEvent) {\n            if (this.condition.enrolledEvent.status < 2) {\n              this.getKPData('')\n            }\n            if (this.condition.enrolledEvent.status === 2) {\n              this.getKPData('completed')\n            }\n          }\n        }\n\n        if (this.condition && !this.condition.isEnrolled) {\n          if (this.condition.currentEvent) {\n            this.getKPData('Complete')\n          }\n        }\n      }\n    }\n  }\n\n  getKPData(btnType: string): void {\n    this.data?.forEach((item: any) => {\n      if (item.displayButton === btnType && item.displayButton !== 'ACBP CLAIM') {\n        this.kpData = item\n        if (this.kpArray.findIndex((_obj: any) => _obj.displayButton === item.displayButton) === -1) {\n          this.kpArray.push(this.kpData)\n        }\n      }\n      if (item.displayButton === 'ACBP CLAIM') {\n        this.btnKPData = item\n      }\n    })\n  }\n\n  onClickOfClaim() {\n    this.clickClaimKarmaPoints.emit('claim')\n    this.btnCategory = ''\n  }\n\n  constructNudgeData() {\n    const nudgeData: any = {\n      type: 'karma-points',\n      iconsDisplay: false,\n      cardClass: 'slider-container',\n      height: 'auto',\n      width: '',\n      sliderData: [],\n      negativeDisplay: false,\n      'dot-default': 'dot-grey',\n      'dot-active': 'dot-active',\n    }\n\n    nudgeData.sliderData = []\n    nudgeData.sliderData = this.kpArray\n    this.karmaPointsSlider = nudgeData\n  }\n\n  getDynamicText(helText: string) {\n    if (this.pCategory !== '') {\n      return helText.replace('course', this.pCategory.toLowerCase())\n    }\n    return helText\n  }\n\n  translateLabels(label: string, type: any) {\n    return this.langTranslations.translateLabelWithoutspace(label, type, '')\n  }\n\n}\n","<ng-container *ngIf=\"!disableKarmaPoints\">\n    <ws-widget-sliders-dynamic [widgetData]=\"karmaPointsSlider\"></ws-widget-sliders-dynamic>\n\n    <ng-container *ngIf=\"btnCategory === 'claim'\">\n        <button class=\"flex flex-wrap gap-1 claim-button\" (click)=\"onClickOfClaim()\" >\n            <img src=\"/assets/icons/home/karma-badge.svg\" width=\"28px\" class=\"mr-2\" alt=\"karma-points image\" />\n            <div *ngIf=\"btnKPData?.textBeforeIcon\">{{ btnKPData.textBeforeIcon }}</div>\n            <div *ngIf=\"btnKPData.points\">{{ btnKPData.points }} {{ translateLabels(btnKPData.textAfterPoints, 'appKarmapointsPanel') }}</div>\n            <div *ngIf=\"btnKPData?.textAfterIcon\">{{ translateLabels(btnKPData.textAfterIcon, 'appKarmapointsPanel') }}</div>\n        </button>\n    </ng-container> \n</ng-container>"]}
256
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"karma-points.component.js","sourceRoot":"","sources":["../../../../../../../../../library/sunbird-cb/toc/src/lib/_collection/_common/content-toc/karma-points/karma-points.component.ts","../../../../../../../../../library/sunbird-cb/toc/src/lib/_collection/_common/content-toc/karma-points/karma-points.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, OnChanges, SimpleChanges } from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\n\nimport { MultilingualTranslationsService, NsContent } from '@sunbird-cb/utils-v2'\n\n@Component({\n  selector: 'ws-widget-karma-points',\n  templateUrl: './karma-points.component.html',\n  styleUrls: ['./karma-points.component.scss'],\n})\n\nexport class KarmaPointsComponent implements OnInit, OnChanges {\n  kpArray: any[] = []\n  constructor(\n    private translate: TranslateService,\n    private langTranslations: MultilingualTranslationsService\n  ) {\n    if (localStorage.getItem('websiteLanguage')) {\n      this.translate.setDefaultLang('en')\n      const lang = localStorage.getItem('websiteLanguage')!\n      this.translate.use(lang)\n    }\n  }\n\n  @Input() content: NsContent.IContent | null = null\n  @Input() data: any = []\n  @Input() pCategory = ''\n  @Input() condition: any\n  @Input() baseContentReadData: any\n  @Output() clickClaimKarmaPoints = new EventEmitter<string>()\n  kpData: any\n  @Input() btnCategory = ''\n  karmaPointsSlider: any\n  btnKPData: any\n  disableKarmaPoints = false\n\n  ngOnInit() {\n    this.constructNudgeData()\n\n    if (this.content && this.content.courseCategory === NsContent.ECourseCategory.CASE_STUDY) {\n      this.disableKarmaPoints = true\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.condition = changes.condition && changes.condition.currentValue || null\n    if (!this.condition) { return }\n    if (this.condition && !this.condition.event) {\n      // For TOC karma points\n      if (!this.condition.isPostAssessment && (this.condition.content && this.condition.content.hasOwnProperty('completionPercentage')\n        && !this.condition.content.completionPercentage\n        || (this.condition.content && this.condition.content.completionPercentage < 100))\n        && !this.condition.certData) {\n        if (this.condition.isAcbpClaim) {\n          this.getKPData('ACBP')\n        }\n\n        if (this.condition.content.primaryCategory === this.condition.primaryCategory.COURSE) {\n          if (!this.condition.isAcbpClaim && !this.condition.monthlyCapExceed) {\n            this.getKPData('Resume')\n          } else if ( this.content.courseCategory === 'Learning Pathway' ) {\n            this.getKPData('Resume')\n          \n          }\n        }\n      }\n\n      if (this.condition && !this.condition.isPostAssessment\n        && ((this.condition.content && this.condition.content.completionPercentage === 100)\n          || this.condition.certData)) {\n        if (this.condition.isAcbpCourse && this.condition.isAcbpClaim && !this.condition.isClaimed) {\n          this.getKPData('ACBP CLAIM')\n          this.btnCategory = 'claim'\n        }\n\n        if (this.condition.content.primaryCategory === this.condition.primaryCategory.COURSE) {\n          if (this.condition && !this.condition.isAcbpCourse && !this.condition.monthlyCapExceed) {\n            this.getKPData('Start again')\n          }\n\n          if (!this.condition.isAcbpCourse && this.condition.monthlyCapExceed && !this.condition.isCompletedThisMonth) {\n            this.getKPData('Start again')\n          }\n        }\n      }\n\n      if (this.condition && this.condition.isPostAssessment\n        && this.condition.showTakeAssessment\n        && this.condition.showTakeAssessment.post_assessment) {\n        this.getKPData('Take Assessment')\n      }\n\n      if (this.condition && (this.condition.content\n        && this.condition.content.primaryCategory) !== this.condition.primaryCategory.RESOURCE\n        && !this.condition.enrollBtnLoading) {\n        if (this.condition.isAcbpCourse) {\n          this.getKPData('ACBP')\n        }\n\n        if (!this.condition.isAcbpCourse && !this.condition.monthlyCapExceed &&\n          this.condition.userEnrollmentList && !this.condition.userEnrollmentList.length) {\n          this.getKPData('Enroll')\n        }\n      }\n\n      if (this.condition && !this.condition.isPostAssessment\n        && (this.condition.content && this.condition.content.hasOwnProperty('completionPercentage')\n          && !this.condition.content.completionPercentage\n          || (this.condition.content && this.condition.content.completionPercentage < 100))) {\n\n        if (this.condition.isAcbpClaim) {\n          this.getKPData('ACBP')\n        }\n\n        if (this.condition.content.primaryCategory === this.condition.primaryCategory.COURSE) {\n          if (!this.condition.isAcbpClaim && !this.condition.monthlyCapExceed) {\n            this.getKPData('Resume')\n          }\n        }\n      }\n\n      if (this.condition && !this.condition.isPostAssessment\n        && (this.condition.content && this.condition.content.completionPercentage === 100)) {\n        if (this.condition.isAcbpCourse && this.condition.isAcbpClaim && !this.condition.isClaimed) {\n          this.getKPData('ACBP CLAIM')\n          this.btnCategory = 'claim'\n        }\n\n        if (this.condition.content.primaryCategory === this.condition.primaryCategory.COURSE) {\n          if (!this.condition.isAcbpCourse && !this.condition.monthlyCapExceed) {\n            this.getKPData('Start again')\n          }\n\n          if (!this.condition.isAcbpCourse && this.condition.monthlyCapExceed && !this.condition.isCompletedThisMonth) {\n            this.getKPData('Start again')\n          }\n        }\n      }\n      if (this.condition && this.condition.isPostAssessment && this.condition.showTakeAssessment\n        && this.condition.showTakeAssessment.post_assessment) {\n        this.getKPData('Take Assessment')\n      }\n\n      if (this.condition && this.condition.resumeData) {\n        if (!this.condition.userRating) {\n          this.getKPData('Rate this course')\n        }\n\n        if (this.condition.userRating) {\n          this.getKPData('Edit rating')\n        }\n      }\n    } else {\n      // For event karma points\n      if (this.condition && !this.condition.completedAfterExpiry) {\n        if (this.condition && this.condition.isEnrolled) {\n          if (this.condition.currentEvent) {\n            this.getKPData('Complete')\n          }\n\n          if (this.condition.pastEvent && this.condition.enrolledEvent) {\n            if (this.condition.enrolledEvent.status < 2) {\n              this.getKPData('')\n            }\n            if (this.condition.enrolledEvent.status === 2) {\n              this.getKPData('completed')\n            }\n          }\n        }\n\n        if (this.condition && !this.condition.isEnrolled) {\n          if (this.condition.currentEvent) {\n            this.getKPData('Complete')\n          }\n        }\n      }\n    }\n    this.addBadgeSlide()\n  }\n\n  getKPData(btnType: string): void {\n    this.data?.forEach((item: any) => {\n      if (item.displayButton === btnType && item.displayButton !== 'ACBP CLAIM') {\n        this.kpData = item\n        if (this.kpArray.findIndex((_obj: any) => _obj.displayButton === item.displayButton) === -1) {\n          this.kpArray.push(this.kpData)\n        }\n      }\n      if (item.displayButton === 'ACBP CLAIM') {\n        this.btnKPData = item\n      }\n    })\n  }\naddBadgeSlide() {\n\n  const badgeDetails = this.baseContentReadData?.badgeDetails_v1\n\n  if (!badgeDetails || !badgeDetails.length) {\n    return\n  }\n\n  const badge = badgeDetails[0]\n\n  if (!badge.badgeEarningDateEnabled) {\n    return\n  }\n\n  const badgeTime = badge.badgeEarningDateTime\n  const currentTime = Date.now()\n\n  const badgeDateIST = new Date(badgeTime).toLocaleString('en-IN', {\n    timeZone: 'Asia/Kolkata',\n  })\n\n  console.log('Badge IST Time:', badgeDateIST)\n  const isEligibleslide = this?.content?.completionPercentage == undefined ||  this?.content?.completionPercentage < 100\n  const badgeSlide = {\n    displayButton: 'Quick Learner Badge',\n    textBeforeIcon: this.content.courseCategory == \"Curated Program\" ? badge?.criteria == \"partialRandomCompletion\" ? `By partially completing this program, earn Quick learner Badge (Any ${badge?.requiredCourseCompletions} course needed)` : 'By completing this course earn Quick learner Badge' : 'By completing this course earn Quick learner Badge',\n    points: '',\n    textAfterPoints: '',\n    toolTipText: 'quickLearnerBadgeTip',\n  }\n\nconst badgeExists = this.kpArray.find(\n  (item: any) => item.displayButton === 'Quick Learner Badge'\n)\n\n  if (isEligibleslide) {\n    if (badge?.badgeEarningDateEnabled === true ) {\n    if (badgeTime > currentTime) {\n      if (!badgeExists) {\n        this.kpArray.push(badgeSlide)\n        this.constructNudgeData()\n      }\n    }\n  } else {\n    if (!badgeExists) {\n      this.kpArray.push(badgeSlide)\n      this.constructNudgeData()\n    }\n  }\n  }\n  \n}\n  onClickOfClaim() {\n    this.clickClaimKarmaPoints.emit('claim')\n    this.btnCategory = ''\n  }\n\n  constructNudgeData() {\n    const nudgeData: any = {\n      type: 'karma-points',\n      iconsDisplay: false,\n      cardClass: 'slider-container',\n      height: 'auto',\n      width: '',\n      sliderData: [],\n      negativeDisplay: false,\n      'dot-default': 'dot-grey',\n      'dot-active': 'dot-active',\n    }\n\n    nudgeData.sliderData = []\n    nudgeData.sliderData = this.kpArray\n    this.karmaPointsSlider = nudgeData\n  }\n\n  getDynamicText(helText: string) {\n    if (this.pCategory !== '') {\n      return helText.replace('course', this.pCategory.toLowerCase())\n    }\n    return helText\n  }\n\n  translateLabels(label: string, type: any) {\n    return this.langTranslations.translateLabelWithoutspace(label, type, '')\n  }\n\n}\n","<ng-container *ngIf=\"!disableKarmaPoints\">\n    <ws-widget-sliders-dynamic [widgetData]=\"karmaPointsSlider\" [baseContentReadData] = \"baseContentReadData\"></ws-widget-sliders-dynamic>\n\n    <ng-container *ngIf=\"btnCategory === 'claim'\">\n        <button class=\"flex flex-wrap gap-1 claim-button\" (click)=\"onClickOfClaim()\" >\n            <img src=\"/assets/icons/home/karma-badge.svg\" width=\"28px\" class=\"mr-2\" alt=\"karma-points image\" />\n            <div *ngIf=\"btnKPData?.textBeforeIcon\">{{ btnKPData.textBeforeIcon }}</div>\n            <div *ngIf=\"btnKPData.points\">{{ btnKPData.points }} {{ translateLabels(btnKPData.textAfterPoints, 'appKarmapointsPanel') }}</div>\n            <div *ngIf=\"btnKPData?.textAfterIcon\">{{ translateLabels(btnKPData.textAfterIcon, 'appKarmapointsPanel') }}</div>\n        </button>\n    </ng-container> \n</ng-container>"]}
@@ -23,6 +23,7 @@ export class SlidersDynamicComponent {
23
23
  }
24
24
  }
25
25
  ngOnInit() {
26
+ console.log('widgetData', this.widgetData, this?.baseContentReadData);
26
27
  this.reInitiateSlideInterval();
27
28
  }
28
29
  reInitiateSlideInterval() {
@@ -98,15 +99,17 @@ export class SlidersDynamicComponent {
98
99
  return this.langTranslations.translateLabelWithoutspace(label, type, '');
99
100
  }
100
101
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SlidersDynamicComponent, deps: [{ token: i1.EventService }, { token: i2.TranslateService }, { token: i1.MultilingualTranslationsService }], target: i0.ɵɵFactoryTarget.Component }); }
101
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SlidersDynamicComponent, selector: "ws-widget-sliders-dynamic", inputs: { widgetData: "widgetData" }, host: { properties: { "id": "this.id" } }, ngImport: i0, template: "<div class=\"banner-container\" (swipeleft)=\"slideTo(currentIndex + 1)\" [ngClass]=\"widgetData?.cardClass\" (swiperight)=\"slideTo(currentIndex - 1)\" [ngStyle]=\"{'min-height': widgetData?.height}\" *ngIf=\"widgetData?.sliderData?.length > 0\">\n <ng-container *ngIf=\"widgetData.type === 'image'\">\n <a (click)=\"raiseTelemetry(widgetData.sliderData[currentIndex].redirectUrl)\"\n [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-overlay\"\n [ngClass]=\"{'cursor-auto': !widgetData.sliderData[currentIndex].redirectUrl}\">\n <div class=\"banner WidgetInstanceId\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n <img i18n-alt alt=\"Page Banner\" [src]=\"slide.banners\" wsUtilsImageResponsive class=\"banner-image\" />\n </div>\n </a>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.type === 'data'\">\n <div class=\"banner WidgetInstanceId flex margin-bottom-xs\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n <div class=\"banner-data flex margin-right-m \">\n {{ widgetData.sliderData[currentIndex].title }}\n </div>\n <div class=\"flex data-analysis flex-middle\" [ngClass]=\"widgetData.sliderData[currentIndex].colorData\" *ngIf=\"widgetData.sliderData[currentIndex].data\">\n <mat-icon class=\"icon-stats\">{{ widgetData.sliderData[currentIndex].icon }}</mat-icon>\n <p class=\"margin-remove text-no-wrap\">{{ widgetData.sliderData[currentIndex].data }}</p>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData?.type === 'tips'\">\n <ng-container *ngFor=\"let slide of widgetData?.sliderData; let i = index\">\n <div class=\"tips banner WidgetInstanceId flex margin-bottom-xs\" [hidden]=\"i !== currentIndex\">\n <div class=\"banner-data flex margin-right-m\">\n {{i + 1}}. {{ slide }}\n </div>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.type === 'karma-points'\">\n <div class=\"flex flex-row items-center gap-2 mb-4\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n <img src=\"/assets/icons/home/karma-badge.svg\" width=\"28px\" alt=\"karma-points image\" />\n <div class=\"text-xs\">\n <span *ngIf=\"slide?.textBeforeIcon\">{{ translateLabels(slide?.textBeforeIcon, 'appKarmapointsPanel') }}</span>&nbsp;\n <span *ngIf=\"slide?.points\" class=\"font-bold\">{{ slide?.points }} {{ translateLabels(slide?.textAfterPoints,\n 'appKarmapointsPanel') }}</span>&nbsp;\n <span *ngIf=\"slide?.textAfterIcon\">{{ translateLabels(slide?.textAfterIcon, 'appKarmapointsPanel') }}</span>\n </div>\n <mat-icon class=\"cursor-pointer ws-mat-black60-text info-icon\" [matTooltip]=\"translateLabels(slide?.toolTipText, 'appKarmapointsPanel')\"\n *ngIf=\"slide?.toolTipText\">info_outline</mat-icon>\n </div>\n </ng-container>\n\n <ng-container>\n <div class=\"banner-meta\">\n <ng-container *ngIf=\"widgetData.type === 'image'\">\n <a [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-title text-truncate\"\n *ngIf=\"widgetData.sliderData[currentIndex].title\" [title]=\"widgetData.sliderData[currentIndex].title\">\n {{ widgetData.sliderData[currentIndex].title }}\n </a>\n </ng-container>\n\n <div class=\"dots-container\" *ngIf=\"widgetData.sliderData?.length > 1\">\n <span class=\"dot\" [ngClass]=\"{ active: j === currentIndex, 'dot-active': j === currentIndex, 'dot-grey': j !== currentIndex }\" *ngFor=\"let slide of widgetData.sliderData; let j = index\" (click)=\"slideTo(j)\"></span>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.iconsDisplay\">\n <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"prev\" (click)=\"slideTo(currentIndex - 1)\">&#10094;</a>\n <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"next\" (click)=\"slideTo(currentIndex + 1)\">&#10095;</a>\n </ng-container>\n\n</div>\n", styles: [".banner-container{min-height:243px;overflow:hidden;position:relative;margin:auto;border-radius:12px}.banner-overlay{z-index:1;top:0;left:0;width:100%;height:100%;background:linear-gradient(to left,#00000040,#0000 15% 85%,#00000040)}.banner{-webkit-animation-name:fade;-webkit-animation-duration:1.5s;animation-name:fade;animation-duration:1.5s;min-height:50px}.banner .banner-image{width:100%;min-height:243px;display:block;border-radius:12px}.tips{min-height:30px}.banner-meta{text-align:center;z-index:2;padding:4px 8px;position:absolute;bottom:0;left:50%;border-radius:12px;transform:translate(-50%);box-sizing:border-box}.banner-meta .banner-title{color:#f2f2f2;margin-bottom:4px;font-size:1.1rem}.banner-meta .dots-container{padding:4px;display:flex;align-items:center;justify-content:center}.banner-meta .dots-container .dot{cursor:pointer;height:4px;width:4px;margin:0 6px;background-color:#d3d3d3;box-shadow:1px 1px 4px #0009;border-radius:50%;display:inline-block;transition:background-color .5s ease!important}.banner-meta .dots-container .dot.active{background-color:#f0f0f0;height:5px;width:5px}@keyframes fade{0%{opacity:.25}to{opacity:1}}.prev,.next{cursor:pointer;position:absolute;top:50%;transform:translateY(-50%);padding:16px;color:#fff;font-weight:700;font-size:24px;z-index:2;border-radius:0 3px 3px 0}.next{right:0;border-radius:3px 0 0 3px}.banner-container-solo{overflow:hidden;margin:auto;border-radius:12px}.banner-image-solo{width:100%;display:block;border-radius:12px}.banner-data{opacity:1;color:#000000de;font-family:Lato-Regular;font-size:.75rem;font-weight:400;font-style:normal;letter-spacing:.25px;text-align:left;line-height:16px}.color-green{color:#1d8923}.color-red{color:#c41112}.data-analysis{opacity:1;font-family:Lato-Regular;font-size:.75rem;font-weight:400;font-style:normal;letter-spacing:.21px;text-align:left;line-height:16px}.data-analysis mat-icon{width:18px;height:18px;font-size:1.2rem}.dot-grey{opacity:.2;background-color:#1b2133!important;width:4px!important;height:4px!important;box-shadow:unset!important}.dot-active{width:8px!important;height:4px!important;border-radius:2px!important;opacity:1;background-color:#f3962f!important;box-shadow:unset!important}.slider-container{background:#ef951e29!important;padding:16px}.text-no-wrap{text-wrap:nowrap;margin-top:4px!important}.icon-stats{margin-right:4px}.info-icon{width:16px;height:16px;font-size:16px}.cursor-auto{cursor:auto}.flex{display:flex}.flex-middle{align-items:center}.flex-row{flex-direction:row}.items-center{align-items:center}.gap-2{gap:.5rem}.mb-4{margin-bottom:1rem}.text-xs{font-size:.75rem}.font-bold{font-weight:700}.margin-bottom-xs{margin-bottom:4px}.margin-right-m{margin-right:16px}.margin-remove{margin:0}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cursor-pointer{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i1.ImageResponsiveDirective, selector: "[wsUtilsImageResponsive]", inputs: ["src"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i6.MatLegacyTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] }); }
102
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SlidersDynamicComponent, selector: "ws-widget-sliders-dynamic", inputs: { widgetData: "widgetData", baseContentReadData: "baseContentReadData" }, host: { properties: { "id": "this.id" } }, ngImport: i0, template: "<div class=\"banner-container\" (swipeleft)=\"slideTo(currentIndex + 1)\" [ngClass]=\"widgetData?.cardClass\" (swiperight)=\"slideTo(currentIndex - 1)\" [ngStyle]=\"{'min-height': widgetData?.height}\" *ngIf=\"widgetData?.sliderData?.length > 0\">\n <ng-container *ngIf=\"widgetData.type === 'image'\">\n <a (click)=\"raiseTelemetry(widgetData.sliderData[currentIndex].redirectUrl)\"\n [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-overlay\"\n [ngClass]=\"{'cursor-auto': !widgetData.sliderData[currentIndex].redirectUrl}\">\n <div class=\"banner WidgetInstanceId\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n <img i18n-alt alt=\"Page Banner\" [src]=\"slide.banners\" wsUtilsImageResponsive class=\"banner-image\" />\n </div>\n </a>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.type === 'data'\">\n <div class=\"banner WidgetInstanceId flex margin-bottom-xs\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n <div class=\"banner-data flex margin-right-m \">\n {{ widgetData.sliderData[currentIndex].title }}\n </div>\n <div class=\"flex data-analysis flex-middle\" [ngClass]=\"widgetData.sliderData[currentIndex].colorData\" *ngIf=\"widgetData.sliderData[currentIndex].data\">\n <mat-icon class=\"icon-stats\">{{ widgetData.sliderData[currentIndex].icon }}</mat-icon>\n <p class=\"margin-remove text-no-wrap\">{{ widgetData.sliderData[currentIndex].data }}</p>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData?.type === 'tips'\">\n <ng-container *ngFor=\"let slide of widgetData?.sliderData; let i = index\">\n <div class=\"tips banner WidgetInstanceId flex margin-bottom-xs\" [hidden]=\"i !== currentIndex\">\n <div class=\"banner-data flex margin-right-m\">\n {{i + 1}}. {{ slide }}\n </div>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.type === 'karma-points'\">\n <div class=\"flex flex-row items-center gap-2 mb-4\" *ngFor=\"let slide of widgetData.sliderData; let i = index\"\n [hidden]=\"i !== currentIndex\">\n <img [src]=\"slide?.displayButton === 'Quick Learner Badge'\n ? '/assets/icons/badges/Medal.svg'\n : '/assets/icons/home/karma-badge.svg'\" width=\"28px\" alt=\"karma-points image\" />\n <div class=\"text-xs\">\n <span *ngIf=\"slide?.textBeforeIcon\">\n {{\n slide?.displayButton === 'Quick Learner Badge'\n ? slide?.textBeforeIcon\n : translateLabels(slide?.textBeforeIcon, 'appKarmapointsPanel')\n }}\n </span>&nbsp;\n <span *ngIf=\"slide?.points\" class=\"font-bold\">{{ slide?.points }} {{ translateLabels(slide?.textAfterPoints,\n 'appKarmapointsPanel') }}</span>&nbsp;\n <span *ngIf=\"slide?.textAfterIcon\">{{ translateLabels(slide?.textAfterIcon, 'appKarmapointsPanel') }}</span>\n </div>\n <mat-icon class=\"cursor-pointer ws-mat-black60-text info-icon\" [matTooltip]=\"translateLabels(slide?.toolTipText, 'appKarmapointsPanel')\"\n *ngIf=\"slide?.toolTipText && slide?.displayButton !== 'Quick Learner Badge'\">info_outline</mat-icon>\n </div>\n </ng-container>\n\n <ng-container>\n <div class=\"banner-meta\">\n <ng-container *ngIf=\"widgetData.type === 'image'\">\n <a [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-title text-truncate\"\n *ngIf=\"widgetData.sliderData[currentIndex].title\" [title]=\"widgetData.sliderData[currentIndex].title\">\n {{ widgetData.sliderData[currentIndex].title }}\n </a>\n </ng-container>\n\n <div class=\"dots-container\" *ngIf=\"widgetData.sliderData?.length > 1\">\n <span class=\"dot\" [ngClass]=\"{ active: j === currentIndex, 'dot-active': j === currentIndex, 'dot-grey': j !== currentIndex }\" *ngFor=\"let slide of widgetData.sliderData; let j = index\" (click)=\"slideTo(j)\"></span>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.iconsDisplay\">\n <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"prev\" (click)=\"slideTo(currentIndex - 1)\">&#10094;</a>\n <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"next\" (click)=\"slideTo(currentIndex + 1)\">&#10095;</a>\n </ng-container>\n\n</div>\n", styles: [".banner-container{min-height:243px;overflow:hidden;position:relative;margin:auto;border-radius:12px}.banner-overlay{z-index:1;top:0;left:0;width:100%;height:100%;background:linear-gradient(to left,#00000040,#0000 15% 85%,#00000040)}.banner{-webkit-animation-name:fade;-webkit-animation-duration:1.5s;animation-name:fade;animation-duration:1.5s;min-height:50px}.banner .banner-image{width:100%;min-height:243px;display:block;border-radius:12px}.tips{min-height:30px}.banner-meta{text-align:center;z-index:2;padding:4px 8px;position:absolute;bottom:0;left:50%;border-radius:12px;transform:translate(-50%);box-sizing:border-box}.banner-meta .banner-title{color:#f2f2f2;margin-bottom:4px;font-size:1.1rem}.banner-meta .dots-container{padding:4px;display:flex;align-items:center;justify-content:center}.banner-meta .dots-container .dot{cursor:pointer;height:4px;width:4px;margin:0 6px;background-color:#d3d3d3;box-shadow:1px 1px 4px #0009;border-radius:50%;display:inline-block;transition:background-color .5s ease!important}.banner-meta .dots-container .dot.active{background-color:#f0f0f0;height:5px;width:5px}@keyframes fade{0%{opacity:.25}to{opacity:1}}.prev,.next{cursor:pointer;position:absolute;top:50%;transform:translateY(-50%);padding:16px;color:#fff;font-weight:700;font-size:24px;z-index:2;border-radius:0 3px 3px 0}.next{right:0;border-radius:3px 0 0 3px}.banner-container-solo{overflow:hidden;margin:auto;border-radius:12px}.banner-image-solo{width:100%;display:block;border-radius:12px}.banner-data{opacity:1;color:#000000de;font-family:Lato-Regular;font-size:.75rem;font-weight:400;font-style:normal;letter-spacing:.25px;text-align:left;line-height:16px}.color-green{color:#1d8923}.color-red{color:#c41112}.data-analysis{opacity:1;font-family:Lato-Regular;font-size:.75rem;font-weight:400;font-style:normal;letter-spacing:.21px;text-align:left;line-height:16px}.data-analysis mat-icon{width:18px;height:18px;font-size:1.2rem}.dot-grey{opacity:.2;background-color:#1b2133!important;width:4px!important;height:4px!important;box-shadow:unset!important}.dot-active{width:8px!important;height:4px!important;border-radius:2px!important;opacity:1;background-color:#f3962f!important;box-shadow:unset!important}.slider-container{background:#ef951e29!important;padding:16px}.text-no-wrap{text-wrap:nowrap;margin-top:4px!important}.icon-stats{margin-right:4px}.info-icon{width:16px;height:16px;font-size:16px}.cursor-auto{cursor:auto}.flex{display:flex}.flex-middle{align-items:center}.flex-row{flex-direction:row}.items-center{align-items:center}.gap-2{gap:.5rem}.mb-4{margin-bottom:1rem}.text-xs{font-size:.75rem}.font-bold{font-weight:700}.margin-bottom-xs{margin-bottom:4px}.margin-right-m{margin-right:16px}.margin-remove{margin:0}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cursor-pointer{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i1.ImageResponsiveDirective, selector: "[wsUtilsImageResponsive]", inputs: ["src"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i6.MatLegacyTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] }); }
102
103
  }
103
104
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SlidersDynamicComponent, decorators: [{
104
105
  type: Component,
105
- args: [{ selector: 'ws-widget-sliders-dynamic', template: "<div class=\"banner-container\" (swipeleft)=\"slideTo(currentIndex + 1)\" [ngClass]=\"widgetData?.cardClass\" (swiperight)=\"slideTo(currentIndex - 1)\" [ngStyle]=\"{'min-height': widgetData?.height}\" *ngIf=\"widgetData?.sliderData?.length > 0\">\n <ng-container *ngIf=\"widgetData.type === 'image'\">\n <a (click)=\"raiseTelemetry(widgetData.sliderData[currentIndex].redirectUrl)\"\n [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-overlay\"\n [ngClass]=\"{'cursor-auto': !widgetData.sliderData[currentIndex].redirectUrl}\">\n <div class=\"banner WidgetInstanceId\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n <img i18n-alt alt=\"Page Banner\" [src]=\"slide.banners\" wsUtilsImageResponsive class=\"banner-image\" />\n </div>\n </a>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.type === 'data'\">\n <div class=\"banner WidgetInstanceId flex margin-bottom-xs\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n <div class=\"banner-data flex margin-right-m \">\n {{ widgetData.sliderData[currentIndex].title }}\n </div>\n <div class=\"flex data-analysis flex-middle\" [ngClass]=\"widgetData.sliderData[currentIndex].colorData\" *ngIf=\"widgetData.sliderData[currentIndex].data\">\n <mat-icon class=\"icon-stats\">{{ widgetData.sliderData[currentIndex].icon }}</mat-icon>\n <p class=\"margin-remove text-no-wrap\">{{ widgetData.sliderData[currentIndex].data }}</p>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData?.type === 'tips'\">\n <ng-container *ngFor=\"let slide of widgetData?.sliderData; let i = index\">\n <div class=\"tips banner WidgetInstanceId flex margin-bottom-xs\" [hidden]=\"i !== currentIndex\">\n <div class=\"banner-data flex margin-right-m\">\n {{i + 1}}. {{ slide }}\n </div>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.type === 'karma-points'\">\n <div class=\"flex flex-row items-center gap-2 mb-4\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n <img src=\"/assets/icons/home/karma-badge.svg\" width=\"28px\" alt=\"karma-points image\" />\n <div class=\"text-xs\">\n <span *ngIf=\"slide?.textBeforeIcon\">{{ translateLabels(slide?.textBeforeIcon, 'appKarmapointsPanel') }}</span>&nbsp;\n <span *ngIf=\"slide?.points\" class=\"font-bold\">{{ slide?.points }} {{ translateLabels(slide?.textAfterPoints,\n 'appKarmapointsPanel') }}</span>&nbsp;\n <span *ngIf=\"slide?.textAfterIcon\">{{ translateLabels(slide?.textAfterIcon, 'appKarmapointsPanel') }}</span>\n </div>\n <mat-icon class=\"cursor-pointer ws-mat-black60-text info-icon\" [matTooltip]=\"translateLabels(slide?.toolTipText, 'appKarmapointsPanel')\"\n *ngIf=\"slide?.toolTipText\">info_outline</mat-icon>\n </div>\n </ng-container>\n\n <ng-container>\n <div class=\"banner-meta\">\n <ng-container *ngIf=\"widgetData.type === 'image'\">\n <a [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-title text-truncate\"\n *ngIf=\"widgetData.sliderData[currentIndex].title\" [title]=\"widgetData.sliderData[currentIndex].title\">\n {{ widgetData.sliderData[currentIndex].title }}\n </a>\n </ng-container>\n\n <div class=\"dots-container\" *ngIf=\"widgetData.sliderData?.length > 1\">\n <span class=\"dot\" [ngClass]=\"{ active: j === currentIndex, 'dot-active': j === currentIndex, 'dot-grey': j !== currentIndex }\" *ngFor=\"let slide of widgetData.sliderData; let j = index\" (click)=\"slideTo(j)\"></span>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.iconsDisplay\">\n <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"prev\" (click)=\"slideTo(currentIndex - 1)\">&#10094;</a>\n <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"next\" (click)=\"slideTo(currentIndex + 1)\">&#10095;</a>\n </ng-container>\n\n</div>\n", styles: [".banner-container{min-height:243px;overflow:hidden;position:relative;margin:auto;border-radius:12px}.banner-overlay{z-index:1;top:0;left:0;width:100%;height:100%;background:linear-gradient(to left,#00000040,#0000 15% 85%,#00000040)}.banner{-webkit-animation-name:fade;-webkit-animation-duration:1.5s;animation-name:fade;animation-duration:1.5s;min-height:50px}.banner .banner-image{width:100%;min-height:243px;display:block;border-radius:12px}.tips{min-height:30px}.banner-meta{text-align:center;z-index:2;padding:4px 8px;position:absolute;bottom:0;left:50%;border-radius:12px;transform:translate(-50%);box-sizing:border-box}.banner-meta .banner-title{color:#f2f2f2;margin-bottom:4px;font-size:1.1rem}.banner-meta .dots-container{padding:4px;display:flex;align-items:center;justify-content:center}.banner-meta .dots-container .dot{cursor:pointer;height:4px;width:4px;margin:0 6px;background-color:#d3d3d3;box-shadow:1px 1px 4px #0009;border-radius:50%;display:inline-block;transition:background-color .5s ease!important}.banner-meta .dots-container .dot.active{background-color:#f0f0f0;height:5px;width:5px}@keyframes fade{0%{opacity:.25}to{opacity:1}}.prev,.next{cursor:pointer;position:absolute;top:50%;transform:translateY(-50%);padding:16px;color:#fff;font-weight:700;font-size:24px;z-index:2;border-radius:0 3px 3px 0}.next{right:0;border-radius:3px 0 0 3px}.banner-container-solo{overflow:hidden;margin:auto;border-radius:12px}.banner-image-solo{width:100%;display:block;border-radius:12px}.banner-data{opacity:1;color:#000000de;font-family:Lato-Regular;font-size:.75rem;font-weight:400;font-style:normal;letter-spacing:.25px;text-align:left;line-height:16px}.color-green{color:#1d8923}.color-red{color:#c41112}.data-analysis{opacity:1;font-family:Lato-Regular;font-size:.75rem;font-weight:400;font-style:normal;letter-spacing:.21px;text-align:left;line-height:16px}.data-analysis mat-icon{width:18px;height:18px;font-size:1.2rem}.dot-grey{opacity:.2;background-color:#1b2133!important;width:4px!important;height:4px!important;box-shadow:unset!important}.dot-active{width:8px!important;height:4px!important;border-radius:2px!important;opacity:1;background-color:#f3962f!important;box-shadow:unset!important}.slider-container{background:#ef951e29!important;padding:16px}.text-no-wrap{text-wrap:nowrap;margin-top:4px!important}.icon-stats{margin-right:4px}.info-icon{width:16px;height:16px;font-size:16px}.cursor-auto{cursor:auto}.flex{display:flex}.flex-middle{align-items:center}.flex-row{flex-direction:row}.items-center{align-items:center}.gap-2{gap:.5rem}.mb-4{margin-bottom:1rem}.text-xs{font-size:.75rem}.font-bold{font-weight:700}.margin-bottom-xs{margin-bottom:4px}.margin-right-m{margin-right:16px}.margin-remove{margin:0}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cursor-pointer{cursor:pointer}\n"] }]
106
+ args: [{ selector: 'ws-widget-sliders-dynamic', template: "<div class=\"banner-container\" (swipeleft)=\"slideTo(currentIndex + 1)\" [ngClass]=\"widgetData?.cardClass\" (swiperight)=\"slideTo(currentIndex - 1)\" [ngStyle]=\"{'min-height': widgetData?.height}\" *ngIf=\"widgetData?.sliderData?.length > 0\">\n <ng-container *ngIf=\"widgetData.type === 'image'\">\n <a (click)=\"raiseTelemetry(widgetData.sliderData[currentIndex].redirectUrl)\"\n [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-overlay\"\n [ngClass]=\"{'cursor-auto': !widgetData.sliderData[currentIndex].redirectUrl}\">\n <div class=\"banner WidgetInstanceId\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n <img i18n-alt alt=\"Page Banner\" [src]=\"slide.banners\" wsUtilsImageResponsive class=\"banner-image\" />\n </div>\n </a>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.type === 'data'\">\n <div class=\"banner WidgetInstanceId flex margin-bottom-xs\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n <div class=\"banner-data flex margin-right-m \">\n {{ widgetData.sliderData[currentIndex].title }}\n </div>\n <div class=\"flex data-analysis flex-middle\" [ngClass]=\"widgetData.sliderData[currentIndex].colorData\" *ngIf=\"widgetData.sliderData[currentIndex].data\">\n <mat-icon class=\"icon-stats\">{{ widgetData.sliderData[currentIndex].icon }}</mat-icon>\n <p class=\"margin-remove text-no-wrap\">{{ widgetData.sliderData[currentIndex].data }}</p>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData?.type === 'tips'\">\n <ng-container *ngFor=\"let slide of widgetData?.sliderData; let i = index\">\n <div class=\"tips banner WidgetInstanceId flex margin-bottom-xs\" [hidden]=\"i !== currentIndex\">\n <div class=\"banner-data flex margin-right-m\">\n {{i + 1}}. {{ slide }}\n </div>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.type === 'karma-points'\">\n <div class=\"flex flex-row items-center gap-2 mb-4\" *ngFor=\"let slide of widgetData.sliderData; let i = index\"\n [hidden]=\"i !== currentIndex\">\n <img [src]=\"slide?.displayButton === 'Quick Learner Badge'\n ? '/assets/icons/badges/Medal.svg'\n : '/assets/icons/home/karma-badge.svg'\" width=\"28px\" alt=\"karma-points image\" />\n <div class=\"text-xs\">\n <span *ngIf=\"slide?.textBeforeIcon\">\n {{\n slide?.displayButton === 'Quick Learner Badge'\n ? slide?.textBeforeIcon\n : translateLabels(slide?.textBeforeIcon, 'appKarmapointsPanel')\n }}\n </span>&nbsp;\n <span *ngIf=\"slide?.points\" class=\"font-bold\">{{ slide?.points }} {{ translateLabels(slide?.textAfterPoints,\n 'appKarmapointsPanel') }}</span>&nbsp;\n <span *ngIf=\"slide?.textAfterIcon\">{{ translateLabels(slide?.textAfterIcon, 'appKarmapointsPanel') }}</span>\n </div>\n <mat-icon class=\"cursor-pointer ws-mat-black60-text info-icon\" [matTooltip]=\"translateLabels(slide?.toolTipText, 'appKarmapointsPanel')\"\n *ngIf=\"slide?.toolTipText && slide?.displayButton !== 'Quick Learner Badge'\">info_outline</mat-icon>\n </div>\n </ng-container>\n\n <ng-container>\n <div class=\"banner-meta\">\n <ng-container *ngIf=\"widgetData.type === 'image'\">\n <a [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-title text-truncate\"\n *ngIf=\"widgetData.sliderData[currentIndex].title\" [title]=\"widgetData.sliderData[currentIndex].title\">\n {{ widgetData.sliderData[currentIndex].title }}\n </a>\n </ng-container>\n\n <div class=\"dots-container\" *ngIf=\"widgetData.sliderData?.length > 1\">\n <span class=\"dot\" [ngClass]=\"{ active: j === currentIndex, 'dot-active': j === currentIndex, 'dot-grey': j !== currentIndex }\" *ngFor=\"let slide of widgetData.sliderData; let j = index\" (click)=\"slideTo(j)\"></span>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"widgetData.iconsDisplay\">\n <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"prev\" (click)=\"slideTo(currentIndex - 1)\">&#10094;</a>\n <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"next\" (click)=\"slideTo(currentIndex + 1)\">&#10095;</a>\n </ng-container>\n\n</div>\n", styles: [".banner-container{min-height:243px;overflow:hidden;position:relative;margin:auto;border-radius:12px}.banner-overlay{z-index:1;top:0;left:0;width:100%;height:100%;background:linear-gradient(to left,#00000040,#0000 15% 85%,#00000040)}.banner{-webkit-animation-name:fade;-webkit-animation-duration:1.5s;animation-name:fade;animation-duration:1.5s;min-height:50px}.banner .banner-image{width:100%;min-height:243px;display:block;border-radius:12px}.tips{min-height:30px}.banner-meta{text-align:center;z-index:2;padding:4px 8px;position:absolute;bottom:0;left:50%;border-radius:12px;transform:translate(-50%);box-sizing:border-box}.banner-meta .banner-title{color:#f2f2f2;margin-bottom:4px;font-size:1.1rem}.banner-meta .dots-container{padding:4px;display:flex;align-items:center;justify-content:center}.banner-meta .dots-container .dot{cursor:pointer;height:4px;width:4px;margin:0 6px;background-color:#d3d3d3;box-shadow:1px 1px 4px #0009;border-radius:50%;display:inline-block;transition:background-color .5s ease!important}.banner-meta .dots-container .dot.active{background-color:#f0f0f0;height:5px;width:5px}@keyframes fade{0%{opacity:.25}to{opacity:1}}.prev,.next{cursor:pointer;position:absolute;top:50%;transform:translateY(-50%);padding:16px;color:#fff;font-weight:700;font-size:24px;z-index:2;border-radius:0 3px 3px 0}.next{right:0;border-radius:3px 0 0 3px}.banner-container-solo{overflow:hidden;margin:auto;border-radius:12px}.banner-image-solo{width:100%;display:block;border-radius:12px}.banner-data{opacity:1;color:#000000de;font-family:Lato-Regular;font-size:.75rem;font-weight:400;font-style:normal;letter-spacing:.25px;text-align:left;line-height:16px}.color-green{color:#1d8923}.color-red{color:#c41112}.data-analysis{opacity:1;font-family:Lato-Regular;font-size:.75rem;font-weight:400;font-style:normal;letter-spacing:.21px;text-align:left;line-height:16px}.data-analysis mat-icon{width:18px;height:18px;font-size:1.2rem}.dot-grey{opacity:.2;background-color:#1b2133!important;width:4px!important;height:4px!important;box-shadow:unset!important}.dot-active{width:8px!important;height:4px!important;border-radius:2px!important;opacity:1;background-color:#f3962f!important;box-shadow:unset!important}.slider-container{background:#ef951e29!important;padding:16px}.text-no-wrap{text-wrap:nowrap;margin-top:4px!important}.icon-stats{margin-right:4px}.info-icon{width:16px;height:16px;font-size:16px}.cursor-auto{cursor:auto}.flex{display:flex}.flex-middle{align-items:center}.flex-row{flex-direction:row}.items-center{align-items:center}.gap-2{gap:.5rem}.mb-4{margin-bottom:1rem}.text-xs{font-size:.75rem}.font-bold{font-weight:700}.margin-bottom-xs{margin-bottom:4px}.margin-right-m{margin-right:16px}.margin-remove{margin:0}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cursor-pointer{cursor:pointer}\n"] }]
106
107
  }], ctorParameters: function () { return [{ type: i1.EventService }, { type: i2.TranslateService }, { type: i1.MultilingualTranslationsService }]; }, propDecorators: { widgetData: [{
107
108
  type: Input
109
+ }], baseContentReadData: [{
110
+ type: Input
108
111
  }], id: [{
109
112
  type: HostBinding,
110
113
  args: ['id']
111
114
  }] } });
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sliders-dynamic.component.js","sourceRoot":"","sources":["../../../../../../../library/sunbird-cb/toc/src/lib/_collection/sliders-dynamic/sliders-dynamic.component.ts","../../../../../../../library/sunbird-cb/toc/src/lib/_collection/sliders-dynamic/sliders-dynamic.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Input, OnInit } from '@angular/core'\nimport { ICarousel } from './sliders-dynamic.model'\nimport { Subscription, interval } from 'rxjs'\nimport { TranslateService } from '@ngx-translate/core'\nimport { MultilingualTranslationsService, EventService, WsEvents } from '@sunbird-cb/utils-v2'\n\n@Component({\n  selector: 'ws-widget-sliders-dynamic',\n  templateUrl: './sliders-dynamic.component.html',\n  styleUrls: ['./sliders-dynamic.component.scss'],\n})\nexport class SlidersDynamicComponent implements OnInit {\n  @Input() widgetData!: ICarousel\n  @HostBinding('id')\n  public id = `banner_${Math.random()}`\n  currentIndex = 0\n  slideInterval: Subscription | null = null\n\n  constructor(\n    private events: EventService,\n    private translate: TranslateService,\n    private langTranslations: MultilingualTranslationsService) {\n    if (localStorage.getItem('websiteLanguage')) {\n      this.translate.setDefaultLang('en')\n      const lang = localStorage.getItem('websiteLanguage')!\n      this.translate.use(lang)\n    }\n  }\n\n  ngOnInit() {\n    this.reInitiateSlideInterval()\n  }\n\n  reInitiateSlideInterval() {\n    if (this.widgetData && this.widgetData.sliderData && this.widgetData.sliderData.length > 1) {\n      try {\n        if (this.slideInterval) {\n          this.slideInterval.unsubscribe()\n        }\n      } catch (e) {\n      } finally {\n        this.slideInterval = interval(8000).subscribe(() => {\n          if (this.currentIndex === this.widgetData.sliderData.length - 1) {\n            this.currentIndex = 0\n          } else {\n            this.currentIndex += 1\n          }\n        })\n      }\n    }\n  }\n\n  slideTo(index: number) {\n    if (this.widgetData && this.widgetData.sliderData) {\n      if (index >= 0 && index < this.widgetData.sliderData.length) {\n        this.currentIndex = index\n      } else if (index === this.widgetData.sliderData.length) {\n        this.currentIndex = 0\n      } else {\n        this.currentIndex = this.widgetData.sliderData.length + index\n      }\n      this.reInitiateSlideInterval()\n    }\n  }\n\n  get isOpenInNewTab() {\n    if (this.widgetData && this.widgetData.sliderData) {\n      const currentData = this.widgetData.sliderData[this.currentIndex]\n      if (currentData && currentData.redirectUrl && currentData.redirectUrl.includes('mailto') ||\n       this.widgetData.sliderData[this.currentIndex]?.openInNewTab) {\n        return true\n      }\n    }\n    return false\n  }\n\n  openInNewTab() {\n    if (this.widgetData && this.widgetData.sliderData) {\n      const currentData = this.widgetData.sliderData[this.currentIndex]\n      if (currentData && currentData.redirectUrl && currentData.redirectUrl.includes('mailto') ||\n       this.widgetData.sliderData[this.currentIndex]?.openInNewTab) {\n        window.open(currentData.redirectUrl)\n      }\n    }\n  }\n\n  raiseTelemetry(bannerUrl: string | undefined) {\n    this.openInNewTab()\n    const path = window.location.pathname.replace('/', '')\n    const url = path + window.location.search\n\n    this.events.raiseInteractTelemetry(\n      {\n        type: 'click',\n        subType: 'banner',\n      },\n      {\n        pageUrl: url,\n        bannerRedirectUrl: bannerUrl,\n      },\n      {\n        pageIdExt: 'banner',\n        module: WsEvents.EnumTelemetrymodules.CONTENT,\n    })\n  }\n\n  translateLabels(label: string, type: any) {\n    return this.langTranslations.translateLabelWithoutspace(label, type, '')\n  }\n}\n","<div class=\"banner-container\" (swipeleft)=\"slideTo(currentIndex + 1)\" [ngClass]=\"widgetData?.cardClass\" (swiperight)=\"slideTo(currentIndex - 1)\" [ngStyle]=\"{'min-height': widgetData?.height}\" *ngIf=\"widgetData?.sliderData?.length > 0\">\n  <ng-container *ngIf=\"widgetData.type === 'image'\">\n    <a (click)=\"raiseTelemetry(widgetData.sliderData[currentIndex].redirectUrl)\"\n    [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-overlay\"\n    [ngClass]=\"{'cursor-auto': !widgetData.sliderData[currentIndex].redirectUrl}\">\n      <div class=\"banner WidgetInstanceId\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n        <img i18n-alt alt=\"Page Banner\" [src]=\"slide.banners\" wsUtilsImageResponsive class=\"banner-image\" />\n      </div>\n    </a>\n  </ng-container>\n\n  <ng-container *ngIf=\"widgetData.type === 'data'\">\n    <div class=\"banner WidgetInstanceId flex margin-bottom-xs\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n      <div class=\"banner-data flex margin-right-m \">\n        {{ widgetData.sliderData[currentIndex].title }}\n      </div>\n      <div class=\"flex data-analysis flex-middle\" [ngClass]=\"widgetData.sliderData[currentIndex].colorData\" *ngIf=\"widgetData.sliderData[currentIndex].data\">\n        <mat-icon class=\"icon-stats\">{{ widgetData.sliderData[currentIndex].icon }}</mat-icon>\n        <p class=\"margin-remove text-no-wrap\">{{ widgetData.sliderData[currentIndex].data }}</p>\n      </div>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"widgetData?.type === 'tips'\">\n    <ng-container *ngFor=\"let slide of widgetData?.sliderData; let i = index\">\n      <div class=\"tips banner WidgetInstanceId flex margin-bottom-xs\" [hidden]=\"i !== currentIndex\">\n        <div class=\"banner-data flex margin-right-m\">\n          {{i + 1}}. {{ slide }}\n        </div>\n      </div>\n    </ng-container>\n  </ng-container>\n\n  <ng-container *ngIf=\"widgetData.type === 'karma-points'\">\n    <div class=\"flex flex-row items-center gap-2 mb-4\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n      <img src=\"/assets/icons/home/karma-badge.svg\" width=\"28px\" alt=\"karma-points image\" />\n      <div class=\"text-xs\">\n        <span *ngIf=\"slide?.textBeforeIcon\">{{ translateLabels(slide?.textBeforeIcon, 'appKarmapointsPanel') }}</span>&nbsp;\n        <span *ngIf=\"slide?.points\" class=\"font-bold\">{{ slide?.points }} {{ translateLabels(slide?.textAfterPoints,\n        'appKarmapointsPanel') }}</span>&nbsp;\n        <span *ngIf=\"slide?.textAfterIcon\">{{ translateLabels(slide?.textAfterIcon, 'appKarmapointsPanel') }}</span>\n      </div>\n      <mat-icon class=\"cursor-pointer ws-mat-black60-text info-icon\" [matTooltip]=\"translateLabels(slide?.toolTipText, 'appKarmapointsPanel')\"\n        *ngIf=\"slide?.toolTipText\">info_outline</mat-icon>\n    </div>\n  </ng-container>\n\n  <ng-container>\n    <div class=\"banner-meta\">\n      <ng-container *ngIf=\"widgetData.type === 'image'\">\n        <a [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-title text-truncate\"\n        *ngIf=\"widgetData.sliderData[currentIndex].title\" [title]=\"widgetData.sliderData[currentIndex].title\">\n          {{ widgetData.sliderData[currentIndex].title }}\n        </a>\n      </ng-container>\n\n      <div class=\"dots-container\" *ngIf=\"widgetData.sliderData?.length > 1\">\n        <span class=\"dot\" [ngClass]=\"{ active: j === currentIndex, 'dot-active': j === currentIndex, 'dot-grey': j !== currentIndex }\" *ngFor=\"let slide of widgetData.sliderData; let j = index\" (click)=\"slideTo(j)\"></span>\n      </div>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"widgetData.iconsDisplay\">\n    <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"prev\" (click)=\"slideTo(currentIndex - 1)\">&#10094;</a>\n    <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"next\" (click)=\"slideTo(currentIndex + 1)\">&#10095;</a>\n  </ng-container>\n\n</div>\n"]}
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sliders-dynamic.component.js","sourceRoot":"","sources":["../../../../../../../library/sunbird-cb/toc/src/lib/_collection/sliders-dynamic/sliders-dynamic.component.ts","../../../../../../../library/sunbird-cb/toc/src/lib/_collection/sliders-dynamic/sliders-dynamic.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Input, OnInit } from '@angular/core'\nimport { ICarousel } from './sliders-dynamic.model'\nimport { Subscription, interval } from 'rxjs'\nimport { TranslateService } from '@ngx-translate/core'\nimport { MultilingualTranslationsService, EventService, WsEvents } from '@sunbird-cb/utils-v2'\n\n@Component({\n  selector: 'ws-widget-sliders-dynamic',\n  templateUrl: './sliders-dynamic.component.html',\n  styleUrls: ['./sliders-dynamic.component.scss'],\n})\nexport class SlidersDynamicComponent implements OnInit {\n  @Input() widgetData!: ICarousel\n  @Input() baseContentReadData : any;\n  @HostBinding('id')\n  public id = `banner_${Math.random()}`\n  currentIndex = 0\n  slideInterval: Subscription | null = null\n\n  constructor(\n    private events: EventService,\n    private translate: TranslateService,\n    private langTranslations: MultilingualTranslationsService) {\n    if (localStorage.getItem('websiteLanguage')) {\n      this.translate.setDefaultLang('en')\n      const lang = localStorage.getItem('websiteLanguage')!\n      this.translate.use(lang)\n    }\n  }\n\n  ngOnInit() {\n    console.log('widgetData', this.widgetData,this?.baseContentReadData)\n    this.reInitiateSlideInterval()\n  }\n\n  reInitiateSlideInterval() {\n    if (this.widgetData && this.widgetData.sliderData && this.widgetData.sliderData.length > 1) {\n      try {\n        if (this.slideInterval) {\n          this.slideInterval.unsubscribe()\n        }\n      } catch (e) {\n      } finally {\n        this.slideInterval = interval(8000).subscribe(() => {\n          if (this.currentIndex === this.widgetData.sliderData.length - 1) {\n            this.currentIndex = 0\n          } else {\n            this.currentIndex += 1\n          }\n        })\n      }\n    }\n  }\n\n  slideTo(index: number) {\n    if (this.widgetData && this.widgetData.sliderData) {\n      if (index >= 0 && index < this.widgetData.sliderData.length) {\n        this.currentIndex = index\n      } else if (index === this.widgetData.sliderData.length) {\n        this.currentIndex = 0\n      } else {\n        this.currentIndex = this.widgetData.sliderData.length + index\n      }\n      this.reInitiateSlideInterval()\n    }\n  }\n\n  get isOpenInNewTab() {\n    if (this.widgetData && this.widgetData.sliderData) {\n      const currentData = this.widgetData.sliderData[this.currentIndex]\n      if (currentData && currentData.redirectUrl && currentData.redirectUrl.includes('mailto') ||\n       this.widgetData.sliderData[this.currentIndex]?.openInNewTab) {\n        return true\n      }\n    }\n    return false\n  }\n\n  openInNewTab() {\n    if (this.widgetData && this.widgetData.sliderData) {\n      const currentData = this.widgetData.sliderData[this.currentIndex]\n      if (currentData && currentData.redirectUrl && currentData.redirectUrl.includes('mailto') ||\n       this.widgetData.sliderData[this.currentIndex]?.openInNewTab) {\n        window.open(currentData.redirectUrl)\n      }\n    }\n  }\n\n  raiseTelemetry(bannerUrl: string | undefined) {\n    this.openInNewTab()\n    const path = window.location.pathname.replace('/', '')\n    const url = path + window.location.search\n\n    this.events.raiseInteractTelemetry(\n      {\n        type: 'click',\n        subType: 'banner',\n      },\n      {\n        pageUrl: url,\n        bannerRedirectUrl: bannerUrl,\n      },\n      {\n        pageIdExt: 'banner',\n        module: WsEvents.EnumTelemetrymodules.CONTENT,\n    })\n  }\n\n  translateLabels(label: string, type: any) {\n    return this.langTranslations.translateLabelWithoutspace(label, type, '')\n  }\n}\n","<div class=\"banner-container\" (swipeleft)=\"slideTo(currentIndex + 1)\" [ngClass]=\"widgetData?.cardClass\" (swiperight)=\"slideTo(currentIndex - 1)\" [ngStyle]=\"{'min-height': widgetData?.height}\" *ngIf=\"widgetData?.sliderData?.length > 0\">\n  <ng-container *ngIf=\"widgetData.type === 'image'\">\n    <a (click)=\"raiseTelemetry(widgetData.sliderData[currentIndex].redirectUrl)\"\n    [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-overlay\"\n    [ngClass]=\"{'cursor-auto': !widgetData.sliderData[currentIndex].redirectUrl}\">\n      <div class=\"banner WidgetInstanceId\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n        <img i18n-alt alt=\"Page Banner\" [src]=\"slide.banners\" wsUtilsImageResponsive class=\"banner-image\" />\n      </div>\n    </a>\n  </ng-container>\n\n  <ng-container *ngIf=\"widgetData.type === 'data'\">\n    <div class=\"banner WidgetInstanceId flex margin-bottom-xs\" *ngFor=\"let slide of widgetData.sliderData; let i = index\" [hidden]=\"i !== currentIndex\">\n      <div class=\"banner-data flex margin-right-m \">\n        {{ widgetData.sliderData[currentIndex].title }}\n      </div>\n      <div class=\"flex data-analysis flex-middle\" [ngClass]=\"widgetData.sliderData[currentIndex].colorData\" *ngIf=\"widgetData.sliderData[currentIndex].data\">\n        <mat-icon class=\"icon-stats\">{{ widgetData.sliderData[currentIndex].icon }}</mat-icon>\n        <p class=\"margin-remove text-no-wrap\">{{ widgetData.sliderData[currentIndex].data }}</p>\n      </div>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"widgetData?.type === 'tips'\">\n    <ng-container *ngFor=\"let slide of widgetData?.sliderData; let i = index\">\n      <div class=\"tips banner WidgetInstanceId flex margin-bottom-xs\" [hidden]=\"i !== currentIndex\">\n        <div class=\"banner-data flex margin-right-m\">\n          {{i + 1}}. {{ slide }}\n        </div>\n      </div>\n    </ng-container>\n  </ng-container>\n\n  <ng-container *ngIf=\"widgetData.type === 'karma-points'\">\n    <div class=\"flex flex-row items-center gap-2 mb-4\" *ngFor=\"let slide of widgetData.sliderData; let i = index\"\n      [hidden]=\"i !== currentIndex\">\n      <img [src]=\"slide?.displayButton === 'Quick Learner Badge'\n    ? '/assets/icons/badges/Medal.svg'\n    : '/assets/icons/home/karma-badge.svg'\" width=\"28px\" alt=\"karma-points image\" />\n      <div class=\"text-xs\">\n        <span *ngIf=\"slide?.textBeforeIcon\">\n          {{\n          slide?.displayButton === 'Quick Learner Badge'\n          ? slide?.textBeforeIcon\n          : translateLabels(slide?.textBeforeIcon, 'appKarmapointsPanel')\n          }}\n        </span>&nbsp;\n        <span *ngIf=\"slide?.points\" class=\"font-bold\">{{ slide?.points }} {{ translateLabels(slide?.textAfterPoints,\n        'appKarmapointsPanel') }}</span>&nbsp;\n        <span *ngIf=\"slide?.textAfterIcon\">{{ translateLabels(slide?.textAfterIcon, 'appKarmapointsPanel') }}</span>\n      </div>\n      <mat-icon class=\"cursor-pointer ws-mat-black60-text info-icon\" [matTooltip]=\"translateLabels(slide?.toolTipText, 'appKarmapointsPanel')\"\n        *ngIf=\"slide?.toolTipText && slide?.displayButton !== 'Quick Learner Badge'\">info_outline</mat-icon>\n    </div>\n  </ng-container>\n\n  <ng-container>\n    <div class=\"banner-meta\">\n      <ng-container *ngIf=\"widgetData.type === 'image'\">\n        <a [routerLink]=\" !isOpenInNewTab ? widgetData.sliderData[currentIndex].redirectUrl : './'\" class=\"banner-title text-truncate\"\n        *ngIf=\"widgetData.sliderData[currentIndex].title\" [title]=\"widgetData.sliderData[currentIndex].title\">\n          {{ widgetData.sliderData[currentIndex].title }}\n        </a>\n      </ng-container>\n\n      <div class=\"dots-container\" *ngIf=\"widgetData.sliderData?.length > 1\">\n        <span class=\"dot\" [ngClass]=\"{ active: j === currentIndex, 'dot-active': j === currentIndex, 'dot-grey': j !== currentIndex }\" *ngFor=\"let slide of widgetData.sliderData; let j = index\" (click)=\"slideTo(j)\"></span>\n      </div>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"widgetData.iconsDisplay\">\n    <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"prev\" (click)=\"slideTo(currentIndex - 1)\">&#10094;</a>\n    <a *ngIf=\"widgetData.sliderData?.length > 1\" role=\"button\" class=\"next\" (click)=\"slideTo(currentIndex + 1)\">&#10095;</a>\n  </ng-container>\n\n</div>\n"]}
@@ -89,7 +89,7 @@ export function viewerRouteGenerator(id, mimeType, collectionId, collectionType,
89
89
  if (forPreview) {
90
90
  queryParams = { ...queryParams, preview: true };
91
91
  }
92
- if (forcreator) {
92
+ if (forcreator || forPreview) {
93
93
  queryParams = { ...queryParams, editMode: true };
94
94
  }
95
95
  if (ML && MLId) {
@@ -100,4 +100,4 @@ export function viewerRouteGenerator(id, mimeType, collectionId, collectionType,
100
100
  url,
101
101
  };
102
102
  }
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewer-route-util.js","sourceRoot":"","sources":["../../../../../../library/sunbird-cb/toc/src/lib/_services/viewer-route-util.ts"],"names":[],"mappings":"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","sourcesContent":["import { NsContent } from './widget-content.model'\n\nexport const VIEWER_ROUTE_FROM_MIME = (mimeType: NsContent.EMimeTypes) => {\n  switch (mimeType) {\n    case NsContent.EMimeTypes.MP3:\n      return 'audio'\n    case NsContent.EMimeTypes.M4A:\n      return 'audio-native'\n    case NsContent.EMimeTypes.COLLECTION:\n      return 'html'\n    case NsContent.EMimeTypes.CHANNEL:\n    // case 'application/json' as any:\n    //   return 'channel'\n    case NsContent.EMimeTypes.CERTIFICATION:\n      return 'certification'\n    case NsContent.EMimeTypes.HTML_TEXT:\n    case NsContent.EMimeTypes.HTML:\n    case NsContent.EMimeTypes.ZIP:\n      if (window.location.href.includes('mobile/html')) {\n        return 'mobile/html'\n      }\n      return 'html'\n    case NsContent.EMimeTypes.TEXT_WEB:\n      return 'youtube'\n    case NsContent.EMimeTypes.SURVEY:\n      return 'survey'\n    case NsContent.EMimeTypes.IAP:\n      return 'iap'\n    case NsContent.EMimeTypes.ILP_FP:\n      return 'ilp-fp'\n    case NsContent.EMimeTypes.PDF:\n      return 'pdf'\n    case NsContent.EMimeTypes.MP4:\n    case NsContent.EMimeTypes.M3U8:\n      return 'video'\n    case NsContent.EMimeTypes.YOUTUBE:\n      return 'youtube'\n    // return 'html'\n    case NsContent.EMimeTypes.WEB_MODULE:\n      return 'web-module'\n    case NsContent.EMimeTypes.WEB_MODULE_EXERCISE:\n      return 'web-module'\n    case NsContent.EMimeTypes.CLASS_DIAGRAM:\n      return 'class-diagram'\n    case NsContent.EMimeTypes.HANDS_ON:\n      return 'hands-on'\n    case NsContent.EMimeTypes.RDBMS_HANDS_ON:\n      return 'rdbms-hands-on'\n    case NsContent.EMimeTypes.HTML_PICKER:\n      return 'html-picker'\n    case NsContent.EMimeTypes.QUIZ:\n    case NsContent.EMimeTypes.APPLICATION_JSON:\n      return 'quiz'\n    case NsContent.EMimeTypes.PRACTICE_RESOURCE:\n      return 'practice'\n    case NsContent.EMimeTypes.COLLECTION_RESOURCE:\n      return 'resource-collection'\n    case NsContent.EMimeTypes.OFFLINE_SESSION:\n      return 'offline-session'\n    default:\n      return 'html'\n  }\n}\n\nexport function viewerRouteGenerator(\n  id: string,\n  mimeType: NsContent.EMimeTypes,\n  collectionId?: string,\n  collectionType?: string,\n  forPreview = false,\n  primaryCategory?: string,\n  batchId?: string,\n  courseName?: string,\n  ML?: string,\n  MLId?: string,\n): { url: string; queryParams: { [key: string]: any } } {\n  let collId = collectionId\n  let collType = collectionType\n  if (collType && !NsContent.PLAYER_SUPPORTED_COLLECTION_TYPES.includes(collType)) {\n    collId = undefined\n    collType = undefined\n  }\n  const url = `/viewer/${VIEWER_ROUTE_FROM_MIME(mimeType)}/${id}`\n  // tslint:disable-next-line\n  // console.log(url,'========>Route from MIME TYPE<==========')\n  const forcreator = window.location.href.includes('editMode=true')\n  let queryParams = {}\n  if (primaryCategory) {\n    queryParams = {\n      primaryCategory,\n    }\n  }\n  if (collectionId && collectionType) {\n    queryParams = { ...queryParams, collectionId: collId, collectionType: collType }\n  }\n  if (batchId) {\n    queryParams = { ...queryParams, batchId }\n  }\n  if (courseName) {\n    queryParams = { ...queryParams, courseName }\n  }\n  if (forPreview) {\n    queryParams = { ...queryParams, preview: true }\n  }\n  if (forcreator) {\n    queryParams = { ...queryParams, editMode: true }\n  }\n  if( ML && MLId) {\n    queryParams = { ...queryParams, ML, MLId }\n  }\n  return {\n    queryParams,\n    url,\n  }\n}\n"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewer-route-util.js","sourceRoot":"","sources":["../../../../../../library/sunbird-cb/toc/src/lib/_services/viewer-route-util.ts"],"names":[],"mappings":"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","sourcesContent":["import { NsContent } from './widget-content.model'\n\nexport const VIEWER_ROUTE_FROM_MIME = (mimeType: NsContent.EMimeTypes) => {\n  switch (mimeType) {\n    case NsContent.EMimeTypes.MP3:\n      return 'audio'\n    case NsContent.EMimeTypes.M4A:\n      return 'audio-native'\n    case NsContent.EMimeTypes.COLLECTION:\n      return 'html'\n    case NsContent.EMimeTypes.CHANNEL:\n    // case 'application/json' as any:\n    //   return 'channel'\n    case NsContent.EMimeTypes.CERTIFICATION:\n      return 'certification'\n    case NsContent.EMimeTypes.HTML_TEXT:\n    case NsContent.EMimeTypes.HTML:\n    case NsContent.EMimeTypes.ZIP:\n      if (window.location.href.includes('mobile/html')) {\n        return 'mobile/html'\n      }\n      return 'html'\n    case NsContent.EMimeTypes.TEXT_WEB:\n      return 'youtube'\n    case NsContent.EMimeTypes.SURVEY:\n      return 'survey'\n    case NsContent.EMimeTypes.IAP:\n      return 'iap'\n    case NsContent.EMimeTypes.ILP_FP:\n      return 'ilp-fp'\n    case NsContent.EMimeTypes.PDF:\n      return 'pdf'\n    case NsContent.EMimeTypes.MP4:\n    case NsContent.EMimeTypes.M3U8:\n      return 'video'\n    case NsContent.EMimeTypes.YOUTUBE:\n      return 'youtube'\n    // return 'html'\n    case NsContent.EMimeTypes.WEB_MODULE:\n      return 'web-module'\n    case NsContent.EMimeTypes.WEB_MODULE_EXERCISE:\n      return 'web-module'\n    case NsContent.EMimeTypes.CLASS_DIAGRAM:\n      return 'class-diagram'\n    case NsContent.EMimeTypes.HANDS_ON:\n      return 'hands-on'\n    case NsContent.EMimeTypes.RDBMS_HANDS_ON:\n      return 'rdbms-hands-on'\n    case NsContent.EMimeTypes.HTML_PICKER:\n      return 'html-picker'\n    case NsContent.EMimeTypes.QUIZ:\n    case NsContent.EMimeTypes.APPLICATION_JSON:\n      return 'quiz'\n    case NsContent.EMimeTypes.PRACTICE_RESOURCE:\n      return 'practice'\n    case NsContent.EMimeTypes.COLLECTION_RESOURCE:\n      return 'resource-collection'\n    case NsContent.EMimeTypes.OFFLINE_SESSION:\n      return 'offline-session'\n    default:\n      return 'html'\n  }\n}\n\nexport function viewerRouteGenerator(\n  id: string,\n  mimeType: NsContent.EMimeTypes,\n  collectionId?: string,\n  collectionType?: string,\n  forPreview = false,\n  primaryCategory?: string,\n  batchId?: string,\n  courseName?: string,\n  ML?: string,\n  MLId?: string,\n): { url: string; queryParams: { [key: string]: any } } {\n  let collId = collectionId\n  let collType = collectionType\n  if (collType && !NsContent.PLAYER_SUPPORTED_COLLECTION_TYPES.includes(collType)) {\n    collId = undefined\n    collType = undefined\n  }\n  const url = `/viewer/${VIEWER_ROUTE_FROM_MIME(mimeType)}/${id}`\n  // tslint:disable-next-line\n  // console.log(url,'========>Route from MIME TYPE<==========')\n  const forcreator = window.location.href.includes('editMode=true')\n  let queryParams = {}\n  if (primaryCategory) {\n    queryParams = {\n      primaryCategory,\n    }\n  }\n  if (collectionId && collectionType) {\n    queryParams = { ...queryParams, collectionId: collId, collectionType: collType }\n  }\n  if (batchId) {\n    queryParams = { ...queryParams, batchId }\n  }\n  if (courseName) {\n    queryParams = { ...queryParams, courseName }\n  }\n  if (forPreview) {\n    queryParams = { ...queryParams, preview: true }\n  }\n  if (forcreator || forPreview) {\n    queryParams = { ...queryParams, editMode: true }\n  }\n  if( ML && MLId) {\n    queryParams = { ...queryParams, ML, MLId }\n  }\n  return {\n    queryParams,\n    url,\n  }\n}\n"]}