@coorpacademy/components 11.34.2 → 11.34.3-alpha.29

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 (215) hide show
  1. package/es/atom/button-link/index.js.map +1 -1
  2. package/es/atom/button-link/style.css +2 -2
  3. package/es/atom/cta/test/fixtures/primary.d.ts +9 -0
  4. package/es/atom/cta/test/fixtures/primary.d.ts.map +1 -0
  5. package/es/atom/cta/test/fixtures/secondary.d.ts +10 -0
  6. package/es/atom/cta/test/fixtures/secondary.d.ts.map +1 -0
  7. package/es/atom/icon/index.d.ts +30 -17
  8. package/es/atom/icon/index.d.ts.map +1 -1
  9. package/es/atom/icon/index.js +4 -6
  10. package/es/atom/icon/index.js.map +1 -1
  11. package/es/atom/radio-with-title/index.d.ts +16 -3
  12. package/es/atom/radio-with-title/index.d.ts.map +1 -1
  13. package/es/atom/radio-with-title/types.d.ts +16 -2
  14. package/es/atom/radio-with-title/types.d.ts.map +1 -1
  15. package/es/atom/tag/index.d.ts +15 -1
  16. package/es/atom/tag/style.css +1 -0
  17. package/es/atom/title/index.d.ts +16 -2
  18. package/es/molecule/base-modal/style.css +0 -1
  19. package/es/molecule/cm-popin/types.d.ts +33 -6
  20. package/es/molecule/cm-popin/types.d.ts.map +1 -1
  21. package/es/molecule/progress-wrapper/index.d.ts.map +1 -1
  22. package/es/molecule/progress-wrapper/index.js +39 -19
  23. package/es/molecule/progress-wrapper/index.js.map +1 -1
  24. package/es/molecule/progress-wrapper/style.css +37 -2
  25. package/es/molecule/skills-chart-side-information-item/index.d.ts +1 -1
  26. package/es/molecule/skills-chart-side-information-panel/index.d.ts +1 -1
  27. package/es/molecule/title-and-checkbox-wrapper/index.d.ts +16 -2
  28. package/es/molecule/title-radio-wrapper/index.d.ts +16 -3
  29. package/es/molecule/title-radio-wrapper/index.d.ts.map +1 -1
  30. package/es/molecule/title-radio-wrapper/types.d.ts +16 -2
  31. package/es/molecule/title-radio-wrapper/types.d.ts.map +1 -1
  32. package/es/organism/cards-grid/index.d.ts +48 -10
  33. package/es/organism/cards-grid/index.d.ts.map +1 -1
  34. package/es/organism/cards-grid/index.js +3 -2
  35. package/es/organism/cards-grid/index.js.map +1 -1
  36. package/es/organism/content-skill-modal/index.d.ts +16 -3
  37. package/es/organism/content-skill-modal/index.d.ts.map +1 -1
  38. package/es/organism/content-skill-modal/types.d.ts +15 -2
  39. package/es/organism/content-skill-modal/types.d.ts.map +1 -1
  40. package/es/organism/list-item/index.js +5 -5
  41. package/es/organism/list-item/index.js.map +1 -1
  42. package/es/organism/list-item/style.css +38 -19
  43. package/es/organism/list-items/index.d.ts +16 -2
  44. package/es/organism/rewards-form/index.d.ts +16 -2
  45. package/es/organism/select-opponents/index.d.ts +16 -3
  46. package/es/organism/select-opponents/index.d.ts.map +1 -1
  47. package/es/organism/select-opponents/types.d.ts +16 -2
  48. package/es/organism/select-opponents/types.d.ts.map +1 -1
  49. package/es/organism/sidebar/index.d.ts +2 -2
  50. package/es/organism/skill-edition/index.d.ts +76 -11
  51. package/es/organism/skill-edition/index.d.ts.map +1 -1
  52. package/es/organism/skill-edition/types.d.ts +76 -10
  53. package/es/organism/skill-edition/types.d.ts.map +1 -1
  54. package/es/organism/title-and-input/index.d.ts +31 -5
  55. package/es/organism/title-and-input/index.d.ts.map +1 -1
  56. package/es/organism/title-and-input/types.d.ts +30 -4
  57. package/es/organism/title-and-input/types.d.ts.map +1 -1
  58. package/es/organism/wizard-contents/index.d.ts +16 -2
  59. package/es/template/app-player/loading/index.d.ts +33 -6
  60. package/es/template/app-player/player/index.d.ts +65 -12
  61. package/es/template/app-player/player/slides/index.d.ts +33 -6
  62. package/es/template/app-player/player/slides/index.d.ts.map +1 -1
  63. package/es/template/app-player/popin-correction/index.d.ts +32 -6
  64. package/es/template/app-player/popin-correction/index.d.ts.map +1 -1
  65. package/es/template/app-player/popin-end/index.d.ts +33 -6
  66. package/es/template/app-review/index.d.ts +33 -7
  67. package/es/template/app-review/index.d.ts.map +1 -1
  68. package/es/template/app-review/player/prop-types.d.ts +33 -6
  69. package/es/template/app-review/player/prop-types.d.ts.map +1 -1
  70. package/es/template/app-review/prop-types.d.ts +33 -6
  71. package/es/template/app-review/prop-types.d.ts.map +1 -1
  72. package/es/template/back-office/brand-update/index.d.ts +138 -20
  73. package/es/template/back-office/brand-update/utils.d.ts +1 -1
  74. package/es/template/certification-detail/style.css +5 -2
  75. package/es/template/common/dashboard/index.d.ts +65 -12
  76. package/es/template/common/search-page/index.d.ts +33 -6
  77. package/es/template/external-course/index.d.ts +33 -6
  78. package/es/template/skill-detail/all-courses.d.ts +61 -17
  79. package/es/template/skill-detail/all-courses.d.ts.map +1 -1
  80. package/es/template/skill-detail/all-courses.js +12 -11
  81. package/es/template/skill-detail/all-courses.js.map +1 -1
  82. package/es/template/skill-detail/continue-learning.d.ts +25 -12
  83. package/es/template/skill-detail/continue-learning.d.ts.map +1 -1
  84. package/es/template/skill-detail/continue-learning.js.map +1 -1
  85. package/es/template/skill-detail/index.d.ts +81 -71
  86. package/es/template/skill-detail/index.d.ts.map +1 -1
  87. package/es/template/skill-detail/index.js +93 -59
  88. package/es/template/skill-detail/index.js.map +1 -1
  89. package/es/template/skill-detail/style.css +96 -38
  90. package/es/variables/colors.d.ts +5 -1
  91. package/es/variables/colors.d.ts.map +1 -1
  92. package/es/variables/colors.js +6 -2
  93. package/es/variables/colors.js.map +1 -1
  94. package/lib/atom/button-link/index.js.map +1 -1
  95. package/lib/atom/button-link/style.css +2 -2
  96. package/lib/atom/cta/test/fixtures/primary.d.ts +9 -0
  97. package/lib/atom/cta/test/fixtures/primary.d.ts.map +1 -0
  98. package/lib/atom/cta/test/fixtures/secondary.d.ts +10 -0
  99. package/lib/atom/cta/test/fixtures/secondary.d.ts.map +1 -0
  100. package/lib/atom/icon/index.d.ts +30 -17
  101. package/lib/atom/icon/index.d.ts.map +1 -1
  102. package/lib/atom/icon/index.js +4 -6
  103. package/lib/atom/icon/index.js.map +1 -1
  104. package/lib/atom/radio-with-title/index.d.ts +16 -3
  105. package/lib/atom/radio-with-title/index.d.ts.map +1 -1
  106. package/lib/atom/radio-with-title/types.d.ts +16 -2
  107. package/lib/atom/radio-with-title/types.d.ts.map +1 -1
  108. package/lib/atom/tag/index.d.ts +15 -1
  109. package/lib/atom/tag/style.css +1 -0
  110. package/lib/atom/title/index.d.ts +16 -2
  111. package/lib/molecule/base-modal/style.css +0 -1
  112. package/lib/molecule/cm-popin/types.d.ts +33 -6
  113. package/lib/molecule/cm-popin/types.d.ts.map +1 -1
  114. package/lib/molecule/progress-wrapper/index.d.ts.map +1 -1
  115. package/lib/molecule/progress-wrapper/index.js +39 -19
  116. package/lib/molecule/progress-wrapper/index.js.map +1 -1
  117. package/lib/molecule/progress-wrapper/style.css +37 -2
  118. package/lib/molecule/skills-chart-side-information-item/index.d.ts +1 -1
  119. package/lib/molecule/skills-chart-side-information-panel/index.d.ts +1 -1
  120. package/lib/molecule/title-and-checkbox-wrapper/index.d.ts +16 -2
  121. package/lib/molecule/title-radio-wrapper/index.d.ts +16 -3
  122. package/lib/molecule/title-radio-wrapper/index.d.ts.map +1 -1
  123. package/lib/molecule/title-radio-wrapper/types.d.ts +16 -2
  124. package/lib/molecule/title-radio-wrapper/types.d.ts.map +1 -1
  125. package/lib/organism/cards-grid/index.d.ts +48 -10
  126. package/lib/organism/cards-grid/index.d.ts.map +1 -1
  127. package/lib/organism/cards-grid/index.js +3 -2
  128. package/lib/organism/cards-grid/index.js.map +1 -1
  129. package/lib/organism/content-skill-modal/index.d.ts +16 -3
  130. package/lib/organism/content-skill-modal/index.d.ts.map +1 -1
  131. package/lib/organism/content-skill-modal/types.d.ts +15 -2
  132. package/lib/organism/content-skill-modal/types.d.ts.map +1 -1
  133. package/lib/organism/list-item/index.js +5 -5
  134. package/lib/organism/list-item/index.js.map +1 -1
  135. package/lib/organism/list-item/style.css +38 -19
  136. package/lib/organism/list-items/index.d.ts +16 -2
  137. package/lib/organism/rewards-form/index.d.ts +16 -2
  138. package/lib/organism/select-opponents/index.d.ts +16 -3
  139. package/lib/organism/select-opponents/index.d.ts.map +1 -1
  140. package/lib/organism/select-opponents/types.d.ts +16 -2
  141. package/lib/organism/select-opponents/types.d.ts.map +1 -1
  142. package/lib/organism/sidebar/index.d.ts +2 -2
  143. package/lib/organism/skill-edition/index.d.ts +76 -11
  144. package/lib/organism/skill-edition/index.d.ts.map +1 -1
  145. package/lib/organism/skill-edition/types.d.ts +76 -10
  146. package/lib/organism/skill-edition/types.d.ts.map +1 -1
  147. package/lib/organism/title-and-input/index.d.ts +31 -5
  148. package/lib/organism/title-and-input/index.d.ts.map +1 -1
  149. package/lib/organism/title-and-input/types.d.ts +30 -4
  150. package/lib/organism/title-and-input/types.d.ts.map +1 -1
  151. package/lib/organism/wizard-contents/index.d.ts +16 -2
  152. package/lib/template/app-player/loading/index.d.ts +33 -6
  153. package/lib/template/app-player/player/index.d.ts +65 -12
  154. package/lib/template/app-player/player/slides/index.d.ts +33 -6
  155. package/lib/template/app-player/player/slides/index.d.ts.map +1 -1
  156. package/lib/template/app-player/popin-correction/index.d.ts +32 -6
  157. package/lib/template/app-player/popin-correction/index.d.ts.map +1 -1
  158. package/lib/template/app-player/popin-end/index.d.ts +33 -6
  159. package/lib/template/app-review/index.d.ts +33 -7
  160. package/lib/template/app-review/index.d.ts.map +1 -1
  161. package/lib/template/app-review/player/prop-types.d.ts +33 -6
  162. package/lib/template/app-review/player/prop-types.d.ts.map +1 -1
  163. package/lib/template/app-review/prop-types.d.ts +33 -6
  164. package/lib/template/app-review/prop-types.d.ts.map +1 -1
  165. package/lib/template/back-office/brand-update/index.d.ts +138 -20
  166. package/lib/template/back-office/brand-update/utils.d.ts +1 -1
  167. package/lib/template/certification-detail/style.css +5 -2
  168. package/lib/template/common/dashboard/index.d.ts +65 -12
  169. package/lib/template/common/search-page/index.d.ts +33 -6
  170. package/lib/template/external-course/index.d.ts +33 -6
  171. package/lib/template/skill-detail/all-courses.d.ts +61 -17
  172. package/lib/template/skill-detail/all-courses.d.ts.map +1 -1
  173. package/lib/template/skill-detail/all-courses.js +11 -11
  174. package/lib/template/skill-detail/all-courses.js.map +1 -1
  175. package/lib/template/skill-detail/continue-learning.d.ts +25 -12
  176. package/lib/template/skill-detail/continue-learning.d.ts.map +1 -1
  177. package/lib/template/skill-detail/continue-learning.js.map +1 -1
  178. package/lib/template/skill-detail/index.d.ts +81 -71
  179. package/lib/template/skill-detail/index.d.ts.map +1 -1
  180. package/lib/template/skill-detail/index.js +93 -59
  181. package/lib/template/skill-detail/index.js.map +1 -1
  182. package/lib/template/skill-detail/style.css +96 -38
  183. package/lib/variables/colors.d.ts +5 -1
  184. package/lib/variables/colors.d.ts.map +1 -1
  185. package/lib/variables/colors.js +6 -2
  186. package/lib/variables/colors.js.map +1 -1
  187. package/locales/bs/global.json +1 -0
  188. package/locales/cs/global.json +1 -0
  189. package/locales/de/global.json +1 -0
  190. package/locales/en/global.json +1 -0
  191. package/locales/es/global.json +1 -0
  192. package/locales/et/global.json +1 -0
  193. package/locales/fi/global.json +1 -0
  194. package/locales/fr/global.json +1 -0
  195. package/locales/hr/global.json +1 -0
  196. package/locales/hu/global.json +1 -0
  197. package/locales/hy/global.json +1 -0
  198. package/locales/it/global.json +1 -0
  199. package/locales/ja/global.json +1 -0
  200. package/locales/ko/global.json +1 -0
  201. package/locales/nl/global.json +1 -0
  202. package/locales/pl/global.json +1 -0
  203. package/locales/pt/global.json +1 -0
  204. package/locales/ro/global.json +1 -0
  205. package/locales/ru/global.json +1 -0
  206. package/locales/sk/global.json +1 -0
  207. package/locales/sl/global.json +1 -0
  208. package/locales/sv/global.json +1 -0
  209. package/locales/tl/global.json +1 -0
  210. package/locales/tr/global.json +1 -0
  211. package/locales/uk/global.json +1 -0
  212. package/locales/vi/global.json +1 -0
  213. package/locales/zh/global.json +1 -0
  214. package/locales/zh_TW/global.json +1 -0
  215. package/package.json +2 -2
@@ -6,17 +6,20 @@ var _isNil2 = _interopRequireDefault(require("lodash/fp/isNil"));
6
6
  var _get2 = _interopRequireDefault(require("lodash/fp/get"));
7
7
  var _react = _interopRequireWildcard(require("react"));
8
8
  var _propTypes = _interopRequireDefault(require("prop-types"));
9
- var _cssColorFunction = require("css-color-function");
10
9
  var _classnames = _interopRequireDefault(require("classnames"));
11
10
  var _markdownToJsx = _interopRequireDefault(require("markdown-to-jsx"));
11
+ var _cssColorFunction = require("css-color-function");
12
12
  var _provider = _interopRequireDefault(require("../../atom/provider"));
13
- var _select = _interopRequireWildcard(require("../../atom/select"));
14
- var _buttonLink = _interopRequireDefault(require("../../atom/button-link"));
15
13
  var _buttonLinkIcon = _interopRequireDefault(require("../../atom/button-link-icon"));
16
14
  var _icon = _interopRequireDefault(require("../../atom/icon"));
15
+ var _iconPreview = _interopRequireDefault(require("../../molecule/icon-preview"));
16
+ var _buttonLink = _interopRequireDefault(require("../../atom/button-link"));
17
17
  var _cardsGrid = _interopRequireDefault(require("../../organism/cards-grid"));
18
- var _style = _interopRequireDefault(require("./style.css"));
18
+ var _secondary = _interopRequireDefault(require("../../atom/cta/test/fixtures/secondary"));
19
+ var _colors = require("../../variables/colors");
20
+ var _select = require("../../atom/select");
19
21
  var _allCourses = _interopRequireDefault(require("./all-courses"));
22
+ var _style = _interopRequireDefault(require("./style.css"));
20
23
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
21
24
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
22
25
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
@@ -30,26 +33,26 @@ const ContinueLearningButton = (props, context) => {
30
33
  translate
31
34
  } = context;
32
35
  const primarySkinColor = (0, _get2.default)('common.primary', skin);
33
- return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_buttonLink.default, {
36
+ return /*#__PURE__*/_react.default.createElement(_buttonLink.default, {
34
37
  label: ongoingCoursesAvailable ? translate('continue_learning') : translate('start_learning'),
35
38
  type: "primary",
36
39
  customStyle: {
37
40
  width: 'fit-content',
38
41
  borderRadius: '12px',
39
- backgroundColor: primarySkinColor
42
+ backgroundColor: _secondary.default
40
43
  },
41
44
  hoverBackgroundColor: (0, _cssColorFunction.convert)(`hsl(from ${primarySkinColor} h s calc(l*(1 - 0.08)))`),
42
- hoverColor: "#FFFFFF",
45
+ hoverColor: _colors.COLORS.white,
43
46
  icon: {
44
47
  position: 'left',
45
48
  faIcon: {
46
49
  name: 'play',
47
- color: '#FFFFFF',
48
- size: 16
50
+ color: _colors.COLORS.white,
51
+ size: 14
49
52
  }
50
53
  },
51
54
  onClick: onClick
52
- }));
55
+ });
53
56
  };
54
57
  exports.ContinueLearningButton = ContinueLearningButton;
55
58
  ContinueLearningButton.contextTypes = {
@@ -71,29 +74,27 @@ const SkillDetail = (props, context) => {
71
74
  ongoingCoursesAvailable,
72
75
  skillIncludedCourses,
73
76
  filters,
74
- sorting,
75
77
  onBackClick,
76
78
  onReviewClick,
77
79
  onContinueLearningClick,
78
80
  search,
79
- bannerMicrolearning = {}
81
+ bannerMicrolearning
80
82
  } = props;
81
- const descriptionRef = (0, _react.useRef)(null);
82
83
  const {
83
84
  score = 0,
84
- questionsToReview,
85
- totalContents
85
+ questionsToReview = 0,
86
+ totalContents = 0
86
87
  } = metrics;
87
88
  const {
88
89
  translate
89
90
  } = context;
90
- const {
91
- action: bannerMicrolearningAction,
92
- oldSwitchValue
93
- } = bannerMicrolearning;
91
+ const bannerMicrolearningAction = bannerMicrolearning?.action;
92
+ const descriptionRef = (0, _react.useRef)(null);
94
93
  const [isDescriptionTruncated, setIsDescriptionTruncated] = (0, _react.useState)(false);
95
94
  const [showMore, setShowMore] = (0, _react.useState)(false);
96
- const handleShowMore = (0, _react.useCallback)(() => setShowMore(!showMore), [setShowMore, showMore]);
95
+ const handleShowMore = (0, _react.useCallback)(() => {
96
+ setShowMore(!showMore);
97
+ }, [showMore]);
97
98
  (0, _react.useEffect)(() => {
98
99
  if (descriptionRef.current) {
99
100
  const {
@@ -107,29 +108,39 @@ const SkillDetail = (props, context) => {
107
108
  return /*#__PURE__*/_react.default.createElement("div", {
108
109
  ref: descriptionRef,
109
110
  className: (0, _classnames.default)(_style.default.description, !showMore && _style.default.truncate)
110
- }, /*#__PURE__*/_react.default.createElement(_markdownToJsx.default, null, description));
111
+ }, description ? /*#__PURE__*/_react.default.createElement(_markdownToJsx.default, null, description) : null);
111
112
  }, [showMore, description]);
112
113
  const ProgressBar = (0, _react.useCallback)(() => {
113
- if (score === undefined) return null;
114
- const progressBarColor = '#3EC483';
115
- const inlineProgressValueStyle = {
114
+ if (typeof score !== 'number') return null;
115
+ const progressBarColor = _colors.COLORS.cm_positive_500;
116
+ const inlineProgressStyle = {
116
117
  backgroundColor: progressBarColor,
117
118
  width: `${score}%`
118
119
  };
119
120
  return /*#__PURE__*/_react.default.createElement("div", {
121
+ className: _style.default.progressBarRow
122
+ }, /*#__PURE__*/_react.default.createElement("div", {
120
123
  className: _style.default.progressBarWrapper
121
124
  }, /*#__PURE__*/_react.default.createElement("div", {
122
125
  "data-name": "progress",
123
126
  className: _style.default.progress,
124
- style: inlineProgressValueStyle,
125
- role: "progressbar"
126
- }));
127
+ style: inlineProgressStyle,
128
+ role: "progressbar",
129
+ "aria-valuenow": score,
130
+ "aria-valuemin": 0,
131
+ "aria-valuemax": 100
132
+ })), /*#__PURE__*/_react.default.createElement("span", {
133
+ className: _style.default.progressInformationNumber
134
+ }, score.toFixed(1), "%"));
127
135
  }, [score]);
136
+ const hasDescription = Boolean(description && description.trim().length > 0);
128
137
  return /*#__PURE__*/_react.default.createElement("div", {
129
138
  className: _style.default.backgroundContainer
130
139
  }, /*#__PURE__*/_react.default.createElement("div", {
131
140
  className: _style.default.container,
132
141
  "data-name": skillRef
142
+ }, /*#__PURE__*/_react.default.createElement("div", {
143
+ className: _style.default.topSection
133
144
  }, !(0, _isNil2.default)(onBackClick) ? /*#__PURE__*/_react.default.createElement(_buttonLinkIcon.default, {
134
145
  faIcon: "arrow-left",
135
146
  "data-name": "back-button",
@@ -137,67 +148,91 @@ const SkillDetail = (props, context) => {
137
148
  onClick: onBackClick,
138
149
  className: _style.default.backButton,
139
150
  tooltipPlacement: "right"
140
- }) : null, /*#__PURE__*/_react.default.createElement("div", {
141
- className: _style.default.ctaContainer
142
- }, /*#__PURE__*/_react.default.createElement("div", null, focused ? /*#__PURE__*/_react.default.createElement("div", {
151
+ }) : null), /*#__PURE__*/_react.default.createElement("div", {
152
+ className: _style.default.mainSection
153
+ }, /*#__PURE__*/_react.default.createElement("div", {
154
+ className: _style.default.leftSide
155
+ }, /*#__PURE__*/_react.default.createElement(_iconPreview.default, {
156
+ icon: {
157
+ name: 'bullseye-arrow',
158
+ color: _colors.COLORS.purple_100
159
+ },
160
+ title: title
161
+ })), /*#__PURE__*/_react.default.createElement("div", {
162
+ className: _style.default.rightSide
163
+ }, focused ? /*#__PURE__*/_react.default.createElement("div", {
143
164
  className: _style.default.skillFocusBadge
144
165
  }, /*#__PURE__*/_react.default.createElement(_icon.default, {
145
166
  iconName: "bullseye-arrow",
146
- backgroundColor: "#DDD1FF",
167
+ backgroundColor: _colors.COLORS.purple_100,
168
+ size: {
169
+ faSize: 10,
170
+ wrapperSize: 16
171
+ }
172
+ }), translate('skill_focus')) : /*#__PURE__*/_react.default.createElement("div", {
173
+ className: _style.default.skillBadge
174
+ }, /*#__PURE__*/_react.default.createElement(_icon.default, {
175
+ iconName: "shapes",
176
+ backgroundColor: _colors.COLORS.gray,
147
177
  size: {
148
178
  faSize: 10,
149
179
  wrapperSize: 16
150
180
  }
151
- }), translate('skill_focus')) : null, /*#__PURE__*/_react.default.createElement("div", {
181
+ }), translate('skill')), /*#__PURE__*/_react.default.createElement("h2", {
152
182
  className: _style.default.title
153
- }, title), description ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(Description, null), isDescriptionTruncated ? /*#__PURE__*/_react.default.createElement("div", {
183
+ }, title), description && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(Description, null), isDescriptionTruncated ? /*#__PURE__*/_react.default.createElement("div", {
154
184
  className: _style.default.showMoreWrapper,
155
185
  onClick: handleShowMore
156
186
  }, showMore ? translate('Show less') : translate('Show more'), /*#__PURE__*/_react.default.createElement(_icon.default, {
157
187
  iconName: showMore ? 'chevron-up' : 'chevron-down',
158
188
  size: {
159
189
  faSize: 14,
160
- wrapperSize: 16
190
+ wrapperSize: 14
191
+ },
192
+ customStyle: {
193
+ padding: '8px'
161
194
  }
162
- })) : null) : null), /*#__PURE__*/_react.default.createElement("div", {
195
+ })) : null), questionsToReview > 0 ? /*#__PURE__*/_react.default.createElement("div", {
196
+ className: _style.default.skillInformation
197
+ }, /*#__PURE__*/_react.default.createElement("span", null, questionsToReview), "\xA0", translate('skill_chart_side_panel_questions_to_review')) : null, /*#__PURE__*/_react.default.createElement("div", {
198
+ className: (0, _classnames.default)(_style.default.progressContainer, !hasDescription && _style.default.noDescriptionSpacing)
199
+ }, /*#__PURE__*/_react.default.createElement(ProgressBar, null)), /*#__PURE__*/_react.default.createElement("div", {
163
200
  className: _style.default.ctaWrapper
164
- }, /*#__PURE__*/_react.default.createElement(_buttonLink.default, {
201
+ }, /*#__PURE__*/_react.default.createElement(ContinueLearningButton, {
202
+ ongoingCoursesAvailable: ongoingCoursesAvailable,
203
+ onClick: onContinueLearningClick
204
+ }), /*#__PURE__*/_react.default.createElement(_buttonLink.default, {
165
205
  type: "secondary",
166
- onClick: onReviewClick,
167
206
  label: translate('review_this_skill'),
168
207
  disabled: !availableForReview,
208
+ onClick: onReviewClick,
209
+ icon: {
210
+ position: 'left',
211
+ faIcon: {
212
+ name: 'rotate-right',
213
+ color: _colors.COLORS.cm_grey_700,
214
+ size: 14
215
+ }
216
+ },
169
217
  customStyle: {
170
- width: 'fit-content',
171
- borderRadius: '12px'
218
+ borderRadius: '12px',
219
+ width: 'fit-content'
172
220
  }
173
- }), /*#__PURE__*/_react.default.createElement(ContinueLearningButton, {
174
- ongoingCoursesAvailable: ongoingCoursesAvailable,
175
- onClick: onContinueLearningClick
176
- }))), questionsToReview > 0 ? /*#__PURE__*/_react.default.createElement("div", {
177
- className: _style.default.skillInformation,
178
- "data-name": "skill-questions"
179
- }, /*#__PURE__*/_react.default.createElement("span", {
180
- className: _style.default.skillInformationNumber
181
- }, questionsToReview), "\xA0", translate('skill_chart_side_panel_questions_to_review')) : null, /*#__PURE__*/_react.default.createElement("div", {
182
- className: _style.default.progressContainer
183
- }, /*#__PURE__*/_react.default.createElement(ProgressBar, null), /*#__PURE__*/_react.default.createElement("span", {
184
- className: _style.default.progressInformationNumber
185
- }, score.toFixed(1), "%")), /*#__PURE__*/_react.default.createElement(_allCourses.default, {
221
+ })))), /*#__PURE__*/_react.default.createElement(_allCourses.default, {
186
222
  content: skillIncludedCourses,
187
223
  filters: filters,
188
- sorting: sorting,
189
224
  totalContents: totalContents,
190
- bannerMicrolearning: bannerMicrolearningAction ? {
225
+ bannerMicrolearning: bannerMicrolearning && bannerMicrolearningAction ? {
191
226
  type: 'skill',
192
227
  action: bannerMicrolearningAction,
193
- oldSwitchValue
194
- } : {},
228
+ oldSwitchValue: bannerMicrolearning.oldSwitchValue
229
+ } : undefined,
195
230
  search: search
196
231
  })));
197
232
  };
198
233
  SkillDetail.contextTypes = {
199
- skin: _provider.default.childContextTypes.skin,
200
- translate: _provider.default.childContextTypes.translate
234
+ translate: _provider.default.childContextTypes.translate,
235
+ skin: _provider.default.childContextTypes.skin
201
236
  };
202
237
  SkillDetail.propTypes = process.env.NODE_ENV !== "production" ? {
203
238
  title: _propTypes.default.string.isRequired,
@@ -216,7 +251,6 @@ SkillDetail.propTypes = process.env.NODE_ENV !== "production" ? {
216
251
  onChange: _propTypes.default.func,
217
252
  options: _propTypes.default.arrayOf(_propTypes.default.shape(_select.SelectOptionPropTypes))
218
253
  }),
219
- sorting: _propTypes.default.shape(_select.default.propTypes),
220
254
  onBackClick: _propTypes.default.func,
221
255
  onReviewClick: _propTypes.default.func,
222
256
  onContinueLearningClick: _propTypes.default.func,
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["_react","_interopRequireWildcard","require","_propTypes","_interopRequireDefault","_cssColorFunction","_classnames","_markdownToJsx","_provider","_select","_buttonLink","_buttonLinkIcon","_icon","_cardsGrid","_style","_allCourses","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ContinueLearningButton","props","context","ongoingCoursesAvailable","onClick","skin","translate","primarySkinColor","_get2","createElement","label","type","customStyle","width","borderRadius","backgroundColor","hoverBackgroundColor","convert","hoverColor","icon","position","faIcon","name","color","size","exports","contextTypes","Provider","childContextTypes","propTypes","process","env","NODE_ENV","PropTypes","bool","func","SkillDetail","title","skillRef","description","metrics","focused","availableForReview","skillIncludedCourses","filters","sorting","onBackClick","onReviewClick","onContinueLearningClick","search","bannerMicrolearning","descriptionRef","useRef","score","questionsToReview","totalContents","action","bannerMicrolearningAction","oldSwitchValue","isDescriptionTruncated","setIsDescriptionTruncated","useState","showMore","setShowMore","handleShowMore","useCallback","useEffect","current","clientHeight","scrollHeight","Description","ref","className","classnames","style","truncate","ProgressBar","undefined","progressBarColor","inlineProgressValueStyle","progressBarWrapper","progress","role","backgroundContainer","container","_isNil2","backButton","tooltipPlacement","ctaContainer","skillFocusBadge","iconName","faSize","wrapperSize","Fragment","showMoreWrapper","ctaWrapper","disabled","skillInformation","skillInformationNumber","progressContainer","progressInformationNumber","toFixed","content","string","isRequired","shape","number","CardsGrid","onChange","options","arrayOf","SelectOptionPropTypes","Select","oldValue","_default"],"sources":["../../../src/template/skill-detail/index.js"],"sourcesContent":["import React, {useCallback, useState, useRef, useEffect} from 'react';\nimport PropTypes from 'prop-types';\nimport {convert} from 'css-color-function';\nimport classnames from 'classnames';\nimport {get, isNil} from 'lodash/fp';\nimport Markdown from 'markdown-to-jsx';\nimport Provider from '../../atom/provider';\nimport Select, {SelectOptionPropTypes} from '../../atom/select';\nimport ButtonLink from '../../atom/button-link';\nimport ButtonLinkIcon from '../../atom/button-link-icon';\nimport Icon from '../../atom/icon';\nimport CardsGrid from '../../organism/cards-grid';\nimport style from './style.css';\nimport AllCourses from './all-courses';\n\nexport const ContinueLearningButton = (props, context) => {\n const {ongoingCoursesAvailable, onClick} = props;\n const {skin, translate} = context;\n const primarySkinColor = get('common.primary', skin);\n\n return (\n <div>\n <ButtonLink\n label={\n ongoingCoursesAvailable ? translate('continue_learning') : translate('start_learning')\n }\n type=\"primary\"\n customStyle={{\n width: 'fit-content',\n borderRadius: '12px',\n backgroundColor: primarySkinColor\n }}\n hoverBackgroundColor={convert(`hsl(from ${primarySkinColor} h s calc(l*(1 - 0.08)))`)}\n hoverColor=\"#FFFFFF\"\n icon={{\n position: 'left',\n faIcon: {\n name: 'play',\n color: '#FFFFFF',\n size: 16\n }\n }}\n onClick={onClick}\n />\n </div>\n );\n};\n\nContinueLearningButton.contextTypes = {\n skin: Provider.childContextTypes.skin,\n translate: Provider.childContextTypes.translate\n};\n\nContinueLearningButton.propTypes = {\n ongoingCoursesAvailable: PropTypes.bool,\n onClick: PropTypes.func\n};\n\nconst SkillDetail = (props, context) => {\n const {\n title,\n skillRef,\n description,\n metrics = {},\n focused,\n availableForReview,\n ongoingCoursesAvailable,\n skillIncludedCourses,\n filters,\n sorting,\n onBackClick,\n onReviewClick,\n onContinueLearningClick,\n search,\n bannerMicrolearning = {}\n } = props;\n const descriptionRef = useRef(null);\n const {score = 0, questionsToReview, totalContents} = metrics;\n const {translate} = context;\n const {action: bannerMicrolearningAction, oldSwitchValue} = bannerMicrolearning;\n\n const [isDescriptionTruncated, setIsDescriptionTruncated] = useState(false);\n const [showMore, setShowMore] = useState(false);\n\n const handleShowMore = useCallback(() => setShowMore(!showMore), [setShowMore, showMore]);\n\n useEffect(() => {\n if (descriptionRef.current) {\n const {clientHeight = 0, scrollHeight = 0} = descriptionRef.current;\n setIsDescriptionTruncated(scrollHeight > clientHeight);\n }\n }, [description]);\n\n const Description = useCallback(() => {\n return (\n <div\n ref={descriptionRef}\n className={classnames(style.description, !showMore && style.truncate)}\n >\n <Markdown>{description}</Markdown>\n </div>\n );\n }, [showMore, description]);\n\n const ProgressBar = useCallback(() => {\n if (score === undefined) return null;\n const progressBarColor = '#3EC483';\n const inlineProgressValueStyle = {\n backgroundColor: progressBarColor,\n width: `${score}%`\n };\n\n return (\n <div className={style.progressBarWrapper}>\n <div\n data-name=\"progress\"\n className={style.progress}\n style={inlineProgressValueStyle}\n role=\"progressbar\"\n />\n </div>\n );\n }, [score]);\n\n return (\n <div className={style.backgroundContainer}>\n <div className={style.container} data-name={skillRef}>\n {!isNil(onBackClick) ? (\n <ButtonLinkIcon\n faIcon=\"arrow-left\"\n data-name=\"back-button\"\n aria-label={translate('back')}\n onClick={onBackClick}\n className={style.backButton}\n tooltipPlacement=\"right\"\n />\n ) : null}\n <div className={style.ctaContainer}>\n <div>\n {focused ? (\n <div className={style.skillFocusBadge}>\n <Icon\n iconName=\"bullseye-arrow\"\n backgroundColor=\"#DDD1FF\"\n size={{\n faSize: 10,\n wrapperSize: 16\n }}\n />\n {translate('skill_focus')}\n </div>\n ) : null}\n <div className={style.title}>{title}</div>\n {description ? (\n <>\n <Description />\n {isDescriptionTruncated ? (\n <div className={style.showMoreWrapper} onClick={handleShowMore}>\n {showMore ? translate('Show less') : translate('Show more')}\n <Icon\n iconName={showMore ? 'chevron-up' : 'chevron-down'}\n size={{\n faSize: 14,\n wrapperSize: 16\n }}\n />\n </div>\n ) : null}\n </>\n ) : null}\n </div>\n\n <div className={style.ctaWrapper}>\n <ButtonLink\n type=\"secondary\"\n onClick={onReviewClick}\n label={translate('review_this_skill')}\n disabled={!availableForReview}\n customStyle={{\n width: 'fit-content',\n borderRadius: '12px'\n }}\n />\n <ContinueLearningButton\n ongoingCoursesAvailable={ongoingCoursesAvailable}\n onClick={onContinueLearningClick}\n />\n </div>\n </div>\n {questionsToReview > 0 ? (\n <div className={style.skillInformation} data-name=\"skill-questions\">\n <span className={style.skillInformationNumber}>{questionsToReview}</span>\n &nbsp;{translate('skill_chart_side_panel_questions_to_review')}\n </div>\n ) : null}\n <div className={style.progressContainer}>\n <ProgressBar />\n <span className={style.progressInformationNumber}>{score.toFixed(1)}%</span>\n </div>\n <AllCourses\n content={skillIncludedCourses}\n filters={filters}\n sorting={sorting}\n totalContents={totalContents}\n bannerMicrolearning={\n bannerMicrolearningAction\n ? {\n type: 'skill',\n action: bannerMicrolearningAction,\n oldSwitchValue\n }\n : {}\n }\n search={search}\n />\n </div>\n </div>\n );\n};\n\nSkillDetail.contextTypes = {\n skin: Provider.childContextTypes.skin,\n translate: Provider.childContextTypes.translate\n};\n\nSkillDetail.propTypes = {\n title: PropTypes.string.isRequired,\n skillRef: PropTypes.string.isRequired,\n description: PropTypes.string,\n metrics: PropTypes.shape({\n score: PropTypes.number,\n questionsToReview: PropTypes.number,\n totalContents: PropTypes.number\n }),\n focused: PropTypes.bool,\n availableForReview: PropTypes.bool,\n ongoingCoursesAvailable: PropTypes.bool,\n skillIncludedCourses: PropTypes.shape(CardsGrid.propTypes),\n filters: PropTypes.shape({\n onChange: PropTypes.func,\n options: PropTypes.arrayOf(PropTypes.shape(SelectOptionPropTypes))\n }),\n sorting: PropTypes.shape(Select.propTypes),\n onBackClick: PropTypes.func,\n onReviewClick: PropTypes.func,\n onContinueLearningClick: PropTypes.func,\n search: PropTypes.shape({\n oldValue: PropTypes.string,\n onChange: PropTypes.func\n }),\n bannerMicrolearning: PropTypes.shape({\n action: PropTypes.func,\n oldSwitchValue: PropTypes.bool\n })\n};\n\nexport default SkillDetail;\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["_react","_interopRequireWildcard","require","_propTypes","_interopRequireDefault","_classnames","_markdownToJsx","_cssColorFunction","_provider","_buttonLinkIcon","_icon","_iconPreview","_buttonLink","_cardsGrid","_secondary","_colors","_select","_allCourses","_style","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ContinueLearningButton","props","context","ongoingCoursesAvailable","onClick","skin","translate","primarySkinColor","_get2","createElement","label","type","customStyle","width","borderRadius","backgroundColor","secondary","hoverBackgroundColor","convert","hoverColor","COLORS","white","icon","position","faIcon","name","color","size","exports","contextTypes","Provider","childContextTypes","propTypes","process","env","NODE_ENV","PropTypes","bool","func","SkillDetail","title","skillRef","description","metrics","focused","availableForReview","skillIncludedCourses","filters","onBackClick","onReviewClick","onContinueLearningClick","search","bannerMicrolearning","score","questionsToReview","totalContents","bannerMicrolearningAction","action","descriptionRef","useRef","isDescriptionTruncated","setIsDescriptionTruncated","useState","showMore","setShowMore","handleShowMore","useCallback","useEffect","current","clientHeight","scrollHeight","Description","ref","className","classnames","style","truncate","ProgressBar","progressBarColor","cm_positive_500","inlineProgressStyle","progressBarRow","progressBarWrapper","progress","role","progressInformationNumber","toFixed","hasDescription","Boolean","trim","length","backgroundContainer","container","topSection","_isNil2","backButton","tooltipPlacement","mainSection","leftSide","purple_100","rightSide","skillFocusBadge","iconName","faSize","wrapperSize","skillBadge","gray","Fragment","showMoreWrapper","padding","skillInformation","progressContainer","noDescriptionSpacing","ctaWrapper","disabled","cm_grey_700","content","oldSwitchValue","undefined","string","isRequired","shape","number","CardsGrid","onChange","options","arrayOf","SelectOptionPropTypes","oldValue","_default"],"sources":["../../../src/template/skill-detail/index.tsx"],"sourcesContent":["import React, {useCallback, useState, useRef, useEffect} from 'react';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport {get, isNil} from 'lodash/fp';\nimport Markdown from 'markdown-to-jsx';\nimport {convert} from 'css-color-function';\nimport Provider from '../../atom/provider';\nimport ButtonLinkIcon from '../../atom/button-link-icon';\nimport Icon from '../../atom/icon';\nimport IconPreview from '../../molecule/icon-preview';\nimport ButtonLink from '../../atom/button-link';\nimport CardsGrid, {CardsGridProps} from '../../organism/cards-grid';\nimport secondary from '../../atom/cta/test/fixtures/secondary';\nimport {COLORS} from '../../variables/colors';\nimport {SelectOptionPropTypes} from '../../atom/select';\nimport AllCourses from './all-courses';\nimport style from './style.css';\n\ninterface ContinueLearningButtonProps {\n ongoingCoursesAvailable?: boolean;\n onClick?: () => void;\n}\ninterface ProviderContext {\n skin: {\n common: {\n primary: string;\n secondary: string;\n };\n };\n translate: (key: string) => string;\n}\n\nexport const ContinueLearningButton = (\n props: ContinueLearningButtonProps,\n context: ProviderContext\n) => {\n const {ongoingCoursesAvailable, onClick} = props;\n const {skin, translate} = context;\n const primarySkinColor = get('common.primary', skin);\n\n return (\n <ButtonLink\n label={ongoingCoursesAvailable ? translate('continue_learning') : translate('start_learning')}\n type=\"primary\"\n customStyle={{\n width: 'fit-content',\n borderRadius: '12px',\n backgroundColor: secondary\n }}\n hoverBackgroundColor={convert(`hsl(from ${primarySkinColor} h s calc(l*(1 - 0.08)))`)}\n hoverColor={COLORS.white}\n icon={{\n position: 'left',\n faIcon: {\n name: 'play',\n color: COLORS.white,\n size: 14\n }\n }}\n onClick={onClick}\n />\n );\n};\n\nContinueLearningButton.contextTypes = {\n skin: Provider.childContextTypes.skin,\n translate: Provider.childContextTypes.translate\n};\n\nContinueLearningButton.propTypes = {\n ongoingCoursesAvailable: PropTypes.bool,\n onClick: PropTypes.func\n};\n\ninterface Metrics {\n score?: number;\n questionsToReview?: number;\n totalContents?: number;\n}\n\ntype BannerMicrolearning =\n | Record<string, never>\n | {\n action: () => void;\n oldSwitchValue: boolean;\n };\ninterface SkillDetailProps {\n title: string;\n skillRef: string;\n description?: string;\n metrics?: Metrics;\n focused?: boolean;\n availableForReview?: boolean;\n ongoingCoursesAvailable?: boolean;\n skillIncludedCourses: CardsGridProps;\n filters: {\n onChange?: () => void;\n options?: unknown[];\n };\n onBackClick?: () => void;\n onReviewClick?: () => void;\n onContinueLearningClick?: () => void;\n search: {\n oldValue: string;\n onChange: () => void;\n };\n bannerMicrolearning?: BannerMicrolearning;\n}\nconst SkillDetail = (props: SkillDetailProps, context: ProviderContext) => {\n const {\n title,\n skillRef,\n description,\n metrics = {},\n focused,\n availableForReview,\n ongoingCoursesAvailable,\n skillIncludedCourses,\n filters,\n onBackClick,\n onReviewClick,\n onContinueLearningClick,\n search,\n bannerMicrolearning\n } = props;\n\n const {score = 0, questionsToReview = 0, totalContents = 0} = metrics;\n const {translate} = context;\n const bannerMicrolearningAction = bannerMicrolearning?.action;\n const descriptionRef = useRef(null);\n const [isDescriptionTruncated, setIsDescriptionTruncated] = useState(false);\n const [showMore, setShowMore] = useState(false);\n\n const handleShowMore = useCallback(() => {\n setShowMore(!showMore);\n }, [showMore]);\n\n useEffect(() => {\n if (descriptionRef.current) {\n const {clientHeight = 0, scrollHeight = 0} = descriptionRef.current;\n setIsDescriptionTruncated(scrollHeight > clientHeight);\n }\n }, [description]);\n\n const Description = useCallback(() => {\n return (\n <div\n ref={descriptionRef}\n className={classnames(style.description, !showMore && style.truncate)}\n >\n {description ? <Markdown>{description}</Markdown> : null}\n </div>\n );\n }, [showMore, description]);\n\n const ProgressBar = useCallback(() => {\n if (typeof score !== 'number') return null;\n\n const progressBarColor = COLORS.cm_positive_500;\n const inlineProgressStyle = {\n backgroundColor: progressBarColor,\n width: `${score}%`\n };\n\n return (\n <div className={style.progressBarRow}>\n <div className={style.progressBarWrapper}>\n <div\n data-name=\"progress\"\n className={style.progress}\n style={inlineProgressStyle}\n role=\"progressbar\"\n aria-valuenow={score}\n aria-valuemin={0}\n aria-valuemax={100}\n />\n </div>\n <span className={style.progressInformationNumber}>{score.toFixed(1)}%</span>\n </div>\n );\n }, [score]);\n const hasDescription = Boolean(description && description.trim().length > 0);\n\n return (\n <div className={style.backgroundContainer}>\n <div className={style.container} data-name={skillRef}>\n {/* Top section for the back arrow (optional) */}\n <div className={style.topSection}>\n {!isNil(onBackClick) ? (\n <ButtonLinkIcon\n faIcon=\"arrow-left\"\n data-name=\"back-button\"\n aria-label={translate('back')}\n onClick={onBackClick}\n className={style.backButton}\n tooltipPlacement=\"right\"\n />\n ) : null}\n </div>\n\n {/* Main section: icon on the left, skill info on the right */}\n <div className={style.mainSection}>\n <div className={style.leftSide}>\n <IconPreview\n icon={{\n name: 'bullseye-arrow',\n color: COLORS.purple_100\n }}\n title={title}\n />\n </div>\n <div className={style.rightSide}>\n {focused ? (\n <div className={style.skillFocusBadge}>\n <Icon\n iconName=\"bullseye-arrow\"\n backgroundColor={COLORS.purple_100}\n size={{faSize: 10, wrapperSize: 16}}\n />\n {translate('skill_focus')}\n </div>\n ) : (\n <div className={style.skillBadge}>\n <Icon\n iconName=\"shapes\"\n backgroundColor={COLORS.gray}\n size={{faSize: 10, wrapperSize: 16}}\n />\n {translate('skill')}\n </div>\n )}\n\n <h2 className={style.title}>{title}</h2>\n\n {description && (\n <>\n <Description />\n {isDescriptionTruncated ? (\n <div className={style.showMoreWrapper} onClick={handleShowMore}>\n {showMore ? translate('Show less') : translate('Show more')}\n <Icon\n iconName={showMore ? 'chevron-up' : 'chevron-down'}\n size={{faSize: 14, wrapperSize: 14}}\n customStyle={{padding: '8px'}}\n />\n </div>\n ) : null}\n </>\n )}\n\n {questionsToReview > 0 ? (\n <div className={style.skillInformation}>\n <span>{questionsToReview}</span>\n &nbsp;{translate('skill_chart_side_panel_questions_to_review')}\n </div>\n ) : null}\n\n <div\n className={classnames(\n style.progressContainer,\n !hasDescription && style.noDescriptionSpacing\n )}\n >\n <ProgressBar />\n </div>\n\n <div className={style.ctaWrapper}>\n <ContinueLearningButton\n ongoingCoursesAvailable={ongoingCoursesAvailable}\n onClick={onContinueLearningClick}\n />\n <ButtonLink\n type=\"secondary\"\n label={translate('review_this_skill')}\n disabled={!availableForReview}\n onClick={onReviewClick}\n icon={{\n position: 'left',\n faIcon: {\n name: 'rotate-right',\n color: COLORS.cm_grey_700,\n size: 14\n }\n }}\n customStyle={{borderRadius: '12px', width: 'fit-content'}}\n />\n </div>\n </div>\n </div>\n\n {/* Courses section below */}\n <AllCourses\n content={skillIncludedCourses}\n filters={filters}\n totalContents={totalContents}\n bannerMicrolearning={\n bannerMicrolearning && bannerMicrolearningAction\n ? {\n type: 'skill',\n action: bannerMicrolearningAction,\n oldSwitchValue: bannerMicrolearning.oldSwitchValue\n }\n : undefined\n }\n search={search}\n />\n </div>\n </div>\n );\n};\n\nSkillDetail.contextTypes = {\n translate: Provider.childContextTypes.translate,\n skin: Provider.childContextTypes.skin\n};\n\nSkillDetail.propTypes = {\n title: PropTypes.string.isRequired,\n skillRef: PropTypes.string.isRequired,\n description: PropTypes.string,\n metrics: PropTypes.shape({\n score: PropTypes.number,\n questionsToReview: PropTypes.number,\n totalContents: PropTypes.number\n }),\n focused: PropTypes.bool,\n availableForReview: PropTypes.bool,\n ongoingCoursesAvailable: PropTypes.bool,\n skillIncludedCourses: PropTypes.shape(CardsGrid.propTypes),\n filters: PropTypes.shape({\n onChange: PropTypes.func,\n options: PropTypes.arrayOf(PropTypes.shape(SelectOptionPropTypes))\n }),\n onBackClick: PropTypes.func,\n onReviewClick: PropTypes.func,\n onContinueLearningClick: PropTypes.func,\n search: PropTypes.shape({\n oldValue: PropTypes.string,\n onChange: PropTypes.func\n }),\n bannerMicrolearning: PropTypes.shape({\n action: PropTypes.func,\n oldSwitchValue: PropTypes.bool\n })\n};\n\nexport default SkillDetail;\n"],"mappings":"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","ignoreList":[]}
@@ -22,12 +22,7 @@
22
22
  .container {
23
23
  composes: textBase;
24
24
  background-color: white;
25
- font-family: "Gilroy";
26
- font-style: normal;
27
- margin-top: 48px;
28
- margin-bottom: 48px;
29
- margin-left: auto;
30
- margin-right: auto;
25
+ margin: 48px auto;
31
26
  padding: 0 16px;
32
27
  position: relative;
33
28
  box-sizing: border-box;
@@ -36,14 +31,48 @@
36
31
  max-width: calc(1080px + 40px);
37
32
  }
38
33
 
39
- .backButton {
40
- margin-bottom: 16px;
34
+ .topSection {
35
+ display: flex;
41
36
  }
42
37
 
43
- .ctaContainer {
38
+ .mainSection {
44
39
  display: flex;
45
- width: 100%;
46
- justify-content: space-between;
40
+ align-items: flex-start;
41
+ gap: 40px;
42
+ }
43
+
44
+ .leftSide {
45
+ width: 420px;
46
+ height: 280px;
47
+ display: flex;
48
+ flex-direction: column;
49
+ gap: 16px;
50
+ }
51
+
52
+ .rightSide {
53
+ max-width: 620px;
54
+ height: 280px;
55
+ display: flex;
56
+ gap: 8px;
57
+ flex-direction: column;
58
+ }
59
+
60
+ .title {
61
+ gap: 8px;
62
+ margin: 0;
63
+ font-size: 24px;
64
+ font-weight: 700;
65
+ line-height: 32px;
66
+ }
67
+
68
+ .ctaWrapper {
69
+ display: flex;
70
+ gap: 8px;
71
+ margin-top: 16px;
72
+ }
73
+
74
+ .backButton {
75
+ margin-bottom: 16px;
47
76
  }
48
77
 
49
78
  .skillFocusBadge {
@@ -58,34 +87,38 @@
58
87
  line-height: 16px;
59
88
  font-weight: 600;
60
89
  color: #3900D6;
61
- margin-bottom: 16px;
62
90
  }
63
91
 
64
- .ctaWrapper,
65
- .showMoreWrapper {
92
+ .skillBadge {
66
93
  display: flex;
67
- gap: 8px;
94
+ height: 12px;
95
+ width: fit-content;
96
+ align-items: center;
97
+ background-color: #EAEAEB;
98
+ border-radius: 24px;
99
+ padding: 4px 8px;
100
+ font-size: 12px;
101
+ line-height: 12px;
102
+ font-weight: 600;
103
+ color: #515161;
68
104
  }
69
105
 
70
106
  .showMoreWrapper {
107
+ display: flex;
71
108
  align-items: center;
72
- margin-top: 8px;
109
+ color: cm_grey_500;
73
110
  font-weight: 600;
74
111
  cursor: pointer;
75
- }
76
-
77
- .title {
78
- font-size: 24px;
79
- font-weight: 700;
80
- line-height: 32px;
112
+ font-size: 14px;
81
113
  }
82
114
 
83
115
  .description {
84
- margin-top: 8px;
85
- max-width: 734px;
116
+ max-width: 620px;
86
117
  font-size: 14px;
87
118
  font-weight: 500;
88
119
  line-height: 20px;
120
+ flex: 1 0 0;
121
+ align-self: stretch;
89
122
  color: cm_grey_400;
90
123
  }
91
124
 
@@ -105,27 +138,38 @@
105
138
  color: cm_grey_400;
106
139
  margin-top: 16px;
107
140
  }
108
-
109
- .skillInformationNumber {
110
- color: #000;
141
+ .noDescriptionSpacing {
142
+ margin-top: 48px ;
111
143
  }
112
144
 
145
+
113
146
  .progressContainer {
114
147
  display: flex;
115
148
  align-items: center;
116
149
  gap: 8px;
117
- margin: 16px 0 40px 0;
118
150
  }
119
151
 
120
152
  .progressInformationNumber {
153
+ font-size: 14px;
154
+ font-weight: 600;
121
155
  color: cm_grey_500;
156
+ flex-shrink: 0;
157
+ }
158
+
159
+ .progressBarRow {
160
+ display: flex;
161
+ align-items: center;
162
+ flex-direction: row;
163
+ width: 100%;
164
+
165
+ gap: 8px;
122
166
  }
123
167
 
124
168
  .progressBarWrapper {
125
169
  position: relative;
126
170
  left: 0;
127
171
  max-width: 300px;
128
- width: 100%;
172
+ flex: 1;
129
173
  height: 4px;
130
174
  border-radius: 2px;
131
175
  overflow: hidden;
@@ -133,27 +177,41 @@
133
177
  }
134
178
 
135
179
  .progress {
136
- display: block;
180
+ display: flex;
137
181
  height: 8px;
138
182
  animation: progressbar 2s ease-in-out;
139
183
  }
140
184
 
141
185
  @media tablet {
142
- .ctaContainer {
143
- flex-direction: column;
186
+ .topSection {
187
+ flex-direction: row;
188
+ align-items: flex-start;
144
189
  }
145
-
146
- .ctaWrapper {
147
- margin-top: 32px;
190
+ .leftSide,
191
+ .rightSide {
192
+ width: 50%;
148
193
  }
149
194
  }
150
195
 
151
196
  @media mobile {
197
+ .topSection {
198
+ flex-direction: column;
199
+ align-items: center;
200
+ }
201
+
202
+ .leftSide,
203
+ .rightSide {
204
+ width: 100%;
205
+ align-items: center;
206
+ }
207
+
152
208
  .ctaWrapper {
153
209
  flex-direction: column;
210
+ gap: 8px;
211
+ margin-top: 16px;
212
+ }
154
213
 
155
- button {
156
- width: 100% !important;
157
- }
214
+ .ctaWrapper button {
215
+ width: 100% !important;
158
216
  }
159
217
  }
@@ -4,10 +4,12 @@ export declare const COLORS: {
4
4
  readonly cm_negative_200: "#B81400";
5
5
  readonly positive: "#35CC7F";
6
6
  readonly cm_positive_200: "#05944F";
7
- readonly white: "#ffffff";
7
+ readonly white: "#FFFFFF";
8
8
  readonly cm_blue_50: "#f1f6fe";
9
9
  readonly cm_grey_400: "#9999A8";
10
10
  readonly cm_grey_800: "#171721";
11
+ readonly cm_grey_150: "#E1E1E3";
12
+ readonly cm_grey_200: "#E1E1E3";
11
13
  readonly cm_primary_blue: "#0061FF";
12
14
  readonly primary_100: "#D6E6FF";
13
15
  readonly primary_600: "#0051D6";
@@ -19,6 +21,8 @@ export declare const COLORS: {
19
21
  readonly yellow_100: "#FFF9D1";
20
22
  readonly red_700: "#A30000";
21
23
  readonly red_100: "#FFD1D1";
24
+ readonly cm_positive_500: "#35CC7F";
25
+ readonly purple_100: "#DDD1FF";
22
26
  };
23
27
  export declare type Colors = typeof COLORS;
24
28
  //# sourceMappingURL=colors.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"colors.d.ts","sourceRoot":"","sources":["../../src/variables/colors.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;CAqBT,CAAC;AAEX,oBAAY,MAAM,GAAG,OAAO,MAAM,CAAC"}
1
+ {"version":3,"file":"colors.d.ts","sourceRoot":"","sources":["../../src/variables/colors.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;CAyBT,CAAC;AAEX,oBAAY,MAAM,GAAG,OAAO,MAAM,CAAC"}
@@ -8,10 +8,12 @@ const COLORS = exports.COLORS = {
8
8
  cm_negative_200: '#B81400',
9
9
  positive: '#35CC7F',
10
10
  cm_positive_200: '#05944F',
11
- white: '#ffffff',
11
+ white: '#FFFFFF',
12
12
  cm_blue_50: '#f1f6fe',
13
13
  cm_grey_400: '#9999A8',
14
14
  cm_grey_800: '#171721',
15
+ cm_grey_150: '#E1E1E3',
16
+ cm_grey_200: '#E1E1E3',
15
17
  cm_primary_blue: '#0061FF',
16
18
  primary_100: '#D6E6FF',
17
19
  primary_600: '#0051D6',
@@ -22,6 +24,8 @@ const COLORS = exports.COLORS = {
22
24
  yellow_700: '#A38300',
23
25
  yellow_100: '#FFF9D1',
24
26
  red_700: '#A30000',
25
- red_100: '#FFD1D1'
27
+ red_100: '#FFD1D1',
28
+ cm_positive_500: '#35CC7F',
29
+ purple_100: '#DDD1FF'
26
30
  };
27
31
  //# sourceMappingURL=colors.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"colors.js","names":["COLORS","exports","gray","negative","cm_negative_200","positive","cm_positive_200","white","cm_blue_50","cm_grey_400","cm_grey_800","cm_primary_blue","primary_100","primary_600","cm_grey_500","cm_grey_700","cm_yellow_400","brand","yellow_700","yellow_100","red_700","red_100"],"sources":["../../src/variables/colors.ts"],"sourcesContent":["export const COLORS = {\n gray: '#EAEAEB',\n negative: '#ed3436',\n cm_negative_200: '#B81400',\n positive: '#35CC7F',\n cm_positive_200: '#05944F',\n white: '#ffffff',\n cm_blue_50: '#f1f6fe',\n cm_grey_400: '#9999A8',\n cm_grey_800: '#171721',\n cm_primary_blue: '#0061FF',\n primary_100: '#D6E6FF',\n primary_600: '#0051D6',\n cm_grey_500: '#515161',\n cm_grey_700: '#1D1D2B',\n cm_yellow_400: '#bd7e00',\n brand: '#00B0FF',\n yellow_700: '#A38300',\n yellow_100: '#FFF9D1',\n red_700: '#A30000',\n red_100: '#FFD1D1'\n} as const;\n\nexport type Colors = typeof COLORS;\n"],"mappings":";;;;AAAO,MAAMA,MAAM,GAAAC,OAAA,CAAAD,MAAA,GAAG;EACpBE,IAAI,EAAE,SAAS;EACfC,QAAQ,EAAE,SAAS;EACnBC,eAAe,EAAE,SAAS;EAC1BC,QAAQ,EAAE,SAAS;EACnBC,eAAe,EAAE,SAAS;EAC1BC,KAAK,EAAE,SAAS;EAChBC,UAAU,EAAE,SAAS;EACrBC,WAAW,EAAE,SAAS;EACtBC,WAAW,EAAE,SAAS;EACtBC,eAAe,EAAE,SAAS;EAC1BC,WAAW,EAAE,SAAS;EACtBC,WAAW,EAAE,SAAS;EACtBC,WAAW,EAAE,SAAS;EACtBC,WAAW,EAAE,SAAS;EACtBC,aAAa,EAAE,SAAS;EACxBC,KAAK,EAAE,SAAS;EAChBC,UAAU,EAAE,SAAS;EACrBC,UAAU,EAAE,SAAS;EACrBC,OAAO,EAAE,SAAS;EAClBC,OAAO,EAAE;AACX,CAAU","ignoreList":[]}
1
+ {"version":3,"file":"colors.js","names":["COLORS","exports","gray","negative","cm_negative_200","positive","cm_positive_200","white","cm_blue_50","cm_grey_400","cm_grey_800","cm_grey_150","cm_grey_200","cm_primary_blue","primary_100","primary_600","cm_grey_500","cm_grey_700","cm_yellow_400","brand","yellow_700","yellow_100","red_700","red_100","cm_positive_500","purple_100"],"sources":["../../src/variables/colors.ts"],"sourcesContent":["export const COLORS = {\n gray: '#EAEAEB',\n negative: '#ed3436',\n cm_negative_200: '#B81400',\n positive: '#35CC7F',\n cm_positive_200: '#05944F',\n white: '#FFFFFF',\n cm_blue_50: '#f1f6fe',\n cm_grey_400: '#9999A8',\n cm_grey_800: '#171721',\n cm_grey_150: '#E1E1E3',\n cm_grey_200: '#E1E1E3',\n cm_primary_blue: '#0061FF',\n primary_100: '#D6E6FF',\n primary_600: '#0051D6',\n cm_grey_500: '#515161',\n cm_grey_700: '#1D1D2B',\n cm_yellow_400: '#bd7e00',\n brand: '#00B0FF',\n yellow_700: '#A38300',\n yellow_100: '#FFF9D1',\n red_700: '#A30000',\n red_100: '#FFD1D1',\n cm_positive_500: '#35CC7F',\n purple_100: '#DDD1FF'\n} as const;\n\nexport type Colors = typeof COLORS;\n"],"mappings":";;;;AAAO,MAAMA,MAAM,GAAAC,OAAA,CAAAD,MAAA,GAAG;EACpBE,IAAI,EAAE,SAAS;EACfC,QAAQ,EAAE,SAAS;EACnBC,eAAe,EAAE,SAAS;EAC1BC,QAAQ,EAAE,SAAS;EACnBC,eAAe,EAAE,SAAS;EAC1BC,KAAK,EAAE,SAAS;EAChBC,UAAU,EAAE,SAAS;EACrBC,WAAW,EAAE,SAAS;EACtBC,WAAW,EAAE,SAAS;EACtBC,WAAW,EAAE,SAAS;EACtBC,WAAW,EAAE,SAAS;EACtBC,eAAe,EAAE,SAAS;EAC1BC,WAAW,EAAE,SAAS;EACtBC,WAAW,EAAE,SAAS;EACtBC,WAAW,EAAE,SAAS;EACtBC,WAAW,EAAE,SAAS;EACtBC,aAAa,EAAE,SAAS;EACxBC,KAAK,EAAE,SAAS;EAChBC,UAAU,EAAE,SAAS;EACrBC,UAAU,EAAE,SAAS;EACrBC,OAAO,EAAE,SAAS;EAClBC,OAAO,EAAE,SAAS;EAClBC,eAAe,EAAE,SAAS;EAC1BC,UAAU,EAAE;AACd,CAAU","ignoreList":[]}