@sunbird-cb/toc 0.0.1-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 (346) hide show
  1. package/esm2022/lib/_collection/_common/ai-tutor/ai-tutor.component.mjs +1169 -0
  2. package/esm2022/lib/_collection/_common/ai-tutor/socket.service.mjs +121 -0
  3. package/esm2022/lib/_collection/_common/attendance-card/attendance-card.component.mjs +55 -0
  4. package/esm2022/lib/_collection/_common/attendance-card/attendance-card.module.mjs +126 -0
  5. package/esm2022/lib/_collection/_common/attendance-helper/attendance-helper.component.mjs +32 -0
  6. package/esm2022/lib/_collection/_common/attendance-helper/attendance-helper.module.mjs +85 -0
  7. package/esm2022/lib/_collection/_common/avatar-photo/avatar-photo.component.mjs +100 -0
  8. package/esm2022/lib/_collection/_common/avatar-photo/avatar-photo.module.mjs +48 -0
  9. package/esm2022/lib/_collection/_common/card-competency/card-competency.component.mjs +58 -0
  10. package/esm2022/lib/_collection/_common/card-competency/card-competency.module.mjs +22 -0
  11. package/esm2022/lib/_collection/_common/card-content-v2/card-content-v2.model.mjs +23 -0
  12. package/esm2022/lib/_collection/_common/certificate-dialog/certificate-dialog.component.mjs +221 -0
  13. package/esm2022/lib/_collection/_common/certificate-dialog/certificate-dialog.module.mjs +96 -0
  14. package/esm2022/lib/_collection/_common/certificate-dialog/svg-to-pdf.component.mjs +48 -0
  15. package/esm2022/lib/_collection/_common/confirm-dialog/confirm-dialog.component.mjs +25 -0
  16. package/esm2022/lib/_collection/_common/confirm-dialog/confirm-dialog.module.mjs +41 -0
  17. package/esm2022/lib/_collection/_common/connection-hover-card/connection-hover-card.component.mjs +89 -0
  18. package/esm2022/lib/_collection/_common/connection-hover-card/connection-hover.module.mjs +42 -0
  19. package/esm2022/lib/_collection/_common/connection-hover-card/connection-hover.servive.mjs +41 -0
  20. package/esm2022/lib/_collection/_common/connection-name/connection-name.component.mjs +78 -0
  21. package/esm2022/lib/_collection/_common/connection-name/connection-name.module.mjs +45 -0
  22. package/esm2022/lib/_collection/_common/connection-name/profile-v2.model.mjs +2 -0
  23. package/esm2022/lib/_collection/_common/content-progress/content-progress.component.mjs +70 -0
  24. package/esm2022/lib/_collection/_common/content-progress/content-progress.module.mjs +28 -0
  25. package/esm2022/lib/_collection/_common/content-rating-v2-dialog/content-rating-v2-dialog.component.mjs +187 -0
  26. package/esm2022/lib/_collection/_common/content-rating-v2-dialog/content-rating-v2-dialog.module.mjs +86 -0
  27. package/esm2022/lib/_collection/_common/content-toc/ai-tutor-confirm-popup/ai-tutor-confirm-popup.component.mjs +31 -0
  28. package/esm2022/lib/_collection/_common/content-toc/app-toc-about/app-toc-about.component.mjs +961 -0
  29. package/esm2022/lib/_collection/_common/content-toc/app-toc-assignment-viewer/app-toc-assignment-viewer.component.mjs +183 -0
  30. package/esm2022/lib/_collection/_common/content-toc/app-toc-assignment-viewerV2/app-toc-assignment-viewerV2.component.mjs +327 -0
  31. package/esm2022/lib/_collection/_common/content-toc/app-toc-batch-assignments/app-toc-batch-assignments.component.mjs +297 -0
  32. package/esm2022/lib/_collection/_common/content-toc/app-toc-content/app-toc-content.component.mjs +304 -0
  33. package/esm2022/lib/_collection/_common/content-toc/app-toc-content-card-v2/app-toc-content-card-v2.component.mjs +1229 -0
  34. package/esm2022/lib/_collection/_common/content-toc/app-toc-content-card-v2-skeleton/app-toc-content-card-v2-skeleton.component.mjs +16 -0
  35. package/esm2022/lib/_collection/_common/content-toc/app-toc-reference-notes/app-toc-reference-notes.component.mjs +43 -0
  36. package/esm2022/lib/_collection/_common/content-toc/app-toc-session-card-new/app-toc-session-card-new.component.mjs +133 -0
  37. package/esm2022/lib/_collection/_common/content-toc/app-toc-sessions-new/app-toc-sessions-new.component.mjs +66 -0
  38. package/esm2022/lib/_collection/_common/content-toc/app-toc-teachers-notes/app-toc-teachers-notes.component.mjs +278 -0
  39. package/esm2022/lib/_collection/_common/content-toc/content-services/handle-claim.service.mjs +21 -0
  40. package/esm2022/lib/_collection/_common/content-toc/content-services/review-component-data.service.mjs +21 -0
  41. package/esm2022/lib/_collection/_common/content-toc/content-toc.component.mjs +833 -0
  42. package/esm2022/lib/_collection/_common/content-toc/content-toc.module.mjs +224 -0
  43. package/esm2022/lib/_collection/_common/content-toc/karma-points/karma-points.component.mjs +212 -0
  44. package/esm2022/lib/_collection/_common/content-toc/karma-points/karma-points.module.mjs +26 -0
  45. package/esm2022/lib/_collection/_common/content-toc/pipes/replace-nbsp.pipe.mjs +19 -0
  46. package/esm2022/lib/_collection/_common/content-toc/pipes/truncate.pipe.mjs +23 -0
  47. package/esm2022/lib/_collection/_common/content-toc/reviews-content/reviews-content.component.mjs +113 -0
  48. package/esm2022/lib/_collection/_common/content-toc/samuhik-charcha-content/samuhik-charcha-content/samuhik-charcha-content.component.mjs +110 -0
  49. package/esm2022/lib/_collection/_common/display-content-type/display-content-type.component.mjs +26 -0
  50. package/esm2022/lib/_collection/_common/display-content-type/display-content-type.module.mjs +19 -0
  51. package/esm2022/lib/_collection/_common/display-content-type-icon/display-content-type-icon.component.mjs +67 -0
  52. package/esm2022/lib/_collection/_common/display-content-type-icon/display-content-type-icon.module.mjs +28 -0
  53. package/esm2022/lib/_collection/_common/mark-as-complete/mark-as-complete.component.mjs +77 -0
  54. package/esm2022/lib/_collection/_common/mark-as-complete/mark-as-complete.model.mjs +2 -0
  55. package/esm2022/lib/_collection/_common/mark-as-complete/mark-as-complete.module.mjs +61 -0
  56. package/esm2022/lib/_collection/_common/pipe-content-route/pipe-content-route.module.mjs +20 -0
  57. package/esm2022/lib/_collection/_common/pipe-content-route/pipe-content-route.pipe.mjs +67 -0
  58. package/esm2022/lib/_collection/_common/player-brief/player-brief.component.mjs +139 -0
  59. package/esm2022/lib/_collection/_common/player-brief/player-brief.module.mjs +71 -0
  60. package/esm2022/lib/_collection/_common/rating-summary/rating-summary.component.mjs +34 -0
  61. package/esm2022/lib/_collection/_common/rating-summary/rating-summary.module.mjs +56 -0
  62. package/esm2022/lib/_collection/_common/skeleton-loader/skeleton-loader.component.mjs +25 -0
  63. package/esm2022/lib/_collection/_common/skeleton-loader/skeleton-loader.module.mjs +37 -0
  64. package/esm2022/lib/_collection/_common/tips-for-learner/tips-for-learner-card/tips-for-learner-card.component.mjs +32 -0
  65. package/esm2022/lib/_collection/_common/tips-for-learner/tips-for-learner.module.mjs +30 -0
  66. package/esm2022/lib/_collection/_common/toc-kpi-values/toc-kpi-values.component.mjs +38 -0
  67. package/esm2022/lib/_collection/_common/toc-kpi-values/toc-kpi-values.module.mjs +51 -0
  68. package/esm2022/lib/_collection/_common/user-autocomplete/user-autocomplete.component.mjs +115 -0
  69. package/esm2022/lib/_collection/_common/user-autocomplete/user-autocomplete.model.mjs +12 -0
  70. package/esm2022/lib/_collection/_common/user-autocomplete/user-autocomplete.module.mjs +51 -0
  71. package/esm2022/lib/_collection/_common/user-autocomplete/user-autocomplete.service.mjs +61 -0
  72. package/esm2022/lib/_collection/_common/user-content-rating/user-content-rating.component.mjs +87 -0
  73. package/esm2022/lib/_collection/_common/user-content-rating/user-content-rating.module.mjs +36 -0
  74. package/esm2022/lib/_collection/_common/user-image/user-image.component.mjs +62 -0
  75. package/esm2022/lib/_collection/_common/user-image/user-image.module.mjs +24 -0
  76. package/esm2022/lib/_collection/btn-page-back/btn-page-back.component.mjs +192 -0
  77. package/esm2022/lib/_collection/btn-page-back/btn-page-back.module.mjs +44 -0
  78. package/esm2022/lib/_collection/btn-page-back/btn-page-back.service.mjs +99 -0
  79. package/esm2022/lib/_collection/card-rating-comment/card-rating-comment.component.mjs +58 -0
  80. package/esm2022/lib/_collection/card-rating-comment/card-rating-comment.module.mjs +67 -0
  81. package/esm2022/lib/_collection/sliders-dynamic/sliders-dynamic.component.mjs +112 -0
  82. package/esm2022/lib/_collection/sliders-dynamic/sliders-dynamic.model.mjs +2 -0
  83. package/esm2022/lib/_collection/sliders-dynamic/sliders-dynamic.module.mjs +69 -0
  84. package/esm2022/lib/_collection-api.mjs +57 -0
  85. package/esm2022/lib/_constants/widget-content.constants.mjs +19 -0
  86. package/esm2022/lib/_directives/tooltip.directive.mjs +68 -0
  87. package/esm2022/lib/_models/common.model.mjs +2 -0
  88. package/esm2022/lib/_models/error.model.mjs +2 -0
  89. package/esm2022/lib/_pipes/highlight.pipe.mjs +24 -0
  90. package/esm2022/lib/_services/rating.service.mjs +89 -0
  91. package/esm2022/lib/_services/samuhik-charcha.service.mjs +29 -0
  92. package/esm2022/lib/_services/viewer-route-util.mjs +103 -0
  93. package/esm2022/lib/_services/widget-content.model.mjs +254 -0
  94. package/esm2022/lib/_services/widget-content.service.mjs +594 -0
  95. package/esm2022/lib/_shared/translate-loader.factory.mjs +9 -0
  96. package/esm2022/lib/app-toc-lib.module.mjs +503 -0
  97. package/esm2022/lib/collection.config.mjs +161 -0
  98. package/esm2022/lib/components/app-toc-analytics-tiles/app-toc-analytics-tiles.component.mjs +37 -0
  99. package/esm2022/lib/components/app-toc-banner/app-toc-banner.component.mjs +1436 -0
  100. package/esm2022/lib/components/app-toc-cios-home/app-toc-cios-home.component.mjs +505 -0
  101. package/esm2022/lib/components/app-toc-cios-home/consent-dialog.component.mjs +119 -0
  102. package/esm2022/lib/components/app-toc-cohorts/app-toc-cohorts.component.mjs +80 -0
  103. package/esm2022/lib/components/app-toc-content-card/app-toc-content-card.component.mjs +249 -0
  104. package/esm2022/lib/components/app-toc-dialog-intro-video/app-toc-dialog-intro-video.component.mjs +39 -0
  105. package/esm2022/lib/components/app-toc-discussion/app-toc-discussion.component.mjs +58 -0
  106. package/esm2022/lib/components/app-toc-home/app-toc-home.component.mjs +2230 -0
  107. package/esm2022/lib/components/app-toc-home-v2/app-toc-home-v2.component.mjs +3001 -0
  108. package/esm2022/lib/components/app-toc-overview/app-toc-overview.component.mjs +157 -0
  109. package/esm2022/lib/components/app-toc-session-card/app-toc-session-card.component.mjs +48 -0
  110. package/esm2022/lib/components/app-toc-sessions/app-toc-sessions.component.mjs +47 -0
  111. package/esm2022/lib/components/app-toc-single-page/app-toc-single-page.component.mjs +766 -0
  112. package/esm2022/lib/components/completion-survey-form/completion-survey-form.component.mjs +243 -0
  113. package/esm2022/lib/components/create-batch-dialog/create-batch-dialog.component.mjs +116 -0
  114. package/esm2022/lib/components/enroll-language-dialogue/enroll-language-dialogue.component.mjs +44 -0
  115. package/esm2022/lib/components/enroll-profile-form/enroll-profile-form.component.mjs +1838 -0
  116. package/esm2022/lib/components/enroll-questionnaire/enroll-questionnaire.component.mjs +236 -0
  117. package/esm2022/lib/components/knowledge-artifact-details/knowledge-artifact-details.component.mjs +213 -0
  118. package/esm2022/lib/components/non-relevent-feedback-dialog/non-relevent-feedback-dialog.component.mjs +36 -0
  119. package/esm2022/lib/components/public-survey-form/public-survey-form.component.mjs +258 -0
  120. package/esm2022/lib/components/survey-form-question/survey-form-question.component.mjs +133 -0
  121. package/esm2022/lib/components/survey-form-section/survey-form-section.component.mjs +36 -0
  122. package/esm2022/lib/models/app-toc-analytics.model.mjs +2 -0
  123. package/esm2022/lib/models/app-toc.model.mjs +38 -0
  124. package/esm2022/lib/models/auto-complete.model.mjs +2 -0
  125. package/esm2022/lib/models/card-content.model.mjs +13 -0
  126. package/esm2022/lib/models/content-strip-with-tabs.model.mjs +2 -0
  127. package/esm2022/lib/models/discussion-forum.model.mjs +14 -0
  128. package/esm2022/lib/models/goal.model.mjs +2 -0
  129. package/esm2022/lib/models/meta-tag.model.mjs +8 -0
  130. package/esm2022/lib/models/playlist.model.mjs +2 -0
  131. package/esm2022/lib/models/profile-revamp.model.mjs +2 -0
  132. package/esm2022/lib/models/rating.model.mjs +2 -0
  133. package/esm2022/lib/models/user-profile.model.mjs +21 -0
  134. package/esm2022/lib/registration-toc-lib.config.mjs +14 -0
  135. package/esm2022/lib/resolvers/app-toc-cios-resolver.service.mjs +24 -0
  136. package/esm2022/lib/resolvers/app-toc-cios-user-enroll-resolver.service.mjs +24 -0
  137. package/esm2022/lib/resolvers/app-toc-content-read-resolver.service.mjs +60 -0
  138. package/esm2022/lib/resolvers/app-toc-ext-public-resolver.service.mjs +25 -0
  139. package/esm2022/lib/resolvers/app-toc-resolver.service.mjs +106 -0
  140. package/esm2022/lib/resolvers/config-resolver.service.mjs +25 -0
  141. package/esm2022/lib/resolvers/profile-resolver.service.mjs +25 -0
  142. package/esm2022/lib/resolvers/restricted-features-resolver.service.mjs +25 -0
  143. package/esm2022/lib/routes/app-toc-home/app-toc-home.component.mjs +51 -0
  144. package/esm2022/lib/routes/app-toc-home/app-toc-home.directive.mjs +16 -0
  145. package/esm2022/lib/routes/app-toc-home/app-toc-home.service.mjs +18 -0
  146. package/esm2022/lib/services/access-control.service.mjs +56 -0
  147. package/esm2022/lib/services/action.service.mjs +23 -0
  148. package/esm2022/lib/services/app-toc-v2.service.mjs +368 -0
  149. package/esm2022/lib/services/app-toc.service.mjs +1577 -0
  150. package/esm2022/lib/services/certificate.service.mjs +114 -0
  151. package/esm2022/lib/services/discuss-utils.service.mjs +58 -0
  152. package/esm2022/lib/services/editor.service.mjs +34 -0
  153. package/esm2022/lib/services/load-check.service.mjs +21 -0
  154. package/esm2022/lib/services/loader.service.mjs +33 -0
  155. package/esm2022/lib/services/mobile-apps.service.mjs +67 -0
  156. package/esm2022/lib/services/netcore.service.mjs +56 -0
  157. package/esm2022/lib/services/nps-grid.service.mjs +31 -0
  158. package/esm2022/lib/services/otp.service.mjs +43 -0
  159. package/esm2022/lib/services/profile-v2.service.mjs +43 -0
  160. package/esm2022/lib/services/reset-ratings.service.mjs +19 -0
  161. package/esm2022/lib/services/resource-download-helper.service.mjs +64 -0
  162. package/esm2022/lib/services/root.service.mjs +106 -0
  163. package/esm2022/lib/services/timer.service.mjs +23 -0
  164. package/esm2022/lib/services/title-tag.service.mjs +71 -0
  165. package/esm2022/lib/services/user-profile.service.mjs +55 -0
  166. package/esm2022/lib/services/viewer-data.service.mjs +64 -0
  167. package/esm2022/lib/services/viewer-util.service.mjs +627 -0
  168. package/esm2022/lib/share-toc/share-toc/share-toc.component.mjs +291 -0
  169. package/esm2022/lib/share-toc/share-toc.module.mjs +119 -0
  170. package/esm2022/public-api.mjs +80 -0
  171. package/esm2022/sunbird-cb-toc.mjs +5 -0
  172. package/fesm2022/sunbird-cb-toc.mjs +27111 -0
  173. package/fesm2022/sunbird-cb-toc.mjs.map +1 -0
  174. package/index.d.ts +5 -0
  175. package/lib/_collection/_common/ai-tutor/ai-tutor.component.d.ts +139 -0
  176. package/lib/_collection/_common/ai-tutor/socket.service.d.ts +19 -0
  177. package/lib/_collection/_common/attendance-card/attendance-card.component.d.ts +16 -0
  178. package/lib/_collection/_common/attendance-card/attendance-card.module.d.ts +31 -0
  179. package/lib/_collection/_common/attendance-helper/attendance-helper.component.d.ts +15 -0
  180. package/lib/_collection/_common/attendance-helper/attendance-helper.module.d.ts +20 -0
  181. package/lib/_collection/_common/avatar-photo/avatar-photo.component.d.ts +22 -0
  182. package/lib/_collection/_common/avatar-photo/avatar-photo.module.d.ts +15 -0
  183. package/lib/_collection/_common/card-competency/card-competency.component.d.ts +14 -0
  184. package/lib/_collection/_common/card-competency/card-competency.module.d.ts +8 -0
  185. package/lib/_collection/_common/card-content-v2/card-content-v2.model.d.ts +44 -0
  186. package/lib/_collection/_common/certificate-dialog/certificate-dialog.component.d.ts +30 -0
  187. package/lib/_collection/_common/certificate-dialog/certificate-dialog.module.d.ts +23 -0
  188. package/lib/_collection/_common/certificate-dialog/svg-to-pdf.component.d.ts +9 -0
  189. package/lib/_collection/_common/confirm-dialog/confirm-dialog.component.d.ts +11 -0
  190. package/lib/_collection/_common/confirm-dialog/confirm-dialog.module.d.ts +12 -0
  191. package/lib/_collection/_common/connection-hover-card/connection-hover-card.component.d.ts +18 -0
  192. package/lib/_collection/_common/connection-hover-card/connection-hover.module.d.ts +14 -0
  193. package/lib/_collection/_common/connection-hover-card/connection-hover.servive.d.ts +11 -0
  194. package/lib/_collection/_common/connection-name/connection-name.component.d.ts +17 -0
  195. package/lib/_collection/_common/connection-name/connection-name.module.d.ts +14 -0
  196. package/lib/_collection/_common/connection-name/profile-v2.model.d.ts +199 -0
  197. package/lib/_collection/_common/content-progress/content-progress.component.d.ts +16 -0
  198. package/lib/_collection/_common/content-progress/content-progress.module.d.ts +10 -0
  199. package/lib/_collection/_common/content-rating-v2-dialog/content-rating-v2-dialog.component.d.ts +38 -0
  200. package/lib/_collection/_common/content-rating-v2-dialog/content-rating-v2-dialog.module.d.ts +19 -0
  201. package/lib/_collection/_common/content-toc/ai-tutor-confirm-popup/ai-tutor-confirm-popup.component.d.ts +11 -0
  202. package/lib/_collection/_common/content-toc/app-toc-about/app-toc-about.component.d.ts +187 -0
  203. package/lib/_collection/_common/content-toc/app-toc-assignment-viewer/app-toc-assignment-viewer.component.d.ts +41 -0
  204. package/lib/_collection/_common/content-toc/app-toc-assignment-viewerV2/app-toc-assignment-viewerV2.component.d.ts +54 -0
  205. package/lib/_collection/_common/content-toc/app-toc-batch-assignments/app-toc-batch-assignments.component.d.ts +47 -0
  206. package/lib/_collection/_common/content-toc/app-toc-content/app-toc-content.component.d.ts +56 -0
  207. package/lib/_collection/_common/content-toc/app-toc-content-card-v2/app-toc-content-card-v2.component.d.ts +195 -0
  208. package/lib/_collection/_common/content-toc/app-toc-content-card-v2-skeleton/app-toc-content-card-v2-skeleton.component.d.ts +8 -0
  209. package/lib/_collection/_common/content-toc/app-toc-reference-notes/app-toc-reference-notes.component.d.ts +16 -0
  210. package/lib/_collection/_common/content-toc/app-toc-session-card-new/app-toc-session-card-new.component.d.ts +40 -0
  211. package/lib/_collection/_common/content-toc/app-toc-sessions-new/app-toc-sessions-new.component.d.ts +21 -0
  212. package/lib/_collection/_common/content-toc/app-toc-teachers-notes/app-toc-teachers-notes.component.d.ts +45 -0
  213. package/lib/_collection/_common/content-toc/content-services/handle-claim.service.d.ts +10 -0
  214. package/lib/_collection/_common/content-toc/content-services/review-component-data.service.d.ts +10 -0
  215. package/lib/_collection/_common/content-toc/content-toc.component.d.ts +131 -0
  216. package/lib/_collection/_common/content-toc/content-toc.module.d.ts +52 -0
  217. package/lib/_collection/_common/content-toc/karma-points/karma-points.component.d.ts +29 -0
  218. package/lib/_collection/_common/content-toc/karma-points/karma-points.module.d.ts +9 -0
  219. package/lib/_collection/_common/content-toc/pipes/replace-nbsp.pipe.d.ts +7 -0
  220. package/lib/_collection/_common/content-toc/pipes/truncate.pipe.d.ts +7 -0
  221. package/lib/_collection/_common/content-toc/reviews-content/reviews-content.component.d.ts +28 -0
  222. package/lib/_collection/_common/content-toc/samuhik-charcha-content/samuhik-charcha-content/samuhik-charcha-content.component.d.ts +24 -0
  223. package/lib/_collection/_common/display-content-type/display-content-type.component.d.ts +14 -0
  224. package/lib/_collection/_common/display-content-type/display-content-type.module.d.ts +9 -0
  225. package/lib/_collection/_common/display-content-type-icon/display-content-type-icon.component.d.ts +12 -0
  226. package/lib/_collection/_common/display-content-type-icon/display-content-type-icon.module.d.ts +10 -0
  227. package/lib/_collection/_common/mark-as-complete/mark-as-complete.component.d.ts +22 -0
  228. package/lib/_collection/_common/mark-as-complete/mark-as-complete.model.d.ts +8 -0
  229. package/lib/_collection/_common/mark-as-complete/mark-as-complete.module.d.ts +18 -0
  230. package/lib/_collection/_common/pipe-content-route/pipe-content-route.module.d.ts +8 -0
  231. package/lib/_collection/_common/pipe-content-route/pipe-content-route.pipe.d.ts +15 -0
  232. package/lib/_collection/_common/player-brief/player-brief.component.d.ts +35 -0
  233. package/lib/_collection/_common/player-brief/player-brief.module.d.ts +19 -0
  234. package/lib/_collection/_common/rating-summary/rating-summary.component.d.ts +14 -0
  235. package/lib/_collection/_common/rating-summary/rating-summary.module.d.ts +13 -0
  236. package/lib/_collection/_common/skeleton-loader/skeleton-loader.component.d.ts +11 -0
  237. package/lib/_collection/_common/skeleton-loader/skeleton-loader.module.d.ts +11 -0
  238. package/lib/_collection/_common/tips-for-learner/tips-for-learner-card/tips-for-learner-card.component.d.ts +15 -0
  239. package/lib/_collection/_common/tips-for-learner/tips-for-learner.module.d.ts +10 -0
  240. package/lib/_collection/_common/toc-kpi-values/toc-kpi-values.component.d.ts +16 -0
  241. package/lib/_collection/_common/toc-kpi-values/toc-kpi-values.module.d.ts +11 -0
  242. package/lib/_collection/_common/user-autocomplete/user-autocomplete.component.d.ts +34 -0
  243. package/lib/_collection/_common/user-autocomplete/user-autocomplete.model.d.ts +17 -0
  244. package/lib/_collection/_common/user-autocomplete/user-autocomplete.module.d.ts +15 -0
  245. package/lib/_collection/_common/user-autocomplete/user-autocomplete.service.d.ts +15 -0
  246. package/lib/_collection/_common/user-content-rating/user-content-rating.component.d.ts +21 -0
  247. package/lib/_collection/_common/user-content-rating/user-content-rating.module.d.ts +12 -0
  248. package/lib/_collection/_common/user-image/user-image.component.d.ts +21 -0
  249. package/lib/_collection/_common/user-image/user-image.module.d.ts +9 -0
  250. package/lib/_collection/btn-page-back/btn-page-back.component.d.ts +47 -0
  251. package/lib/_collection/btn-page-back/btn-page-back.module.d.ts +14 -0
  252. package/lib/_collection/btn-page-back/btn-page-back.service.d.ts +22 -0
  253. package/lib/_collection/card-rating-comment/card-rating-comment.component.d.ts +19 -0
  254. package/lib/_collection/card-rating-comment/card-rating-comment.module.d.ts +15 -0
  255. package/lib/_collection/sliders-dynamic/sliders-dynamic.component.d.ts +25 -0
  256. package/lib/_collection/sliders-dynamic/sliders-dynamic.model.d.ts +21 -0
  257. package/lib/_collection/sliders-dynamic/sliders-dynamic.module.d.ts +18 -0
  258. package/lib/_collection-api.d.ts +34 -0
  259. package/lib/_constants/widget-content.constants.d.ts +7 -0
  260. package/lib/_directives/tooltip.directive.d.ts +17 -0
  261. package/lib/_models/common.model.d.ts +3 -0
  262. package/lib/_models/error.model.d.ts +5 -0
  263. package/lib/_pipes/highlight.pipe.d.ts +10 -0
  264. package/lib/_services/rating.service.d.ts +18 -0
  265. package/lib/_services/samuhik-charcha.service.d.ts +13 -0
  266. package/lib/_services/viewer-route-util.d.ts +8 -0
  267. package/lib/_services/widget-content.model.d.ts +521 -0
  268. package/lib/_services/widget-content.service.d.ts +101 -0
  269. package/lib/_shared/translate-loader.factory.d.ts +7 -0
  270. package/lib/app-toc-lib.module.d.ts +89 -0
  271. package/lib/collection.config.d.ts +159 -0
  272. package/lib/components/app-toc-analytics-tiles/app-toc-analytics-tiles.component.d.ts +17 -0
  273. package/lib/components/app-toc-banner/app-toc-banner.component.d.ts +225 -0
  274. package/lib/components/app-toc-cios-home/app-toc-cios-home.component.d.ts +82 -0
  275. package/lib/components/app-toc-cios-home/consent-dialog.component.d.ts +22 -0
  276. package/lib/components/app-toc-cohorts/app-toc-cohorts.component.d.ts +31 -0
  277. package/lib/components/app-toc-content-card/app-toc-content-card.component.d.ts +47 -0
  278. package/lib/components/app-toc-dialog-intro-video/app-toc-dialog-intro-video.component.d.ts +14 -0
  279. package/lib/components/app-toc-discussion/app-toc-discussion.component.d.ts +21 -0
  280. package/lib/components/app-toc-home/app-toc-home.component.d.ts +315 -0
  281. package/lib/components/app-toc-home-v2/app-toc-home-v2.component.d.ts +417 -0
  282. package/lib/components/app-toc-overview/app-toc-overview.component.d.ts +47 -0
  283. package/lib/components/app-toc-session-card/app-toc-session-card.component.d.ts +22 -0
  284. package/lib/components/app-toc-sessions/app-toc-sessions.component.d.ts +14 -0
  285. package/lib/components/app-toc-single-page/app-toc-single-page.component.d.ts +149 -0
  286. package/lib/components/completion-survey-form/completion-survey-form.component.d.ts +42 -0
  287. package/lib/components/create-batch-dialog/create-batch-dialog.component.d.ts +27 -0
  288. package/lib/components/enroll-language-dialogue/enroll-language-dialogue.component.d.ts +15 -0
  289. package/lib/components/enroll-profile-form/enroll-profile-form.component.d.ts +195 -0
  290. package/lib/components/enroll-questionnaire/enroll-questionnaire.component.d.ts +44 -0
  291. package/lib/components/knowledge-artifact-details/knowledge-artifact-details.component.d.ts +54 -0
  292. package/lib/components/non-relevent-feedback-dialog/non-relevent-feedback-dialog.component.d.ts +18 -0
  293. package/lib/components/public-survey-form/public-survey-form.component.d.ts +44 -0
  294. package/lib/components/survey-form-question/survey-form-question.component.d.ts +20 -0
  295. package/lib/components/survey-form-section/survey-form-section.component.d.ts +13 -0
  296. package/lib/models/app-toc-analytics.model.d.ts +152 -0
  297. package/lib/models/app-toc.model.d.ts +84 -0
  298. package/lib/models/auto-complete.model.d.ts +27 -0
  299. package/lib/models/card-content.model.d.ts +19 -0
  300. package/lib/models/content-strip-with-tabs.model.d.ts +44 -0
  301. package/lib/models/discussion-forum.model.d.ts +40 -0
  302. package/lib/models/goal.model.d.ts +22 -0
  303. package/lib/models/meta-tag.model.d.ts +6 -0
  304. package/lib/models/playlist.model.d.ts +23 -0
  305. package/lib/models/profile-revamp.model.d.ts +14 -0
  306. package/lib/models/rating.model.d.ts +17 -0
  307. package/lib/models/user-profile.model.d.ts +37 -0
  308. package/lib/registration-toc-lib.config.d.ts +4 -0
  309. package/lib/resolvers/app-toc-cios-resolver.service.d.ts +12 -0
  310. package/lib/resolvers/app-toc-cios-user-enroll-resolver.service.d.ts +12 -0
  311. package/lib/resolvers/app-toc-content-read-resolver.service.d.ts +16 -0
  312. package/lib/resolvers/app-toc-ext-public-resolver.service.d.ts +12 -0
  313. package/lib/resolvers/app-toc-resolver.service.d.ts +16 -0
  314. package/lib/resolvers/config-resolver.service.d.ts +11 -0
  315. package/lib/resolvers/profile-resolver.service.d.ts +11 -0
  316. package/lib/resolvers/restricted-features-resolver.service.d.ts +11 -0
  317. package/lib/routes/app-toc-home/app-toc-home.component.d.ts +19 -0
  318. package/lib/routes/app-toc-home/app-toc-home.directive.d.ts +8 -0
  319. package/lib/routes/app-toc-home/app-toc-home.service.d.ts +8 -0
  320. package/lib/services/access-control.service.d.ts +29 -0
  321. package/lib/services/action.service.d.ts +9 -0
  322. package/lib/services/app-toc-v2.service.d.ts +17 -0
  323. package/lib/services/app-toc.service.d.ts +190 -0
  324. package/lib/services/certificate.service.d.ts +41 -0
  325. package/lib/services/discuss-utils.service.d.ts +33 -0
  326. package/lib/services/editor.service.d.ts +17 -0
  327. package/lib/services/load-check.service.d.ts +8 -0
  328. package/lib/services/loader.service.d.ts +16 -0
  329. package/lib/services/mobile-apps.service.d.ts +38 -0
  330. package/lib/services/netcore.service.d.ts +33 -0
  331. package/lib/services/nps-grid.service.d.ts +15 -0
  332. package/lib/services/otp.service.d.ts +20 -0
  333. package/lib/services/profile-v2.service.d.ts +20 -0
  334. package/lib/services/reset-ratings.service.d.ts +8 -0
  335. package/lib/services/resource-download-helper.service.d.ts +29 -0
  336. package/lib/services/root.service.d.ts +26 -0
  337. package/lib/services/timer.service.d.ts +9 -0
  338. package/lib/services/title-tag.service.d.ts +21 -0
  339. package/lib/services/user-profile.service.d.ts +24 -0
  340. package/lib/services/viewer-data.service.d.ts +62 -0
  341. package/lib/services/viewer-util.service.d.ts +76 -0
  342. package/lib/share-toc/share-toc/share-toc.component.d.ts +56 -0
  343. package/lib/share-toc/share-toc.module.d.ts +32 -0
  344. package/package.json +34 -0
  345. package/public-api.d.ts +64 -0
  346. package/sunbird-cb-toc-0.0.1-mauritius.tgz +0 -0
@@ -0,0 +1,3001 @@
1
+ import { Component, HostListener, ViewChild, ViewEncapsulation, Input, Inject, } from '@angular/core';
2
+ import { NavigationEnd } from '@angular/router';
3
+ import { UntypedFormControl, Validators } from '@angular/forms';
4
+ import { Subject, of, from } from 'rxjs';
5
+ import { catchError, share, switchMap, takeUntil } from 'rxjs/operators';
6
+ import dayjs from 'dayjs';
7
+ // tslint:disable-next-line
8
+ import _ from 'lodash';
9
+ import moment from 'moment';
10
+ import isSameOrBefore from 'dayjs/plugin/isSameOrBefore';
11
+ import { NsContent } from '../../_services/widget-content.model';
12
+ import { viewerRouteGenerator } from '../../_services/viewer-route-util';
13
+ import { WsEvents, } from '@sunbird-cb/utils-v2';
14
+ import { ConfirmationDialogComponent, TOCMultiLingualDialogComponent } from '@sunbird-cb/consumption';
15
+ import { NsAppToc } from '../../models/app-toc.model';
16
+ import { AppTocDialogIntroVideoComponent } from '../app-toc-dialog-intro-video/app-toc-dialog-intro-video.component';
17
+ import { ContentRatingV2DialogComponent } from '../../_collection/_common/content-rating-v2-dialog/content-rating-v2-dialog.component';
18
+ import { EnrollLanguageDialogueComponent } from '../enroll-language-dialogue/enroll-language-dialogue.component';
19
+ import { CompletionSurveyFormComponent } from '../completion-survey-form/completion-survey-form.component';
20
+ import { PublicSurveyFormComponent } from '../public-survey-form/public-survey-form.component';
21
+ import { NsCardContent } from '../../models/card-content.model';
22
+ import { NonReleventFeedbackDialogComponent } from '../non-relevent-feedback-dialog/non-relevent-feedback-dialog.component';
23
+ import * as i0 from "@angular/core";
24
+ import * as i1 from "@angular/router";
25
+ import * as i2 from "../../_services/widget-content.service";
26
+ import * as i3 from "../../services/app-toc.service";
27
+ import * as i4 from "@sunbird-cb/utils-v2";
28
+ import * as i5 from "@angular/platform-browser";
29
+ import * as i6 from "@angular/material/legacy-snack-bar";
30
+ import * as i7 from "@angular/material/legacy-dialog";
31
+ import * as i8 from "../../services/mobile-apps.service";
32
+ import * as i9 from "@sunbird-cb/consumption";
33
+ import * as i10 from "../../services/action.service";
34
+ import * as i11 from "../../services/viewer-util.service";
35
+ import * as i12 from "../../_services/rating.service";
36
+ import * as i13 from "@ngx-translate/core";
37
+ import * as i14 from "../../services/load-check.service";
38
+ import * as i15 from "../../_collection/_common/content-toc/content-services/handle-claim.service";
39
+ import * as i16 from "../../services/reset-ratings.service";
40
+ import * as i17 from "../../services/timer.service";
41
+ import * as i18 from "@angular/material/snack-bar";
42
+ import * as i19 from "../../services/netcore.service";
43
+ import * as i20 from "../../services/app-toc-v2.service";
44
+ import * as i21 from "@angular/common";
45
+ import * as i22 from "@angular/material/icon";
46
+ import * as i23 from "@angular/material/legacy-button";
47
+ import * as i24 from "@angular/material/legacy-menu";
48
+ import * as i25 from "@angular/material/legacy-chips";
49
+ import * as i26 from "@angular/material/legacy-radio";
50
+ import * as i27 from "../../_collection/_common/skeleton-loader/skeleton-loader.component";
51
+ import * as i28 from "../../_collection/_common/content-progress/content-progress.component";
52
+ import * as i29 from "../../_collection/_common/avatar-photo/avatar-photo.component";
53
+ import * as i30 from "../../_collection/_common/content-toc/content-toc.component";
54
+ import * as i31 from "../../share-toc/share-toc/share-toc.component";
55
+ import * as i32 from "../../_collection/_common/toc-kpi-values/toc-kpi-values.component";
56
+ import * as i33 from "../../_collection/_common/content-toc/karma-points/karma-points.component";
57
+ import * as i34 from "../../_collection/_common/tips-for-learner/tips-for-learner-card/tips-for-learner-card.component";
58
+ import * as i35 from "../app-toc-banner/app-toc-banner.component";
59
+ dayjs.extend(isSameOrBefore);
60
+ export var ErrorType;
61
+ (function (ErrorType) {
62
+ ErrorType["internalServer"] = "internalServer";
63
+ ErrorType["serviceUnavailable"] = "serviceUnavailable";
64
+ ErrorType["somethingWrong"] = "somethingWrong";
65
+ })(ErrorType || (ErrorType = {}));
66
+ const flattenItems = (items, key) => {
67
+ return items.reduce((flattenedItems, item) => {
68
+ flattenedItems.push(item);
69
+ if (Array.isArray(item[key])) {
70
+ // tslint:disable-next-line
71
+ flattenedItems = flattenedItems.concat(flattenItems(item[key], key));
72
+ }
73
+ return flattenedItems;
74
+ // tslint:disable-next-line
75
+ }, []);
76
+ };
77
+ const SNACKBAR_DURATION = 3000;
78
+ export class AppTocHomeV2Component {
79
+ handleScroll() {
80
+ const windowScroll = window.pageYOffset;
81
+ if (windowScroll >= this.elementPosition - 100) {
82
+ this.sticky = true;
83
+ }
84
+ else {
85
+ this.sticky = false;
86
+ }
87
+ if (this.scrollLimit) {
88
+ if ((window.scrollY + this.rcElem.BottomPos) >= this.scrollLimit) {
89
+ this.rcElement.nativeElement.style.position = 'sticky';
90
+ }
91
+ else {
92
+ if (this.rcElement) {
93
+ this.rcElement.nativeElement.style.position = 'fixed';
94
+ }
95
+ }
96
+ }
97
+ // 236... (OffsetTop of right container + 104)
98
+ if (window.scrollY > (this.rcElem.offSetTop + 104)) {
99
+ this.scrolled = true;
100
+ }
101
+ else {
102
+ this.scrolled = false;
103
+ }
104
+ }
105
+ constructor(route, router, contentSvc, tocSvc, loggerSvc, configSvc, domSanitizer, snackBar, dialog, mobileAppsSvc, utilitySvc,
106
+ // private progressSvc: ContentProgressService,
107
+ contentLangSvc, actionSVC, viewerSvc, ratingSvc, telemetryService, translate, langtranslations, events,
108
+ // private matSnackBar: MatSnackBar,
109
+ loadCheckService, handleClaimService, resetRatingsService, timerService, enrollSvc, contentLibSvc, dataTransferSvc, matSnackbarNew, userServiceLib, netCoreService, appTocV2Svc, location, domainConfSvc, environment) {
110
+ this.route = route;
111
+ this.router = router;
112
+ this.contentSvc = contentSvc;
113
+ this.tocSvc = tocSvc;
114
+ this.loggerSvc = loggerSvc;
115
+ this.configSvc = configSvc;
116
+ this.domSanitizer = domSanitizer;
117
+ this.snackBar = snackBar;
118
+ this.dialog = dialog;
119
+ this.mobileAppsSvc = mobileAppsSvc;
120
+ this.utilitySvc = utilitySvc;
121
+ this.contentLangSvc = contentLangSvc;
122
+ this.actionSVC = actionSVC;
123
+ this.viewerSvc = viewerSvc;
124
+ this.ratingSvc = ratingSvc;
125
+ this.telemetryService = telemetryService;
126
+ this.translate = translate;
127
+ this.langtranslations = langtranslations;
128
+ this.events = events;
129
+ this.loadCheckService = loadCheckService;
130
+ this.handleClaimService = handleClaimService;
131
+ this.resetRatingsService = resetRatingsService;
132
+ this.timerService = timerService;
133
+ this.enrollSvc = enrollSvc;
134
+ this.contentLibSvc = contentLibSvc;
135
+ this.dataTransferSvc = dataTransferSvc;
136
+ this.matSnackbarNew = matSnackbarNew;
137
+ this.userServiceLib = userServiceLib;
138
+ this.netCoreService = netCoreService;
139
+ this.appTocV2Svc = appTocV2Svc;
140
+ this.location = location;
141
+ this.domainConfSvc = domainConfSvc;
142
+ this.environment = environment;
143
+ this.queryParamsData = {}; // Initialize queryParamsData
144
+ this.show = false;
145
+ this.changeTab = false;
146
+ this.skeletonLoader = true;
147
+ this.banners = null;
148
+ this.showMoreGlance = false;
149
+ this.content = null;
150
+ this.contentReadData = null;
151
+ this.baseContentReadData = null;
152
+ this.errorCode = null;
153
+ this.resumeData = null;
154
+ this.nsCardContentData = NsCardContent.ACBPConst;
155
+ this.batchData = null;
156
+ this.currentCourseBatchId = null;
157
+ this.routeSubscription = null;
158
+ this.pageNavbar = this.configSvc.pageNavBar;
159
+ this.isCohortsRestricted = false;
160
+ this.sticky = false;
161
+ this.isInIframe = false;
162
+ this.forPreview = window.location.href.includes('/public/') || window.location.href.includes('/author/') || window.location.href.includes('/preview/');
163
+ this.displayViewBtn = true;
164
+ // forPreview = window.location.href.includes('/author/')
165
+ this.analytics = this.route.snapshot.data?.pageData?.data?.analytics;
166
+ this.errorWidgetData = {
167
+ widgetType: 'errorResolver',
168
+ widgetSubType: 'errorResolver',
169
+ widgetData: {
170
+ errorType: 'internalServer',
171
+ },
172
+ };
173
+ this.isAuthor = false;
174
+ this.authorBtnWidget = {
175
+ actionBtnId: 'feature_authoring',
176
+ config: {
177
+ type: 'mat-button',
178
+ },
179
+ };
180
+ this.tocConfig = null;
181
+ this.primaryCategory = NsContent.EPrimaryCategory;
182
+ this.courseCategory = NsContent.ECourseCategory;
183
+ this.WFBlendedProgramStatus = NsContent.WFBlendedProgramStatus;
184
+ this.askAuthorEnabled = true;
185
+ this.trainingLHubEnabled = false;
186
+ this.body = null;
187
+ this.viewMoreRelatedTopics = false;
188
+ this.hasTocStructure = false;
189
+ this.tocStructure = null;
190
+ this.contentParents = {};
191
+ this.objKeys = Object.keys;
192
+ this.activeFragment = this.route.fragment.pipe(share());
193
+ this.currentFragment = 'overview';
194
+ this.showScrollHeight = 300;
195
+ this.hideScrollHeight = 10;
196
+ this.batchSubscription = null;
197
+ this.batchDataSubscription = null;
198
+ this.resumeDataSubscription = null;
199
+ this.translationSubscription = null;
200
+ this.hashmapUpdatedSubscription = null;
201
+ this.batchControl = new UntypedFormControl('', Validators.required);
202
+ this.contentProgress = 0;
203
+ this.bannerUrl = null;
204
+ this.routePath = 'overview';
205
+ this.validPaths = new Set(['overview', 'contents', 'analytics']);
206
+ this.routerParamSubscription = null;
207
+ this.actionBtnStatus = 'wait';
208
+ this.isRegistrationSupported = false;
209
+ this.showIntranetMessage = false;
210
+ this.firstResourceLink = null;
211
+ this.resumeDataLink = null;
212
+ this.certData = null;
213
+ this.showTakeAssessment = null;
214
+ this.checkRegistrationSources = new Set([
215
+ 'SkillSoft Digitalization',
216
+ 'SkillSoft Leadership',
217
+ 'Pluralsight',
218
+ ]);
219
+ this.externalContentFetchStatus = 'done';
220
+ this.registerForExternal = false;
221
+ this.isGoalsEnabled = false;
222
+ this.defaultSLogo = '';
223
+ this.disableEnrollBtn = false;
224
+ this.isAssessVisible = false;
225
+ this.isPracticeVisible = false;
226
+ this.certificateOpen = false;
227
+ this.courseCompleteState = 2;
228
+ this.dakshtaName = this.environment.dakshtaName;
229
+ this.cscmsUrl = this.environment.cscmsUrl;
230
+ this.showBtn = false;
231
+ this.kparray = [];
232
+ this.enrollBtnLoading = false;
233
+ this.isAcbpCourse = false;
234
+ this.isAcbpClaim = false;
235
+ this.isClaimed = false;
236
+ this.monthlyCapExceed = false;
237
+ this.isCompletedThisMonth = false;
238
+ this.sourceEllipsis = false;
239
+ this.scrollLimit = 0;
240
+ this.rcElem = {
241
+ offSetTop: 0,
242
+ BottomPos: 0,
243
+ };
244
+ this.scrolled = false;
245
+ this.pathSet = new Set();
246
+ this.canShare = false;
247
+ this.enableShare = false;
248
+ this.contentCreatorData = [];
249
+ // randomlearnAdvisoryObj: any
250
+ // learnAdvisoryDataLength: any
251
+ this.destroySubject$ = new Subject();
252
+ this.isReleventBtnHovered = false;
253
+ this.SAKSHAMAI_ICON_NORMAL = '/assets/images/sakshamAI/ai-icon.svg';
254
+ this.SAKSHAMAI_ICON_LOADER = '/assets/images/sakshamAI/saksham_ai_loader.gif';
255
+ this.recommendedCoursesId = '';
256
+ this.preAssessmentCompletionStatus = false;
257
+ this.fromAITutor = false;
258
+ this.languageList = [];
259
+ this.preAssessmentRequiredFlag = false;
260
+ this.lockCertificate = false;
261
+ this.lastProgressRefreshTime = 0;
262
+ this.isRefreshingProgress = false;
263
+ this.historyData = history.state;
264
+ this.handleBreadcrumbs();
265
+ this.mobileAppsSvc.mobileTopHeaderVisibilityStatus.next(true);
266
+ if (localStorage.getItem('websiteLanguage')) {
267
+ this.translate.setDefaultLang('en');
268
+ const lang = localStorage.getItem('websiteLanguage');
269
+ this.translate.use(lang);
270
+ }
271
+ this.loadCheckService.childComponentLoaded$.subscribe(_isLoaded => {
272
+ // Present in app-toc-about.component
273
+ if (document.getElementById('ratingsDiv')) {
274
+ setTimeout(() => {
275
+ const ratingsDiv = document.getElementById('ratingsDiv');
276
+ if (ratingsDiv) {
277
+ this.scrollLimit = ratingsDiv.getBoundingClientRect().bottom;
278
+ }
279
+ }, 500);
280
+ }
281
+ if (document.getElementById('contentContainer')) {
282
+ const contentDiv = document.getElementById('contentContainer');
283
+ if (contentDiv) {
284
+ this.scrollLimit = contentDiv.getBoundingClientRect().bottom;
285
+ }
286
+ }
287
+ });
288
+ this.handleClaimService.getClaimData().subscribe((_eventData) => {
289
+ this.onClickOfClaim(_eventData);
290
+ });
291
+ }
292
+ getKarmapointsLimit() {
293
+ if (!this.forPreview) {
294
+ this.contentSvc.userKarmaPoints().subscribe((res) => {
295
+ if (res && res.kpList) {
296
+ const info = res.kpList.addinfo;
297
+ if (info) {
298
+ this.monthlyCapExceed = JSON.parse(info).claimedNonACBPCourseKarmaQuota >= 4;
299
+ }
300
+ }
301
+ });
302
+ }
303
+ }
304
+ isCourseCompletedOnThisMonth() {
305
+ const now = moment(this.serverDate).format('YYYY-MM-DD');
306
+ if (this.content) {
307
+ const courseData = this.enrolledCourseData;
308
+ if (courseData && courseData.completionPercentage === 100 && courseData.completedOn) {
309
+ const completedOn = moment(courseData.completedOn).format('YYYY-MM-DD');
310
+ const completedMonth = moment(completedOn, 'YYYY-MM-DD').month();
311
+ const currentMonth = moment(now, 'YYYY-MM-DD').month();
312
+ this.isCompletedThisMonth = completedMonth === currentMonth;
313
+ this.content['viewMore'] = false;
314
+ this.content['completedOn'] = courseData.completedOn;
315
+ }
316
+ }
317
+ }
318
+ filteredAcbpList(res) {
319
+ return res.filter((v) => v.identifier === this.courseID);
320
+ }
321
+ findACPB() {
322
+ const localCbp = localStorage.getItem('cbpData');
323
+ if (localCbp) {
324
+ const storeageCbp = JSON.parse(localCbp);
325
+ const cbp = this.filteredAcbpList(storeageCbp);
326
+ if (cbp.length) {
327
+ const acbp = 'cbPlan';
328
+ this.cbPlanEndDate = cbp[0].endDate;
329
+ const sDate = dayjs(this.serverDate).format('YYYY-MM-DD');
330
+ const daysCount = dayjs(this.cbPlanEndDate).diff(this.serverDate, 'day');
331
+ this.cbPlanDuration = daysCount < 0 ? NsCardContent.ACBPConst.OVERDUE : daysCount > 29
332
+ ? NsCardContent.ACBPConst.SUCCESS : NsCardContent.ACBPConst.UPCOMING;
333
+ if (acbp && this.cbPlanEndDate && acbp === 'cbPlan') {
334
+ this.isAcbpCourse = true;
335
+ const eDate = dayjs(this.cbPlanEndDate).format('YYYY-MM-DD');
336
+ if (dayjs(sDate).isSameOrBefore(eDate)) {
337
+ const requestObj = {
338
+ request: {
339
+ filters: {
340
+ contextType: 'Course',
341
+ contextId: this.courseID,
342
+ },
343
+ },
344
+ };
345
+ this.contentSvc.getCourseKarmaPoints(requestObj).subscribe((res) => {
346
+ if (res && res.kpList) {
347
+ const row = res.kpList;
348
+ if (row.addinfo) {
349
+ if (JSON.parse(row.addinfo).ACBP) {
350
+ this.isAcbpClaim = false;
351
+ this.isClaimed = true;
352
+ }
353
+ else {
354
+ this.isAcbpClaim = true;
355
+ }
356
+ }
357
+ else {
358
+ this.isAcbpClaim = true;
359
+ }
360
+ }
361
+ else {
362
+ this.isAcbpClaim = true;
363
+ }
364
+ });
365
+ }
366
+ }
367
+ }
368
+ }
369
+ }
370
+ raiseTelemeteryForProvider(providerName, prividerId) {
371
+ this.events.raiseInteractTelemetry({
372
+ type: 'click',
373
+ id: 'btn-provider',
374
+ }, {
375
+ id: providerName,
376
+ type: prividerId,
377
+ }, {
378
+ pageIdExt: 'btn-provider',
379
+ module: WsEvents.EnumTelemetrymodules.CONTENT,
380
+ });
381
+ }
382
+ raiseTelemetry() {
383
+ this.events.raiseInteractTelemetry({
384
+ type: 'click',
385
+ subType: 'karmapoints-claim',
386
+ id: this.courseID,
387
+ }, {
388
+ id: this.courseID,
389
+ type: 'course',
390
+ }, {
391
+ pageIdExt: 'btn-acbp-claim',
392
+ module: WsEvents.EnumTelemetrymodules.KARMAPOINTS,
393
+ });
394
+ }
395
+ onClickOfClaim(event) {
396
+ const request = {
397
+ userId: this.configSvc.unMappedUser.identifier,
398
+ courseId: this.courseID,
399
+ };
400
+ this.raiseTelemetry();
401
+ this.contentSvc.claimKarmapoints(request).subscribe((res) => {
402
+ this.isClaimed = true;
403
+ this.openSnackbar('Karma points are successfully claimed.');
404
+ // this.getUserEnrollmentList()
405
+ this.checkIfUserEnrolled();
406
+ }, (error) => {
407
+ this.openSnackbar('something went wrong.');
408
+ });
409
+ }
410
+ ngAfterViewInit() {
411
+ if (this.rcElement) {
412
+ this.rcElem.BottomPos = this.rcElement.nativeElement.offsetTop + this.rcElement.nativeElement.offsetHeight;
413
+ this.rcElem.offSetTop = this.rcElement.nativeElement.offsetTop;
414
+ }
415
+ // Get Time for the batch
416
+ this.timerUnsubscribe = this.timerService.getTimerData()
417
+ .pipe(takeUntil(this.destroySubject$))
418
+ .subscribe((_timer) => {
419
+ this.timer = _timer;
420
+ });
421
+ }
422
+ handleBreadcrumbs() {
423
+ if (this.historyData) {
424
+ if (this.historyData.path === 'Search') {
425
+ const searchurl = `/app/globalsearch`;
426
+ const qParam = {
427
+ q: this.historyData.param,
428
+ };
429
+ // tslint:disable-next-line:max-line-length
430
+ this.breadcrumbs = { url: 'home', titles: [{ title: 'Search', url: searchurl, queryParams: qParam }, { title: 'Details', url: 'none' }] };
431
+ }
432
+ else if (this.historyData.path === 'competency-details') {
433
+ const finalUrl = `/app/learn/browse-by/competency/${this.historyData.param}`;
434
+ // tslint:disable-next-line: max-line-length
435
+ this.breadcrumbs = { url: 'home', titles: [{ title: this.historyData.param, url: finalUrl }, { title: 'Details', url: 'none' }] };
436
+ }
437
+ else if (this.historyData.path === 'all-CBP') {
438
+ const finalURL = `/app/learn/browse-by/provider/${this.historyData.param}`;
439
+ this.breadcrumbs = { url: 'home', titles: [{ title: `all CBP's`, url: finalURL }, { title: 'Details', url: 'none' }] };
440
+ }
441
+ else if (this.historyData.path === 'all-competencies') {
442
+ const finalUrl = `/app/learn/browse-by/competency/all-competencies`;
443
+ // tslint:disable-next-line: max-line-length
444
+ this.breadcrumbs = { url: 'home', titles: [{ title: 'all competencies', url: finalUrl }, { title: 'Details', url: 'none' }] };
445
+ }
446
+ else if (this.historyData.path === 'curatedCollections') {
447
+ const finalUrl = `/app/curatedCollections/home`;
448
+ // tslint:disable-next-line: max-line-length
449
+ this.breadcrumbs = { url: 'home', titles: [{ title: 'curated collections', url: finalUrl }, { title: 'Details', url: 'none' }] };
450
+ }
451
+ else {
452
+ // tslint:disable-next-line:max-line-length
453
+ this.breadcrumbs = { url: 'home', titles: [{ title: 'Learn', url: '/page/learn', icon: 'school' }, { title: 'Details', url: 'none' }] };
454
+ }
455
+ }
456
+ }
457
+ ngAfterViewChecked() {
458
+ try {
459
+ if (this.fragment) {
460
+ // tslint:disable-next-line: no-non-null-assertion
461
+ document.querySelector(`#${this.fragment}`).scrollTo({
462
+ top: 80,
463
+ behavior: 'smooth',
464
+ });
465
+ }
466
+ }
467
+ catch (e) { }
468
+ }
469
+ get enableAnalytics() {
470
+ if (this.configSvc.restrictedFeatures) {
471
+ return !this.configSvc.restrictedFeatures.has('tocAnalytics');
472
+ }
473
+ return false;
474
+ }
475
+ get isResource() {
476
+ if (this.content) {
477
+ const isResource = this.content.primaryCategory === NsContent.EPrimaryCategory.KNOWLEDGE_ARTIFACT ||
478
+ this.content.primaryCategory === NsContent.EPrimaryCategory.RESOURCE
479
+ || this.content.primaryCategory === NsContent.EPrimaryCategory.PRACTICE_RESOURCE
480
+ || this.content.primaryCategory === NsContent.EPrimaryCategory.FINAL_ASSESSMENT
481
+ || this.content.primaryCategory === NsContent.EPrimaryCategory.COMP_ASSESSMENT
482
+ || this.content.primaryCategory === NsContent.EPrimaryCategory.OFFLINE_SESSION
483
+ || !(this.content.children && this.content.children.length);
484
+ if (isResource) {
485
+ this.mobileAppsSvc.sendViewerData(this.content);
486
+ }
487
+ return isResource;
488
+ }
489
+ return false;
490
+ }
491
+ get getStartDate() {
492
+ if (this.enrolledCourseData) {
493
+ const now = new Date().getTime();
494
+ // const batch = _.first(_.filter(this.content['batches'], { batchId: this.currentCourseBatchId }) || [])
495
+ const batch = this.enrolledCourseData.batch;
496
+ this.currentCourseBatchId = batch.batchId;
497
+ if (batch && this.currentCourseBatchId) {
498
+ this.startDate = (_.get(batch, 'startDate'));
499
+ // const parsedDate = moment(this.startDate);
500
+ // const dateOnly = parsedDate.clone().startOf('day');
501
+ const startDateTime = this.startDate && new Date(this.startDate).getTime();
502
+ this.startDateDifference = startDateTime - now;
503
+ if (this.startDateDifference && this.startDateDifference > 0) {
504
+ const days = Math.floor(this.startDateDifference / (1000 * 60 * 60 * 24));
505
+ const hours = Math.floor((this.startDateDifference % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
506
+ const minutes = Math.floor((this.startDateDifference % (1000 * 60 * 60)) / (1000 * 60));
507
+ return (`${days} Days : ${hours} Hours : ${minutes} Minutes`);
508
+ }
509
+ return 'NA';
510
+ }
511
+ return 'NA';
512
+ // if (_.get(batch, 'startDate') && moment(_.get(batch, 'startDate')).isAfter()) {
513
+ // return moment(_.get(batch, 'startDate')).from(now)
514
+ // }
515
+ // if (_.get(batch, 'endDate') && moment(_.get(batch, 'endDate')).isBefore()) {
516
+ // return 'NA'
517
+ // }
518
+ // if (startDateTime && moment(startDateTime).isAfter()) {
519
+ // return moment(startDateTime).from(now)
520
+ // }
521
+ // if (endDateTime && moment(endDateTime).isBefore()) {
522
+ // return 'NA'
523
+ // }
524
+ // return 'NA'
525
+ }
526
+ return 'NA';
527
+ }
528
+ get isBatchInProgress() {
529
+ // if (this.content && this.content['batches']) {
530
+ // const batches = this.content['batches'] as NsContent.IBatch
531
+ // if (this.currentCourseBatchId) {
532
+ // // const now = moment().format('YYYY-MM-DD HH:mm:ss')
533
+ // const now = new Date().getTime()
534
+ // if (this.batchData && this.batchData.content) {
535
+ // const batch = _.first(_.filter(this.batchData.content, { batchId: this.currentCourseBatchId }) || [])
536
+ // if (batch) {
537
+ // // const startDate = moment(batch.startDate).format('YYYY-MM-DD HH:mm:ss')
538
+ // // const endDate = batch.endDate ? moment(batch.endDate).format('YYYY-MM-DD HH:mm:ss') : now
539
+ // // return (
540
+ // // // batch.status &&
541
+ // // moment(startDate).isSameOrBefore(now)
542
+ // // && moment(endDate).isSameOrAfter(now)
543
+ // // )
544
+ // this.startDate = batch && (_.get(batch, 'startTime'))
545
+ // this.endDate = batch && (_.get(batch, 'endTime'))
546
+ // const endDateTime = new Date(this.endDate).getTime()
547
+ // this.endDateDifference = endDateTime - now
548
+ // if(this.endDateDifference > 0) {
549
+ // return batch.status
550
+ // }
551
+ // }
552
+ // return false
553
+ // }
554
+ // return false
555
+ // } return false
556
+ if (this.enrolledCourseData) {
557
+ const now = new Date().getTime();
558
+ const batch = this.enrolledCourseData.batch;
559
+ this.currentCourseBatchId = batch.batchId;
560
+ if (batch && this.currentCourseBatchId) {
561
+ this.startDate = (_.get(batch, 'startDate'));
562
+ this.endDate = (_.get(batch, 'endDate'));
563
+ if (this.endDate) {
564
+ const startDateTime = this.startDate && new Date(this.startDate).getTime();
565
+ let endDate = this.endDate && new Date(this.endDate);
566
+ endDate.setHours(23, 59, 59, 999);
567
+ const endDateTime = endDate.getTime();
568
+ this.startDateDifference = now - startDateTime;
569
+ this.endDateDifference = endDateTime - now;
570
+ if (this.endDateDifference > 0 && this.startDateDifference > 0 && batch.status !== 2) {
571
+ return true;
572
+ }
573
+ return false;
574
+ }
575
+ return true;
576
+ }
577
+ return false;
578
+ }
579
+ return false;
580
+ }
581
+ getUserRating(fireUpdate) {
582
+ if (!this.forPreview) {
583
+ if (this.configSvc.userProfile) {
584
+ this.userId = this.configSvc.userProfile.userId || '';
585
+ }
586
+ if (this.content && this.content.identifier && this.content.primaryCategory) {
587
+ this.ratingSvc.getRating(this.content.identifier, this.content.primaryCategory, this.userId).subscribe((res) => {
588
+ if (res && res.result && res.result.response) {
589
+ this.userRating = res.result.response;
590
+ if (fireUpdate) {
591
+ this.tocSvc.changeUpdateReviews(true);
592
+ }
593
+ }
594
+ this.contentViewEventForNetCore('view');
595
+ }, (err) => {
596
+ this.loggerSvc.error('USER RATING FETCH ERROR >', err);
597
+ });
598
+ }
599
+ }
600
+ setTimeout(() => {
601
+ if (this.contentSource && this.contentSource.nativeElement.offsetHeight > 44) {
602
+ this.sourceEllipsis = true;
603
+ }
604
+ }, 250);
605
+ }
606
+ fetchUserWFForBlended() {
607
+ const applicationIds = (this.batchData && this.batchData.content && this.batchData.content.map(e => e.batchId)) || [];
608
+ const req = {
609
+ applicationIds,
610
+ serviceName: 'blendedprogram',
611
+ limit: 100,
612
+ offset: 0,
613
+ };
614
+ this.contentSvc.fetchBlendedUserWF(req).then((data) => {
615
+ if (data && data.result && data.result.data.length) {
616
+ const latestWF = _.maxBy(data.result.data[0].wfInfo, (el) => {
617
+ return new Date(el.lastUpdatedOn).getTime();
618
+ });
619
+ // latestWF.currentStatus = this.WFBlendedProgramStatus.REJECTED
620
+ /* tslint:disable-next-line */
621
+ this.batchData.workFlow = {
622
+ wfInitiated: true,
623
+ /* tslint:disable-next-line */
624
+ batch: this.batchData && this.batchData.content && this.batchData.content.find((e) => e.batchId === latestWF.applicationId),
625
+ wfItem: latestWF,
626
+ };
627
+ this.tocSvc.setWFData(this.batchData);
628
+ }
629
+ this.loggerSvc.info('fetchBlendedUserWF data == ', data);
630
+ }, (error) => {
631
+ this.loggerSvc.error('CONTENT HISTORY FETCH ERROR >', error);
632
+ });
633
+ }
634
+ checkIfBatchExists(latest) {
635
+ if (!this.batchData || !this.batchData.content) {
636
+ return false;
637
+ }
638
+ return this.batchData.content.find(b => b.batchId === latest.batchId);
639
+ }
640
+ getBatchId() {
641
+ let batchId = '';
642
+ if (this.batchData && this.batchData.content) {
643
+ for (const batch of this.batchData.content) {
644
+ batchId = batch.batchId;
645
+ }
646
+ }
647
+ return batchId;
648
+ }
649
+ handleAutoBatchAssign() {
650
+ if (this.forPreview) {
651
+ this.navigateToPlayerPage('');
652
+ }
653
+ else {
654
+ this.enrollBtnLoading = true;
655
+ this.changeTab = !this.changeTab;
656
+ this.raiseEnrollTelemetry();
657
+ if (this.recommendedCoursesId) {
658
+ this.raiseEnrollTelementryForSakshamAIGenerated();
659
+ }
660
+ if (this.recommendedCoursesId) {
661
+ this.raiseEnrollTelementryForSakshamAIGenerated();
662
+ }
663
+ const batchData = this.contentReadData && this.contentReadData.batches && this.contentReadData.batches[0];
664
+ if (this.content && this.content.primaryCategory === NsContent.EPrimaryCategory.CURATED_PROGRAM) {
665
+ this.autoEnrollCuratedProgram(NsContent.ECourseCategory.CURATED_PROGRAM, batchData);
666
+ }
667
+ else if (this.content && this.content.courseCategory === NsContent.ECourseCategory.MODERATED_PROGRAM) {
668
+ let moderatedBatchData;
669
+ if (this.batchData && this.batchData.content && this.batchData.content.length > 1) {
670
+ moderatedBatchData = this.selectedBatchData && this.selectedBatchData.content && this.selectedBatchData.content[0];
671
+ }
672
+ else {
673
+ moderatedBatchData = this.batchData && this.batchData.content && this.batchData.content[0];
674
+ }
675
+ this.autoEnrollCuratedProgram(NsContent.ECourseCategory.MODERATED_PROGRAM, moderatedBatchData);
676
+ }
677
+ else if (this.content.courseCategory === NsContent.ECourseCategory.LEARNING_PATHWAY) {
678
+ this.autoEnrollLearningPathway(batchData);
679
+ }
680
+ else {
681
+ this.autoAssignEnroll();
682
+ }
683
+ }
684
+ this.contentViewEventForNetCore('enroll');
685
+ }
686
+ autoEnrollLearningPathway(batchData) {
687
+ let batchId = batchData?.batchId;
688
+ if (batchId) {
689
+ this.contentSvc.autoEnrollLP(this.content?.identifier).subscribe((res) => {
690
+ if (res) {
691
+ this.navigateToPlayerPage(batchId);
692
+ this.enrollBtnLoading = false;
693
+ }
694
+ }, (err) => {
695
+ let errMsg = err?.error?.params?.errmsg || err?.params?.errmsg || 'Something went wrong';
696
+ if (errMsg?.includes('course.') && this.content?.courseCategory) {
697
+ errMsg = errMsg.replace('course.', this.content?.courseCategory) + '.';
698
+ }
699
+ this.snackBar.open(errMsg);
700
+ this.enrollBtnLoading = false;
701
+ });
702
+ }
703
+ else {
704
+ this.snackBar.open('No batches found');
705
+ this.enrollBtnLoading = false;
706
+ }
707
+ }
708
+ autoEnrollCuratedProgram(programType, batchData) {
709
+ if (!batchData) {
710
+ this.enrollBtnLoading = false;
711
+ this.snackBar.open('No bacthes found');
712
+ return;
713
+ }
714
+ if (this.content && this.content.identifier) {
715
+ let userId = '';
716
+ if (this.configSvc.userProfile && this.configSvc.userProfile.userId) {
717
+ userId = this.configSvc.userProfile.userId;
718
+ }
719
+ const req = {
720
+ request: {
721
+ userId,
722
+ programId: this.content.identifier,
723
+ // as of now curated program only one batch is coming need to check and modify
724
+ batchId: batchData?.batchId,
725
+ },
726
+ };
727
+ this.contentSvc.autoAssignCuratedBatchApi(req, programType).subscribe((data) => {
728
+ if (data) {
729
+ if (programType === NsContent.ECourseCategory.MODERATED_PROGRAM && batchData.endDate) {
730
+ this.batchData = {
731
+ content: [batchData],
732
+ enrolled: true,
733
+ };
734
+ this.routerChangeHandler(true);
735
+ setTimeout(() => {
736
+ // this.getUserEnrollmentList()
737
+ this.checkIfUserEnrolled();
738
+ }, 2000);
739
+ }
740
+ else {
741
+ this.navigateToPlayerPage(req.request.batchId);
742
+ }
743
+ }
744
+ }, (_error) => {
745
+ // console.log('_error', _error)
746
+ // if(_error && _error.error && _error.error.params && _error.error.params.err && _error.error.params.err.errmsg) {
747
+ this.snackBar.open(_.get(_error, 'error.params.errmsg') || 'Please try again later');
748
+ // }
749
+ this.enrollBtnLoading = false;
750
+ });
751
+ }
752
+ }
753
+ autoAssignEnroll() {
754
+ /************* ✨ Windsurf Command ⭐ *************/
755
+ /**
756
+ * If the user is not enrolled in the course, auto-assigns a batch and navigates to the player page.
757
+ * If the user is already enrolled, does nothing.
758
+ */
759
+ /******* 6d94c646-254c-44d6-a7c3-90bdb9507318 *******/ if (this.baseContentReadData && this.baseContentReadData.identifier) {
760
+ this.contentSvc.autoAssignBatchApi(this.baseContentReadData.identifier, this.selectedLanguage).subscribe((data) => {
761
+ this.batchData = {
762
+ content: data.content,
763
+ enrolled: true,
764
+ };
765
+ const batchId = this.getBatchId();
766
+ if (batchId) {
767
+ this.navigateToPlayerPage(batchId);
768
+ }
769
+ // this.enrollBtnLoading = false
770
+ }, (_error) => {
771
+ this.snackBar.open(_.get(_error, 'error.params.errmsg') || 'Please try again later');
772
+ this.enrollBtnLoading = false;
773
+ });
774
+ }
775
+ }
776
+ async navigateToPlayerPage(batchId) {
777
+ if (this.content) {
778
+ this.enrollBtnLoading = true;
779
+ let firstPlayableContent;
780
+ if (this.content && this.content.identifier === this.selectedLanguage.identifier) {
781
+ firstPlayableContent = this.contentSvc.getFirstChildInHierarchy(this.content);
782
+ }
783
+ else {
784
+ // fetch hierarchy for the selected language in popup first, then get first playable content and redirect to it
785
+ await this.fetchContentHierarchy(this.selectedLanguage.identifier);
786
+ firstPlayableContent = this.contentSvc.getFirstChildInHierarchy(this.content);
787
+ }
788
+ let primaryCategory;
789
+ if (this.content.secureSettings !== undefined) {
790
+ primaryCategory = 'Learning Resource';
791
+ }
792
+ else {
793
+ primaryCategory = firstPlayableContent.primaryCategory || this.content.primaryCategory;
794
+ }
795
+ this.firstResourceLink = this.getResumeUrl(firstPlayableContent, batchId, primaryCategory);
796
+ this.router.navigate([`${this.firstResourceLink.url}`], { queryParams: { ...this.firstResourceLink.queryParams, fromAITutor: this.fromAITutor } });
797
+ }
798
+ }
799
+ fetchBatchDetails() {
800
+ if (this.content && this.content.identifier) {
801
+ const req = {
802
+ request: {
803
+ filters: {
804
+ courseId: this.content.identifier,
805
+ status: ['0', '1', '2'],
806
+ // createdBy: 'fca2925f-1eee-4654-9177-fece3fd6afc9',
807
+ },
808
+ sort_by: { createdDate: 'desc' },
809
+ },
810
+ };
811
+ this.contentSvc.fetchCourseBatches(req).subscribe((data) => {
812
+ this.batchData = data;
813
+ this.batchData.enrolled = false;
814
+ this.tocSvc.setBatchData(this.batchData);
815
+ this.routerChangeHandler(false);
816
+ }, (error) => {
817
+ this.loggerSvc.error('CONTENT HISTORY FETCH ERROR >', error);
818
+ });
819
+ }
820
+ }
821
+ scrollToTop() {
822
+ (function smoothscroll() {
823
+ const currentScroll = document.documentElement.scrollTop || document.body.scrollTop;
824
+ if (currentScroll > 0) {
825
+ // window.requestAnimationFrame(smoothscroll)
826
+ // window.scrollTo(0, currentScroll - (currentScroll / 5))
827
+ window.scrollTo({
828
+ top: 0,
829
+ behavior: 'smooth',
830
+ });
831
+ }
832
+ })();
833
+ }
834
+ getCompetencies(competencies) {
835
+ const competenciesArray = JSON.parse(competencies);
836
+ const competencyStringArray = [];
837
+ competenciesArray.map((c) => {
838
+ competencyStringArray.push(c.name);
839
+ });
840
+ return competencyStringArray;
841
+ }
842
+ get showIntranetMsg() {
843
+ if (this.isMobile) {
844
+ return true;
845
+ }
846
+ return this.showIntranetMessage;
847
+ }
848
+ get showStart() {
849
+ return this.tocSvc.showStartButton(this.content);
850
+ }
851
+ get isPostAssessment() {
852
+ if (!(this.tocConfig && this.tocConfig.postAssessment)) {
853
+ return false;
854
+ }
855
+ if (this.content) {
856
+ return (this.content.primaryCategory === NsContent.EPrimaryCategory.COURSE &&
857
+ this.content.learningMode === 'Instructor-Led');
858
+ }
859
+ return false;
860
+ }
861
+ get isMobile() {
862
+ return this.utilitySvc.isMobile;
863
+ }
864
+ get showSubtitleOnBanner() {
865
+ return this.tocSvc.subtitleOnBanners;
866
+ }
867
+ handleEnrollmentEndDate(batch) {
868
+ const enrollmentEndDate = dayjs(_.get(batch, 'enrollmentEndDate')).format('YYYY-MM-DD');
869
+ const systemDate = dayjs();
870
+ return enrollmentEndDate ? dayjs(enrollmentEndDate).isBefore(systemDate) : false;
871
+ }
872
+ openSnackbar(primaryMsg, duration = 5000) {
873
+ this.snackBar.open(primaryMsg, 'X', {
874
+ duration,
875
+ });
876
+ }
877
+ get showInstructorLedMsg() {
878
+ return (this.showActionButtons &&
879
+ this.content &&
880
+ this.content.learningMode === 'Instructor-Led' &&
881
+ !this.content.children.length &&
882
+ !this.content.artifactUrl);
883
+ }
884
+ get isHeaderHidden() {
885
+ return this.isResource && this.content && !this.content.artifactUrl.length;
886
+ }
887
+ get showActionButtons() {
888
+ return (this.actionBtnStatus !== 'wait' &&
889
+ this.content &&
890
+ this.content.status !== 'Deleted' &&
891
+ this.content.status !== 'Expired');
892
+ }
893
+ get showButtonContainer() {
894
+ return (this.actionBtnStatus === 'grant' &&
895
+ !(this.isMobile && this.content && this.content.isInIntranet) &&
896
+ !(this.content &&
897
+ this.content.contentType === 'Course' &&
898
+ this.content.children.length === 0 &&
899
+ !this.content.artifactUrl) &&
900
+ !(this.content && this.content.contentType === 'Resource' && !this.content.artifactUrl));
901
+ }
902
+ getResumeDataFromList(type) {
903
+ const resumeCopy = [...this.resumeData];
904
+ if (resumeCopy && resumeCopy.length) {
905
+ if (!type) {
906
+ // tslint:disable-next-line:max-line-length
907
+ const lastItem = resumeCopy && resumeCopy.sort((a, b) => new Date(b.lastAccessTime).getTime() - new Date(a.lastAccessTime).getTime()).shift();
908
+ return {
909
+ identifier: lastItem.contentId,
910
+ mimeType: lastItem.progressdetails && lastItem.progressdetails.mimeType,
911
+ };
912
+ }
913
+ const firstItem = resumeCopy && resumeCopy.length && resumeCopy[0];
914
+ return {
915
+ identifier: firstItem.contentId,
916
+ mimeType: firstItem.progressdetails && firstItem.progressdetails.mimeType,
917
+ };
918
+ }
919
+ return {};
920
+ }
921
+ modifySensibleContentRating() {
922
+ if (this.content &&
923
+ this.content.averageRating &&
924
+ typeof this.content.averageRating !== 'number') {
925
+ this.content.averageRating = this.content.averageRating[this.configSvc.rootOrg || ''];
926
+ }
927
+ if (this.content && this.content.totalRating && typeof this.content.totalRating !== 'number') {
928
+ this.content.totalRating = this.content.totalRating[this.configSvc.rootOrg || ''];
929
+ }
930
+ }
931
+ getLearningUrls() {
932
+ if (this.content) {
933
+ this.isPracticeVisible = Boolean(this.tocSvc.filterToc(this.content, NsContent.EFilterCategory.PRACTICE));
934
+ this.isAssessVisible = Boolean(this.tocSvc.filterToc(this.content, NsContent.EFilterCategory.ASSESS));
935
+ const firstPlayableContent = this.contentSvc.getFirstChildInHierarchy(this.content);
936
+ let primaryCategory;
937
+ if (this.content.secureSettings !== undefined) {
938
+ primaryCategory = 'Learning Resource';
939
+ }
940
+ else {
941
+ primaryCategory = firstPlayableContent.primaryCategory || this.content.primaryCategory;
942
+ }
943
+ this.firstResourceLink = this.getResumeUrl(firstPlayableContent, null, primaryCategory);
944
+ /* tslint:disable-next-line */
945
+ // if (firstPlayableContent.optionalReading && firstPlayableContent.primaryCategory === 'Learning Resource') {
946
+ // this.updateProgress(2, firstPlayableContent.identifier)
947
+ // }
948
+ }
949
+ }
950
+ assignPathAndUpdateBanner(url) {
951
+ const path = url.split('/').pop();
952
+ if (path && this.validPaths.has(path)) {
953
+ this.routePath = path;
954
+ this.updateBannerUrl();
955
+ }
956
+ }
957
+ updateBannerUrl() {
958
+ if (this.banners) {
959
+ this.bannerUrl = this.domSanitizer.bypassSecurityTrustStyle(`url(${this.banners[this.routePath]})`);
960
+ }
961
+ }
962
+ playIntroVideo() {
963
+ if (this.content) {
964
+ this.dialog.open(AppTocDialogIntroVideoComponent, {
965
+ data: this.content.introductoryVideo,
966
+ height: '350px',
967
+ width: '620px',
968
+ });
969
+ }
970
+ }
971
+ get sanitizedIntroductoryVideoIcon() {
972
+ if (this.content && this.content.introductoryVideoIcon) {
973
+ return this.domSanitizer.bypassSecurityTrustStyle(`url(${this.content.introductoryVideoIcon})`);
974
+ }
975
+ return null;
976
+ }
977
+ fetchExternalContentAccess() {
978
+ if (this.content && this.content.registrationUrl) {
979
+ if (!this.forPreview) {
980
+ this.externalContentFetchStatus = 'fetching';
981
+ this.registerForExternal = false;
982
+ this.tocSvc.fetchExternalContentAccess(this.content.identifier).subscribe(data => {
983
+ this.externalContentFetchStatus = 'done';
984
+ this.registerForExternal = data.hasAccess;
985
+ }, _error => {
986
+ this.externalContentFetchStatus = 'done';
987
+ this.registerForExternal = false;
988
+ });
989
+ }
990
+ else {
991
+ this.externalContentFetchStatus = 'done';
992
+ this.registerForExternal = true;
993
+ }
994
+ }
995
+ }
996
+ getRatingIcon(ratingIndex) {
997
+ if (this.content && this.content.averageRating) {
998
+ const avgRating = this.content.averageRating;
999
+ const ratingFloor = Math.floor(avgRating);
1000
+ if (ratingIndex <= ratingFloor) {
1001
+ return 'star';
1002
+ }
1003
+ if (ratingFloor === ratingIndex - 1 && avgRating % 1 > 0) {
1004
+ return 'star_half';
1005
+ }
1006
+ }
1007
+ return 'star_border';
1008
+ }
1009
+ checkRegistrationStatus() {
1010
+ const source = (this.content && this.content.sourceShortName) || '';
1011
+ if (!this.forPreview &&
1012
+ !this.isRegistrationSupported &&
1013
+ this.checkRegistrationSources.has(source)) {
1014
+ this.contentSvc
1015
+ .getRegistrationStatus(source)
1016
+ .then(res => {
1017
+ if (res.hasAccess) {
1018
+ this.actionBtnStatus = 'grant';
1019
+ }
1020
+ else {
1021
+ this.actionBtnStatus = 'reject';
1022
+ if (res.registrationUrl && this.content) {
1023
+ this.content.registrationUrl = res.registrationUrl;
1024
+ }
1025
+ }
1026
+ })
1027
+ .catch(_err => { });
1028
+ }
1029
+ else {
1030
+ this.actionBtnStatus = 'grant';
1031
+ }
1032
+ }
1033
+ generateQuery(type) {
1034
+ if (this.firstResourceLink && (type === 'START' || type === 'START_OVER')) {
1035
+ let qParams = {
1036
+ ...this.firstResourceLink.queryParams,
1037
+ viewMode: type,
1038
+ batchId: this.getBatchId(),
1039
+ };
1040
+ if (this.contextId && this.contextPath) {
1041
+ qParams = {
1042
+ ...qParams,
1043
+ collectionId: this.contextId,
1044
+ collectionType: this.contextPath,
1045
+ };
1046
+ }
1047
+ if (this.forPreview) {
1048
+ delete qParams.viewMode;
1049
+ }
1050
+ qParams = {
1051
+ ...qParams,
1052
+ channelId: this.channelId,
1053
+ };
1054
+ return qParams;
1055
+ }
1056
+ if (this.resumeDataLink && type === 'RESUME') {
1057
+ let qParams = {
1058
+ ...this.resumeDataLink.queryParams,
1059
+ batchId: this.getBatchId(),
1060
+ viewMode: 'RESUME',
1061
+ // courseName: this.content ? this.content.name : '',
1062
+ };
1063
+ if (this.contextId && this.contextPath) {
1064
+ qParams = {
1065
+ ...qParams,
1066
+ collectionId: this.contextId,
1067
+ collectionType: this.contextPath,
1068
+ };
1069
+ }
1070
+ if (this.forPreview) {
1071
+ delete qParams.viewMode;
1072
+ }
1073
+ qParams = {
1074
+ ...qParams,
1075
+ channelId: this.channelId,
1076
+ };
1077
+ return qParams;
1078
+ }
1079
+ if (this.forPreview) {
1080
+ return {};
1081
+ }
1082
+ return {
1083
+ batchId: this.getBatchId(),
1084
+ viewMode: type,
1085
+ };
1086
+ }
1087
+ get isInIFrame() {
1088
+ try {
1089
+ return window.self !== window.top;
1090
+ }
1091
+ catch (e) {
1092
+ return true;
1093
+ }
1094
+ }
1095
+ openFeedbackDialog(content) {
1096
+ const dialogRef = this.dialog.open(ContentRatingV2DialogComponent, {
1097
+ width: '768px',
1098
+ data: { content, userId: this.userId, userRating: this.userRating },
1099
+ });
1100
+ dialogRef.afterClosed().subscribe((result) => {
1101
+ if (result) {
1102
+ this.getUserRating(true);
1103
+ // this.getUserEnrollmentList()
1104
+ this.checkIfUserEnrolled();
1105
+ this.resetRatingsService.setRatingServiceUpdate(true);
1106
+ }
1107
+ });
1108
+ }
1109
+ updateProgress(status, resourceId) {
1110
+ const collectionId = this.route.snapshot.params.id ?
1111
+ this.route.snapshot.params.id : '';
1112
+ const batchId = this.route.snapshot.queryParams.batchId ?
1113
+ this.route.snapshot.queryParams.batchId : '';
1114
+ const isPreAssessment = this.route.snapshot.queryParams.preAssessment;
1115
+ if (isPreAssessment) {
1116
+ return this.viewerSvc
1117
+ .realTimeProgressUpdateForPreAssessmentQuiz(resourceId, status);
1118
+ }
1119
+ return this.viewerSvc.realTimeProgressUpdateQuiz(resourceId, collectionId, batchId, status);
1120
+ }
1121
+ getProgramDuration(batchData) {
1122
+ if (batchData) {
1123
+ const startDate = dayjs(dayjs(batchData.startDate).format('YYYY-MM-DD'));
1124
+ const endDate = dayjs(dayjs(batchData.endDate).format('YYYY-MM-DD'));
1125
+ // adding 1 to include the start date
1126
+ return (endDate.diff(startDate, 'days') + 1);
1127
+ }
1128
+ return '';
1129
+ }
1130
+ withdrawOrEnroll(data) {
1131
+ if (data === NsContent.WFBlendedProgramStatus.INITIATE) {
1132
+ this.fetchUserWFForBlended();
1133
+ }
1134
+ }
1135
+ handleCapitalize(str, type) {
1136
+ let returnValue = '';
1137
+ if (str) {
1138
+ if (type === 'name') {
1139
+ returnValue = str.split(' ').map(_str => {
1140
+ return _str.charAt(0).toUpperCase() + _str.slice(1);
1141
+ }).join(' ');
1142
+ }
1143
+ else {
1144
+ returnValue = str && (str.charAt(0).toUpperCase() + str.slice(1));
1145
+ }
1146
+ }
1147
+ return returnValue;
1148
+ }
1149
+ handleParseJsonData(s) {
1150
+ try {
1151
+ const parsedString = JSON.parse(s);
1152
+ return parsedString;
1153
+ }
1154
+ catch {
1155
+ return [];
1156
+ }
1157
+ }
1158
+ handleNavigateToReviews() {
1159
+ const elementToView = document.getElementById('reviewContainer');
1160
+ if (elementToView) {
1161
+ window.scrollTo({
1162
+ top: elementToView.offsetTop,
1163
+ behavior: 'smooth',
1164
+ });
1165
+ }
1166
+ }
1167
+ raiseCertIntreactTelemetry() {
1168
+ this.events.raiseInteractTelemetry({
1169
+ type: WsEvents.EnumInteractTypes.CLICK,
1170
+ id: 'view-certificate',
1171
+ subType: WsEvents.EnumInteractSubTypes.CERTIFICATE,
1172
+ }, {
1173
+ id: this.certId,
1174
+ type: WsEvents.EnumInteractSubTypes.CERTIFICATE,
1175
+ });
1176
+ }
1177
+ translateLabels(label, type) {
1178
+ return this.langtranslations.translateLabel(label, type, '');
1179
+ }
1180
+ getLastPlayedResource() {
1181
+ let firstPlayableContent;
1182
+ let resumeDataV2;
1183
+ if (this.resumeData && this.resumeData.length > 0 && this.content) {
1184
+ if (this.content.completionPercentage === 100) {
1185
+ resumeDataV2 = this.getResumeDataFromList('start');
1186
+ }
1187
+ else {
1188
+ resumeDataV2 = this.getResumeDataFromList();
1189
+ }
1190
+ this.expandThePath(resumeDataV2.identifier);
1191
+ }
1192
+ else {
1193
+ if (this.content) {
1194
+ firstPlayableContent = this.contentSvc.getFirstChildInHierarchy(this.content);
1195
+ this.expandThePath(firstPlayableContent.identifier);
1196
+ }
1197
+ }
1198
+ }
1199
+ expandThePath(resourceId) {
1200
+ if (this.content && resourceId) {
1201
+ const path = this.utilitySvc.getPath(this.content, resourceId);
1202
+ this.pathSet = new Set(path.map((u) => u.identifier));
1203
+ }
1204
+ }
1205
+ raiseEnrollTelemetry() {
1206
+ this.events.raiseInteractTelemetry({
1207
+ type: 'click',
1208
+ subType: 'enroll',
1209
+ id: this.content ? this.content.identifier : '',
1210
+ }, {
1211
+ id: this.content ? this.content.identifier : '',
1212
+ type: this.content ? this.content.primaryCategory : '',
1213
+ }, {
1214
+ pageIdExt: `btn-enroll`,
1215
+ module: WsEvents.EnumTelemetrymodules.CONTENT,
1216
+ });
1217
+ }
1218
+ raiseEnrollTelementryForSakshamAIGenerated() {
1219
+ this.events.raiseInteractTelemetry({
1220
+ type: 'click',
1221
+ subType: 'enroll',
1222
+ id: this.content ? this.content.identifier : '',
1223
+ target: {
1224
+ id: this.recommendedCoursesId,
1225
+ ver: "1.0",
1226
+ type: "igot-ai"
1227
+ },
1228
+ }, {
1229
+ id: this.content ? this.content.identifier : '',
1230
+ type: this.content ? this.content.primaryCategory : '',
1231
+ }, {
1232
+ pageId: `/app/toc/${this.content?.identifier}/overview_btn-enroll`,
1233
+ module: WsEvents.EnumTelemetrymodules.CONTENT,
1234
+ });
1235
+ }
1236
+ onClickOfShare() {
1237
+ this.enableShare = true;
1238
+ this.raiseTelemetryForShare('shareContent');
1239
+ }
1240
+ /* tslint:disable */
1241
+ raiseTelemetryForShare(subType) {
1242
+ this.events.raiseInteractTelemetry({
1243
+ type: 'click',
1244
+ subType,
1245
+ id: this.content ? this.content.identifier : '',
1246
+ }, {
1247
+ id: this.content ? this.content.identifier : '',
1248
+ type: this.content ? this.content.primaryCategory : '',
1249
+ }, {
1250
+ pageIdExt: `btn-${subType}`,
1251
+ module: WsEvents.EnumTelemetrymodules.CONTENT,
1252
+ });
1253
+ }
1254
+ resetEnableShare() {
1255
+ this.enableShare = false;
1256
+ }
1257
+ translateLabel(label, type) {
1258
+ if (label && type) {
1259
+ return this.langtranslations.translateLabel(label, type, '');
1260
+ }
1261
+ }
1262
+ ngOnDestroy() {
1263
+ if (this.routeSubscription) {
1264
+ this.routeSubscription.unsubscribe();
1265
+ }
1266
+ if (this.batchSubscription) {
1267
+ this.batchSubscription.unsubscribe();
1268
+ }
1269
+ if (this.batchDataSubscription) {
1270
+ this.batchDataSubscription.unsubscribe();
1271
+ }
1272
+ this.tocSvc.analyticsFetchStatus = 'none';
1273
+ if (this.routerParamSubscription) {
1274
+ this.routerParamSubscription.unsubscribe();
1275
+ }
1276
+ if (this.selectedBatchSubscription) {
1277
+ this.selectedBatchSubscription.unsubscribe();
1278
+ }
1279
+ if (this.resumeDataSubscription) {
1280
+ this.resumeDataSubscription.unsubscribe();
1281
+ }
1282
+ if (this.timerUnsubscribe) {
1283
+ this.timerUnsubscribe.unsubscribe();
1284
+ }
1285
+ if (this.hashmapUpdatedSubscription) {
1286
+ this.hashmapUpdatedSubscription.unsubscribe();
1287
+ }
1288
+ // Clear content data to prevent stale data when navigating between contents
1289
+ this.tocSvc.resetContentData();
1290
+ }
1291
+ programEnrollCall(batchData) {
1292
+ this.autoEnrollCuratedProgram(NsContent.ECourseCategory.MODERATED_PROGRAM, batchData);
1293
+ }
1294
+ raiseTelemetryForPublic($event) {
1295
+ // Check if we should first prevent navigation to player page
1296
+ const shouldPreventNavigation = this.shouldShowSurveyPopup();
1297
+ if (shouldPreventNavigation) {
1298
+ $event.preventDefault();
1299
+ $event.stopPropagation();
1300
+ }
1301
+ this.events.raiseInteractTelemetry({
1302
+ type: 'click',
1303
+ id: "view-assessment",
1304
+ subType: "anonymous-assessment",
1305
+ }, {}, {
1306
+ module: 'Landing Page',
1307
+ });
1308
+ if (shouldPreventNavigation) {
1309
+ // Prepare navigation details
1310
+ const navigationUrl = (this.resumeData && !this.certData) ? this.resumeDataLink?.url : this.firstResourceLink?.url;
1311
+ const queryParams = (this.resumeData && !this.certData) ? this.generateQuery('RESUME') : this.generateQuery('START');
1312
+ // Open survey popup directly with navigation details
1313
+ if (navigationUrl) {
1314
+ this.openPublicSurveyPopup(navigationUrl, queryParams);
1315
+ }
1316
+ return false;
1317
+ }
1318
+ }
1319
+ shouldShowSurveyPopup() {
1320
+ // Single source of truth for survey popup condition
1321
+ // Check if it's public view and content is a case study
1322
+ return this.forPreview && this.content && this.contentReadData
1323
+ && this.contentReadData.courseCategory === NsContent.ECourseCategory.CASE_STUDY;
1324
+ }
1325
+ async checkIfUserEnrolled() {
1326
+ this.contentLibSvc.oneStepResumeEnable = false;
1327
+ this.enrollBtnLoading = true;
1328
+ this.tocSvc.contentLoader.next(true);
1329
+ // only for resource
1330
+ // tslint:disable-next-line
1331
+ if (this.baseContentReadData && this.baseContentReadData.identifier && this.baseContentReadData.primaryCategory !== this.primaryCategory.COURSE &&
1332
+ this.baseContentReadData.primaryCategory !== this.primaryCategory.PROGRAM &&
1333
+ this.baseContentReadData.primaryCategory !== this.primaryCategory.MANDATORY_COURSE_GOAL &&
1334
+ this.baseContentReadData.primaryCategory !== this.primaryCategory.STANDALONE_ASSESSMENT &&
1335
+ this.baseContentReadData.primaryCategory !== this.primaryCategory.BLENDED_PROGRAM &&
1336
+ this.baseContentReadData.primaryCategory !== this.primaryCategory.CURATED_PROGRAM) {
1337
+ // const collectionId = this.isResource ? '' : this.baseContentReadData.identifier
1338
+ return this.getContinueLearningData(this.baseContentReadData.identifier);
1339
+ }
1340
+ let enrolledCourse;
1341
+ if (this.content && this.baseContentReadData && this.baseContentReadData.identifier && !this.forPreview) {
1342
+ if (this.userEnrollmentList && this.userEnrollmentList.length) {
1343
+ enrolledCourse = this.userEnrollmentList.find((course) => {
1344
+ const identifier = this.baseContentReadData && this.baseContentReadData.identifier || '';
1345
+ if (course.courseId !== identifier) {
1346
+ return undefined;
1347
+ }
1348
+ return course;
1349
+ });
1350
+ }
1351
+ // If current course is present in the list of user enrolled course
1352
+ if (enrolledCourse && enrolledCourse.batchId) {
1353
+ this.resumeDataSubscription = this.tocSvc.resumeData.subscribe((res) => {
1354
+ if (res) {
1355
+ this.resumeData = res;
1356
+ this.getLastPlayedResource();
1357
+ this.generateResumeDataLinkNew();
1358
+ }
1359
+ });
1360
+ this.tocSvc.checkModuleWiseData(this.content);
1361
+ this.enrolledCourseData = enrolledCourse;
1362
+ this.isCourseCompletedOnThisMonth();
1363
+ this.currentCourseBatchId = enrolledCourse.batchId;
1364
+ // this.downloadCert(enrolledCourse.issuedCertificates)
1365
+ if (enrolledCourse && enrolledCourse.issuedCertificates &&
1366
+ enrolledCourse.issuedCertificates.length) {
1367
+ const certificate = enrolledCourse.issuedCertificates.sort((a, b) => new Date(b.lastIssuedOn).getTime() - new Date(a.lastIssuedOn).getTime());
1368
+ const certId = certificate[0].identifier;
1369
+ this.certId = certId;
1370
+ if (this.content) {
1371
+ this.content['certificateObj'] = {
1372
+ certId,
1373
+ certData: '',
1374
+ };
1375
+ }
1376
+ }
1377
+ // if enrolled course is completed then to make all languages courses as well as all content as completed
1378
+ if (this.contentReadData.courseCategory !== NsContent.ECourseCategory.LEARNING_PATHWAY && enrolledCourse.status === 2) {
1379
+ this.content['completionPercentage'] = 100;
1380
+ this.content['completionStatus'] = 2;
1381
+ await this.tocSvc.mapCompletionChildPercentageProgram(this.content);
1382
+ let contentLag = this.contentLangSvc.getContentLanguage(this.contentReadData);
1383
+ this.getContinueLearningData(this.baseContentReadData.identifier, enrolledCourse.batchId, contentLag);
1384
+ this.enrollBtnLoading = false;
1385
+ this.tocSvc.mapModuleCount(this.content);
1386
+ this.checkForCompletionSurveyTrigger();
1387
+ }
1388
+ else {
1389
+ if (this.contentReadData && this.contentReadData.cumulativeTracking && this.contentReadData.courseCategory !== NsContent.ECourseCategory.LEARNING_PATHWAY) {
1390
+ await this.tocSvc.mapCompletionPercentageProgram(this.content, this.userEnrollmentList);
1391
+ this.checkForCompletionSurveyTrigger();
1392
+ this.resumeDataSubscription = this.tocSvc.resumeData.subscribe((res) => {
1393
+ if (res) {
1394
+ this.resumeData = res;
1395
+ this.getLastPlayedResource();
1396
+ this.generateResumeDataLinkNew();
1397
+ }
1398
+ });
1399
+ this.enrollBtnLoading = false;
1400
+ // this.tocSvc.contentLoader.next(false)
1401
+ }
1402
+ else {
1403
+ if (this.contentReadData && this.contentReadData.courseCategory !== NsContent.ECourseCategory.LEARNING_PATHWAY) {
1404
+ let contentLag = this.contentLangSvc.getContentLanguage(this.contentReadData);
1405
+ this.getContinueLearningData(this.baseContentReadData.identifier, enrolledCourse.batchId, contentLag);
1406
+ this.content['completionPercentage'] = enrolledCourse.completionPercentage;
1407
+ this.tocSvc.mapModuleCount(this.content);
1408
+ }
1409
+ this.enrollBtnLoading = false;
1410
+ // this.tocSvc.contentLoader.next(false)
1411
+ }
1412
+ }
1413
+ if (this.baseContentReadData?.courseCategory === NsContent.ECourseCategory.LEARNING_PATHWAY) {
1414
+ // this.appTocV2Svc.mapContentHierarchyProgressUpdate(this.content,this.userEnrollmentList)
1415
+ console.log('mapping progress for learning pathway', this.content);
1416
+ this.tocSvc.callHirarchyProgressHashmap(this.content);
1417
+ console.log('mapped progress for learning pathway', this.tocSvc.hashmap);
1418
+ this.tocSvc.computeMilestoneLockingStatus(true);
1419
+ this.syncMilestoneLockStatus();
1420
+ }
1421
+ this.batchData = {
1422
+ content: [enrolledCourse.batch],
1423
+ enrolled: true,
1424
+ };
1425
+ this.tocSvc.setBatchData(this.batchData);
1426
+ this.tocSvc.getSelectedBatchData(this.batchData);
1427
+ this.tocSvc.mapSessionCompletionPercentage(this.batchData, this.resumeData);
1428
+ this.routerChangeHandler(true);
1429
+ this.tocSvc.contentLoader.next(false);
1430
+ }
1431
+ else {
1432
+ this.tocSvc.checkModuleWiseData(this.content);
1433
+ this.tocSvc.mapModuleCount(this.content);
1434
+ // It's understood that user is not already enrolled
1435
+ // Fetch the available batches and present to user
1436
+ if (this.content.primaryCategory === this.primaryCategory.COURSE
1437
+ || this.content.primaryCategory !== this.primaryCategory.PROGRAM) {
1438
+ // Disabling auto enrollment to batch
1439
+ if (this.content.primaryCategory === this.primaryCategory.BLENDED_PROGRAM) {
1440
+ this.fetchBatchDetails();
1441
+ }
1442
+ }
1443
+ else {
1444
+ this.fetchBatchDetails();
1445
+ }
1446
+ this.tocSvc.callHirarchyProgressHashmap(this.content);
1447
+ // For Learning Pathways, compute milestone locking when not enrolled (all locked)
1448
+ if (this.baseContentReadData?.courseCategory === NsContent.ECourseCategory.LEARNING_PATHWAY) {
1449
+ this.tocSvc.computeMilestoneLockingStatus(false);
1450
+ this.syncMilestoneLockStatus();
1451
+ }
1452
+ this.enrollBtnLoading = false;
1453
+ this.tocSvc.contentLoader.next(false);
1454
+ }
1455
+ }
1456
+ this.skeletonLoader = false;
1457
+ }
1458
+ bindCompletionPercentage() {
1459
+ let completionPercentage = 0;
1460
+ let completionStatus = 0;
1461
+ if (this.languageMapProgress && Object.keys(this.languageMapProgress).length) {
1462
+ let langPercentage = this.languageMapProgress[this.selectedLanguage.langId] || 0;
1463
+ completionPercentage = langPercentage;
1464
+ completionStatus = langPercentage >= 100 ? 2 : 0;
1465
+ }
1466
+ else {
1467
+ let enrolledData = this.tocSvc.findEnrolmentByCollectionId(this.userEnrollmentList, (this.baseContentReadData?.identifier || ''));
1468
+ if (enrolledData && enrolledData.completionPercentage) {
1469
+ completionPercentage = enrolledData.completionPercentage;
1470
+ completionStatus = enrolledData.status;
1471
+ }
1472
+ }
1473
+ if (this.content) {
1474
+ this.content.completionPercentage = completionPercentage;
1475
+ this.content.completionStatus = completionStatus;
1476
+ }
1477
+ }
1478
+ handleAcceptRelevent() {
1479
+ this.saveFeedback('', 1);
1480
+ }
1481
+ handleDeclineRelevent() {
1482
+ const dialogRef = this.dialog.open(NonReleventFeedbackDialogComponent, {
1483
+ disableClose: true,
1484
+ width: '502px',
1485
+ panelClass: ['relevent-feedback-dialog'],
1486
+ });
1487
+ dialogRef.afterClosed().subscribe((result) => {
1488
+ if (result) {
1489
+ this.saveFeedback(result, 0);
1490
+ dialogRef.close();
1491
+ }
1492
+ else {
1493
+ dialogRef.close();
1494
+ }
1495
+ });
1496
+ }
1497
+ contentViewEventForNetCore(eventType) {
1498
+ if (this.configSvc.netcoreConfig && this.configSvc.netcoreConfig.netcoreWebConfig // NOSONAR
1499
+ && this.configSvc.netcoreConfig.netcoreWebConfig.isActive // NOSONAR
1500
+ && this.configSvc.netcoreConfig.netcoreWebConfig.events // NOSONAR
1501
+ && this.configSvc.netcoreConfig.netcoreWebConfig.events.content_view // NOSONAR
1502
+ && this.configSvc.netcoreConfig.netcoreWebConfig.events.content_view.isActive // NOSONAR
1503
+ ) {
1504
+ let payload = {};
1505
+ // if (this.configSvc && this.configSvc.unMappedUser && this.configSvc.unMappedUser.identifier) { // NOSONAR
1506
+ // payload['pk^userid'] = this.configSvc.unMappedUser.identifier.trim().toLowerCase()
1507
+ // }
1508
+ if (this.content && this.content.name) {
1509
+ payload['content_name'] = this.content.name;
1510
+ }
1511
+ if (this.content && this.content.courseCategory) {
1512
+ payload['content_category'] = this.content.courseCategory;
1513
+ }
1514
+ if (this.content && this.content.identifier) {
1515
+ payload['content_id'] = this.content.identifier;
1516
+ }
1517
+ // if(this.content && this.content.name) {
1518
+ payload['content_url'] = window.location.href;
1519
+ // }
1520
+ if (this.content && this.content.appIcon) {
1521
+ payload['content_image'] = this.content.appIcon;
1522
+ }
1523
+ if (this.content && this.content.duration) {
1524
+ payload['content_duration'] = this.content.duration && Number(this.content.duration) > 0 ? Number(this.content.duration) : 0;
1525
+ }
1526
+ else {
1527
+ payload['content_duration'] = 0;
1528
+ }
1529
+ if (this.content && this.content.avgRating) {
1530
+ payload['content_rating'] = this.content.avgRating;
1531
+ payload['content rating'] = this.content.avgRating;
1532
+ }
1533
+ if (this.content && this.content.totalNoOfRating) {
1534
+ payload['no_users_rated'] = this.content.totalNoOfRating;
1535
+ }
1536
+ // if(this.content && this.content.name) {
1537
+ payload['learning_path_content'] = this.userEnrollmentList && this.userEnrollmentList.length ? true : false;
1538
+ payload['learning path content'] = this.userEnrollmentList && this.userEnrollmentList.length ? true : false;
1539
+ // }
1540
+ if (this.content && this.content.source) {
1541
+ payload['content_provider_name'] = this.content.source;
1542
+ }
1543
+ // console.log('payload', payload)
1544
+ if (eventType === 'view') {
1545
+ this.netCoreService.trackEventForContentAndEvent('content_view', this.configSvc.unMappedUser.identifier.trim().toLowerCase(), payload);
1546
+ }
1547
+ else if (eventType === 'enroll') {
1548
+ this.netCoreService.trackEventForContentAndEvent('content_enrolment', this.configSvc.unMappedUser.identifier.trim().toLowerCase(), payload);
1549
+ }
1550
+ else if (eventType === 'complete') {
1551
+ this.netCoreService.trackEventForContentAndEvent('content_completion', this.configSvc.unMappedUser.identifier.trim().toLowerCase(), payload);
1552
+ }
1553
+ }
1554
+ }
1555
+ secondsToTime(d) {
1556
+ d = Number(d);
1557
+ var h = Math.floor(d / 3600);
1558
+ var m = Math.floor(d % 3600 / 60);
1559
+ var s = Math.floor(d % 3600 % 60);
1560
+ var hDisplay = h > 0 ? h + (h == 1 ? " hour, " : " hours, ") : "";
1561
+ var mDisplay = m > 0 ? m + (m == 1 ? " minute, " : " minutes, ") : "";
1562
+ var sDisplay = s > 0 ? s + (s == 1 ? " second" : " seconds") : "";
1563
+ return hDisplay + mDisplay + sDisplay;
1564
+ }
1565
+ async saveFeedback(comment, rating = 0) {
1566
+ const payload = {
1567
+ "recommendation_id": this.recommendedCoursesId,
1568
+ "course_id": this.courseID,
1569
+ "rating": rating,
1570
+ "comments": comment,
1571
+ "user_id": this.configSvc.userProfile?.userId || ''
1572
+ };
1573
+ const response = await this.contentLibSvc.saveFeedbackSakshamAI(payload).toPromise().catch(() => { });
1574
+ if (response && response?.message) {
1575
+ this.matSnackbarNew.open('Thank you for your feedback.', 'X', { duration: SNACKBAR_DURATION, panelClass: ['success'] });
1576
+ this.feedbackGiven = { course_id: this.courseID, rating: rating, comments: comment };
1577
+ }
1578
+ else if (!response) {
1579
+ this.matSnackbarNew.open('Something is wrong. Please try again later.', 'X', { duration: SNACKBAR_DURATION, panelClass: ['error'] });
1580
+ }
1581
+ }
1582
+ playResumeForAI() {
1583
+ if (this.content) {
1584
+ if (this.firstResourceLink) {
1585
+ this.router.navigate([this.firstResourceLink.url], { queryParams: this.firstResourceLink.queryParams });
1586
+ }
1587
+ }
1588
+ }
1589
+ enrollUserToAI() {
1590
+ this.fromAITutor = true;
1591
+ this.handleAutoBatchAssign();
1592
+ }
1593
+ openSurveyFormPopup(event) {
1594
+ if (event) {
1595
+ this.openCompletionSurveyFormPopup();
1596
+ }
1597
+ }
1598
+ generatePreAssessmentQuery(type) {
1599
+ if (this.firstResourceLink && (type === 'START' || type === 'START_OVER')) {
1600
+ let qParams = {
1601
+ ...this.firstResourceLink.queryParams,
1602
+ viewMode: type,
1603
+ batchId: this.getBatchId(),
1604
+ };
1605
+ if (this.contextId && this.contextPath) {
1606
+ qParams = {
1607
+ ...qParams,
1608
+ collectionId: this.contextId,
1609
+ collectionType: this.contextPath,
1610
+ };
1611
+ }
1612
+ if (this.forPreview) {
1613
+ delete qParams.viewMode;
1614
+ }
1615
+ qParams = {
1616
+ ...qParams,
1617
+ channelId: this.channelId,
1618
+ };
1619
+ return qParams;
1620
+ }
1621
+ if (this.resumeDataLink && type === 'RESUME') {
1622
+ let qParams = {
1623
+ ...this.resumeDataLink.queryParams,
1624
+ batchId: this.getBatchId(),
1625
+ viewMode: 'RESUME',
1626
+ // courseName: this.content ? this.content.name : '',
1627
+ };
1628
+ if (this.contextId && this.contextPath) {
1629
+ qParams = {
1630
+ ...qParams,
1631
+ collectionId: this.contextId,
1632
+ collectionType: this.contextPath,
1633
+ };
1634
+ }
1635
+ if (this.forPreview) {
1636
+ delete qParams.viewMode;
1637
+ }
1638
+ qParams = {
1639
+ ...qParams,
1640
+ channelId: this.channelId,
1641
+ };
1642
+ return qParams;
1643
+ }
1644
+ if (this.forPreview) {
1645
+ return {};
1646
+ }
1647
+ return {
1648
+ batchId: this.getBatchId(),
1649
+ viewMode: type,
1650
+ };
1651
+ }
1652
+ routeToPreAssessent() {
1653
+ if (this.contentReadData) {
1654
+ // this.generatePreAssessmentQuery('START')
1655
+ let firstResource = this.contentReadData.preEnrolmentResources[0];
1656
+ let mimeType = firstResource?.courseCategory === 'Pre Enrolment Assessment' ? 'application/vnd.sunbird.questionset' : firstResource.mimeType;
1657
+ this.firstResourceLink = viewerRouteGenerator(firstResource.identifier, mimeType, this.contentReadData?.identifier, this.contentReadData?.courseCategory, this.forPreview, this.contentReadData && this.contentReadData.preEnrolmentResources[0]?.primaryCategory || '', '');
1658
+ let routerLink = this.firstResourceLink?.url;
1659
+ let queryParams = this.generatePreAssessmentQuery('START');
1660
+ queryParams = { ...queryParams, preAssessment: 'true' };
1661
+ this.router.navigate([`${routerLink}`], { queryParams });
1662
+ }
1663
+ }
1664
+ getPreAssessmentRequired() {
1665
+ this.preAssessmentRequiredFlag = false;
1666
+ if (this.contentReadData?.preEnrolmentResources?.length) {
1667
+ this.contentReadData?.preEnrolmentResources?.forEach((item) => {
1668
+ if (item && item?.isMandatory) {
1669
+ this.preAssessmentRequiredFlag = true;
1670
+ }
1671
+ });
1672
+ }
1673
+ }
1674
+ getPreAssessmentCompletionStatus() {
1675
+ this.preAssessmentCompletionStatus = false;
1676
+ let preEnrollmentResourcesArr = [];
1677
+ let preEnrollmentMandatoryResourcesArr = [];
1678
+ if (this.contentReadData?.preEnrolmentResources?.length) {
1679
+ this.contentReadData?.preEnrolmentResources?.forEach((item) => {
1680
+ preEnrollmentResourcesArr.push(item?.identifier);
1681
+ if (item && item?.isMandatory) {
1682
+ preEnrollmentMandatoryResourcesArr.push(item?.identifier);
1683
+ }
1684
+ });
1685
+ }
1686
+ if (preEnrollmentResourcesArr && preEnrollmentResourcesArr.length) {
1687
+ let req = {
1688
+ "request": {
1689
+ "contentIds": preEnrollmentResourcesArr,
1690
+ "fields": []
1691
+ }
1692
+ };
1693
+ this.tocSvc.readPreEnrollmentResourcesState(req).subscribe((data) => {
1694
+ let mandatoryIdsCompleted = [];
1695
+ if (data && data.result && data.result.contentList && data.result.contentList.length) {
1696
+ for (let i = 0; i < data.result.contentList.length; i++) {
1697
+ if (data.result.contentList[i]['status'] === 2 && preEnrollmentMandatoryResourcesArr.includes(data.result.contentList[i]['contentId'])) {
1698
+ mandatoryIdsCompleted.push(data.result.contentList[i]['contentId']);
1699
+ }
1700
+ }
1701
+ if (preEnrollmentResourcesArr?.length === data.result.contentList?.length) {
1702
+ this.preAssessmentCompletionStatus = true;
1703
+ }
1704
+ else if (mandatoryIdsCompleted.length === preEnrollmentMandatoryResourcesArr.length) {
1705
+ this.preAssessmentCompletionStatus = true;
1706
+ }
1707
+ else {
1708
+ this.preAssessmentCompletionStatus = false;
1709
+ }
1710
+ }
1711
+ else {
1712
+ this.preAssessmentCompletionStatus = false;
1713
+ }
1714
+ });
1715
+ }
1716
+ }
1717
+ ngOnInit() {
1718
+ this.dataTransferSvc.setEnrollData(null);
1719
+ this.getServerDateTime();
1720
+ this.mobile1200 = window.innerWidth < 1201;
1721
+ this.getI18NTranslations();
1722
+ this.loadLearnerAdvisoryData();
1723
+ this.setupSelectedBatchSubscription();
1724
+ this.setChannelId();
1725
+ this.checkIframeContext();
1726
+ this.queryParamsData = this.setupRouteSubscriptions();
1727
+ this.setupFragmentSubscription();
1728
+ this.setupBatchSubscriptions();
1729
+ this.configureDefaultLogo();
1730
+ this.configureFeatureFlags();
1731
+ this.checkRegistrationStatus();
1732
+ this.setupRouterEventSubscription();
1733
+ this.getContentCreatorData();
1734
+ this.setupHashmapUpdateSubscription();
1735
+ this.userId = this.configSvc?.userProfile?.userId || '';
1736
+ this.domainConfSvc.initFromConfig(this.configSvc.globalConfig.applicationConfig);
1737
+ }
1738
+ initData(data) {
1739
+ const initData = this.tocSvc.initData(data, true);
1740
+ this.setErrorCode(initData.errorCode);
1741
+ this.setupBatchControlSubscription();
1742
+ this.tocSvc.contentLoader.next(false);
1743
+ }
1744
+ setErrorCode(errorCode) {
1745
+ this.errorCode = errorCode;
1746
+ switch (this.errorCode) {
1747
+ case NsAppToc.EWsTocErrorCode.API_FAILURE:
1748
+ case NsAppToc.EWsTocErrorCode.INVALID_DATA:
1749
+ case NsAppToc.EWsTocErrorCode.NO_DATA:
1750
+ this.errorWidgetData.widgetData.errorType = ErrorType.internalServer;
1751
+ break;
1752
+ default:
1753
+ this.errorWidgetData.widgetData.errorType = ErrorType.somethingWrong;
1754
+ break;
1755
+ }
1756
+ }
1757
+ initializeTocStructure() {
1758
+ this.contentParents = {};
1759
+ this.tocStructure = {
1760
+ assessment: 0,
1761
+ course: 0,
1762
+ handsOn: 0,
1763
+ interactiveVideo: 0,
1764
+ learningModule: 0,
1765
+ other: 0,
1766
+ pdf: 0,
1767
+ survey: 0,
1768
+ podcast: 0,
1769
+ practiceTest: 0,
1770
+ finalTest: 0,
1771
+ quiz: 0,
1772
+ video: 0,
1773
+ webModule: 0,
1774
+ webPage: 0,
1775
+ youtube: 0,
1776
+ interactivecontent: 0,
1777
+ offlineSession: 0,
1778
+ preEnrollmentAssessment: 0,
1779
+ };
1780
+ }
1781
+ setupBatchControlSubscription() {
1782
+ this.batchControl.valueChanges.subscribe((batch) => {
1783
+ if (batch) {
1784
+ this.handleBatchEnrollment(batch);
1785
+ }
1786
+ });
1787
+ }
1788
+ handleBatchEnrollment(batch) {
1789
+ this.disableEnrollBtn = true;
1790
+ let userId = this.configSvc.userProfile?.userId || '';
1791
+ const req = {
1792
+ request: {
1793
+ userId,
1794
+ courseId: batch.courseId,
1795
+ batchId: batch.batchId,
1796
+ },
1797
+ };
1798
+ this.contentSvc.enrollUserToBatch(req).then((datab) => {
1799
+ if (datab?.result?.response === 'SUCCESS') {
1800
+ this.handleSuccessfulEnrollment(batch);
1801
+ }
1802
+ else {
1803
+ this.handleEnrollmentFailure();
1804
+ }
1805
+ });
1806
+ }
1807
+ handleSuccessfulEnrollment(batch) {
1808
+ this.batchData = {
1809
+ content: [batch],
1810
+ enrolled: true,
1811
+ };
1812
+ this.tocSvc.getSelectedBatchData(this.batchData);
1813
+ this.tocSvc.mapSessionCompletionPercentage(this.batchData);
1814
+ // CRITICAL: For Learning Pathways, compute milestone locking status after enrollment
1815
+ // This ensures milestones are properly locked until pre-assessment is completed
1816
+ if (this.baseContentReadData?.courseCategory === 'Learning Pathway') {
1817
+ this.tocSvc.callHirarchyProgressHashmap(this.content);
1818
+ this.tocSvc.computeMilestoneLockingStatus(true);
1819
+ this.syncMilestoneLockStatus();
1820
+ }
1821
+ this.routerChangeHandler(true);
1822
+ this.openSnackbar('Enrolled Successfully!');
1823
+ this.disableEnrollBtn = false;
1824
+ }
1825
+ handleEnrollmentFailure() {
1826
+ this.openSnackbar('Something went wrong, please try again later!');
1827
+ this.disableEnrollBtn = false;
1828
+ }
1829
+ loadLearnerAdvisoryData() {
1830
+ if (this.route.snapshot.data.pageData && this.route.snapshot.data.pageData.data) {
1831
+ this.learnAdvisoryData = this.route.snapshot.data.pageData.data.learnerAdvisory;
1832
+ }
1833
+ }
1834
+ setupSelectedBatchSubscription() {
1835
+ this.selectedBatchSubscription = this.tocSvc.getSelectedBatch.subscribe(batchData => {
1836
+ this.selectedBatchData = batchData;
1837
+ });
1838
+ }
1839
+ setChannelId() {
1840
+ this.channelId = this.telemetryService.telemetryConfig
1841
+ ? this.telemetryService.telemetryConfig.channel
1842
+ : '';
1843
+ }
1844
+ checkIframeContext() {
1845
+ try {
1846
+ this.isInIframe = window.self !== window.top;
1847
+ }
1848
+ catch (_ex) {
1849
+ this.isInIframe = false;
1850
+ }
1851
+ }
1852
+ setupRouteSubscriptions() {
1853
+ let queryParamstemp = {};
1854
+ if (this.route) {
1855
+ this.skeletonLoader = true;
1856
+ this.routeSubscription = this.route.data.subscribe(async (data) => {
1857
+ if (data?.content?.data?.identifier) {
1858
+ queryParamstemp = await this.processRouteData(data);
1859
+ }
1860
+ else {
1861
+ const tempData = {
1862
+ content: {
1863
+ data: this.inputContent
1864
+ }
1865
+ };
1866
+ queryParamstemp = await this.processRouteData(tempData);
1867
+ }
1868
+ });
1869
+ }
1870
+ return queryParamstemp;
1871
+ }
1872
+ async processRouteData(data) {
1873
+ this.courseID = data?.content?.data?.status === 'Retired' ? '' : data.content.data?.identifier;
1874
+ const initData = this.tocSvc.initData(data, true);
1875
+ // Get query parameters
1876
+ const queryParamsDataTemp = await this.getQueryParams();
1877
+ // Handle multilingual content if mlId is present in query parameters
1878
+ if (queryParamsDataTemp.MLId) {
1879
+ // Store the original content data for reference
1880
+ this.baseContentReadData = initData.content;
1881
+ // Fetch the multilingual content
1882
+ try {
1883
+ if (this.baseContentReadData.identifier === queryParamsDataTemp.MLId) {
1884
+ this.contentReadData = initData.content;
1885
+ }
1886
+ else {
1887
+ const success = await this.fetchContentRead(queryParamsDataTemp.MLId);
1888
+ if (!success) {
1889
+ // If multilingual content fetch fails, fall back to the original content
1890
+ this.contentReadData = initData.content;
1891
+ this.loggerSvc.warn('Failed to load multilingual content, using original content instead');
1892
+ }
1893
+ }
1894
+ }
1895
+ catch (error) {
1896
+ // On error, use the original content
1897
+ this.contentReadData = initData.content;
1898
+ this.loggerSvc.error('Error loading multilingual content:', error);
1899
+ this.snackBar.open('Failed to load content in selected language', 'X', {
1900
+ duration: 3000,
1901
+ });
1902
+ }
1903
+ }
1904
+ else {
1905
+ // No multilingual content requested, use the original content
1906
+ this.contentReadData = initData.content;
1907
+ this.baseContentReadData = initData.content;
1908
+ }
1909
+ // Added to make sure this reference was incorrect, assigning again to make sure global variable is properly updated
1910
+ this.queryParamsData = queryParamsDataTemp;
1911
+ // Continue with the rest of the processing
1912
+ this.loadLanguageData();
1913
+ this.getPreAssessmentCompletionStatus();
1914
+ this.getPreAssessmentRequired();
1915
+ await this.handleContentPreviewOrEnrollment();
1916
+ this.initialrouteData = data;
1917
+ this.loadBannerAndTocConfig(data);
1918
+ this.fetchPostAssessmentStatusIfNeeded();
1919
+ this.initData(data);
1920
+ // to clear public survey data if any on load,
1921
+ // if not cleared then it will be cleared on popup close,
1922
+ // but the teachers notes will be visible on ciming back from player page
1923
+ const surveyId = this.environment.publicContentSurveyId || '';
1924
+ const courseId = this.contentReadData?.identifier || '';
1925
+ this.clearExistingPublicSurveyData(surveyId, courseId);
1926
+ return queryParamsDataTemp;
1927
+ }
1928
+ openCompletionSurveyFormPopup() {
1929
+ if (this.baseContentReadData && _.get(this.baseContentReadData, 'completionSurveyLink')) {
1930
+ const sID = this.baseContentReadData.completionSurveyLink.split('surveys/');
1931
+ const surveyId = sID[1];
1932
+ const data = {
1933
+ surveyId,
1934
+ courseName: this.contentReadData?.name || '',
1935
+ courseID: this.contentReadData?.identifier || '',
1936
+ contextOrgId: this.contentReadData?.createdFor && this.contentReadData?.createdFor.length > 0 ?
1937
+ this.contentReadData?.createdFor[0] : ''
1938
+ };
1939
+ const dialogRef = this.dialog.open(CompletionSurveyFormComponent, {
1940
+ disableClose: true,
1941
+ width: '750px',
1942
+ maxWidth: '90vw',
1943
+ data: data,
1944
+ autoFocus: false,
1945
+ });
1946
+ dialogRef.afterClosed().subscribe((result) => {
1947
+ if (result) {
1948
+ this.openConfirmationDialog();
1949
+ }
1950
+ else {
1951
+ this.lockCertificate = true;
1952
+ }
1953
+ });
1954
+ }
1955
+ }
1956
+ openConfirmationDialog() {
1957
+ const dialogData = {
1958
+ messages: [
1959
+ {
1960
+ message: this.translate.instant('apptoc.surveySubmitted'),
1961
+ classes: 'dialog-title'
1962
+ },
1963
+ {
1964
+ message: this.translate.instant('apptoc.surveyCompletedCertificateGenerating'),
1965
+ classes: 'dialog-description mb-2'
1966
+ }
1967
+ ],
1968
+ iconName: 'check_circle',
1969
+ type: 'primary',
1970
+ buttonsPositionClass: 'justify-center items-center',
1971
+ buttons: [
1972
+ {
1973
+ classes: 'succes-button width-full',
1974
+ text: this.translate.instant('apptoc.returnToProgramPage'),
1975
+ response: true
1976
+ }
1977
+ ]
1978
+ };
1979
+ const dialogRef = this.dialog.open(ConfirmationDialogComponent, {
1980
+ data: dialogData,
1981
+ disableClose: true,
1982
+ width: '500px',
1983
+ maxWidth: '90vw'
1984
+ });
1985
+ dialogRef.afterClosed().subscribe((result) => {
1986
+ if (result) {
1987
+ this.lockCertificate = false;
1988
+ }
1989
+ });
1990
+ }
1991
+ loadLanguageData() {
1992
+ this.languageList = this.contentLangSvc.getAllContentLanguages(this.contentReadData);
1993
+ this.selectedLanguage = this.contentLangSvc.getSelectedLanguage(this.contentReadData);
1994
+ }
1995
+ async handleContentPreviewOrEnrollment() {
1996
+ if (this.forPreview) {
1997
+ await this.loadContentForPreview();
1998
+ }
1999
+ else {
2000
+ // // If we're working with multilingual content, make sure to fetch its hierarchy
2001
+ // if (this.queryParamsData.mlId && this.contentReadData &&
2002
+ // this.contentReadData.identifier === this.queryParamsData.mlId) {
2003
+ // // Fetch content hierarchy for the multilingual content
2004
+ // try {
2005
+ // await this.fetchContentHierarchy(this.contentReadData.identifier);
2006
+ // // After fetching hierarchy, update UI components
2007
+ // this.getLearningUrls();
2008
+ // } catch (error) {
2009
+ // this.loggerSvc.error('Error fetching hierarchy for multilingual content:', error);
2010
+ // }
2011
+ // }
2012
+ // Continue with regular enrollment flow
2013
+ this.fetchUserEnrollmentDataV2();
2014
+ }
2015
+ }
2016
+ async loadContentForPreview() {
2017
+ this.tocSvc.contentLoader.next(true);
2018
+ await this.fetchContentHierarchy(this.contentReadData?.identifier || '');
2019
+ this.tocSvc.contentLoader.next(false);
2020
+ this.tocSvc.checkModuleWiseData(this.content);
2021
+ this.skeletonLoader = false;
2022
+ }
2023
+ loadBannerAndTocConfig(data) {
2024
+ this.banners = data?.pageData?.data?.banners || [];
2025
+ this.tocSvc.subtitleOnBanners = data?.pageData?.data?.subtitleOnBanners || false;
2026
+ this.tocSvc.showDescription = data?.pageData?.data?.showDescription || false;
2027
+ this.tocConfig = data?.pageData?.data || {};
2028
+ if (this.contentReadData?.courseCategory === NsContent.ECourseCategory.LEARNING_PATHWAY) {
2029
+ this.kparray = this.tocConfig.karmaPointsLP || [
2030
+ {
2031
+ "displayButton": "Resume",
2032
+ "textBeforeIcon": "earn",
2033
+ "points": "25",
2034
+ "textAfterPoints": "karmaPoints",
2035
+ "textAfterIcon": "byCompletingLP",
2036
+ "toolTipText": "lpCompleteTip"
2037
+ }
2038
+ ];
2039
+ }
2040
+ else {
2041
+ this.kparray = this.tocConfig.karmaPoints || [];
2042
+ }
2043
+ }
2044
+ fetchPostAssessmentStatusIfNeeded() {
2045
+ if (this.content && this.isPostAssessment) {
2046
+ this.tocSvc.fetchPostAssessmentStatus(this.content.identifier).subscribe(res => {
2047
+ const assessmentData = res.result;
2048
+ for (const o of assessmentData) {
2049
+ if (o.contentId === (this.content && this.content.identifier)) {
2050
+ this.showTakeAssessment = o;
2051
+ break;
2052
+ }
2053
+ }
2054
+ });
2055
+ }
2056
+ }
2057
+ setupFragmentSubscription() {
2058
+ this.currentFragment = 'overview';
2059
+ this.route.fragment.subscribe((fragment) => {
2060
+ this.currentFragment = fragment || 'overview';
2061
+ });
2062
+ }
2063
+ setupBatchSubscriptions() {
2064
+ this.batchSubscription = this.tocSvc.batchReplaySubject.subscribe(() => this.handleBatchUpdate(), () => this.loggerSvc.error('error on batchSubscription'));
2065
+ this.batchDataSubscription = this.tocSvc.setBatchDataSubject.subscribe(() => this.handleBlendedProgramUpdate(), () => this.loggerSvc.error('error on batchDataSubscription'));
2066
+ }
2067
+ handleBatchUpdate() {
2068
+ this.fetchBatchDetails();
2069
+ if (this.content?.primaryCategory === this.primaryCategory.BLENDED_PROGRAM) {
2070
+ this.fetchUserWFForBlended();
2071
+ }
2072
+ }
2073
+ handleBlendedProgramUpdate() {
2074
+ if (this.content?.primaryCategory === this.primaryCategory.BLENDED_PROGRAM) {
2075
+ this.fetchUserWFForBlended();
2076
+ }
2077
+ }
2078
+ configureDefaultLogo() {
2079
+ const instanceConfig = this.configSvc.instanceConfig;
2080
+ if (instanceConfig?.logos?.defaultSourceLogo) {
2081
+ this.defaultSLogo = instanceConfig.logos.defaultSourceLogo;
2082
+ }
2083
+ }
2084
+ configureFeatureFlags() {
2085
+ if (this.configSvc.restrictedFeatures) {
2086
+ this.isGoalsEnabled = !this.configSvc.restrictedFeatures.has('goals');
2087
+ this.isRegistrationSupported = this.configSvc.restrictedFeatures.has('registrationExternal');
2088
+ this.showIntranetMessage = !this.configSvc.restrictedFeatures.has('showIntranetMessageDesktop');
2089
+ }
2090
+ }
2091
+ setupRouterEventSubscription() {
2092
+ this.routerParamSubscription = this.router.events.subscribe((routerEvent) => {
2093
+ if (routerEvent instanceof NavigationEnd) {
2094
+ this.assignPathAndUpdateBanner(routerEvent.url);
2095
+ // Check if we're on the TOC/overview page for a Learning Pathway
2096
+ const isTocPage = routerEvent.url.includes('/app/toc') ||
2097
+ routerEvent.url.includes('/overview') ||
2098
+ routerEvent.url.includes('/content');
2099
+ }
2100
+ });
2101
+ }
2102
+ /**
2103
+ * Subscribe to hashmap updates to recompute milestone lock status in real-time
2104
+ * This ensures that when progress changes, milestone locks update immediately without page refresh
2105
+ */
2106
+ setupHashmapUpdateSubscription() {
2107
+ this.hashmapUpdatedSubscription = this.tocSvc.hashmapUpdated$.subscribe((update) => {
2108
+ if (update && this.baseContentReadData?.courseCategory === 'Learning Pathway') {
2109
+ const isEnrolled = this.userEnrollmentList && this.userEnrollmentList.length > 0;
2110
+ // Sync content tree's isLocked with the updated hashmap values
2111
+ this.syncMilestoneLockStatus();
2112
+ }
2113
+ });
2114
+ }
2115
+ fetchUserEnrollmentDataV2() {
2116
+ const identifier = this.baseContentReadData?.identifier || '';
2117
+ if (!identifier) {
2118
+ this.loggerSvc.error('Cannot fetch enrollment data: content identifier is missing');
2119
+ this.userEnrollmentList = [];
2120
+ this.checkIfUserEnrolled();
2121
+ return;
2122
+ }
2123
+ const request = {
2124
+ request: {
2125
+ retiredCoursesEnabled: true,
2126
+ courseId: [identifier]
2127
+ }
2128
+ };
2129
+ this.enrollSvc.fetchEnrollContentData(request).pipe(takeUntil(this.destroySubject$), switchMap((res) => {
2130
+ if (res?.result?.courses?.length) {
2131
+ this.userEnrollmentList = res.result.courses;
2132
+ // Check for completed content
2133
+ const completedContentData = this.userEnrollmentList.find((el) => el.collectionId === this.baseContentReadData?.identifier &&
2134
+ el.completionPercentage === 100);
2135
+ if (completedContentData) {
2136
+ this.contentViewEventForNetCore('complete');
2137
+ }
2138
+ this.dataTransferSvc.setEnrollData(this.userEnrollmentList);
2139
+ if (this.isMultilingual) {
2140
+ // in case of back from player we need to check recent language and load
2141
+ if (!this.contentLibSvc?.oneStepResumeEnable && this.baseContentReadData?.identifier === this.contentReadData?.identifier) {
2142
+ let lang = this.baseContentReadData?.language?.length ? this.baseContentReadData?.language[0] : '';
2143
+ let baseContentFromEnrollData = this.userEnrollmentList.find((el) => el.collectionId === this.baseContentReadData?.identifier);
2144
+ if (lang && baseContentFromEnrollData && baseContentFromEnrollData?.recent_language?.toLowerCase() !== lang) {
2145
+ let localLang = this.contentLangSvc.getRequiredLanguageDetails(this.baseContentReadData, baseContentFromEnrollData?.recent_language);
2146
+ if (localLang && Object.keys(localLang).length) {
2147
+ this.processLanguageSelection(this.contentLangSvc.getRequiredLanguageDetails(this.baseContentReadData, baseContentFromEnrollData?.recent_language));
2148
+ }
2149
+ else {
2150
+ this.processLanguageSelection(this.contentLangSvc.getSelectedLanguage(this.contentReadData));
2151
+ }
2152
+ }
2153
+ return of(false);
2154
+ }
2155
+ else {
2156
+ // Always call fetchContentHierarchy first
2157
+ return from(this.fetchContentHierarchy(this.contentReadData?.identifier || ''));
2158
+ }
2159
+ }
2160
+ else {
2161
+ // Always call fetchContentHierarchy first
2162
+ return from(this.fetchContentHierarchy(this.contentReadData?.identifier || ''));
2163
+ }
2164
+ }
2165
+ else {
2166
+ this.userEnrollmentList = [];
2167
+ // Check if we have content ID from either content or contentReadData
2168
+ const contentId = this.contentReadData?.identifier || this.baseContentReadData?.identifier || '';
2169
+ if (!contentId) {
2170
+ this.loggerSvc.error('Cannot fetch hierarchy: content identifier is missing');
2171
+ return of(false);
2172
+ }
2173
+ // Fetch hierarchy content for additional data
2174
+ return from(this.fetchContentHierarchy(contentId));
2175
+ }
2176
+ }),
2177
+ // Add catchError here to handle errors from fetchContentHierarchy
2178
+ catchError(error => {
2179
+ this.loggerSvc.error('Error in enrollment data processing', error);
2180
+ return of(false);
2181
+ })).subscribe({
2182
+ next: () => {
2183
+ if (this.userEnrollmentList?.length && this.contentLibSvc?.oneStepResumeEnable) {
2184
+ this.handleOneStepResume();
2185
+ this.checkIfUserEnrolled();
2186
+ }
2187
+ else {
2188
+ this.checkIfUserEnrolled();
2189
+ }
2190
+ },
2191
+ error: (error) => {
2192
+ this.loggerSvc.error('Failed to fetch user enrollment data', error);
2193
+ this.userEnrollmentList = [];
2194
+ this.checkIfUserEnrolled();
2195
+ },
2196
+ complete: () => {
2197
+ // Optional completion handler if needed
2198
+ }
2199
+ });
2200
+ }
2201
+ async handleOneStepResume() {
2202
+ try {
2203
+ if (!this.content) {
2204
+ this.loggerSvc.error('Content not available for one-step resume');
2205
+ }
2206
+ const foundContent = this.userEnrollmentList.find((el) => el.collectionId === this.baseContentReadData?.identifier);
2207
+ if (!foundContent) {
2208
+ this.loggerSvc.warn('No matching enrolled content found for one-step resume');
2209
+ }
2210
+ const urlData = await this.contentLibSvc.getResourseLink(this.content, [foundContent], true, this.baseContentReadData, this.contentReadData?.identifier || '');
2211
+ if (!urlData) {
2212
+ this.loggerSvc.warn('No URL data returned for one-step resume');
2213
+ }
2214
+ if (urlData?.url) {
2215
+ if (urlData.url.includes('app/toc')) {
2216
+ this.contentLibSvc.oneStepResumeEnable = false;
2217
+ }
2218
+ else {
2219
+ this.contentLibSvc.oneStepResumeEnable = false;
2220
+ // When coming from search page for particular language content, confirm first to one step resume or load the searched language
2221
+ if (urlData?.queryParams?.ML && (urlData?.queryParams?.ML !== this.queryParamsData['ML'])) {
2222
+ this.showOneStepResumeConfirm(urlData);
2223
+ }
2224
+ else {
2225
+ this.router.navigate([urlData.url], { queryParams: urlData.queryParams });
2226
+ }
2227
+ }
2228
+ }
2229
+ }
2230
+ catch (error) {
2231
+ this.loggerSvc.error('Error in handleOneStepResume', error);
2232
+ this.contentLibSvc.oneStepResumeEnable = false;
2233
+ }
2234
+ }
2235
+ fetchContentHierarchy(identifier) {
2236
+ if (this.baseContentReadData?.courseCategory === 'Learning Pathway') {
2237
+ return new Promise((resolve) => {
2238
+ const content = this.baseContentReadData;
2239
+ // STEP 1: Construct hierarchy structure
2240
+ let contentHeirarchyData = this.appTocV2Svc.constructHeirarchyData(content);
2241
+ // STEP 2: Update progress with latest enrollment data
2242
+ this.appTocV2Svc.mapContentHierarchyProgressUpdate(contentHeirarchyData, this.userEnrollmentList);
2243
+ // STEP 3: Create hashmap from updated hierarchy (this should preserve completion status)
2244
+ this.tocSvc.callHirarchyProgressHashmap(contentHeirarchyData);
2245
+ this.content = contentHeirarchyData;
2246
+ // Check if user is enrolled
2247
+ const isEnrolled = this.userEnrollmentList && this.userEnrollmentList.length > 0;
2248
+ // STEP 4: Compute milestone locking status with enrollment status and updated progress data
2249
+ this.tocSvc.computeMilestoneLockingStatus(isEnrolled);
2250
+ // STEP 5: Sync content tree's isLocked with computed values
2251
+ this.syncMilestoneLockStatus();
2252
+ this.getOrgIdForShare();
2253
+ this.getTocStructure();
2254
+ resolve(true);
2255
+ return;
2256
+ });
2257
+ }
2258
+ else {
2259
+ return new Promise((resolve, reject) => {
2260
+ if (!identifier) {
2261
+ resolve(false);
2262
+ return;
2263
+ }
2264
+ // Make sure fetchHierarchyContent returns an Observable
2265
+ const observable = this.contentSvc.fetchHierarchyContent(identifier, 'detail');
2266
+ if (!observable) {
2267
+ this.loggerSvc.error('fetchHierarchyContent did not return an Observable');
2268
+ resolve(false);
2269
+ return;
2270
+ }
2271
+ const subscription = observable.subscribe({
2272
+ next: (response) => {
2273
+ if (response?.result?.content) {
2274
+ this.content = response.result.content;
2275
+ this.getOrgIdForShare();
2276
+ this.getTocStructure();
2277
+ if (!this.forPreview) {
2278
+ this.userRating = undefined;
2279
+ this.getUserRating(false);
2280
+ }
2281
+ resolve(true);
2282
+ }
2283
+ else {
2284
+ resolve(false);
2285
+ }
2286
+ subscription.unsubscribe();
2287
+ },
2288
+ error: (error) => {
2289
+ this.loggerSvc.error('Failed to fetch hierarchy content', error);
2290
+ reject(error);
2291
+ subscription.unsubscribe();
2292
+ }
2293
+ });
2294
+ });
2295
+ }
2296
+ }
2297
+ getTocStructure() {
2298
+ this.initializeTocStructure();
2299
+ if (this.content && this.tocStructure) {
2300
+ this.hasTocStructure = false;
2301
+ this.tocStructure.learningModule = this.content.primaryCategory === this.primaryCategory.MODULE ? -1 : 0;
2302
+ this.tocStructure.course = this.content.primaryCategory === this.primaryCategory.COURSE ? -1 : 0;
2303
+ this.tocStructure = this.tocSvc.getTocStructure(this.content, this.tocStructure);
2304
+ for (const progType in this.tocStructure) {
2305
+ if (this.tocStructure[progType] > 0) {
2306
+ this.hasTocStructure = true;
2307
+ break;
2308
+ }
2309
+ }
2310
+ // from ngOnChanges
2311
+ this.fetchExternalContentAccess();
2312
+ this.modifySensibleContentRating();
2313
+ this.assignPathAndUpdateBanner(this.router.url);
2314
+ this.getLearningUrls();
2315
+ }
2316
+ }
2317
+ /**
2318
+ * Sync milestone isLocked property with computed locking status from hashmap
2319
+ * This ensures the content tree reflects the actual lock status
2320
+ */
2321
+ syncMilestoneLockStatus() {
2322
+ if (!this.content || !this.content.children)
2323
+ return;
2324
+ let hasChanges = false;
2325
+ this.content.children.forEach((child) => {
2326
+ if (child.primaryCategory === 'Milestone' && child.identifier) {
2327
+ const hashData = this.tocSvc.hashmap[child.identifier];
2328
+ if (hashData && hashData.computedIsLocked !== undefined) {
2329
+ const oldLocked = child.isLocked;
2330
+ child.isLocked = hashData.computedIsLocked;
2331
+ if (oldLocked !== child.isLocked) {
2332
+ hasChanges = true;
2333
+ }
2334
+ }
2335
+ }
2336
+ });
2337
+ }
2338
+ /**
2339
+ * Refresh milestone locking status from the already-updated hashmap
2340
+ * This method should be called after progress updates to sync UI with computed lock status
2341
+ * Note: Does NOT fetch enrollment data - uses existing hashmap which is already updated
2342
+ */
2343
+ refreshEnrollmentAndProgress() {
2344
+ if (!this.content) {
2345
+ return;
2346
+ }
2347
+ try {
2348
+ // Check if user is enrolled
2349
+ const isEnrolled = this.userEnrollmentList && this.userEnrollmentList.length > 0;
2350
+ // Recompute milestone locking status from existing hashmap
2351
+ // The hashmap is already updated with latest progress via hashmap update subscription
2352
+ this.tocSvc.computeMilestoneLockingStatus(isEnrolled);
2353
+ // Sync lock status from hashmap to content tree
2354
+ this.syncMilestoneLockStatus();
2355
+ }
2356
+ catch (error) {
2357
+ console.error('❌ Error in refreshEnrollmentAndProgress:', error);
2358
+ }
2359
+ }
2360
+ onLanguageSelect(lang) {
2361
+ // Check if the selected language is already set
2362
+ if (this.selectedLanguage && this.selectedLanguage.identifier === lang.identifier) {
2363
+ return; // Exit the function if the language is the same
2364
+ }
2365
+ if (this.userEnrollmentList && this.userEnrollmentList.length) {
2366
+ let data = {};
2367
+ // TODO: Remove hardcode strings
2368
+ const enrolledCourse = this.tocSvc.findEnrolmentByCollectionId(this.userEnrollmentList, (this.baseContentReadData?.identifier || ''));
2369
+ if (enrolledCourse && enrolledCourse.status === 2) {
2370
+ this.processLanguageSelection(lang);
2371
+ }
2372
+ else {
2373
+ // If there is progress in the selected language,
2374
+ if (this.languageMapProgress && this.languageMapProgress[lang.langId] > 0) {
2375
+ data = {
2376
+ width: '500px',
2377
+ height: 'auto',
2378
+ data: {
2379
+ from: 'languageSwitch',
2380
+ icon: 'translate',
2381
+ header: `Continue where you left off in ${lang.name}?`,
2382
+ message: `You've already made some progress in this language.\n If you continue it will resume from where you left off.`,
2383
+ cancelButton: 'Back',
2384
+ acceptButton: 'Resume',
2385
+ }
2386
+ };
2387
+ }
2388
+ else {
2389
+ // If there is no progress in the selected language, or first time selection
2390
+ data = {
2391
+ width: '500px',
2392
+ height: 'auto',
2393
+ data: {
2394
+ from: 'languageSwitch',
2395
+ icon: 'translate',
2396
+ header: 'Are you sure you want to change the language?',
2397
+ message: 'Switching the language will reset your progress. \n The course will restart from the beginning in the selected language.',
2398
+ cancelButton: 'Back',
2399
+ acceptButton: 'Change language',
2400
+ }
2401
+ };
2402
+ }
2403
+ this.showLangSwitchPopup(lang, data);
2404
+ }
2405
+ }
2406
+ else {
2407
+ this.processLanguageSelection(lang);
2408
+ }
2409
+ }
2410
+ showLangSwitchPopup(lang, data) {
2411
+ const dialogRef = this.dialog.open(TOCMultiLingualDialogComponent, data);
2412
+ dialogRef.afterClosed().subscribe((confirmed) => {
2413
+ if (confirmed) {
2414
+ this.processLanguageSelection(lang);
2415
+ }
2416
+ });
2417
+ }
2418
+ showOneStepResumeConfirm(urlData) {
2419
+ const data = {
2420
+ width: '500px',
2421
+ height: 'auto',
2422
+ data: {
2423
+ from: 'languageSwitch',
2424
+ icon: 'translate',
2425
+ header: `You've already started this course`,
2426
+ message: `You’ve made some <b>progress</b> in another language of this course. \nWould you like to <b>resume where you left off</b>, or continue with this version instead?`,
2427
+ cancelButton: 'Continue Here',
2428
+ acceptButton: 'Resume',
2429
+ }
2430
+ };
2431
+ const dialogRef = this.dialog.open(TOCMultiLingualDialogComponent, data);
2432
+ dialogRef.afterClosed().subscribe((confirmed) => {
2433
+ if (confirmed) {
2434
+ this.router.navigate([urlData.url], { queryParams: urlData.queryParams });
2435
+ }
2436
+ else {
2437
+ const lang = this.contentLangSvc.getRequiredLanguageDetails(this.baseContentReadData, this.queryParamsData['ML']);
2438
+ this.processLanguageSelection(lang);
2439
+ }
2440
+ });
2441
+ }
2442
+ processLanguageSelection(lang) {
2443
+ this.selectedLanguage = lang;
2444
+ // Set skeleton loader to show loading state
2445
+ this.skeletonLoader = true;
2446
+ // Check if language object has required properties
2447
+ if (lang && lang.identifier) {
2448
+ // Create a promise chain to fetch content data and hierarchy sequentially
2449
+ this.fetchContentRead(lang.identifier)
2450
+ .then(() => {
2451
+ // After content read is successful, fetch the hierarchy
2452
+ return this.fetchContentHierarchy(lang.identifier);
2453
+ })
2454
+ .then(() => {
2455
+ // Both operations were successful
2456
+ // Update UI as needed with new content
2457
+ this.routerChangeHandler(true);
2458
+ if (this.userEnrollmentList && this.userEnrollmentList.length) {
2459
+ this.generateResumeDataLinkNew();
2460
+ }
2461
+ if (this.content) {
2462
+ this.getLearningUrls();
2463
+ // Reset user progress and fetch enrollment data if not in preview mode
2464
+ if (!this.forPreview) {
2465
+ this.checkIfUserEnrolled();
2466
+ }
2467
+ }
2468
+ // Update subject to notify rating summry component and load the sumamry of selected language
2469
+ this.resetRatingsService.setRatingServiceUpdate(true);
2470
+ // Finally set loading state to false
2471
+ this.skeletonLoader = false;
2472
+ })
2473
+ .catch((error) => {
2474
+ // Handle any errors in the promise chain
2475
+ this.loggerSvc.error('Error during language change:', error);
2476
+ this.skeletonLoader = false;
2477
+ this.snackBar.open('Failed to load content in selected language', 'X', {
2478
+ duration: 3000,
2479
+ });
2480
+ });
2481
+ }
2482
+ else {
2483
+ this.loggerSvc.error('Invalid language selection', lang);
2484
+ this.skeletonLoader = false;
2485
+ this.snackBar.open('Invalid language selection', 'X', {
2486
+ duration: 3000,
2487
+ });
2488
+ }
2489
+ }
2490
+ /**
2491
+ * Fetches content data for a given identifier and updates the contentReadData property
2492
+ * @param identifier The content identifier to fetch
2493
+ * @returns Promise that resolves to true if content was fetched successfully, false otherwise
2494
+ */
2495
+ async fetchContentRead(identifier) {
2496
+ return new Promise((resolve, reject) => {
2497
+ if (!identifier) {
2498
+ this.loggerSvc.error('Cannot fetch content: identifier is missing');
2499
+ resolve(false);
2500
+ return;
2501
+ }
2502
+ const observable = this.contentSvc.fetchContentData(identifier);
2503
+ if (!observable) {
2504
+ this.loggerSvc.error('fetchContentData did not return an Observable');
2505
+ resolve(false);
2506
+ return;
2507
+ }
2508
+ const subscription = observable.subscribe({
2509
+ next: (response) => {
2510
+ if (response?.result?.content) {
2511
+ // Update contentReadData with the fetched content
2512
+ this.contentReadData = response.result.content;
2513
+ // Update language list after content is fetched
2514
+ if (this.contentReadData) {
2515
+ this.languageList = this.contentLangSvc.getAllContentLanguages(this.contentReadData);
2516
+ this.selectedLanguage = this.contentLangSvc.getSelectedLanguage(this.contentReadData);
2517
+ }
2518
+ resolve(true);
2519
+ }
2520
+ else {
2521
+ this.loggerSvc.warn('Content data not found in response', response);
2522
+ resolve(false);
2523
+ }
2524
+ subscription.unsubscribe();
2525
+ },
2526
+ error: (error) => {
2527
+ this.loggerSvc.error('Failed to fetch content data', error);
2528
+ reject(error);
2529
+ subscription.unsubscribe();
2530
+ }
2531
+ });
2532
+ });
2533
+ }
2534
+ routerChangeHandler(appendBatchId) {
2535
+ const queryParams = {};
2536
+ // Add batch ID if needed
2537
+ if (appendBatchId && this.getBatchId()) {
2538
+ queryParams.batchId = this.getBatchId();
2539
+ }
2540
+ // Add multilingual ID and language to query params if available
2541
+ if (this.contentReadData && this.contentReadData.identifier) {
2542
+ let language = '';
2543
+ // Handle both string and array language formats
2544
+ if (Array.isArray(this.contentReadData.language)) {
2545
+ language = this.contentReadData.language[0].toLowerCase();
2546
+ }
2547
+ else if (this.contentReadData.language) {
2548
+ language = this.contentReadData.language.toLowerCase();
2549
+ }
2550
+ if (!(this.selectedLanguage && Object.keys(this.selectedLanguage).length)) {
2551
+ this.selectedLanguage = {
2552
+ langId: language,
2553
+ name: this.contentReadData.language[0]
2554
+ };
2555
+ }
2556
+ // Only add parameters if we have valid data
2557
+ if (language) {
2558
+ queryParams.ML = language;
2559
+ }
2560
+ queryParams.MLId = this.contentReadData.identifier;
2561
+ }
2562
+ // Only navigate if we have batch ID or other parameters
2563
+ if (Object.keys(queryParams).length > 0) {
2564
+ this.router.navigate([], {
2565
+ relativeTo: this.route,
2566
+ queryParams: queryParams,
2567
+ queryParamsHandling: 'merge',
2568
+ });
2569
+ }
2570
+ }
2571
+ getContinueLearningData(contentId, batchId, lang) {
2572
+ this.tocSvc.contentLoader.next(true);
2573
+ this.resumeData = null;
2574
+ let userId;
2575
+ if (this.configSvc.userProfile) {
2576
+ userId = this.configSvc.userProfile.userId || '';
2577
+ }
2578
+ const req = {
2579
+ request: {
2580
+ batchId,
2581
+ userId,
2582
+ courseId: contentId || '',
2583
+ contentIds: [],
2584
+ fields: ['progressdetails'],
2585
+ ...(lang ? { language: lang } : null),
2586
+ },
2587
+ };
2588
+ if (this.content && this.content.primaryCategory !== NsContent.EPrimaryCategory.RESOURCE) {
2589
+ this.contentSvc.fetchContentHistoryV2(req).subscribe(data => {
2590
+ if (data && data.result && data.result.contentList && data.result.contentList.length) {
2591
+ const tempResumeData = _.get(data, 'result.contentList');
2592
+ this.languageMapProgress = _.get(data, 'result.languageProgress') || {};
2593
+ this.resumeData = _.map(tempResumeData, rr => {
2594
+ // tslint:disable-next-line
2595
+ const items = _.filter(flattenItems(_.get(this.content, 'children') || [], 'children'), { 'identifier': rr.contentId, primaryCategory: 'Learning Resource' });
2596
+ _.set(rr, 'progressdetails.mimeType', _.get(_.first(items), 'mimeType'));
2597
+ if (!_.get(rr, 'completionPercentage')) {
2598
+ if (_.get(rr, 'status') === 2) {
2599
+ _.set(rr, 'completionPercentage', 100);
2600
+ }
2601
+ else {
2602
+ _.set(rr, 'completionPercentage', 0);
2603
+ }
2604
+ }
2605
+ return rr;
2606
+ });
2607
+ const progress = _.map(this.resumeData, 'completionPercentage');
2608
+ const totalCount = _.toInteger(_.get(this.content, 'leafNodesCount')) || 1;
2609
+ if (progress.length < totalCount) {
2610
+ const diff = totalCount - progress.length;
2611
+ if (diff) {
2612
+ // tslint:disable-next-line
2613
+ _.each(new Array(diff), () => {
2614
+ progress.push(0);
2615
+ });
2616
+ }
2617
+ }
2618
+ this.generateResumeDataLinkNew();
2619
+ this.tocSvc.updateResumaData(this.resumeData);
2620
+ // this.tocSvc.mapModuleDurationAndProgress(this.content, this.content)
2621
+ this.getLastPlayedResource();
2622
+ if (this.content?.completionPercentage !== 100) {
2623
+ this.tocSvc.mapCompletionPercentage(this.content, this.resumeData);
2624
+ }
2625
+ this.tocSvc.callHirarchyProgressHashmap(this.content);
2626
+ // Recompute milestone locking status after progress update
2627
+ if (this.baseContentReadData?.courseCategory === 'Learning Pathway') {
2628
+ const isEnrolled = this.userEnrollmentList && this.userEnrollmentList.length > 0;
2629
+ this.tocSvc.computeMilestoneLockingStatus(isEnrolled);
2630
+ this.syncMilestoneLockStatus();
2631
+ }
2632
+ this.tocSvc.contentLoader.next(false);
2633
+ }
2634
+ else {
2635
+ this.resumeData = null;
2636
+ this.tocSvc.callHirarchyProgressHashmap(this.content);
2637
+ // Recompute milestone locking status even with no progress data
2638
+ if (this.baseContentReadData?.courseCategory === 'Learning Pathway') {
2639
+ const isEnrolled = this.userEnrollmentList && this.userEnrollmentList.length > 0;
2640
+ this.tocSvc.computeMilestoneLockingStatus(isEnrolled);
2641
+ this.syncMilestoneLockStatus();
2642
+ }
2643
+ this.tocSvc.contentLoader.next(false);
2644
+ }
2645
+ this.contentSvc.setProgramChildResumeData(this.resumeData, contentId);
2646
+ if (this.content?.completionPercentage !== 100) {
2647
+ this.bindCompletionPercentage();
2648
+ }
2649
+ }, (error) => {
2650
+ this.loggerSvc.error('CONTENT HISTORY FETCH ERROR >', error);
2651
+ });
2652
+ }
2653
+ }
2654
+ generateResumeDataLinkNew() {
2655
+ if (this.resumeData && this.content) {
2656
+ let resumeDataV2;
2657
+ if (this.content.completionPercentage === 100) {
2658
+ resumeDataV2 = this.getResumeDataFromList('start');
2659
+ }
2660
+ else {
2661
+ resumeDataV2 = this.getResumeDataFromList();
2662
+ }
2663
+ if (!resumeDataV2.mimeType) {
2664
+ resumeDataV2.mimeType = this.tocSvc.getMimeType(this.content, resumeDataV2.identifier);
2665
+ }
2666
+ this.resumeDataLink = this.getResumeUrl(resumeDataV2);
2667
+ this.actionSVC.setUpdateCompGroupO = this.resumeDataLink;
2668
+ /* tslint:disable-next-line */
2669
+ }
2670
+ }
2671
+ isSelectedInMoreDropdown() {
2672
+ if (!this.selectedLanguage?.identifier || !this.languageList) {
2673
+ return false;
2674
+ }
2675
+ return this.languageList.slice(5).some((lang) => lang?.identifier === this.selectedLanguage?.identifier);
2676
+ }
2677
+ async getQueryParams() {
2678
+ const tempQueryParamsData = {};
2679
+ this.routeSubscription = this.route.queryParamMap.subscribe(async (qParamsMap) => {
2680
+ // Extract all parameters from the ParamMap
2681
+ qParamsMap.keys.forEach(key => {
2682
+ tempQueryParamsData[key] = qParamsMap.get(key) ?? '';
2683
+ });
2684
+ tempQueryParamsData;
2685
+ // Process specific parameters
2686
+ const contextId = tempQueryParamsData['contextId'];
2687
+ const contextPath = tempQueryParamsData['contextPath'];
2688
+ const recommendedCoursesId = tempQueryParamsData['recommendationId'];
2689
+ if (contextId && contextPath) {
2690
+ this.contextId = contextId;
2691
+ this.contextPath = contextPath;
2692
+ }
2693
+ if (recommendedCoursesId) {
2694
+ this.recommendedCoursesId = recommendedCoursesId;
2695
+ try {
2696
+ const response = await this.userServiceLib.getRecommendedCoursesSakshamAI(recommendedCoursesId).toPromise();
2697
+ if (response && response.feedbacks && response.feedbacks.length) {
2698
+ this.feedbackGiven = response.feedbacks.find((feedback) => feedback?.course_id === this.courseID);
2699
+ }
2700
+ }
2701
+ catch (error) {
2702
+ this.loggerSvc.error('Error fetching recommended courses:', error);
2703
+ }
2704
+ }
2705
+ });
2706
+ return tempQueryParamsData;
2707
+ }
2708
+ getOrgIdForShare() {
2709
+ if (this.content && ![
2710
+ NsContent.ECourseCategory.MODERATED_COURSE,
2711
+ NsContent.ECourseCategory.MODERATED_ASSESSEMENT,
2712
+ NsContent.ECourseCategory.MODERATED_PROGRAM,
2713
+ NsContent.ECourseCategory.INVITE_ONLY_PROGRAM,
2714
+ ].includes(this.content.courseCategory)) {
2715
+ this.canShare = true;
2716
+ if (this.configSvc.userProfile) {
2717
+ this.rootOrgId = this.configSvc.userProfile.rootOrgId;
2718
+ }
2719
+ }
2720
+ }
2721
+ /**
2722
+ * Fetches and processes content creator data from the current content
2723
+ * - Sets contentCreatorData from parsed creator contacts
2724
+ * - Determines if "show button" flag should be enabled based on content name
2725
+ * - Includes proper error handling for null values and parsing
2726
+ */
2727
+ getContentCreatorData() {
2728
+ try {
2729
+ // Only proceed if we have valid content data
2730
+ if (!this.contentReadData) {
2731
+ this.loggerSvc.warn('Cannot get creator data: contentReadData is not available');
2732
+ return;
2733
+ }
2734
+ // Process content name for comparison (safely handle null/undefined)
2735
+ const contentName = this.contentReadData.name?.trim() || '';
2736
+ // Parse and set creator contacts if available
2737
+ if (this.contentReadData.creatorContacts) {
2738
+ // Use the existing parsing method to handle creator contacts
2739
+ this.contentCreatorData = this.handleParseJsonData(this.contentReadData.creatorContacts);
2740
+ }
2741
+ else {
2742
+ // Reset to empty array if no creator contacts
2743
+ this.contentCreatorData = [];
2744
+ }
2745
+ // Set showBtn flag based on dakshta name comparison (case insensitive)
2746
+ // This determines if the special button for dakshta content is shown
2747
+ this.showBtn = contentName.toLowerCase() === this.dakshtaName.toLowerCase();
2748
+ }
2749
+ catch (error) {
2750
+ // Handle any unexpected errors
2751
+ this.loggerSvc.error('Error processing content creator data:', error);
2752
+ this.contentCreatorData = [];
2753
+ this.showBtn = false;
2754
+ }
2755
+ }
2756
+ getI18NTranslations() {
2757
+ // Subscribe to language translation flag changes
2758
+ const translationSubscription = this.configSvc.languageTranslationFlag
2759
+ .pipe(takeUntil(this.destroySubject$)) // Ensure subscription is cleaned up on component destroy
2760
+ .subscribe({
2761
+ next: (data) => {
2762
+ // Only proceed if we have valid data
2763
+ if (data) {
2764
+ // Check if website language is set in localStorage
2765
+ const storedLanguage = localStorage.getItem('websiteLanguage');
2766
+ if (storedLanguage) {
2767
+ // Set default language as fallback
2768
+ this.translate.setDefaultLang('en');
2769
+ // Use the stored language preference
2770
+ this.translate.use(storedLanguage);
2771
+ }
2772
+ }
2773
+ },
2774
+ error: (error) => {
2775
+ // Log any errors that occur during subscription
2776
+ this.loggerSvc.error('Error in language translation subscription:', error);
2777
+ }
2778
+ });
2779
+ // Store subscription for cleanup (optional alternative to takeUntil)
2780
+ this.translationSubscription = translationSubscription;
2781
+ }
2782
+ getServerDateTime() {
2783
+ // Fetch the server date time and process the response
2784
+ this.tocSvc.getServerDate().subscribe((response) => {
2785
+ // Check if response contains valid system date
2786
+ if (response && response.systemDate) {
2787
+ // Update service with server date (removed duplicate call)
2788
+ this.tocSvc.changeServerDate(response.systemDate);
2789
+ this.serverDate = response.systemDate;
2790
+ }
2791
+ else {
2792
+ // Fallback to client's time if server time is not available
2793
+ const clientTime = new Date().getTime();
2794
+ this.tocSvc.changeServerDate(clientTime);
2795
+ this.serverDate = clientTime;
2796
+ }
2797
+ // Initialize dependent functions that need server date
2798
+ this.findACPB();
2799
+ this.getKarmapointsLimit();
2800
+ }, (error) => {
2801
+ // Log the error for debugging
2802
+ this.loggerSvc.error('Failed to get server date:', error);
2803
+ // Fallback to client's time on error
2804
+ const clientTime = new Date().getTime();
2805
+ this.tocSvc.changeServerDate(clientTime);
2806
+ this.serverDate = clientTime;
2807
+ });
2808
+ // Subscribe to server date changes from service
2809
+ this.serverDateSubscription = this.tocSvc.serverDate
2810
+ .pipe(takeUntil(this.destroySubject$)) // Ensure subscription is cleaned up
2811
+ .subscribe(serverDate => {
2812
+ this.serverDate = serverDate;
2813
+ });
2814
+ }
2815
+ get getBaseContentIdentifier() {
2816
+ return this.baseContentReadData?.identifier || this.content?.identifier || '';
2817
+ }
2818
+ get isMultilingual() {
2819
+ if (this.baseContentReadData && this.baseContentReadData.languageMapV1) {
2820
+ return this.languageList.length > 1;
2821
+ }
2822
+ return false;
2823
+ }
2824
+ handleEnrollment(event) {
2825
+ if (this.isMultilingual) {
2826
+ this.openLangDialog(event);
2827
+ }
2828
+ else {
2829
+ this.handleAutoBatchAssign();
2830
+ }
2831
+ }
2832
+ openLangDialog(_event) {
2833
+ const dialogRef = this.dialog.open(EnrollLanguageDialogueComponent, {
2834
+ width: '500px',
2835
+ height: 'auto',
2836
+ autoFocus: false,
2837
+ restoreFocus: false,
2838
+ data: {
2839
+ preSelect: this.selectedLanguage,
2840
+ languageList: this.languageList,
2841
+ }
2842
+ });
2843
+ dialogRef.afterClosed().subscribe((selectedLang) => {
2844
+ if (selectedLang) {
2845
+ this.selectedLanguage = selectedLang;
2846
+ this.handleAutoBatchAssign();
2847
+ }
2848
+ });
2849
+ }
2850
+ getResumeUrl(resourceData, batchId, primaryCategory) {
2851
+ let MLId = this.selectedLanguage?.identifier || '';
2852
+ let ML = this.selectedLanguage?.langId || '';
2853
+ let resumeDataUrl = viewerRouteGenerator(resourceData.identifier, resourceData.mimeType, this.isResource ? undefined : this.baseContentReadData && this.baseContentReadData?.identifier || '', this.isResource ? undefined : this.baseContentReadData && this.baseContentReadData?.contentType || '', this.forPreview, primaryCategory || 'Learning Resource', batchId || this.getBatchId(), this.baseContentReadData && this.baseContentReadData?.name || '', ML, MLId);
2854
+ return resumeDataUrl;
2855
+ }
2856
+ get contentCompletionPercent() {
2857
+ if (this.batchData?.enrolled) {
2858
+ if (this.contentReadData && this.contentReadData.primaryCategory === 'Course' && this.isMultilingual) {
2859
+ if (this.languageMapProgress && this.selectedLanguage?.langId && this.languageMapProgress[this.selectedLanguage?.langId]) {
2860
+ return this.languageMapProgress[this.selectedLanguage?.langId];
2861
+ }
2862
+ else {
2863
+ return 0;
2864
+ }
2865
+ }
2866
+ else {
2867
+ return this.content?.completionPercentage || 0;
2868
+ }
2869
+ }
2870
+ }
2871
+ checkForCompletionSurveyTrigger() {
2872
+ if (this.content && this.contentReadData) {
2873
+ // check if completion survey is enabled and user has completed the course before 23rd DEC 2023 (release date of completion survey)
2874
+ if (this.configSvc.instanceConfig && this.configSvc.instanceConfig.completionSurvey && this.configSvc.instanceConfig.completionSurvey.enabled &&
2875
+ this.enrolledCourseData && this.enrolledCourseData && this.enrolledCourseData.completedOn >= this.configSvc.instanceConfig.completionSurvey.startDate) {
2876
+ if ((this.content.completionStatus === 2 || this.content.completionPercentage === 100) && this.contentReadData.completionSurveyLink) {
2877
+ const sID = this.contentReadData.completionSurveyLink.split('surveys/');
2878
+ const surveyId = sID[1];
2879
+ const courseId = this.contentReadData.identifier;
2880
+ // Call API to see if survey is submitted or not
2881
+ this.tocSvc.getApllicationsById(surveyId, courseId).subscribe((res) => {
2882
+ if (res.result.response && Object.keys(res.result.response).length > 0) {
2883
+ this.lockCertificate = false;
2884
+ }
2885
+ else {
2886
+ this.lockCertificate = true;
2887
+ this.openCompletionSurveyFormPopup();
2888
+ }
2889
+ });
2890
+ }
2891
+ }
2892
+ }
2893
+ }
2894
+ // Clear existing survey data from local storage before opening popup
2895
+ clearExistingPublicSurveyData(surveyId, courseId) {
2896
+ const storageKey = `survey_${surveyId}_${courseId}`;
2897
+ if (localStorage.getItem(storageKey)) {
2898
+ localStorage.removeItem(storageKey);
2899
+ }
2900
+ }
2901
+ openPublicSurveyPopup(navigationUrl, queryParams) {
2902
+ // Get survey ID and course ID from environment and content data
2903
+ if (this.forPreview) {
2904
+ this.router.navigate([navigationUrl], { queryParams: queryParams });
2905
+ }
2906
+ else {
2907
+ const surveyId = this.environment.publicContentSurveyId || '';
2908
+ const courseId = this.contentReadData?.identifier || '';
2909
+ const courseName = this.contentReadData?.name || '';
2910
+ const contextOrgId = this.contentReadData?.createdFor && this.contentReadData?.createdFor.length > 0 ?
2911
+ this.contentReadData?.createdFor[0] : '';
2912
+ this.clearExistingPublicSurveyData(surveyId, courseId);
2913
+ const data = {
2914
+ surveyId: surveyId,
2915
+ courseId: courseId,
2916
+ courseName: courseName,
2917
+ contextOrgId: contextOrgId,
2918
+ forPreview: this.forPreview
2919
+ };
2920
+ const dialogRef = this.dialog.open(PublicSurveyFormComponent, {
2921
+ // disableClose: true,
2922
+ width: '750px',
2923
+ maxWidth: '90vw',
2924
+ height: '80vh',
2925
+ data: data,
2926
+ autoFocus: false,
2927
+ });
2928
+ dialogRef.afterClosed().subscribe((result) => {
2929
+ if (result) {
2930
+ // Navigate to the intended URL only when survey is submitted successfully
2931
+ if (navigationUrl) {
2932
+ this.router.navigate([navigationUrl], { queryParams: queryParams });
2933
+ }
2934
+ }
2935
+ });
2936
+ }
2937
+ }
2938
+ resumeContentData() {
2939
+ const navigationUrl = (this.resumeData && !this.certData) ? this.resumeDataLink?.url : this.firstResourceLink?.url;
2940
+ const queryParams = (this.resumeData && !this.certData) ? this.generateQuery('RESUME') : this.generateQuery('START');
2941
+ this.router.navigate([navigationUrl], { queryParams: queryParams });
2942
+ }
2943
+ /**
2944
+ * Check if user can enroll in the course
2945
+ * Returns true when enrollment is allowed
2946
+ */
2947
+ navigateToNewVersion() {
2948
+ this.router.navigateByUrl('/app/toc', { skipLocationChange: true }).then(() => {
2949
+ this.router.navigate([`app/toc/${this.contentReadData?.contentVersionInfo?.identifier}/overview`]);
2950
+ });
2951
+ }
2952
+ canEnroll() {
2953
+ if (this.contentReadData && this.contentReadData.lastEnrollmentDate) {
2954
+ const serverTime = dayjs(this.serverDate).format('YYYY-MM-DD');
2955
+ const eDate = dayjs(this.contentReadData.lastEnrollmentDate).format('YYYY-MM-DD');
2956
+ if (dayjs(serverTime).isSameOrBefore(eDate)) {
2957
+ return true;
2958
+ }
2959
+ else {
2960
+ return false;
2961
+ }
2962
+ }
2963
+ else {
2964
+ return true;
2965
+ }
2966
+ }
2967
+ goBack() {
2968
+ this.location.back();
2969
+ }
2970
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AppTocHomeV2Component, deps: [{ token: i1.ActivatedRoute }, { token: i1.Router }, { token: i2.WidgetContentService }, { token: i3.AppTocService }, { token: i4.LoggerService }, { token: i4.ConfigurationsService }, { token: i5.DomSanitizer }, { token: i6.MatLegacySnackBar }, { token: i7.MatLegacyDialog }, { token: i8.MobileAppsService }, { token: i4.UtilityService }, { token: i9.ContentLanguageService }, { token: i10.ActionService }, { token: i11.ViewerUtilService }, { token: i12.RatingService }, { token: i4.TelemetryService }, { token: i13.TranslateService }, { token: i4.MultilingualTranslationsService }, { token: i4.EventService }, { token: i14.LoadCheckService }, { token: i15.HandleClaimService }, { token: i16.ResetRatingsService }, { token: i17.TimerService }, { token: i4.WidgetEnrollService }, { token: i9.WidgetContentLibService }, { token: i4.DataTransferService }, { token: i18.MatSnackBar }, { token: i9.WidgetUserServiceLib }, { token: i19.NetCoreService }, { token: i20.AppTocV2Service }, { token: i21.Location }, { token: i4.DomainConfService }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Component }); }
2971
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AppTocHomeV2Component, selector: "ws-app-app-toc-home-v2", inputs: { forPreview: "forPreview", inputContent: "inputContent", displayViewBtn: "displayViewBtn" }, host: { listeners: { "window:scroll": "handleScroll($event)" } }, viewQueries: [{ propertyName: "menuElement", first: true, predicate: ["stickyMenu"], descendants: true, static: true }, { propertyName: "rcElement", first: true, predicate: ["rightContainer"], descendants: true }, { propertyName: "bannerElem", first: true, predicate: ["bannerDetails"], descendants: true, static: true }, { propertyName: "contentSource", first: true, predicate: ["contentSource"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"courseID else noDataFound\">\n <ng-template #enrollFunctionality>\n <div [hidden]=\"isResource && !content?.artifactUrl?.length\" class=\"flex flex-col gap-4 text-center\">\n <!-- Course block -->\n <ng-container *ngIf=\"contentReadData?.primaryCategory !== primaryCategory.PROGRAM\n && contentReadData?.primaryCategory !== primaryCategory.CURATED_PROGRAM\n && contentReadData?.primaryCategory !== primaryCategory.STANDALONE_ASSESSMENT &&\n contentReadData?.primaryCategory !== primaryCategory.BLENDED_PROGRAM\">\n <ng-container *ngIf=\"(actionBtnStatus === 'grant' && !(isMobile && content?.isInIntranet) &&\n !(contentReadData?.primaryCategory === primaryCategory.COURSE && content?.children.length === 0 &&\n !content?.artifactUrl?.length) &&\n !(contentReadData?.primaryCategory === primaryCategory.COURSE && !batchData?.enrolled) &&\n !(contentReadData?.primaryCategory === primaryCategory.RESOURCE && !content?.artifactUrl) &&\n !(contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL)) &&\n !(contentReadData?.primaryCategory === primaryCategory.PROGRAM && currentCourseBatchId)\">\n <a *ngIf=\"showStart.show && !isPostAssessment && !forPreview\" (click)=\"raiseTelemetryForPublic()\"\n [routerLink]=\"(resumeData && !certData) ? resumeDataLink?.url : firstResourceLink?.url\"\n [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\"\n class=\"flex action-button justify-center\">\n <ng-container *ngIf=\"(!content?.completionPercentage || content?.completionPercentage < 100) && !certData\">\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">\n {{ translateLabels('resume', 'apptochome') }}\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"content?.completionPercentage === 100 || certData\">\n {{ content?.completionPercentage >= 100 ? translateLabels('Start again', 'apptochome') :\n translateLabels('resume', 'apptochome') }}\n </ng-container>\n </a>\n\n <button *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\" (click)=\"raiseTelemetryForPublic()\"\n [routerLink]=\"firstResourceLink?.url\" class=\"flex action-button justify-center\">\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">{{ 'apptochome.takeAssessment' | translate\n }}</ng-container>\n </button>\n\n <!-- <div\n *ngIf=\"!isPostAssessment && (!content?.completionPercentage || content?.completionPercentage < 100) && !certData\">\n <ng-container *ngIf=\"isAcbpClaim\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container>\n <ng-container *ngIf=\"!isAcbpClaim && !monthlyCapExceed\">\n <ws-app-karmapoints-panel [btntype]=\"'Resume'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container>\n </div> -->\n\n <!-- <div *ngIf=\"!isPostAssessment && (content?.completionPercentage === 100 || certData)\">\n <div *ngIf=\"isAcbpCourse && isAcbpClaim && !isClaimed\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP CLAIM'\" [data]=\"kparray\" [btnCategory]=\"'claim'\"\n (clickClaimKarmaPoints)=\"onClickOfClaim($event)\"></ws-app-karmapoints-panel>\n </div>\n <div *ngIf=\"!isAcbpCourse && !monthlyCapExceed\">\n <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div>\n <div *ngIf=\"!isAcbpCourse && monthlyCapExceed && !isCompletedThisMonth\">\n <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div>\n </div> -->\n\n <!-- <div *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\">\n <ws-app-karmapoints-panel [btntype]=\"'Take Assessment'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div> -->\n </ng-container>\n\n <ng-container *ngIf=\" (actionBtnStatus === 'grant' && !(isMobile && content?.isInIntranet) &&\n !( contentReadData?.primaryCategory === primaryCategory.COURSE && content?.children.length === 0 && !content?.artifactUrl?.length ) &&\n !( contentReadData?.primaryCategory === primaryCategory.COURSE && batchData?.enrolled ) &&\n !(contentReadData?.primaryCategory === primaryCategory.RESOURCE && !content?.artifactUrl)) &&\n !(contentReadData?.primaryCategory === primaryCategory.PROGRAM) &&\n !(contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL)\">\n <ng-container *ngIf=\"contentReadData?.primaryCategory !== primaryCategory.RESOURCE && !enrollBtnLoading\">\n <a class=\"flex action-button justify-center resume\" *ngIf=\"!forPreview || isInIFrame\"\n (click)=\"handleEnrollment()\" [ngClass]=\"{'disable-start-btn': !canEnroll()}\">\n <ng-container>\n {{ 'apptochome.enroll' | translate }}\n </ng-container>\n </a>\n <!-- <ng-container *ngIf=\"isAcbpCourse\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container> -->\n <!-- <ng-container *ngIf=\"!isAcbpCourse && !monthlyCapExceed && userEnrollmentList && !userEnrollmentList.length\">\n <ws-app-karmapoints-panel [btntype]=\"'Enroll'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container> -->\n </ng-container>\n </ng-container>\n </ng-container>\n\n\n <!-- PRogram & mandatory course block -->\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authViewBtn\">\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.PROGRAM || contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL\">\n <ng-container\n *ngIf=\"(courseCategory?.MODERATED_PROGRAM === contentReadData?.courseCategory) && (contentReadData?.batches && !batchData?.enrolled)\">\n <ng-container\n *ngIf=\"((contentReadData?.primaryCategory !== primaryCategory.RESOURCE) && !enrollBtnLoading) && !contentReadData?.batches[0].endDate\">\n <a class=\"flex action-button justify-center resume\" (click)=\"handleEnrollment()\">\n <ng-container *ngIf=\"!forPreview || isInIFrame\">\n {{'apptochome.enroll' | translate}}\n </ng-container>\n </a>\n <!-- <ng-container *ngIf=\"isAcbpCourse\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container>\n <ng-container *ngIf=\"!isAcbpCourse && !monthlyCapExceed && userEnrollmentList && !userEnrollmentList.length\">\n <ws-app-karmapoints-panel [btntype]=\"'Enroll'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container> -->\n </ng-container>\n <ng-container *ngIf=\"!forPreview || isInIFrame\">\n <ng-container\n *ngIf=\"((contentReadData?.primaryCategory !== primaryCategory.RESOURCE) && !enrollBtnLoading) && contentReadData?.batches[0].endDate\">\n <ws-app-toc-banner role=\"banner\" [banners]=\"banners\" [forPreview]=\"forPreview\" [content]=\"content\"\n [userEnrollmentList]=\"userEnrollmentList\" [analytics]=\"analytics\"\n (programEnrollCall)=\"programEnrollCall($event)\" [resumeData]=\"resumeData\" [batchData]=\"batchData\"\n [contentReadData]=\"contentReadData\">\n </ws-app-toc-banner>\n </ng-container>\n </ng-container>\n </ng-container>\n <ng-container\n *ngIf=\"(courseCategory?.MODERATED_PROGRAM === contentReadData?.courseCategory) && !contentReadData?.batches && !batchData?.enrolled && !enrollBtnLoading\">\n No Batches\n </ng-container>\n <ng-container\n *ngIf=\"courseCategory?.MODERATED_PROGRAM !== contentReadData?.courseCategory && !enrollBtnLoading\">\n <ng-container\n *ngIf=\"!(contentReadData?.primaryCategory === primaryCategory.PROGRAM && currentCourseBatchId) && contentReadData?.primaryCategory !== primaryCategory.MANDATORY_COURSE_GOAL\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.youAreNotInvited' | translate }} </span>\n </ng-container>\n <ng-container *ngIf=\"!isBatchInProgress && !!currentCourseBatchId && getStartDate === 'NA'\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.noActiveBatches' | translate }}</span>\n </ng-container>\n <ng-container *ngIf=\"!isBatchInProgress && currentCourseBatchId && getStartDate !== 'NA'\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.batchWillStart' | translate }}\n {{getStartDate}}!</span>\n </ng-container>\n </ng-container>\n <ng-container\n *ngIf=\"!isBatchInProgress && courseCategory?.MODERATED_PROGRAM === contentReadData?.courseCategory && !enrollBtnLoading\">\n <ng-container *ngIf=\"!isBatchInProgress && currentCourseBatchId && getStartDate !== 'NA'\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.batchWillStart' | translate }}\n {{getStartDate}}!</span>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"isBatchInProgress &&\n ( actionBtnStatus === 'grant' &&\n !(isMobile && content?.isInIntranet) &&\n (contentReadData?.primaryCategory === primaryCategory.PROGRAM && currentCourseBatchId) ||\n (contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL && currentCourseBatchId)\n )\">\n <a *ngIf=\"showStart.show && !isPostAssessment\"\n [routerLink]=\"resumeData ? resumeDataLink?.url : firstResourceLink?.url\"\n [queryParams]=\"resumeData ? generateQuery('RESUME') : generateQuery('START')\"\n class=\"flex action-button justify-center resume\">\n <ng-container *ngIf=\"!content?.completionPercentage || content?.completionPercentage < 100\">\n <ng-container *ngIf=\"!forPreview || isInIFrame\">\n {{ resumeData && (content?.completionPercentage < 100 && content?.completionPercentage> 0) ?\n translateLabels('resume', 'apptochome') :\n translateLabels('start', 'apptochome') }}\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"content?.completionPercentage === 100\">\n {{ (resumeData) || content?.completionPercentage === 100 ? \"Start again\" : \"Start\" }}\n </ng-container>\n </a>\n <a *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\" [routerLink]=\"firstResourceLink?.url\"\n class=\"flex action-button justify-center resume\">\n <ng-container *ngIf=\"!forPreview || isInIFrame\">{{ 'apptochome.takeAssessment' | translate\n }}</ng-container>\n </a>\n <!-- <div *ngIf=\"!isPostAssessment && (!content?.completionPercentage || content?.completionPercentage < 100)\">\n <ng-container *ngIf=\"isAcbpClaim\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container>\n <ng-container *ngIf=\"!isAcbpClaim && !monthlyCapExceed\">\n <ws-app-karmapoints-panel [btntype]=\"'Resume'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container>\n </div> -->\n <!-- <div *ngIf=\"!isPostAssessment && (content?.completionPercentage === 100)\">\n <div *ngIf=\"isAcbpCourse && isAcbpClaim && !isClaimed\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP CLAIM'\" [condition]=\"{isPostAssessment: isPostAssessment, content: content, isAcbpCourse: isAcbpCourse, isClaimed: isClaimed, monthlyCapExceed: monthlyCapExceed, isCompletedThisMonth: isCompletedThisMonth, showTakeAssessment: showTakeAssessment, userEnrollmentList: userEnrollmentList, isCompletedThisMonth: isCompletedThisMonth, resumeData: resumeData, userRating: userRating}\" [data]=\"kparray\" [btnCategory]=\"'claim'\"\n (clickClaimKarmaPoints)=\"onClickOfClaim($event)\"></ws-app-karmapoints-panel>\n </div>\n <div *ngIf=\"!isAcbpCourse && !monthlyCapExceed\">\n <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div>\n <div *ngIf=\"!isAcbpCourse && monthlyCapExceed && !isCompletedThisMonth\">\n <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div>\n </div>\n <div *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\">\n <ws-app-karmapoints-panel [btntype]=\"'Take Assessment'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div> -->\n </ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container\n *ngIf=\"isBatchInProgress && (contentReadData?.primaryCategory === primaryCategory.CURATED_PROGRAM && batchData?.enrolled) && !enrollBtnLoading\">\n <a *ngIf=\"showStart.show && !isPostAssessment\" (click)=\"raiseTelemetryForPublic()\"\n [routerLink]=\"resumeData ? resumeDataLink?.url : firstResourceLink?.url\"\n [queryParams]=\"resumeData ? generateQuery('RESUME') : generateQuery('START')\"\n class=\"flex action-button justify-center resume\">\n <ng-container *ngIf=\"!content?.completionPercentage || content?.completionPercentage < 100\">\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">\n {{ resumeData && (content?.completionPercentage < 100 && content?.completionPercentage> 0) ?\n translateLabels('resume', 'apptochome') :\n translateLabels('resume', 'apptochome') }}\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"content?.completionPercentage === 100\">\n {{ resumeData || content?.completionPercentage === 100 ? translateLabels('Start again', 'apptochome') :\n translateLabels('resume', 'apptochome') }}\n </ng-container>\n </a>\n </ng-container>\n\n <ng-container *ngIf=\"enrollBtnLoading\">\n <ws-widget-skeleton-loader [width]=\"'100%'\" [height]=\"'36px'\"\n [bindingClass]=\"'flex rounded h-8'\"></ws-widget-skeleton-loader>\n </ng-container>\n\n <!-- Curated program block -->\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.CURATED_PROGRAM && !batchData?.enrolled && !enrollBtnLoading\">\n <a class=\"flex action-button justify-center resume\" *ngIf=\"!forPreview || isInIFrame\"\n (click)=\"handleEnrollment()\">\n <ng-container>\n {{ 'apptochome.enroll' | translate }}\n </ng-container>\n </a>\n </ng-container>\n <!-- STANDALONE_ASSESSMENT black -->\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && !batchData?.enrolled && !enrollBtnLoading && contentReadData?.courseCategory !== 'Invite-Only Assessment'\">\n <a class=\"flex action-button justify-center resume\" (click)=\"handleEnrollment()\"\n *ngIf=\"!forPreview || isInIFrame\">\n <ng-container>\n {{ 'apptochome.enroll' | translate }}\n </ng-container>\n </a>\n </ng-container>\n <!-- INVITE ONLY STANDALONE ASSESSMENT block-->\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && !batchData?.enrolled && !enrollBtnLoading && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authViewForInviteOnlyAssessment\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.youAreNotInvitedForAssessment' | translate }}\n </span>\n </ng-container>\n </ng-container>\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && batchData?.enrolled && isBatchInProgress && !enrollBtnLoading && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n <a class=\"flex action-button justify-center resume\" [routerLink]=\"firstResourceLink?.url\"\n [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\">\n <ng-container *ngIf=\"content?.completionPercentage === 100\">{{ 'apptochome.takeTestAgain' | translate\n }}</ng-container>\n <ng-container *ngIf=\"content?.completionPercentage < 100\">{{ 'apptochome.takeTest' | translate\n }}</ng-container>\n </a>\n </ng-container>\n <ng-container\n *ngIf=\"!isBatchInProgress && !!currentCourseBatchId && getStartDate === 'NA' && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.noActiveBatches' | translate }}</span>\n </ng-container>\n <ng-container\n *ngIf=\"!isBatchInProgress && currentCourseBatchId && getStartDate !== 'NA' && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.batchWillStart' | translate }}\n {{getStartDate}}!</span>\n </ng-container>\n\n <!-- STANDALONE_ASSESSMENT enrolled black -->\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && batchData?.enrolled && !enrollBtnLoading && contentReadData?.courseCategory !== 'Invite-Only Assessment'\">\n <a class=\"flex action-button justify-center resume\" [routerLink]=\"firstResourceLink?.url\"\n [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\">\n <ng-container *ngIf=\"content?.completionPercentage === 100\">{{ 'apptochome.takeTestAgain' | translate\n }}</ng-container>\n <ng-container *ngIf=\"content?.completionPercentage < 100\">{{ 'apptochome.takeTest' | translate\n }}</ng-container>\n </a>\n </ng-container>\n <!-- BLENDED_PROGRAM block -->\n <ng-container *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM\">\n\n <ng-container *ngIf=\"batchData?.workFlow?.wfInitiated &&\n !(batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.APPROVED ||\n batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.REJECTED ||\n batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.WITHDRAWN ||\n batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.REMOVED)\">\n <div class=\"ws-mat-accent-text ws-mat-accent-light-bg flex items-center justify-center statusMsg\">\n <p class=\"margin-remove-bottom font-bold\">\n {{ 'apptochome.requestUnderReview' | translate }}\n </p>\n </div>\n </ng-container>\n <ng-container>\n <a *ngIf=\"showStart.show && batchData?.workFlow?.wfInitiated && batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.APPROVED\"\n [routerLink]=\"isBatchInProgress? (resumeData && !certData) ? resumeDataLink?.url : firstResourceLink?.url : '' \"\n (click)=\"raiseTelemetryForPublic()\"\n [queryParams]=\"isBatchInProgress ? (resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START') : '' \"\n class=\"flex action-button justify-center resume\" [ngClass]=\"{'disable-start-btn': !isBatchInProgress}\">\n <ng-container *ngIf=\"(!content?.completionPercentage || content?.completionPercentage < 100) && !certData\">\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">\n {{ resumeData && (content?.completionPercentage < 100 && content?.completionPercentage> 0) ?\n translateLabels('resume', 'apptochome') :\n translateLabels('start', 'apptochome') }}\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"content?.completionPercentage === 100 || certData\">\n {{ resumeData || content?.completionPercentage === 100 ? translateLabels('Start again', 'apptochome') :\n translateLabels('start', 'apptochome') }}\n </ng-container>\n </a>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"actionBtnStatus == 'reject' && content?.registrationUrl\">\n <a [href]=\"content?.registrationUrl\" target=\"_blank\" class=\"flex action-button justify-center\">{{\n 'apptochome.register' | translate }}</a>\n </ng-container>\n\n </div>\n </ng-template>\n\n <ng-template #progressFunctionality>\n <div class=\"flex flex-row gap-4\">\n <div class=\"flex-1\">\n <div class=\"flex flex-col gap-2\">\n <div class=\"flex flex-row gap-4 text-sm\">\n <div class=\"flex-1 text-xs\">{{ 'apptocsinglepage.overallProgress' | translate }}</div>\n <div class=\"text-xs\" *ngIf=\"content?.completionPercentage > 0\"> {{ content?.completionPercentage }} %</div>\n </div>\n <ws-widget-content-progress *ngIf=\"content?.identifier\" [forPreview]=\"forPreview\"\n [contentId]=\"content?.identifier\" [progress]=\"content?.completionPercentage\" [progressType]=\"'percentage'\"\n [customClassName]=\"'content-progress'\">\n </ws-widget-content-progress>\n </div>\n </div>\n\n <ng-container *ngIf=\"contentCompletionPercent >= 50\">\n <button mat-stroked-button color=\"accent\" type=\"button\" class=\"rate-button\"\n (click)=\"openFeedbackDialog(content)\">\n <mat-icon class=\"nodtranslate\">star_purple500</mat-icon>\n <ng-container *ngIf=\"!userRating\">\n <div>{{ 'apptocsinglepage.rateNow' | translate }}</div>\n </ng-container>\n <ng-container *ngIf=\"userRating\">\n <div>{{ 'apptocsinglepage.editRating' | translate }}</div>\n </ng-container>\n </button>\n </ng-container>\n </div>\n </ng-template>\n\n <div class=\"toc-banner\">\n <div class=\"flex flex-row gap-6 fixed-width\">\n <div class=\"banner-details toc-content\" #bannerDetails>\n <div class=\"flex flex-col gap-4\">\n <div class=\"mobile-back-btn\" (click)=\"goBack()\">\n <mat-icon class=\"text-white\">arrow_back</mat-icon>\n </div>\n <div class=\"flex items-center justify-between gap-4\">\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'132px'\" [height]=\"'32px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'140px'\" [height]=\"'24px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n </ng-container>\n\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"flex flex-row gap-2\">\n <div class=\"flex flex-row tag-div rounded-2xl gap-1 items-center p-2\">\n <mat-icon class=\"ws-mat-orange-text nodtranslate\">video_library</mat-icon>\n <ng-container *ngIf=\"contentReadData?.courseCategory\">\n <div class=\"text-xs font-bold text-white leading-3 nodtranslate\">{{\n translateLabel(contentReadData?.courseCategory, 'searchfilters') }}</div>\n </ng-container>\n <ng-container *ngIf=\"!contentReadData?.courseCategory\">\n <div class=\"text-xs font-bold text-white leading-3 nodtranslate\">{{\n translateLabel(contentReadData?.primaryCategory, 'searchfilters') }}</div>\n </ng-container>\n </div>\n <div class=\"flex flex-row tag-div rounded-2xl gap-1 items-center p-2\"\n *ngIf=\"contentReadData?.additionalTags?.includes('iGOT Specialization')\">\n <img class=\"approved-icon\" src=\"./assets/icons/approved.svg\" alt=\"approved\">\n <div class=\"text-xs font-bold text-white leading-3 nodtranslate\">{{\n 'cardcontentv2.iGOTSpecializationProgram' | translate }}</div>\n </div>\n <!-- Knowledge level block for search box -->\n <!-- {{content?.difficultyLevel}} -->\n <div *ngIf=\"contentReadData?.difficultyLevel\" class=\"knowledge-level-container\">\n <span *ngIf=\"contentReadData?.difficultyLevel?.toLowerCase() === 'beginner'\"\n class=\"level-badge beginner\">\n <!-- <span *ngIf=\"false\" class=\"level-badge beginner\"> -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\">\n <rect width=\"16\" height=\"16\" fill=\"#DBF4DC\" />\n <path\n d=\"M7.42267 5C7.67927 4.55555 8.32077 4.55556 8.57737 5L12.0415 11C12.2981 11.4444 11.9773 12 11.4641 12H4.53592C4.02272 12 3.70197 11.4444 3.95857 11L7.42267 5Z\"\n fill=\"#49C951\" />\n </svg>\n {{contentReadData?.difficultyLevel}}\n </span>\n <span *ngIf=\"contentReadData?.difficultyLevel?.toLowerCase() === 'intermediate'\"\n class=\"level-badge intermediate\">\n <!-- <span *ngIf=\"true\" class=\"level-badge intermediate\"> -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\">\n <rect width=\"16\" height=\"16\" fill=\"#D1DBEC\" />\n <path\n d=\"M7.42267 2.66666C7.67927 2.22221 8.32077 2.22221 8.57737 2.66666L12.0415 8.66666C12.2981 9.1111 11.9773 9.66666 11.4641 9.66666H4.53592C4.02272 9.66666 3.70197 9.1111 3.95857 8.66666L7.42267 2.66666Z\"\n fill=\"#1B4CA1\" />\n <path\n d=\"M7.42267 5.66666C7.67927 5.22221 8.32077 5.22221 8.57737 5.66666L12.0415 11.6667C12.2981 12.1111 11.9773 12.6667 11.4641 12.6667H4.53592C4.02272 12.6667 3.70197 12.1111 3.95857 11.6667L7.42267 5.66666Z\"\n fill=\"#1B4CA1\" stroke=\"#D1DBEC\" stroke-width=\"0.5\" />\n </svg>\n {{contentReadData?.difficultyLevel}}\n </span>\n <span *ngIf=\"contentReadData?.difficultyLevel?.toLowerCase() === 'advanced'\"\n class=\"level-badge advanced\">\n <!-- <span *ngIf=\"false\" class=\"level-badge advanced\"> -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\">\n <g clip-path=\"url(#clip0)\">\n <rect width=\"16\" height=\"16\" fill=\"#FFE6E1\" />\n <path\n d=\"M7.42264 2.33334C7.67924 1.8889 8.32074 1.8889 8.57734 2.33334L12.0414 8.33334C12.298 8.77779 11.9773 9.33334 11.4641 9.33334H4.53589C4.02269 9.33334 3.70194 8.77779 3.95854 8.33334L7.42264 2.33334Z\"\n fill=\"#FF8268\" />\n <path\n d=\"M7.42264 5C7.67924 4.55555 8.32074 4.55556 8.57734 5L12.0414 11C12.298 11.4444 11.9773 12 11.4641 12H4.53589C4.02269 12 3.70194 11.4444 3.95854 11L7.42264 5Z\"\n fill=\"#FF8268\" stroke=\"#FFE6E1\" stroke-width=\"0.5\" />\n <path\n d=\"M7.42264 7.66669C7.67924 7.22224 8.32074 7.22224 8.57734 7.66669L12.0414 13.6667C12.298 14.1111 11.9773 14.6667 11.4641 14.6667H4.53589C4.02269 14.6667 3.70194 14.1111 3.95854 13.6667L7.42264 7.66669Z\"\n fill=\"#FF8268\" stroke=\"#FFE6E1\" stroke-width=\"0.5\" />\n </g>\n <defs>\n <clipPath id=\"clip0\">\n <rect width=\"16\" height=\"16\" fill=\"white\" />\n </clipPath>\n </defs>\n </svg>\n {{contentReadData?.difficultyLevel}}\n </span>\n </div>\n\n <div class=\"flex items-center\" *ngIf=\"cbPlanEndDate\">\n <div class=\"flex items-center due-tag text-xs leading-3\"\n [ngClass]=\"{'due-warning': cbPlanDuration === nsCardContentData.UPCOMING, 'due-overdue': cbPlanDuration === nsCardContentData.OVERDUE, 'due-success': cbPlanDuration === nsCardContentData.SUCCESS}\">\n {{ 'common.dueBy' | translate }} - &nbsp;<span class=\"font-bold\">{{ cbPlanEndDate | date: 'd\n MMM,y'}}</span>\n </div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!skeletonLoader && contentReadData?.contentVersionInfo?.identifier\">\n <div class=\"new-version-chip rounded-2xl\" (click)=\"navigateToNewVersion()\"\n (keydown)=\"navigateToNewVersion()\">\n <span class=\"new-version-text nodtranslate\">{{ 'apptoc.newVersion' | translate }}</span>\n </div>\n </ng-container>\n <div class=\"flex items-center text-white mob-share\" *ngIf=\"canShare\">\n <mat-icon class=\"nodtranslate\" (click)=\"onClickOfShare()\">share</mat-icon>\n </div>\n </div>\n <div class=\"flex flex-col gap-2\">\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'90%'\" [height]=\"'32px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'70%'\" [height]=\"'32px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n </ng-container>\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"banner-text text-base sm:text-4xl leading-6 sm:leading-10 font-bold nodtranslate\">{{\n handleCapitalize(contentReadData?.name) }}</div>\n <div class=\"text-sm sm:text-base source-text font-semibold break-words nodtranslate\" #contentSource\n [ngClass]=\"{'sourceEllipsis': sourceEllipsis}\" title=\"{{contentReadData?.source}}\">{{ 'cardcontentv2.by'\n | translate }} {{ contentReadData?.source }}</div>\n </ng-container>\n </div>\n\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'120px'\" [height]=\"'40px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'88px'\" [height]=\"'24px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n </ng-container>\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"flex gap-4 items-center\">\n <div class=\"flex flex-row rating-chip py-2 items-center cursor-pointer\"\n (click)=\"handleNavigateToReviews()\" *ngIf=\"content?.averageRating\">\n <div class=\"flex flex-row gap-1 margin-left-s items-center\">\n <mat-icon class=\"nodtranslate\">grade</mat-icon>\n <div class=\"text-white text-sm leading-4\">{{ content?.averageRating }}</div>\n </div>\n <div class=\"separator\"></div>\n <div class=\"text-white text-sm leading-4 margin-right-m\">{{ content?.totalRating | pipeCountTransform }}\n </div>\n </div>\n <div class=\"flex items-center\" *ngIf=\"content?.additionalTags?.length\">\n <div class=\"most-enrolled-chip text-xs leading-3\">\n <span *ngIf=\"content?.additionalTags?.includes('mostTrending')\">{{ 'cardcontentv2.mostTrending' |\n translate }}</span>\n <span *ngIf=\"content?.additionalTags?.includes('mostEnrolled')\">{{ 'cardcontentv2.mostEnrolled' |\n translate }}</span>\n </div>\n </div>\n <div class=\"flex items-center\" *ngIf=\"contentReadData?.retirementDate\">\n <div class=\"new-version-pill text-xs leading-3\" *ngIf=\"contentReadData?.status !== 'Retired'\">\n <span>{{ 'apptoc.pendingRetirement' | translate }}</span>\n </div>\n <div class=\"new-version-retire-pill text-xs leading-3\" *ngIf=\"contentReadData?.status === 'Retired'\">\n <span>{{ 'apptoc.retired' | translate }}</span>\n </div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'180px'\" [height]=\"'20px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n </ng-container>\n <ng-container *ngIf=\"!skeletonLoader && contentReadData?.sYS_INTERNAL_LAST_UPDATED_ON\">\n <div class=\"text-xs leading-4 source-text nodtranslate\">({{ 'apptoc.lastUpdatedOn' | translate }} {{\n contentReadData?.sYS_INTERNAL_LAST_UPDATED_ON | date: 'MMM d, y' }})</div>\n </ng-container>\n <ng-container>\n <div class=\"flex flex-row gap-2\" *ngIf=\"languageList?.length > 1\">\n <mat-chip-list class=\"lang-chips\">\n <!-- Show up to 6 chips -->\n <ng-container *ngFor=\"let lang of languageList | slice:0:5; let i = index\">\n <mat-chip class=\"matchip-custom\" selectable=\"true\"\n [selected]=\"lang?.identifier === selectedLanguage?.identifier\" (click)=\"onLanguageSelect(lang)\">\n {{ lang.name || lang.value }}\n </mat-chip>\n </ng-container>\n\n <!-- \"More\" chip if there are more than 6 languages -->\n <ng-container *ngIf=\"languageList.length > 5\">\n <mat-chip [matMenuTriggerFor]=\"moreLanguagesMenu\" selectable=\"false\" class=\"more-chip matchip-custom\"\n [selected]=\"isSelectedInMoreDropdown()\">\n More <mat-icon class=\"mat-icon\">keyboard_arrow_down</mat-icon>\n </mat-chip>\n <mat-menu #moreLanguagesMenu=\"matMenu\">\n <mat-radio-group class=\"mat-radio-group flex flex-col gap-2 p-3\" [value]=\"selectedLanguage\">\n <mat-radio-button *ngFor=\"let lang of languageList | slice:5\" [value]=\"lang\"\n [checked]=\"lang?.identifier === selectedLanguage?.identifier\" (change)=\"onLanguageSelect(lang)\">\n {{ lang.displayName || lang.name || lang }}\n </mat-radio-button>\n </mat-radio-group>\n </mat-menu>\n </ng-container>\n </mat-chip-list>\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"flex flex-row gap-6 fixed-width\">\n <div class=\"toc-content\">\n <ng-container *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM &&\n selectedBatchData?.content[0]?.batchAttributes?.batchLocationDetails &&\n selectedBatchData?.content[0]?.enrollmentEndDate\">\n <div class=\"location-details mt-6\">\n <div class=\"flex items-center gap-4 pb-3\">\n <mat-icon class=\"location-icon nodtranslate\">\n location_on\n </mat-icon>\n <div class=\"loc-desc\">\n {{selectedBatchData?.content[0]?.batchAttributes?.batchLocationDetails}}\n </div>\n </div>\n <div class=\"flex items-center gap-4\">\n <mat-icon class=\"event-icon nodtranslate\">\n event</mat-icon>\n <div class=\"loc-desc\">\n Last date of enrollment - {{selectedBatchData?.content[0]?.enrollmentEndDate | date: 'dd/MM/yyyy'}}\n </div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"recommendedCoursesId && !feedbackGiven\">\n <div class=\"px-4 py-3 mt-6 relevent-wrapper\">\n <div class=\"flex gap-4 items-center flex-wrap flex justify-center md:justify-start\">\n <img src=\"/assets/images/sakshamAI/lady-greet.svg\" alt=\"greet\" width=\"56.89\" height=\"64\">\n <div class=\"relevent-info\">\n <span class=\"font-bolder text-sm relevent-heading block mb-1\">{{ 'home.tocReleventHeading' | translate\n }}</span>\n <span class=\"relevent-subinfo font-normal text-sm block\">{{ 'home.tocReleventSubHeading' | translate\n }}</span>\n </div>\n <div class=\"flex flex-middle relevant-container\">\n <div class=\"flex flex-middle relevent-normal relevent-btn py-2 px-4 relevant-box\"\n (mouseenter)=\"isReleventBtnHovered = true\" (mouseleave)=\"isReleventBtnHovered = false\"\n (click)=\"handleAcceptRelevent()\">\n <img [src]=\"isReleventBtnHovered && !isRelevent ? SAKSHAMAI_ICON_LOADER : SAKSHAMAI_ICON_NORMAL\"\n alt=\"loader\" width=\"16\" height=\"16\" class=\"mr-2\">\n <span class=\"text-relevent ff-lato text-sm font-bold\">{{ 'home.relevent' | translate }}</span>\n </div>\n\n <div class=\"flex flex-middle no-button ml-8\" (click)=\"handleDeclineRelevent()\">\n <mat-icon class=\"mat-icon text-no mr-1 nodtranslate\">thumb_down</mat-icon>\n <span class=\"text-no ff-lato text-sm font-bold\">{{ 'home.no' | translate }}</span>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n <div class=\"pb-4 lg:py-4\"\n *ngIf=\"contentReadData?.identifier && content?.identifier && baseContentReadData?.identifier\">\n <!-- Overall progress functionality -->\n <div class=\"mobile-progress\">\n <ng-container [ngTemplateOutlet]=\"progressFunctionality\"></ng-container>\n </div>\n <!-- Overall progress functionality -->\n <ws-widget-content-toc [content]=\"content\" [componentName]=\"'toc'\" [pathSet]=\"pathSet\"\n [tocStructure]=\"tocStructure\" [forPreview]=\"forPreview\" [isEnrolled]=\"batchData?.enrolled\"\n [resumeData]=\"resumeData\" [batchData]=\"selectedBatchData\" [skeletonLoader]=\"skeletonLoader\"\n [changeTab]=\"changeTab\" [hierarchyMapData]=\"tocSvc?.hashmap\" [selectedBatchData]=\"selectedBatchData\"\n [condition]=\"{isPostAssessment: isPostAssessment, content: content, isAcbpCourse: isAcbpCourse, isClaimed: isClaimed, monthlyCapExceed: monthlyCapExceed, isCompletedThisMonth: isCompletedThisMonth, showTakeAssessment: showTakeAssessment, userEnrollmentList: userEnrollmentList, resumeData: resumeData, userRating: userRating, enrollBtnLoading: enrollBtnLoading, primaryCategory: primaryCategory, currentCourseBatchId: currentCourseBatchId, isAcbpClaim: isAcbpClaim}\"\n [kparray]=\"kparray\" (playResumeForAI)=\"playResumeForAI()\" (enrollUserToAI)=\"enrollUserToAI()\"\n [contentReadData]=\"contentReadData\" [baseContentReadData]=\"baseContentReadData\" [languageList]=\"languageList\"\n [lockCertificate]=\"lockCertificate\" (trigerCompletionSurveyForm)=\"openSurveyFormPopup($event)\"\n (resumeContent)=\"resumeContentData()\"></ws-widget-content-toc>\n <div class=\"mob-tip-for-learner\">\n <div *ngIf=\"learnAdvisoryData && learnAdvisoryData?.length\">\n <ws-widget-tips-for-learner-card [learnAdvisoryData]=\"learnAdvisoryData\"></ws-widget-tips-for-learner-card>\n </div>\n </div>\n </div>\n </div>\n\n\n <div class=\"right-container\">\n\n <!-- if needed sticky of right container add this to below div => #rightContainer -->\n <div class=\"right-content\">\n <div class=\"right-content-inner\">\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'384px'\" [height]=\"'224px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </ng-container>\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"flex flex-col image-div\"\n [ngStyle]=\"{\n 'background-image': 'url(' + contentReadData?.posterImage + ')', 'background-repeat': 'no-repeat', 'background-size': 'cover'}\"\n [ngClass]=\"{'image-backdrop': scrolled}\">\n <div class=\"flex flex-col justify-between text-container\">\n <div class=\"flex items-center gap-4 justify-between\"\n [ngClass]=\"{'justify-between': scrolled, 'justify-end': !scrolled}\">\n <div class=\"flex flex-row tag-div rounded-2xl gap-1 items-center p-2\" *ngIf=\"scrolled\">\n <mat-icon class=\"ws-mat-orange-text nodtranslate\">video_library</mat-icon>\n <ng-container *ngIf=\"contentReadData?.courseCategory\">\n <div class=\"text-xs font-bold text-white leading-3\">{{\n translateLabel(contentReadData?.courseCategory, 'searchfilters') }}</div>\n </ng-container>\n <ng-container *ngIf=\"!contentReadData?.courseCategory\">\n <div class=\"text-xs font-bold text-white leading-3\">{{\n translateLabel(contentReadData?.primaryCategory, 'searchfilters') }}</div>\n </ng-container>\n </div>\n <div (click)=\"onClickOfShare()\" class=\"flex flex-row items-center justify-end gap-2 share-tag\"\n *ngIf=\"canShare && !forPreview\">\n <mat-icon class=\"nodtranslate\">share</mat-icon>\n <div>{{ 'apptocsinglepage.share' | translate }}</div>\n </div>\n </div>\n <div class=\"flex flex-col gap-1\" *ngIf=\"scrolled\">\n <div class=\"text-xl leading-6 text-white font-bold\">{{ handleCapitalize(contentReadData?.name) }}\n </div>\n <div class=\"text-sm source-text font-semibold break-words\" #contentSource\n [ngClass]=\"{'sourceEllipsis': sourceEllipsis}\" title=\"{{contentReadData?.source}}\">{{\n 'cardcontentv2.by' | translate }} {{ contentReadData?.source }}</div>\n </div>\n </div>\n </div>\n </ng-container>\n\n\n <div class=\"flex flex-col gap-4 p-5 border-bottom\">\n <div class=\"flex flex-col gap-1 cursor-pointer switch-version\"\n *ngIf=\"!skeletonLoader && contentReadData?.contentVersionInfo?.identifier\"\n (click)=\"navigateToNewVersion()\" (keydown)=\"navigateToNewVersion()\">\n <span class=\"btn-switch\">{{ 'apptoc.switchToNewVersion' | translate }}</span>\n </div>\n\n <div class=\"flex flex-col gap-4\"\n *ngIf=\"contentReadData && contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM\">\n <div class=\"flex flex-row gap-3 justify-around\">\n <div class=\"batch-info\">\n <div class=\"font-base font-bold\">{{ selectedBatchData?.content[0]?.batchAttributes?.currentBatchSize\n || '0' }}</div>\n <div class=\"batch-label\">{{ 'apptoc.batchSize' | translate }}</div>\n </div>\n <div class=\"batch-info\">\n <div class=\"font-base font-bold\">{{ selectedBatchData?.userCount?.totalApplied || '0' }}</div>\n <div class=\"batch-label\">{{ 'apptoc.totalApplied' | translate }}</div>\n </div>\n <div class=\"batch-info\">\n <div class=\"font-base font-bold\">{{ selectedBatchData?.userCount?.enrolled || '0' }}</div>\n <div class=\"batch-label\">{{ 'apptoc.totalEnrolled' | translate }}</div>\n </div>\n </div>\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM && !preAssessmentCompletionStatus\">\n <a class=\"flex action-button enroll-btn justify-center resume\"\n *ngIf=\"contentReadData?.preEnrolmentResources?.length\" (click)=\"routeToPreAssessent()\">\n <ng-container>\n {{ 'apptochome.preEnroll' | translate }}\n </ng-container>\n </a>\n </ng-container>\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM && preAssessmentCompletionStatus\">\n <a class=\"flex preenrolldone-btn justify-center resume\">\n <ng-container>\n {{ 'apptochome.preEnrollDone' | translate }}<img src=\"/assets/icons/Accept_icon.png\" alt=\"tick\"\n class=\"tick-icon\">\n </ng-container>\n </a>\n </ng-container>\n <ng-container\n *ngIf=\"timer && timer.days >= 0 && contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM\">\n <div class=\"flex flex-col gap-6 batch-timer\">\n <div class=\"flex flex-row\">\n <div class=\"flex-1\">\n <div class=\"flex underline\"></div>\n </div>\n <div class=\"flex\">\n <div class=\"timer-label\">{{ 'apptocsinglepage.batchStartsIn' | translate }}</div>\n </div>\n <div class=\"flex-1\">\n <div class=\"flex underline\"></div>\n </div>\n </div>\n <div class=\"flex flex-row gap-4 justify-center\">\n <div class=\"flex flex-row gap-1 items-center\">\n <div class=\"text-4xl leading-10 counter\">{{ timer.days || 0 }}</div>\n <div class=\"counter-label\">{{ 'apptocsinglepage.days' | translate }}</div>\n </div>\n <div class=\"flex items-center counter-label\">\n :\n </div>\n <div class=\"flex flex-row gap-1 items-center\">\n <div class=\"text-4xl leading-10 counter\">{{ timer.min === 60 ? timer.hours + 1 : timer.hours }}\n </div>\n <div class=\"counter-label\">{{ 'apptocsinglepage.hours' | translate }}</div>\n </div>\n <div class=\"flex items-center counter-label\">\n :\n </div>\n <div class=\"flex flex-row gap-1 items-center\">\n <div class=\"text-4xl leading-10 counter\">{{ timer.min === 60 ? 00 : timer.min }}</div>\n <div class=\"counter-label\">{{ 'apptocsinglepage.minutes' | translate }}</div>\n </div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authViewBtn\">\n <ng-container *ngIf=\"!mobile1200 && (\n !contentReadData?.preEnrolmentResources?.length ||\n (contentReadData?.preEnrolmentResources?.length && (preAssessmentCompletionStatus || !preAssessmentRequiredFlag))\n )\">\n\n <ws-app-toc-banner role=\"banner\" [banners]=\"banners\" [forPreview]=\"forPreview\" [content]=\"content\"\n [userEnrollmentList]=\"userEnrollmentList\" (withdrawOrEnroll)=\"withdrawOrEnroll($event)\"\n [analytics]=\"analytics\" [resumeData]=\"resumeData\" [batchData]=\"batchData\"\n [contentReadData]=\"contentReadData\">\n </ws-app-toc-banner>\n </ng-container>\n </ng-container>\n </div>\n\n\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'336px'\" [height]=\"'40px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'336px'\" [height]=\"'68px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </ng-container>\n\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"flex flex-col gap-4\">\n <div class=\"flex flex-row items-center gap-2 info-div\" *ngIf=\"content?.isInIntranet && showIntranetMsg\">\n <mat-icon class=\"nodtranslate\">info</mat-icon>\n <ng-container>{{ 'apptochome.viewedInIntranet' | translate }}</ng-container>\n </div>\n <div class=\"flex flex-row items-center gap-2 info-div\" *ngIf=\"showInstructorLedMsg\">\n <mat-icon class=\"nodtranslate\">info</mat-icon>&nbsp;\n <ng-container>{{ 'apptochome.notAvailableOnline' | translate }}</ng-container>\n </div>\n <div class=\"flex flex-row items-center gap-2 info-div\" *ngIf=\"showStart.msg === 'youtubeForbidden'\">\n <mat-icon class=\"nodtranslate\">info</mat-icon>&nbsp;\n <ng-container>{{ 'apptochome.youtubeContentBlocked' | translate }}</ng-container>\n </div>\n <div *ngIf=\"showBtn\">\n <a href=\"{{ cscmsUrl }}\" target=\"_blank\" class=\"flex action-button justify-center\">\n {{ 'apptochome.applyForPhysicalTraining' | translate }}</a>\n </div>\n\n <!-- Overall progress functionality -->\n <ng-container *ngIf=\"content?.completionStatus <= 2 && isBatchInProgress\">\n <ng-container [ngTemplateOutlet]=\"progressFunctionality\"></ng-container>\n </ng-container>\n <!-- Overall progress functionality -->\n\n <!-- <div *ngIf=\"resumeData && !userRating\"> -->\n <!-- <ws-app-karmapoints-panel [btntype]=\"'Rate this course'\" [data]=\"kparray\"\n [pCategory]=\"contentReadData?.primaryCategory\"></ws-app-karmapoints-panel> -->\n <!-- </div> -->\n\n <!-- <div *ngIf=\"resumeData && userRating\">\n <ws-app-karmapoints-panel [btntype]=\"'Edit rating'\" [data]=\"kparray\"\n [pCategory]=\"contentReadData?.primaryCategory\"></ws-app-karmapoints-panel>\n </div> -->\n\n <ng-container\n *ngIf=\"actionBtnStatus !== 'wait' && contentReadData?.status !== 'Deleted' && contentReadData?.status !== 'Expired'\">\n <ng-container [ngTemplateOutlet]=\"enrollFunctionality\"></ng-container>\n </ng-container>\n </div>\n\n <div class=\"karma-points-div\">\n <ws-widget-karma-points [data]=\"kparray\" (clickClaimKarmaPoints)=\"onClickOfClaim($event)\"\n [content]=\"content\"\n [condition]=\"{isPostAssessment: isPostAssessment, content: content, isAcbpCourse: isAcbpCourse, isClaimed: isClaimed, monthlyCapExceed: monthlyCapExceed, isCompletedThisMonth: isCompletedThisMonth, showTakeAssessment: showTakeAssessment, userEnrollmentList: userEnrollmentList, isCompletedThisMonth: isCompletedThisMonth, resumeData: resumeData, userRating: userRating, enrollBtnLoading: enrollBtnLoading, primaryCategory: primaryCategory, currentCourseBatchId: currentCourseBatchId, isAcbpClaim: isAcbpClaim}\"></ws-widget-karma-points>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"skeletonLoader\">\n <div class=\"flex flex-wrap gap-6\">\n <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'40px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"!skeletonLoader\">\n <ws-widget-toc-kpi-values [content]=\"content\" [tocStructure]=\"tocStructure\"\n [showInstructorLedMsg]=\"showInstructorLedMsg\" [contentReadData]=\"contentReadData\"\n [languageList]=\"languageList\"></ws-widget-toc-kpi-values>\n </ng-container>\n </div>\n\n <div class=\"flex flex-col gap-8 p-5\">\n <ng-container *ngIf=\"skeletonLoader\">\n <div class=\"flex flex-col gap-4\" *ngFor=\"let i of [1, 2]\">\n <ws-widget-skeleton-loader [width]=\"'72px'\" [height]=\"'20px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n\n <div class=\"flex flex-row items-center gap-3\">\n <ws-widget-skeleton-loader [width]=\"'36px'\" [height]=\"'36px'\"\n [bindingClass]=\"'rounded-full'\"></ws-widget-skeleton-loader>\n <div class=\"flex flex-col gap-2\">\n <ws-widget-skeleton-loader [width]=\"'124px'\" [height]=\"'20px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'124px'\" [height]=\"'12px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"flex flex-col gap-3\" *ngIf=\"handleParseJsonData(contentReadData?.creatorDetails)?.length\">\n <div class=\"text-base font-bold\">{{ 'apptocsinglepage.authors' | translate }}</div>\n <div class=\"flex flex-row gap-4 items-center\"\n *ngFor=\"let author of handleParseJsonData(contentReadData?.creatorDetails)\">\n <div class=\"flex items-center justify-center\">\n <ws-widget-avatar-photo [randomColor]=\"true\" [datalen]=\"1\" [size]=\"'round-m'\"\n [photoUrl]=\"author?.photo || ''\" [name]=\"author?.name\">\n </ws-widget-avatar-photo>\n </div>\n <div class=\"flex flex-col gap-1 justify-center\">\n <div class=\"font-bold\">{{ handleCapitalize(author?.name, 'name') }}</div>\n <div class=\"text-xs leading-3\">{{ 'apptocsinglepage.author' | translate }}</div>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3\" *ngIf=\"handleParseJsonData(contentReadData?.creatorContacts)?.length\">\n <div class=\"text-base font-bold\">{{ 'apptocsinglepage.creators' | translate }}</div>\n <div class=\"flex flex-row gap-4 items-center\"\n *ngFor=\"let creeator of handleParseJsonData(contentReadData?.creatorContacts)\">\n <div class=\"flex items-center justify-center\">\n <ws-widget-avatar-photo [randomColor]=\"true\" [datalen]=\"1\" [size]=\"'round-m'\"\n [photoUrl]=\"creeator?.photo || ''\" [name]=\"creeator?.name\">\n </ws-widget-avatar-photo>\n </div>\n <div class=\"flex flex-col gap-1 justify-center\">\n <div class=\"font-bold\">{{ handleCapitalize(creeator?.name, 'name') }}</div>\n <div class=\"text-xs leading-3\">{{ 'apptocsinglepage.creator' | translate }}</div>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3\"\n *ngIf=\"contentReadData?.source && (contentCreatorData && contentCreatorData?.length)\">\n <div class=\"text-base font-bold\">{{ 'apptocsinglepage.provider' | translate }}</div>\n <div class=\"flex flex-row gap-4 items-center\" *ngFor=\"let creator of contentCreatorData\">\n <div class=\"flex provider-logo-div\">\n <img *ngIf=\"contentReadData?.creatorLogo\" [src]=\"contentReadData?.creatorLogo\"\n alt=\"{{ 'apptocsinglepage.provider' | translate }}\" />\n <img *ngIf=\"!contentReadData?.creatorLogo\" class=\"mat-icon\"\n src=\"/assets/instances/eagle/app_logos/KarmayogiBharat_Logo.svg\"\n alt=\"{{ 'apptocsinglepage.provider' | translate }}\" />\n </div>\n <div class=\"text-sm word-break cursor-pointer\" *ngIf=\"contentReadData?.createdFor?.length\"\n (click)=\"raiseTelemeteryForProvider(contentReadData?.source, contentReadData?.createdFor[0])\"\n [routerLink]=\"['/app/learn/browse-by/provider', contentReadData?.source, contentReadData?.createdFor[0], 'micro-sites']\">\n {{ handleCapitalize(contentReadData?.source, 'source') }}\n </div>\n <div class=\"text-sm word-break\" *ngIf=\"!contentReadData?.createdFor?.length\">{{\n handleCapitalize(contentReadData?.source, 'source') }}\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n\n <div *ngIf=\"learnAdvisoryData && learnAdvisoryData?.length\">\n <ws-widget-tips-for-learner-card [learnAdvisoryData]=\"learnAdvisoryData\"></ws-widget-tips-for-learner-card>\n </div>\n </div>\n\n\n\n </div>\n </div>\n <div class=\"mobile-enroll-div\"\n [ngClass]=\"{'bg-white': contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM }\">\n <ng-container *ngIf=\"content && contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM \">\n <div class=\"mb-2\" *ngIf=\"mobile1200 && !forPreview || isInIFrame; else authViewBtn\">\n <ws-app-toc-banner role=\"banner\" [banners]=\"banners\" [forPreview]=\"forPreview\" [content]=\"content\"\n [userEnrollmentList]=\"userEnrollmentList\" (withdrawOrEnroll)=\"withdrawOrEnroll($event)\"\n [analytics]=\"analytics\" [resumeData]=\"resumeData\" [batchData]=\"batchData\" [contentReadData]=\"contentReadData\">\n </ws-app-toc-banner>\n </div>\n </ng-container>\n <ng-container [ngTemplateOutlet]=\"enrollFunctionality\"></ng-container>\n </div>\n\n <ws-app-share-toc *ngIf=\"enableShare\" [rootOrgId]=\"rootOrgId\" [content]=\"content\"\n (resetEnableShare)=\"resetEnableShare($event)\" [baseContentReadData]=\"baseContentReadData\"></ws-app-share-toc>\n</ng-container>\n<ng-template #noDataFound>\n <div\n class=\"error-not-found flex flex-wrapped margin-left-m margin-top-xl margin-right-m flex-col justify-center align-items-center text-center\">\n <div class=\"error-logo\">\n <div class=\"error-message ws-mat-primary-text font-weight-bold\">\n The page you requested cannot be found\n </div>\n </div>\n <!-- <div class=\"error-support\">\n <div class=\"support-message\" >We have updated our web site and many URLs have changed.</div>\n <div class=\"support-message\" >You might want to:</div>\n </div> -->\n </div>\n\n</ng-template>\n\n<ng-template #authView>{{'apptochome.view' | translate}}</ng-template>\n\n<ng-template #authViewBtn i18n>\n <ng-container *ngIf=\"displayViewBtn\">\n <a (click)=\"raiseTelemetryForPublic($event)\"\n [routerLink]=\"shouldShowSurveyPopup() ? null : ((resumeData && !certData) ? resumeDataLink?.url : firstResourceLink?.url)\"\n [queryParams]=\"shouldShowSurveyPopup() ? null : ((resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START'))\"\n class=\"flex action-button justify-center\">\n {{'apptochome.view' | translate}}\n </a>\n </ng-container>\n</ng-template>\n<ng-template #authViewForInviteOnlyAssessment>\n <ng-container *ngIf=\"forPreview && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n <a class=\"flex action-button justify-center resume\" [routerLink]=\"firstResourceLink?.url\"\n [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\">\n <ng-container>{{ 'apptochome.takeTest' | translate }}</ng-container>\n </a>\n </ng-container>\n</ng-template>", styles: [".source-text{color:#ffffffb3}.approved-icon{width:12px;height:12px}.preenrolldone-btn{opacity:1;color:#1d8923;font-family:Lato-Bold,sans-serif;font-size:14px;font-weight:700;font-style:normal;letter-spacing:.5px;text-align:center;line-height:20px;background:#fff;border-radius:64px;padding:8px 16px;border:2px solid #1D8923;cursor:pointer;height:40px;box-sizing:border-box}.preenrolldone-btn img{margin-left:8px;margin-top:-2px}.toc-banner{background:#3a83cf;background:linear-gradient(135deg,#3a83cf,#1b4ca1);width:100%}.toc-banner .fixed-width{padding:0 16px}.toc-banner .banner-details{padding:36px 0}@media screen and (max-width: 576px){.toc-banner .banner-details{padding-top:10px;padding-bottom:20px}}.toc-banner .banner-details .due-tag{padding:4px;color:#fff;border-radius:4px}.toc-banner .banner-details .due-warning{background-color:#ff9800;border:1px solid #FF9800}.toc-banner .banner-details .due-overdue{background-color:#f44336;border:1px solid #F44336}.toc-banner .banner-details .due-success{background-color:#4caf50;border:1px solid #4CAF50}.toc-banner .banner-details .rating-chip{border:1px solid rgba(0,0,0,.6);border-radius:20px;background-color:#0009}.toc-banner .banner-details .rating-chip mat-icon{width:16px;height:16px;color:#ff9800;font-size:16px}.toc-banner .banner-details .rating-chip .separator{width:1px;height:20px;border-right:1px solid rgba(255,255,255,.16);margin:0 8px}.toc-banner .banner-details .banner-text{color:#fffffff2}.toc-banner .info-div{max-width:384px;width:100%}.toc-banner .most-enrolled-chip{background-color:#ffea9e;border:1px solid #FFEA9E;padding:4px;border-radius:2px}.toc-banner .new-version-pill{background-color:#f9cb97;border:1px solid rgb(249,203,151);padding:4px;border-radius:2px}.toc-banner .new-version-retire-pill{background-color:#d13924;border:1px solid #d13924;padding:4px;color:#fff;border-radius:2px}.text-info-div{padding:8px;background-color:#fff;border-radius:64px}.mobile-back-btn{display:flex!important;align-items:center;justify-content:flex-start;cursor:pointer;padding:0;margin-bottom:8px;color:#fff!important}.mobile-back-btn mat-icon{font-size:24px!important;width:24px!important;height:24px!important}@media screen and (min-width: 577px){.mobile-back-btn{display:none!important}}.tag-div{border:1px solid #FF9800;background-color:#00000080}.tag-div mat-icon{font-size:12px;width:12px;height:12px}.fixed-width{max-width:1200px;display:block;margin:0 auto}.mat-subheading-1{margin-bottom:4px!important}.initial-circle{width:36px;height:36px;border-radius:50%;background:#1b2133;color:#fff;text-transform:uppercase}.toc-content{max-width:792px;width:100%}@media (min-resolution: 1.5dppx){.toc-content{max-width:735px}}.right-container .image-div{height:220px;background-color:#ccc;border-top-left-radius:12px;border-top-right-radius:12px}.right-container .image-div img{max-width:384px;width:100%;height:220px;border-top-left-radius:12px;border-top-right-radius:12px;position:relative;top:-42px}.right-container .image-div .share-container{position:relative;z-index:2;top:20px;margin-right:20px}.right-container .image-div .share-tag{font-weight:700;background-color:#000;border:1px solid #FFF;border-radius:20px;padding:6px 16px;color:#fff;cursor:pointer}.right-container .tag-div mat-icon{width:16px;height:16px;font-size:16px}.right-container .share-tag mat-icon{width:20px;height:20px;font-size:20px}.right-container .text-container{position:relative;z-index:2;height:220px;padding:16px}.right-container .right-content{position:absolute;z-index:10;top:132px;padding-bottom:1rem}.right-container .right-content-inner{background-color:#fff;border-radius:12px;width:384px;margin-bottom:1rem;box-shadow:0 2px 6px -1px #00000080,0 -4px 4px -2px #00000080}.right-container .border-bottom{border-bottom:1px solid rgba(0,0,0,.2)}.right-container .view-more{display:flex;align-items:center;text-align:center;height:40px;justify-content:center}.right-container .view-more:hover{background-color:#dcdfe5}.right-container .info-div{background-color:#fef7ed;border:none;border-radius:8px;padding:8px 12px;font-size:14px}.right-container .info-div .mat-icon{width:18px;height:18px;font-size:18px}.right-container .kpi-values{width:64px;padding:8px;text-align:center}.right-container .kpi-values .timer-icon{color:#1b4ca1;height:20px}.batch-info{padding:16px;border-radius:4px;background-color:#1b4ca114;border:1px solid rgba(27,76,161,.08);text-align:center}.batch-info .batch-label{font-size:.75rem;color:#0009;line-height:1rem}.mob-tip-for-learner{display:none}@media screen and (max-width: 1000px){.mob-tip-for-learner{display:block;width:100%;padding:0 16px;overflow:hidden;box-sizing:border-box}}.button{border-radius:64px;letter-spacing:.25px;padding:12px 36px;font-weight:700;cursor:pointer;text-align:center}@media screen and (max-width: 1200px){.right-container{display:none}.action-button:before{content:\"\";position:absolute;inset:-10px;background-color:#ffffff40;border-radius:inherit;filter:blur(10px);z-index:-1}.action-button:after{content:\"\";position:absolute;inset:-10px;box-shadow:0 0 -4px -4px #fff9;border-radius:inherit;z-index:-1}.karma-points-div{display:none}}.enroll-modal{max-width:600px!important;width:100%!important}.enroll-modal .mat-dialog-container{padding:0;border-radius:12px}.confirmation-modal{max-width:420px!important;width:100%!important}.confirmation-modal .mat-dialog-container{border-radius:12px;padding:0}.image-backdrop{background-color:#000!important;position:relative}.image-backdrop:after{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);content:\"\";display:block;position:absolute;width:100%;height:100%;top:0;left:0;background-color:#000000a6;border-top-left-radius:12px;border-top-right-radius:12px}@media screen and (max-width: 1000px){.confirmation-modal,.enroll-modal{max-width:90vw!important}}.kpi-loader-div{width:18%}a.action-button{color:#fff!important;width:auto;box-sizing:border-box;height:40px;line-height:24px!important}.rate-button{color:#1b4ca1!important;font-size:.875rem;font-weight:700;border:none!important}.rate-button .mat-button-wrapper{display:flex;gap:8px;align-items:center}.mobile-enroll-div{padding:16px;position:fixed;z-index:1000;bottom:0;width:calc(100% - 32px)}.mobile-enroll-div .action-button,.mobile-enroll-div .preenrolldone-btn{min-width:320px;max-width:400px;margin:auto}@media only screen and (max-width: 768px){.new-version-text{font-size:12px!important}.new-version-chip{padding-top:0!important}}@media screen and (min-width: 1201px){.mobile-enroll-div,.mob-share{display:none!important}.hideAbove1200{display:none}}.mobile-progress{padding:16px}@media screen and (min-width: 1200px){.mobile-progress{display:none}}.sourceEllipsis{white-space:break-spaces;position:relative;overflow:hidden;text-overflow:clip;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}.text-white{color:#fff!important}.custom-button,.fluid-width{width:100%}.toc-container{background:#fff;width:100%}mat-divider{border-top-color:#d9d9d9}.sticky{top:56px;overflow:hidden;z-index:10;width:100%}.statusMsg{border-radius:4px;height:40px}.toc-body{padding-bottom:1rem}.toc-body .toc-links{width:100%;z-index:1;border:none;background:transparent}.toc-body .toc-links .mat-tab-link{text-align:left;justify-content:flex-start}.toc-body .toc-links .mat-tab-link.justify-center{justify-content:center}.toc-body .toc-links .mat-tab-link.link-active{color:#0074b6!important}.tab:focus{outline:1px solid!important}.rounded-icon{background:#fff 0% 0% no-repeat padding-box;box-shadow:0 2px 4px #00000029;border:2px solid #00A9F4;border-radius:50%;min-width:0;opacity:1;height:35px;width:35px;padding:0;align-items:center;align-self:center;float:right}.rounded-icon mat-icon{color:#00a9f4}.blue-border{border:2px solid #0074b6!important}.hidden-xs-inline{display:inline}@media only screen and (max-width: 599px){.hidden-xs-inline{display:none}}.visible-xs-inline{display:none}@media only screen and (max-width: 599px){.visible-xs-inline{display:inline}}.meta-section{flex:1;min-width:1px}.meta-section .unit-meta-item{border-radius:2px;box-sizing:border-box;margin-bottom:16px;box-shadow:none;padding-left:0}@media only screen and (max-width: 599px){.meta-section{width:100%}}.font-bold-imp{font-weight:700!important}.info-section{width:20%;min-width:250px}.info-section .custom-button{background:#0074b6 0% 0% no-repeat padding-box!important;border-radius:4px}@media only screen and (max-width: 599px){.info-section{width:100%;margin-left:0!important}}.info-section .glance-container .at-glance-heading{letter-spacing:0px;color:#222}.info-section .glance-container .info-item .cs-icons .mat-icon{color:#666;vertical-align:middle;font-size:20px}.info-section .glance-container .info-item .cs-icons img{width:20px;height:20px;vertical-align:middle}.info-section .glance-container .info-item .item-heading{font:600 14px/21px Lato;margin:0 0 4px;letter-spacing:0px;color:#0074b6!important}.info-section .glance-container .info-item .item-value{letter-spacing:0px;color:#5f5f5f}.info-section .glance-container .info-item .item-icon{width:20px;height:20px;font-size:20px;margin-left:8px}.toc-discussion-container{display:flex;justify-content:space-between;flex-wrap:wrap-reverse}.toc-discussion-container .discussion{flex:1;min-width:1px}.toc-discussion-container .cohorts{width:100%;background:#fff 0% 0% no-repeat padding-box;border:1px solid #D9D9D9;border-radius:8px;box-shadow:none}@media only screen and (min-width: 600px) and (max-width: 959px){.toc-discussion-container .cohorts{margin-left:24px;min-width:250px}}@media only screen and (max-width: 599px){.toc-discussion-container .cohorts{margin-left:0;margin-bottom:24px;width:100%}}.mtb-xl{margin-top:3.5rem;margin-bottom:3.5rem}.detailBar{display:flex}.editDetails{margin:auto;display:flex}.white-bg{background:#fff!important;background-color:#fff!important}.contacts-container{padding:22px 0 10px;border:0;border-top:1px;border-style:solid;border-bottom:1px;border-color:#ececec}.contacts-container .contacts-head{letter-spacing:0px;color:#222;background:transparent;margin-bottom:24px}.contacts-container .author-card{min-width:291px;width:291px;display:flex;flex-direction:row;align-items:center;margin-bottom:30px;padding-right:10px}.contacts-container .author-card .right{padding:0 15px}.contacts-container .author-card .user-name{letter-spacing:0px;color:#5f5f5f}.contacts-container .author-card .user-university{letter-spacing:0px;color:#00a9f4}.contacts-container .author-card .user-button{background:#fff 0% 0% no-repeat padding-box;border:1px solid #F58634;border-radius:15px;letter-spacing:0px;color:#f58634;max-width:60px;padding:4px}.divider-transparent{border-top-color:transparent!important}.scroll-to-top{position:fixed;bottom:15px;right:15px;opacity:0;transition:all .2s ease-in-out;border-radius:50%}.scroll-to-top .icon{font-size:24px!important}.show-scroll{opacity:1;transition:all .2s ease-in-out}.sticky-breadcrumbs{position:sticky;z-index:999;top:72px;width:100%}.sticky-banner{position:sticky;z-index:999}.sticky-navs{position:sticky!important;background:#fff;z-index:999;top:auto}.actbutton{border:1px solid rgba(0,0,0,.16);border-radius:4px;padding:0 15px;width:100%;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.actbutton .mat-icon{margin-right:6px}.disable-start-btn{cursor:not-allowed!important;pointer-events:none!important;opacity:.5!important}.cb-plan-wrap{opacity:1;color:#1b4ca1;font-family:Lato-Regular;font-size:12px;font-weight:400;font-style:normal;letter-spacing:.25px;text-align:left;line-height:16px}.cb-plan-wrap .cb-danger{border-radius:2px;padding:4px 8px;border:1px solid #d13924;background-color:#d13924!important;color:#fff!important;opacity:1}.cb-plan-wrap .cb-success{padding:4px 8px;border-radius:2px;border:1px solid #1d8922;background-color:#1d8922!important;color:#fff!important;opacity:1}.cb-plan-wrap .cb-warning{padding:4px 8px;border-radius:2px;border:1px solid #ef951e;background-color:#ef951e!important;color:#fff!important;opacity:1}.bg-white{background-color:#fff}.provider-logo-div{border-radius:4px;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.provider-logo-div img{display:flex;border-radius:4px;width:40px;height:40px;padding:4px}.location-details{background-color:#1b4ca114;padding:16px;border-radius:4px}.location-details .location-icon,.location-details .event-icon{color:#1b4ca1;height:20px;width:14px;font-size:22px}.location-details .loc-desc{font-family:Lato;font-weight:700;font-size:14px;line-height:20px;letter-spacing:.25}.location-details .mat-icon{overflow:visible!important}.batch-timer .underline{border-top:1.5px solid rgba(0,0,0,.16);margin:16px 0}.batch-timer .timer-label{font-size:12px;padding:4px 8px;border:1px solid rgba(0,0,0,.16);border-radius:16px;color:#000000de}.batch-timer .counter{color:#000000de}.batch-timer .counter-label{color:#0006;text-transform:uppercase;font-size:12px;line-height:16px}.relevent-wrapper{background:#1b4ca129;border-radius:12px}.relevent-wrapper .relevent-info{max-width:400px;margin-right:auto}.relevent-wrapper .relevent-info .relevent-heading{font-family:Montserrat;line-height:17.07px;font-weight:600;color:#000!important}.relevent-wrapper .relevent-info .relevent-subinfo{font-family:Lato;line-height:16.8px;color:#545454}.relevent-normal.relevent-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#276de5;background-color:#fff;border-radius:21px;text-decoration:none;overflow:hidden;transition:all .3s ease-in-out}.relevent-normal.relevent-btn:hover{box-shadow:0 1px 10px #276de599}.relevent-normal.relevent-btn{cursor:pointer}.relevent-normal.relevent-btn:before{content:\"\";position:absolute;inset:0;padding:2px 2.5px;border-radius:21px;background:linear-gradient(89.96deg,#f3962f .04%,#276de5 99.96%);-webkit-mask:linear-gradient(white,white) content-box,linear-gradient(white,white);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s ease-in-out;cursor:pointer}.relevent-normal.relevent-btn:hover:before{opacity:1}.relevant-container{width:max-content}.no-button{opacity:1;transform:scale(1);transition:opacity .3s ease-in-out,transform .3s ease-in-out;color:#1b4ca1;cursor:pointer}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom{background:transparent;border:1px solid #fff;color:#fff!important;cursor:pointer;margin:0!important}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom mat-icon{color:#fff!important}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom mat-icon:hover{color:#1b4ca1!important}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom:hover,.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom.mat-chip-selected{background:#fff!important;border:1px solid #fff;color:#1b4ca1!important}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom:hover mat-icon,.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom.mat-chip-selected mat-icon{color:#1b4ca1!important}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom:after{opacity:0!important;background:transparent}.new-version-chip{gap:10px;padding:2px 8px;background-color:#f3962f;cursor:pointer;position:relative;overflow:hidden}.new-version-chip:before{content:\"\";position:absolute;top:0;left:-100%;width:25%;height:100%;background:linear-gradient(314deg,transparent,rgba(213,210,210,.6),transparent);animation:shimmer 1s infinite}.new-version-chip .new-version-text{font-family:Lato;font-weight:400;font-size:20px;line-height:100%}.btn-switch{font-family:Lato,sans-serif;font-size:14px;font-weight:700;font-style:normal;letter-spacing:.5px;text-align:center;line-height:20px;background:#fff;border-radius:64px;padding:8px 16px;border:none;border:1px solid rgb(243,150,47);color:#f3962f;background:#ef951e29!important}@keyframes shimmer{0%{left:-100%}to{left:100%}}.knowledge-level-container{margin-left:auto}.level-badge{display:inline-flex;height:24px;padding:2px 8px;align-items:center;gap:4px;flex-shrink:0;border-radius:12px;font-weight:600;font-size:12px;line-height:16px;white-space:nowrap}.level-badge.beginner{border:1px solid #49C951;background:linear-gradient(0deg,#49c95133 0% 100%),#fff;color:#2f8132;border-radius:16px}.level-badge.intermediate{border:1px solid #1B4CA1;background:linear-gradient(0deg,#1b4ca133 0% 100%),#fff;color:#1b4ca1;border-radius:16px}.level-badge.advanced{border:1px solid #FF8268;background:linear-gradient(0deg,#ff826833 0% 100%),#fff;color:#ff4b25;border-radius:16px}.level-badge svg{flex-shrink:0}\n"], dependencies: [{ kind: "directive", type: i21.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i21.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i21.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i21.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i21.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i22.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i23.MatLegacyButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i24.MatLegacyMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "directive", type: i24.MatLegacyMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i25.MatLegacyChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i25.MatLegacyChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i26.MatLegacyRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i26.MatLegacyRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { kind: "component", type: i27.SkeletonLoaderComponent, selector: "ws-widget-skeleton-loader", inputs: ["bindingClass", "height", "width"] }, { kind: "component", type: i28.ContentProgressComponent, selector: "ws-widget-content-progress", inputs: ["contentId", "progress", "progressType", "forPreview", "className", "customClassName"] }, { kind: "component", type: i29.AvatarPhotoComponent, selector: "ws-widget-avatar-photo", inputs: ["datalen", "photoUrl", "name", "size", "randomColor", "initials", "showBadge"] }, { kind: "component", type: i30.ContentTocComponent, selector: "ws-widget-content-toc", inputs: ["content", "contentReadData", "initialRouteData", "changeTab", "baseContentReadData", "forPreview", "contentTabFlag", "resumeData", "batchData", "skeletonLoader", "tocStructure", "pathSet", "fromViewer", "hierarchyMapData", "condition", "kparray", "selectedBatchData", "config", "componentName", "isEnrolled", "playResourceId", "sideNavBarOpened", "languageList", "lockCertificate", "fromMDO"], outputs: ["playResumeForAI", "enrollUserToAI", "trigerCompletionSurveyForm", "resumeContent"] }, { kind: "component", type: i31.ShareTocComponent, selector: "ws-app-share-toc", inputs: ["rootOrgId", "content", "contentLink", "baseContentReadData"], outputs: ["resetEnableShare"] }, { kind: "component", type: i32.TocKpiValuesComponent, selector: "ws-widget-toc-kpi-values", inputs: ["tocStructure", "content", "contentReadData", "isMobile", "showInstructorLedMsg", "baseContentReadData", "languageList"] }, { kind: "component", type: i33.KarmaPointsComponent, selector: "ws-widget-karma-points", inputs: ["content", "data", "pCategory", "condition", "btnCategory"], outputs: ["clickClaimKarmaPoints"] }, { kind: "component", type: i34.TipsForLearnerCardComponent, selector: "ws-widget-tips-for-learner-card", inputs: ["learnAdvisoryData"] }, { kind: "component", type: i35.AppTocBannerComponent, selector: "ws-app-toc-banner", inputs: ["banners", "content", "resumeData", "analytics", "forPreview", "batchData", "userEnrollmentList", "contentReadData", "clickToShare"], outputs: ["withdrawOrEnroll", "programEnrollCall"] }, { kind: "pipe", type: i21.SlicePipe, name: "slice" }, { kind: "pipe", type: i21.DatePipe, name: "date" }, { kind: "pipe", type: i4.PipeCountTransformPipe, name: "pipeCountTransform" }, { kind: "pipe", type: i13.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
2972
+ }
2973
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AppTocHomeV2Component, decorators: [{
2974
+ type: Component,
2975
+ args: [{ selector: 'ws-app-app-toc-home-v2', encapsulation: ViewEncapsulation.None, template: "<ng-container *ngIf=\"courseID else noDataFound\">\n <ng-template #enrollFunctionality>\n <div [hidden]=\"isResource && !content?.artifactUrl?.length\" class=\"flex flex-col gap-4 text-center\">\n <!-- Course block -->\n <ng-container *ngIf=\"contentReadData?.primaryCategory !== primaryCategory.PROGRAM\n && contentReadData?.primaryCategory !== primaryCategory.CURATED_PROGRAM\n && contentReadData?.primaryCategory !== primaryCategory.STANDALONE_ASSESSMENT &&\n contentReadData?.primaryCategory !== primaryCategory.BLENDED_PROGRAM\">\n <ng-container *ngIf=\"(actionBtnStatus === 'grant' && !(isMobile && content?.isInIntranet) &&\n !(contentReadData?.primaryCategory === primaryCategory.COURSE && content?.children.length === 0 &&\n !content?.artifactUrl?.length) &&\n !(contentReadData?.primaryCategory === primaryCategory.COURSE && !batchData?.enrolled) &&\n !(contentReadData?.primaryCategory === primaryCategory.RESOURCE && !content?.artifactUrl) &&\n !(contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL)) &&\n !(contentReadData?.primaryCategory === primaryCategory.PROGRAM && currentCourseBatchId)\">\n <a *ngIf=\"showStart.show && !isPostAssessment && !forPreview\" (click)=\"raiseTelemetryForPublic()\"\n [routerLink]=\"(resumeData && !certData) ? resumeDataLink?.url : firstResourceLink?.url\"\n [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\"\n class=\"flex action-button justify-center\">\n <ng-container *ngIf=\"(!content?.completionPercentage || content?.completionPercentage < 100) && !certData\">\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">\n {{ translateLabels('resume', 'apptochome') }}\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"content?.completionPercentage === 100 || certData\">\n {{ content?.completionPercentage >= 100 ? translateLabels('Start again', 'apptochome') :\n translateLabels('resume', 'apptochome') }}\n </ng-container>\n </a>\n\n <button *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\" (click)=\"raiseTelemetryForPublic()\"\n [routerLink]=\"firstResourceLink?.url\" class=\"flex action-button justify-center\">\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">{{ 'apptochome.takeAssessment' | translate\n }}</ng-container>\n </button>\n\n <!-- <div\n *ngIf=\"!isPostAssessment && (!content?.completionPercentage || content?.completionPercentage < 100) && !certData\">\n <ng-container *ngIf=\"isAcbpClaim\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container>\n <ng-container *ngIf=\"!isAcbpClaim && !monthlyCapExceed\">\n <ws-app-karmapoints-panel [btntype]=\"'Resume'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container>\n </div> -->\n\n <!-- <div *ngIf=\"!isPostAssessment && (content?.completionPercentage === 100 || certData)\">\n <div *ngIf=\"isAcbpCourse && isAcbpClaim && !isClaimed\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP CLAIM'\" [data]=\"kparray\" [btnCategory]=\"'claim'\"\n (clickClaimKarmaPoints)=\"onClickOfClaim($event)\"></ws-app-karmapoints-panel>\n </div>\n <div *ngIf=\"!isAcbpCourse && !monthlyCapExceed\">\n <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div>\n <div *ngIf=\"!isAcbpCourse && monthlyCapExceed && !isCompletedThisMonth\">\n <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div>\n </div> -->\n\n <!-- <div *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\">\n <ws-app-karmapoints-panel [btntype]=\"'Take Assessment'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div> -->\n </ng-container>\n\n <ng-container *ngIf=\" (actionBtnStatus === 'grant' && !(isMobile && content?.isInIntranet) &&\n !( contentReadData?.primaryCategory === primaryCategory.COURSE && content?.children.length === 0 && !content?.artifactUrl?.length ) &&\n !( contentReadData?.primaryCategory === primaryCategory.COURSE && batchData?.enrolled ) &&\n !(contentReadData?.primaryCategory === primaryCategory.RESOURCE && !content?.artifactUrl)) &&\n !(contentReadData?.primaryCategory === primaryCategory.PROGRAM) &&\n !(contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL)\">\n <ng-container *ngIf=\"contentReadData?.primaryCategory !== primaryCategory.RESOURCE && !enrollBtnLoading\">\n <a class=\"flex action-button justify-center resume\" *ngIf=\"!forPreview || isInIFrame\"\n (click)=\"handleEnrollment()\" [ngClass]=\"{'disable-start-btn': !canEnroll()}\">\n <ng-container>\n {{ 'apptochome.enroll' | translate }}\n </ng-container>\n </a>\n <!-- <ng-container *ngIf=\"isAcbpCourse\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container> -->\n <!-- <ng-container *ngIf=\"!isAcbpCourse && !monthlyCapExceed && userEnrollmentList && !userEnrollmentList.length\">\n <ws-app-karmapoints-panel [btntype]=\"'Enroll'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container> -->\n </ng-container>\n </ng-container>\n </ng-container>\n\n\n <!-- PRogram & mandatory course block -->\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authViewBtn\">\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.PROGRAM || contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL\">\n <ng-container\n *ngIf=\"(courseCategory?.MODERATED_PROGRAM === contentReadData?.courseCategory) && (contentReadData?.batches && !batchData?.enrolled)\">\n <ng-container\n *ngIf=\"((contentReadData?.primaryCategory !== primaryCategory.RESOURCE) && !enrollBtnLoading) && !contentReadData?.batches[0].endDate\">\n <a class=\"flex action-button justify-center resume\" (click)=\"handleEnrollment()\">\n <ng-container *ngIf=\"!forPreview || isInIFrame\">\n {{'apptochome.enroll' | translate}}\n </ng-container>\n </a>\n <!-- <ng-container *ngIf=\"isAcbpCourse\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container>\n <ng-container *ngIf=\"!isAcbpCourse && !monthlyCapExceed && userEnrollmentList && !userEnrollmentList.length\">\n <ws-app-karmapoints-panel [btntype]=\"'Enroll'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container> -->\n </ng-container>\n <ng-container *ngIf=\"!forPreview || isInIFrame\">\n <ng-container\n *ngIf=\"((contentReadData?.primaryCategory !== primaryCategory.RESOURCE) && !enrollBtnLoading) && contentReadData?.batches[0].endDate\">\n <ws-app-toc-banner role=\"banner\" [banners]=\"banners\" [forPreview]=\"forPreview\" [content]=\"content\"\n [userEnrollmentList]=\"userEnrollmentList\" [analytics]=\"analytics\"\n (programEnrollCall)=\"programEnrollCall($event)\" [resumeData]=\"resumeData\" [batchData]=\"batchData\"\n [contentReadData]=\"contentReadData\">\n </ws-app-toc-banner>\n </ng-container>\n </ng-container>\n </ng-container>\n <ng-container\n *ngIf=\"(courseCategory?.MODERATED_PROGRAM === contentReadData?.courseCategory) && !contentReadData?.batches && !batchData?.enrolled && !enrollBtnLoading\">\n No Batches\n </ng-container>\n <ng-container\n *ngIf=\"courseCategory?.MODERATED_PROGRAM !== contentReadData?.courseCategory && !enrollBtnLoading\">\n <ng-container\n *ngIf=\"!(contentReadData?.primaryCategory === primaryCategory.PROGRAM && currentCourseBatchId) && contentReadData?.primaryCategory !== primaryCategory.MANDATORY_COURSE_GOAL\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.youAreNotInvited' | translate }} </span>\n </ng-container>\n <ng-container *ngIf=\"!isBatchInProgress && !!currentCourseBatchId && getStartDate === 'NA'\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.noActiveBatches' | translate }}</span>\n </ng-container>\n <ng-container *ngIf=\"!isBatchInProgress && currentCourseBatchId && getStartDate !== 'NA'\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.batchWillStart' | translate }}\n {{getStartDate}}!</span>\n </ng-container>\n </ng-container>\n <ng-container\n *ngIf=\"!isBatchInProgress && courseCategory?.MODERATED_PROGRAM === contentReadData?.courseCategory && !enrollBtnLoading\">\n <ng-container *ngIf=\"!isBatchInProgress && currentCourseBatchId && getStartDate !== 'NA'\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.batchWillStart' | translate }}\n {{getStartDate}}!</span>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"isBatchInProgress &&\n ( actionBtnStatus === 'grant' &&\n !(isMobile && content?.isInIntranet) &&\n (contentReadData?.primaryCategory === primaryCategory.PROGRAM && currentCourseBatchId) ||\n (contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL && currentCourseBatchId)\n )\">\n <a *ngIf=\"showStart.show && !isPostAssessment\"\n [routerLink]=\"resumeData ? resumeDataLink?.url : firstResourceLink?.url\"\n [queryParams]=\"resumeData ? generateQuery('RESUME') : generateQuery('START')\"\n class=\"flex action-button justify-center resume\">\n <ng-container *ngIf=\"!content?.completionPercentage || content?.completionPercentage < 100\">\n <ng-container *ngIf=\"!forPreview || isInIFrame\">\n {{ resumeData && (content?.completionPercentage < 100 && content?.completionPercentage> 0) ?\n translateLabels('resume', 'apptochome') :\n translateLabels('start', 'apptochome') }}\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"content?.completionPercentage === 100\">\n {{ (resumeData) || content?.completionPercentage === 100 ? \"Start again\" : \"Start\" }}\n </ng-container>\n </a>\n <a *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\" [routerLink]=\"firstResourceLink?.url\"\n class=\"flex action-button justify-center resume\">\n <ng-container *ngIf=\"!forPreview || isInIFrame\">{{ 'apptochome.takeAssessment' | translate\n }}</ng-container>\n </a>\n <!-- <div *ngIf=\"!isPostAssessment && (!content?.completionPercentage || content?.completionPercentage < 100)\">\n <ng-container *ngIf=\"isAcbpClaim\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container>\n <ng-container *ngIf=\"!isAcbpClaim && !monthlyCapExceed\">\n <ws-app-karmapoints-panel [btntype]=\"'Resume'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </ng-container>\n </div> -->\n <!-- <div *ngIf=\"!isPostAssessment && (content?.completionPercentage === 100)\">\n <div *ngIf=\"isAcbpCourse && isAcbpClaim && !isClaimed\">\n <ws-app-karmapoints-panel [btntype]=\"'ACBP CLAIM'\" [condition]=\"{isPostAssessment: isPostAssessment, content: content, isAcbpCourse: isAcbpCourse, isClaimed: isClaimed, monthlyCapExceed: monthlyCapExceed, isCompletedThisMonth: isCompletedThisMonth, showTakeAssessment: showTakeAssessment, userEnrollmentList: userEnrollmentList, isCompletedThisMonth: isCompletedThisMonth, resumeData: resumeData, userRating: userRating}\" [data]=\"kparray\" [btnCategory]=\"'claim'\"\n (clickClaimKarmaPoints)=\"onClickOfClaim($event)\"></ws-app-karmapoints-panel>\n </div>\n <div *ngIf=\"!isAcbpCourse && !monthlyCapExceed\">\n <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div>\n <div *ngIf=\"!isAcbpCourse && monthlyCapExceed && !isCompletedThisMonth\">\n <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div>\n </div>\n <div *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\">\n <ws-app-karmapoints-panel [btntype]=\"'Take Assessment'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n </div> -->\n </ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container\n *ngIf=\"isBatchInProgress && (contentReadData?.primaryCategory === primaryCategory.CURATED_PROGRAM && batchData?.enrolled) && !enrollBtnLoading\">\n <a *ngIf=\"showStart.show && !isPostAssessment\" (click)=\"raiseTelemetryForPublic()\"\n [routerLink]=\"resumeData ? resumeDataLink?.url : firstResourceLink?.url\"\n [queryParams]=\"resumeData ? generateQuery('RESUME') : generateQuery('START')\"\n class=\"flex action-button justify-center resume\">\n <ng-container *ngIf=\"!content?.completionPercentage || content?.completionPercentage < 100\">\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">\n {{ resumeData && (content?.completionPercentage < 100 && content?.completionPercentage> 0) ?\n translateLabels('resume', 'apptochome') :\n translateLabels('resume', 'apptochome') }}\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"content?.completionPercentage === 100\">\n {{ resumeData || content?.completionPercentage === 100 ? translateLabels('Start again', 'apptochome') :\n translateLabels('resume', 'apptochome') }}\n </ng-container>\n </a>\n </ng-container>\n\n <ng-container *ngIf=\"enrollBtnLoading\">\n <ws-widget-skeleton-loader [width]=\"'100%'\" [height]=\"'36px'\"\n [bindingClass]=\"'flex rounded h-8'\"></ws-widget-skeleton-loader>\n </ng-container>\n\n <!-- Curated program block -->\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.CURATED_PROGRAM && !batchData?.enrolled && !enrollBtnLoading\">\n <a class=\"flex action-button justify-center resume\" *ngIf=\"!forPreview || isInIFrame\"\n (click)=\"handleEnrollment()\">\n <ng-container>\n {{ 'apptochome.enroll' | translate }}\n </ng-container>\n </a>\n </ng-container>\n <!-- STANDALONE_ASSESSMENT black -->\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && !batchData?.enrolled && !enrollBtnLoading && contentReadData?.courseCategory !== 'Invite-Only Assessment'\">\n <a class=\"flex action-button justify-center resume\" (click)=\"handleEnrollment()\"\n *ngIf=\"!forPreview || isInIFrame\">\n <ng-container>\n {{ 'apptochome.enroll' | translate }}\n </ng-container>\n </a>\n </ng-container>\n <!-- INVITE ONLY STANDALONE ASSESSMENT block-->\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && !batchData?.enrolled && !enrollBtnLoading && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authViewForInviteOnlyAssessment\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.youAreNotInvitedForAssessment' | translate }}\n </span>\n </ng-container>\n </ng-container>\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && batchData?.enrolled && isBatchInProgress && !enrollBtnLoading && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n <a class=\"flex action-button justify-center resume\" [routerLink]=\"firstResourceLink?.url\"\n [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\">\n <ng-container *ngIf=\"content?.completionPercentage === 100\">{{ 'apptochome.takeTestAgain' | translate\n }}</ng-container>\n <ng-container *ngIf=\"content?.completionPercentage < 100\">{{ 'apptochome.takeTest' | translate\n }}</ng-container>\n </a>\n </ng-container>\n <ng-container\n *ngIf=\"!isBatchInProgress && !!currentCourseBatchId && getStartDate === 'NA' && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.noActiveBatches' | translate }}</span>\n </ng-container>\n <ng-container\n *ngIf=\"!isBatchInProgress && currentCourseBatchId && getStartDate !== 'NA' && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.batchWillStart' | translate }}\n {{getStartDate}}!</span>\n </ng-container>\n\n <!-- STANDALONE_ASSESSMENT enrolled black -->\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && batchData?.enrolled && !enrollBtnLoading && contentReadData?.courseCategory !== 'Invite-Only Assessment'\">\n <a class=\"flex action-button justify-center resume\" [routerLink]=\"firstResourceLink?.url\"\n [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\">\n <ng-container *ngIf=\"content?.completionPercentage === 100\">{{ 'apptochome.takeTestAgain' | translate\n }}</ng-container>\n <ng-container *ngIf=\"content?.completionPercentage < 100\">{{ 'apptochome.takeTest' | translate\n }}</ng-container>\n </a>\n </ng-container>\n <!-- BLENDED_PROGRAM block -->\n <ng-container *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM\">\n\n <ng-container *ngIf=\"batchData?.workFlow?.wfInitiated &&\n !(batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.APPROVED ||\n batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.REJECTED ||\n batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.WITHDRAWN ||\n batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.REMOVED)\">\n <div class=\"ws-mat-accent-text ws-mat-accent-light-bg flex items-center justify-center statusMsg\">\n <p class=\"margin-remove-bottom font-bold\">\n {{ 'apptochome.requestUnderReview' | translate }}\n </p>\n </div>\n </ng-container>\n <ng-container>\n <a *ngIf=\"showStart.show && batchData?.workFlow?.wfInitiated && batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.APPROVED\"\n [routerLink]=\"isBatchInProgress? (resumeData && !certData) ? resumeDataLink?.url : firstResourceLink?.url : '' \"\n (click)=\"raiseTelemetryForPublic()\"\n [queryParams]=\"isBatchInProgress ? (resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START') : '' \"\n class=\"flex action-button justify-center resume\" [ngClass]=\"{'disable-start-btn': !isBatchInProgress}\">\n <ng-container *ngIf=\"(!content?.completionPercentage || content?.completionPercentage < 100) && !certData\">\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">\n {{ resumeData && (content?.completionPercentage < 100 && content?.completionPercentage> 0) ?\n translateLabels('resume', 'apptochome') :\n translateLabels('start', 'apptochome') }}\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"content?.completionPercentage === 100 || certData\">\n {{ resumeData || content?.completionPercentage === 100 ? translateLabels('Start again', 'apptochome') :\n translateLabels('start', 'apptochome') }}\n </ng-container>\n </a>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"actionBtnStatus == 'reject' && content?.registrationUrl\">\n <a [href]=\"content?.registrationUrl\" target=\"_blank\" class=\"flex action-button justify-center\">{{\n 'apptochome.register' | translate }}</a>\n </ng-container>\n\n </div>\n </ng-template>\n\n <ng-template #progressFunctionality>\n <div class=\"flex flex-row gap-4\">\n <div class=\"flex-1\">\n <div class=\"flex flex-col gap-2\">\n <div class=\"flex flex-row gap-4 text-sm\">\n <div class=\"flex-1 text-xs\">{{ 'apptocsinglepage.overallProgress' | translate }}</div>\n <div class=\"text-xs\" *ngIf=\"content?.completionPercentage > 0\"> {{ content?.completionPercentage }} %</div>\n </div>\n <ws-widget-content-progress *ngIf=\"content?.identifier\" [forPreview]=\"forPreview\"\n [contentId]=\"content?.identifier\" [progress]=\"content?.completionPercentage\" [progressType]=\"'percentage'\"\n [customClassName]=\"'content-progress'\">\n </ws-widget-content-progress>\n </div>\n </div>\n\n <ng-container *ngIf=\"contentCompletionPercent >= 50\">\n <button mat-stroked-button color=\"accent\" type=\"button\" class=\"rate-button\"\n (click)=\"openFeedbackDialog(content)\">\n <mat-icon class=\"nodtranslate\">star_purple500</mat-icon>\n <ng-container *ngIf=\"!userRating\">\n <div>{{ 'apptocsinglepage.rateNow' | translate }}</div>\n </ng-container>\n <ng-container *ngIf=\"userRating\">\n <div>{{ 'apptocsinglepage.editRating' | translate }}</div>\n </ng-container>\n </button>\n </ng-container>\n </div>\n </ng-template>\n\n <div class=\"toc-banner\">\n <div class=\"flex flex-row gap-6 fixed-width\">\n <div class=\"banner-details toc-content\" #bannerDetails>\n <div class=\"flex flex-col gap-4\">\n <div class=\"mobile-back-btn\" (click)=\"goBack()\">\n <mat-icon class=\"text-white\">arrow_back</mat-icon>\n </div>\n <div class=\"flex items-center justify-between gap-4\">\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'132px'\" [height]=\"'32px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'140px'\" [height]=\"'24px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n </ng-container>\n\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"flex flex-row gap-2\">\n <div class=\"flex flex-row tag-div rounded-2xl gap-1 items-center p-2\">\n <mat-icon class=\"ws-mat-orange-text nodtranslate\">video_library</mat-icon>\n <ng-container *ngIf=\"contentReadData?.courseCategory\">\n <div class=\"text-xs font-bold text-white leading-3 nodtranslate\">{{\n translateLabel(contentReadData?.courseCategory, 'searchfilters') }}</div>\n </ng-container>\n <ng-container *ngIf=\"!contentReadData?.courseCategory\">\n <div class=\"text-xs font-bold text-white leading-3 nodtranslate\">{{\n translateLabel(contentReadData?.primaryCategory, 'searchfilters') }}</div>\n </ng-container>\n </div>\n <div class=\"flex flex-row tag-div rounded-2xl gap-1 items-center p-2\"\n *ngIf=\"contentReadData?.additionalTags?.includes('iGOT Specialization')\">\n <img class=\"approved-icon\" src=\"./assets/icons/approved.svg\" alt=\"approved\">\n <div class=\"text-xs font-bold text-white leading-3 nodtranslate\">{{\n 'cardcontentv2.iGOTSpecializationProgram' | translate }}</div>\n </div>\n <!-- Knowledge level block for search box -->\n <!-- {{content?.difficultyLevel}} -->\n <div *ngIf=\"contentReadData?.difficultyLevel\" class=\"knowledge-level-container\">\n <span *ngIf=\"contentReadData?.difficultyLevel?.toLowerCase() === 'beginner'\"\n class=\"level-badge beginner\">\n <!-- <span *ngIf=\"false\" class=\"level-badge beginner\"> -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\">\n <rect width=\"16\" height=\"16\" fill=\"#DBF4DC\" />\n <path\n d=\"M7.42267 5C7.67927 4.55555 8.32077 4.55556 8.57737 5L12.0415 11C12.2981 11.4444 11.9773 12 11.4641 12H4.53592C4.02272 12 3.70197 11.4444 3.95857 11L7.42267 5Z\"\n fill=\"#49C951\" />\n </svg>\n {{contentReadData?.difficultyLevel}}\n </span>\n <span *ngIf=\"contentReadData?.difficultyLevel?.toLowerCase() === 'intermediate'\"\n class=\"level-badge intermediate\">\n <!-- <span *ngIf=\"true\" class=\"level-badge intermediate\"> -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\">\n <rect width=\"16\" height=\"16\" fill=\"#D1DBEC\" />\n <path\n d=\"M7.42267 2.66666C7.67927 2.22221 8.32077 2.22221 8.57737 2.66666L12.0415 8.66666C12.2981 9.1111 11.9773 9.66666 11.4641 9.66666H4.53592C4.02272 9.66666 3.70197 9.1111 3.95857 8.66666L7.42267 2.66666Z\"\n fill=\"#1B4CA1\" />\n <path\n d=\"M7.42267 5.66666C7.67927 5.22221 8.32077 5.22221 8.57737 5.66666L12.0415 11.6667C12.2981 12.1111 11.9773 12.6667 11.4641 12.6667H4.53592C4.02272 12.6667 3.70197 12.1111 3.95857 11.6667L7.42267 5.66666Z\"\n fill=\"#1B4CA1\" stroke=\"#D1DBEC\" stroke-width=\"0.5\" />\n </svg>\n {{contentReadData?.difficultyLevel}}\n </span>\n <span *ngIf=\"contentReadData?.difficultyLevel?.toLowerCase() === 'advanced'\"\n class=\"level-badge advanced\">\n <!-- <span *ngIf=\"false\" class=\"level-badge advanced\"> -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\">\n <g clip-path=\"url(#clip0)\">\n <rect width=\"16\" height=\"16\" fill=\"#FFE6E1\" />\n <path\n d=\"M7.42264 2.33334C7.67924 1.8889 8.32074 1.8889 8.57734 2.33334L12.0414 8.33334C12.298 8.77779 11.9773 9.33334 11.4641 9.33334H4.53589C4.02269 9.33334 3.70194 8.77779 3.95854 8.33334L7.42264 2.33334Z\"\n fill=\"#FF8268\" />\n <path\n d=\"M7.42264 5C7.67924 4.55555 8.32074 4.55556 8.57734 5L12.0414 11C12.298 11.4444 11.9773 12 11.4641 12H4.53589C4.02269 12 3.70194 11.4444 3.95854 11L7.42264 5Z\"\n fill=\"#FF8268\" stroke=\"#FFE6E1\" stroke-width=\"0.5\" />\n <path\n d=\"M7.42264 7.66669C7.67924 7.22224 8.32074 7.22224 8.57734 7.66669L12.0414 13.6667C12.298 14.1111 11.9773 14.6667 11.4641 14.6667H4.53589C4.02269 14.6667 3.70194 14.1111 3.95854 13.6667L7.42264 7.66669Z\"\n fill=\"#FF8268\" stroke=\"#FFE6E1\" stroke-width=\"0.5\" />\n </g>\n <defs>\n <clipPath id=\"clip0\">\n <rect width=\"16\" height=\"16\" fill=\"white\" />\n </clipPath>\n </defs>\n </svg>\n {{contentReadData?.difficultyLevel}}\n </span>\n </div>\n\n <div class=\"flex items-center\" *ngIf=\"cbPlanEndDate\">\n <div class=\"flex items-center due-tag text-xs leading-3\"\n [ngClass]=\"{'due-warning': cbPlanDuration === nsCardContentData.UPCOMING, 'due-overdue': cbPlanDuration === nsCardContentData.OVERDUE, 'due-success': cbPlanDuration === nsCardContentData.SUCCESS}\">\n {{ 'common.dueBy' | translate }} - &nbsp;<span class=\"font-bold\">{{ cbPlanEndDate | date: 'd\n MMM,y'}}</span>\n </div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!skeletonLoader && contentReadData?.contentVersionInfo?.identifier\">\n <div class=\"new-version-chip rounded-2xl\" (click)=\"navigateToNewVersion()\"\n (keydown)=\"navigateToNewVersion()\">\n <span class=\"new-version-text nodtranslate\">{{ 'apptoc.newVersion' | translate }}</span>\n </div>\n </ng-container>\n <div class=\"flex items-center text-white mob-share\" *ngIf=\"canShare\">\n <mat-icon class=\"nodtranslate\" (click)=\"onClickOfShare()\">share</mat-icon>\n </div>\n </div>\n <div class=\"flex flex-col gap-2\">\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'90%'\" [height]=\"'32px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'70%'\" [height]=\"'32px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n </ng-container>\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"banner-text text-base sm:text-4xl leading-6 sm:leading-10 font-bold nodtranslate\">{{\n handleCapitalize(contentReadData?.name) }}</div>\n <div class=\"text-sm sm:text-base source-text font-semibold break-words nodtranslate\" #contentSource\n [ngClass]=\"{'sourceEllipsis': sourceEllipsis}\" title=\"{{contentReadData?.source}}\">{{ 'cardcontentv2.by'\n | translate }} {{ contentReadData?.source }}</div>\n </ng-container>\n </div>\n\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'120px'\" [height]=\"'40px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'88px'\" [height]=\"'24px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n </ng-container>\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"flex gap-4 items-center\">\n <div class=\"flex flex-row rating-chip py-2 items-center cursor-pointer\"\n (click)=\"handleNavigateToReviews()\" *ngIf=\"content?.averageRating\">\n <div class=\"flex flex-row gap-1 margin-left-s items-center\">\n <mat-icon class=\"nodtranslate\">grade</mat-icon>\n <div class=\"text-white text-sm leading-4\">{{ content?.averageRating }}</div>\n </div>\n <div class=\"separator\"></div>\n <div class=\"text-white text-sm leading-4 margin-right-m\">{{ content?.totalRating | pipeCountTransform }}\n </div>\n </div>\n <div class=\"flex items-center\" *ngIf=\"content?.additionalTags?.length\">\n <div class=\"most-enrolled-chip text-xs leading-3\">\n <span *ngIf=\"content?.additionalTags?.includes('mostTrending')\">{{ 'cardcontentv2.mostTrending' |\n translate }}</span>\n <span *ngIf=\"content?.additionalTags?.includes('mostEnrolled')\">{{ 'cardcontentv2.mostEnrolled' |\n translate }}</span>\n </div>\n </div>\n <div class=\"flex items-center\" *ngIf=\"contentReadData?.retirementDate\">\n <div class=\"new-version-pill text-xs leading-3\" *ngIf=\"contentReadData?.status !== 'Retired'\">\n <span>{{ 'apptoc.pendingRetirement' | translate }}</span>\n </div>\n <div class=\"new-version-retire-pill text-xs leading-3\" *ngIf=\"contentReadData?.status === 'Retired'\">\n <span>{{ 'apptoc.retired' | translate }}</span>\n </div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'180px'\" [height]=\"'20px'\"\n [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n </ng-container>\n <ng-container *ngIf=\"!skeletonLoader && contentReadData?.sYS_INTERNAL_LAST_UPDATED_ON\">\n <div class=\"text-xs leading-4 source-text nodtranslate\">({{ 'apptoc.lastUpdatedOn' | translate }} {{\n contentReadData?.sYS_INTERNAL_LAST_UPDATED_ON | date: 'MMM d, y' }})</div>\n </ng-container>\n <ng-container>\n <div class=\"flex flex-row gap-2\" *ngIf=\"languageList?.length > 1\">\n <mat-chip-list class=\"lang-chips\">\n <!-- Show up to 6 chips -->\n <ng-container *ngFor=\"let lang of languageList | slice:0:5; let i = index\">\n <mat-chip class=\"matchip-custom\" selectable=\"true\"\n [selected]=\"lang?.identifier === selectedLanguage?.identifier\" (click)=\"onLanguageSelect(lang)\">\n {{ lang.name || lang.value }}\n </mat-chip>\n </ng-container>\n\n <!-- \"More\" chip if there are more than 6 languages -->\n <ng-container *ngIf=\"languageList.length > 5\">\n <mat-chip [matMenuTriggerFor]=\"moreLanguagesMenu\" selectable=\"false\" class=\"more-chip matchip-custom\"\n [selected]=\"isSelectedInMoreDropdown()\">\n More <mat-icon class=\"mat-icon\">keyboard_arrow_down</mat-icon>\n </mat-chip>\n <mat-menu #moreLanguagesMenu=\"matMenu\">\n <mat-radio-group class=\"mat-radio-group flex flex-col gap-2 p-3\" [value]=\"selectedLanguage\">\n <mat-radio-button *ngFor=\"let lang of languageList | slice:5\" [value]=\"lang\"\n [checked]=\"lang?.identifier === selectedLanguage?.identifier\" (change)=\"onLanguageSelect(lang)\">\n {{ lang.displayName || lang.name || lang }}\n </mat-radio-button>\n </mat-radio-group>\n </mat-menu>\n </ng-container>\n </mat-chip-list>\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"flex flex-row gap-6 fixed-width\">\n <div class=\"toc-content\">\n <ng-container *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM &&\n selectedBatchData?.content[0]?.batchAttributes?.batchLocationDetails &&\n selectedBatchData?.content[0]?.enrollmentEndDate\">\n <div class=\"location-details mt-6\">\n <div class=\"flex items-center gap-4 pb-3\">\n <mat-icon class=\"location-icon nodtranslate\">\n location_on\n </mat-icon>\n <div class=\"loc-desc\">\n {{selectedBatchData?.content[0]?.batchAttributes?.batchLocationDetails}}\n </div>\n </div>\n <div class=\"flex items-center gap-4\">\n <mat-icon class=\"event-icon nodtranslate\">\n event</mat-icon>\n <div class=\"loc-desc\">\n Last date of enrollment - {{selectedBatchData?.content[0]?.enrollmentEndDate | date: 'dd/MM/yyyy'}}\n </div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"recommendedCoursesId && !feedbackGiven\">\n <div class=\"px-4 py-3 mt-6 relevent-wrapper\">\n <div class=\"flex gap-4 items-center flex-wrap flex justify-center md:justify-start\">\n <img src=\"/assets/images/sakshamAI/lady-greet.svg\" alt=\"greet\" width=\"56.89\" height=\"64\">\n <div class=\"relevent-info\">\n <span class=\"font-bolder text-sm relevent-heading block mb-1\">{{ 'home.tocReleventHeading' | translate\n }}</span>\n <span class=\"relevent-subinfo font-normal text-sm block\">{{ 'home.tocReleventSubHeading' | translate\n }}</span>\n </div>\n <div class=\"flex flex-middle relevant-container\">\n <div class=\"flex flex-middle relevent-normal relevent-btn py-2 px-4 relevant-box\"\n (mouseenter)=\"isReleventBtnHovered = true\" (mouseleave)=\"isReleventBtnHovered = false\"\n (click)=\"handleAcceptRelevent()\">\n <img [src]=\"isReleventBtnHovered && !isRelevent ? SAKSHAMAI_ICON_LOADER : SAKSHAMAI_ICON_NORMAL\"\n alt=\"loader\" width=\"16\" height=\"16\" class=\"mr-2\">\n <span class=\"text-relevent ff-lato text-sm font-bold\">{{ 'home.relevent' | translate }}</span>\n </div>\n\n <div class=\"flex flex-middle no-button ml-8\" (click)=\"handleDeclineRelevent()\">\n <mat-icon class=\"mat-icon text-no mr-1 nodtranslate\">thumb_down</mat-icon>\n <span class=\"text-no ff-lato text-sm font-bold\">{{ 'home.no' | translate }}</span>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n <div class=\"pb-4 lg:py-4\"\n *ngIf=\"contentReadData?.identifier && content?.identifier && baseContentReadData?.identifier\">\n <!-- Overall progress functionality -->\n <div class=\"mobile-progress\">\n <ng-container [ngTemplateOutlet]=\"progressFunctionality\"></ng-container>\n </div>\n <!-- Overall progress functionality -->\n <ws-widget-content-toc [content]=\"content\" [componentName]=\"'toc'\" [pathSet]=\"pathSet\"\n [tocStructure]=\"tocStructure\" [forPreview]=\"forPreview\" [isEnrolled]=\"batchData?.enrolled\"\n [resumeData]=\"resumeData\" [batchData]=\"selectedBatchData\" [skeletonLoader]=\"skeletonLoader\"\n [changeTab]=\"changeTab\" [hierarchyMapData]=\"tocSvc?.hashmap\" [selectedBatchData]=\"selectedBatchData\"\n [condition]=\"{isPostAssessment: isPostAssessment, content: content, isAcbpCourse: isAcbpCourse, isClaimed: isClaimed, monthlyCapExceed: monthlyCapExceed, isCompletedThisMonth: isCompletedThisMonth, showTakeAssessment: showTakeAssessment, userEnrollmentList: userEnrollmentList, resumeData: resumeData, userRating: userRating, enrollBtnLoading: enrollBtnLoading, primaryCategory: primaryCategory, currentCourseBatchId: currentCourseBatchId, isAcbpClaim: isAcbpClaim}\"\n [kparray]=\"kparray\" (playResumeForAI)=\"playResumeForAI()\" (enrollUserToAI)=\"enrollUserToAI()\"\n [contentReadData]=\"contentReadData\" [baseContentReadData]=\"baseContentReadData\" [languageList]=\"languageList\"\n [lockCertificate]=\"lockCertificate\" (trigerCompletionSurveyForm)=\"openSurveyFormPopup($event)\"\n (resumeContent)=\"resumeContentData()\"></ws-widget-content-toc>\n <div class=\"mob-tip-for-learner\">\n <div *ngIf=\"learnAdvisoryData && learnAdvisoryData?.length\">\n <ws-widget-tips-for-learner-card [learnAdvisoryData]=\"learnAdvisoryData\"></ws-widget-tips-for-learner-card>\n </div>\n </div>\n </div>\n </div>\n\n\n <div class=\"right-container\">\n\n <!-- if needed sticky of right container add this to below div => #rightContainer -->\n <div class=\"right-content\">\n <div class=\"right-content-inner\">\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'384px'\" [height]=\"'224px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </ng-container>\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"flex flex-col image-div\"\n [ngStyle]=\"{\n 'background-image': 'url(' + contentReadData?.posterImage + ')', 'background-repeat': 'no-repeat', 'background-size': 'cover'}\"\n [ngClass]=\"{'image-backdrop': scrolled}\">\n <div class=\"flex flex-col justify-between text-container\">\n <div class=\"flex items-center gap-4 justify-between\"\n [ngClass]=\"{'justify-between': scrolled, 'justify-end': !scrolled}\">\n <div class=\"flex flex-row tag-div rounded-2xl gap-1 items-center p-2\" *ngIf=\"scrolled\">\n <mat-icon class=\"ws-mat-orange-text nodtranslate\">video_library</mat-icon>\n <ng-container *ngIf=\"contentReadData?.courseCategory\">\n <div class=\"text-xs font-bold text-white leading-3\">{{\n translateLabel(contentReadData?.courseCategory, 'searchfilters') }}</div>\n </ng-container>\n <ng-container *ngIf=\"!contentReadData?.courseCategory\">\n <div class=\"text-xs font-bold text-white leading-3\">{{\n translateLabel(contentReadData?.primaryCategory, 'searchfilters') }}</div>\n </ng-container>\n </div>\n <div (click)=\"onClickOfShare()\" class=\"flex flex-row items-center justify-end gap-2 share-tag\"\n *ngIf=\"canShare && !forPreview\">\n <mat-icon class=\"nodtranslate\">share</mat-icon>\n <div>{{ 'apptocsinglepage.share' | translate }}</div>\n </div>\n </div>\n <div class=\"flex flex-col gap-1\" *ngIf=\"scrolled\">\n <div class=\"text-xl leading-6 text-white font-bold\">{{ handleCapitalize(contentReadData?.name) }}\n </div>\n <div class=\"text-sm source-text font-semibold break-words\" #contentSource\n [ngClass]=\"{'sourceEllipsis': sourceEllipsis}\" title=\"{{contentReadData?.source}}\">{{\n 'cardcontentv2.by' | translate }} {{ contentReadData?.source }}</div>\n </div>\n </div>\n </div>\n </ng-container>\n\n\n <div class=\"flex flex-col gap-4 p-5 border-bottom\">\n <div class=\"flex flex-col gap-1 cursor-pointer switch-version\"\n *ngIf=\"!skeletonLoader && contentReadData?.contentVersionInfo?.identifier\"\n (click)=\"navigateToNewVersion()\" (keydown)=\"navigateToNewVersion()\">\n <span class=\"btn-switch\">{{ 'apptoc.switchToNewVersion' | translate }}</span>\n </div>\n\n <div class=\"flex flex-col gap-4\"\n *ngIf=\"contentReadData && contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM\">\n <div class=\"flex flex-row gap-3 justify-around\">\n <div class=\"batch-info\">\n <div class=\"font-base font-bold\">{{ selectedBatchData?.content[0]?.batchAttributes?.currentBatchSize\n || '0' }}</div>\n <div class=\"batch-label\">{{ 'apptoc.batchSize' | translate }}</div>\n </div>\n <div class=\"batch-info\">\n <div class=\"font-base font-bold\">{{ selectedBatchData?.userCount?.totalApplied || '0' }}</div>\n <div class=\"batch-label\">{{ 'apptoc.totalApplied' | translate }}</div>\n </div>\n <div class=\"batch-info\">\n <div class=\"font-base font-bold\">{{ selectedBatchData?.userCount?.enrolled || '0' }}</div>\n <div class=\"batch-label\">{{ 'apptoc.totalEnrolled' | translate }}</div>\n </div>\n </div>\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM && !preAssessmentCompletionStatus\">\n <a class=\"flex action-button enroll-btn justify-center resume\"\n *ngIf=\"contentReadData?.preEnrolmentResources?.length\" (click)=\"routeToPreAssessent()\">\n <ng-container>\n {{ 'apptochome.preEnroll' | translate }}\n </ng-container>\n </a>\n </ng-container>\n <ng-container\n *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM && preAssessmentCompletionStatus\">\n <a class=\"flex preenrolldone-btn justify-center resume\">\n <ng-container>\n {{ 'apptochome.preEnrollDone' | translate }}<img src=\"/assets/icons/Accept_icon.png\" alt=\"tick\"\n class=\"tick-icon\">\n </ng-container>\n </a>\n </ng-container>\n <ng-container\n *ngIf=\"timer && timer.days >= 0 && contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM\">\n <div class=\"flex flex-col gap-6 batch-timer\">\n <div class=\"flex flex-row\">\n <div class=\"flex-1\">\n <div class=\"flex underline\"></div>\n </div>\n <div class=\"flex\">\n <div class=\"timer-label\">{{ 'apptocsinglepage.batchStartsIn' | translate }}</div>\n </div>\n <div class=\"flex-1\">\n <div class=\"flex underline\"></div>\n </div>\n </div>\n <div class=\"flex flex-row gap-4 justify-center\">\n <div class=\"flex flex-row gap-1 items-center\">\n <div class=\"text-4xl leading-10 counter\">{{ timer.days || 0 }}</div>\n <div class=\"counter-label\">{{ 'apptocsinglepage.days' | translate }}</div>\n </div>\n <div class=\"flex items-center counter-label\">\n :\n </div>\n <div class=\"flex flex-row gap-1 items-center\">\n <div class=\"text-4xl leading-10 counter\">{{ timer.min === 60 ? timer.hours + 1 : timer.hours }}\n </div>\n <div class=\"counter-label\">{{ 'apptocsinglepage.hours' | translate }}</div>\n </div>\n <div class=\"flex items-center counter-label\">\n :\n </div>\n <div class=\"flex flex-row gap-1 items-center\">\n <div class=\"text-4xl leading-10 counter\">{{ timer.min === 60 ? 00 : timer.min }}</div>\n <div class=\"counter-label\">{{ 'apptocsinglepage.minutes' | translate }}</div>\n </div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!forPreview || isInIFrame; else authViewBtn\">\n <ng-container *ngIf=\"!mobile1200 && (\n !contentReadData?.preEnrolmentResources?.length ||\n (contentReadData?.preEnrolmentResources?.length && (preAssessmentCompletionStatus || !preAssessmentRequiredFlag))\n )\">\n\n <ws-app-toc-banner role=\"banner\" [banners]=\"banners\" [forPreview]=\"forPreview\" [content]=\"content\"\n [userEnrollmentList]=\"userEnrollmentList\" (withdrawOrEnroll)=\"withdrawOrEnroll($event)\"\n [analytics]=\"analytics\" [resumeData]=\"resumeData\" [batchData]=\"batchData\"\n [contentReadData]=\"contentReadData\">\n </ws-app-toc-banner>\n </ng-container>\n </ng-container>\n </div>\n\n\n <ng-container *ngIf=\"skeletonLoader\">\n <ws-widget-skeleton-loader [width]=\"'336px'\" [height]=\"'40px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'336px'\" [height]=\"'68px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </ng-container>\n\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"flex flex-col gap-4\">\n <div class=\"flex flex-row items-center gap-2 info-div\" *ngIf=\"content?.isInIntranet && showIntranetMsg\">\n <mat-icon class=\"nodtranslate\">info</mat-icon>\n <ng-container>{{ 'apptochome.viewedInIntranet' | translate }}</ng-container>\n </div>\n <div class=\"flex flex-row items-center gap-2 info-div\" *ngIf=\"showInstructorLedMsg\">\n <mat-icon class=\"nodtranslate\">info</mat-icon>&nbsp;\n <ng-container>{{ 'apptochome.notAvailableOnline' | translate }}</ng-container>\n </div>\n <div class=\"flex flex-row items-center gap-2 info-div\" *ngIf=\"showStart.msg === 'youtubeForbidden'\">\n <mat-icon class=\"nodtranslate\">info</mat-icon>&nbsp;\n <ng-container>{{ 'apptochome.youtubeContentBlocked' | translate }}</ng-container>\n </div>\n <div *ngIf=\"showBtn\">\n <a href=\"{{ cscmsUrl }}\" target=\"_blank\" class=\"flex action-button justify-center\">\n {{ 'apptochome.applyForPhysicalTraining' | translate }}</a>\n </div>\n\n <!-- Overall progress functionality -->\n <ng-container *ngIf=\"content?.completionStatus <= 2 && isBatchInProgress\">\n <ng-container [ngTemplateOutlet]=\"progressFunctionality\"></ng-container>\n </ng-container>\n <!-- Overall progress functionality -->\n\n <!-- <div *ngIf=\"resumeData && !userRating\"> -->\n <!-- <ws-app-karmapoints-panel [btntype]=\"'Rate this course'\" [data]=\"kparray\"\n [pCategory]=\"contentReadData?.primaryCategory\"></ws-app-karmapoints-panel> -->\n <!-- </div> -->\n\n <!-- <div *ngIf=\"resumeData && userRating\">\n <ws-app-karmapoints-panel [btntype]=\"'Edit rating'\" [data]=\"kparray\"\n [pCategory]=\"contentReadData?.primaryCategory\"></ws-app-karmapoints-panel>\n </div> -->\n\n <ng-container\n *ngIf=\"actionBtnStatus !== 'wait' && contentReadData?.status !== 'Deleted' && contentReadData?.status !== 'Expired'\">\n <ng-container [ngTemplateOutlet]=\"enrollFunctionality\"></ng-container>\n </ng-container>\n </div>\n\n <div class=\"karma-points-div\">\n <ws-widget-karma-points [data]=\"kparray\" (clickClaimKarmaPoints)=\"onClickOfClaim($event)\"\n [content]=\"content\"\n [condition]=\"{isPostAssessment: isPostAssessment, content: content, isAcbpCourse: isAcbpCourse, isClaimed: isClaimed, monthlyCapExceed: monthlyCapExceed, isCompletedThisMonth: isCompletedThisMonth, showTakeAssessment: showTakeAssessment, userEnrollmentList: userEnrollmentList, isCompletedThisMonth: isCompletedThisMonth, resumeData: resumeData, userRating: userRating, enrollBtnLoading: enrollBtnLoading, primaryCategory: primaryCategory, currentCourseBatchId: currentCourseBatchId, isAcbpClaim: isAcbpClaim}\"></ws-widget-karma-points>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"skeletonLoader\">\n <div class=\"flex flex-wrap gap-6\">\n <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'40px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"!skeletonLoader\">\n <ws-widget-toc-kpi-values [content]=\"content\" [tocStructure]=\"tocStructure\"\n [showInstructorLedMsg]=\"showInstructorLedMsg\" [contentReadData]=\"contentReadData\"\n [languageList]=\"languageList\"></ws-widget-toc-kpi-values>\n </ng-container>\n </div>\n\n <div class=\"flex flex-col gap-8 p-5\">\n <ng-container *ngIf=\"skeletonLoader\">\n <div class=\"flex flex-col gap-4\" *ngFor=\"let i of [1, 2]\">\n <ws-widget-skeleton-loader [width]=\"'72px'\" [height]=\"'20px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n\n <div class=\"flex flex-row items-center gap-3\">\n <ws-widget-skeleton-loader [width]=\"'36px'\" [height]=\"'36px'\"\n [bindingClass]=\"'rounded-full'\"></ws-widget-skeleton-loader>\n <div class=\"flex flex-col gap-2\">\n <ws-widget-skeleton-loader [width]=\"'124px'\" [height]=\"'20px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n <ws-widget-skeleton-loader [width]=\"'124px'\" [height]=\"'12px'\"\n [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n </div>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"!skeletonLoader\">\n <div class=\"flex flex-col gap-3\" *ngIf=\"handleParseJsonData(contentReadData?.creatorDetails)?.length\">\n <div class=\"text-base font-bold\">{{ 'apptocsinglepage.authors' | translate }}</div>\n <div class=\"flex flex-row gap-4 items-center\"\n *ngFor=\"let author of handleParseJsonData(contentReadData?.creatorDetails)\">\n <div class=\"flex items-center justify-center\">\n <ws-widget-avatar-photo [randomColor]=\"true\" [datalen]=\"1\" [size]=\"'round-m'\"\n [photoUrl]=\"author?.photo || ''\" [name]=\"author?.name\">\n </ws-widget-avatar-photo>\n </div>\n <div class=\"flex flex-col gap-1 justify-center\">\n <div class=\"font-bold\">{{ handleCapitalize(author?.name, 'name') }}</div>\n <div class=\"text-xs leading-3\">{{ 'apptocsinglepage.author' | translate }}</div>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3\" *ngIf=\"handleParseJsonData(contentReadData?.creatorContacts)?.length\">\n <div class=\"text-base font-bold\">{{ 'apptocsinglepage.creators' | translate }}</div>\n <div class=\"flex flex-row gap-4 items-center\"\n *ngFor=\"let creeator of handleParseJsonData(contentReadData?.creatorContacts)\">\n <div class=\"flex items-center justify-center\">\n <ws-widget-avatar-photo [randomColor]=\"true\" [datalen]=\"1\" [size]=\"'round-m'\"\n [photoUrl]=\"creeator?.photo || ''\" [name]=\"creeator?.name\">\n </ws-widget-avatar-photo>\n </div>\n <div class=\"flex flex-col gap-1 justify-center\">\n <div class=\"font-bold\">{{ handleCapitalize(creeator?.name, 'name') }}</div>\n <div class=\"text-xs leading-3\">{{ 'apptocsinglepage.creator' | translate }}</div>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3\"\n *ngIf=\"contentReadData?.source && (contentCreatorData && contentCreatorData?.length)\">\n <div class=\"text-base font-bold\">{{ 'apptocsinglepage.provider' | translate }}</div>\n <div class=\"flex flex-row gap-4 items-center\" *ngFor=\"let creator of contentCreatorData\">\n <div class=\"flex provider-logo-div\">\n <img *ngIf=\"contentReadData?.creatorLogo\" [src]=\"contentReadData?.creatorLogo\"\n alt=\"{{ 'apptocsinglepage.provider' | translate }}\" />\n <img *ngIf=\"!contentReadData?.creatorLogo\" class=\"mat-icon\"\n src=\"/assets/instances/eagle/app_logos/KarmayogiBharat_Logo.svg\"\n alt=\"{{ 'apptocsinglepage.provider' | translate }}\" />\n </div>\n <div class=\"text-sm word-break cursor-pointer\" *ngIf=\"contentReadData?.createdFor?.length\"\n (click)=\"raiseTelemeteryForProvider(contentReadData?.source, contentReadData?.createdFor[0])\"\n [routerLink]=\"['/app/learn/browse-by/provider', contentReadData?.source, contentReadData?.createdFor[0], 'micro-sites']\">\n {{ handleCapitalize(contentReadData?.source, 'source') }}\n </div>\n <div class=\"text-sm word-break\" *ngIf=\"!contentReadData?.createdFor?.length\">{{\n handleCapitalize(contentReadData?.source, 'source') }}\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n\n <div *ngIf=\"learnAdvisoryData && learnAdvisoryData?.length\">\n <ws-widget-tips-for-learner-card [learnAdvisoryData]=\"learnAdvisoryData\"></ws-widget-tips-for-learner-card>\n </div>\n </div>\n\n\n\n </div>\n </div>\n <div class=\"mobile-enroll-div\"\n [ngClass]=\"{'bg-white': contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM }\">\n <ng-container *ngIf=\"content && contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM \">\n <div class=\"mb-2\" *ngIf=\"mobile1200 && !forPreview || isInIFrame; else authViewBtn\">\n <ws-app-toc-banner role=\"banner\" [banners]=\"banners\" [forPreview]=\"forPreview\" [content]=\"content\"\n [userEnrollmentList]=\"userEnrollmentList\" (withdrawOrEnroll)=\"withdrawOrEnroll($event)\"\n [analytics]=\"analytics\" [resumeData]=\"resumeData\" [batchData]=\"batchData\" [contentReadData]=\"contentReadData\">\n </ws-app-toc-banner>\n </div>\n </ng-container>\n <ng-container [ngTemplateOutlet]=\"enrollFunctionality\"></ng-container>\n </div>\n\n <ws-app-share-toc *ngIf=\"enableShare\" [rootOrgId]=\"rootOrgId\" [content]=\"content\"\n (resetEnableShare)=\"resetEnableShare($event)\" [baseContentReadData]=\"baseContentReadData\"></ws-app-share-toc>\n</ng-container>\n<ng-template #noDataFound>\n <div\n class=\"error-not-found flex flex-wrapped margin-left-m margin-top-xl margin-right-m flex-col justify-center align-items-center text-center\">\n <div class=\"error-logo\">\n <div class=\"error-message ws-mat-primary-text font-weight-bold\">\n The page you requested cannot be found\n </div>\n </div>\n <!-- <div class=\"error-support\">\n <div class=\"support-message\" >We have updated our web site and many URLs have changed.</div>\n <div class=\"support-message\" >You might want to:</div>\n </div> -->\n </div>\n\n</ng-template>\n\n<ng-template #authView>{{'apptochome.view' | translate}}</ng-template>\n\n<ng-template #authViewBtn i18n>\n <ng-container *ngIf=\"displayViewBtn\">\n <a (click)=\"raiseTelemetryForPublic($event)\"\n [routerLink]=\"shouldShowSurveyPopup() ? null : ((resumeData && !certData) ? resumeDataLink?.url : firstResourceLink?.url)\"\n [queryParams]=\"shouldShowSurveyPopup() ? null : ((resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START'))\"\n class=\"flex action-button justify-center\">\n {{'apptochome.view' | translate}}\n </a>\n </ng-container>\n</ng-template>\n<ng-template #authViewForInviteOnlyAssessment>\n <ng-container *ngIf=\"forPreview && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n <a class=\"flex action-button justify-center resume\" [routerLink]=\"firstResourceLink?.url\"\n [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\">\n <ng-container>{{ 'apptochome.takeTest' | translate }}</ng-container>\n </a>\n </ng-container>\n</ng-template>", styles: [".source-text{color:#ffffffb3}.approved-icon{width:12px;height:12px}.preenrolldone-btn{opacity:1;color:#1d8923;font-family:Lato-Bold,sans-serif;font-size:14px;font-weight:700;font-style:normal;letter-spacing:.5px;text-align:center;line-height:20px;background:#fff;border-radius:64px;padding:8px 16px;border:2px solid #1D8923;cursor:pointer;height:40px;box-sizing:border-box}.preenrolldone-btn img{margin-left:8px;margin-top:-2px}.toc-banner{background:#3a83cf;background:linear-gradient(135deg,#3a83cf,#1b4ca1);width:100%}.toc-banner .fixed-width{padding:0 16px}.toc-banner .banner-details{padding:36px 0}@media screen and (max-width: 576px){.toc-banner .banner-details{padding-top:10px;padding-bottom:20px}}.toc-banner .banner-details .due-tag{padding:4px;color:#fff;border-radius:4px}.toc-banner .banner-details .due-warning{background-color:#ff9800;border:1px solid #FF9800}.toc-banner .banner-details .due-overdue{background-color:#f44336;border:1px solid #F44336}.toc-banner .banner-details .due-success{background-color:#4caf50;border:1px solid #4CAF50}.toc-banner .banner-details .rating-chip{border:1px solid rgba(0,0,0,.6);border-radius:20px;background-color:#0009}.toc-banner .banner-details .rating-chip mat-icon{width:16px;height:16px;color:#ff9800;font-size:16px}.toc-banner .banner-details .rating-chip .separator{width:1px;height:20px;border-right:1px solid rgba(255,255,255,.16);margin:0 8px}.toc-banner .banner-details .banner-text{color:#fffffff2}.toc-banner .info-div{max-width:384px;width:100%}.toc-banner .most-enrolled-chip{background-color:#ffea9e;border:1px solid #FFEA9E;padding:4px;border-radius:2px}.toc-banner .new-version-pill{background-color:#f9cb97;border:1px solid rgb(249,203,151);padding:4px;border-radius:2px}.toc-banner .new-version-retire-pill{background-color:#d13924;border:1px solid #d13924;padding:4px;color:#fff;border-radius:2px}.text-info-div{padding:8px;background-color:#fff;border-radius:64px}.mobile-back-btn{display:flex!important;align-items:center;justify-content:flex-start;cursor:pointer;padding:0;margin-bottom:8px;color:#fff!important}.mobile-back-btn mat-icon{font-size:24px!important;width:24px!important;height:24px!important}@media screen and (min-width: 577px){.mobile-back-btn{display:none!important}}.tag-div{border:1px solid #FF9800;background-color:#00000080}.tag-div mat-icon{font-size:12px;width:12px;height:12px}.fixed-width{max-width:1200px;display:block;margin:0 auto}.mat-subheading-1{margin-bottom:4px!important}.initial-circle{width:36px;height:36px;border-radius:50%;background:#1b2133;color:#fff;text-transform:uppercase}.toc-content{max-width:792px;width:100%}@media (min-resolution: 1.5dppx){.toc-content{max-width:735px}}.right-container .image-div{height:220px;background-color:#ccc;border-top-left-radius:12px;border-top-right-radius:12px}.right-container .image-div img{max-width:384px;width:100%;height:220px;border-top-left-radius:12px;border-top-right-radius:12px;position:relative;top:-42px}.right-container .image-div .share-container{position:relative;z-index:2;top:20px;margin-right:20px}.right-container .image-div .share-tag{font-weight:700;background-color:#000;border:1px solid #FFF;border-radius:20px;padding:6px 16px;color:#fff;cursor:pointer}.right-container .tag-div mat-icon{width:16px;height:16px;font-size:16px}.right-container .share-tag mat-icon{width:20px;height:20px;font-size:20px}.right-container .text-container{position:relative;z-index:2;height:220px;padding:16px}.right-container .right-content{position:absolute;z-index:10;top:132px;padding-bottom:1rem}.right-container .right-content-inner{background-color:#fff;border-radius:12px;width:384px;margin-bottom:1rem;box-shadow:0 2px 6px -1px #00000080,0 -4px 4px -2px #00000080}.right-container .border-bottom{border-bottom:1px solid rgba(0,0,0,.2)}.right-container .view-more{display:flex;align-items:center;text-align:center;height:40px;justify-content:center}.right-container .view-more:hover{background-color:#dcdfe5}.right-container .info-div{background-color:#fef7ed;border:none;border-radius:8px;padding:8px 12px;font-size:14px}.right-container .info-div .mat-icon{width:18px;height:18px;font-size:18px}.right-container .kpi-values{width:64px;padding:8px;text-align:center}.right-container .kpi-values .timer-icon{color:#1b4ca1;height:20px}.batch-info{padding:16px;border-radius:4px;background-color:#1b4ca114;border:1px solid rgba(27,76,161,.08);text-align:center}.batch-info .batch-label{font-size:.75rem;color:#0009;line-height:1rem}.mob-tip-for-learner{display:none}@media screen and (max-width: 1000px){.mob-tip-for-learner{display:block;width:100%;padding:0 16px;overflow:hidden;box-sizing:border-box}}.button{border-radius:64px;letter-spacing:.25px;padding:12px 36px;font-weight:700;cursor:pointer;text-align:center}@media screen and (max-width: 1200px){.right-container{display:none}.action-button:before{content:\"\";position:absolute;inset:-10px;background-color:#ffffff40;border-radius:inherit;filter:blur(10px);z-index:-1}.action-button:after{content:\"\";position:absolute;inset:-10px;box-shadow:0 0 -4px -4px #fff9;border-radius:inherit;z-index:-1}.karma-points-div{display:none}}.enroll-modal{max-width:600px!important;width:100%!important}.enroll-modal .mat-dialog-container{padding:0;border-radius:12px}.confirmation-modal{max-width:420px!important;width:100%!important}.confirmation-modal .mat-dialog-container{border-radius:12px;padding:0}.image-backdrop{background-color:#000!important;position:relative}.image-backdrop:after{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);content:\"\";display:block;position:absolute;width:100%;height:100%;top:0;left:0;background-color:#000000a6;border-top-left-radius:12px;border-top-right-radius:12px}@media screen and (max-width: 1000px){.confirmation-modal,.enroll-modal{max-width:90vw!important}}.kpi-loader-div{width:18%}a.action-button{color:#fff!important;width:auto;box-sizing:border-box;height:40px;line-height:24px!important}.rate-button{color:#1b4ca1!important;font-size:.875rem;font-weight:700;border:none!important}.rate-button .mat-button-wrapper{display:flex;gap:8px;align-items:center}.mobile-enroll-div{padding:16px;position:fixed;z-index:1000;bottom:0;width:calc(100% - 32px)}.mobile-enroll-div .action-button,.mobile-enroll-div .preenrolldone-btn{min-width:320px;max-width:400px;margin:auto}@media only screen and (max-width: 768px){.new-version-text{font-size:12px!important}.new-version-chip{padding-top:0!important}}@media screen and (min-width: 1201px){.mobile-enroll-div,.mob-share{display:none!important}.hideAbove1200{display:none}}.mobile-progress{padding:16px}@media screen and (min-width: 1200px){.mobile-progress{display:none}}.sourceEllipsis{white-space:break-spaces;position:relative;overflow:hidden;text-overflow:clip;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}.text-white{color:#fff!important}.custom-button,.fluid-width{width:100%}.toc-container{background:#fff;width:100%}mat-divider{border-top-color:#d9d9d9}.sticky{top:56px;overflow:hidden;z-index:10;width:100%}.statusMsg{border-radius:4px;height:40px}.toc-body{padding-bottom:1rem}.toc-body .toc-links{width:100%;z-index:1;border:none;background:transparent}.toc-body .toc-links .mat-tab-link{text-align:left;justify-content:flex-start}.toc-body .toc-links .mat-tab-link.justify-center{justify-content:center}.toc-body .toc-links .mat-tab-link.link-active{color:#0074b6!important}.tab:focus{outline:1px solid!important}.rounded-icon{background:#fff 0% 0% no-repeat padding-box;box-shadow:0 2px 4px #00000029;border:2px solid #00A9F4;border-radius:50%;min-width:0;opacity:1;height:35px;width:35px;padding:0;align-items:center;align-self:center;float:right}.rounded-icon mat-icon{color:#00a9f4}.blue-border{border:2px solid #0074b6!important}.hidden-xs-inline{display:inline}@media only screen and (max-width: 599px){.hidden-xs-inline{display:none}}.visible-xs-inline{display:none}@media only screen and (max-width: 599px){.visible-xs-inline{display:inline}}.meta-section{flex:1;min-width:1px}.meta-section .unit-meta-item{border-radius:2px;box-sizing:border-box;margin-bottom:16px;box-shadow:none;padding-left:0}@media only screen and (max-width: 599px){.meta-section{width:100%}}.font-bold-imp{font-weight:700!important}.info-section{width:20%;min-width:250px}.info-section .custom-button{background:#0074b6 0% 0% no-repeat padding-box!important;border-radius:4px}@media only screen and (max-width: 599px){.info-section{width:100%;margin-left:0!important}}.info-section .glance-container .at-glance-heading{letter-spacing:0px;color:#222}.info-section .glance-container .info-item .cs-icons .mat-icon{color:#666;vertical-align:middle;font-size:20px}.info-section .glance-container .info-item .cs-icons img{width:20px;height:20px;vertical-align:middle}.info-section .glance-container .info-item .item-heading{font:600 14px/21px Lato;margin:0 0 4px;letter-spacing:0px;color:#0074b6!important}.info-section .glance-container .info-item .item-value{letter-spacing:0px;color:#5f5f5f}.info-section .glance-container .info-item .item-icon{width:20px;height:20px;font-size:20px;margin-left:8px}.toc-discussion-container{display:flex;justify-content:space-between;flex-wrap:wrap-reverse}.toc-discussion-container .discussion{flex:1;min-width:1px}.toc-discussion-container .cohorts{width:100%;background:#fff 0% 0% no-repeat padding-box;border:1px solid #D9D9D9;border-radius:8px;box-shadow:none}@media only screen and (min-width: 600px) and (max-width: 959px){.toc-discussion-container .cohorts{margin-left:24px;min-width:250px}}@media only screen and (max-width: 599px){.toc-discussion-container .cohorts{margin-left:0;margin-bottom:24px;width:100%}}.mtb-xl{margin-top:3.5rem;margin-bottom:3.5rem}.detailBar{display:flex}.editDetails{margin:auto;display:flex}.white-bg{background:#fff!important;background-color:#fff!important}.contacts-container{padding:22px 0 10px;border:0;border-top:1px;border-style:solid;border-bottom:1px;border-color:#ececec}.contacts-container .contacts-head{letter-spacing:0px;color:#222;background:transparent;margin-bottom:24px}.contacts-container .author-card{min-width:291px;width:291px;display:flex;flex-direction:row;align-items:center;margin-bottom:30px;padding-right:10px}.contacts-container .author-card .right{padding:0 15px}.contacts-container .author-card .user-name{letter-spacing:0px;color:#5f5f5f}.contacts-container .author-card .user-university{letter-spacing:0px;color:#00a9f4}.contacts-container .author-card .user-button{background:#fff 0% 0% no-repeat padding-box;border:1px solid #F58634;border-radius:15px;letter-spacing:0px;color:#f58634;max-width:60px;padding:4px}.divider-transparent{border-top-color:transparent!important}.scroll-to-top{position:fixed;bottom:15px;right:15px;opacity:0;transition:all .2s ease-in-out;border-radius:50%}.scroll-to-top .icon{font-size:24px!important}.show-scroll{opacity:1;transition:all .2s ease-in-out}.sticky-breadcrumbs{position:sticky;z-index:999;top:72px;width:100%}.sticky-banner{position:sticky;z-index:999}.sticky-navs{position:sticky!important;background:#fff;z-index:999;top:auto}.actbutton{border:1px solid rgba(0,0,0,.16);border-radius:4px;padding:0 15px;width:100%;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.actbutton .mat-icon{margin-right:6px}.disable-start-btn{cursor:not-allowed!important;pointer-events:none!important;opacity:.5!important}.cb-plan-wrap{opacity:1;color:#1b4ca1;font-family:Lato-Regular;font-size:12px;font-weight:400;font-style:normal;letter-spacing:.25px;text-align:left;line-height:16px}.cb-plan-wrap .cb-danger{border-radius:2px;padding:4px 8px;border:1px solid #d13924;background-color:#d13924!important;color:#fff!important;opacity:1}.cb-plan-wrap .cb-success{padding:4px 8px;border-radius:2px;border:1px solid #1d8922;background-color:#1d8922!important;color:#fff!important;opacity:1}.cb-plan-wrap .cb-warning{padding:4px 8px;border-radius:2px;border:1px solid #ef951e;background-color:#ef951e!important;color:#fff!important;opacity:1}.bg-white{background-color:#fff}.provider-logo-div{border-radius:4px;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.provider-logo-div img{display:flex;border-radius:4px;width:40px;height:40px;padding:4px}.location-details{background-color:#1b4ca114;padding:16px;border-radius:4px}.location-details .location-icon,.location-details .event-icon{color:#1b4ca1;height:20px;width:14px;font-size:22px}.location-details .loc-desc{font-family:Lato;font-weight:700;font-size:14px;line-height:20px;letter-spacing:.25}.location-details .mat-icon{overflow:visible!important}.batch-timer .underline{border-top:1.5px solid rgba(0,0,0,.16);margin:16px 0}.batch-timer .timer-label{font-size:12px;padding:4px 8px;border:1px solid rgba(0,0,0,.16);border-radius:16px;color:#000000de}.batch-timer .counter{color:#000000de}.batch-timer .counter-label{color:#0006;text-transform:uppercase;font-size:12px;line-height:16px}.relevent-wrapper{background:#1b4ca129;border-radius:12px}.relevent-wrapper .relevent-info{max-width:400px;margin-right:auto}.relevent-wrapper .relevent-info .relevent-heading{font-family:Montserrat;line-height:17.07px;font-weight:600;color:#000!important}.relevent-wrapper .relevent-info .relevent-subinfo{font-family:Lato;line-height:16.8px;color:#545454}.relevent-normal.relevent-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#276de5;background-color:#fff;border-radius:21px;text-decoration:none;overflow:hidden;transition:all .3s ease-in-out}.relevent-normal.relevent-btn:hover{box-shadow:0 1px 10px #276de599}.relevent-normal.relevent-btn{cursor:pointer}.relevent-normal.relevent-btn:before{content:\"\";position:absolute;inset:0;padding:2px 2.5px;border-radius:21px;background:linear-gradient(89.96deg,#f3962f .04%,#276de5 99.96%);-webkit-mask:linear-gradient(white,white) content-box,linear-gradient(white,white);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s ease-in-out;cursor:pointer}.relevent-normal.relevent-btn:hover:before{opacity:1}.relevant-container{width:max-content}.no-button{opacity:1;transform:scale(1);transition:opacity .3s ease-in-out,transform .3s ease-in-out;color:#1b4ca1;cursor:pointer}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom{background:transparent;border:1px solid #fff;color:#fff!important;cursor:pointer;margin:0!important}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom mat-icon{color:#fff!important}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom mat-icon:hover{color:#1b4ca1!important}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom:hover,.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom.mat-chip-selected{background:#fff!important;border:1px solid #fff;color:#1b4ca1!important}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom:hover mat-icon,.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom.mat-chip-selected mat-icon{color:#1b4ca1!important}.theme-igot.day-mode .lang-chips .mat-chip.matchip-custom:after{opacity:0!important;background:transparent}.new-version-chip{gap:10px;padding:2px 8px;background-color:#f3962f;cursor:pointer;position:relative;overflow:hidden}.new-version-chip:before{content:\"\";position:absolute;top:0;left:-100%;width:25%;height:100%;background:linear-gradient(314deg,transparent,rgba(213,210,210,.6),transparent);animation:shimmer 1s infinite}.new-version-chip .new-version-text{font-family:Lato;font-weight:400;font-size:20px;line-height:100%}.btn-switch{font-family:Lato,sans-serif;font-size:14px;font-weight:700;font-style:normal;letter-spacing:.5px;text-align:center;line-height:20px;background:#fff;border-radius:64px;padding:8px 16px;border:none;border:1px solid rgb(243,150,47);color:#f3962f;background:#ef951e29!important}@keyframes shimmer{0%{left:-100%}to{left:100%}}.knowledge-level-container{margin-left:auto}.level-badge{display:inline-flex;height:24px;padding:2px 8px;align-items:center;gap:4px;flex-shrink:0;border-radius:12px;font-weight:600;font-size:12px;line-height:16px;white-space:nowrap}.level-badge.beginner{border:1px solid #49C951;background:linear-gradient(0deg,#49c95133 0% 100%),#fff;color:#2f8132;border-radius:16px}.level-badge.intermediate{border:1px solid #1B4CA1;background:linear-gradient(0deg,#1b4ca133 0% 100%),#fff;color:#1b4ca1;border-radius:16px}.level-badge.advanced{border:1px solid #FF8268;background:linear-gradient(0deg,#ff826833 0% 100%),#fff;color:#ff4b25;border-radius:16px}.level-badge svg{flex-shrink:0}\n"] }]
2976
+ }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i1.Router }, { type: i2.WidgetContentService }, { type: i3.AppTocService }, { type: i4.LoggerService }, { type: i4.ConfigurationsService }, { type: i5.DomSanitizer }, { type: i6.MatLegacySnackBar }, { type: i7.MatLegacyDialog }, { type: i8.MobileAppsService }, { type: i4.UtilityService }, { type: i9.ContentLanguageService }, { type: i10.ActionService }, { type: i11.ViewerUtilService }, { type: i12.RatingService }, { type: i4.TelemetryService }, { type: i13.TranslateService }, { type: i4.MultilingualTranslationsService }, { type: i4.EventService }, { type: i14.LoadCheckService }, { type: i15.HandleClaimService }, { type: i16.ResetRatingsService }, { type: i17.TimerService }, { type: i4.WidgetEnrollService }, { type: i9.WidgetContentLibService }, { type: i4.DataTransferService }, { type: i18.MatSnackBar }, { type: i9.WidgetUserServiceLib }, { type: i19.NetCoreService }, { type: i20.AppTocV2Service }, { type: i21.Location }, { type: i4.DomainConfService }, { type: undefined, decorators: [{
2977
+ type: Inject,
2978
+ args: ['environment']
2979
+ }] }]; }, propDecorators: { forPreview: [{
2980
+ type: Input
2981
+ }], inputContent: [{
2982
+ type: Input
2983
+ }], displayViewBtn: [{
2984
+ type: Input
2985
+ }], menuElement: [{
2986
+ type: ViewChild,
2987
+ args: ['stickyMenu', { static: true }]
2988
+ }], rcElement: [{
2989
+ type: ViewChild,
2990
+ args: ['rightContainer']
2991
+ }], bannerElem: [{
2992
+ type: ViewChild,
2993
+ args: ['bannerDetails', { static: true }]
2994
+ }], contentSource: [{
2995
+ type: ViewChild,
2996
+ args: ['contentSource']
2997
+ }], handleScroll: [{
2998
+ type: HostListener,
2999
+ args: ['window:scroll', ['$event']]
3000
+ }] } });
3001
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app-toc-home-v2.component.js","sourceRoot":"","sources":["../../../../../../../library/sunbird-cb/toc/src/lib/components/app-toc-home-v2/app-toc-home-v2.component.ts","../../../../../../../library/sunbird-cb/toc/src/lib/components/app-toc-home-v2/app-toc-home-v2.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, OnDestroy, OnInit, AfterViewInit, AfterViewChecked,\n  HostListener, ElementRef, ViewChild, ViewEncapsulation, Input,\n  Inject,\n} from '@angular/core'\nimport { Location } from '@angular/common'\nimport { SafeHtml, DomSanitizer, SafeStyle } from '@angular/platform-browser'\nimport { ActivatedRoute, Event, Data, Router, NavigationEnd } from '@angular/router'\nimport { UntypedFormControl, Validators } from '@angular/forms'\n// import { HttpErrorResponse } from '@angular/common/http'\nimport { TranslateService } from '@ngx-translate/core'\nimport { Subscription, Observable, Subject, of, from } from 'rxjs'\nimport { catchError, share, switchMap, takeUntil } from 'rxjs/operators'\nimport dayjs from 'dayjs'\n// tslint:disable-next-line\nimport _ from 'lodash'\ndayjs.extend(isSameOrBefore)\nimport moment from 'moment'\nimport isSameOrBefore from 'dayjs/plugin/isSameOrBefore'\n\nimport { NsContent } from '../../_services/widget-content.model'\nimport { WidgetContentService } from '../../_services/widget-content.service'\nimport { viewerRouteGenerator } from '../../_services/viewer-route-util'\nimport { NsWidgetResolver } from '@sunbird-cb/resolver-v2'\nimport {\n  ConfigurationsService, DataTransferService, DomainConfService, EventService,\n  LoggerService, MultilingualTranslationsService,\n  NsPage, TFetchStatus, TelemetryService,\n  UtilityService, WidgetEnrollService, WsEvents,\n} from '@sunbird-cb/utils-v2'\n\nimport { ConfirmationDialogComponent, ContentLanguageService, TOCMultiLingualDialogComponent, WidgetContentLibService, WidgetUserServiceLib } from '@sunbird-cb/consumption'\nimport { NsAppToc } from '../../models/app-toc.model'\nimport { AppTocService } from '../../services/app-toc.service'\nimport { MobileAppsService } from '../../services/mobile-apps.service'\nimport { HandleClaimService } from '../../_collection/_common/content-toc/content-services/handle-claim.service'\nimport { ActionService } from '../../services/action.service'\nimport { RatingService } from '../../_services/rating.service'\nimport { ViewerUtilService } from '../../services/viewer-util.service'\nimport { LoadCheckService } from '../../services/load-check.service'\nimport { ResetRatingsService } from '../../services/reset-ratings.service'\n\nimport { AppTocDialogIntroVideoComponent } from '../app-toc-dialog-intro-video/app-toc-dialog-intro-video.component'\nimport { ContentRatingV2DialogComponent } from '../../_collection/_common/content-rating-v2-dialog/content-rating-v2-dialog.component'\nimport { TimerService } from '../../services/timer.service'\nimport { MatLegacyDialog as MatDialog } from '@angular/material/legacy-dialog'\nimport { MatLegacySnackBar as MatSnackBar } from '@angular/material/legacy-snack-bar'\nimport { MatSnackBar as MatSnackbarNew } from '@angular/material/snack-bar'\nimport { NetCoreService } from '../../services/netcore.service'\nimport { EnrollLanguageDialogueComponent } from '../enroll-language-dialogue/enroll-language-dialogue.component'\nimport { CompletionSurveyFormComponent } from '../completion-survey-form/completion-survey-form.component'\nimport { PublicSurveyFormComponent } from '../public-survey-form/public-survey-form.component'\nimport { NsCardContent } from '../../models/card-content.model'\nimport { NonReleventFeedbackDialogComponent } from '../non-relevent-feedback-dialog/non-relevent-feedback-dialog.component'\nimport { AppTocV2Service } from '../../services/app-toc-v2.service'\n\nexport enum ErrorType {\n  internalServer = 'internalServer',\n  serviceUnavailable = 'serviceUnavailable',\n  somethingWrong = 'somethingWrong',\n}\n\nconst flattenItems = (items: any[], key: string | number) => {\n  return items.reduce((flattenedItems, item) => {\n    flattenedItems.push(item)\n    if (Array.isArray(item[key])) {\n      // tslint:disable-next-line\n      flattenedItems = flattenedItems.concat(flattenItems(item[key], key))\n    }\n    return flattenedItems\n    // tslint:disable-next-line\n  }, [])\n}\nconst SNACKBAR_DURATION = 3000\n@Component({\n  selector: 'ws-app-app-toc-home-v2',\n  templateUrl: './app-toc-home-v2.component.html',\n  styleUrls: ['./app-toc-home-v2.component.scss'],\n  // tslint:disable-next-line: use-component-view-encapsulation\n  encapsulation: ViewEncapsulation.None,\n})\nexport class AppTocHomeV2Component implements OnInit, OnDestroy, AfterViewChecked, AfterViewInit {\n  queryParamsData: { [key: string]: string } = {}; // Initialize queryParamsData\n  show = false\n  changeTab = false\n  skeletonLoader = true\n  banners: NsAppToc.ITocBanner | null = null\n  showMoreGlance = false\n  content: NsContent.IContent | null = null\n  contentReadData: NsContent.IContent | null = null\n  baseContentReadData: NsContent.IContent | null = null\n  errorCode: NsAppToc.EWsTocErrorCode | null = null\n  resumeData: any = null\n  nsCardContentData: any = NsCardContent.ACBPConst\n  batchData: NsContent.IBatchListResponse | null = null\n  currentCourseBatchId: string | null = null\n  userEnrollmentList!: NsContent.ICourse[]\n  routeSubscription: Subscription | null = null\n  pageNavbar: Partial<NsPage.INavBackground> = this.configSvc.pageNavBar\n  isCohortsRestricted = false\n  sticky = false\n  isInIframe = false\n  cbPlanEndDate: any\n  cbPlanDuration: any\n  enrolledCourseData: any\n  @Input() forPreview: any = window.location.href.includes('/public/') || window.location.href.includes('/author/') || window.location.href.includes('/preview/')\n  @Input() inputContent: any\n  @Input() displayViewBtn: any = true\n  // forPreview = window.location.href.includes('/author/')\n  analytics = this.route.snapshot.data?.pageData?.data?.analytics\n  errorWidgetData: NsWidgetResolver.IRenderConfigWithTypedData<any> = {\n    widgetType: 'errorResolver',\n    widgetSubType: 'errorResolver',\n    widgetData: {\n      errorType: 'internalServer',\n    },\n  }\n  isAuthor = false\n  authorBtnWidget: NsPage.INavLink = {\n    actionBtnId: 'feature_authoring',\n    config: {\n      type: 'mat-button',\n    },\n  }\n  tocConfig: any = null\n  primaryCategory = NsContent.EPrimaryCategory\n  courseCategory = NsContent.ECourseCategory\n  WFBlendedProgramStatus = NsContent.WFBlendedProgramStatus\n  askAuthorEnabled = true\n  trainingLHubEnabled = false\n  trainingLHubCount$?: Observable<number>\n  body: SafeHtml | null = null\n  viewMoreRelatedTopics = false\n  hasTocStructure = false\n  tocStructure: NsAppToc.ITocStructure | null = null\n  contentParents: { [key: string]: NsAppToc.IContentParentResponse[] } = {}\n  objKeys = Object.keys\n  fragment!: string\n  activeFragment = this.route.fragment.pipe(share())\n  currentFragment = 'overview'\n  showScroll!: boolean\n  showScrollHeight = 300\n  hideScrollHeight = 10\n  elementPosition: any\n  batchSubscription: Subscription | null = null\n  batchDataSubscription: Subscription | null = null\n  resumeDataSubscription: Subscription | null = null\n  translationSubscription: Subscription | null = null\n  hashmapUpdatedSubscription: Subscription | null = null\n  @ViewChild('stickyMenu', { static: true }) menuElement!: ElementRef\n  batchControl = new UntypedFormControl('', Validators.required)\n  contentProgress = 0\n  bannerUrl: SafeStyle | null = null\n  routePath = 'overview'\n  validPaths = new Set(['overview', 'contents', 'analytics'])\n  routerParamSubscription: Subscription | null = null\n  initialrouteData: any\n  actionBtnStatus = 'wait'\n  isRegistrationSupported = false\n  showIntranetMessage = false\n  firstResourceLink: { url: string; queryParams: { [key: string]: any } } | null = null\n  resumeDataLink: { url: string; queryParams: { [key: string]: any } } | null = null\n  certData: any = null\n  showTakeAssessment: NsAppToc.IPostAssessment | null = null\n  checkRegistrationSources: Set<string> = new Set([\n    'SkillSoft Digitalization',\n    'SkillSoft Leadership',\n    'Pluralsight',\n  ])\n  externalContentFetchStatus: TFetchStatus = 'done'\n  registerForExternal = false\n  isGoalsEnabled = false\n  contextId?: string\n  contextPath?: string\n  defaultSLogo = ''\n  disableEnrollBtn = false\n  isAssessVisible = false\n  isPracticeVisible = false\n  certificateOpen = false\n  breadcrumbs: any\n  historyData: any\n  courseCompleteState = 2\n  userId: any\n  userRating: any\n  dakshtaName = this.environment.dakshtaName\n  cscmsUrl = this.environment.cscmsUrl\n  showBtn = false\n  channelId: any\n  selectedBatchData: any\n  selectedBatchSubscription: any\n  serverDateSubscription: any\n  serverDate: any\n  kparray: any = []\n  enrollBtnLoading = false\n  isAcbpCourse = false\n  isAcbpClaim = false\n  courseID: any\n  isClaimed = false\n  monthlyCapExceed = false\n  isCompletedThisMonth = false\n  startDate: any\n  endDate: any\n  startDateDifference: any\n  endDateDifference: any\n  @ViewChild('rightContainer') rcElement!: ElementRef\n  @ViewChild('bannerDetails', { static: true }) bannerElem!: ElementRef\n  @ViewChild('contentSource') contentSource!: ElementRef\n  sourceEllipsis = false\n  scrollLimit = 0\n  rcElem = {\n    offSetTop: 0,\n    BottomPos: 0,\n  }\n  scrolled = false\n  pathSet = new Set()\n  canShare = false\n  enableShare = false\n  rootOrgId: any\n  certId: any\n  mobile1200: any\n  assessmentStrip: any\n  learnAdvisoryData: any\n  contentCreatorData: any = []\n  // randomlearnAdvisoryObj: any\n  // learnAdvisoryDataLength: any\n\n  private destroySubject$ = new Subject<any>()\n  timerUnsubscribe: any\n  timer: any\n  isReleventBtnHovered = false\n  SAKSHAMAI_ICON_NORMAL = '/assets/images/sakshamAI/ai-icon.svg'\n  SAKSHAMAI_ICON_LOADER = '/assets/images/sakshamAI/saksham_ai_loader.gif'\n  recommendedCoursesId = ''\n  feedbackGiven: any\n  preAssessmentCompletionStatus = false\n  fromAITutor = false\n  languageList: any = []\n  selectedLanguage: any\n  languageMapProgress: any\n  preAssessmentRequiredFlag: any = false\n  lockCertificate = false\n  private lastProgressRefreshTime: number = 0\n  private isRefreshingProgress: boolean = false\n  @HostListener('window:scroll', ['$event'])\n  handleScroll() {\n    const windowScroll = window.pageYOffset\n    if (windowScroll >= this.elementPosition - 100) {\n      this.sticky = true\n    } else {\n      this.sticky = false\n    }\n\n    if (this.scrollLimit) {\n      if ((window.scrollY + this.rcElem.BottomPos) >= this.scrollLimit) {\n        this.rcElement.nativeElement.style.position = 'sticky'\n      } else {\n        if (this.rcElement) {\n          this.rcElement.nativeElement.style.position = 'fixed'\n        }\n\n      }\n    }\n\n    // 236... (OffsetTop of right container + 104)\n    if (window.scrollY > (this.rcElem.offSetTop + 104)) {\n      this.scrolled = true\n    } else {\n      this.scrolled = false\n    }\n  }\n\n  constructor(\n    private route: ActivatedRoute,\n    private router: Router,\n    private contentSvc: WidgetContentService,\n    public tocSvc: AppTocService,\n    private loggerSvc: LoggerService,\n    private configSvc: ConfigurationsService,\n    private domSanitizer: DomSanitizer,\n    private snackBar: MatSnackBar,\n    private dialog: MatDialog,\n    private mobileAppsSvc: MobileAppsService,\n    private utilitySvc: UtilityService,\n    // private progressSvc: ContentProgressService,\n    private contentLangSvc: ContentLanguageService,\n    private actionSVC: ActionService,\n    private viewerSvc: ViewerUtilService,\n    private ratingSvc: RatingService,\n    private telemetryService: TelemetryService,\n    private translate: TranslateService,\n    private langtranslations: MultilingualTranslationsService,\n    private events: EventService,\n    // private matSnackBar: MatSnackBar,\n    private loadCheckService: LoadCheckService,\n    private handleClaimService: HandleClaimService,\n    private resetRatingsService: ResetRatingsService,\n    private timerService: TimerService,\n    public enrollSvc: WidgetEnrollService,\n    public contentLibSvc: WidgetContentLibService,\n    public dataTransferSvc: DataTransferService,\n    private matSnackbarNew: MatSnackbarNew,\n    private userServiceLib: WidgetUserServiceLib,\n    public netCoreService: NetCoreService,\n    public appTocV2Svc: AppTocV2Service,\n    private location: Location,\n    public domainConfSvc: DomainConfService,\n    @Inject('environment') public environment: any\n  ) {\n    this.historyData = history.state\n    this.handleBreadcrumbs()\n    this.mobileAppsSvc.mobileTopHeaderVisibilityStatus.next(true)\n    if (localStorage.getItem('websiteLanguage')) {\n      this.translate.setDefaultLang('en')\n      const lang = localStorage.getItem('websiteLanguage')!\n      this.translate.use(lang)\n    }\n\n    this.loadCheckService.childComponentLoaded$.subscribe(_isLoaded => {\n      // Present in app-toc-about.component\n      if (document.getElementById('ratingsDiv')) {\n        setTimeout(() => {\n          const ratingsDiv = document.getElementById('ratingsDiv') as any\n          if (ratingsDiv) {\n            this.scrollLimit = ratingsDiv.getBoundingClientRect().bottom as any\n          }\n        }, 500)\n      }\n\n      if (document.getElementById('contentContainer')) {\n        const contentDiv = document.getElementById('contentContainer') as any\n        if (contentDiv) {\n          this.scrollLimit = contentDiv.getBoundingClientRect().bottom as any\n        }\n      }\n    })\n\n    this.handleClaimService.getClaimData().subscribe((_eventData: any) => {\n      this.onClickOfClaim(_eventData)\n    })\n  }\n\n  getKarmapointsLimit() {\n    if (!this.forPreview) {\n      this.contentSvc.userKarmaPoints().subscribe((res: any) => {\n        if (res && res.kpList) {\n          const info = res.kpList.addinfo\n          if (info) {\n            this.monthlyCapExceed = JSON.parse(info).claimedNonACBPCourseKarmaQuota >= 4\n          }\n        }\n      })\n    }\n  }\n\n  isCourseCompletedOnThisMonth() {\n    const now = moment(this.serverDate).format('YYYY-MM-DD')\n    if (this.content) {\n      const courseData = this.enrolledCourseData\n      if (courseData && courseData.completionPercentage === 100 && courseData.completedOn) {\n        const completedOn = moment(courseData.completedOn).format('YYYY-MM-DD')\n        const completedMonth = moment(completedOn, 'YYYY-MM-DD').month()\n        const currentMonth = moment(now, 'YYYY-MM-DD').month()\n        this.isCompletedThisMonth = completedMonth === currentMonth\n        this.content['viewMore'] = false\n        this.content['completedOn'] = courseData.completedOn\n      }\n    }\n  }\n\n  filteredAcbpList(res: any) {\n    return res.filter((v: any) => v.identifier === this.courseID)\n  }\n\n  findACPB() {\n    const localCbp = localStorage.getItem('cbpData')\n    if (localCbp) {\n      const storeageCbp = JSON.parse(localCbp)\n      const cbp = this.filteredAcbpList(storeageCbp)\n      if (cbp.length) {\n        const acbp = 'cbPlan'\n        this.cbPlanEndDate = cbp[0].endDate\n        const sDate = dayjs(this.serverDate).format('YYYY-MM-DD')\n        const daysCount = dayjs(this.cbPlanEndDate).diff(this.serverDate, 'day')\n        this.cbPlanDuration = daysCount < 0 ? NsCardContent.ACBPConst.OVERDUE : daysCount > 29\n          ? NsCardContent.ACBPConst.SUCCESS : NsCardContent.ACBPConst.UPCOMING\n        if (acbp && this.cbPlanEndDate && acbp === 'cbPlan') {\n          this.isAcbpCourse = true\n          const eDate = dayjs(this.cbPlanEndDate).format('YYYY-MM-DD')\n          if (dayjs(sDate).isSameOrBefore(eDate)) {\n            const requestObj = {\n              request: {\n                filters: {\n                  contextType: 'Course',\n                  contextId: this.courseID,\n                },\n              },\n            }\n            this.contentSvc.getCourseKarmaPoints(requestObj).subscribe((res: any) => {\n              if (res && res.kpList) {\n                const row = res.kpList\n                if (row.addinfo) {\n                  if (JSON.parse(row.addinfo).ACBP) {\n                    this.isAcbpClaim = false\n                    this.isClaimed = true\n                  } else {\n                    this.isAcbpClaim = true\n                  }\n                } else {\n                  this.isAcbpClaim = true\n                }\n              } else {\n                this.isAcbpClaim = true\n              }\n            })\n          }\n        }\n      }\n    }\n  }\n\n  raiseTelemeteryForProvider(providerName: string, prividerId: string) {\n    this.events.raiseInteractTelemetry(\n      {\n        type: 'click',\n        id: 'btn-provider',\n      },\n      {\n        id: providerName,\n        type: prividerId,\n      },\n      {\n        pageIdExt: 'btn-provider',\n        module: WsEvents.EnumTelemetrymodules.CONTENT,\n      })\n\n  }\n\n  raiseTelemetry() {\n    this.events.raiseInteractTelemetry(\n      {\n        type: 'click',\n        subType: 'karmapoints-claim',\n        id: this.courseID,\n      },\n      {\n        id: this.courseID,\n        type: 'course',\n      },\n      {\n        pageIdExt: 'btn-acbp-claim',\n        module: WsEvents.EnumTelemetrymodules.KARMAPOINTS,\n      })\n  }\n\n  onClickOfClaim(event: any) {\n    const request = {\n      userId: this.configSvc.unMappedUser.identifier,\n      courseId: this.courseID,\n    }\n    this.raiseTelemetry()\n    this.contentSvc.claimKarmapoints(request).subscribe((res: any) => {\n      this.isClaimed = true\n      this.openSnackbar('Karma points are successfully claimed.')\n      // this.getUserEnrollmentList()\n      this.checkIfUserEnrolled()\n    }, (error: any) => {\n      this.openSnackbar('something went wrong.')\n    })\n  }\n\n  ngAfterViewInit() {\n    if (this.rcElement) {\n      this.rcElem.BottomPos = this.rcElement.nativeElement.offsetTop + this.rcElement.nativeElement.offsetHeight\n      this.rcElem.offSetTop = this.rcElement.nativeElement.offsetTop\n    }\n    // Get Time for the batch\n    this.timerUnsubscribe = this.timerService.getTimerData()\n      .pipe(takeUntil(this.destroySubject$))\n      .subscribe((_timer: any) => {\n        this.timer = _timer\n      })\n  }\n\n  handleBreadcrumbs() {\n    if (this.historyData) {\n      if (this.historyData.path === 'Search') {\n        const searchurl = `/app/globalsearch`\n        const qParam = {\n          q: this.historyData.param,\n        }\n        // tslint:disable-next-line:max-line-length\n        this.breadcrumbs = { url: 'home', titles: [{ title: 'Search', url: searchurl, queryParams: qParam }, { title: 'Details', url: 'none' }] }\n      } else if (this.historyData.path === 'competency-details') {\n        const finalUrl = `/app/learn/browse-by/competency/${this.historyData.param}`\n        // tslint:disable-next-line: max-line-length\n        this.breadcrumbs = { url: 'home', titles: [{ title: this.historyData.param, url: finalUrl }, { title: 'Details', url: 'none' }] }\n      } else if (this.historyData.path === 'all-CBP') {\n        const finalURL = `/app/learn/browse-by/provider/${this.historyData.param}`\n        this.breadcrumbs = { url: 'home', titles: [{ title: `all CBP's`, url: finalURL }, { title: 'Details', url: 'none' }] }\n      } else if (this.historyData.path === 'all-competencies') {\n        const finalUrl = `/app/learn/browse-by/competency/all-competencies`\n        // tslint:disable-next-line: max-line-length\n        this.breadcrumbs = { url: 'home', titles: [{ title: 'all competencies', url: finalUrl }, { title: 'Details', url: 'none' }] }\n      } else if (this.historyData.path === 'curatedCollections') {\n        const finalUrl = `/app/curatedCollections/home`\n        // tslint:disable-next-line: max-line-length\n        this.breadcrumbs = { url: 'home', titles: [{ title: 'curated collections', url: finalUrl }, { title: 'Details', url: 'none' }] }\n      } else {\n        // tslint:disable-next-line:max-line-length\n        this.breadcrumbs = { url: 'home', titles: [{ title: 'Learn', url: '/page/learn', icon: 'school' }, { title: 'Details', url: 'none' }] }\n      }\n    }\n  }\n\n  ngAfterViewChecked(): void {\n    try {\n      if (this.fragment) {\n        // tslint:disable-next-line: no-non-null-assertion\n        document!.querySelector(`#${this.fragment}`)!.scrollTo({\n          top: 80,\n          behavior: 'smooth',\n        })\n      }\n    } catch (e) { }\n  }\n\n  get enableAnalytics(): boolean {\n    if (this.configSvc.restrictedFeatures) {\n      return !this.configSvc.restrictedFeatures.has('tocAnalytics')\n    }\n    return false\n  }\n\n  get isResource() {\n    if (this.content) {\n      const isResource = this.content.primaryCategory === NsContent.EPrimaryCategory.KNOWLEDGE_ARTIFACT ||\n        this.content.primaryCategory === NsContent.EPrimaryCategory.RESOURCE\n        || this.content.primaryCategory === NsContent.EPrimaryCategory.PRACTICE_RESOURCE\n        || this.content.primaryCategory === NsContent.EPrimaryCategory.FINAL_ASSESSMENT\n        || this.content.primaryCategory === NsContent.EPrimaryCategory.COMP_ASSESSMENT\n        || this.content.primaryCategory === NsContent.EPrimaryCategory.OFFLINE_SESSION\n        || !(this.content.children && this.content.children.length)\n      if (isResource) {\n        this.mobileAppsSvc.sendViewerData(this.content)\n      }\n      return isResource\n    }\n    return false\n  }\n\n  get getStartDate() {\n    if (this.enrolledCourseData) {\n      const now = new Date().getTime()\n      // const batch = _.first(_.filter(this.content['batches'], { batchId: this.currentCourseBatchId }) || [])\n      const batch = this.enrolledCourseData.batch\n      this.currentCourseBatchId = batch.batchId\n      if (batch && this.currentCourseBatchId) {\n        this.startDate = (_.get(batch, 'startDate'))\n        // const parsedDate = moment(this.startDate);\n        // const dateOnly = parsedDate.clone().startOf('day');\n        const startDateTime = this.startDate && new Date(this.startDate).getTime()\n        this.startDateDifference = startDateTime - now\n        if (this.startDateDifference && this.startDateDifference > 0) {\n          const days = Math.floor(this.startDateDifference / (1000 * 60 * 60 * 24))\n          const hours = Math.floor((this.startDateDifference % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60))\n          const minutes = Math.floor((this.startDateDifference % (1000 * 60 * 60)) / (1000 * 60))\n          return (`${days} Days : ${hours} Hours : ${minutes} Minutes`)\n        }\n        return 'NA'\n      }\n      return 'NA'\n      // if (_.get(batch, 'startDate') && moment(_.get(batch, 'startDate')).isAfter()) {\n      //   return moment(_.get(batch, 'startDate')).from(now)\n      // }\n      // if (_.get(batch, 'endDate') && moment(_.get(batch, 'endDate')).isBefore()) {\n      //   return 'NA'\n      // }\n      // if (startDateTime && moment(startDateTime).isAfter())  {\n      //   return moment(startDateTime).from(now)\n      // }\n      // if (endDateTime && moment(endDateTime).isBefore()) {\n      //     return 'NA'\n      //   }\n      // return 'NA'\n    } return 'NA'\n  }\n\n  get isBatchInProgress() {\n    // if (this.content && this.content['batches']) {\n    // const batches = this.content['batches'] as NsContent.IBatch\n    // if (this.currentCourseBatchId) {\n    //   // const now = moment().format('YYYY-MM-DD HH:mm:ss')\n    //   const now = new Date().getTime()\n    //   if (this.batchData && this.batchData.content) {\n    //     const batch = _.first(_.filter(this.batchData.content, { batchId: this.currentCourseBatchId }) || [])\n    //     if (batch) {\n    //       // const startDate = moment(batch.startDate).format('YYYY-MM-DD HH:mm:ss')\n    //       // const endDate = batch.endDate ? moment(batch.endDate).format('YYYY-MM-DD HH:mm:ss') : now\n    //       // return (\n    //       //   // batch.status &&\n    //       //   moment(startDate).isSameOrBefore(now)\n    //       //   && moment(endDate).isSameOrAfter(now)\n    //       // )\n    //       this.startDate = batch && (_.get(batch, 'startTime'))\n    //       this.endDate = batch && (_.get(batch, 'endTime'))\n    //       const endDateTime = new Date(this.endDate).getTime()\n    //       this.endDateDifference = endDateTime - now\n    //       if(this.endDateDifference > 0) {\n    //       return  batch.status\n    //       }\n    //     }\n    //     return false\n    //   }\n    //   return false\n    // } return false\n\n    if (this.enrolledCourseData) {\n      const now = new Date().getTime()\n      const batch = this.enrolledCourseData.batch\n      this.currentCourseBatchId = batch.batchId\n      if (batch && this.currentCourseBatchId) {\n        this.startDate = (_.get(batch, 'startDate'))\n        this.endDate = (_.get(batch, 'endDate'))\n        if (this.endDate) {\n          const startDateTime = this.startDate && new Date(this.startDate).getTime()\n          let endDate = this.endDate && new Date(this.endDate)\n          endDate.setHours(23, 59, 59, 999)\n          const endDateTime = endDate.getTime()\n          this.startDateDifference = now - startDateTime\n          this.endDateDifference = endDateTime - now\n          if (this.endDateDifference > 0 && this.startDateDifference > 0 && batch.status !== 2) {\n            return true\n          }\n          return false\n        }\n        return true\n      }\n      return false\n    }\n    return false\n  }\n\n\n\n  getUserRating(fireUpdate: boolean) {\n    if (!this.forPreview) {\n      if (this.configSvc.userProfile) {\n        this.userId = this.configSvc.userProfile.userId || ''\n      }\n      if (this.content && this.content.identifier && this.content.primaryCategory) {\n        this.ratingSvc.getRating(this.content.identifier, this.content.primaryCategory, this.userId).subscribe(\n          (res: any) => {\n\n            if (res && res.result && res.result.response) {\n              this.userRating = res.result.response\n              if (fireUpdate) {\n                this.tocSvc.changeUpdateReviews(true)\n              }\n            }\n            this.contentViewEventForNetCore('view')\n          },\n          (err: any) => {\n            this.loggerSvc.error('USER RATING FETCH ERROR >', err)\n          }\n        )\n      }\n    }\n\n    setTimeout(() => {\n      if (this.contentSource && this.contentSource.nativeElement.offsetHeight > 44) {\n        this.sourceEllipsis = true\n      }\n    }, 250)\n  }\n\n\n\n  public fetchUserWFForBlended() {\n    const applicationIds = (this.batchData && this.batchData.content && this.batchData.content.map(e => e.batchId)) || []\n    const req = {\n      applicationIds,\n      serviceName: 'blendedprogram',\n      limit: 100,\n      offset: 0,\n    }\n\n    this.contentSvc.fetchBlendedUserWF(req).then(\n      (data: any) => {\n        if (data && data.result && data.result.data.length) {\n          const latestWF = _.maxBy(data.result.data[0].wfInfo, (el: any) => {\n            return new Date(el.lastUpdatedOn).getTime()\n          })\n          // latestWF.currentStatus = this.WFBlendedProgramStatus.REJECTED\n          /* tslint:disable-next-line */\n          this.batchData!.workFlow = {\n            wfInitiated: true,\n            /* tslint:disable-next-line */\n            batch: this.batchData && this.batchData.content && this.batchData.content.find((e: any) => e.batchId === latestWF.applicationId),\n            wfItem: latestWF,\n          }\n          this.tocSvc.setWFData(this.batchData)\n        }\n\n        this.loggerSvc.info('fetchBlendedUserWF data == ', data)\n      },\n      (error: any) => {\n        this.loggerSvc.error('CONTENT HISTORY FETCH ERROR >', error)\n      },\n    )\n  }\n\n  public checkIfBatchExists(latest: any) {\n    if (!this.batchData || !this.batchData.content) {\n      return false\n    }\n    return this.batchData.content.find(b => b.batchId === latest.batchId)\n  }\n\n  public getBatchId(): string {\n    let batchId = ''\n    if (this.batchData && this.batchData.content) {\n      for (const batch of this.batchData.content) {\n        batchId = batch.batchId\n      }\n    }\n    return batchId\n  }\n\n\n  public handleAutoBatchAssign() {\n    if (this.forPreview) {\n      this.navigateToPlayerPage('')\n    } else {\n      this.enrollBtnLoading = true\n      this.changeTab = !this.changeTab\n      this.raiseEnrollTelemetry()\n      if (this.recommendedCoursesId) {\n        this.raiseEnrollTelementryForSakshamAIGenerated()\n      }\n      if (this.recommendedCoursesId) {\n        this.raiseEnrollTelementryForSakshamAIGenerated()\n      }\n      const batchData = this.contentReadData && this.contentReadData.batches && this.contentReadData.batches[0]\n      if (this.content && this.content.primaryCategory === NsContent.EPrimaryCategory.CURATED_PROGRAM) {\n        this.autoEnrollCuratedProgram(NsContent.ECourseCategory.CURATED_PROGRAM, batchData)\n      } else if (this.content && this.content.courseCategory === NsContent.ECourseCategory.MODERATED_PROGRAM) {\n        let moderatedBatchData: any\n        if (this.batchData && this.batchData.content && this.batchData.content.length > 1) {\n          moderatedBatchData = this.selectedBatchData && this.selectedBatchData.content && this.selectedBatchData.content[0]\n        } else {\n          moderatedBatchData = this.batchData && this.batchData.content && this.batchData.content[0]\n        }\n        this.autoEnrollCuratedProgram(NsContent.ECourseCategory.MODERATED_PROGRAM, moderatedBatchData)\n      } else if (this.content.courseCategory === NsContent.ECourseCategory.LEARNING_PATHWAY) {\n        this.autoEnrollLearningPathway(batchData)\n      } else {\n        this.autoAssignEnroll()\n      }\n    }\n    this.contentViewEventForNetCore('enroll')\n  }\n\n  public autoEnrollLearningPathway(batchData: any) {\n    let batchId = batchData?.batchId\n    if (batchId) {\n      this.contentSvc.autoEnrollLP(this.content?.identifier).subscribe((res: any) => {\n        if (res) {\n          this.navigateToPlayerPage(batchId)\n          this.enrollBtnLoading = false\n        }\n      }, (err: any) => {\n        let errMsg = err?.error?.params?.errmsg || err?.params?.errmsg || 'Something went wrong'\n        if (errMsg?.includes('course.') && this.content?.courseCategory) {\n          errMsg = errMsg.replace('course.', this.content?.courseCategory) + '.';\n        }\n        this.snackBar.open(errMsg)\n        this.enrollBtnLoading = false\n      })\n    } else {\n      this.snackBar.open('No batches found')\n      this.enrollBtnLoading = false\n    }\n  }\n\n  public autoEnrollCuratedProgram(programType: any, batchData: any) {\n    if (!batchData) {\n      this.enrollBtnLoading = false\n      this.snackBar.open('No bacthes found')\n      return\n    }\n    if (this.content && this.content.identifier) {\n      let userId = ''\n      if (this.configSvc.userProfile && this.configSvc.userProfile.userId) {\n        userId = this.configSvc.userProfile.userId\n      }\n      const req = {\n        request: {\n          userId,\n          programId: this.content.identifier,\n          // as of now curated program only one batch is coming need to check and modify\n          batchId: batchData?.batchId,\n        },\n      }\n      this.contentSvc.autoAssignCuratedBatchApi(req, programType).subscribe(\n        (data: NsContent.IBatchListResponse) => {\n          if (data) {\n            if (programType === NsContent.ECourseCategory.MODERATED_PROGRAM && batchData.endDate) {\n              this.batchData = {\n                content: [batchData],\n                enrolled: true,\n              }\n              this.routerChangeHandler(true)\n              setTimeout(() => {\n                // this.getUserEnrollmentList()\n                this.checkIfUserEnrolled()\n              }, 2000)\n            } else {\n              this.navigateToPlayerPage(req.request.batchId)\n            }\n          }\n        },\n        (_error: any) => {\n          // console.log('_error', _error)\n          // if(_error && _error.error && _error.error.params && _error.error.params.err && _error.error.params.err.errmsg) {\n          this.snackBar.open(_.get(_error, 'error.params.errmsg') || 'Please try again later')\n          // }\n          this.enrollBtnLoading = false\n        }\n      )\n    }\n  }\n\n  public autoAssignEnroll() {\n/*************  ✨ Windsurf Command ⭐  *************/\n  /**\n   * If the user is not enrolled in the course, auto-assigns a batch and navigates to the player page.\n   * If the user is already enrolled, does nothing.\n   */\n/*******  6d94c646-254c-44d6-a7c3-90bdb9507318  *******/    if (this.baseContentReadData && this.baseContentReadData.identifier) {\n      this.contentSvc.autoAssignBatchApi(this.baseContentReadData.identifier, this.selectedLanguage).subscribe(\n        (data: NsContent.IBatchListResponse) => {\n          this.batchData = {\n            content: data.content,\n            enrolled: true,\n          }\n          const batchId = this.getBatchId()\n          if (batchId) {\n            this.navigateToPlayerPage(batchId)\n          }\n          // this.enrollBtnLoading = false\n        },\n        (_error: any) => {\n          this.snackBar.open(_.get(_error, 'error.params.errmsg') || 'Please try again later')\n          this.enrollBtnLoading = false\n        }\n      )\n    }\n  }\n\n  async navigateToPlayerPage(batchId: string) {\n    if (this.content) {\n      this.enrollBtnLoading = true\n      let firstPlayableContent\n      if (this.content && this.content.identifier === this.selectedLanguage.identifier) {\n        firstPlayableContent = this.contentSvc.getFirstChildInHierarchy(this.content)\n      } else {\n        // fetch hierarchy for the selected language in popup first, then get first playable content and redirect to it\n        await this.fetchContentHierarchy(this.selectedLanguage.identifier)\n        firstPlayableContent = this.contentSvc.getFirstChildInHierarchy(this.content)\n      }\n      let primaryCategory\n      if (this.content.secureSettings !== undefined) {\n        primaryCategory = 'Learning Resource'\n      } else {\n        primaryCategory = firstPlayableContent.primaryCategory || this.content.primaryCategory\n      }\n      this.firstResourceLink = this.getResumeUrl(firstPlayableContent, batchId, primaryCategory)\n      this.router.navigate([`${this.firstResourceLink.url}`], { queryParams: { ...this.firstResourceLink.queryParams, fromAITutor: this.fromAITutor } })\n    }\n  }\n\n  public fetchBatchDetails() {\n    if (this.content && this.content.identifier) {\n      const req = {\n        request: {\n          filters: {\n            courseId: this.content.identifier,\n            status: ['0', '1', '2'],\n            // createdBy: 'fca2925f-1eee-4654-9177-fece3fd6afc9',\n          },\n          sort_by: { createdDate: 'desc' },\n        },\n      }\n      this.contentSvc.fetchCourseBatches(req).subscribe(\n        (data: NsContent.IBatchListResponse) => {\n          this.batchData = data\n          this.batchData.enrolled = false\n          this.tocSvc.setBatchData(this.batchData)\n          this.routerChangeHandler(false)\n        },\n        (error: any) => {\n          this.loggerSvc.error('CONTENT HISTORY FETCH ERROR >', error)\n        },\n      )\n    }\n  }\n\n\n  scrollToTop() {\n    (function smoothscroll() {\n      const currentScroll = document.documentElement.scrollTop || document.body.scrollTop\n      if (currentScroll > 0) {\n        // window.requestAnimationFrame(smoothscroll)\n        // window.scrollTo(0, currentScroll - (currentScroll / 5))\n        window.scrollTo({\n          top: 0,\n          behavior: 'smooth',\n        })\n      }\n    })()\n  }\n\n  public getCompetencies(competencies: any) {\n    const competenciesArray = JSON.parse(competencies)\n    const competencyStringArray: any[] = []\n    competenciesArray.map((c: any) => {\n      competencyStringArray.push(c.name)\n    })\n    return competencyStringArray\n  }\n\n  get showIntranetMsg() {\n    if (this.isMobile) {\n      return true\n    }\n    return this.showIntranetMessage\n  }\n\n  get showStart() {\n    return this.tocSvc.showStartButton(this.content)\n  }\n\n  get isPostAssessment(): boolean {\n    if (!(this.tocConfig && this.tocConfig.postAssessment)) {\n      return false\n    }\n    if (this.content) {\n      return (\n        this.content.primaryCategory === NsContent.EPrimaryCategory.COURSE &&\n        this.content.learningMode === 'Instructor-Led'\n      )\n    }\n    return false\n  }\n\n  get isMobile(): boolean {\n    return this.utilitySvc.isMobile\n  }\n\n  get showSubtitleOnBanner() {\n    return this.tocSvc.subtitleOnBanners\n  }\n\n  public handleEnrollmentEndDate(batch: any) {\n    const enrollmentEndDate = dayjs(_.get(batch, 'enrollmentEndDate')).format('YYYY-MM-DD')\n    const systemDate = dayjs()\n    return enrollmentEndDate ? dayjs(enrollmentEndDate).isBefore(systemDate) : false\n  }\n\n  private openSnackbar(primaryMsg: string, duration: number = 5000) {\n    this.snackBar.open(primaryMsg, 'X', {\n      duration,\n    })\n  }\n\n  get showInstructorLedMsg() {\n    return (\n      this.showActionButtons &&\n      this.content &&\n      this.content.learningMode === 'Instructor-Led' &&\n      !this.content.children.length &&\n      !this.content.artifactUrl\n    )\n  }\n\n  get isHeaderHidden() {\n    return this.isResource && this.content && !this.content.artifactUrl.length\n  }\n\n  get showActionButtons() {\n    return (\n      this.actionBtnStatus !== 'wait' &&\n      this.content &&\n      this.content.status !== 'Deleted' &&\n      this.content.status !== 'Expired'\n    )\n  }\n\n  get showButtonContainer() {\n    return (\n      this.actionBtnStatus === 'grant' &&\n      !(this.isMobile && this.content && this.content.isInIntranet) &&\n      !(\n        this.content &&\n        this.content.contentType === 'Course' &&\n        this.content.children.length === 0 &&\n        !this.content.artifactUrl\n      ) &&\n      !(this.content && this.content.contentType === 'Resource' && !this.content.artifactUrl)\n    )\n  }\n\n  private getResumeDataFromList(type?: string): any | void {\n    const resumeCopy = [...this.resumeData]\n    if (resumeCopy && resumeCopy.length) {\n      if (!type) {\n        // tslint:disable-next-line:max-line-length\n\n        const lastItem = resumeCopy && resumeCopy.sort((a: any, b: any) =>\n          new Date(b.lastAccessTime).getTime() - new Date(a.lastAccessTime).getTime()).shift()\n        return {\n          identifier: lastItem.contentId,\n          mimeType: lastItem.progressdetails && lastItem.progressdetails.mimeType,\n        }\n      }\n      const firstItem = resumeCopy && resumeCopy.length && resumeCopy[0]\n      return {\n        identifier: firstItem.contentId,\n        mimeType: firstItem.progressdetails && firstItem.progressdetails.mimeType,\n      }\n    }\n    return {}\n  }\n\n  private modifySensibleContentRating() {\n    if (\n      this.content &&\n      this.content.averageRating &&\n      typeof this.content.averageRating !== 'number'\n    ) {\n      this.content.averageRating = (this.content.averageRating as any)[this.configSvc.rootOrg || '']\n    }\n    if (this.content && this.content.totalRating && typeof this.content.totalRating !== 'number') {\n      this.content.totalRating = (this.content.totalRating as any)[this.configSvc.rootOrg || '']\n    }\n  }\n\n  private getLearningUrls() {\n    if (this.content) {\n      this.isPracticeVisible = Boolean(\n        this.tocSvc.filterToc(this.content, NsContent.EFilterCategory.PRACTICE),\n      )\n\n      this.isAssessVisible = Boolean(\n        this.tocSvc.filterToc(this.content, NsContent.EFilterCategory.ASSESS),\n      )\n\n      const firstPlayableContent = this.contentSvc.getFirstChildInHierarchy(this.content)\n      let primaryCategory\n      if (this.content.secureSettings !== undefined) {\n        primaryCategory = 'Learning Resource'\n      } else {\n        primaryCategory = firstPlayableContent.primaryCategory || this.content.primaryCategory\n      }\n      this.firstResourceLink = this.getResumeUrl(firstPlayableContent, null, primaryCategory)\n\n      /* tslint:disable-next-line */\n      // if (firstPlayableContent.optionalReading && firstPlayableContent.primaryCategory === 'Learning Resource') {\n      //   this.updateProgress(2, firstPlayableContent.identifier)\n      // }\n    }\n  }\n\n  private assignPathAndUpdateBanner(url: string) {\n    const path = url.split('/').pop()\n    if (path && this.validPaths.has(path)) {\n      this.routePath = path\n      this.updateBannerUrl()\n    }\n  }\n\n  private updateBannerUrl() {\n    if (this.banners) {\n      this.bannerUrl = this.domSanitizer.bypassSecurityTrustStyle(\n        `url(${this.banners[this.routePath]})`,\n      )\n    }\n  }\n\n  playIntroVideo() {\n    if (this.content) {\n      this.dialog.open(AppTocDialogIntroVideoComponent, {\n        data: this.content.introductoryVideo,\n        height: '350px',\n        width: '620px',\n      })\n    }\n  }\n\n  get sanitizedIntroductoryVideoIcon() {\n    if (this.content && this.content.introductoryVideoIcon) {\n      return this.domSanitizer.bypassSecurityTrustStyle(`url(${this.content.introductoryVideoIcon})`)\n    }\n    return null\n  }\n\n  private fetchExternalContentAccess() {\n    if (this.content && this.content.registrationUrl) {\n      if (!this.forPreview) {\n        this.externalContentFetchStatus = 'fetching'\n        this.registerForExternal = false\n        this.tocSvc.fetchExternalContentAccess(this.content.identifier).subscribe(\n          data => {\n            this.externalContentFetchStatus = 'done'\n            this.registerForExternal = data.hasAccess\n          },\n          _error => {\n            this.externalContentFetchStatus = 'done'\n            this.registerForExternal = false\n          },\n        )\n      } else {\n        this.externalContentFetchStatus = 'done'\n        this.registerForExternal = true\n      }\n    }\n  }\n\n  getRatingIcon(ratingIndex: number): 'star' | 'star_border' | 'star_half' {\n    if (this.content && this.content.averageRating) {\n      const avgRating = this.content.averageRating\n      const ratingFloor = Math.floor(avgRating)\n      if (ratingIndex <= ratingFloor) {\n        return 'star'\n      }\n      if (ratingFloor === ratingIndex - 1 && avgRating % 1 > 0) {\n        return 'star_half'\n      }\n    }\n    return 'star_border'\n  }\n\n  private checkRegistrationStatus() {\n    const source = (this.content && this.content.sourceShortName) || ''\n    if (\n      !this.forPreview &&\n      !this.isRegistrationSupported &&\n      this.checkRegistrationSources.has(source)\n    ) {\n      this.contentSvc\n        .getRegistrationStatus(source)\n        .then(res => {\n          if (res.hasAccess) {\n            this.actionBtnStatus = 'grant'\n          } else {\n            this.actionBtnStatus = 'reject'\n            if (res.registrationUrl && this.content) {\n              this.content.registrationUrl = res.registrationUrl\n            }\n          }\n        })\n        .catch(_err => { })\n    } else {\n      this.actionBtnStatus = 'grant'\n    }\n  }\n\n  generateQuery(type: 'RESUME' | 'START_OVER' | 'START'): { [key: string]: string } {\n    if (this.firstResourceLink && (type === 'START' || type === 'START_OVER')) {\n      let qParams: { [key: string]: string } = {\n        ...this.firstResourceLink.queryParams,\n        viewMode: type,\n        batchId: this.getBatchId(),\n      }\n      if (this.contextId && this.contextPath) {\n        qParams = {\n          ...qParams,\n          collectionId: this.contextId,\n          collectionType: this.contextPath,\n        }\n      }\n      if (this.forPreview) {\n        delete qParams.viewMode\n      }\n      qParams = {\n        ...qParams,\n        channelId: this.channelId,\n      }\n      return qParams\n    }\n\n    if (this.resumeDataLink && type === 'RESUME') {\n      let qParams: { [key: string]: string } = {\n        ...this.resumeDataLink.queryParams,\n        batchId: this.getBatchId(),\n        viewMode: 'RESUME',\n        // courseName: this.content ? this.content.name : '',\n      }\n      if (this.contextId && this.contextPath) {\n        qParams = {\n          ...qParams,\n          collectionId: this.contextId,\n          collectionType: this.contextPath,\n        }\n      }\n      if (this.forPreview) {\n        delete qParams.viewMode\n      }\n      qParams = {\n        ...qParams,\n        channelId: this.channelId,\n      }\n      return qParams\n    }\n    if (this.forPreview) {\n      return {}\n    }\n    return {\n      batchId: this.getBatchId(),\n      viewMode: type,\n    }\n  }\n\n  get isInIFrame(): boolean {\n    try {\n      return window.self !== window.top\n    } catch (e) {\n      return true\n    }\n  }\n\n  openFeedbackDialog(content: any): void {\n    const dialogRef = this.dialog.open(ContentRatingV2DialogComponent, {\n      width: '768px',\n      data: { content, userId: this.userId, userRating: this.userRating },\n    })\n\n    dialogRef.afterClosed().subscribe((result: any) => {\n      if (result) {\n        this.getUserRating(true)\n        // this.getUserEnrollmentList()\n        this.checkIfUserEnrolled()\n        this.resetRatingsService.setRatingServiceUpdate(true)\n      }\n    })\n  }\n\n  updateProgress(status: number, resourceId: any) {\n    const collectionId = this.route.snapshot.params.id ?\n      this.route.snapshot.params.id : ''\n    const batchId = this.route.snapshot.queryParams.batchId ?\n      this.route.snapshot.queryParams.batchId : ''\n    const isPreAssessment = this.route.snapshot.queryParams.preAssessment\n    if (isPreAssessment) {\n      return this.viewerSvc\n        .realTimeProgressUpdateForPreAssessmentQuiz(resourceId, status)\n\n    }\n    return this.viewerSvc.realTimeProgressUpdateQuiz(resourceId, collectionId, batchId, status)\n  }\n\n  getProgramDuration(batchData: any) {\n    if (batchData) {\n      const startDate = dayjs(dayjs(batchData.startDate).format('YYYY-MM-DD'))\n      const endDate = dayjs(dayjs(batchData.endDate).format('YYYY-MM-DD'))\n      // adding 1 to include the start date\n      return (endDate.diff(startDate, 'days') + 1)\n    }\n    return ''\n  }\n\n  withdrawOrEnroll(data: string) {\n    if (data === NsContent.WFBlendedProgramStatus.INITIATE) {\n      this.fetchUserWFForBlended()\n    }\n  }\n\n\n\n  handleCapitalize(str: string, type?: string): string {\n    let returnValue = ''\n    if (str) {\n      if (type === 'name') {\n        returnValue = str.split(' ').map(_str => {\n          return _str.charAt(0).toUpperCase() + _str.slice(1)\n        }).join(' ')\n      } else {\n\n        returnValue = str && (str.charAt(0).toUpperCase() + str.slice(1))\n      }\n    }\n    return returnValue\n  }\n\n  public handleParseJsonData(s: any) {\n    try {\n      const parsedString = JSON.parse(s)\n      return parsedString\n    } catch {\n      return []\n    }\n  }\n\n  handleNavigateToReviews(): void {\n    const elementToView = document.getElementById('reviewContainer') as any\n\n    if (elementToView) {\n      window.scrollTo({\n        top: elementToView.offsetTop,\n        behavior: 'smooth',\n      })\n    }\n  }\n\n  raiseCertIntreactTelemetry() {\n    this.events.raiseInteractTelemetry(\n      {\n        type: WsEvents.EnumInteractTypes.CLICK,\n        id: 'view-certificate',\n        subType: WsEvents.EnumInteractSubTypes.CERTIFICATE,\n      },\n      {\n        id: this.certId,   // id of the certificate\n        type: WsEvents.EnumInteractSubTypes.CERTIFICATE,\n      })\n  }\n\n  translateLabels(label: string, type: any) {\n    return this.langtranslations.translateLabel(label, type, '')\n  }\n\n\n\n  getLastPlayedResource() {\n    let firstPlayableContent\n    let resumeDataV2: any\n    if (this.resumeData && this.resumeData.length > 0 && this.content) {\n      if (this.content.completionPercentage === 100) {\n        resumeDataV2 = this.getResumeDataFromList('start')\n      } else {\n        resumeDataV2 = this.getResumeDataFromList()\n      }\n      this.expandThePath(resumeDataV2.identifier)\n    } else {\n      if (this.content) {\n        firstPlayableContent = this.contentSvc.getFirstChildInHierarchy(this.content)\n        this.expandThePath(firstPlayableContent.identifier)\n\n      }\n    }\n  }\n\n  expandThePath(resourceId: string) {\n    if (this.content && resourceId) {\n      const path = this.utilitySvc.getPath(this.content, resourceId)\n      this.pathSet = new Set(path.map((u: { identifier: any }) => u.identifier))\n    }\n  }\n\n  raiseEnrollTelemetry() {\n    this.events.raiseInteractTelemetry(\n      {\n        type: 'click',\n        subType: 'enroll',\n        id: this.content ? this.content.identifier : '',\n      },\n      {\n        id: this.content ? this.content.identifier : '',\n        type: this.content ? this.content.primaryCategory : '',\n      },\n      {\n        pageIdExt: `btn-enroll`,\n        module: WsEvents.EnumTelemetrymodules.CONTENT,\n      }\n    )\n  }\n\n  raiseEnrollTelementryForSakshamAIGenerated() {\n    this.events.raiseInteractTelemetry(\n      {\n        type: 'click',\n        subType: 'enroll',\n        id: this.content ? this.content.identifier : '',\n        target: {\n          id: this.recommendedCoursesId,\n          ver: \"1.0\",\n          type: \"igot-ai\"\n        },\n      } as any,\n      {\n        id: this.content ? this.content.identifier : '',\n        type: this.content ? this.content.primaryCategory : '',\n      },\n      {\n        pageId: `/app/toc/${this.content?.identifier}/overview_btn-enroll`,\n        module: WsEvents.EnumTelemetrymodules.CONTENT,\n      }\n    )\n  }\n\n  onClickOfShare() {\n    this.enableShare = true\n    this.raiseTelemetryForShare('shareContent')\n  }\n\n  /* tslint:disable */\n  raiseTelemetryForShare(subType: any) {\n    this.events.raiseInteractTelemetry(\n      {\n        type: 'click',\n        subType,\n        id: this.content ? this.content.identifier : '',\n      },\n      {\n        id: this.content ? this.content.identifier : '',\n        type: this.content ? this.content.primaryCategory : '',\n      },\n      {\n        pageIdExt: `btn-${subType}`,\n        module: WsEvents.EnumTelemetrymodules.CONTENT,\n      }\n    )\n  }\n\n  resetEnableShare() {\n    this.enableShare = false\n  }\n\n  translateLabel(label: string, type: any) {\n    if (label && type) {\n      return this.langtranslations.translateLabel(label, type, '')\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.routeSubscription) {\n      this.routeSubscription.unsubscribe()\n    }\n    if (this.batchSubscription) {\n      this.batchSubscription.unsubscribe()\n    }\n    if (this.batchDataSubscription) {\n      this.batchDataSubscription.unsubscribe()\n    }\n    this.tocSvc.analyticsFetchStatus = 'none'\n    if (this.routerParamSubscription) {\n      this.routerParamSubscription.unsubscribe()\n    }\n    if (this.selectedBatchSubscription) {\n      this.selectedBatchSubscription.unsubscribe()\n    }\n    if (this.resumeDataSubscription) {\n      this.resumeDataSubscription.unsubscribe()\n    }\n    if (this.timerUnsubscribe) {\n      this.timerUnsubscribe.unsubscribe()\n    }\n    if (this.hashmapUpdatedSubscription) {\n      this.hashmapUpdatedSubscription.unsubscribe()\n    }\n\n    // Clear content data to prevent stale data when navigating between contents\n    this.tocSvc.resetContentData()\n  }\n\n  programEnrollCall(batchData: any) {\n    this.autoEnrollCuratedProgram(NsContent.ECourseCategory.MODERATED_PROGRAM, batchData)\n  }\n\n  raiseTelemetryForPublic($event: any) {\n    // Check if we should first prevent navigation to player page\n    const shouldPreventNavigation = this.shouldShowSurveyPopup()\n    if (shouldPreventNavigation) {\n      $event.preventDefault()\n      $event.stopPropagation()\n    }\n\n    this.events.raiseInteractTelemetry(\n      {\n        type: 'click',\n        id: \"view-assessment\",\n        subType: \"anonymous-assessment\",\n      }, {},\n      {\n        module: 'Landing Page',\n      })\n\n    if (shouldPreventNavigation) {\n      // Prepare navigation details\n      const navigationUrl = (this.resumeData && !this.certData) ? this.resumeDataLink?.url : this.firstResourceLink?.url\n      const queryParams = (this.resumeData && !this.certData) ? this.generateQuery('RESUME') : this.generateQuery('START')\n\n      // Open survey popup directly with navigation details\n      if (navigationUrl) {\n        this.openPublicSurveyPopup(navigationUrl, queryParams)\n      }\n      return false\n    }\n  }\n\n  shouldShowSurveyPopup(): boolean {\n    // Single source of truth for survey popup condition\n    // Check if it's public view and content is a case study\n    return this.forPreview && this.content && this.contentReadData\n      && this.contentReadData.courseCategory === NsContent.ECourseCategory.CASE_STUDY\n  }\n\n\n  async checkIfUserEnrolled() {\n    this.contentLibSvc.oneStepResumeEnable = false\n    this.enrollBtnLoading = true\n    this.tocSvc.contentLoader.next(true)\n    // only for  resource\n    // tslint:disable-next-line\n    if (this.baseContentReadData && this.baseContentReadData.identifier && this.baseContentReadData.primaryCategory !== this.primaryCategory.COURSE &&\n      this.baseContentReadData.primaryCategory !== this.primaryCategory.PROGRAM &&\n      this.baseContentReadData.primaryCategory !== this.primaryCategory.MANDATORY_COURSE_GOAL &&\n      this.baseContentReadData.primaryCategory !== this.primaryCategory.STANDALONE_ASSESSMENT &&\n      this.baseContentReadData.primaryCategory !== this.primaryCategory.BLENDED_PROGRAM &&\n      this.baseContentReadData.primaryCategory !== this.primaryCategory.CURATED_PROGRAM) {\n      // const collectionId = this.isResource ? '' : this.baseContentReadData.identifier\n      return this.getContinueLearningData(this.baseContentReadData.identifier)\n    }\n\n    let enrolledCourse: NsContent.ICourse | undefined\n    if (this.content && this.baseContentReadData && this.baseContentReadData.identifier && !this.forPreview) {\n      if (this.userEnrollmentList && this.userEnrollmentList.length) {\n        enrolledCourse = this.userEnrollmentList.find((course: any) => {\n          const identifier = this.baseContentReadData && this.baseContentReadData.identifier || ''\n          if (course.courseId !== identifier) {\n            return undefined\n          }\n          return course\n        })\n      }\n\n      // If current course is present in the list of user enrolled course\n      if (enrolledCourse && enrolledCourse.batchId) {\n        this.resumeDataSubscription = this.tocSvc.resumeData.subscribe((res: any) => {\n          if (res) {\n            this.resumeData = res\n            this.getLastPlayedResource()\n            this.generateResumeDataLinkNew()\n          }\n        })\n        this.tocSvc.checkModuleWiseData(this.content)\n        this.enrolledCourseData = enrolledCourse\n        this.isCourseCompletedOnThisMonth()\n        this.currentCourseBatchId = enrolledCourse.batchId\n        // this.downloadCert(enrolledCourse.issuedCertificates)\n        if (enrolledCourse && enrolledCourse.issuedCertificates &&\n          enrolledCourse.issuedCertificates.length) {\n          const certificate: any = enrolledCourse.issuedCertificates.sort((a: any, b: any) =>\n            new Date(b.lastIssuedOn).getTime() - new Date(a.lastIssuedOn).getTime())\n          const certId = certificate[0].identifier\n          this.certId = certId\n          if (this.content) {\n            this.content['certificateObj'] = {\n              certId,\n              certData: '',\n            }\n          }\n        }\n        // if enrolled course is completed then to make all languages courses as well as all content as completed\n        if (this.contentReadData.courseCategory !== NsContent.ECourseCategory.LEARNING_PATHWAY && enrolledCourse.status === 2) {\n          this.content['completionPercentage'] = 100\n          this.content['completionStatus'] = 2\n          await this.tocSvc.mapCompletionChildPercentageProgram(this.content)\n          let contentLag = this.contentLangSvc.getContentLanguage(this.contentReadData)\n          this.getContinueLearningData(this.baseContentReadData.identifier, enrolledCourse.batchId, contentLag)\n          this.enrollBtnLoading = false\n          this.tocSvc.mapModuleCount(this.content)\n          this.checkForCompletionSurveyTrigger()\n        } else {\n          if (this.contentReadData && this.contentReadData.cumulativeTracking && this.contentReadData.courseCategory !== NsContent.ECourseCategory.LEARNING_PATHWAY) {\n            await this.tocSvc.mapCompletionPercentageProgram(this.content, this.userEnrollmentList)\n            this.checkForCompletionSurveyTrigger()\n            this.resumeDataSubscription = this.tocSvc.resumeData.subscribe((res: any) => {\n              if (res) {\n                this.resumeData = res\n                this.getLastPlayedResource()\n                this.generateResumeDataLinkNew()\n              }\n            })\n\n            this.enrollBtnLoading = false\n            // this.tocSvc.contentLoader.next(false)\n          } else {\n            if (this.contentReadData && this.contentReadData.courseCategory !== NsContent.ECourseCategory.LEARNING_PATHWAY) {\n              let contentLag = this.contentLangSvc.getContentLanguage(this.contentReadData)\n              this.getContinueLearningData(this.baseContentReadData.identifier, enrolledCourse.batchId, contentLag)\n              this.content['completionPercentage'] = enrolledCourse.completionPercentage\n              this.tocSvc.mapModuleCount(this.content)\n            }\n            this.enrollBtnLoading = false\n            // this.tocSvc.contentLoader.next(false)\n          }\n        }\n        if (this.baseContentReadData?.courseCategory === NsContent.ECourseCategory.LEARNING_PATHWAY) {\n          // this.appTocV2Svc.mapContentHierarchyProgressUpdate(this.content,this.userEnrollmentList)\n          console.log('mapping progress for learning pathway', this.content)\n          this.tocSvc.callHirarchyProgressHashmap(this.content)\n          console.log('mapped progress for learning pathway', this.tocSvc.hashmap)\n          this.tocSvc.computeMilestoneLockingStatus(true)\n          this.syncMilestoneLockStatus()\n\n        }\n        this.batchData = {\n          content: [enrolledCourse.batch],\n          enrolled: true,\n        }\n        this.tocSvc.setBatchData(this.batchData)\n        this.tocSvc.getSelectedBatchData(this.batchData)\n        this.tocSvc.mapSessionCompletionPercentage(this.batchData, this.resumeData)\n        this.routerChangeHandler(true)\n        this.tocSvc.contentLoader.next(false)\n      } else {\n        this.tocSvc.checkModuleWiseData(this.content)\n        this.tocSvc.mapModuleCount(this.content)\n        // It's understood that user is not already enrolled\n        // Fetch the available batches and present to user\n        if (this.content.primaryCategory === this.primaryCategory.COURSE\n          || this.content.primaryCategory !== this.primaryCategory.PROGRAM) {\n          // Disabling auto enrollment to batch\n          if (this.content.primaryCategory === this.primaryCategory.BLENDED_PROGRAM) {\n            this.fetchBatchDetails()\n          }\n        } else {\n          this.fetchBatchDetails()\n        }\n        this.tocSvc.callHirarchyProgressHashmap(this.content)\n        // For Learning Pathways, compute milestone locking when not enrolled (all locked)\n        if (this.baseContentReadData?.courseCategory === NsContent.ECourseCategory.LEARNING_PATHWAY) {\n          this.tocSvc.computeMilestoneLockingStatus(false)\n          this.syncMilestoneLockStatus()\n        }\n        this.enrollBtnLoading = false\n        this.tocSvc.contentLoader.next(false)\n      }\n    }\n\n    this.skeletonLoader = false\n  }\n\n  bindCompletionPercentage() {\n    let completionPercentage = 0\n    let completionStatus = 0\n    if (this.languageMapProgress && Object.keys(this.languageMapProgress).length) {\n      let langPercentage = this.languageMapProgress[this.selectedLanguage.langId] || 0\n      completionPercentage = langPercentage\n      completionStatus = langPercentage >= 100 ? 2 : 0\n    } else {\n      let enrolledData = this.tocSvc.findEnrolmentByCollectionId(this.userEnrollmentList, (this.baseContentReadData?.identifier || ''))\n      if (enrolledData && enrolledData.completionPercentage) {\n        completionPercentage = enrolledData.completionPercentage\n        completionStatus = enrolledData.status\n      }\n    }\n\n    if (this.content) {\n      this.content.completionPercentage = completionPercentage\n      this.content.completionStatus = completionStatus\n    }\n  }\n\n  handleAcceptRelevent() {\n    this.saveFeedback('', 1)\n  }\n\n  handleDeclineRelevent() {\n    const dialogRef = this.dialog.open(NonReleventFeedbackDialogComponent, {\n      disableClose: true,\n      width: '502px',\n      panelClass: ['relevent-feedback-dialog'],\n    })\n    dialogRef.afterClosed().subscribe((result: any) => {\n      if (result) {\n        this.saveFeedback(result, 0)\n        dialogRef.close()\n      } else {\n        dialogRef.close()\n      }\n    })\n  }\n\n  contentViewEventForNetCore(eventType: any) {\n    if (this.configSvc.netcoreConfig && this.configSvc.netcoreConfig.netcoreWebConfig  // NOSONAR\n      && this.configSvc.netcoreConfig.netcoreWebConfig.isActive // NOSONAR\n      && this.configSvc.netcoreConfig.netcoreWebConfig.events // NOSONAR\n      && this.configSvc.netcoreConfig.netcoreWebConfig.events.content_view // NOSONAR\n      && this.configSvc.netcoreConfig.netcoreWebConfig.events.content_view.isActive // NOSONAR\n    ) {\n      let payload: any = {}\n      // if (this.configSvc && this.configSvc.unMappedUser && this.configSvc.unMappedUser.identifier) { // NOSONAR\n      //   payload['pk^userid'] = this.configSvc.unMappedUser.identifier.trim().toLowerCase()\n      // }\n      if (this.content && this.content.name) {\n        payload['content_name'] = this.content.name\n      }\n      if (this.content && this.content.courseCategory) {\n        payload['content_category'] = this.content.courseCategory\n      }\n      if (this.content && this.content.identifier) {\n        payload['content_id'] = this.content.identifier\n      }\n      // if(this.content && this.content.name) {\n      payload['content_url'] = window.location.href\n      // }\n      if (this.content && this.content.appIcon) {\n        payload['content_image'] = this.content.appIcon\n      }\n      if (this.content && this.content.duration) {\n        payload['content_duration'] = this.content.duration && Number(this.content.duration) > 0 ? Number(this.content.duration) : 0\n      } else {\n        payload['content_duration'] = 0\n      }\n      if (this.content && this.content.avgRating\n      ) {\n        payload['content_rating'] = this.content.avgRating\n        payload['content rating'] = this.content.avgRating\n      }\n      if (this.content && this.content.totalNoOfRating) {\n        payload['no_users_rated'] = this.content.totalNoOfRating\n      }\n      // if(this.content && this.content.name) {\n      payload['learning_path_content'] = this.userEnrollmentList && this.userEnrollmentList.length ? true : false\n      payload['learning path content'] = this.userEnrollmentList && this.userEnrollmentList.length ? true : false\n      // }\n      if (this.content && this.content.source) {\n        payload['content_provider_name'] = this.content.source\n      }\n      // console.log('payload', payload)\n      if (eventType === 'view') {\n        this.netCoreService.trackEventForContentAndEvent('content_view', this.configSvc.unMappedUser.identifier.trim().toLowerCase(), payload)\n      } else if (eventType === 'enroll') {\n        this.netCoreService.trackEventForContentAndEvent('content_enrolment', this.configSvc.unMappedUser.identifier.trim().toLowerCase(), payload)\n      } else if (eventType === 'complete') {\n        this.netCoreService.trackEventForContentAndEvent('content_completion', this.configSvc.unMappedUser.identifier.trim().toLowerCase(), payload)\n      }\n\n    }\n  }\n\n  secondsToTime(d: any) {\n    d = Number(d)\n    var h = Math.floor(d / 3600)\n    var m = Math.floor(d % 3600 / 60)\n    var s = Math.floor(d % 3600 % 60)\n\n    var hDisplay = h > 0 ? h + (h == 1 ? \" hour, \" : \" hours, \") : \"\"\n    var mDisplay = m > 0 ? m + (m == 1 ? \" minute, \" : \" minutes, \") : \"\"\n    var sDisplay = s > 0 ? s + (s == 1 ? \" second\" : \" seconds\") : \"\"\n    return hDisplay + mDisplay + sDisplay\n  }\n\n\n  async saveFeedback(comment: string, rating = 0) {\n    const payload = {\n      \"recommendation_id\": this.recommendedCoursesId,\n      \"course_id\": this.courseID,\n      \"rating\": rating,\n      \"comments\": comment,\n      \"user_id\": this.configSvc.userProfile?.userId || ''\n    }\n    const response = await this.contentLibSvc.saveFeedbackSakshamAI(payload).toPromise().catch(() => { })\n    if (response && response?.message) {\n      this.matSnackbarNew.open(\n        'Thank you for your feedback.', 'X',\n        { duration: SNACKBAR_DURATION, panelClass: ['success'] }\n      )\n      this.feedbackGiven = { course_id: this.courseID, rating: rating, comments: comment }\n\n    } else if (!response) {\n      this.matSnackbarNew.open(\n        'Something is wrong. Please try again later.', 'X',\n        { duration: SNACKBAR_DURATION, panelClass: ['error'] }\n      )\n    }\n  }\n\n  playResumeForAI() {\n    if (this.content) {\n      if (this.firstResourceLink) {\n        this.router.navigate([this.firstResourceLink.url], { queryParams: this.firstResourceLink.queryParams })\n      }\n    }\n\n  }\n\n  enrollUserToAI() {\n    this.fromAITutor = true\n    this.handleAutoBatchAssign()\n  }\n\n  openSurveyFormPopup(event: boolean) {\n    if (event) {\n      this.openCompletionSurveyFormPopup()\n    }\n  }\n\n  generatePreAssessmentQuery(type: 'RESUME' | 'START_OVER' | 'START'): { [key: string]: string } {\n    if (this.firstResourceLink && (type === 'START' || type === 'START_OVER')) {\n      let qParams: { [key: string]: string } = {\n        ...this.firstResourceLink.queryParams,\n        viewMode: type,\n        batchId: this.getBatchId(),\n      }\n      if (this.contextId && this.contextPath) {\n        qParams = {\n          ...qParams,\n          collectionId: this.contextId,\n          collectionType: this.contextPath,\n        }\n      }\n      if (this.forPreview) {\n        delete qParams.viewMode\n      }\n      qParams = {\n        ...qParams,\n        channelId: this.channelId,\n      }\n      return qParams\n    }\n\n    if (this.resumeDataLink && type === 'RESUME') {\n      let qParams: { [key: string]: string } = {\n        ...this.resumeDataLink.queryParams,\n        batchId: this.getBatchId(),\n        viewMode: 'RESUME',\n        // courseName: this.content ? this.content.name : '',\n      }\n      if (this.contextId && this.contextPath) {\n        qParams = {\n          ...qParams,\n          collectionId: this.contextId,\n          collectionType: this.contextPath,\n        }\n      }\n      if (this.forPreview) {\n        delete qParams.viewMode\n      }\n      qParams = {\n        ...qParams,\n        channelId: this.channelId,\n      }\n      return qParams\n    }\n    if (this.forPreview) {\n      return {}\n    }\n    return {\n      batchId: this.getBatchId(),\n      viewMode: type,\n    }\n  }\n\n  routeToPreAssessent() {\n    if (this.contentReadData) {\n      // this.generatePreAssessmentQuery('START')\n      let firstResource = this.contentReadData.preEnrolmentResources[0]\n      let mimeType = firstResource?.courseCategory === 'Pre Enrolment Assessment' ? 'application/vnd.sunbird.questionset' : firstResource.mimeType\n      this.firstResourceLink = viewerRouteGenerator(\n        firstResource.identifier,\n        mimeType,\n        this.contentReadData?.identifier,\n        this.contentReadData?.courseCategory,\n        this.forPreview,\n        this.contentReadData && this.contentReadData.preEnrolmentResources[0]?.primaryCategory || '',\n        '',\n      )\n      let routerLink = this.firstResourceLink?.url\n      let queryParams = this.generatePreAssessmentQuery('START')\n      queryParams = { ...queryParams, preAssessment: 'true' }\n      this.router.navigate([`${routerLink}`], { queryParams })\n    }\n  }\n\n  getPreAssessmentRequired() {\n    this.preAssessmentRequiredFlag = false\n    if (this.contentReadData?.preEnrolmentResources?.length) {\n      this.contentReadData?.preEnrolmentResources?.forEach((item: any) => {\n        if (item && item?.isMandatory) {\n          this.preAssessmentRequiredFlag = true\n        }\n      })\n    }\n  }\n\n  getPreAssessmentCompletionStatus() {\n    this.preAssessmentCompletionStatus = false\n    let preEnrollmentResourcesArr: any = []\n    let preEnrollmentMandatoryResourcesArr: any = []\n    if (this.contentReadData?.preEnrolmentResources?.length) {\n      this.contentReadData?.preEnrolmentResources?.forEach((item: any) => {\n        preEnrollmentResourcesArr.push(item?.identifier)\n        if (item && item?.isMandatory) {\n          preEnrollmentMandatoryResourcesArr.push(item?.identifier)\n        }\n      })\n    }\n    if (preEnrollmentResourcesArr && preEnrollmentResourcesArr.length) {\n      let req = {\n        \"request\": {\n          \"contentIds\": preEnrollmentResourcesArr,\n          \"fields\": [\n          ]\n        }\n      }\n      this.tocSvc.readPreEnrollmentResourcesState(req).subscribe((data: any) => {\n        let mandatoryIdsCompleted = []\n        if (data && data.result && data.result.contentList && data.result.contentList.length) {\n          for (let i = 0; i < data.result.contentList.length; i++) {\n            if (data.result.contentList[i]['status'] === 2 && preEnrollmentMandatoryResourcesArr.includes(data.result.contentList[i]['contentId'])) {\n              mandatoryIdsCompleted.push(data.result.contentList[i]['contentId'])\n            }\n          }\n          if (preEnrollmentResourcesArr?.length === data.result.contentList?.length) {\n            this.preAssessmentCompletionStatus = true\n          } else if (mandatoryIdsCompleted.length === preEnrollmentMandatoryResourcesArr.length) {\n            this.preAssessmentCompletionStatus = true\n          } else {\n            this.preAssessmentCompletionStatus = false\n          }\n        } else {\n          this.preAssessmentCompletionStatus = false\n        }\n      })\n    }\n  }\n\n  ngOnInit() {\n    this.dataTransferSvc.setEnrollData(null)\n    this.getServerDateTime()\n    this.mobile1200 = window.innerWidth < 1201\n    this.getI18NTranslations()\n    this.loadLearnerAdvisoryData()\n    this.setupSelectedBatchSubscription()\n    this.setChannelId()\n    this.checkIframeContext()\n    this.queryParamsData = this.setupRouteSubscriptions()\n    this.setupFragmentSubscription()\n    this.setupBatchSubscriptions()\n    this.configureDefaultLogo()\n    this.configureFeatureFlags()\n    this.checkRegistrationStatus()\n    this.setupRouterEventSubscription()\n    this.getContentCreatorData()\n    this.setupHashmapUpdateSubscription()\n\n    this.userId = this.configSvc?.userProfile?.userId || ''\n    this.domainConfSvc.initFromConfig(this.configSvc.globalConfig.applicationConfig)\n  }\n\n  private initData(data: Data) {\n    const initData: any = this.tocSvc.initData(data, true)\n    this.setErrorCode(initData.errorCode)\n    this.setupBatchControlSubscription()\n    this.tocSvc.contentLoader.next(false)\n  }\n\n  private setErrorCode(errorCode: NsAppToc.EWsTocErrorCode) {\n    this.errorCode = errorCode\n    switch (this.errorCode) {\n      case NsAppToc.EWsTocErrorCode.API_FAILURE:\n      case NsAppToc.EWsTocErrorCode.INVALID_DATA:\n      case NsAppToc.EWsTocErrorCode.NO_DATA:\n        this.errorWidgetData.widgetData.errorType = ErrorType.internalServer\n        break\n      default:\n        this.errorWidgetData.widgetData.errorType = ErrorType.somethingWrong\n        break\n    }\n  }\n\n\n\n  private initializeTocStructure() {\n    this.contentParents = {}\n    this.tocStructure = {\n      assessment: 0,\n      course: 0,\n      handsOn: 0,\n      interactiveVideo: 0,\n      learningModule: 0,\n      other: 0,\n      pdf: 0,\n      survey: 0,\n      podcast: 0,\n      practiceTest: 0,\n      finalTest: 0,\n      quiz: 0,\n      video: 0,\n      webModule: 0,\n      webPage: 0,\n      youtube: 0,\n      interactivecontent: 0,\n      offlineSession: 0,\n      preEnrollmentAssessment: 0,\n    }\n  }\n\n  private setupBatchControlSubscription() {\n    this.batchControl.valueChanges.subscribe((batch: NsContent.IBatch) => {\n      if (batch) {\n        this.handleBatchEnrollment(batch)\n      }\n    })\n  }\n\n  private handleBatchEnrollment(batch: NsContent.IBatch) {\n    this.disableEnrollBtn = true\n    let userId = this.configSvc.userProfile?.userId || ''\n\n    const req = {\n      request: {\n        userId,\n        courseId: batch.courseId,\n        batchId: batch.batchId,\n      },\n    }\n\n    this.contentSvc.enrollUserToBatch(req).then((datab: any) => {\n      if (datab?.result?.response === 'SUCCESS') {\n        this.handleSuccessfulEnrollment(batch)\n      } else {\n        this.handleEnrollmentFailure()\n      }\n    })\n  }\n\n  private handleSuccessfulEnrollment(batch: NsContent.IBatch) {\n    this.batchData = {\n      content: [batch],\n      enrolled: true,\n    }\n    this.tocSvc.getSelectedBatchData(this.batchData)\n    this.tocSvc.mapSessionCompletionPercentage(this.batchData)\n\n    // CRITICAL: For Learning Pathways, compute milestone locking status after enrollment\n    // This ensures milestones are properly locked until pre-assessment is completed\n    if (this.baseContentReadData?.courseCategory === 'Learning Pathway') {\n      this.tocSvc.callHirarchyProgressHashmap(this.content)\n      this.tocSvc.computeMilestoneLockingStatus(true)\n      this.syncMilestoneLockStatus()\n    }\n\n    this.routerChangeHandler(true)\n    this.openSnackbar('Enrolled Successfully!')\n    this.disableEnrollBtn = false\n  }\n\n  private handleEnrollmentFailure() {\n    this.openSnackbar('Something went wrong, please try again later!')\n    this.disableEnrollBtn = false\n  }\n\n  private loadLearnerAdvisoryData() {\n    if (this.route.snapshot.data.pageData && this.route.snapshot.data.pageData.data) {\n      this.learnAdvisoryData = this.route.snapshot.data.pageData.data.learnerAdvisory\n    }\n  }\n\n  private setupSelectedBatchSubscription() {\n    this.selectedBatchSubscription = this.tocSvc.getSelectedBatch.subscribe(batchData => {\n      this.selectedBatchData = batchData\n    })\n  }\n\n  private setChannelId() {\n    this.channelId = this.telemetryService.telemetryConfig\n      ? this.telemetryService.telemetryConfig.channel\n      : ''\n  }\n\n  private checkIframeContext() {\n    try {\n      this.isInIframe = window.self !== window.top\n    } catch (_ex) {\n      this.isInIframe = false\n    }\n  }\n\n  private setupRouteSubscriptions() {\n    let queryParamstemp: any = {}\n    if (this.route) {\n      this.skeletonLoader = true\n      this.routeSubscription = this.route.data.subscribe(async (data: Data) => {\n        if (data?.content?.data?.identifier) {\n          queryParamstemp = await this.processRouteData(data)\n        } else {\n          const tempData = {\n            content: {\n              data: this.inputContent\n            }\n          }\n          queryParamstemp = await this.processRouteData(tempData)\n        }\n      })\n    }\n    return queryParamstemp\n  }\n\n  private async processRouteData(data: Data) {\n    this.courseID = data?.content?.data?.status === 'Retired' ? '' : data.content.data?.identifier\n    const initData = this.tocSvc.initData(data, true)\n    // Get query parameters\n    const queryParamsDataTemp = await this.getQueryParams()\n    // Handle multilingual content if mlId is present in query parameters\n    if (queryParamsDataTemp.MLId) {\n      // Store the original content data for reference\n      this.baseContentReadData = initData.content\n\n      // Fetch the multilingual content\n      try {\n        if (this.baseContentReadData.identifier === queryParamsDataTemp.MLId) {\n          this.contentReadData = initData.content\n        } else {\n          const success = await this.fetchContentRead(queryParamsDataTemp.MLId)\n          if (!success) {\n            // If multilingual content fetch fails, fall back to the original content\n            this.contentReadData = initData.content\n            this.loggerSvc.warn('Failed to load multilingual content, using original content instead')\n          }\n        }\n      } catch (error) {\n        // On error, use the original content\n        this.contentReadData = initData.content\n        this.loggerSvc.error('Error loading multilingual content:', error)\n        this.snackBar.open('Failed to load content in selected language', 'X', {\n          duration: 3000,\n        })\n      }\n    } else {\n      // No multilingual content requested, use the original content\n      this.contentReadData = initData.content\n      this.baseContentReadData = initData.content\n    }\n    // Added to make sure this reference was incorrect, assigning again to make sure global variable is properly updated\n    this.queryParamsData = queryParamsDataTemp\n\n    // Continue with the rest of the processing\n    this.loadLanguageData()\n    this.getPreAssessmentCompletionStatus()\n    this.getPreAssessmentRequired()\n\n    await this.handleContentPreviewOrEnrollment()\n\n    this.initialrouteData = data\n    this.loadBannerAndTocConfig(data)\n    this.fetchPostAssessmentStatusIfNeeded()\n    this.initData(data)\n\n    // to clear public survey data if any on load,\n    // if not cleared then it will be cleared on popup close,\n    //  but the teachers notes will be visible on ciming back from player page\n    const surveyId = this.environment.publicContentSurveyId || ''\n    const courseId = this.contentReadData?.identifier || ''\n    this.clearExistingPublicSurveyData(surveyId, courseId)\n\n    return queryParamsDataTemp\n  }\n\n  openCompletionSurveyFormPopup() {\n    if (this.baseContentReadData && _.get(this.baseContentReadData, 'completionSurveyLink')) {\n      const sID = this.baseContentReadData.completionSurveyLink.split('surveys/')\n      const surveyId = sID[1]\n      const data = {\n        surveyId,\n        courseName: this.contentReadData?.name || '',\n        courseID: this.contentReadData?.identifier || '',\n        contextOrgId: this.contentReadData?.createdFor && this.contentReadData?.createdFor.length > 0 ?\n          this.contentReadData?.createdFor[0] : ''\n      }\n      const dialogRef = this.dialog.open(CompletionSurveyFormComponent, {\n        disableClose: true,\n        width: '750px',\n        maxWidth: '90vw',\n        data: data,\n        autoFocus: false,\n      })\n      dialogRef.afterClosed().subscribe((result) => {\n        if (result) {\n          this.openConfirmationDialog()\n        } else {\n          this.lockCertificate = true\n        }\n      })\n    }\n  }\n\n  openConfirmationDialog() {\n    const dialogData = {\n      messages: [\n        {\n          message: this.translate.instant('apptoc.surveySubmitted'),\n          classes: 'dialog-title'\n        },\n        {\n          message: this.translate.instant('apptoc.surveyCompletedCertificateGenerating'),\n          classes: 'dialog-description mb-2'\n        }\n      ],\n      iconName: 'check_circle',\n      type: 'primary',\n      buttonsPositionClass: 'justify-center items-center',\n      buttons: [\n        {\n          classes: 'succes-button width-full',\n          text: this.translate.instant('apptoc.returnToProgramPage'),\n          response: true\n        }\n      ]\n    }\n    const dialogRef = this.dialog.open(ConfirmationDialogComponent, {\n      data: dialogData,\n      disableClose: true,\n      width: '500px',\n      maxWidth: '90vw'\n    })\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result) {\n        this.lockCertificate = false\n      }\n    })\n  }\n\n  private loadLanguageData() {\n    this.languageList = this.contentLangSvc.getAllContentLanguages(this.contentReadData)\n    this.selectedLanguage = this.contentLangSvc.getSelectedLanguage(this.contentReadData)\n  }\n\n  private async handleContentPreviewOrEnrollment() {\n    if (this.forPreview) {\n      await this.loadContentForPreview()\n    } else {\n      // // If we're working with multilingual content, make sure to fetch its hierarchy\n      // if (this.queryParamsData.mlId && this.contentReadData &&\n      //     this.contentReadData.identifier === this.queryParamsData.mlId) {\n      //   // Fetch content hierarchy for the multilingual content\n      //   try {\n      //     await this.fetchContentHierarchy(this.contentReadData.identifier);\n      //     // After fetching hierarchy, update UI components\n      //     this.getLearningUrls();\n      //   } catch (error) {\n      //     this.loggerSvc.error('Error fetching hierarchy for multilingual content:', error);\n      //   }\n      // }\n\n      // Continue with regular enrollment flow\n      this.fetchUserEnrollmentDataV2()\n    }\n  }\n\n  private async loadContentForPreview() {\n    this.tocSvc.contentLoader.next(true)\n    await this.fetchContentHierarchy(this.contentReadData?.identifier || '')\n    this.tocSvc.contentLoader.next(false)\n    this.tocSvc.checkModuleWiseData(this.content)\n    this.skeletonLoader = false\n  }\n\n  private loadBannerAndTocConfig(data: Data) {\n    this.banners = data?.pageData?.data?.banners || []\n    this.tocSvc.subtitleOnBanners = data?.pageData?.data?.subtitleOnBanners || false\n    this.tocSvc.showDescription = data?.pageData?.data?.showDescription || false\n    this.tocConfig = data?.pageData?.data || {}\n    if (this.contentReadData?.courseCategory === NsContent.ECourseCategory.LEARNING_PATHWAY) {\n      this.kparray = this.tocConfig.karmaPointsLP || [\n        {\n          \"displayButton\": \"Resume\",\n          \"textBeforeIcon\": \"earn\",\n          \"points\": \"25\",\n          \"textAfterPoints\": \"karmaPoints\",\n          \"textAfterIcon\": \"byCompletingLP\",\n          \"toolTipText\": \"lpCompleteTip\"\n        }\n      ]\n    } else {\n      this.kparray = this.tocConfig.karmaPoints || []\n\n    }\n  }\n\n  private fetchPostAssessmentStatusIfNeeded() {\n    if (this.content && this.isPostAssessment) {\n      this.tocSvc.fetchPostAssessmentStatus(this.content.identifier).subscribe(res => {\n        const assessmentData = res.result\n        for (const o of assessmentData) {\n          if (o.contentId === (this.content && this.content.identifier)) {\n            this.showTakeAssessment = o\n            break\n          }\n        }\n      })\n    }\n  }\n\n  private setupFragmentSubscription() {\n    this.currentFragment = 'overview'\n    this.route.fragment.subscribe((fragment: any) => {\n      this.currentFragment = fragment || 'overview'\n    })\n  }\n\n  private setupBatchSubscriptions() {\n    this.batchSubscription = this.tocSvc.batchReplaySubject.subscribe(\n      () => this.handleBatchUpdate(),\n      () => this.loggerSvc.error('error on batchSubscription')\n    )\n\n    this.batchDataSubscription = this.tocSvc.setBatchDataSubject.subscribe(\n      () => this.handleBlendedProgramUpdate(),\n      () => this.loggerSvc.error('error on batchDataSubscription')\n    )\n  }\n\n  private handleBatchUpdate() {\n    this.fetchBatchDetails()\n    if (this.content?.primaryCategory === this.primaryCategory.BLENDED_PROGRAM) {\n      this.fetchUserWFForBlended()\n    }\n  }\n\n  private handleBlendedProgramUpdate() {\n    if (this.content?.primaryCategory === this.primaryCategory.BLENDED_PROGRAM) {\n      this.fetchUserWFForBlended()\n    }\n  }\n\n  private configureDefaultLogo() {\n    const instanceConfig = this.configSvc.instanceConfig\n    if (instanceConfig?.logos?.defaultSourceLogo) {\n      this.defaultSLogo = instanceConfig.logos.defaultSourceLogo\n    }\n  }\n\n  private configureFeatureFlags() {\n    if (this.configSvc.restrictedFeatures) {\n      this.isGoalsEnabled = !this.configSvc.restrictedFeatures.has('goals')\n      this.isRegistrationSupported = this.configSvc.restrictedFeatures.has('registrationExternal')\n      this.showIntranetMessage = !this.configSvc.restrictedFeatures.has('showIntranetMessageDesktop')\n    }\n  }\n\n  private setupRouterEventSubscription() {\n    this.routerParamSubscription = this.router.events.subscribe((routerEvent: Event) => {\n      if (routerEvent instanceof NavigationEnd) {\n        this.assignPathAndUpdateBanner(routerEvent.url)\n\n        // Check if we're on the TOC/overview page for a Learning Pathway\n        const isTocPage = routerEvent.url.includes('/app/toc') ||\n          routerEvent.url.includes('/overview') ||\n          routerEvent.url.includes('/content')\n\n\n      }\n    })\n  }\n\n\n\n  /**\n   * Subscribe to hashmap updates to recompute milestone lock status in real-time\n   * This ensures that when progress changes, milestone locks update immediately without page refresh\n   */\n  private setupHashmapUpdateSubscription() {\n    this.hashmapUpdatedSubscription = this.tocSvc.hashmapUpdated$.subscribe((update) => {\n      if (update && this.baseContentReadData?.courseCategory === 'Learning Pathway') {\n        const isEnrolled = this.userEnrollmentList && this.userEnrollmentList.length > 0\n        // Sync content tree's isLocked with the updated hashmap values\n        this.syncMilestoneLockStatus()\n      }\n    })\n  }\n\n\n  fetchUserEnrollmentDataV2() {\n\n    const identifier = this.baseContentReadData?.identifier || ''\n    if (!identifier) {\n      this.loggerSvc.error('Cannot fetch enrollment data: content identifier is missing')\n      this.userEnrollmentList = []\n      this.checkIfUserEnrolled()\n      return\n    }\n\n    const request = {\n      request: {\n        retiredCoursesEnabled: true,\n        courseId: [identifier]\n      }\n    }\n\n    this.enrollSvc.fetchEnrollContentData(request).pipe(\n      takeUntil(this.destroySubject$),\n      switchMap((res: any) => {\n        if (res?.result?.courses?.length) {\n          this.userEnrollmentList = res.result.courses\n          // Check for completed content\n          const completedContentData = this.userEnrollmentList.find(\n            (el: any) => el.collectionId === this.baseContentReadData?.identifier &&\n              el.completionPercentage === 100\n          )\n          if (completedContentData) {\n            this.contentViewEventForNetCore('complete')\n          }\n          this.dataTransferSvc.setEnrollData(this.userEnrollmentList)\n          if (this.isMultilingual) {\n            // in case of back from player we need to check recent language and load\n            if (!this.contentLibSvc?.oneStepResumeEnable && this.baseContentReadData?.identifier === this.contentReadData?.identifier) {\n              let lang = this.baseContentReadData?.language?.length ? this.baseContentReadData?.language[0] : ''\n              let baseContentFromEnrollData = this.userEnrollmentList.find((el: any) => el.collectionId === this.baseContentReadData?.identifier)\n              if (lang && baseContentFromEnrollData && baseContentFromEnrollData?.recent_language?.toLowerCase() !== lang) {\n                let localLang = this.contentLangSvc.getRequiredLanguageDetails(this.baseContentReadData, baseContentFromEnrollData?.recent_language)\n                if (localLang && Object.keys(localLang).length) {\n                  this.processLanguageSelection(this.contentLangSvc.getRequiredLanguageDetails(this.baseContentReadData, baseContentFromEnrollData?.recent_language))\n                } else {\n                  this.processLanguageSelection(this.contentLangSvc.getSelectedLanguage(this.contentReadData))\n                }\n              }\n              return of(false)\n            } else {\n              // Always call fetchContentHierarchy first\n              return from(this.fetchContentHierarchy(this.contentReadData?.identifier || ''))\n            }\n          } else {\n            // Always call fetchContentHierarchy first\n            return from(this.fetchContentHierarchy(this.contentReadData?.identifier || ''))\n          }\n\n        } else {\n          this.userEnrollmentList = []\n          // Check if we have content ID from either content or contentReadData\n          const contentId = this.contentReadData?.identifier || this.baseContentReadData?.identifier || ''\n          if (!contentId) {\n            this.loggerSvc.error('Cannot fetch hierarchy: content identifier is missing')\n            return of(false)\n          }\n          // Fetch hierarchy content for additional data\n          return from(this.fetchContentHierarchy(contentId))\n        }\n      }),\n      // Add catchError here to handle errors from fetchContentHierarchy\n      catchError(error => {\n        this.loggerSvc.error('Error in enrollment data processing', error)\n        return of(false)\n      })\n    ).subscribe({\n      next: () => {\n        if (this.userEnrollmentList?.length && this.contentLibSvc?.oneStepResumeEnable) {\n          this.handleOneStepResume()\n          this.checkIfUserEnrolled()\n        } else {\n          this.checkIfUserEnrolled()\n        }\n      },\n      error: (error) => {\n        this.loggerSvc.error('Failed to fetch user enrollment data', error)\n        this.userEnrollmentList = []\n        this.checkIfUserEnrolled()\n      },\n      complete: () => {\n        // Optional completion handler if needed\n      }\n    })\n  }\n\n  private async handleOneStepResume() {\n    try {\n      if (!this.content) {\n        this.loggerSvc.error('Content not available for one-step resume')\n\n      }\n\n      const foundContent = this.userEnrollmentList.find(\n        (el: any) => el.collectionId === this.baseContentReadData?.identifier\n      )\n\n      if (!foundContent) {\n        this.loggerSvc.warn('No matching enrolled content found for one-step resume')\n\n      }\n\n      const urlData = await this.contentLibSvc.getResourseLink(\n        this.content,\n        [foundContent],\n        true,\n        this.baseContentReadData,\n        this.contentReadData?.identifier || '',\n      )\n\n      if (!urlData) {\n        this.loggerSvc.warn('No URL data returned for one-step resume')\n\n      }\n\n      if (urlData?.url) {\n        if (urlData.url.includes('app/toc')) {\n          this.contentLibSvc.oneStepResumeEnable = false\n        } else {\n          this.contentLibSvc.oneStepResumeEnable = false\n          // When coming from search page for particular language content, confirm first to one step resume or load the searched language\n          if (urlData?.queryParams?.ML && (urlData?.queryParams?.ML !== this.queryParamsData['ML'])) {\n            this.showOneStepResumeConfirm(urlData)\n          } else {\n            this.router.navigate(\n              [urlData.url],\n              { queryParams: urlData.queryParams })\n          }\n        }\n      }\n\n    } catch (error) {\n      this.loggerSvc.error('Error in handleOneStepResume', error)\n      this.contentLibSvc.oneStepResumeEnable = false\n    }\n  }\n  private fetchContentHierarchy(identifier: string): Promise<boolean> {\n    if (this.baseContentReadData?.courseCategory === 'Learning Pathway') {\n      return new Promise<boolean>((resolve) => {\n        const content = this.baseContentReadData\n\n\n        // STEP 1: Construct hierarchy structure\n        let contentHeirarchyData = this.appTocV2Svc.constructHeirarchyData(content)\n\n        // STEP 2: Update progress with latest enrollment data\n        this.appTocV2Svc.mapContentHierarchyProgressUpdate(contentHeirarchyData, this.userEnrollmentList)\n\n        // STEP 3: Create hashmap from updated hierarchy (this should preserve completion status)\n        this.tocSvc.callHirarchyProgressHashmap(contentHeirarchyData)\n        this.content = contentHeirarchyData\n        // Check if user is enrolled\n        const isEnrolled = this.userEnrollmentList && this.userEnrollmentList.length > 0\n\n        // STEP 4: Compute milestone locking status with enrollment status and updated progress data\n        this.tocSvc.computeMilestoneLockingStatus(isEnrolled)\n\n        // STEP 5: Sync content tree's isLocked with computed values\n        this.syncMilestoneLockStatus()\n\n        this.getOrgIdForShare()\n        this.getTocStructure()\n        resolve(true)\n        return\n      })\n    } else {\n      return new Promise<boolean>((resolve, reject) => {\n        if (!identifier) {\n          resolve(false)\n          return\n        }\n\n        // Make sure fetchHierarchyContent returns an Observable\n        const observable = this.contentSvc.fetchHierarchyContent(identifier, 'detail')\n\n        if (!observable) {\n          this.loggerSvc.error('fetchHierarchyContent did not return an Observable')\n          resolve(false)\n          return\n        }\n\n        const subscription = observable.subscribe({\n          next: (response: any) => {\n            if (response?.result?.content) {\n              this.content = response.result.content\n              this.getOrgIdForShare()\n              this.getTocStructure()\n              if (!this.forPreview) {\n                this.userRating = undefined\n                this.getUserRating(false)\n              }\n              resolve(true)\n            } else {\n              resolve(false)\n            }\n            subscription.unsubscribe()\n          },\n          error: (error: any) => {\n            this.loggerSvc.error('Failed to fetch hierarchy content', error)\n            reject(error)\n            subscription.unsubscribe()\n          }\n        })\n      })\n    }\n  }\n\n  getTocStructure() {\n    this.initializeTocStructure()\n    if (this.content && this.tocStructure) {\n      this.hasTocStructure = false\n      this.tocStructure.learningModule = this.content.primaryCategory === this.primaryCategory.MODULE ? -1 : 0\n      this.tocStructure.course = this.content.primaryCategory === this.primaryCategory.COURSE ? -1 : 0\n      this.tocStructure = this.tocSvc.getTocStructure(this.content, this.tocStructure)\n      for (const progType in this.tocStructure) {\n        if (this.tocStructure[progType] > 0) {\n          this.hasTocStructure = true\n          break\n        }\n      }\n\n      // from ngOnChanges\n      this.fetchExternalContentAccess()\n      this.modifySensibleContentRating()\n      this.assignPathAndUpdateBanner(this.router.url)\n      this.getLearningUrls()\n    }\n  }\n\n  /**\n   * Sync milestone isLocked property with computed locking status from hashmap\n   * This ensures the content tree reflects the actual lock status\n   */\n  syncMilestoneLockStatus() {\n    if (!this.content || !this.content.children) return\n\n    let hasChanges = false\n    this.content.children.forEach((child: any) => {\n      if (child.primaryCategory === 'Milestone' && child.identifier) {\n        const hashData = this.tocSvc.hashmap[child.identifier]\n        if (hashData && hashData.computedIsLocked !== undefined) {\n          const oldLocked = child.isLocked\n          child.isLocked = hashData.computedIsLocked\n          if (oldLocked !== child.isLocked) {\n            hasChanges = true\n          }\n        }\n      }\n    })\n  }\n\n  /**\n   * Refresh milestone locking status from the already-updated hashmap\n   * This method should be called after progress updates to sync UI with computed lock status\n   * Note: Does NOT fetch enrollment data - uses existing hashmap which is already updated\n   */\n  private refreshEnrollmentAndProgress() {\n    if (!this.content) {\n      return\n    }\n\n    try {\n\n      // Check if user is enrolled\n      const isEnrolled = this.userEnrollmentList && this.userEnrollmentList.length > 0\n\n      // Recompute milestone locking status from existing hashmap\n      // The hashmap is already updated with latest progress via hashmap update subscription\n      this.tocSvc.computeMilestoneLockingStatus(isEnrolled)\n\n      // Sync lock status from hashmap to content tree\n      this.syncMilestoneLockStatus()\n\n    } catch (error) {\n      console.error('❌ Error in refreshEnrollmentAndProgress:', error)\n    }\n  }\n\n  onLanguageSelect(lang: any) {\n    // Check if the selected language is already set\n    if (this.selectedLanguage && this.selectedLanguage.identifier === lang.identifier) {\n      return // Exit the function if the language is the same\n    }\n\n    if (this.userEnrollmentList && this.userEnrollmentList.length) {\n      let data = {}\n      // TODO: Remove hardcode strings\n      const enrolledCourse = this.tocSvc.findEnrolmentByCollectionId(this.userEnrollmentList, (this.baseContentReadData?.identifier || ''))\n      if (enrolledCourse && enrolledCourse.status === 2) {\n        this.processLanguageSelection(lang)\n      } else {\n        // If there is progress in the selected language,\n        if (this.languageMapProgress && this.languageMapProgress[lang.langId] > 0) {\n          data = {\n            width: '500px',\n            height: 'auto',\n            data: {\n              from: 'languageSwitch',\n              icon: 'translate',\n              header: `Continue where you left off in ${lang.name}?`,\n              message: `You've already made some progress in this language.\\n If you continue it will resume from where you left off.`,\n              cancelButton: 'Back',\n              acceptButton: 'Resume',\n            }\n          }\n        } else {\n          // If there is no progress in the selected language, or first time selection\n          data = {\n            width: '500px',\n            height: 'auto',\n            data: {\n              from: 'languageSwitch',\n              icon: 'translate',\n              header: 'Are you sure you want to change the language?',\n              message: 'Switching the language will reset your progress. \\n The course will restart from the beginning in the selected language.',\n              cancelButton: 'Back',\n              acceptButton: 'Change language',\n            }\n          }\n        }\n        this.showLangSwitchPopup(lang, data)\n      }\n    } else {\n      this.processLanguageSelection(lang)\n    }\n  }\n\n  showLangSwitchPopup(lang: any, data?: any) {\n    const dialogRef = this.dialog.open(TOCMultiLingualDialogComponent, data)\n    dialogRef.afterClosed().subscribe((confirmed) => {\n      if (confirmed) {\n        this.processLanguageSelection(lang)\n      }\n    })\n  }\n\n  showOneStepResumeConfirm(urlData: any) {\n    const data = {\n      width: '500px',\n      height: 'auto',\n      data: {\n        from: 'languageSwitch',\n        icon: 'translate',\n        header: `You've already started this course`,\n        message: `You’ve made some <b>progress</b> in another language of this course. \\nWould you like to <b>resume where you left off</b>, or continue with this version instead?`,\n        cancelButton: 'Continue Here',\n        acceptButton: 'Resume',\n      }\n    }\n    const dialogRef = this.dialog.open(TOCMultiLingualDialogComponent, data)\n    dialogRef.afterClosed().subscribe((confirmed) => {\n      if (confirmed) {\n        this.router.navigate(\n          [urlData.url],\n          { queryParams: urlData.queryParams })\n      } else {\n        const lang = this.contentLangSvc.getRequiredLanguageDetails(this.baseContentReadData, this.queryParamsData['ML'])\n        this.processLanguageSelection(lang)\n      }\n    })\n  }\n\n  processLanguageSelection(lang: any) {\n    this.selectedLanguage = lang\n\n    // Set skeleton loader to show loading state\n    this.skeletonLoader = true\n    // Check if language object has required properties\n    if (lang && lang.identifier) {\n      // Create a promise chain to fetch content data and hierarchy sequentially\n      this.fetchContentRead(lang.identifier)\n        .then(() => {\n          // After content read is successful, fetch the hierarchy\n          return this.fetchContentHierarchy(lang.identifier)\n        })\n        .then(() => {\n          // Both operations were successful\n          // Update UI as needed with new content\n          this.routerChangeHandler(true)\n          if (this.userEnrollmentList && this.userEnrollmentList.length) {\n            this.generateResumeDataLinkNew()\n          }\n          if (this.content) {\n            this.getLearningUrls()\n            // Reset user progress and fetch enrollment data if not in preview mode\n            if (!this.forPreview) {\n              this.checkIfUserEnrolled()\n            }\n          }\n          // Update subject to notify rating summry component and load the sumamry of selected language\n          this.resetRatingsService.setRatingServiceUpdate(true)\n          // Finally set loading state to false\n          this.skeletonLoader = false\n        })\n        .catch((error) => {\n          // Handle any errors in the promise chain\n          this.loggerSvc.error('Error during language change:', error)\n          this.skeletonLoader = false\n          this.snackBar.open('Failed to load content in selected language', 'X', {\n            duration: 3000,\n          })\n        })\n    } else {\n      this.loggerSvc.error('Invalid language selection', lang)\n      this.skeletonLoader = false\n      this.snackBar.open('Invalid language selection', 'X', {\n        duration: 3000,\n      })\n    }\n  }\n\n  /**\n   * Fetches content data for a given identifier and updates the contentReadData property\n   * @param identifier The content identifier to fetch\n   * @returns Promise that resolves to true if content was fetched successfully, false otherwise\n   */\n  private async fetchContentRead(identifier: string): Promise<boolean> {\n    return new Promise<boolean>((resolve, reject) => {\n      if (!identifier) {\n        this.loggerSvc.error('Cannot fetch content: identifier is missing')\n        resolve(false)\n        return\n      }\n\n      const observable = this.contentSvc.fetchContentData(identifier)\n\n      if (!observable) {\n        this.loggerSvc.error('fetchContentData did not return an Observable')\n        resolve(false)\n        return\n      }\n\n      const subscription = observable.subscribe({\n        next: (response: any) => {\n          if (response?.result?.content) {\n            // Update contentReadData with the fetched content\n            this.contentReadData = response.result.content\n\n            // Update language list after content is fetched\n            if (this.contentReadData) {\n              this.languageList = this.contentLangSvc.getAllContentLanguages(this.contentReadData)\n              this.selectedLanguage = this.contentLangSvc.getSelectedLanguage(this.contentReadData)\n            }\n\n            resolve(true)\n          } else {\n            this.loggerSvc.warn('Content data not found in response', response)\n            resolve(false)\n          }\n          subscription.unsubscribe()\n        },\n        error: (error: any) => {\n          this.loggerSvc.error('Failed to fetch content data', error)\n          reject(error)\n          subscription.unsubscribe()\n        }\n      })\n    })\n  }\n\n  routerChangeHandler(appendBatchId: boolean) {\n    const queryParams: any = {}\n\n    // Add batch ID if needed\n    if (appendBatchId && this.getBatchId()) {\n      queryParams.batchId = this.getBatchId()\n    }\n\n    // Add multilingual ID and language to query params if available\n    if (this.contentReadData && this.contentReadData.identifier) {\n      let language = ''\n\n      // Handle both string and array language formats\n      if (Array.isArray(this.contentReadData.language)) {\n        language = this.contentReadData.language[0].toLowerCase()\n      } else if (this.contentReadData.language) {\n        language = this.contentReadData.language.toLowerCase()\n      }\n      if (!(this.selectedLanguage && Object.keys(this.selectedLanguage).length)) {\n        this.selectedLanguage = {\n          langId: language,\n          name: this.contentReadData.language[0]\n        }\n      }\n      // Only add parameters if we have valid data\n      if (language) {\n        queryParams.ML = language\n      }\n\n      queryParams.MLId = this.contentReadData.identifier\n    }\n\n    // Only navigate if we have batch ID or other parameters\n    if (Object.keys(queryParams).length > 0) {\n      this.router.navigate(\n        [],\n        {\n          relativeTo: this.route,\n          queryParams: queryParams,\n          queryParamsHandling: 'merge',\n        }\n      )\n    }\n  }\n\n  private getContinueLearningData(contentId: string, batchId?: string, lang?: string) {\n    this.tocSvc.contentLoader.next(true)\n    this.resumeData = null\n    let userId\n    if (this.configSvc.userProfile) {\n      userId = this.configSvc.userProfile.userId || ''\n    }\n\n    const req: NsContent.IContinueLearningDataReq = {\n      request: {\n        batchId,\n        userId,\n        courseId: contentId || '',\n        contentIds: [],\n        fields: ['progressdetails'],\n        ...(lang ? { language: lang } : null),\n      },\n    }\n    if (this.content && this.content.primaryCategory !== NsContent.EPrimaryCategory.RESOURCE) {\n      this.contentSvc.fetchContentHistoryV2(req).subscribe(\n        data => {\n          if (data && data.result && data.result.contentList && data.result.contentList.length) {\n            const tempResumeData = _.get(data, 'result.contentList')\n            this.languageMapProgress = _.get(data, 'result.languageProgress') || {}\n            this.resumeData = _.map(tempResumeData, rr => {\n              // tslint:disable-next-line\n              const items = _.filter(flattenItems(_.get(this.content, 'children') || [], 'children'), { 'identifier': rr.contentId, primaryCategory: 'Learning Resource' })\n              _.set(rr, 'progressdetails.mimeType', _.get(_.first(items), 'mimeType'))\n              if (!_.get(rr, 'completionPercentage')) {\n                if (_.get(rr, 'status') === 2) {\n                  _.set(rr, 'completionPercentage', 100)\n                } else {\n                  _.set(rr, 'completionPercentage', 0)\n                }\n              }\n              return rr\n            })\n            const progress = _.map(this.resumeData, 'completionPercentage')\n            const totalCount = _.toInteger(_.get(this.content, 'leafNodesCount')) || 1\n            if (progress.length < totalCount) {\n              const diff = totalCount - progress.length\n              if (diff) {\n                // tslint:disable-next-line\n                _.each(new Array(diff), () => {\n                  progress.push(0)\n                })\n              }\n            }\n            this.generateResumeDataLinkNew()\n            this.tocSvc.updateResumaData(this.resumeData)\n            // this.tocSvc.mapModuleDurationAndProgress(this.content, this.content)\n            this.getLastPlayedResource()\n            if (this.content?.completionPercentage !== 100) {\n              this.tocSvc.mapCompletionPercentage(this.content, this.resumeData)\n            }\n            this.tocSvc.callHirarchyProgressHashmap(this.content)\n            // Recompute milestone locking status after progress update\n            if (this.baseContentReadData?.courseCategory === 'Learning Pathway') {\n              const isEnrolled = this.userEnrollmentList && this.userEnrollmentList.length > 0\n              this.tocSvc.computeMilestoneLockingStatus(isEnrolled)\n              this.syncMilestoneLockStatus()\n            }\n            this.tocSvc.contentLoader.next(false)\n          } else {\n            this.resumeData = null\n            this.tocSvc.callHirarchyProgressHashmap(this.content)\n            // Recompute milestone locking status even with no progress data\n            if (this.baseContentReadData?.courseCategory === 'Learning Pathway') {\n              const isEnrolled = this.userEnrollmentList && this.userEnrollmentList.length > 0\n              this.tocSvc.computeMilestoneLockingStatus(isEnrolled)\n              this.syncMilestoneLockStatus()\n            }\n            this.tocSvc.contentLoader.next(false)\n          }\n\n          this.contentSvc.setProgramChildResumeData(this.resumeData, contentId)\n          if (this.content?.completionPercentage !== 100) {\n            this.bindCompletionPercentage()\n          }\n        },\n        (error: any) => {\n          this.loggerSvc.error('CONTENT HISTORY FETCH ERROR >', error)\n        },\n      )\n    }\n  }\n\n  generateResumeDataLinkNew() {\n    if (this.resumeData && this.content) {\n      let resumeDataV2: any\n      if (this.content.completionPercentage === 100) {\n        resumeDataV2 = this.getResumeDataFromList('start')\n      } else {\n        resumeDataV2 = this.getResumeDataFromList()\n      }\n      if (!resumeDataV2.mimeType) {\n        resumeDataV2.mimeType = this.tocSvc.getMimeType(this.content, resumeDataV2.identifier)\n      }\n      this.resumeDataLink = this.getResumeUrl(resumeDataV2)\n      this.actionSVC.setUpdateCompGroupO = this.resumeDataLink\n      /* tslint:disable-next-line */\n    }\n  }\n  isSelectedInMoreDropdown(): boolean {\n    if (!this.selectedLanguage?.identifier || !this.languageList) {\n      return false\n    }\n    return this.languageList.slice(5).some((lang: any) =>\n      lang?.identifier === this.selectedLanguage?.identifier\n    )\n  }\n\n  async getQueryParams() {\n    const tempQueryParamsData: any = {}\n    this.routeSubscription = this.route.queryParamMap.subscribe(async qParamsMap => {\n\n      // Extract all parameters from the ParamMap\n      qParamsMap.keys.forEach(key => {\n        tempQueryParamsData[key] = qParamsMap.get(key) ?? ''\n      })\n      tempQueryParamsData\n\n      // Process specific parameters\n      const contextId = tempQueryParamsData['contextId']\n      const contextPath = tempQueryParamsData['contextPath']\n      const recommendedCoursesId = tempQueryParamsData['recommendationId']\n\n      if (contextId && contextPath) {\n        this.contextId = contextId\n        this.contextPath = contextPath\n      }\n\n      if (recommendedCoursesId) {\n        this.recommendedCoursesId = recommendedCoursesId\n        try {\n          const response = await this.userServiceLib.getRecommendedCoursesSakshamAI(recommendedCoursesId).toPromise()\n          if (response && response.feedbacks && response.feedbacks.length) {\n            this.feedbackGiven = response.feedbacks.find((feedback: any) => feedback?.course_id === this.courseID)\n          }\n        } catch (error) {\n          this.loggerSvc.error('Error fetching recommended courses:', error)\n        }\n      }\n    })\n    return tempQueryParamsData\n  }\n\n  getOrgIdForShare() {\n    if (this.content && ![\n      NsContent.ECourseCategory.MODERATED_COURSE,\n      NsContent.ECourseCategory.MODERATED_ASSESSEMENT,\n      NsContent.ECourseCategory.MODERATED_PROGRAM,\n      NsContent.ECourseCategory.INVITE_ONLY_PROGRAM,\n    ].includes(this.content.courseCategory)) {\n      this.canShare = true\n      if (this.configSvc.userProfile) {\n        this.rootOrgId = this.configSvc.userProfile.rootOrgId\n      }\n    }\n  }\n\n  /**\n   * Fetches and processes content creator data from the current content\n   * - Sets contentCreatorData from parsed creator contacts\n   * - Determines if \"show button\" flag should be enabled based on content name\n   * - Includes proper error handling for null values and parsing\n   */\n  getContentCreatorData() {\n    try {\n      // Only proceed if we have valid content data\n      if (!this.contentReadData) {\n        this.loggerSvc.warn('Cannot get creator data: contentReadData is not available')\n        return\n      }\n\n      // Process content name for comparison (safely handle null/undefined)\n      const contentName = this.contentReadData.name?.trim() || ''\n\n      // Parse and set creator contacts if available\n      if (this.contentReadData.creatorContacts) {\n        // Use the existing parsing method to handle creator contacts\n        this.contentCreatorData = this.handleParseJsonData(this.contentReadData.creatorContacts)\n      } else {\n        // Reset to empty array if no creator contacts\n        this.contentCreatorData = []\n      }\n\n      // Set showBtn flag based on dakshta name comparison (case insensitive)\n      // This determines if the special button for dakshta content is shown\n      this.showBtn = contentName.toLowerCase() === this.dakshtaName.toLowerCase()\n    } catch (error) {\n      // Handle any unexpected errors\n      this.loggerSvc.error('Error processing content creator data:', error)\n      this.contentCreatorData = []\n      this.showBtn = false\n    }\n  }\n\n  getI18NTranslations() {\n    // Subscribe to language translation flag changes\n    const translationSubscription = this.configSvc.languageTranslationFlag\n      .pipe(takeUntil(this.destroySubject$)) // Ensure subscription is cleaned up on component destroy\n      .subscribe({\n        next: (data: any) => {\n          // Only proceed if we have valid data\n          if (data) {\n            // Check if website language is set in localStorage\n            const storedLanguage = localStorage.getItem('websiteLanguage')\n            if (storedLanguage) {\n              // Set default language as fallback\n              this.translate.setDefaultLang('en')\n\n              // Use the stored language preference\n              this.translate.use(storedLanguage)\n            }\n          }\n        },\n        error: (error) => {\n          // Log any errors that occur during subscription\n          this.loggerSvc.error('Error in language translation subscription:', error)\n        }\n      })\n\n    // Store subscription for cleanup (optional alternative to takeUntil)\n    this.translationSubscription = translationSubscription\n  }\n\n  getServerDateTime() {\n    // Fetch the server date time and process the response\n    this.tocSvc.getServerDate().subscribe(\n      (response: any) => {\n        // Check if response contains valid system date\n        if (response && response.systemDate) {\n          // Update service with server date (removed duplicate call)\n          this.tocSvc.changeServerDate(response.systemDate)\n          this.serverDate = response.systemDate\n        } else {\n          // Fallback to client's time if server time is not available\n          const clientTime = new Date().getTime()\n          this.tocSvc.changeServerDate(clientTime)\n          this.serverDate = clientTime\n        }\n\n        // Initialize dependent functions that need server date\n        this.findACPB()\n        this.getKarmapointsLimit()\n      },\n      (error: any) => {\n        // Log the error for debugging\n        this.loggerSvc.error('Failed to get server date:', error)\n\n        // Fallback to client's time on error\n        const clientTime = new Date().getTime()\n        this.tocSvc.changeServerDate(clientTime)\n        this.serverDate = clientTime\n      }\n    )\n\n    // Subscribe to server date changes from service\n    this.serverDateSubscription = this.tocSvc.serverDate\n      .pipe(takeUntil(this.destroySubject$)) // Ensure subscription is cleaned up\n      .subscribe(serverDate => {\n        this.serverDate = serverDate\n      })\n  }\n\n  get getBaseContentIdentifier() {\n    return this.baseContentReadData?.identifier || this.content?.identifier || ''\n  }\n\n  get isMultilingual() {\n    if (this.baseContentReadData && this.baseContentReadData.languageMapV1) {\n      return this.languageList.length > 1\n    }\n    return false\n  }\n\n  handleEnrollment(event: any) {\n\n    if (this.isMultilingual) {\n      this.openLangDialog(event)\n    } else {\n      this.handleAutoBatchAssign()\n    }\n  }\n\n  openLangDialog(_event: any) {\n    const dialogRef = this.dialog.open(EnrollLanguageDialogueComponent, {\n      width: '500px',\n      height: 'auto',\n      autoFocus: false,\n      restoreFocus: false,\n      data: {\n        preSelect: this.selectedLanguage,\n        languageList: this.languageList,\n      }\n    })\n    dialogRef.afterClosed().subscribe((selectedLang) => {\n      if (selectedLang) {\n        this.selectedLanguage = selectedLang\n        this.handleAutoBatchAssign()\n      }\n    })\n  }\n\n  getResumeUrl(resourceData: any, batchId?: any, primaryCategory?: any) {\n    let MLId = this.selectedLanguage?.identifier || ''\n    let ML = this.selectedLanguage?.langId || ''\n    let resumeDataUrl = viewerRouteGenerator(\n      resourceData.identifier,\n      resourceData.mimeType,\n      this.isResource ? undefined : this.baseContentReadData && this.baseContentReadData?.identifier || '',\n      this.isResource ? undefined : this.baseContentReadData && this.baseContentReadData?.contentType || '',\n      this.forPreview,\n      primaryCategory || 'Learning Resource',\n      batchId || this.getBatchId(),\n      this.baseContentReadData && this.baseContentReadData?.name || '',\n      ML,\n      MLId,\n    )\n    return resumeDataUrl\n  }\n\n  get contentCompletionPercent() {\n    if (this.batchData?.enrolled) {\n      if (this.contentReadData && this.contentReadData.primaryCategory === 'Course' && this.isMultilingual) {\n        if (this.languageMapProgress && this.selectedLanguage?.langId && this.languageMapProgress[this.selectedLanguage?.langId]) {\n          return this.languageMapProgress[this.selectedLanguage?.langId]\n        } else {\n          return 0\n        }\n      } else {\n        return this.content?.completionPercentage || 0\n      }\n    }\n  }\n\n  checkForCompletionSurveyTrigger() {\n    if (this.content && this.contentReadData) {\n      // check if completion survey is enabled and user has completed the course before 23rd DEC 2023 (release date of completion survey)\n      if (this.configSvc.instanceConfig && this.configSvc.instanceConfig.completionSurvey && this.configSvc.instanceConfig.completionSurvey.enabled &&\n        this.enrolledCourseData && this.enrolledCourseData && this.enrolledCourseData.completedOn >= this.configSvc.instanceConfig.completionSurvey.startDate) {\n        if ((this.content.completionStatus === 2 || this.content.completionPercentage === 100) && this.contentReadData.completionSurveyLink) {\n          const sID = this.contentReadData.completionSurveyLink.split('surveys/')\n          const surveyId = sID[1]\n          const courseId = this.contentReadData.identifier\n          // Call API to see if survey is submitted or not\n          this.tocSvc.getApllicationsById(surveyId, courseId).subscribe((res) => {\n            if (res.result.response && Object.keys(res.result.response).length > 0) {\n              this.lockCertificate = false\n            } else {\n              this.lockCertificate = true\n              this.openCompletionSurveyFormPopup()\n            }\n          })\n        }\n      }\n    }\n  }\n\n  // Clear existing survey data from local storage before opening popup\n  clearExistingPublicSurveyData(surveyId: string, courseId: string) {\n    const storageKey = `survey_${surveyId}_${courseId}`\n    if (localStorage.getItem(storageKey)) {\n      localStorage.removeItem(storageKey)\n    }\n  }\n\n  openPublicSurveyPopup(navigationUrl?: string, queryParams?: any) {\n    // Get survey ID and course ID from environment and content data\n\n    if (this.forPreview) {\n      this.router.navigate([navigationUrl], { queryParams: queryParams })\n    } else {\n      const surveyId = this.environment.publicContentSurveyId || ''\n      const courseId = this.contentReadData?.identifier || ''\n      const courseName = this.contentReadData?.name || ''\n      const contextOrgId = this.contentReadData?.createdFor && this.contentReadData?.createdFor.length > 0 ?\n        this.contentReadData?.createdFor[0] : ''\n\n      this.clearExistingPublicSurveyData(surveyId, courseId)\n\n      const data = {\n        surveyId: surveyId,\n        courseId: courseId,\n        courseName: courseName,\n        contextOrgId: contextOrgId,\n        forPreview: this.forPreview\n      }\n\n      const dialogRef = this.dialog.open(PublicSurveyFormComponent, {\n        // disableClose: true,\n        width: '750px',\n        maxWidth: '90vw',\n        height: '80vh',\n        data: data,\n        autoFocus: false,\n      })\n      dialogRef.afterClosed().subscribe((result) => {\n        if (result) {\n          // Navigate to the intended URL only when survey is submitted successfully\n          if (navigationUrl) {\n            this.router.navigate([navigationUrl], { queryParams: queryParams })\n          }\n        }\n      })\n    }\n\n\n  }\n\n  resumeContentData() {\n    const navigationUrl = (this.resumeData && !this.certData) ? this.resumeDataLink?.url : this.firstResourceLink?.url\n    const queryParams = (this.resumeData && !this.certData) ? this.generateQuery('RESUME') : this.generateQuery('START')\n    this.router.navigate([navigationUrl], { queryParams: queryParams })\n  }\n\n  /**\n   * Check if user can enroll in the course\n   * Returns true when enrollment is allowed\n   */\n\n\n  navigateToNewVersion() {\n    this.router.navigateByUrl('/app/toc', { skipLocationChange: true }).then(() => {\n      this.router.navigate([`app/toc/${this.contentReadData?.contentVersionInfo?.identifier}/overview`])\n    })\n\n  }\n\n  canEnroll() {\n    if (this.contentReadData && this.contentReadData.lastEnrollmentDate) {\n      const serverTime = dayjs(this.serverDate).format('YYYY-MM-DD')\n      const eDate = dayjs(this.contentReadData.lastEnrollmentDate).format('YYYY-MM-DD')\n      if (dayjs(serverTime).isSameOrBefore(eDate)) {\n        return true\n      } else {\n        return false\n      }\n    } else {\n      return true\n    }\n  }\n\n  goBack() {\n    this.location.back()\n  }\n}\n","<ng-container *ngIf=\"courseID else noDataFound\">\n  <ng-template #enrollFunctionality>\n    <div [hidden]=\"isResource && !content?.artifactUrl?.length\" class=\"flex flex-col gap-4 text-center\">\n      <!-- Course block -->\n      <ng-container *ngIf=\"contentReadData?.primaryCategory !== primaryCategory.PROGRAM\n                    && contentReadData?.primaryCategory !== primaryCategory.CURATED_PROGRAM\n                    && contentReadData?.primaryCategory !== primaryCategory.STANDALONE_ASSESSMENT &&\n                    contentReadData?.primaryCategory !== primaryCategory.BLENDED_PROGRAM\">\n        <ng-container *ngIf=\"(actionBtnStatus === 'grant' && !(isMobile && content?.isInIntranet) &&\n                      !(contentReadData?.primaryCategory === primaryCategory.COURSE && content?.children.length === 0 &&\n                      !content?.artifactUrl?.length) &&\n                      !(contentReadData?.primaryCategory === primaryCategory.COURSE && !batchData?.enrolled) &&\n                      !(contentReadData?.primaryCategory === primaryCategory.RESOURCE && !content?.artifactUrl) &&\n                      !(contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL)) &&\n                      !(contentReadData?.primaryCategory === primaryCategory.PROGRAM && currentCourseBatchId)\">\n          <a *ngIf=\"showStart.show && !isPostAssessment && !forPreview\" (click)=\"raiseTelemetryForPublic()\"\n            [routerLink]=\"(resumeData && !certData) ? resumeDataLink?.url : firstResourceLink?.url\"\n            [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\"\n            class=\"flex action-button justify-center\">\n            <ng-container *ngIf=\"(!content?.completionPercentage || content?.completionPercentage < 100) && !certData\">\n              <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">\n                {{ translateLabels('resume', 'apptochome') }}\n              </ng-container>\n            </ng-container>\n            <ng-container *ngIf=\"content?.completionPercentage === 100 || certData\">\n              {{ content?.completionPercentage >= 100 ? translateLabels('Start again', 'apptochome') :\n              translateLabels('resume', 'apptochome') }}\n            </ng-container>\n          </a>\n\n          <button *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\" (click)=\"raiseTelemetryForPublic()\"\n            [routerLink]=\"firstResourceLink?.url\" class=\"flex action-button justify-center\">\n            <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">{{ 'apptochome.takeAssessment' | translate\n              }}</ng-container>\n          </button>\n\n          <!-- <div\n            *ngIf=\"!isPostAssessment && (!content?.completionPercentage || content?.completionPercentage < 100) && !certData\">\n            <ng-container *ngIf=\"isAcbpClaim\">\n              <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n            </ng-container>\n            <ng-container *ngIf=\"!isAcbpClaim && !monthlyCapExceed\">\n              <ws-app-karmapoints-panel [btntype]=\"'Resume'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n            </ng-container>\n          </div> -->\n\n          <!-- <div *ngIf=\"!isPostAssessment && (content?.completionPercentage === 100 || certData)\">\n            <div *ngIf=\"isAcbpCourse && isAcbpClaim && !isClaimed\">\n              <ws-app-karmapoints-panel [btntype]=\"'ACBP CLAIM'\" [data]=\"kparray\" [btnCategory]=\"'claim'\"\n                (clickClaimKarmaPoints)=\"onClickOfClaim($event)\"></ws-app-karmapoints-panel>\n            </div>\n            <div *ngIf=\"!isAcbpCourse && !monthlyCapExceed\">\n              <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n            </div>\n            <div *ngIf=\"!isAcbpCourse && monthlyCapExceed && !isCompletedThisMonth\">\n              <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n            </div>\n          </div> -->\n\n          <!-- <div *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\">\n            <ws-app-karmapoints-panel [btntype]=\"'Take Assessment'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n          </div> -->\n        </ng-container>\n\n        <ng-container *ngIf=\" (actionBtnStatus === 'grant' && !(isMobile && content?.isInIntranet) &&\n                      !( contentReadData?.primaryCategory === primaryCategory.COURSE && content?.children.length === 0 && !content?.artifactUrl?.length ) &&\n                      !( contentReadData?.primaryCategory === primaryCategory.COURSE && batchData?.enrolled ) &&\n                      !(contentReadData?.primaryCategory === primaryCategory.RESOURCE && !content?.artifactUrl)) &&\n                      !(contentReadData?.primaryCategory === primaryCategory.PROGRAM) &&\n                      !(contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL)\">\n          <ng-container *ngIf=\"contentReadData?.primaryCategory !== primaryCategory.RESOURCE  && !enrollBtnLoading\">\n            <a class=\"flex action-button justify-center resume\" *ngIf=\"!forPreview || isInIFrame\"\n              (click)=\"handleEnrollment()\" [ngClass]=\"{'disable-start-btn': !canEnroll()}\">\n              <ng-container>\n                {{ 'apptochome.enroll' | translate }}\n              </ng-container>\n            </a>\n            <!-- <ng-container *ngIf=\"isAcbpCourse\">\n              <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n            </ng-container> -->\n            <!-- <ng-container *ngIf=\"!isAcbpCourse && !monthlyCapExceed && userEnrollmentList && !userEnrollmentList.length\">\n              <ws-app-karmapoints-panel [btntype]=\"'Enroll'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n            </ng-container> -->\n          </ng-container>\n        </ng-container>\n      </ng-container>\n\n\n      <!-- PRogram & mandatory course block -->\n      <ng-container *ngIf=\"!forPreview || isInIFrame; else authViewBtn\">\n        <ng-container\n          *ngIf=\"contentReadData?.primaryCategory === primaryCategory.PROGRAM || contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL\">\n          <ng-container\n            *ngIf=\"(courseCategory?.MODERATED_PROGRAM === contentReadData?.courseCategory) && (contentReadData?.batches && !batchData?.enrolled)\">\n            <ng-container\n              *ngIf=\"((contentReadData?.primaryCategory !== primaryCategory.RESOURCE)  && !enrollBtnLoading) && !contentReadData?.batches[0].endDate\">\n              <a class=\"flex action-button justify-center resume\" (click)=\"handleEnrollment()\">\n                <ng-container *ngIf=\"!forPreview || isInIFrame\">\n                  {{'apptochome.enroll' | translate}}\n                </ng-container>\n              </a>\n              <!-- <ng-container *ngIf=\"isAcbpCourse\">\n                <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n              </ng-container>\n              <ng-container *ngIf=\"!isAcbpCourse && !monthlyCapExceed && userEnrollmentList && !userEnrollmentList.length\">\n                <ws-app-karmapoints-panel [btntype]=\"'Enroll'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n              </ng-container> -->\n            </ng-container>\n            <ng-container *ngIf=\"!forPreview || isInIFrame\">\n              <ng-container\n                *ngIf=\"((contentReadData?.primaryCategory !== primaryCategory.RESOURCE)  && !enrollBtnLoading) && contentReadData?.batches[0].endDate\">\n                <ws-app-toc-banner role=\"banner\" [banners]=\"banners\" [forPreview]=\"forPreview\" [content]=\"content\"\n                  [userEnrollmentList]=\"userEnrollmentList\" [analytics]=\"analytics\"\n                  (programEnrollCall)=\"programEnrollCall($event)\" [resumeData]=\"resumeData\" [batchData]=\"batchData\"\n                  [contentReadData]=\"contentReadData\">\n                </ws-app-toc-banner>\n              </ng-container>\n            </ng-container>\n          </ng-container>\n          <ng-container\n            *ngIf=\"(courseCategory?.MODERATED_PROGRAM === contentReadData?.courseCategory) && !contentReadData?.batches && !batchData?.enrolled && !enrollBtnLoading\">\n            No Batches\n          </ng-container>\n          <ng-container\n            *ngIf=\"courseCategory?.MODERATED_PROGRAM !== contentReadData?.courseCategory && !enrollBtnLoading\">\n            <ng-container\n              *ngIf=\"!(contentReadData?.primaryCategory === primaryCategory.PROGRAM && currentCourseBatchId) && contentReadData?.primaryCategory !== primaryCategory.MANDATORY_COURSE_GOAL\">\n              <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.youAreNotInvited' | translate }} </span>\n            </ng-container>\n            <ng-container *ngIf=\"!isBatchInProgress && !!currentCourseBatchId && getStartDate === 'NA'\">\n              <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.noActiveBatches' | translate }}</span>\n            </ng-container>\n            <ng-container *ngIf=\"!isBatchInProgress && currentCourseBatchId && getStartDate !== 'NA'\">\n              <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.batchWillStart' | translate }}\n                {{getStartDate}}!</span>\n            </ng-container>\n          </ng-container>\n          <ng-container\n            *ngIf=\"!isBatchInProgress && courseCategory?.MODERATED_PROGRAM === contentReadData?.courseCategory && !enrollBtnLoading\">\n            <ng-container *ngIf=\"!isBatchInProgress && currentCourseBatchId && getStartDate !== 'NA'\">\n              <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.batchWillStart' | translate }}\n                {{getStartDate}}!</span>\n            </ng-container>\n          </ng-container>\n          <ng-container *ngIf=\"isBatchInProgress &&\n                        ( actionBtnStatus === 'grant' &&\n                          !(isMobile && content?.isInIntranet) &&\n                          (contentReadData?.primaryCategory === primaryCategory.PROGRAM && currentCourseBatchId) ||\n                          (contentReadData?.primaryCategory === primaryCategory.MANDATORY_COURSE_GOAL && currentCourseBatchId)\n                        )\">\n            <a *ngIf=\"showStart.show && !isPostAssessment\"\n              [routerLink]=\"resumeData ? resumeDataLink?.url : firstResourceLink?.url\"\n              [queryParams]=\"resumeData ? generateQuery('RESUME') : generateQuery('START')\"\n              class=\"flex action-button justify-center resume\">\n              <ng-container *ngIf=\"!content?.completionPercentage || content?.completionPercentage < 100\">\n                <ng-container *ngIf=\"!forPreview || isInIFrame\">\n                  {{ resumeData && (content?.completionPercentage < 100 && content?.completionPercentage> 0) ?\n                    translateLabels('resume', 'apptochome') :\n                    translateLabels('start', 'apptochome') }}\n                </ng-container>\n              </ng-container>\n              <ng-container *ngIf=\"content?.completionPercentage === 100\">\n                {{ (resumeData) || content?.completionPercentage === 100 ? \"Start again\" : \"Start\" }}\n              </ng-container>\n            </a>\n            <a *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\" [routerLink]=\"firstResourceLink?.url\"\n              class=\"flex action-button justify-center resume\">\n              <ng-container *ngIf=\"!forPreview || isInIFrame\">{{ 'apptochome.takeAssessment' | translate\n                }}</ng-container>\n            </a>\n            <!-- <div *ngIf=\"!isPostAssessment && (!content?.completionPercentage || content?.completionPercentage < 100)\">\n              <ng-container *ngIf=\"isAcbpClaim\">\n                <ws-app-karmapoints-panel [btntype]=\"'ACBP'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n              </ng-container>\n              <ng-container *ngIf=\"!isAcbpClaim && !monthlyCapExceed\">\n                <ws-app-karmapoints-panel [btntype]=\"'Resume'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n              </ng-container>\n            </div> -->\n            <!-- <div *ngIf=\"!isPostAssessment && (content?.completionPercentage === 100)\">\n              <div *ngIf=\"isAcbpCourse && isAcbpClaim && !isClaimed\">\n                <ws-app-karmapoints-panel [btntype]=\"'ACBP CLAIM'\" [condition]=\"{isPostAssessment: isPostAssessment, content: content, isAcbpCourse: isAcbpCourse, isClaimed: isClaimed, monthlyCapExceed: monthlyCapExceed, isCompletedThisMonth: isCompletedThisMonth, showTakeAssessment: showTakeAssessment, userEnrollmentList: userEnrollmentList, isCompletedThisMonth: isCompletedThisMonth, resumeData: resumeData, userRating: userRating}\" [data]=\"kparray\" [btnCategory]=\"'claim'\"\n                  (clickClaimKarmaPoints)=\"onClickOfClaim($event)\"></ws-app-karmapoints-panel>\n              </div>\n              <div *ngIf=\"!isAcbpCourse && !monthlyCapExceed\">\n                <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n              </div>\n              <div *ngIf=\"!isAcbpCourse && monthlyCapExceed && !isCompletedThisMonth\">\n                <ws-app-karmapoints-panel [btntype]=\"'Start again'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n              </div>\n            </div>\n            <div *ngIf=\"isPostAssessment && showTakeAssessment?.post_assessment\">\n              <ws-app-karmapoints-panel [btntype]=\"'Take Assessment'\" [data]=\"kparray\"></ws-app-karmapoints-panel>\n            </div> -->\n          </ng-container>\n        </ng-container>\n      </ng-container>\n\n      <ng-container\n        *ngIf=\"isBatchInProgress && (contentReadData?.primaryCategory === primaryCategory.CURATED_PROGRAM && batchData?.enrolled) && !enrollBtnLoading\">\n        <a *ngIf=\"showStart.show && !isPostAssessment\" (click)=\"raiseTelemetryForPublic()\"\n          [routerLink]=\"resumeData ? resumeDataLink?.url : firstResourceLink?.url\"\n          [queryParams]=\"resumeData ? generateQuery('RESUME') : generateQuery('START')\"\n          class=\"flex action-button justify-center resume\">\n          <ng-container *ngIf=\"!content?.completionPercentage || content?.completionPercentage < 100\">\n            <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">\n              {{ resumeData && (content?.completionPercentage < 100 && content?.completionPercentage> 0) ?\n                translateLabels('resume', 'apptochome') :\n                translateLabels('resume', 'apptochome') }}\n            </ng-container>\n          </ng-container>\n          <ng-container *ngIf=\"content?.completionPercentage === 100\">\n            {{ resumeData || content?.completionPercentage === 100 ? translateLabels('Start again', 'apptochome') :\n            translateLabels('resume', 'apptochome') }}\n          </ng-container>\n        </a>\n      </ng-container>\n\n      <ng-container *ngIf=\"enrollBtnLoading\">\n        <ws-widget-skeleton-loader [width]=\"'100%'\" [height]=\"'36px'\"\n          [bindingClass]=\"'flex rounded h-8'\"></ws-widget-skeleton-loader>\n      </ng-container>\n\n      <!-- Curated program block -->\n      <ng-container\n        *ngIf=\"contentReadData?.primaryCategory === primaryCategory.CURATED_PROGRAM && !batchData?.enrolled && !enrollBtnLoading\">\n        <a class=\"flex action-button justify-center resume\" *ngIf=\"!forPreview || isInIFrame\"\n          (click)=\"handleEnrollment()\">\n          <ng-container>\n            {{ 'apptochome.enroll' | translate }}\n          </ng-container>\n        </a>\n      </ng-container>\n      <!-- STANDALONE_ASSESSMENT black -->\n      <ng-container\n        *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && !batchData?.enrolled && !enrollBtnLoading && contentReadData?.courseCategory !== 'Invite-Only Assessment'\">\n        <a class=\"flex action-button justify-center resume\" (click)=\"handleEnrollment()\"\n          *ngIf=\"!forPreview || isInIFrame\">\n          <ng-container>\n            {{ 'apptochome.enroll' | translate }}\n          </ng-container>\n        </a>\n      </ng-container>\n      <!-- INVITE ONLY STANDALONE ASSESSMENT block-->\n      <ng-container\n        *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && !batchData?.enrolled && !enrollBtnLoading && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n\n        <ng-container *ngIf=\"!forPreview || isInIFrame; else authViewForInviteOnlyAssessment\">\n          <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.youAreNotInvitedForAssessment' | translate }}\n          </span>\n        </ng-container>\n      </ng-container>\n      <ng-container\n        *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && batchData?.enrolled && isBatchInProgress && !enrollBtnLoading && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n        <a class=\"flex action-button justify-center resume\" [routerLink]=\"firstResourceLink?.url\"\n          [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\">\n          <ng-container *ngIf=\"content?.completionPercentage === 100\">{{ 'apptochome.takeTestAgain' | translate\n            }}</ng-container>\n          <ng-container *ngIf=\"content?.completionPercentage < 100\">{{ 'apptochome.takeTest' | translate\n            }}</ng-container>\n        </a>\n      </ng-container>\n      <ng-container\n        *ngIf=\"!isBatchInProgress && !!currentCourseBatchId && getStartDate === 'NA' && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n        <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.noActiveBatches' | translate }}</span>\n      </ng-container>\n      <ng-container\n        *ngIf=\"!isBatchInProgress && currentCourseBatchId && getStartDate !== 'NA' && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n        <span class=\"font-bold shadow-lg text-info-div\">{{ 'apptochome.batchWillStart' | translate }}\n          {{getStartDate}}!</span>\n      </ng-container>\n\n      <!-- STANDALONE_ASSESSMENT enrolled black -->\n      <ng-container\n        *ngIf=\"contentReadData?.primaryCategory === primaryCategory.STANDALONE_ASSESSMENT && batchData?.enrolled && !enrollBtnLoading && contentReadData?.courseCategory !== 'Invite-Only Assessment'\">\n        <a class=\"flex action-button justify-center resume\" [routerLink]=\"firstResourceLink?.url\"\n          [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\">\n          <ng-container *ngIf=\"content?.completionPercentage === 100\">{{ 'apptochome.takeTestAgain' | translate\n            }}</ng-container>\n          <ng-container *ngIf=\"content?.completionPercentage < 100\">{{ 'apptochome.takeTest' | translate\n            }}</ng-container>\n        </a>\n      </ng-container>\n      <!-- BLENDED_PROGRAM block -->\n      <ng-container *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM\">\n\n        <ng-container *ngIf=\"batchData?.workFlow?.wfInitiated &&\n                      !(batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.APPROVED ||\n                      batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.REJECTED ||\n                      batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.WITHDRAWN ||\n                      batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.REMOVED)\">\n          <div class=\"ws-mat-accent-text ws-mat-accent-light-bg flex items-center justify-center statusMsg\">\n            <p class=\"margin-remove-bottom font-bold\">\n              {{ 'apptochome.requestUnderReview' | translate }}\n            </p>\n          </div>\n        </ng-container>\n        <ng-container>\n          <a *ngIf=\"showStart.show && batchData?.workFlow?.wfInitiated && batchData?.workFlow?.wfItem?.currentStatus === WFBlendedProgramStatus.APPROVED\"\n            [routerLink]=\"isBatchInProgress? (resumeData && !certData) ? resumeDataLink?.url : firstResourceLink?.url : '' \"\n            (click)=\"raiseTelemetryForPublic()\"\n            [queryParams]=\"isBatchInProgress ? (resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START') : '' \"\n            class=\"flex action-button justify-center resume\" [ngClass]=\"{'disable-start-btn': !isBatchInProgress}\">\n            <ng-container *ngIf=\"(!content?.completionPercentage || content?.completionPercentage < 100) && !certData\">\n              <ng-container *ngIf=\"!forPreview || isInIFrame; else authView\">\n                {{ resumeData && (content?.completionPercentage < 100 && content?.completionPercentage> 0) ?\n                  translateLabels('resume', 'apptochome') :\n                  translateLabels('start', 'apptochome') }}\n              </ng-container>\n            </ng-container>\n            <ng-container *ngIf=\"content?.completionPercentage === 100 || certData\">\n              {{ resumeData || content?.completionPercentage === 100 ? translateLabels('Start again', 'apptochome') :\n              translateLabels('start', 'apptochome') }}\n            </ng-container>\n          </a>\n        </ng-container>\n      </ng-container>\n\n      <ng-container *ngIf=\"actionBtnStatus == 'reject' && content?.registrationUrl\">\n        <a [href]=\"content?.registrationUrl\" target=\"_blank\" class=\"flex action-button justify-center\">{{\n          'apptochome.register' | translate }}</a>\n      </ng-container>\n\n    </div>\n  </ng-template>\n\n  <ng-template #progressFunctionality>\n    <div class=\"flex flex-row gap-4\">\n      <div class=\"flex-1\">\n        <div class=\"flex flex-col gap-2\">\n          <div class=\"flex flex-row gap-4 text-sm\">\n            <div class=\"flex-1 text-xs\">{{ 'apptocsinglepage.overallProgress' | translate }}</div>\n            <div class=\"text-xs\" *ngIf=\"content?.completionPercentage > 0\"> {{ content?.completionPercentage }} %</div>\n          </div>\n          <ws-widget-content-progress *ngIf=\"content?.identifier\" [forPreview]=\"forPreview\"\n            [contentId]=\"content?.identifier\" [progress]=\"content?.completionPercentage\" [progressType]=\"'percentage'\"\n            [customClassName]=\"'content-progress'\">\n          </ws-widget-content-progress>\n        </div>\n      </div>\n\n      <ng-container *ngIf=\"contentCompletionPercent >= 50\">\n        <button mat-stroked-button color=\"accent\" type=\"button\" class=\"rate-button\"\n          (click)=\"openFeedbackDialog(content)\">\n          <mat-icon class=\"nodtranslate\">star_purple500</mat-icon>\n          <ng-container *ngIf=\"!userRating\">\n            <div>{{ 'apptocsinglepage.rateNow' | translate }}</div>\n          </ng-container>\n          <ng-container *ngIf=\"userRating\">\n            <div>{{ 'apptocsinglepage.editRating' | translate }}</div>\n          </ng-container>\n        </button>\n      </ng-container>\n    </div>\n  </ng-template>\n\n  <div class=\"toc-banner\">\n    <div class=\"flex flex-row gap-6 fixed-width\">\n      <div class=\"banner-details toc-content\" #bannerDetails>\n        <div class=\"flex flex-col gap-4\">\n          <div class=\"mobile-back-btn\" (click)=\"goBack()\">\n            <mat-icon class=\"text-white\">arrow_back</mat-icon>\n          </div>\n          <div class=\"flex items-center justify-between gap-4\">\n            <ng-container *ngIf=\"skeletonLoader\">\n              <ws-widget-skeleton-loader [width]=\"'132px'\" [height]=\"'32px'\"\n                [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n              <ws-widget-skeleton-loader [width]=\"'140px'\" [height]=\"'24px'\"\n                [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n            </ng-container>\n\n            <ng-container *ngIf=\"!skeletonLoader\">\n              <div class=\"flex flex-row gap-2\">\n                <div class=\"flex flex-row tag-div rounded-2xl gap-1 items-center p-2\">\n                  <mat-icon class=\"ws-mat-orange-text nodtranslate\">video_library</mat-icon>\n                  <ng-container *ngIf=\"contentReadData?.courseCategory\">\n                    <div class=\"text-xs font-bold text-white leading-3 nodtranslate\">{{\n                      translateLabel(contentReadData?.courseCategory, 'searchfilters') }}</div>\n                  </ng-container>\n                  <ng-container *ngIf=\"!contentReadData?.courseCategory\">\n                    <div class=\"text-xs font-bold text-white leading-3 nodtranslate\">{{\n                      translateLabel(contentReadData?.primaryCategory, 'searchfilters') }}</div>\n                  </ng-container>\n                </div>\n                <div class=\"flex flex-row tag-div rounded-2xl gap-1 items-center p-2\"\n                  *ngIf=\"contentReadData?.additionalTags?.includes('iGOT Specialization')\">\n                  <img class=\"approved-icon\" src=\"./assets/icons/approved.svg\" alt=\"approved\">\n                  <div class=\"text-xs font-bold text-white leading-3 nodtranslate\">{{\n                    'cardcontentv2.iGOTSpecializationProgram' | translate }}</div>\n                </div>\n                <!-- Knowledge level block for search box -->\n                <!-- {{content?.difficultyLevel}} -->\n                <div *ngIf=\"contentReadData?.difficultyLevel\" class=\"knowledge-level-container\">\n                  <span *ngIf=\"contentReadData?.difficultyLevel?.toLowerCase() === 'beginner'\"\n                    class=\"level-badge beginner\">\n                    <!-- <span *ngIf=\"false\" class=\"level-badge beginner\"> -->\n                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\">\n                      <rect width=\"16\" height=\"16\" fill=\"#DBF4DC\" />\n                      <path\n                        d=\"M7.42267 5C7.67927 4.55555 8.32077 4.55556 8.57737 5L12.0415 11C12.2981 11.4444 11.9773 12 11.4641 12H4.53592C4.02272 12 3.70197 11.4444 3.95857 11L7.42267 5Z\"\n                        fill=\"#49C951\" />\n                    </svg>\n                    {{contentReadData?.difficultyLevel}}\n                  </span>\n                  <span *ngIf=\"contentReadData?.difficultyLevel?.toLowerCase() === 'intermediate'\"\n                    class=\"level-badge intermediate\">\n                    <!-- <span *ngIf=\"true\" class=\"level-badge intermediate\"> -->\n                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\">\n                      <rect width=\"16\" height=\"16\" fill=\"#D1DBEC\" />\n                      <path\n                        d=\"M7.42267 2.66666C7.67927 2.22221 8.32077 2.22221 8.57737 2.66666L12.0415 8.66666C12.2981 9.1111 11.9773 9.66666 11.4641 9.66666H4.53592C4.02272 9.66666 3.70197 9.1111 3.95857 8.66666L7.42267 2.66666Z\"\n                        fill=\"#1B4CA1\" />\n                      <path\n                        d=\"M7.42267 5.66666C7.67927 5.22221 8.32077 5.22221 8.57737 5.66666L12.0415 11.6667C12.2981 12.1111 11.9773 12.6667 11.4641 12.6667H4.53592C4.02272 12.6667 3.70197 12.1111 3.95857 11.6667L7.42267 5.66666Z\"\n                        fill=\"#1B4CA1\" stroke=\"#D1DBEC\" stroke-width=\"0.5\" />\n                    </svg>\n                    {{contentReadData?.difficultyLevel}}\n                  </span>\n                  <span *ngIf=\"contentReadData?.difficultyLevel?.toLowerCase() === 'advanced'\"\n                    class=\"level-badge advanced\">\n                    <!-- <span *ngIf=\"false\" class=\"level-badge advanced\"> -->\n                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\">\n                      <g clip-path=\"url(#clip0)\">\n                        <rect width=\"16\" height=\"16\" fill=\"#FFE6E1\" />\n                        <path\n                          d=\"M7.42264 2.33334C7.67924 1.8889 8.32074 1.8889 8.57734 2.33334L12.0414 8.33334C12.298 8.77779 11.9773 9.33334 11.4641 9.33334H4.53589C4.02269 9.33334 3.70194 8.77779 3.95854 8.33334L7.42264 2.33334Z\"\n                          fill=\"#FF8268\" />\n                        <path\n                          d=\"M7.42264 5C7.67924 4.55555 8.32074 4.55556 8.57734 5L12.0414 11C12.298 11.4444 11.9773 12 11.4641 12H4.53589C4.02269 12 3.70194 11.4444 3.95854 11L7.42264 5Z\"\n                          fill=\"#FF8268\" stroke=\"#FFE6E1\" stroke-width=\"0.5\" />\n                        <path\n                          d=\"M7.42264 7.66669C7.67924 7.22224 8.32074 7.22224 8.57734 7.66669L12.0414 13.6667C12.298 14.1111 11.9773 14.6667 11.4641 14.6667H4.53589C4.02269 14.6667 3.70194 14.1111 3.95854 13.6667L7.42264 7.66669Z\"\n                          fill=\"#FF8268\" stroke=\"#FFE6E1\" stroke-width=\"0.5\" />\n                      </g>\n                      <defs>\n                        <clipPath id=\"clip0\">\n                          <rect width=\"16\" height=\"16\" fill=\"white\" />\n                        </clipPath>\n                      </defs>\n                    </svg>\n                    {{contentReadData?.difficultyLevel}}\n                  </span>\n                </div>\n\n                <div class=\"flex items-center\" *ngIf=\"cbPlanEndDate\">\n                  <div class=\"flex items-center due-tag text-xs leading-3\"\n                    [ngClass]=\"{'due-warning': cbPlanDuration === nsCardContentData.UPCOMING, 'due-overdue': cbPlanDuration === nsCardContentData.OVERDUE, 'due-success': cbPlanDuration === nsCardContentData.SUCCESS}\">\n                    {{ 'common.dueBy' | translate }} - &nbsp;<span class=\"font-bold\">{{ cbPlanEndDate | date: 'd\n                      MMM,y'}}</span>\n                  </div>\n                </div>\n              </div>\n            </ng-container>\n            <ng-container *ngIf=\"!skeletonLoader && contentReadData?.contentVersionInfo?.identifier\">\n              <div class=\"new-version-chip rounded-2xl\" (click)=\"navigateToNewVersion()\"\n                (keydown)=\"navigateToNewVersion()\">\n                <span class=\"new-version-text nodtranslate\">{{ 'apptoc.newVersion' | translate }}</span>\n              </div>\n            </ng-container>\n            <div class=\"flex items-center text-white mob-share\" *ngIf=\"canShare\">\n              <mat-icon class=\"nodtranslate\" (click)=\"onClickOfShare()\">share</mat-icon>\n            </div>\n          </div>\n          <div class=\"flex flex-col gap-2\">\n            <ng-container *ngIf=\"skeletonLoader\">\n              <ws-widget-skeleton-loader [width]=\"'90%'\" [height]=\"'32px'\"\n                [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n              <ws-widget-skeleton-loader [width]=\"'70%'\" [height]=\"'32px'\"\n                [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n            </ng-container>\n            <ng-container *ngIf=\"!skeletonLoader\">\n              <div class=\"banner-text text-base sm:text-4xl leading-6 sm:leading-10 font-bold nodtranslate\">{{\n                handleCapitalize(contentReadData?.name) }}</div>\n              <div class=\"text-sm sm:text-base source-text font-semibold break-words nodtranslate\" #contentSource\n                [ngClass]=\"{'sourceEllipsis': sourceEllipsis}\" title=\"{{contentReadData?.source}}\">{{ 'cardcontentv2.by'\n                | translate }} {{ contentReadData?.source }}</div>\n            </ng-container>\n          </div>\n\n          <ng-container *ngIf=\"skeletonLoader\">\n            <ws-widget-skeleton-loader [width]=\"'120px'\" [height]=\"'40px'\"\n              [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n            <ws-widget-skeleton-loader [width]=\"'88px'\" [height]=\"'24px'\"\n              [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n          </ng-container>\n          <ng-container *ngIf=\"!skeletonLoader\">\n            <div class=\"flex gap-4 items-center\">\n              <div class=\"flex flex-row rating-chip py-2 items-center cursor-pointer\"\n                (click)=\"handleNavigateToReviews()\" *ngIf=\"content?.averageRating\">\n                <div class=\"flex flex-row gap-1 margin-left-s items-center\">\n                  <mat-icon class=\"nodtranslate\">grade</mat-icon>\n                  <div class=\"text-white text-sm leading-4\">{{ content?.averageRating }}</div>\n                </div>\n                <div class=\"separator\"></div>\n                <div class=\"text-white text-sm leading-4 margin-right-m\">{{ content?.totalRating | pipeCountTransform }}\n                </div>\n              </div>\n              <div class=\"flex items-center\" *ngIf=\"content?.additionalTags?.length\">\n                <div class=\"most-enrolled-chip text-xs leading-3\">\n                  <span *ngIf=\"content?.additionalTags?.includes('mostTrending')\">{{ 'cardcontentv2.mostTrending' |\n                    translate }}</span>\n                  <span *ngIf=\"content?.additionalTags?.includes('mostEnrolled')\">{{ 'cardcontentv2.mostEnrolled' |\n                    translate }}</span>\n                </div>\n              </div>\n              <div class=\"flex items-center\" *ngIf=\"contentReadData?.retirementDate\">\n                <div class=\"new-version-pill text-xs leading-3\" *ngIf=\"contentReadData?.status !== 'Retired'\">\n                  <span>{{ 'apptoc.pendingRetirement' | translate }}</span>\n                </div>\n                <div class=\"new-version-retire-pill text-xs leading-3\" *ngIf=\"contentReadData?.status === 'Retired'\">\n                  <span>{{ 'apptoc.retired' | translate }}</span>\n                </div>\n              </div>\n            </div>\n          </ng-container>\n          <ng-container *ngIf=\"skeletonLoader\">\n            <ws-widget-skeleton-loader [width]=\"'180px'\" [height]=\"'20px'\"\n              [bindingClass]=\"'rounded blue-2-loader'\"></ws-widget-skeleton-loader>\n          </ng-container>\n          <ng-container *ngIf=\"!skeletonLoader && contentReadData?.sYS_INTERNAL_LAST_UPDATED_ON\">\n            <div class=\"text-xs leading-4 source-text nodtranslate\">({{ 'apptoc.lastUpdatedOn' | translate }} {{\n              contentReadData?.sYS_INTERNAL_LAST_UPDATED_ON | date: 'MMM d, y' }})</div>\n          </ng-container>\n          <ng-container>\n            <div class=\"flex flex-row gap-2\" *ngIf=\"languageList?.length > 1\">\n              <mat-chip-list class=\"lang-chips\">\n                <!-- Show up to 6 chips -->\n                <ng-container *ngFor=\"let lang of languageList | slice:0:5; let i = index\">\n                  <mat-chip class=\"matchip-custom\" selectable=\"true\"\n                    [selected]=\"lang?.identifier === selectedLanguage?.identifier\" (click)=\"onLanguageSelect(lang)\">\n                    {{ lang.name || lang.value }}\n                  </mat-chip>\n                </ng-container>\n\n                <!-- \"More\" chip if there are more than 6 languages -->\n                <ng-container *ngIf=\"languageList.length > 5\">\n                  <mat-chip [matMenuTriggerFor]=\"moreLanguagesMenu\" selectable=\"false\" class=\"more-chip matchip-custom\"\n                    [selected]=\"isSelectedInMoreDropdown()\">\n                    More <mat-icon class=\"mat-icon\">keyboard_arrow_down</mat-icon>\n                  </mat-chip>\n                  <mat-menu #moreLanguagesMenu=\"matMenu\">\n                    <mat-radio-group class=\"mat-radio-group flex flex-col gap-2 p-3\" [value]=\"selectedLanguage\">\n                      <mat-radio-button *ngFor=\"let lang of languageList | slice:5\" [value]=\"lang\"\n                        [checked]=\"lang?.identifier === selectedLanguage?.identifier\" (change)=\"onLanguageSelect(lang)\">\n                        {{ lang.displayName || lang.name || lang }}\n                      </mat-radio-button>\n                    </mat-radio-group>\n                  </mat-menu>\n                </ng-container>\n              </mat-chip-list>\n            </div>\n          </ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"flex flex-row gap-6 fixed-width\">\n    <div class=\"toc-content\">\n      <ng-container *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM &&\n        selectedBatchData?.content[0]?.batchAttributes?.batchLocationDetails &&\n        selectedBatchData?.content[0]?.enrollmentEndDate\">\n        <div class=\"location-details mt-6\">\n          <div class=\"flex items-center gap-4 pb-3\">\n            <mat-icon class=\"location-icon nodtranslate\">\n              location_on\n            </mat-icon>\n            <div class=\"loc-desc\">\n              {{selectedBatchData?.content[0]?.batchAttributes?.batchLocationDetails}}\n            </div>\n          </div>\n          <div class=\"flex items-center gap-4\">\n            <mat-icon class=\"event-icon nodtranslate\">\n              event</mat-icon>\n            <div class=\"loc-desc\">\n              Last date of enrollment - {{selectedBatchData?.content[0]?.enrollmentEndDate | date: 'dd/MM/yyyy'}}\n            </div>\n          </div>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"recommendedCoursesId && !feedbackGiven\">\n        <div class=\"px-4 py-3 mt-6 relevent-wrapper\">\n          <div class=\"flex gap-4 items-center flex-wrap flex justify-center md:justify-start\">\n            <img src=\"/assets/images/sakshamAI/lady-greet.svg\" alt=\"greet\" width=\"56.89\" height=\"64\">\n            <div class=\"relevent-info\">\n              <span class=\"font-bolder text-sm relevent-heading block mb-1\">{{ 'home.tocReleventHeading' | translate\n                }}</span>\n              <span class=\"relevent-subinfo font-normal text-sm block\">{{ 'home.tocReleventSubHeading' | translate\n                }}</span>\n            </div>\n            <div class=\"flex flex-middle relevant-container\">\n              <div class=\"flex flex-middle relevent-normal relevent-btn py-2 px-4 relevant-box\"\n                (mouseenter)=\"isReleventBtnHovered = true\" (mouseleave)=\"isReleventBtnHovered = false\"\n                (click)=\"handleAcceptRelevent()\">\n                <img [src]=\"isReleventBtnHovered && !isRelevent ? SAKSHAMAI_ICON_LOADER : SAKSHAMAI_ICON_NORMAL\"\n                  alt=\"loader\" width=\"16\" height=\"16\" class=\"mr-2\">\n                <span class=\"text-relevent ff-lato text-sm font-bold\">{{ 'home.relevent' | translate }}</span>\n              </div>\n\n              <div class=\"flex flex-middle no-button ml-8\" (click)=\"handleDeclineRelevent()\">\n                <mat-icon class=\"mat-icon text-no mr-1 nodtranslate\">thumb_down</mat-icon>\n                <span class=\"text-no ff-lato text-sm font-bold\">{{ 'home.no' | translate }}</span>\n              </div>\n            </div>\n          </div>\n        </div>\n      </ng-container>\n      <div class=\"pb-4 lg:py-4\"\n        *ngIf=\"contentReadData?.identifier && content?.identifier && baseContentReadData?.identifier\">\n        <!-- Overall progress functionality -->\n        <div class=\"mobile-progress\">\n          <ng-container [ngTemplateOutlet]=\"progressFunctionality\"></ng-container>\n        </div>\n        <!-- Overall progress functionality -->\n        <ws-widget-content-toc [content]=\"content\" [componentName]=\"'toc'\" [pathSet]=\"pathSet\"\n          [tocStructure]=\"tocStructure\" [forPreview]=\"forPreview\" [isEnrolled]=\"batchData?.enrolled\"\n          [resumeData]=\"resumeData\" [batchData]=\"selectedBatchData\" [skeletonLoader]=\"skeletonLoader\"\n          [changeTab]=\"changeTab\" [hierarchyMapData]=\"tocSvc?.hashmap\" [selectedBatchData]=\"selectedBatchData\"\n          [condition]=\"{isPostAssessment: isPostAssessment, content: content, isAcbpCourse: isAcbpCourse, isClaimed: isClaimed, monthlyCapExceed: monthlyCapExceed, isCompletedThisMonth: isCompletedThisMonth, showTakeAssessment: showTakeAssessment, userEnrollmentList: userEnrollmentList, resumeData: resumeData, userRating: userRating, enrollBtnLoading: enrollBtnLoading, primaryCategory: primaryCategory, currentCourseBatchId: currentCourseBatchId, isAcbpClaim: isAcbpClaim}\"\n          [kparray]=\"kparray\" (playResumeForAI)=\"playResumeForAI()\" (enrollUserToAI)=\"enrollUserToAI()\"\n          [contentReadData]=\"contentReadData\" [baseContentReadData]=\"baseContentReadData\" [languageList]=\"languageList\"\n          [lockCertificate]=\"lockCertificate\" (trigerCompletionSurveyForm)=\"openSurveyFormPopup($event)\"\n          (resumeContent)=\"resumeContentData()\"></ws-widget-content-toc>\n        <div class=\"mob-tip-for-learner\">\n          <div *ngIf=\"learnAdvisoryData && learnAdvisoryData?.length\">\n            <ws-widget-tips-for-learner-card [learnAdvisoryData]=\"learnAdvisoryData\"></ws-widget-tips-for-learner-card>\n          </div>\n        </div>\n      </div>\n    </div>\n\n\n    <div class=\"right-container\">\n\n      <!-- if needed sticky of right container add this to below div => #rightContainer -->\n      <div class=\"right-content\">\n        <div class=\"right-content-inner\">\n          <ng-container *ngIf=\"skeletonLoader\">\n            <ws-widget-skeleton-loader [width]=\"'384px'\" [height]=\"'224px'\"\n              [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n          </ng-container>\n          <ng-container *ngIf=\"!skeletonLoader\">\n            <div class=\"flex flex-col image-div\"\n              [ngStyle]=\"{\n        'background-image': 'url(' + contentReadData?.posterImage + ')', 'background-repeat': 'no-repeat', 'background-size': 'cover'}\"\n              [ngClass]=\"{'image-backdrop': scrolled}\">\n              <div class=\"flex flex-col justify-between text-container\">\n                <div class=\"flex items-center gap-4 justify-between\"\n                  [ngClass]=\"{'justify-between': scrolled, 'justify-end': !scrolled}\">\n                  <div class=\"flex flex-row tag-div rounded-2xl gap-1 items-center p-2\" *ngIf=\"scrolled\">\n                    <mat-icon class=\"ws-mat-orange-text nodtranslate\">video_library</mat-icon>\n                    <ng-container *ngIf=\"contentReadData?.courseCategory\">\n                      <div class=\"text-xs font-bold text-white leading-3\">{{\n                        translateLabel(contentReadData?.courseCategory, 'searchfilters') }}</div>\n                    </ng-container>\n                    <ng-container *ngIf=\"!contentReadData?.courseCategory\">\n                      <div class=\"text-xs font-bold text-white leading-3\">{{\n                        translateLabel(contentReadData?.primaryCategory, 'searchfilters') }}</div>\n                    </ng-container>\n                  </div>\n                  <div (click)=\"onClickOfShare()\" class=\"flex flex-row items-center justify-end gap-2 share-tag\"\n                    *ngIf=\"canShare && !forPreview\">\n                    <mat-icon class=\"nodtranslate\">share</mat-icon>\n                    <div>{{ 'apptocsinglepage.share' | translate }}</div>\n                  </div>\n                </div>\n                <div class=\"flex flex-col gap-1\" *ngIf=\"scrolled\">\n                  <div class=\"text-xl leading-6 text-white font-bold\">{{ handleCapitalize(contentReadData?.name) }}\n                  </div>\n                  <div class=\"text-sm source-text font-semibold break-words\" #contentSource\n                    [ngClass]=\"{'sourceEllipsis': sourceEllipsis}\" title=\"{{contentReadData?.source}}\">{{\n                    'cardcontentv2.by' | translate }} {{ contentReadData?.source }}</div>\n                </div>\n              </div>\n            </div>\n          </ng-container>\n\n\n          <div class=\"flex flex-col gap-4 p-5 border-bottom\">\n            <div class=\"flex flex-col gap-1  cursor-pointer switch-version\"\n              *ngIf=\"!skeletonLoader && contentReadData?.contentVersionInfo?.identifier\"\n              (click)=\"navigateToNewVersion()\" (keydown)=\"navigateToNewVersion()\">\n              <span class=\"btn-switch\">{{ 'apptoc.switchToNewVersion' | translate }}</span>\n            </div>\n\n            <div class=\"flex flex-col gap-4\"\n              *ngIf=\"contentReadData && contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM\">\n              <div class=\"flex flex-row gap-3 justify-around\">\n                <div class=\"batch-info\">\n                  <div class=\"font-base font-bold\">{{ selectedBatchData?.content[0]?.batchAttributes?.currentBatchSize\n                    || '0' }}</div>\n                  <div class=\"batch-label\">{{ 'apptoc.batchSize' | translate }}</div>\n                </div>\n                <div class=\"batch-info\">\n                  <div class=\"font-base font-bold\">{{ selectedBatchData?.userCount?.totalApplied || '0' }}</div>\n                  <div class=\"batch-label\">{{ 'apptoc.totalApplied' | translate }}</div>\n                </div>\n                <div class=\"batch-info\">\n                  <div class=\"font-base font-bold\">{{ selectedBatchData?.userCount?.enrolled || '0' }}</div>\n                  <div class=\"batch-label\">{{ 'apptoc.totalEnrolled' | translate }}</div>\n                </div>\n              </div>\n              <ng-container\n                *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM && !preAssessmentCompletionStatus\">\n                <a class=\"flex action-button enroll-btn justify-center resume\"\n                  *ngIf=\"contentReadData?.preEnrolmentResources?.length\" (click)=\"routeToPreAssessent()\">\n                  <ng-container>\n                    {{ 'apptochome.preEnroll' | translate }}\n                  </ng-container>\n                </a>\n              </ng-container>\n              <ng-container\n                *ngIf=\"contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM && preAssessmentCompletionStatus\">\n                <a class=\"flex preenrolldone-btn justify-center resume\">\n                  <ng-container>\n                    {{ 'apptochome.preEnrollDone' | translate }}<img src=\"/assets/icons/Accept_icon.png\" alt=\"tick\"\n                      class=\"tick-icon\">\n                  </ng-container>\n                </a>\n              </ng-container>\n              <ng-container\n                *ngIf=\"timer && timer.days >= 0 && contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM\">\n                <div class=\"flex flex-col gap-6 batch-timer\">\n                  <div class=\"flex flex-row\">\n                    <div class=\"flex-1\">\n                      <div class=\"flex underline\"></div>\n                    </div>\n                    <div class=\"flex\">\n                      <div class=\"timer-label\">{{ 'apptocsinglepage.batchStartsIn' | translate }}</div>\n                    </div>\n                    <div class=\"flex-1\">\n                      <div class=\"flex underline\"></div>\n                    </div>\n                  </div>\n                  <div class=\"flex flex-row gap-4 justify-center\">\n                    <div class=\"flex flex-row gap-1 items-center\">\n                      <div class=\"text-4xl leading-10 counter\">{{ timer.days || 0 }}</div>\n                      <div class=\"counter-label\">{{ 'apptocsinglepage.days' | translate }}</div>\n                    </div>\n                    <div class=\"flex items-center counter-label\">\n                      :\n                    </div>\n                    <div class=\"flex flex-row gap-1 items-center\">\n                      <div class=\"text-4xl leading-10 counter\">{{ timer.min === 60 ? timer.hours + 1 : timer.hours }}\n                      </div>\n                      <div class=\"counter-label\">{{ 'apptocsinglepage.hours' | translate }}</div>\n                    </div>\n                    <div class=\"flex items-center counter-label\">\n                      :\n                    </div>\n                    <div class=\"flex flex-row gap-1 items-center\">\n                      <div class=\"text-4xl leading-10 counter\">{{ timer.min === 60 ? 00 : timer.min }}</div>\n                      <div class=\"counter-label\">{{ 'apptocsinglepage.minutes' | translate }}</div>\n                    </div>\n                  </div>\n                </div>\n              </ng-container>\n              <ng-container *ngIf=\"!forPreview || isInIFrame; else authViewBtn\">\n                <ng-container *ngIf=\"!mobile1200 && (\n         !contentReadData?.preEnrolmentResources?.length ||\n         (contentReadData?.preEnrolmentResources?.length && (preAssessmentCompletionStatus ||  !preAssessmentRequiredFlag))\n       )\">\n\n                  <ws-app-toc-banner role=\"banner\" [banners]=\"banners\" [forPreview]=\"forPreview\" [content]=\"content\"\n                    [userEnrollmentList]=\"userEnrollmentList\" (withdrawOrEnroll)=\"withdrawOrEnroll($event)\"\n                    [analytics]=\"analytics\" [resumeData]=\"resumeData\" [batchData]=\"batchData\"\n                    [contentReadData]=\"contentReadData\">\n                  </ws-app-toc-banner>\n                </ng-container>\n              </ng-container>\n            </div>\n\n\n            <ng-container *ngIf=\"skeletonLoader\">\n              <ws-widget-skeleton-loader [width]=\"'336px'\" [height]=\"'40px'\"\n                [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n              <ws-widget-skeleton-loader [width]=\"'336px'\" [height]=\"'68px'\"\n                [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n            </ng-container>\n\n            <ng-container *ngIf=\"!skeletonLoader\">\n              <div class=\"flex flex-col gap-4\">\n                <div class=\"flex flex-row items-center gap-2 info-div\" *ngIf=\"content?.isInIntranet && showIntranetMsg\">\n                  <mat-icon class=\"nodtranslate\">info</mat-icon>\n                  <ng-container>{{ 'apptochome.viewedInIntranet' | translate }}</ng-container>\n                </div>\n                <div class=\"flex flex-row items-center gap-2 info-div\" *ngIf=\"showInstructorLedMsg\">\n                  <mat-icon class=\"nodtranslate\">info</mat-icon>&nbsp;\n                  <ng-container>{{ 'apptochome.notAvailableOnline' | translate }}</ng-container>\n                </div>\n                <div class=\"flex flex-row items-center gap-2 info-div\" *ngIf=\"showStart.msg === 'youtubeForbidden'\">\n                  <mat-icon class=\"nodtranslate\">info</mat-icon>&nbsp;\n                  <ng-container>{{ 'apptochome.youtubeContentBlocked' | translate }}</ng-container>\n                </div>\n                <div *ngIf=\"showBtn\">\n                  <a href=\"{{ cscmsUrl }}\" target=\"_blank\" class=\"flex action-button justify-center\">\n                    {{ 'apptochome.applyForPhysicalTraining' | translate }}</a>\n                </div>\n\n                <!-- Overall progress functionality -->\n                <ng-container *ngIf=\"content?.completionStatus <= 2 && isBatchInProgress\">\n                  <ng-container [ngTemplateOutlet]=\"progressFunctionality\"></ng-container>\n                </ng-container>\n                <!-- Overall progress functionality -->\n\n                <!-- <div *ngIf=\"resumeData && !userRating\"> -->\n                <!-- <ws-app-karmapoints-panel [btntype]=\"'Rate this course'\" [data]=\"kparray\"\n                  [pCategory]=\"contentReadData?.primaryCategory\"></ws-app-karmapoints-panel> -->\n                <!-- </div> -->\n\n                <!-- <div *ngIf=\"resumeData && userRating\">\n                <ws-app-karmapoints-panel [btntype]=\"'Edit rating'\" [data]=\"kparray\"\n                  [pCategory]=\"contentReadData?.primaryCategory\"></ws-app-karmapoints-panel>\n              </div> -->\n\n                <ng-container\n                  *ngIf=\"actionBtnStatus !== 'wait' && contentReadData?.status !== 'Deleted' && contentReadData?.status !== 'Expired'\">\n                  <ng-container [ngTemplateOutlet]=\"enrollFunctionality\"></ng-container>\n                </ng-container>\n              </div>\n\n              <div class=\"karma-points-div\">\n                <ws-widget-karma-points [data]=\"kparray\" (clickClaimKarmaPoints)=\"onClickOfClaim($event)\"\n                  [content]=\"content\"\n                  [condition]=\"{isPostAssessment: isPostAssessment, content: content, isAcbpCourse: isAcbpCourse, isClaimed: isClaimed, monthlyCapExceed: monthlyCapExceed, isCompletedThisMonth: isCompletedThisMonth, showTakeAssessment: showTakeAssessment, userEnrollmentList: userEnrollmentList, isCompletedThisMonth: isCompletedThisMonth, resumeData: resumeData, userRating: userRating, enrollBtnLoading: enrollBtnLoading, primaryCategory: primaryCategory, currentCourseBatchId: currentCourseBatchId, isAcbpClaim: isAcbpClaim}\"></ws-widget-karma-points>\n              </div>\n            </ng-container>\n\n            <ng-container *ngIf=\"skeletonLoader\">\n              <div class=\"flex flex-wrap gap-6\">\n                <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n                  <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n                    [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                  <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n                    [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                </div>\n                <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n                  <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n                    [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                  <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n                    [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                </div>\n                <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n                  <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n                    [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                  <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n                    [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                </div>\n                <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n                  <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n                    [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                  <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n                    [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                </div>\n                <div class=\"flex flex-col items-center gap-2 kpi-loader-div\">\n                  <ws-widget-skeleton-loader [width]=\"'28px'\" [height]=\"'28px'\"\n                    [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                  <ws-widget-skeleton-loader [width]=\"'40px'\" [height]=\"'8px'\"\n                    [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                  <ws-widget-skeleton-loader [width]=\"'48px'\" [height]=\"'8px'\"\n                    [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                </div>\n              </div>\n            </ng-container>\n\n            <ng-container *ngIf=\"!skeletonLoader\">\n              <ws-widget-toc-kpi-values [content]=\"content\" [tocStructure]=\"tocStructure\"\n                [showInstructorLedMsg]=\"showInstructorLedMsg\" [contentReadData]=\"contentReadData\"\n                [languageList]=\"languageList\"></ws-widget-toc-kpi-values>\n            </ng-container>\n          </div>\n\n          <div class=\"flex flex-col gap-8 p-5\">\n            <ng-container *ngIf=\"skeletonLoader\">\n              <div class=\"flex flex-col gap-4\" *ngFor=\"let i of [1, 2]\">\n                <ws-widget-skeleton-loader [width]=\"'72px'\" [height]=\"'20px'\"\n                  [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n\n                <div class=\"flex flex-row items-center gap-3\">\n                  <ws-widget-skeleton-loader [width]=\"'36px'\" [height]=\"'36px'\"\n                    [bindingClass]=\"'rounded-full'\"></ws-widget-skeleton-loader>\n                  <div class=\"flex flex-col gap-2\">\n                    <ws-widget-skeleton-loader [width]=\"'124px'\" [height]=\"'20px'\"\n                      [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                    <ws-widget-skeleton-loader [width]=\"'124px'\" [height]=\"'12px'\"\n                      [bindingClass]=\"'rounded'\"></ws-widget-skeleton-loader>\n                  </div>\n                </div>\n              </div>\n            </ng-container>\n\n            <ng-container *ngIf=\"!skeletonLoader\">\n              <div class=\"flex flex-col gap-3\" *ngIf=\"handleParseJsonData(contentReadData?.creatorDetails)?.length\">\n                <div class=\"text-base font-bold\">{{ 'apptocsinglepage.authors' | translate }}</div>\n                <div class=\"flex flex-row gap-4 items-center\"\n                  *ngFor=\"let author of handleParseJsonData(contentReadData?.creatorDetails)\">\n                  <div class=\"flex items-center justify-center\">\n                    <ws-widget-avatar-photo [randomColor]=\"true\" [datalen]=\"1\" [size]=\"'round-m'\"\n                      [photoUrl]=\"author?.photo || ''\" [name]=\"author?.name\">\n                    </ws-widget-avatar-photo>\n                  </div>\n                  <div class=\"flex flex-col gap-1 justify-center\">\n                    <div class=\"font-bold\">{{ handleCapitalize(author?.name, 'name') }}</div>\n                    <div class=\"text-xs leading-3\">{{ 'apptocsinglepage.author' | translate }}</div>\n                  </div>\n                </div>\n              </div>\n              <div class=\"flex flex-col gap-3\" *ngIf=\"handleParseJsonData(contentReadData?.creatorContacts)?.length\">\n                <div class=\"text-base font-bold\">{{ 'apptocsinglepage.creators' | translate }}</div>\n                <div class=\"flex flex-row gap-4 items-center\"\n                  *ngFor=\"let creeator of handleParseJsonData(contentReadData?.creatorContacts)\">\n                  <div class=\"flex items-center justify-center\">\n                    <ws-widget-avatar-photo [randomColor]=\"true\" [datalen]=\"1\" [size]=\"'round-m'\"\n                      [photoUrl]=\"creeator?.photo || ''\" [name]=\"creeator?.name\">\n                    </ws-widget-avatar-photo>\n                  </div>\n                  <div class=\"flex flex-col gap-1 justify-center\">\n                    <div class=\"font-bold\">{{ handleCapitalize(creeator?.name, 'name') }}</div>\n                    <div class=\"text-xs leading-3\">{{ 'apptocsinglepage.creator' | translate }}</div>\n                  </div>\n                </div>\n              </div>\n              <div class=\"flex flex-col gap-3\"\n                *ngIf=\"contentReadData?.source  && (contentCreatorData && contentCreatorData?.length)\">\n                <div class=\"text-base font-bold\">{{ 'apptocsinglepage.provider' | translate }}</div>\n                <div class=\"flex flex-row gap-4 items-center\" *ngFor=\"let creator of contentCreatorData\">\n                  <div class=\"flex provider-logo-div\">\n                    <img *ngIf=\"contentReadData?.creatorLogo\" [src]=\"contentReadData?.creatorLogo\"\n                      alt=\"{{ 'apptocsinglepage.provider' | translate }}\" />\n                    <img *ngIf=\"!contentReadData?.creatorLogo\" class=\"mat-icon\"\n                      src=\"/assets/instances/eagle/app_logos/KarmayogiBharat_Logo.svg\"\n                      alt=\"{{ 'apptocsinglepage.provider' | translate }}\" />\n                  </div>\n                  <div class=\"text-sm word-break cursor-pointer\" *ngIf=\"contentReadData?.createdFor?.length\"\n                    (click)=\"raiseTelemeteryForProvider(contentReadData?.source, contentReadData?.createdFor[0])\"\n                    [routerLink]=\"['/app/learn/browse-by/provider', contentReadData?.source, contentReadData?.createdFor[0], 'micro-sites']\">\n                    {{ handleCapitalize(contentReadData?.source, 'source') }}\n                  </div>\n                  <div class=\"text-sm word-break\" *ngIf=\"!contentReadData?.createdFor?.length\">{{\n                    handleCapitalize(contentReadData?.source, 'source') }}\n                  </div>\n                </div>\n              </div>\n            </ng-container>\n          </div>\n        </div>\n\n        <div *ngIf=\"learnAdvisoryData && learnAdvisoryData?.length\">\n          <ws-widget-tips-for-learner-card [learnAdvisoryData]=\"learnAdvisoryData\"></ws-widget-tips-for-learner-card>\n        </div>\n      </div>\n\n\n\n    </div>\n  </div>\n  <div class=\"mobile-enroll-div\"\n    [ngClass]=\"{'bg-white': contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM }\">\n    <ng-container *ngIf=\"content && contentReadData?.primaryCategory === primaryCategory.BLENDED_PROGRAM \">\n      <div class=\"mb-2\" *ngIf=\"mobile1200 && !forPreview || isInIFrame; else authViewBtn\">\n        <ws-app-toc-banner role=\"banner\" [banners]=\"banners\" [forPreview]=\"forPreview\" [content]=\"content\"\n          [userEnrollmentList]=\"userEnrollmentList\" (withdrawOrEnroll)=\"withdrawOrEnroll($event)\"\n          [analytics]=\"analytics\" [resumeData]=\"resumeData\" [batchData]=\"batchData\" [contentReadData]=\"contentReadData\">\n        </ws-app-toc-banner>\n      </div>\n    </ng-container>\n    <ng-container [ngTemplateOutlet]=\"enrollFunctionality\"></ng-container>\n  </div>\n\n  <ws-app-share-toc *ngIf=\"enableShare\" [rootOrgId]=\"rootOrgId\" [content]=\"content\"\n    (resetEnableShare)=\"resetEnableShare($event)\" [baseContentReadData]=\"baseContentReadData\"></ws-app-share-toc>\n</ng-container>\n<ng-template #noDataFound>\n  <div\n    class=\"error-not-found flex flex-wrapped margin-left-m margin-top-xl margin-right-m flex-col justify-center align-items-center text-center\">\n    <div class=\"error-logo\">\n      <div class=\"error-message ws-mat-primary-text font-weight-bold\">\n        The page you requested cannot be found\n      </div>\n    </div>\n    <!-- <div class=\"error-support\">\n      <div class=\"support-message\" >We have updated our web site and many URLs have changed.</div>\n      <div class=\"support-message\" >You might want to:</div>\n    </div> -->\n  </div>\n\n</ng-template>\n\n<ng-template #authView>{{'apptochome.view' | translate}}</ng-template>\n\n<ng-template #authViewBtn i18n>\n  <ng-container *ngIf=\"displayViewBtn\">\n    <a (click)=\"raiseTelemetryForPublic($event)\"\n    [routerLink]=\"shouldShowSurveyPopup() ? null : ((resumeData && !certData) ? resumeDataLink?.url : firstResourceLink?.url)\"\n    [queryParams]=\"shouldShowSurveyPopup() ? null : ((resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START'))\"\n    class=\"flex action-button justify-center\">\n    {{'apptochome.view' | translate}}\n  </a>\n  </ng-container>\n</ng-template>\n<ng-template #authViewForInviteOnlyAssessment>\n  <ng-container *ngIf=\"forPreview && contentReadData?.courseCategory === 'Invite-Only Assessment'\">\n    <a class=\"flex action-button justify-center resume\" [routerLink]=\"firstResourceLink?.url\"\n      [queryParams]=\"(resumeData && !certData) ? generateQuery('RESUME') : generateQuery('START')\">\n      <ng-container>{{ 'apptochome.takeTest' | translate }}</ng-container>\n    </a>\n  </ng-container>\n</ng-template>"]}