@cuemath/leap 2.8.55 → 2.8.56-as1

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 (192) hide show
  1. package/dist/assets/illustrations/illustrations.js +9 -0
  2. package/dist/assets/illustrations/illustrations.js.map +1 -1
  3. package/dist/assets/line-icons/icons/alarm.js +41 -0
  4. package/dist/assets/line-icons/icons/alarm.js.map +1 -0
  5. package/dist/assets/line-icons/icons/dart.js +23 -0
  6. package/dist/assets/line-icons/icons/dart.js.map +1 -0
  7. package/dist/assets/line-icons/icons/exclamation.js +26 -0
  8. package/dist/assets/line-icons/icons/exclamation.js.map +1 -0
  9. package/dist/assets/line-icons/icons/home2.js +25 -0
  10. package/dist/assets/line-icons/icons/home2.js.map +1 -0
  11. package/dist/assets/line-icons/icons/important.js +23 -0
  12. package/dist/assets/line-icons/icons/important.js.map +1 -0
  13. package/dist/assets/line-icons/icons/puzzle.js +25 -0
  14. package/dist/assets/line-icons/icons/puzzle.js.map +1 -0
  15. package/dist/assets/line-icons/icons/recap.js +32 -0
  16. package/dist/assets/line-icons/icons/recap.js.map +1 -0
  17. package/dist/assets/line-icons/icons/status.js +41 -0
  18. package/dist/assets/line-icons/icons/status.js.map +1 -0
  19. package/dist/assets/line-icons/icons/testtube.js +33 -0
  20. package/dist/assets/line-icons/icons/testtube.js.map +1 -0
  21. package/dist/features/analytics-events/whitelist-events.js +7 -9
  22. package/dist/features/analytics-events/whitelist-events.js.map +1 -1
  23. package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js +98 -33
  24. package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js.map +1 -1
  25. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js +76 -47
  26. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
  27. package/dist/features/chapters/chapters-list/chapters-list-styled.js +5 -5
  28. package/dist/features/chapters/chapters-list/chapters-list-styled.js.map +1 -1
  29. package/dist/features/chapters/chapters-list/chapters-list.js +65 -70
  30. package/dist/features/chapters/chapters-list/chapters-list.js.map +1 -1
  31. package/dist/features/chapters-v2/api/chapter.js +10 -0
  32. package/dist/features/chapters-v2/api/chapter.js.map +1 -0
  33. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js +112 -0
  34. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js.map +1 -0
  35. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections-styled.js +26 -0
  36. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections-styled.js.map +1 -0
  37. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js +69 -0
  38. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js.map +1 -0
  39. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner-styled.js +90 -0
  40. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner-styled.js.map +1 -0
  41. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner.js +97 -0
  42. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner.js.map +1 -0
  43. package/dist/features/chapters-v2/chapter-details/chapter-details-styled.js +52 -0
  44. package/dist/features/chapters-v2/chapter-details/chapter-details-styled.js.map +1 -0
  45. package/dist/features/chapters-v2/chapter-details/chapter-details.js +103 -0
  46. package/dist/features/chapters-v2/chapter-details/chapter-details.js.map +1 -0
  47. package/dist/features/chapters-v2/comps/node-card/border-path-animation.js +13 -0
  48. package/dist/features/chapters-v2/comps/node-card/border-path-animation.js.map +1 -0
  49. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js +153 -0
  50. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js.map +1 -0
  51. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js +16 -0
  52. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js.map +1 -0
  53. package/dist/features/chapters-v2/comps/node-card/node-card.js +12 -0
  54. package/dist/features/chapters-v2/comps/node-card/node-card.js.map +1 -0
  55. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options-styled.js +32 -0
  56. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options-styled.js.map +1 -0
  57. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options.js +31 -0
  58. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options.js.map +1 -0
  59. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js +160 -0
  60. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js.map +1 -0
  61. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js +184 -0
  62. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js.map +1 -0
  63. package/dist/features/chapters-v2/comps/tag/tag-styled.js +13 -0
  64. package/dist/features/chapters-v2/comps/tag/tag-styled.js.map +1 -0
  65. package/dist/features/chapters-v2/comps/tag/tag.js +28 -0
  66. package/dist/features/chapters-v2/comps/tag/tag.js.map +1 -0
  67. package/dist/features/chapters-v2/constants/block-constants.js +20 -0
  68. package/dist/features/chapters-v2/constants/block-constants.js.map +1 -0
  69. package/dist/features/chapters-v2/constants/node-constants.js +15 -0
  70. package/dist/features/chapters-v2/constants/node-constants.js.map +1 -0
  71. package/dist/features/chapters-v2/utils/index.js +41 -0
  72. package/dist/features/chapters-v2/utils/index.js.map +1 -0
  73. package/dist/features/chapters-v2/utils/node-card-utils.js +106 -0
  74. package/dist/features/chapters-v2/utils/node-card-utils.js.map +1 -0
  75. package/dist/features/circle-games/games/tutorial/tutorial.js +14 -13
  76. package/dist/features/circle-games/games/tutorial/tutorial.js.map +1 -1
  77. package/dist/features/homework/card-menu-options.js +36 -0
  78. package/dist/features/homework/card-menu-options.js.map +1 -0
  79. package/dist/features/homework/homework-card.js +136 -0
  80. package/dist/features/homework/homework-card.js.map +1 -0
  81. package/dist/features/homework/styles.js +114 -0
  82. package/dist/features/homework/styles.js.map +1 -0
  83. package/dist/features/homework/utils.js +28 -0
  84. package/dist/features/homework/utils.js.map +1 -0
  85. package/dist/features/hooks/use-auto-play-permission/use-auto-play-permission-context-provider.js +10 -10
  86. package/dist/features/hooks/use-auto-play-permission/use-auto-play-permission-context-provider.js.map +1 -1
  87. package/dist/features/milestone/edit/comps/edit-milestone-modal/index.js +51 -53
  88. package/dist/features/milestone/edit/comps/edit-milestone-modal/index.js.map +1 -1
  89. package/dist/features/milestone/milestone-list-container/api/get-milestones.js +9 -17
  90. package/dist/features/milestone/milestone-list-container/api/get-milestones.js.map +1 -1
  91. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js +116 -91
  92. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js.map +1 -1
  93. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js +105 -121
  94. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js.map +1 -1
  95. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js +145 -173
  96. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js.map +1 -1
  97. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs-styled.js +24 -10
  98. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs-styled.js.map +1 -1
  99. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js +76 -81
  100. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js.map +1 -1
  101. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-utils.js +10 -22
  102. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-utils.js.map +1 -1
  103. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-styled.js +70 -37
  104. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-styled.js.map +1 -1
  105. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js +114 -174
  106. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js.map +1 -1
  107. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-rank.js +29 -16
  108. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-rank.js.map +1 -1
  109. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-styled.js +19 -23
  110. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-styled.js.map +1 -1
  111. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome.js +23 -35
  112. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome.js.map +1 -1
  113. package/dist/features/milestone/milestone-list-container/milestone-list-container.js +34 -36
  114. package/dist/features/milestone/milestone-list-container/milestone-list-container.js.map +1 -1
  115. package/dist/features/milestone/milestone-resources/resources-list/resources-list-styled.js +1 -1
  116. package/dist/features/milestone/milestone-resources/resources-list/resources-list-styled.js.map +1 -1
  117. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js +96 -78
  118. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js.map +1 -1
  119. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js +6 -34
  120. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js.map +1 -1
  121. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js +73 -73
  122. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js.map +1 -1
  123. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js +8 -7
  124. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js.map +1 -1
  125. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js +77 -68
  126. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js.map +1 -1
  127. package/dist/features/recent-chapters/api/get-recent-chapters.js +9 -0
  128. package/dist/features/recent-chapters/api/get-recent-chapters.js.map +1 -0
  129. package/dist/features/recent-chapters/recent-chapters-styled.js +23 -0
  130. package/dist/features/recent-chapters/recent-chapters-styled.js.map +1 -0
  131. package/dist/features/recent-chapters/recent-chapters.js +49 -0
  132. package/dist/features/recent-chapters/recent-chapters.js.map +1 -0
  133. package/dist/features/sheets/resources-list/resource-item/resource-item.js +65 -179
  134. package/dist/features/sheets/resources-list/resource-item/resource-item.js.map +1 -1
  135. package/dist/features/sheets/resources-list/resources-list.js +5 -5
  136. package/dist/features/sheets/resources-list/resources-list.js.map +1 -1
  137. package/dist/features/sheets/resources-list/styled.js +9 -13
  138. package/dist/features/sheets/resources-list/styled.js.map +1 -1
  139. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/teacher-actions/teacher-actions-constant.js +4 -3
  140. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/teacher-actions/teacher-actions-constant.js.map +1 -1
  141. package/dist/features/sheets/utils/is-v3-worksheet.js.map +1 -1
  142. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js +30 -29
  143. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js.map +1 -1
  144. package/dist/features/ui/constants/z-index.js +1 -1
  145. package/dist/features/ui/constants/z-index.js.map +1 -1
  146. package/dist/features/ui/context-menu/context-menu-styled.js +28 -14
  147. package/dist/features/ui/context-menu/context-menu-styled.js.map +1 -1
  148. package/dist/features/ui/context-menu/context-menu.js +30 -15
  149. package/dist/features/ui/context-menu/context-menu.js.map +1 -1
  150. package/dist/features/ui/theme/button.js +17 -102
  151. package/dist/features/ui/theme/button.js.map +1 -1
  152. package/dist/index.d.ts +200 -12
  153. package/dist/index.js +487 -469
  154. package/dist/index.js.map +1 -1
  155. package/dist/static/chapter-header-bg-2.c8d96894.svg +1 -0
  156. package/dist/static/node-custom-test-bg.d3b757be.svg +1 -0
  157. package/dist/static/node-learn-bg.b61f815c.svg +1 -0
  158. package/dist/static/node-practice-bg.16cbaf2a.svg +1 -0
  159. package/dist/static/node-project-bg.e6a33e28.svg +1 -0
  160. package/dist/static/node-puzzle-bg.3422135c.svg +1 -0
  161. package/dist/static/node-recap-bg.546154e4.svg +1 -0
  162. package/dist/static/node-test-prep-bg.42c0b9c4.svg +1 -0
  163. package/dist/static/node-video-bg.3df3f73a.svg +1 -0
  164. package/package.json +1 -1
  165. package/dist/assets/line-icons/icons/closed-eye.js +0 -23
  166. package/dist/assets/line-icons/icons/closed-eye.js.map +0 -1
  167. package/dist/features/milestone/create/comps/milestone-progress-v2/milestone-progress-v2.js +0 -92
  168. package/dist/features/milestone/create/comps/milestone-progress-v2/milestone-progress-v2.js.map +0 -1
  169. package/dist/features/milestone/create/comps/milestone-progress-v2/styled.js +0 -25
  170. package/dist/features/milestone/create/comps/milestone-progress-v2/styled.js.map +0 -1
  171. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element-styled.js +0 -13
  172. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element-styled.js.map +0 -1
  173. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element.js +0 -38
  174. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element.js.map +0 -1
  175. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-status.js +0 -53
  176. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-status.js.map +0 -1
  177. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-info.js +0 -25
  178. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-info.js.map +0 -1
  179. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js +0 -71
  180. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js.map +0 -1
  181. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js +0 -31
  182. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js.map +0 -1
  183. package/dist/features/sheets/resources-list/resource-item/context-menu-helper/menu-element-styled.js +0 -15
  184. package/dist/features/sheets/resources-list/resource-item/context-menu-helper/menu-element-styled.js.map +0 -1
  185. package/dist/features/sheets/resources-list/resource-item/context-menu-helper/menu-element.js +0 -26
  186. package/dist/features/sheets/resources-list/resource-item/context-menu-helper/menu-element.js.map +0 -1
  187. package/dist/features/sheets/resources-list/resource-item/styled.js +0 -38
  188. package/dist/features/sheets/resources-list/resource-item/styled.js.map +0 -1
  189. package/dist/features/sheets/resources-list/resource-item/utils.js +0 -23
  190. package/dist/features/sheets/resources-list/resource-item/utils.js.map +0 -1
  191. package/dist/features/sheets/sheets-analytics-events.js +0 -11
  192. package/dist/features/sheets/sheets-analytics-events.js.map +0 -1
@@ -0,0 +1,112 @@
1
+ import { jsx as t, jsxs as n } from "react/jsx-runtime";
2
+ import k from "../../../../assets/line-icons/icons/more-vertical.js";
3
+ import I from "../../../../assets/line-icons/icons/skip.js";
4
+ import O from "../../../ui/context-menu/context-menu.js";
5
+ import c from "../../../ui/layout/flex-view.js";
6
+ import f from "../../../ui/text/text.js";
7
+ import T from "../../comps/node-card/node-card.js";
8
+ import j from "../../comps/node-card/node-menu-options/node-menu-options.js";
9
+ import { BLOCK_NAME as y } from "../../constants/block-constants.js";
10
+ import { getSheetNLessonCount as M } from "../../utils/index.js";
11
+ import { BlockSectionWrapper as B, BlockOptionsWrapper as K, BlockSheetContainer as V } from "./block-sections-styled.js";
12
+ const J = ({
13
+ userType: o,
14
+ imageHue: m,
15
+ blockData: s,
16
+ lessonIdx: p,
17
+ isLastBlock: $,
18
+ isGoalBlock: r,
19
+ onNodeAttempt: u,
20
+ onNodeAttemptLocationChange: C,
21
+ onNodeMarkAsDone: g,
22
+ onNodeReattempt: x,
23
+ onNodeReview: _,
24
+ onNodeView: b,
25
+ onBlockSkipUnskip: i
26
+ }) => {
27
+ const { block_type: l, name: E, sheets: a, is_skipped: e, permissions: N } = s, { can_skip: w, can_unskip: d } = N, A = y[l], L = M(e, a.length, r, p), S = [
28
+ {
29
+ id: "node-card-skip",
30
+ label: d ? "Revert 'Skip'" : "Skip",
31
+ icon: I,
32
+ disabled: !1,
33
+ onClick: () => i == null ? void 0 : i(s, !e)
34
+ }
35
+ ];
36
+ return o === "STUDENT" && e ? null : /* @__PURE__ */ t(
37
+ B,
38
+ {
39
+ $background: r ? `${m}_1` : "WHITE_1",
40
+ $gutterX: 1,
41
+ $lastBlock: $,
42
+ $flexGap: 12,
43
+ children: /* @__PURE__ */ n(c, { $flexGap: 12, children: [
44
+ /* @__PURE__ */ n(c, { $flexDirection: "row", $alignItems: "center", $justifyContent: "space-between", children: [
45
+ /* @__PURE__ */ n(c, { $opacity: e ? 0.5 : 1, children: [
46
+ /* @__PURE__ */ n(
47
+ f,
48
+ {
49
+ $renderAs: "ac4",
50
+ $color: "BLACK_T_60",
51
+ $textDecoration: e ? "line-through" : "none",
52
+ children: [
53
+ A,
54
+ " ",
55
+ L
56
+ ]
57
+ }
58
+ ),
59
+ r && (p ?? 0) > 0 && /* @__PURE__ */ t(
60
+ f,
61
+ {
62
+ $renderAs: "ab2-bold",
63
+ $color: "BLACK_1",
64
+ $textDecoration: e ? "line-through" : "none",
65
+ children: E
66
+ }
67
+ )
68
+ ] }),
69
+ o === "TEACHER" && (w || d) && /* @__PURE__ */ t(
70
+ O,
71
+ {
72
+ targetElement: /* @__PURE__ */ t(
73
+ K,
74
+ {
75
+ $width: 20,
76
+ $height: 20,
77
+ $justifyContent: "center",
78
+ $alignItems: "center",
79
+ children: /* @__PURE__ */ t(k, { width: 16, height: 16 })
80
+ }
81
+ ),
82
+ menuElement: /* @__PURE__ */ t(j, { options: S }),
83
+ menuOffset: 5,
84
+ menuZIndex: 4
85
+ }
86
+ )
87
+ ] }),
88
+ /* @__PURE__ */ t(V, { $opacity: e ? 0.5 : 1, children: a.map((h) => /* @__PURE__ */ t(
89
+ T,
90
+ {
91
+ imageHue: m || "BLUE",
92
+ userType: o,
93
+ nodeData: h,
94
+ blockType: l,
95
+ isSkipped: e,
96
+ onNodeAttempt: u,
97
+ onNodeAttemptLocationChange: C,
98
+ onNodeMarkAsDone: g,
99
+ onNodeReattempt: x,
100
+ onNodeReview: _,
101
+ onNodeView: b
102
+ },
103
+ h.node_id
104
+ )) })
105
+ ] })
106
+ }
107
+ );
108
+ };
109
+ export {
110
+ J as default
111
+ };
112
+ //# sourceMappingURL=block-section-view.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"block-section-view.js","sources":["../../../../../src/features/chapters-v2/chapter-details/block-sections/block-section-view.tsx"],"sourcesContent":["import type { INodeMenuOption } from '../../comps/node-card/node-menu-options/node-menu-options-types';\nimport type { IBlockSectionProps } from './block-sections-types';\nimport type { FC } from 'react';\n\nimport MoreVerticalIcon from '../../../../assets/line-icons/icons/more-vertical';\nimport SkipIcon from '../../../../assets/line-icons/icons/skip';\nimport ContextMenu from '../../../ui/context-menu/context-menu';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\nimport NodeCard from '../../comps/node-card/node-card';\nimport NodeMenuOptions from '../../comps/node-card/node-menu-options/node-menu-options';\nimport { BLOCK_NAME } from '../../constants/block-constants';\nimport { getSheetNLessonCount } from '../../utils';\nimport * as Styled from './block-sections-styled';\n\nconst BlockSectionView: FC<IBlockSectionProps> = ({\n userType,\n imageHue,\n blockData,\n lessonIdx,\n isLastBlock,\n isGoalBlock,\n onNodeAttempt,\n onNodeAttemptLocationChange,\n onNodeMarkAsDone,\n onNodeReattempt,\n onNodeReview,\n onNodeView,\n onBlockSkipUnskip,\n}) => {\n const { block_type: blockType, name, sheets, is_skipped: isSkipped, permissions } = blockData;\n\n const { can_skip: canSkip, can_unskip: canUnskip } = permissions;\n const blockName = BLOCK_NAME[blockType];\n\n const sheetNLessonCount = getSheetNLessonCount(isSkipped, sheets.length, isGoalBlock, lessonIdx);\n\n const menuOptions: INodeMenuOption[] = [\n {\n id: 'node-card-skip',\n label: canUnskip ? `Revert 'Skip'` : 'Skip',\n icon: SkipIcon,\n disabled: false,\n onClick: () => onBlockSkipUnskip?.(blockData, !isSkipped),\n },\n ];\n\n if (userType === 'STUDENT' && isSkipped) return null;\n\n return (\n <Styled.BlockSectionWrapper\n $background={isGoalBlock ? `${imageHue}_1` : 'WHITE_1'}\n $gutterX={1}\n $lastBlock={isLastBlock}\n $flexGap={12}\n >\n <FlexView $flexGap={12}>\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $justifyContent=\"space-between\">\n <FlexView $opacity={isSkipped ? 0.5 : 1}>\n <Text\n $renderAs=\"ac4\"\n $color=\"BLACK_T_60\"\n $textDecoration={isSkipped ? 'line-through' : 'none'}\n >\n {blockName} {sheetNLessonCount}\n </Text>\n\n {isGoalBlock && (lessonIdx ?? 0) > 0 && (\n <Text\n $renderAs=\"ab2-bold\"\n $color=\"BLACK_1\"\n $textDecoration={isSkipped ? 'line-through' : 'none'}\n >\n {name}\n </Text>\n )}\n </FlexView>\n\n {userType === 'TEACHER' && (canSkip || canUnskip) && (\n <ContextMenu\n targetElement={\n <Styled.BlockOptionsWrapper\n $width={20}\n $height={20}\n $justifyContent=\"center\"\n $alignItems=\"center\"\n >\n <MoreVerticalIcon width={16} height={16} />\n </Styled.BlockOptionsWrapper>\n }\n menuElement={<NodeMenuOptions options={menuOptions} />}\n menuOffset={5}\n menuZIndex={4}\n />\n )}\n </FlexView>\n\n <Styled.BlockSheetContainer $opacity={isSkipped ? 0.5 : 1}>\n {sheets.map(nodeData => (\n <NodeCard\n key={nodeData.node_id}\n imageHue={imageHue || 'BLUE'}\n userType={userType}\n nodeData={nodeData}\n blockType={blockType}\n isSkipped={isSkipped}\n onNodeAttempt={onNodeAttempt}\n onNodeAttemptLocationChange={onNodeAttemptLocationChange}\n onNodeMarkAsDone={onNodeMarkAsDone}\n onNodeReattempt={onNodeReattempt}\n onNodeReview={onNodeReview}\n onNodeView={onNodeView}\n />\n ))}\n </Styled.BlockSheetContainer>\n </FlexView>\n </Styled.BlockSectionWrapper>\n );\n};\n\nexport default BlockSectionView;\n"],"names":["BlockSectionView","userType","imageHue","blockData","lessonIdx","isLastBlock","isGoalBlock","onNodeAttempt","onNodeAttemptLocationChange","onNodeMarkAsDone","onNodeReattempt","onNodeReview","onNodeView","onBlockSkipUnskip","blockType","name","sheets","isSkipped","permissions","canSkip","canUnskip","blockName","BLOCK_NAME","sheetNLessonCount","getSheetNLessonCount","menuOptions","SkipIcon","jsx","Styled.BlockSectionWrapper","jsxs","FlexView","Text","ContextMenu","Styled.BlockOptionsWrapper","MoreVerticalIcon","NodeMenuOptions","Styled.BlockSheetContainer","nodeData","NodeCard"],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import o from "styled-components";
2
+ import p from "../../../ui/layout/flex-view.js";
3
+ const i = o(p)(({ $lastBlock: r }) => `
4
+ padding-top: 32px;
5
+ ${r ? "padding-bottom: 32px;" : "padding-bottom: 0px;"}
6
+ `), n = o.div(({ $opacity: r }) => `
7
+ display: grid;
8
+ grid-template-columns: repeat(4, 1fr);
9
+ grid-row-gap: 12px;
10
+ grid-column-gap: 16px;
11
+ opacity: ${r ?? 1};
12
+
13
+ `), d = o(p)(({ theme: r }) => `
14
+ cursor: pointer;
15
+
16
+ &:hover {
17
+ border-radius: 50%;
18
+ background: ${r.colors.WHITE_4};
19
+ }
20
+ `);
21
+ export {
22
+ d as BlockOptionsWrapper,
23
+ i as BlockSectionWrapper,
24
+ n as BlockSheetContainer
25
+ };
26
+ //# sourceMappingURL=block-sections-styled.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"block-sections-styled.js","sources":["../../../../../src/features/chapters-v2/chapter-details/block-sections/block-sections-styled.tsx"],"sourcesContent":["import styled from 'styled-components';\n\nimport FlexView from '../../../ui/layout/flex-view';\n\ninterface IBlockSectionWrapper {\n $lastBlock?: boolean;\n}\n\nconst BlockSectionWrapper = styled(FlexView)<IBlockSectionWrapper>(({ $lastBlock }) => {\n return `\n padding-top: 32px;\n ${$lastBlock ? 'padding-bottom: 32px;' : 'padding-bottom: 0px;'}\n `;\n});\n\ninterface IBlockSheetContainer {\n $opacity?: number;\n}\n\nconst BlockSheetContainer = styled.div<IBlockSheetContainer>(({ $opacity }) => {\n return `\n display: grid;\n grid-template-columns: repeat(4, 1fr);\n grid-row-gap: 12px;\n grid-column-gap: 16px;\n opacity: ${$opacity ?? 1};\n\n `;\n});\n\nconst BlockOptionsWrapper = styled(FlexView)(({ theme }) => {\n return `\n cursor: pointer;\n \n &:hover {\n border-radius: 50%;\n background: ${theme.colors.WHITE_4}; \n }\n `;\n});\n\nexport { BlockSectionWrapper, BlockSheetContainer, BlockOptionsWrapper };\n"],"names":["BlockSectionWrapper","styled","FlexView","$lastBlock","BlockSheetContainer","$opacity","BlockOptionsWrapper","theme"],"mappings":";;AAQA,MAAMA,IAAsBC,EAAOC,CAAQ,EAAwB,CAAC,EAAE,YAAAC,QAC7D;AAAA;AAAA,MAEHA,IAAa,0BAA0B,sBAAsB;AAAA,GAElE,GAMKC,IAAsBH,EAAO,IAA0B,CAAC,EAAE,UAAAI,QACvD;AAAA;AAAA;AAAA;AAAA;AAAA,eAKMA,KAAY,CAAC;AAAA;AAAA,GAG3B,GAEKC,IAAsBL,EAAOC,CAAQ,EAAE,CAAC,EAAE,OAAAK,QACvC;AAAA;AAAA;AAAA;AAAA;AAAA,oBAKWA,EAAM,OAAO,OAAO;AAAA;AAAA,GAGvC;"}
@@ -0,0 +1,69 @@
1
+ import { jsxs as x, jsx as u } from "react/jsx-runtime";
2
+ import { memo as G } from "react";
3
+ import L from "../../../ui/layout/flex-view.js";
4
+ import B from "./block-section-view.js";
5
+ const O = G((A) => {
6
+ const {
7
+ blocks: t,
8
+ imageHue: n,
9
+ userType: i,
10
+ onNodeAttempt: s,
11
+ onNodeAttemptLocationChange: c,
12
+ onNodeMarkAsDone: l,
13
+ onNodeReattempt: r,
14
+ onNodeReview: p,
15
+ onNodeView: d,
16
+ onBlockSkipUnskip: k
17
+ } = A;
18
+ let m = 0;
19
+ const a = t.filter((o) => o.section_code === "GOALS"), N = t.filter((o) => o.section_code !== "GOALS");
20
+ return /* @__PURE__ */ x(L, { $width: "100%", children: [
21
+ a.map((o, e) => {
22
+ const { block_type: S, block_id: _, is_skipped: b } = o;
23
+ let f = 0;
24
+ const w = e === a.length - 1;
25
+ return S === "GOAL" && (b || (m += 1), f = m), /* @__PURE__ */ u(
26
+ B,
27
+ {
28
+ blockData: o,
29
+ userType: i,
30
+ isLastBlock: w,
31
+ lessonIdx: f,
32
+ imageHue: n,
33
+ isGoalBlock: !0,
34
+ onNodeAttempt: s,
35
+ onNodeAttemptLocationChange: c,
36
+ onNodeMarkAsDone: l,
37
+ onNodeReattempt: r,
38
+ onNodeReview: p,
39
+ onNodeView: d,
40
+ onBlockSkipUnskip: k
41
+ },
42
+ _
43
+ );
44
+ }),
45
+ N.map((o) => {
46
+ const { block_id: e } = o;
47
+ return /* @__PURE__ */ u(
48
+ B,
49
+ {
50
+ blockData: o,
51
+ userType: i,
52
+ imageHue: n,
53
+ onNodeAttempt: s,
54
+ onNodeAttemptLocationChange: c,
55
+ onNodeMarkAsDone: l,
56
+ onNodeReattempt: r,
57
+ onNodeReview: p,
58
+ onNodeView: d,
59
+ onBlockSkipUnskip: k
60
+ },
61
+ e
62
+ );
63
+ })
64
+ ] });
65
+ });
66
+ export {
67
+ O as default
68
+ };
69
+ //# sourceMappingURL=block-sections.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"block-sections.js","sources":["../../../../../src/features/chapters-v2/chapter-details/block-sections/block-sections.tsx"],"sourcesContent":["import type { IBlockSectionsProps } from './block-sections-types';\nimport type { FC } from 'react';\n\nimport { memo } from 'react';\n\nimport FlexView from '../../../ui/layout/flex-view';\nimport BlockSectionView from './block-section-view';\n\nconst BlockSections: FC<IBlockSectionsProps> = memo(props => {\n const {\n blocks,\n imageHue,\n userType,\n onNodeAttempt,\n onNodeAttemptLocationChange,\n onNodeMarkAsDone,\n onNodeReattempt,\n onNodeReview,\n onNodeView,\n onBlockSkipUnskip,\n } = props;\n\n let lessonCount = 0;\n\n const goalBlocks = blocks.filter(block => block.section_code === 'GOALS');\n const nonGoalBlocks = blocks.filter(block => block.section_code !== 'GOALS');\n\n return (\n <FlexView $width=\"100%\">\n {goalBlocks.map((blockData, idx) => {\n const { block_type: blockType, block_id: blockId, is_skipped: isSkipped } = blockData;\n let lessonIdx = 0;\n\n const isLastBlock = idx === goalBlocks.length - 1;\n\n if (blockType === 'GOAL') {\n if (!isSkipped) {\n lessonCount += 1;\n }\n\n lessonIdx = lessonCount;\n }\n\n return (\n <BlockSectionView\n blockData={blockData}\n userType={userType}\n isLastBlock={isLastBlock}\n key={blockId}\n lessonIdx={lessonIdx}\n imageHue={imageHue}\n isGoalBlock\n onNodeAttempt={onNodeAttempt}\n onNodeAttemptLocationChange={onNodeAttemptLocationChange}\n onNodeMarkAsDone={onNodeMarkAsDone}\n onNodeReattempt={onNodeReattempt}\n onNodeReview={onNodeReview}\n onNodeView={onNodeView}\n onBlockSkipUnskip={onBlockSkipUnskip}\n />\n );\n })}\n\n {nonGoalBlocks.map(blockData => {\n const { block_id: blockId } = blockData;\n\n return (\n <BlockSectionView\n key={blockId}\n blockData={blockData}\n userType={userType}\n imageHue={imageHue}\n onNodeAttempt={onNodeAttempt}\n onNodeAttemptLocationChange={onNodeAttemptLocationChange}\n onNodeMarkAsDone={onNodeMarkAsDone}\n onNodeReattempt={onNodeReattempt}\n onNodeReview={onNodeReview}\n onNodeView={onNodeView}\n onBlockSkipUnskip={onBlockSkipUnskip}\n />\n );\n })}\n </FlexView>\n );\n});\n\nexport default BlockSections;\n"],"names":["BlockSections","memo","props","blocks","imageHue","userType","onNodeAttempt","onNodeAttemptLocationChange","onNodeMarkAsDone","onNodeReattempt","onNodeReview","onNodeView","onBlockSkipUnskip","lessonCount","goalBlocks","block","nonGoalBlocks","jsxs","FlexView","blockData","idx","blockType","blockId","isSkipped","lessonIdx","isLastBlock","jsx","BlockSectionView"],"mappings":";;;;AAQM,MAAAA,IAAyCC,EAAK,CAASC,MAAA;AACrD,QAAA;AAAA,IACJ,QAAAC;AAAA,IACA,UAAAC;AAAA,IACA,UAAAC;AAAA,IACA,eAAAC;AAAA,IACA,6BAAAC;AAAA,IACA,kBAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,cAAAC;AAAA,IACA,YAAAC;AAAA,IACA,mBAAAC;AAAA,EACE,IAAAV;AAEJ,MAAIW,IAAc;AAElB,QAAMC,IAAaX,EAAO,OAAO,CAASY,MAAAA,EAAM,iBAAiB,OAAO,GAClEC,IAAgBb,EAAO,OAAO,CAASY,MAAAA,EAAM,iBAAiB,OAAO;AAGzE,SAAA,gBAAAE,EAACC,GAAS,EAAA,QAAO,QACd,UAAA;AAAA,IAAWJ,EAAA,IAAI,CAACK,GAAWC,MAAQ;AAClC,YAAM,EAAE,YAAYC,GAAW,UAAUC,GAAS,YAAYC,EAAc,IAAAJ;AAC5E,UAAIK,IAAY;AAEV,YAAAC,IAAcL,MAAQN,EAAW,SAAS;AAEhD,aAAIO,MAAc,WACXE,MACYV,KAAA,IAGLW,IAAAX,IAIZ,gBAAAa;AAAA,QAACC;AAAA,QAAA;AAAA,UACC,WAAAR;AAAA,UACA,UAAAd;AAAA,UACA,aAAAoB;AAAA,UAEA,WAAAD;AAAA,UACA,UAAApB;AAAA,UACA,aAAW;AAAA,UACX,eAAAE;AAAA,UACA,6BAAAC;AAAA,UACA,kBAAAC;AAAA,UACA,iBAAAC;AAAA,UACA,cAAAC;AAAA,UACA,YAAAC;AAAA,UACA,mBAAAC;AAAA,QAAA;AAAA,QAVKU;AAAA,MAAA;AAAA,IAWP,CAEH;AAAA,IAEAN,EAAc,IAAI,CAAaG,MAAA;AACxB,YAAA,EAAE,UAAUG,EAAY,IAAAH;AAG5B,aAAA,gBAAAO;AAAA,QAACC;AAAA,QAAA;AAAA,UAEC,WAAAR;AAAA,UACA,UAAAd;AAAA,UACA,UAAAD;AAAA,UACA,eAAAE;AAAA,UACA,6BAAAC;AAAA,UACA,kBAAAC;AAAA,UACA,iBAAAC;AAAA,UACA,cAAAC;AAAA,UACA,YAAAC;AAAA,UACA,mBAAAC;AAAA,QAAA;AAAA,QAVKU;AAAA,MAAA;AAAA,IAWP,CAEH;AAAA,EACH,EAAA,CAAA;AAEJ,CAAC;"}
@@ -0,0 +1,90 @@
1
+ import o from "styled-components";
2
+ import x from "../../../../assets/line-icons/icons/important.js";
3
+ import i from "../../../ui/layout/flex-view.js";
4
+ const f = o(i)(() => `
5
+ position: relative;
6
+ height: 168px;
7
+ `);
8
+ o.div`
9
+ width: 760px;
10
+ height: 100%;
11
+ position: relative;
12
+ `;
13
+ const m = o(i)`
14
+ position: absolute;
15
+ left: 73px;
16
+ top: 32px;
17
+ `, $ = o.img(({ theme: e }) => {
18
+ const { gutter: t } = e.layout;
19
+ return `
20
+ width: ${t * 6.625}px;
21
+ height: ${t * 6.625}px;
22
+ border-radius: 50%;
23
+ z-index: 1;
24
+ `;
25
+ }), y = o.svg(() => `
26
+ position: absolute;
27
+ inset: 50%;
28
+ transform: translate(-50%, -50%) rotate(-90deg);
29
+ z-index: 2;
30
+ `), I = o.circle(
31
+ ({ theme: e, $progressCircle: t, $progress: n, $progressBackground: s }) => {
32
+ const { colors: r, layout: l } = e, { WHITE_1: h } = r, { gutter: a } = l, p = a * 21, u = t ? p - n : n;
33
+ return `
34
+ stroke-dasharray: ${p};
35
+ stroke-dashoffset: ${u};
36
+ stroke: ${t ? r[s || "BLACK"] : h};
37
+
38
+ stroke-width: ${a * 0.1875}px;
39
+ fill: none;
40
+ `;
41
+ }
42
+ ), b = o(i)(({ theme: e }) => `
43
+ position: absolute;
44
+ top: 50%;
45
+ left: ${e.layout.gutter * 13.75}px;
46
+ transform: translateY(-50%);
47
+ z-index: 1;
48
+ `), k = o(x)(({
49
+ theme: e,
50
+ $progress: t,
51
+ $top: n,
52
+ $left: s
53
+ }) => {
54
+ const { gutter: r } = e.layout;
55
+ return t ? `
56
+ width: ${r * 1.25}px;
57
+ height: ${r * 1.25}px;
58
+ position: absolute;
59
+ top: ${n ?? 0}px;
60
+ left: ${s ?? 0}px;
61
+ transform: translate(-50%, -50%);
62
+ z-index: 2;
63
+ ` : `
64
+ width: ${r * 0.75}px;
65
+ height: ${r * 0.75}px;
66
+ `;
67
+ }), w = o.div(({ theme: e }) => {
68
+ const { layout: t } = e;
69
+ return `
70
+ position: absolute;
71
+ top: 6px;
72
+ right: 8px;
73
+ z-index: 2;
74
+
75
+ width: ${t.gutter * 1.25}px;
76
+ height: ${t.gutter * 1.25}px;
77
+ border-radius: 50%;
78
+ `;
79
+ });
80
+ export {
81
+ f as BannerContainer,
82
+ $ as BannerImage,
83
+ m as BannerImageWrapper,
84
+ b as BannerTitleWrapper,
85
+ y as ChapterProgressSVG,
86
+ I as ChapterProgressSVGCircle,
87
+ w as StyledCheckIcon,
88
+ k as StyledImportantIcon
89
+ };
90
+ //# sourceMappingURL=chapter-banner-styled.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chapter-banner-styled.js","sources":["../../../../../src/features/chapters-v2/chapter-details/chapter-banner/chapter-banner-styled.tsx"],"sourcesContent":["import type { TColorNames } from '../../../ui/types';\n\nimport styled from 'styled-components';\n\nimport ImportantIcon from '../../../../assets/line-icons/icons/important';\nimport FlexView from '../../../ui/layout/flex-view';\n\nconst BannerContainer = styled(FlexView)(() => {\n return `\n position: relative;\n height: 168px;\n `;\n});\n\nconst BannerContainerBg = styled.div`\n width: 760px;\n height: 100%;\n position: relative;\n`;\n\nconst BannerImageWrapper = styled(FlexView)`\n position: absolute;\n left: 73px;\n top: 32px;\n`;\n\nconst BannerImage = styled.img(({ theme }) => {\n const { gutter } = theme.layout;\n\n return `\n width: ${gutter * 6.625}px;\n height: ${gutter * 6.625}px;\n border-radius: 50%;\n z-index: 1;\n `;\n});\n\nconst ChapterProgressSVG = styled.svg(() => {\n return `\n position: absolute;\n inset: 50%;\n transform: translate(-50%, -50%) rotate(-90deg);\n z-index: 2;\n `;\n});\n\ninterface IChapterProgressSVGCircleProps {\n $progressCircle?: boolean;\n $progress: number;\n $progressBackground?: TColorNames;\n}\n\nconst ChapterProgressSVGCircle = styled.circle<IChapterProgressSVGCircleProps>(\n ({ theme, $progressCircle, $progress, $progressBackground }) => {\n const { colors, layout } = theme;\n const { WHITE_1 } = colors;\n const { gutter } = layout;\n\n const strokeDashArray = gutter * 21;\n const strokeDashOffset = $progressCircle ? strokeDashArray - $progress : $progress;\n\n return `\n stroke-dasharray: ${strokeDashArray};\n stroke-dashoffset: ${strokeDashOffset};\n stroke: ${$progressCircle ? colors[$progressBackground || 'BLACK'] : WHITE_1};\n\n stroke-width: ${gutter * 0.1875}px;\n fill: none;\n `;\n },\n);\n\nconst BannerTitleWrapper = styled(FlexView)(({ theme }) => {\n return `\n position: absolute;\n top: 50%;\n left: ${theme.layout.gutter * 13.75}px;\n transform: translateY(-50%);\n z-index: 1;\n `;\n});\n\ninterface IStyledImportantIconProps {\n $left?: number;\n $top?: number;\n $progress?: boolean;\n}\n\nconst StyledImportantIcon = styled(ImportantIcon)<IStyledImportantIconProps>(({\n theme,\n $progress,\n $top,\n $left,\n}) => {\n const { gutter } = theme.layout;\n\n if ($progress) {\n return `\n width: ${gutter * 1.25}px;\n height: ${gutter * 1.25}px;\n position: absolute;\n top: ${$top ?? 0}px;\n left: ${$left ?? 0}px;\n transform: translate(-50%, -50%);\n z-index: 2;\n `;\n }\n\n return `\n width: ${gutter * 0.75}px;\n height: ${gutter * 0.75}px;\n `;\n});\n\nconst StyledCheckIcon = styled.div(({ theme }) => {\n const { layout } = theme;\n\n return `\n position: absolute;\n top: 6px;\n right: 8px;\n z-index: 2;\n\n width: ${layout.gutter * 1.25}px;\n height: ${layout.gutter * 1.25}px;\n border-radius: 50%;\n `;\n});\n\nexport {\n BannerContainer,\n BannerContainerBg,\n BannerImageWrapper,\n BannerImage,\n ChapterProgressSVG,\n ChapterProgressSVGCircle,\n BannerTitleWrapper,\n StyledImportantIcon,\n StyledCheckIcon,\n};\n"],"names":["BannerContainer","styled","FlexView","BannerImageWrapper","BannerImage","theme","gutter","ChapterProgressSVG","ChapterProgressSVGCircle","$progressCircle","$progress","$progressBackground","colors","layout","WHITE_1","strokeDashArray","strokeDashOffset","BannerTitleWrapper","StyledImportantIcon","ImportantIcon","$top","$left","StyledCheckIcon"],"mappings":";;;AAOA,MAAMA,IAAkBC,EAAOC,CAAQ,EAAE,MAChC;AAAA;AAAA;AAAA,GAIR;AAEyBD,EAAO;AAAA;AAAA;AAAA;AAAA;AAM3B,MAAAE,IAAqBF,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,GAMpCE,IAAcH,EAAO,IAAI,CAAC,EAAE,OAAAI,QAAY;AACtC,QAAA,EAAE,QAAAC,EAAO,IAAID,EAAM;AAElB,SAAA;AAAA,aACIC,IAAS,KAAK;AAAA,cACbA,IAAS,KAAK;AAAA;AAAA;AAAA;AAI5B,CAAC,GAEKC,IAAqBN,EAAO,IAAI,MAC7B;AAAA;AAAA;AAAA;AAAA;AAAA,GAMR,GAQKO,IAA2BP,EAAO;AAAA,EACtC,CAAC,EAAE,OAAAI,GAAO,iBAAAI,GAAiB,WAAAC,GAAW,qBAAAC,QAA0B;AACxD,UAAA,EAAE,QAAAC,GAAQ,QAAAC,EAAW,IAAAR,GACrB,EAAE,SAAAS,EAAY,IAAAF,GACd,EAAE,QAAAN,EAAW,IAAAO,GAEbE,IAAkBT,IAAS,IAC3BU,IAAmBP,IAAkBM,IAAkBL,IAAYA;AAElE,WAAA;AAAA,0BACeK,CAAe;AAAA,2BACdC,CAAgB;AAAA,gBAC3BP,IAAkBG,EAAOD,KAAuB,OAAO,IAAIG,CAAO;AAAA;AAAA,sBAE5DR,IAAS,MAAM;AAAA;AAAA;AAAA,EAGnC;AACF,GAEMW,IAAqBhB,EAAOC,CAAQ,EAAE,CAAC,EAAE,OAAAG,QACtC;AAAA;AAAA;AAAA,YAGGA,EAAM,OAAO,SAAS,KAAK;AAAA;AAAA;AAAA,GAItC,GAQKa,IAAsBjB,EAAOkB,CAAa,EAA6B,CAAC;AAAA,EAC5E,OAAAd;AAAA,EACA,WAAAK;AAAA,EACA,MAAAU;AAAA,EACA,OAAAC;AACF,MAAM;AACE,QAAA,EAAE,QAAAf,EAAO,IAAID,EAAM;AAEzB,SAAIK,IACK;AAAA,eACIJ,IAAS,IAAI;AAAA,gBACZA,IAAS,IAAI;AAAA;AAAA,aAEhBc,KAAQ,CAAC;AAAA,cACRC,KAAS,CAAC;AAAA;AAAA;AAAA,QAMf;AAAA,aACIf,IAAS,IAAI;AAAA,cACZA,IAAS,IAAI;AAAA;AAE3B,CAAC,GAEKgB,IAAkBrB,EAAO,IAAI,CAAC,EAAE,OAAAI,QAAY;AAC1C,QAAA,EAAE,QAAAQ,EAAW,IAAAR;AAEZ,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,aAMIQ,EAAO,SAAS,IAAI;AAAA,cACnBA,EAAO,SAAS,IAAI;AAAA;AAAA;AAGlC,CAAC;"}
@@ -0,0 +1,97 @@
1
+ import { jsx as e, jsxs as t } from "react/jsx-runtime";
2
+ import { memo as B, useMemo as h } from "react";
3
+ import { ILLUSTRATIONS as D } from "../../../../assets/illustrations/illustrations.js";
4
+ import d from "../../../../assets/line-icons/icons/check2.js";
5
+ import V from "../../../ui/image/image.js";
6
+ import n from "../../../ui/layout/flex-view.js";
7
+ import i from "../../../ui/text/text.js";
8
+ import g from "../../comps/tag/tag.js";
9
+ import { getChapterCompletionPercentage as W } from "../../utils/index.js";
10
+ import { BannerContainer as b, BannerImageWrapper as M, BannerImage as O, ChapterProgressSVG as X, ChapterProgressSVGCircle as C, StyledImportantIcon as $, StyledCheckIcon as j, BannerTitleWrapper as H } from "./chapter-banner-styled.js";
11
+ const a = 52, l = 54, c = 54, ee = B((f) => {
12
+ const { progressStats: o, imageHue: I, title: S, imageUrl: x } = f, r = h(() => W(o), [o]), { iconTopVal: u, iconLeftVal: R } = h(() => {
13
+ const m = (-(r === 100 ? 60 : r) * 3.6 - 180) * Math.PI / 180, P = c + a * Math.sin(m), A = l + a * Math.cos(m);
14
+ return {
15
+ iconLeftVal: P,
16
+ iconTopVal: A
17
+ };
18
+ }, [r]);
19
+ if (!o) return null;
20
+ const { mandatory: E, optional: _, class_work: w } = o, { completed: T = 0, total: k = 0 } = E || {}, { completed: y = 0, total: s = 0 } = _ || {}, { completed: G = 0, total: p = 0 } = w || {}, L = p > 0 && G === p;
21
+ return /* @__PURE__ */ e(
22
+ b,
23
+ {
24
+ $flexDirection: "row",
25
+ $justifyContent: "center",
26
+ $alignItems: "center",
27
+ $widthX: 50,
28
+ $background: `${I}_4`,
29
+ children: /* @__PURE__ */ t(n, { $height: 168, $position: "relative", children: [
30
+ /* @__PURE__ */ e(
31
+ V,
32
+ {
33
+ width: "100%",
34
+ height: "168px",
35
+ src: D.CHAPTER_HEADER_BG,
36
+ alt: "Chapter header background",
37
+ withLoader: !0
38
+ }
39
+ ),
40
+ /* @__PURE__ */ t(M, { children: [
41
+ /* @__PURE__ */ e(O, { src: x, alt: "Chapter image" }),
42
+ /* @__PURE__ */ t(X, { width: "108px", height: "108px", children: [
43
+ /* @__PURE__ */ e(
44
+ C,
45
+ {
46
+ $progress: 0,
47
+ r: a,
48
+ cx: l,
49
+ cy: c
50
+ }
51
+ ),
52
+ /* @__PURE__ */ e(
53
+ C,
54
+ {
55
+ $progressCircle: !0,
56
+ $progressBackground: "BLACK",
57
+ $progress: 3.3 * r,
58
+ r: a,
59
+ cx: l,
60
+ cy: c
61
+ }
62
+ )
63
+ ] }),
64
+ r > 0 && /* @__PURE__ */ e($, { $progress: !0, $top: u, $left: R }),
65
+ r === 100 && /* @__PURE__ */ e(j, { children: /* @__PURE__ */ e(g, { Icon: d }) })
66
+ ] }),
67
+ /* @__PURE__ */ t(H, { $flexGap: 4, children: [
68
+ /* @__PURE__ */ e(i, { $renderAs: "ah4-bold", children: S }),
69
+ /* @__PURE__ */ t(n, { $flexDirection: "row", $alignItems: "center", $flexGapX: 2.75, children: [
70
+ /* @__PURE__ */ t(n, { $position: "relative", $flexDirection: "row", children: [
71
+ /* @__PURE__ */ e($, {}),
72
+ /* @__PURE__ */ t(n, { $flexDirection: "row", $alignItems: "center", $flexGap: 4, children: [
73
+ /* @__PURE__ */ t(i, { $renderAs: "ab2", children: [
74
+ "Core - ",
75
+ T,
76
+ "/",
77
+ k
78
+ ] }),
79
+ L && /* @__PURE__ */ e(g, { Icon: d, label: "CW" })
80
+ ] })
81
+ ] }),
82
+ s > 0 && /* @__PURE__ */ t(i, { $renderAs: "ab2", children: [
83
+ "Supplementary - ",
84
+ y,
85
+ "/",
86
+ s
87
+ ] })
88
+ ] })
89
+ ] })
90
+ ] })
91
+ }
92
+ );
93
+ });
94
+ export {
95
+ ee as default
96
+ };
97
+ //# sourceMappingURL=chapter-banner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chapter-banner.js","sources":["../../../../../src/features/chapters-v2/chapter-details/chapter-banner/chapter-banner.tsx"],"sourcesContent":["import type { IChapterBannerProps } from './chapter-banner-types';\nimport type { FC } from 'react';\n\nimport { memo, useMemo } from 'react';\n\nimport { ILLUSTRATIONS } from '../../../../assets/illustrations/illustrations';\nimport Check2Icon from '../../../../assets/line-icons/icons/check2';\nimport Image from '../../../ui/image/image';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\nimport Tag from '../../comps/tag/tag';\nimport { getChapterCompletionPercentage } from '../../utils';\nimport * as Styled from './chapter-banner-styled';\n\nconst PROGRESS_CIRCLE_RADIUS = 52;\nconst PROGRESS_CIRCLE_CENTER_X = 54;\nconst PROGRESS_CIRCLE_CENTER_Y = 54;\n\n// This component renders a banner for a chapter, displaying its title, progress, and associated tags.\n// It includes an image, progress visualization, and details about the chapter's core and supplementary sheets.\n// It calculates the completion percentage and dynamically positions an icon based on progress.\nconst ChapterBanner: FC<IChapterBannerProps> = memo(props => {\n const { progressStats, imageHue, title, imageUrl } = props;\n\n const completionPercentage = useMemo(() => {\n return getChapterCompletionPercentage(progressStats);\n }, [progressStats]);\n\n const { iconTopVal, iconLeftVal } = useMemo(() => {\n //* Calculate the position of the important icon based on the completion percentage\n //* Convert degrees to radians\n const angleInDegree = completionPercentage === 100 ? 60 : completionPercentage;\n\n const angleInRadian = ((-angleInDegree * 3.6 - 180) * Math.PI) / 180;\n const positionX = PROGRESS_CIRCLE_CENTER_Y + PROGRESS_CIRCLE_RADIUS * Math.sin(angleInRadian);\n const positionY = PROGRESS_CIRCLE_CENTER_X + PROGRESS_CIRCLE_RADIUS * Math.cos(angleInRadian);\n\n return {\n iconLeftVal: positionX,\n iconTopVal: positionY,\n };\n }, [completionPercentage]);\n\n if (!progressStats) return null;\n\n const { mandatory, optional, class_work: classWork } = progressStats;\n const { completed: completedMandatorySheets = 0, total: totalMandatorySheets = 0 } =\n mandatory || {};\n const { completed: completedOptionalSheets = 0, total: totalOptionalSheets = 0 } = optional || {};\n const { completed: completedClassWorkSheets = 0, total: totalClassWorkSheets = 0 } =\n classWork || {};\n\n const showClassWorkTag =\n totalClassWorkSheets > 0 && completedClassWorkSheets === totalClassWorkSheets;\n\n return (\n <Styled.BannerContainer\n $flexDirection=\"row\"\n $justifyContent=\"center\"\n $alignItems=\"center\"\n $widthX={50}\n $background={`${imageHue}_4`}\n >\n <FlexView $height={168} $position=\"relative\">\n <Image\n width=\"100%\"\n height=\"168px\"\n src={ILLUSTRATIONS.CHAPTER_HEADER_BG}\n alt=\"Chapter header background\"\n withLoader\n />\n\n <Styled.BannerImageWrapper>\n <Styled.BannerImage src={imageUrl} alt=\"Chapter image\" />\n\n <Styled.ChapterProgressSVG width=\"108px\" height=\"108px\">\n <Styled.ChapterProgressSVGCircle\n $progress={0}\n r={PROGRESS_CIRCLE_RADIUS}\n cx={PROGRESS_CIRCLE_CENTER_X}\n cy={PROGRESS_CIRCLE_CENTER_Y}\n />\n <Styled.ChapterProgressSVGCircle\n $progressCircle\n $progressBackground={'BLACK'}\n $progress={3.3 * completionPercentage}\n r={PROGRESS_CIRCLE_RADIUS}\n cx={PROGRESS_CIRCLE_CENTER_X}\n cy={PROGRESS_CIRCLE_CENTER_Y}\n />\n </Styled.ChapterProgressSVG>\n\n {completionPercentage > 0 && (\n <Styled.StyledImportantIcon $progress $top={iconTopVal} $left={iconLeftVal} />\n )}\n\n {completionPercentage === 100 && (\n <Styled.StyledCheckIcon>\n <Tag Icon={Check2Icon} />\n </Styled.StyledCheckIcon>\n )}\n </Styled.BannerImageWrapper>\n\n <Styled.BannerTitleWrapper $flexGap={4}>\n <Text $renderAs=\"ah4-bold\">{title}</Text>\n\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexGapX={2.75}>\n <FlexView $position=\"relative\" $flexDirection=\"row\">\n <Styled.StyledImportantIcon />\n\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexGap={4}>\n <Text $renderAs=\"ab2\">\n Core - {completedMandatorySheets}/{totalMandatorySheets}\n </Text>\n\n {showClassWorkTag && <Tag Icon={Check2Icon} label=\"CW\" />}\n </FlexView>\n </FlexView>\n\n {totalOptionalSheets > 0 && (\n <Text $renderAs=\"ab2\">\n Supplementary - {completedOptionalSheets}/{totalOptionalSheets}\n </Text>\n )}\n </FlexView>\n </Styled.BannerTitleWrapper>\n </FlexView>\n </Styled.BannerContainer>\n );\n});\n\nexport default ChapterBanner;\n"],"names":["PROGRESS_CIRCLE_RADIUS","PROGRESS_CIRCLE_CENTER_X","PROGRESS_CIRCLE_CENTER_Y","ChapterBanner","memo","props","progressStats","imageHue","title","imageUrl","completionPercentage","useMemo","getChapterCompletionPercentage","iconTopVal","iconLeftVal","angleInRadian","positionX","positionY","mandatory","optional","classWork","completedMandatorySheets","totalMandatorySheets","completedOptionalSheets","totalOptionalSheets","completedClassWorkSheets","totalClassWorkSheets","showClassWorkTag","jsx","Styled.BannerContainer","jsxs","FlexView","Image","ILLUSTRATIONS","Styled.BannerImageWrapper","Styled.BannerImage","Styled.ChapterProgressSVG","Styled.ChapterProgressSVGCircle","Styled.StyledImportantIcon","Styled.StyledCheckIcon","Tag","Check2Icon","Styled.BannerTitleWrapper","Text"],"mappings":"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"}
@@ -0,0 +1,52 @@
1
+ import o from "styled-components";
2
+ import r from "../../ui/layout/flex-view.js";
3
+ const a = o.div(({ theme: t }) => `
4
+ height: 100%;
5
+ position: absolute;
6
+ left: 0;
7
+ right: 0;
8
+ top: 0;
9
+ bottom: 0;
10
+ background: rgba(204, 204, 204, 0.25);
11
+ z-index: 2;
12
+
13
+ & * {
14
+ pointer-events: none;
15
+ }
16
+
17
+ & img {
18
+ top: 50%;
19
+ position: absolute;
20
+ left: 50%;
21
+ transform: translate(-50%, -50%);
22
+ width: ${t.layout.gutter * 5}px;
23
+ height: ${t.layout.gutter * 5}px;
24
+ filter: brightness(0);
25
+ }
26
+ `), p = o(r)(
27
+ ({ $disablePointerEvents: t, theme: e }) => `
28
+ position: relative;
29
+ margin: 0 auto;
30
+ pointer-events: ${t ? "none" : "auto"};
31
+ border: 1px solid ${e.colors.WHITE_5};
32
+ border-top: none;
33
+ padding-bottom: ${e.layout.gutter * 4}px;
34
+ `
35
+ ), s = o(r)`
36
+ position: absolute;
37
+ top: 0;
38
+ left: 0;
39
+ z-index: 6;
40
+ `, u = o(r)(({ theme: t }) => `
41
+ position: sticky;
42
+ top: ${t.layout.gutter}px;
43
+ transform: translateX(${t.layout.gutter}px);
44
+ z-index: 6;
45
+ `);
46
+ export {
47
+ s as BackButtonContainer,
48
+ u as BackButtonWrapper,
49
+ p as ContentWrapper,
50
+ a as LoaderWrapper
51
+ };
52
+ //# sourceMappingURL=chapter-details-styled.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chapter-details-styled.js","sources":["../../../../src/features/chapters-v2/chapter-details/chapter-details-styled.tsx"],"sourcesContent":["import styled from 'styled-components';\n\nimport FlexView from '../../ui/layout/flex-view';\n\nconst LoaderWrapper = styled.div(({ theme }) => {\n return `\n height: 100%;\n position: absolute;\n left: 0;\n right: 0;\n top: 0;\n bottom: 0;\n background: rgba(204, 204, 204, 0.25);\n z-index: 2;\n\n & * {\n pointer-events: none;\n }\n\n & img {\n top: 50%;\n position: absolute;\n left: 50%;\n transform: translate(-50%, -50%);\n width: ${theme.layout.gutter * 5}px;\n height: ${theme.layout.gutter * 5}px;\n filter: brightness(0);\n }\n `;\n});\n\nconst ContentWrapper = styled(FlexView)<{ $disablePointerEvents: boolean }>(\n ({ $disablePointerEvents, theme }) => `\n position: relative;\n margin: 0 auto;\n pointer-events: ${$disablePointerEvents ? 'none' : 'auto'};\n border: 1px solid ${theme.colors.WHITE_5};\n border-top: none;\n padding-bottom: ${theme.layout.gutter * 4}px;\n `,\n);\n\nconst BackButtonContainer = styled(FlexView)`\n position: absolute;\n top: 0;\n left: 0;\n z-index: 6;\n`;\n\nconst BackButtonWrapper = styled(FlexView)(({ theme }) => {\n return `\n position: sticky;\n top: ${theme.layout.gutter}px;\n transform: translateX(${theme.layout.gutter}px);\n z-index: 6;\n `;\n});\n\nexport { ContentWrapper, LoaderWrapper, BackButtonContainer, BackButtonWrapper };\n"],"names":["LoaderWrapper","styled","theme","ContentWrapper","FlexView","$disablePointerEvents","BackButtonContainer","BackButtonWrapper"],"mappings":";;AAIA,MAAMA,IAAgBC,EAAO,IAAI,CAAC,EAAE,OAAAC,QAC3B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,eAmBMA,EAAM,OAAO,SAAS,CAAC;AAAA,gBACtBA,EAAM,OAAO,SAAS,CAAC;AAAA;AAAA;AAAA,GAItC,GAEKC,IAAiBF,EAAOG,CAAQ;AAAA,EACpC,CAAC,EAAE,uBAAAC,GAAuB,OAAAH,EAAA,MAAY;AAAA;AAAA;AAAA,wBAGhBG,IAAwB,SAAS,MAAM;AAAA,0BACrCH,EAAM,OAAO,OAAO;AAAA;AAAA,wBAEtBA,EAAM,OAAO,SAAS,CAAC;AAAA;AAE/C,GAEMI,IAAsBL,EAAOG,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,GAOrCG,IAAoBN,EAAOG,CAAQ,EAAE,CAAC,EAAE,OAAAF,QACrC;AAAA;AAAA,WAEEA,EAAM,OAAO,MAAM;AAAA,4BACFA,EAAM,OAAO,MAAM;AAAA;AAAA,GAG9C;"}
@@ -0,0 +1,103 @@
1
+ import { jsxs as m, jsx as t } from "react/jsx-runtime";
2
+ import { memo as x, useCallback as y, useEffect as p } from "react";
3
+ import { ILLUSTRATIONS as A } from "../../../assets/illustrations/illustrations.js";
4
+ import I from "../../../assets/line-icons/icons/back2.js";
5
+ import w from "../../ui/buttons/button/button.js";
6
+ import L from "../../ui/buttons/icon-button/icon-button.js";
7
+ import N from "../../ui/layout/flex-view.js";
8
+ import S from "../../ui/loader/app-loader/app-loader.js";
9
+ import _ from "../../ui/text/text.js";
10
+ import { useGetChapterDetails as b } from "../api/chapter.js";
11
+ import D from "./block-sections/block-sections.js";
12
+ import v from "./chapter-banner/chapter-banner.js";
13
+ import { ContentWrapper as T, BackButtonContainer as j, BackButtonWrapper as E, LoaderWrapper as P } from "./chapter-details-styled.js";
14
+ const R = x((l) => {
15
+ const {
16
+ userChapterId: i,
17
+ studentId: n,
18
+ userType: c,
19
+ onBlockSkipUnskip: h,
20
+ onNodeAttempt: d,
21
+ onNodeAttemptLocationChange: g,
22
+ onNodeMarkAsDone: f,
23
+ onNodeReattempt: u,
24
+ onNodeReview: C,
25
+ onNodeView: k,
26
+ onExit: $
27
+ } = l, {
28
+ get: a,
29
+ data: e,
30
+ isProcessing: r,
31
+ isProcessingFailed: B,
32
+ isStale: s
33
+ } = b(), o = y(() => {
34
+ a(i, void 0, { studentId: n });
35
+ }, [a, i, n]);
36
+ return p(() => {
37
+ o();
38
+ }, [o]), p(() => {
39
+ !r && s && o();
40
+ }, [o, r, s]), B ? /* @__PURE__ */ m(N, { $flexGapX: 1.5, $height: "100vh", $justifyContent: "center", $alignItems: "center", children: [
41
+ /* @__PURE__ */ t(_, { $renderAs: "h6", children: "Oops! Something went wrong. Please try again later." }),
42
+ /* @__PURE__ */ t(
43
+ w,
44
+ {
45
+ widthX: 14,
46
+ size: "small",
47
+ shape: "square",
48
+ renderAs: "primary",
49
+ label: "Try again",
50
+ onClick: o
51
+ }
52
+ )
53
+ ] }) : !e && r ? /* @__PURE__ */ t(S, { height: "80vh" }) : /* @__PURE__ */ m(
54
+ T,
55
+ {
56
+ $widthX: 50,
57
+ $disablePointerEvents: r,
58
+ $justifyContent: "center",
59
+ $alignItems: "center",
60
+ children: [
61
+ /* @__PURE__ */ t(j, { $height: "100%", children: /* @__PURE__ */ t(E, { children: /* @__PURE__ */ t(
62
+ L,
63
+ {
64
+ Icon: I,
65
+ renderAs: "secondary-gray",
66
+ analyticsLabel: "chapter_page_exit",
67
+ size: "xsmall",
68
+ onClick: $
69
+ }
70
+ ) }) }),
71
+ r && /* @__PURE__ */ t(P, { children: /* @__PURE__ */ t("img", { src: A.LOADER_1, alt: "loader" }) }),
72
+ e && /* @__PURE__ */ t(
73
+ v,
74
+ {
75
+ title: e.name,
76
+ imageHue: e.image_hue,
77
+ imageUrl: e.image_url,
78
+ progressStats: e == null ? void 0 : e.progress_stat
79
+ }
80
+ ),
81
+ e && /* @__PURE__ */ t(
82
+ D,
83
+ {
84
+ imageHue: e.image_hue,
85
+ userType: c,
86
+ blocks: e.blocks,
87
+ onBlockSkipUnskip: h,
88
+ onNodeAttempt: d,
89
+ onNodeAttemptLocationChange: g,
90
+ onNodeMarkAsDone: f,
91
+ onNodeReattempt: u,
92
+ onNodeReview: C,
93
+ onNodeView: k
94
+ }
95
+ )
96
+ ]
97
+ }
98
+ );
99
+ }), Q = R;
100
+ export {
101
+ Q as default
102
+ };
103
+ //# sourceMappingURL=chapter-details.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chapter-details.js","sources":["../../../../src/features/chapters-v2/chapter-details/chapter-details.tsx"],"sourcesContent":["import type { IChapterDetails } from './chapter-details-types';\nimport type { FC } from 'react';\n\nimport { memo, useCallback, useEffect } from 'react';\n\nimport { ILLUSTRATIONS } from '../../../assets/illustrations/illustrations';\nimport Back2Icon from '../../../assets/line-icons/icons/back2';\nimport Button from '../../ui/buttons/button/button';\nimport IconButton from '../../ui/buttons/icon-button/icon-button';\nimport FlexView from '../../ui/layout/flex-view';\nimport AppLoader from '../../ui/loader/app-loader/app-loader';\nimport Text from '../../ui/text/text';\nimport { useGetChapterDetails } from '../api/chapter';\nimport BlockSections from './block-sections/block-sections';\nimport ChapterBanner from './chapter-banner/chapter-banner';\nimport * as Styled from './chapter-details-styled';\n\nconst ChapterDetails: FC<IChapterDetails> = memo(props => {\n const {\n userChapterId,\n studentId,\n userType,\n onBlockSkipUnskip,\n onNodeAttempt,\n onNodeAttemptLocationChange,\n onNodeMarkAsDone,\n onNodeReattempt,\n onNodeReview,\n onNodeView,\n onExit,\n } = props;\n\n const {\n get: getChapterDetails,\n data: chapterDetails,\n isProcessing,\n isProcessingFailed,\n isStale,\n } = useGetChapterDetails();\n\n const fetchChapterDetails = useCallback(() => {\n getChapterDetails(userChapterId, undefined, { studentId });\n }, [getChapterDetails, userChapterId, studentId]);\n\n useEffect(() => {\n fetchChapterDetails();\n }, [fetchChapterDetails]);\n\n useEffect(() => {\n if (!isProcessing && isStale) {\n fetchChapterDetails();\n }\n }, [fetchChapterDetails, isProcessing, isStale]);\n\n if (isProcessingFailed) {\n return (\n <FlexView $flexGapX={1.5} $height=\"100vh\" $justifyContent=\"center\" $alignItems=\"center\">\n <Text $renderAs=\"h6\">Oops! Something went wrong. Please try again later.</Text>\n <Button\n widthX={14}\n size=\"small\"\n shape=\"square\"\n renderAs=\"primary\"\n label=\"Try again\"\n onClick={fetchChapterDetails}\n />\n </FlexView>\n );\n }\n\n if (!chapterDetails && isProcessing) {\n return <AppLoader height=\"80vh\" />;\n }\n\n return (\n <Styled.ContentWrapper\n $widthX={50}\n $disablePointerEvents={isProcessing}\n $justifyContent=\"center\"\n $alignItems=\"center\"\n >\n <Styled.BackButtonContainer $height=\"100%\">\n <Styled.BackButtonWrapper>\n <IconButton\n Icon={Back2Icon}\n renderAs=\"secondary-gray\"\n analyticsLabel=\"chapter_page_exit\"\n size=\"xsmall\"\n onClick={onExit}\n />\n </Styled.BackButtonWrapper>\n </Styled.BackButtonContainer>\n\n {isProcessing && (\n <Styled.LoaderWrapper>\n <img src={ILLUSTRATIONS.LOADER_1} alt=\"loader\" />\n </Styled.LoaderWrapper>\n )}\n\n {chapterDetails && (\n <ChapterBanner\n title={chapterDetails.name}\n imageHue={chapterDetails.image_hue}\n imageUrl={chapterDetails.image_url}\n progressStats={chapterDetails?.progress_stat}\n />\n )}\n\n {chapterDetails && (\n <BlockSections\n imageHue={chapterDetails.image_hue}\n userType={userType}\n blocks={chapterDetails.blocks}\n onBlockSkipUnskip={onBlockSkipUnskip}\n onNodeAttempt={onNodeAttempt}\n onNodeAttemptLocationChange={onNodeAttemptLocationChange}\n onNodeMarkAsDone={onNodeMarkAsDone}\n onNodeReattempt={onNodeReattempt}\n onNodeReview={onNodeReview}\n onNodeView={onNodeView}\n />\n )}\n </Styled.ContentWrapper>\n );\n});\n\nexport default ChapterDetails;\n"],"names":["ChapterDetails","memo","props","userChapterId","studentId","userType","onBlockSkipUnskip","onNodeAttempt","onNodeAttemptLocationChange","onNodeMarkAsDone","onNodeReattempt","onNodeReview","onNodeView","onExit","getChapterDetails","chapterDetails","isProcessing","isProcessingFailed","isStale","useGetChapterDetails","fetchChapterDetails","useCallback","useEffect","jsxs","FlexView","jsx","Text","Button","AppLoader","Styled.ContentWrapper","Styled.BackButtonContainer","Styled.BackButtonWrapper","IconButton","Back2Icon","Styled.LoaderWrapper","ILLUSTRATIONS","ChapterBanner","BlockSections","ChapterDetails$1"],"mappings":";;;;;;;;;;;;;AAiBA,MAAMA,IAAsCC,EAAK,CAASC,MAAA;AAClD,QAAA;AAAA,IACJ,eAAAC;AAAA,IACA,WAAAC;AAAA,IACA,UAAAC;AAAA,IACA,mBAAAC;AAAA,IACA,eAAAC;AAAA,IACA,6BAAAC;AAAA,IACA,kBAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,cAAAC;AAAA,IACA,YAAAC;AAAA,IACA,QAAAC;AAAA,EACE,IAAAX,GAEE;AAAA,IACJ,KAAKY;AAAA,IACL,MAAMC;AAAA,IACN,cAAAC;AAAA,IACA,oBAAAC;AAAA,IACA,SAAAC;AAAA,MACEC,EAAqB,GAEnBC,IAAsBC,EAAY,MAAM;AAC5C,IAAAP,EAAkBX,GAAe,QAAW,EAAE,WAAAC,EAAW,CAAA;AAAA,EACxD,GAAA,CAACU,GAAmBX,GAAeC,CAAS,CAAC;AAYhD,SAVAkB,EAAU,MAAM;AACM,IAAAF;EAAA,GACnB,CAACA,CAAmB,CAAC,GAExBE,EAAU,MAAM;AACV,IAAA,CAACN,KAAgBE,KACCE;EAErB,GAAA,CAACA,GAAqBJ,GAAcE,CAAO,CAAC,GAE3CD,IAEA,gBAAAM,EAACC,KAAS,WAAW,KAAK,SAAQ,SAAQ,iBAAgB,UAAS,aAAY,UAC7E,UAAA;AAAA,IAAC,gBAAAC,EAAAC,GAAA,EAAK,WAAU,MAAK,UAAmD,uDAAA;AAAA,IACxE,gBAAAD;AAAA,MAACE;AAAA,MAAA;AAAA,QACC,QAAQ;AAAA,QACR,MAAK;AAAA,QACL,OAAM;AAAA,QACN,UAAS;AAAA,QACT,OAAM;AAAA,QACN,SAASP;AAAA,MAAA;AAAA,IACX;AAAA,EACF,EAAA,CAAA,IAIA,CAACL,KAAkBC,IACd,gBAAAS,EAACG,GAAU,EAAA,QAAO,OAAO,CAAA,IAIhC,gBAAAL;AAAA,IAACM;AAAAA,IAAA;AAAA,MACC,SAAS;AAAA,MACT,uBAAuBb;AAAA,MACvB,iBAAgB;AAAA,MAChB,aAAY;AAAA,MAEZ,UAAA;AAAA,QAAC,gBAAAS,EAAAK,GAAA,EAA2B,SAAQ,QAClC,UAAC,gBAAAL,EAAAM,GAAA,EACC,UAAA,gBAAAN;AAAA,UAACO;AAAA,UAAA;AAAA,YACC,MAAMC;AAAA,YACN,UAAS;AAAA,YACT,gBAAe;AAAA,YACf,MAAK;AAAA,YACL,SAASpB;AAAA,UAAA;AAAA,WAEb,EACF,CAAA;AAAA,QAECG,KACC,gBAAAS,EAACS,GAAA,EACC,UAAA,gBAAAT,EAAC,OAAI,EAAA,KAAKU,EAAc,UAAU,KAAI,SAAA,CAAS,EACjD,CAAA;AAAA,QAGDpB,KACC,gBAAAU;AAAA,UAACW;AAAA,UAAA;AAAA,YACC,OAAOrB,EAAe;AAAA,YACtB,UAAUA,EAAe;AAAA,YACzB,UAAUA,EAAe;AAAA,YACzB,eAAeA,KAAA,gBAAAA,EAAgB;AAAA,UAAA;AAAA,QACjC;AAAA,QAGDA,KACC,gBAAAU;AAAA,UAACY;AAAA,UAAA;AAAA,YACC,UAAUtB,EAAe;AAAA,YACzB,UAAAV;AAAA,YACA,QAAQU,EAAe;AAAA,YACvB,mBAAAT;AAAA,YACA,eAAAC;AAAA,YACA,6BAAAC;AAAA,YACA,kBAAAC;AAAA,YACA,iBAAAC;AAAA,YACA,cAAAC;AAAA,YACA,YAAAC;AAAA,UAAA;AAAA,QACF;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAIR,CAAC,GAED0B,IAAetC;"}