@ndla/ui 49.0.0 → 49.0.1

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.
@@ -39,7 +39,7 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
39
39
  var LinkedVideoButton = /*#__PURE__*/(0, _base.default)(_button.ButtonV2, {
40
40
  target: "e2wbdyh1",
41
41
  label: "LinkedVideoButton"
42
- })("margin-left:", _core.spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJyaWdodGNvdmVFbWJlZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEIwQyIsImZpbGUiOiJCcmlnaHRjb3ZlRW1iZWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjMtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc29ydEJ5IGZyb20gJ2xvZGFzaC9zb3J0QnknO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ09QWVJJR0hURUQgfSBmcm9tICdAbmRsYS9saWNlbnNlcyc7XG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgcGFyc2UgZnJvbSAnaHRtbC1yZWFjdC1wYXJzZXInO1xuaW1wb3J0IHsgQnJpZ2h0Y292ZUVtYmVkRGF0YSwgQnJpZ2h0Y292ZU1ldGFEYXRhLCBCcmlnaHRjb3ZlVmlkZW9Tb3VyY2UgfSBmcm9tICdAbmRsYS90eXBlcy1lbWJlZCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgRmlndXJlIH0gZnJvbSAnLi4vRmlndXJlJztcbmltcG9ydCB7IEVtYmVkQnlsaW5lIH0gZnJvbSAnLi4vTGljZW5zZUJ5bGluZSc7XG5pbXBvcnQgRW1iZWRFcnJvclBsYWNlaG9sZGVyIGZyb20gJy4vRW1iZWRFcnJvclBsYWNlaG9sZGVyJztcbmltcG9ydCB7IEhlYXJ0QnV0dG9uVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogQnJpZ2h0Y292ZU1ldGFEYXRhO1xuICBpc0NvbmNlcHQ/OiBib29sZWFuO1xuICBoZWFydEJ1dHRvbj86IEhlYXJ0QnV0dG9uVHlwZTtcbn1cblxuY29uc3QgTGlua2VkVmlkZW9CdXR0b24gPSBzdHlsZWQoQnV0dG9uVjIpYFxuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbmA7XG5cbmNvbnN0IEJyaWdodGNvdmVJZnJhbWUgPSBzdHlsZWQuaWZyYW1lYFxuICBoZWlnaHQ6IGF1dG87XG5gO1xuXG5leHBvcnQgY29uc3QgbWFrZUlmcmFtZVN0cmluZyA9ICh1cmw6IHN0cmluZywgd2lkdGg6IHN0cmluZyB8IG51bWJlciwgaGVpZ2h0OiBzdHJpbmcgfCBudW1iZXIsIHRpdGxlOiBzdHJpbmcgPSAnJykgPT4ge1xuICBjb25zdCBzdHJpcHBlZFdpZHRoID0gdHlwZW9mIHdpZHRoID09PSAnbnVtYmVyJyA/IHdpZHRoIDogd2lkdGgucmVwbGFjZSgvXFxzKnB4LywgJycpO1xuICBjb25zdCBzdHJpcHBlZEhlaWdodCA9IHR5cGVvZiBoZWlnaHQgPT09ICdudW1iZXInID8gaGVpZ2h0IDogaGVpZ2h0LnJlcGxhY2UoL1xccypweC8sICcnKTtcbiAgY29uc3QgdXJsT3JUaXRsZSA9IHRpdGxlIHx8IHVybDtcbiAgcmV0dXJuIGA8aWZyYW1lIHRpdGxlPVwiJHt1cmxPclRpdGxlfVwiIGFyaWEtbGFiZWw9XCIke3VybE9yVGl0bGV9XCIgc3JjPVwiJHt1cmx9XCIgd2lkdGg9XCIke3N0cmlwcGVkV2lkdGh9XCIgaGVpZ2h0PVwiJHtzdHJpcHBlZEhlaWdodH1cIiBhbGxvd2Z1bGxzY3JlZW4gc2Nyb2xsaW5nPVwibm9cIiBmcmFtZWJvcmRlcj1cIjBcIiBsb2FkaW5nPVwibGF6eVwiPjwvaWZyYW1lPmA7XG59O1xuXG5leHBvcnQgY29uc3QgaXNOdW1lcmljID0gKHZhbHVlOiBhbnkpID0+ICFOdW1iZXIuaXNOYU4odmFsdWUgLSBwYXJzZUZsb2F0KHZhbHVlKSk7XG5cbmNvbnN0IGdldElmcmFtZVByb3BzID0gKGRhdGE6IEJyaWdodGNvdmVFbWJlZERhdGEsIHNvdXJjZXM6IEJyaWdodGNvdmVWaWRlb1NvdXJjZVtdKSA9PiB7XG4gIGNvbnN0IHsgYWNjb3VudCwgdmlkZW9pZCwgcGxheWVyID0gJ2RlZmF1bHQnIH0gPSBkYXRhO1xuXG4gIGNvbnN0IHNvdXJjZSA9IHNvcnRCeShcbiAgICBzb3VyY2VzLmZpbHRlcigocykgPT4gcy53aWR0aCAmJiBzLmhlaWdodCksXG4gICAgKHMpID0+IHMuaGVpZ2h0LFxuICApWzBdO1xuXG4gIHJldHVybiB7XG4gICAgc3JjOiBgaHR0cHM6Ly9wbGF5ZXJzLmJyaWdodGNvdmUubmV0LyR7YWNjb3VudH0vJHtwbGF5ZXJ9X2RlZmF1bHQvaW5kZXguaHRtbD92aWRlb0lkPSR7dmlkZW9pZH1gLFxuICAgIGhlaWdodDogc291cmNlPy5oZWlnaHQgPz8gJzQ4MCcsXG4gICAgd2lkdGg6IHNvdXJjZT8ud2lkdGggPz8gJzY0MCcsXG4gIH07XG59O1xuY29uc3QgQnJpZ2h0Y292ZUVtYmVkID0gKHsgZW1iZWQsIGlzQ29uY2VwdCwgaGVhcnRCdXR0b246IEhlYXJ0QnV0dG9uIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IFtzaG93T3JpZ2luYWxWaWRlbywgc2V0U2hvd09yaWdpbmFsVmlkZW9dID0gdXNlU3RhdGUodHJ1ZSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgaWZyYW1lUmVmID0gdXNlUmVmPEhUTUxJRnJhbWVFbGVtZW50PihudWxsKTtcbiAgY29uc3QgeyBlbWJlZERhdGEgfSA9IGVtYmVkO1xuICBjb25zdCBmYWxsYmFja1RpdGxlID0gYCR7dCgnZW1iZWQudHlwZS52aWRlbycpfTogJHtlbWJlZERhdGEudmlkZW9pZH1gO1xuICBjb25zdCBwYXJzZWREZXNjcmlwdGlvbiA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIGlmIChlbWJlZC5lbWJlZERhdGEuY2FwdGlvbikge1xuICAgICAgcmV0dXJuIHBhcnNlKGVtYmVkLmVtYmVkRGF0YS5jYXB0aW9uKTtcbiAgICB9IGVsc2UgaWYgKGVtYmVkLnN0YXR1cyA9PT0gJ3N1Y2Nlc3MnICYmIGVtYmVkLmRhdGEuZGVzY3JpcHRpb24pIHtcbiAgICAgIHJldHVybiBwYXJzZShlbWJlZC5kYXRhLmRlc2NyaXB0aW9uKTtcbiAgICB9XG4gIH0sIFtlbWJlZF0pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaWZyYW1lID0gaWZyYW1lUmVmLmN1cnJlbnQ7XG4gICAgaWYgKGlmcmFtZSkge1xuICAgICAgY29uc3QgW3dpZHRoLCBoZWlnaHRdID0gW3BhcnNlSW50KGlmcmFtZS53aWR0aCksIHBhcnNlSW50KGlmcmFtZS5oZWlnaHQpXTtcbiAgICAgIGlmcmFtZS5zdHlsZS5hc3BlY3RSYXRpbyA9IGAke3dpZHRofS8ke2hlaWdodH1gO1xuICAgICAgaWZyYW1lLndpZHRoID0gJyc7XG4gICAgICBpZnJhbWUuaGVpZ2h0ID0gJyc7XG4gICAgfVxuICB9LCBbXSk7XG4gIGlmIChlbWJlZC5zdGF0dXMgPT09ICdlcnJvcicpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPEVtYmVkRXJyb3JQbGFjZWhvbGRlciB0eXBlPVwidmlkZW9cIj5cbiAgICAgICAgPEJyaWdodGNvdmVJZnJhbWVcbiAgICAgICAgICByZWY9e2lmcmFtZVJlZn1cbiAgICAgICAgICB0aXRsZT17ZW1iZWREYXRhLmFsdCA/PyBmYWxsYmFja1RpdGxlfVxuICAgICAgICAgIGFyaWEtbGFiZWw9e2VtYmVkRGF0YS5hbHQgPz8gZmFsbGJhY2tUaXRsZX1cbiAgICAgICAgICBmcmFtZUJvcmRlcj1cIjBcIlxuICAgICAgICAgIHsuLi5nZXRJZnJhbWVQcm9wcyhlbWJlZERhdGEsIFtdKX1cbiAgICAgICAgICBhbGxvd0Z1bGxTY3JlZW5cbiAgICAgICAgLz5cbiAgICAgIDwvRW1iZWRFcnJvclBsYWNlaG9sZGVyPlxuICAgICk7XG4gIH1cbiAgY29uc3QgeyBkYXRhIH0gPSBlbWJlZDtcblxuICBjb25zdCBsaW5rZWRWaWRlb0lkID0gaXNOdW1lcmljKGRhdGEubGluaz8udGV4dCkgPyBkYXRhLmxpbms/LnRleHQgOiB1bmRlZmluZWQ7XG5cbiAgY29uc3Qgb3JpZ2luYWxWaWRlb1Byb3BzID0gZ2V0SWZyYW1lUHJvcHMoZW1iZWREYXRhLCBkYXRhLnNvdXJjZXMpO1xuICBjb25zdCBhbHRlcm5hdGl2ZVZpZGVvUHJvcHMgPSBsaW5rZWRWaWRlb0lkXG4gICAgPyBnZXRJZnJhbWVQcm9wcyh7IC4uLmVtYmVkRGF0YSwgdmlkZW9pZDogbGlua2VkVmlkZW9JZCB9LCBkYXRhLnNvdXJjZXMpXG4gICAgOiB1bmRlZmluZWQ7XG5cbiAgcmV0dXJuIChcbiAgICA8RmlndXJlIHR5cGU9e2lzQ29uY2VwdCA/ICdmdWxsLWNvbHVtbicgOiAnZnVsbCd9IHJlc2l6ZUlmcmFtZT5cbiAgICAgIDxkaXYgY2xhc3NOYW1lPVwiYnJpZ2h0Y292ZS12aWRlb1wiPlxuICAgICAgICA8QnJpZ2h0Y292ZUlmcmFtZVxuICAgICAgICAgIHJlZj17aWZyYW1lUmVmfVxuICAgICAgICAgIGNsYXNzTmFtZT1cIm9yaWdpbmFsXCJcbiAgICAgICAgICB0aXRsZT17ZW1iZWREYXRhLmFsdCA/PyBkYXRhLm5hbWUgPz8gZmFsbGJhY2tUaXRsZX1cbiAgICAgICAgICBhcmlhLWxhYmVsPXtlbWJlZERhdGEuYWx0ID8/IGRhdGEubmFtZSA/PyBmYWxsYmFja1RpdGxlfVxuICAgICAgICAgIGZyYW1lQm9yZGVyPVwiMFwiXG4gICAgICAgICAgey4uLihhbHRlcm5hdGl2ZVZpZGVvUHJvcHMgJiYgIXNob3dPcmlnaW5hbFZpZGVvID8gYWx0ZXJuYXRpdmVWaWRlb1Byb3BzIDogb3JpZ2luYWxWaWRlb1Byb3BzKX1cbiAgICAgICAgICBhbGxvd0Z1bGxTY3JlZW5cbiAgICAgICAgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPEVtYmVkQnlsaW5lIHR5cGU9XCJ2aWRlb1wiIGNvcHlyaWdodD17ZGF0YS5jb3B5cmlnaHQhfSBkZXNjcmlwdGlvbj17cGFyc2VkRGVzY3JpcHRpb259IGJvdHRvbVJvdW5kZWQ+XG4gICAgICAgIHshIWxpbmtlZFZpZGVvSWQgJiYgKFxuICAgICAgICAgIDxMaW5rZWRWaWRlb0J1dHRvblxuICAgICAgICAgICAgdmFyaWFudD1cIm91dGxpbmVcIlxuICAgICAgICAgICAgc2hhcGU9XCJwaWxsXCJcbiAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiBzZXRTaG93T3JpZ2luYWxWaWRlbygocCkgPT4gIXApfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHt0KGBmaWd1cmUuYnV0dG9uLiR7IXNob3dPcmlnaW5hbFZpZGVvID8gJ29yaWdpbmFsJyA6ICdhbHRlcm5hdGl2ZSd9YCl9XG4gICAgICAgICAgPC9MaW5rZWRWaWRlb0J1dHRvbj5cbiAgICAgICAgKX1cbiAgICAgICAge0hlYXJ0QnV0dG9uICYmIGRhdGEuY29weXJpZ2h0Py5saWNlbnNlLmxpY2Vuc2UudG9Mb3dlckNhc2UoKSAhPT0gQ09QWVJJR0hURUQgJiYgPEhlYXJ0QnV0dG9uIGVtYmVkPXtlbWJlZH0gLz59XG4gICAgICA8L0VtYmVkQnlsaW5lPlxuICAgIDwvRmlndXJlPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQnJpZ2h0Y292ZUVtYmVkO1xuIl19 */"));
42
+ })("margin-left:", _core.spacing.small, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJyaWdodGNvdmVFbWJlZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkIwQyIsImZpbGUiOiJCcmlnaHRjb3ZlRW1iZWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjMtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc29ydEJ5IGZyb20gJ2xvZGFzaC9zb3J0QnknO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ09QWVJJR0hURUQgfSBmcm9tICdAbmRsYS9saWNlbnNlcyc7XG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgcGFyc2UgZnJvbSAnaHRtbC1yZWFjdC1wYXJzZXInO1xuaW1wb3J0IHsgQnJpZ2h0Y292ZUVtYmVkRGF0YSwgQnJpZ2h0Y292ZU1ldGFEYXRhLCBCcmlnaHRjb3ZlVmlkZW9Tb3VyY2UgfSBmcm9tICdAbmRsYS90eXBlcy1lbWJlZCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgRmlndXJlIH0gZnJvbSAnLi4vRmlndXJlJztcbmltcG9ydCB7IEVtYmVkQnlsaW5lIH0gZnJvbSAnLi4vTGljZW5zZUJ5bGluZSc7XG5pbXBvcnQgRW1iZWRFcnJvclBsYWNlaG9sZGVyIGZyb20gJy4vRW1iZWRFcnJvclBsYWNlaG9sZGVyJztcbmltcG9ydCB7IEhlYXJ0QnV0dG9uVHlwZSwgUmVuZGVyQ29udGV4dCB9IGZyb20gJy4vdHlwZXMnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogQnJpZ2h0Y292ZU1ldGFEYXRhO1xuICBpc0NvbmNlcHQ/OiBib29sZWFuO1xuICBoZWFydEJ1dHRvbj86IEhlYXJ0QnV0dG9uVHlwZTtcbiAgcmVuZGVyQ29udGV4dD86IFJlbmRlckNvbnRleHQ7XG59XG5cbmNvbnN0IExpbmtlZFZpZGVvQnV0dG9uID0gc3R5bGVkKEJ1dHRvblYyKWBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG5gO1xuXG5jb25zdCBCcmlnaHRjb3ZlSWZyYW1lID0gc3R5bGVkLmlmcmFtZWBcbiAgaGVpZ2h0OiBhdXRvO1xuYDtcblxuZXhwb3J0IGNvbnN0IG1ha2VJZnJhbWVTdHJpbmcgPSAodXJsOiBzdHJpbmcsIHdpZHRoOiBzdHJpbmcgfCBudW1iZXIsIGhlaWdodDogc3RyaW5nIHwgbnVtYmVyLCB0aXRsZTogc3RyaW5nID0gJycpID0+IHtcbiAgY29uc3Qgc3RyaXBwZWRXaWR0aCA9IHR5cGVvZiB3aWR0aCA9PT0gJ251bWJlcicgPyB3aWR0aCA6IHdpZHRoLnJlcGxhY2UoL1xccypweC8sICcnKTtcbiAgY29uc3Qgc3RyaXBwZWRIZWlnaHQgPSB0eXBlb2YgaGVpZ2h0ID09PSAnbnVtYmVyJyA/IGhlaWdodCA6IGhlaWdodC5yZXBsYWNlKC9cXHMqcHgvLCAnJyk7XG4gIGNvbnN0IHVybE9yVGl0bGUgPSB0aXRsZSB8fCB1cmw7XG4gIHJldHVybiBgPGlmcmFtZSB0aXRsZT1cIiR7dXJsT3JUaXRsZX1cIiBhcmlhLWxhYmVsPVwiJHt1cmxPclRpdGxlfVwiIHNyYz1cIiR7dXJsfVwiIHdpZHRoPVwiJHtzdHJpcHBlZFdpZHRofVwiIGhlaWdodD1cIiR7c3RyaXBwZWRIZWlnaHR9XCIgYWxsb3dmdWxsc2NyZWVuIHNjcm9sbGluZz1cIm5vXCIgZnJhbWVib3JkZXI9XCIwXCIgbG9hZGluZz1cImxhenlcIj48L2lmcmFtZT5gO1xufTtcblxuZXhwb3J0IGNvbnN0IGlzTnVtZXJpYyA9ICh2YWx1ZTogYW55KSA9PiAhTnVtYmVyLmlzTmFOKHZhbHVlIC0gcGFyc2VGbG9hdCh2YWx1ZSkpO1xuXG5jb25zdCBnZXRJZnJhbWVQcm9wcyA9IChkYXRhOiBCcmlnaHRjb3ZlRW1iZWREYXRhLCBzb3VyY2VzOiBCcmlnaHRjb3ZlVmlkZW9Tb3VyY2VbXSkgPT4ge1xuICBjb25zdCB7IGFjY291bnQsIHZpZGVvaWQsIHBsYXllciA9ICdkZWZhdWx0JyB9ID0gZGF0YTtcblxuICBjb25zdCBzb3VyY2UgPSBzb3J0QnkoXG4gICAgc291cmNlcy5maWx0ZXIoKHMpID0+IHMud2lkdGggJiYgcy5oZWlnaHQpLFxuICAgIChzKSA9PiBzLmhlaWdodCxcbiAgKVswXTtcblxuICByZXR1cm4ge1xuICAgIHNyYzogYGh0dHBzOi8vcGxheWVycy5icmlnaHRjb3ZlLm5ldC8ke2FjY291bnR9LyR7cGxheWVyfV9kZWZhdWx0L2luZGV4Lmh0bWw/dmlkZW9JZD0ke3ZpZGVvaWR9YCxcbiAgICBoZWlnaHQ6IHNvdXJjZT8uaGVpZ2h0ID8/ICc0ODAnLFxuICAgIHdpZHRoOiBzb3VyY2U/LndpZHRoID8/ICc2NDAnLFxuICB9O1xufTtcbmNvbnN0IEJyaWdodGNvdmVFbWJlZCA9ICh7IGVtYmVkLCBpc0NvbmNlcHQsIGhlYXJ0QnV0dG9uOiBIZWFydEJ1dHRvbiwgcmVuZGVyQ29udGV4dCA9ICdhcnRpY2xlJyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBbc2hvd09yaWdpbmFsVmlkZW8sIHNldFNob3dPcmlnaW5hbFZpZGVvXSA9IHVzZVN0YXRlKHRydWUpO1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IGlmcmFtZVJlZiA9IHVzZVJlZjxIVE1MSUZyYW1lRWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IHsgZW1iZWREYXRhIH0gPSBlbWJlZDtcbiAgY29uc3QgZmFsbGJhY2tUaXRsZSA9IGAke3QoJ2VtYmVkLnR5cGUudmlkZW8nKX06ICR7ZW1iZWREYXRhLnZpZGVvaWR9YDtcbiAgY29uc3QgcGFyc2VkRGVzY3JpcHRpb24gPSB1c2VNZW1vKCgpID0+IHtcbiAgICBpZiAoZW1iZWQuZW1iZWREYXRhLmNhcHRpb24gfHwgcmVuZGVyQ29udGV4dCA9PT0gJ2FydGljbGUnKSB7XG4gICAgICByZXR1cm4gZW1iZWQuZW1iZWREYXRhLmNhcHRpb24gPyBwYXJzZShlbWJlZC5lbWJlZERhdGEuY2FwdGlvbikgOiB1bmRlZmluZWQ7XG4gICAgfSBlbHNlIGlmIChlbWJlZC5zdGF0dXMgPT09ICdzdWNjZXNzJyAmJiBlbWJlZC5kYXRhLmRlc2NyaXB0aW9uKSB7XG4gICAgICByZXR1cm4gcGFyc2UoZW1iZWQuZGF0YS5kZXNjcmlwdGlvbik7XG4gICAgfVxuICB9LCBbZW1iZWQsIHJlbmRlckNvbnRleHRdKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGlmcmFtZSA9IGlmcmFtZVJlZi5jdXJyZW50O1xuICAgIGlmIChpZnJhbWUpIHtcbiAgICAgIGNvbnN0IFt3aWR0aCwgaGVpZ2h0XSA9IFtwYXJzZUludChpZnJhbWUud2lkdGgpLCBwYXJzZUludChpZnJhbWUuaGVpZ2h0KV07XG4gICAgICBpZnJhbWUuc3R5bGUuYXNwZWN0UmF0aW8gPSBgJHt3aWR0aH0vJHtoZWlnaHR9YDtcbiAgICAgIGlmcmFtZS53aWR0aCA9ICcnO1xuICAgICAgaWZyYW1lLmhlaWdodCA9ICcnO1xuICAgIH1cbiAgfSwgW10pO1xuICBpZiAoZW1iZWQuc3RhdHVzID09PSAnZXJyb3InKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxFbWJlZEVycm9yUGxhY2Vob2xkZXIgdHlwZT1cInZpZGVvXCI+XG4gICAgICAgIDxCcmlnaHRjb3ZlSWZyYW1lXG4gICAgICAgICAgcmVmPXtpZnJhbWVSZWZ9XG4gICAgICAgICAgdGl0bGU9e2VtYmVkRGF0YS5hbHQgPz8gZmFsbGJhY2tUaXRsZX1cbiAgICAgICAgICBhcmlhLWxhYmVsPXtlbWJlZERhdGEuYWx0ID8/IGZhbGxiYWNrVGl0bGV9XG4gICAgICAgICAgZnJhbWVCb3JkZXI9XCIwXCJcbiAgICAgICAgICB7Li4uZ2V0SWZyYW1lUHJvcHMoZW1iZWREYXRhLCBbXSl9XG4gICAgICAgICAgYWxsb3dGdWxsU2NyZWVuXG4gICAgICAgIC8+XG4gICAgICA8L0VtYmVkRXJyb3JQbGFjZWhvbGRlcj5cbiAgICApO1xuICB9XG4gIGNvbnN0IHsgZGF0YSB9ID0gZW1iZWQ7XG5cbiAgY29uc3QgbGlua2VkVmlkZW9JZCA9IGlzTnVtZXJpYyhkYXRhLmxpbms/LnRleHQpID8gZGF0YS5saW5rPy50ZXh0IDogdW5kZWZpbmVkO1xuXG4gIGNvbnN0IG9yaWdpbmFsVmlkZW9Qcm9wcyA9IGdldElmcmFtZVByb3BzKGVtYmVkRGF0YSwgZGF0YS5zb3VyY2VzKTtcbiAgY29uc3QgYWx0ZXJuYXRpdmVWaWRlb1Byb3BzID0gbGlua2VkVmlkZW9JZFxuICAgID8gZ2V0SWZyYW1lUHJvcHMoeyAuLi5lbWJlZERhdGEsIHZpZGVvaWQ6IGxpbmtlZFZpZGVvSWQgfSwgZGF0YS5zb3VyY2VzKVxuICAgIDogdW5kZWZpbmVkO1xuXG4gIHJldHVybiAoXG4gICAgPEZpZ3VyZSB0eXBlPXtpc0NvbmNlcHQgPyAnZnVsbC1jb2x1bW4nIDogJ2Z1bGwnfSByZXNpemVJZnJhbWU+XG4gICAgICA8ZGl2IGNsYXNzTmFtZT1cImJyaWdodGNvdmUtdmlkZW9cIj5cbiAgICAgICAgPEJyaWdodGNvdmVJZnJhbWVcbiAgICAgICAgICByZWY9e2lmcmFtZVJlZn1cbiAgICAgICAgICBjbGFzc05hbWU9XCJvcmlnaW5hbFwiXG4gICAgICAgICAgdGl0bGU9e2VtYmVkRGF0YS5hbHQgPz8gZGF0YS5uYW1lID8/IGZhbGxiYWNrVGl0bGV9XG4gICAgICAgICAgYXJpYS1sYWJlbD17ZW1iZWREYXRhLmFsdCA/PyBkYXRhLm5hbWUgPz8gZmFsbGJhY2tUaXRsZX1cbiAgICAgICAgICBmcmFtZUJvcmRlcj1cIjBcIlxuICAgICAgICAgIHsuLi4oYWx0ZXJuYXRpdmVWaWRlb1Byb3BzICYmICFzaG93T3JpZ2luYWxWaWRlbyA/IGFsdGVybmF0aXZlVmlkZW9Qcm9wcyA6IG9yaWdpbmFsVmlkZW9Qcm9wcyl9XG4gICAgICAgICAgYWxsb3dGdWxsU2NyZWVuXG4gICAgICAgIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxFbWJlZEJ5bGluZSB0eXBlPVwidmlkZW9cIiBjb3B5cmlnaHQ9e2RhdGEuY29weXJpZ2h0IX0gZGVzY3JpcHRpb249e3BhcnNlZERlc2NyaXB0aW9ufSBib3R0b21Sb3VuZGVkPlxuICAgICAgICB7ISFsaW5rZWRWaWRlb0lkICYmIChcbiAgICAgICAgICA8TGlua2VkVmlkZW9CdXR0b25cbiAgICAgICAgICAgIHZhcmlhbnQ9XCJvdXRsaW5lXCJcbiAgICAgICAgICAgIHNoYXBlPVwicGlsbFwiXG4gICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgb25DbGljaz17KCkgPT4gc2V0U2hvd09yaWdpbmFsVmlkZW8oKHApID0+ICFwKX1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7dChgZmlndXJlLmJ1dHRvbi4keyFzaG93T3JpZ2luYWxWaWRlbyA/ICdvcmlnaW5hbCcgOiAnYWx0ZXJuYXRpdmUnfWApfVxuICAgICAgICAgIDwvTGlua2VkVmlkZW9CdXR0b24+XG4gICAgICAgICl9XG4gICAgICAgIHtIZWFydEJ1dHRvbiAmJiBkYXRhLmNvcHlyaWdodD8ubGljZW5zZS5saWNlbnNlLnRvTG93ZXJDYXNlKCkgIT09IENPUFlSSUdIVEVEICYmIDxIZWFydEJ1dHRvbiBlbWJlZD17ZW1iZWR9IC8+fVxuICAgICAgPC9FbWJlZEJ5bGluZT5cbiAgICA8L0ZpZ3VyZT5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEJyaWdodGNvdmVFbWJlZDtcbiJdfQ== */"));
43
43
  var BrightcoveIframe = /*#__PURE__*/(0, _base.default)("iframe", {
44
44
  target: "e2wbdyh0",
45
45
  label: "BrightcoveIframe"
@@ -49,7 +49,7 @@ var BrightcoveIframe = /*#__PURE__*/(0, _base.default)("iframe", {
49
49
  } : {
50
50
  name: "pit38s",
51
51
  styles: "height:auto",
52
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJyaWdodGNvdmVFbWJlZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0NzQyIsImZpbGUiOiJCcmlnaHRjb3ZlRW1iZWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjMtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc29ydEJ5IGZyb20gJ2xvZGFzaC9zb3J0QnknO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ09QWVJJR0hURUQgfSBmcm9tICdAbmRsYS9saWNlbnNlcyc7XG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgcGFyc2UgZnJvbSAnaHRtbC1yZWFjdC1wYXJzZXInO1xuaW1wb3J0IHsgQnJpZ2h0Y292ZUVtYmVkRGF0YSwgQnJpZ2h0Y292ZU1ldGFEYXRhLCBCcmlnaHRjb3ZlVmlkZW9Tb3VyY2UgfSBmcm9tICdAbmRsYS90eXBlcy1lbWJlZCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgRmlndXJlIH0gZnJvbSAnLi4vRmlndXJlJztcbmltcG9ydCB7IEVtYmVkQnlsaW5lIH0gZnJvbSAnLi4vTGljZW5zZUJ5bGluZSc7XG5pbXBvcnQgRW1iZWRFcnJvclBsYWNlaG9sZGVyIGZyb20gJy4vRW1iZWRFcnJvclBsYWNlaG9sZGVyJztcbmltcG9ydCB7IEhlYXJ0QnV0dG9uVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogQnJpZ2h0Y292ZU1ldGFEYXRhO1xuICBpc0NvbmNlcHQ/OiBib29sZWFuO1xuICBoZWFydEJ1dHRvbj86IEhlYXJ0QnV0dG9uVHlwZTtcbn1cblxuY29uc3QgTGlua2VkVmlkZW9CdXR0b24gPSBzdHlsZWQoQnV0dG9uVjIpYFxuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLnNtYWxsfTtcbmA7XG5cbmNvbnN0IEJyaWdodGNvdmVJZnJhbWUgPSBzdHlsZWQuaWZyYW1lYFxuICBoZWlnaHQ6IGF1dG87XG5gO1xuXG5leHBvcnQgY29uc3QgbWFrZUlmcmFtZVN0cmluZyA9ICh1cmw6IHN0cmluZywgd2lkdGg6IHN0cmluZyB8IG51bWJlciwgaGVpZ2h0OiBzdHJpbmcgfCBudW1iZXIsIHRpdGxlOiBzdHJpbmcgPSAnJykgPT4ge1xuICBjb25zdCBzdHJpcHBlZFdpZHRoID0gdHlwZW9mIHdpZHRoID09PSAnbnVtYmVyJyA/IHdpZHRoIDogd2lkdGgucmVwbGFjZSgvXFxzKnB4LywgJycpO1xuICBjb25zdCBzdHJpcHBlZEhlaWdodCA9IHR5cGVvZiBoZWlnaHQgPT09ICdudW1iZXInID8gaGVpZ2h0IDogaGVpZ2h0LnJlcGxhY2UoL1xccypweC8sICcnKTtcbiAgY29uc3QgdXJsT3JUaXRsZSA9IHRpdGxlIHx8IHVybDtcbiAgcmV0dXJuIGA8aWZyYW1lIHRpdGxlPVwiJHt1cmxPclRpdGxlfVwiIGFyaWEtbGFiZWw9XCIke3VybE9yVGl0bGV9XCIgc3JjPVwiJHt1cmx9XCIgd2lkdGg9XCIke3N0cmlwcGVkV2lkdGh9XCIgaGVpZ2h0PVwiJHtzdHJpcHBlZEhlaWdodH1cIiBhbGxvd2Z1bGxzY3JlZW4gc2Nyb2xsaW5nPVwibm9cIiBmcmFtZWJvcmRlcj1cIjBcIiBsb2FkaW5nPVwibGF6eVwiPjwvaWZyYW1lPmA7XG59O1xuXG5leHBvcnQgY29uc3QgaXNOdW1lcmljID0gKHZhbHVlOiBhbnkpID0+ICFOdW1iZXIuaXNOYU4odmFsdWUgLSBwYXJzZUZsb2F0KHZhbHVlKSk7XG5cbmNvbnN0IGdldElmcmFtZVByb3BzID0gKGRhdGE6IEJyaWdodGNvdmVFbWJlZERhdGEsIHNvdXJjZXM6IEJyaWdodGNvdmVWaWRlb1NvdXJjZVtdKSA9PiB7XG4gIGNvbnN0IHsgYWNjb3VudCwgdmlkZW9pZCwgcGxheWVyID0gJ2RlZmF1bHQnIH0gPSBkYXRhO1xuXG4gIGNvbnN0IHNvdXJjZSA9IHNvcnRCeShcbiAgICBzb3VyY2VzLmZpbHRlcigocykgPT4gcy53aWR0aCAmJiBzLmhlaWdodCksXG4gICAgKHMpID0+IHMuaGVpZ2h0LFxuICApWzBdO1xuXG4gIHJldHVybiB7XG4gICAgc3JjOiBgaHR0cHM6Ly9wbGF5ZXJzLmJyaWdodGNvdmUubmV0LyR7YWNjb3VudH0vJHtwbGF5ZXJ9X2RlZmF1bHQvaW5kZXguaHRtbD92aWRlb0lkPSR7dmlkZW9pZH1gLFxuICAgIGhlaWdodDogc291cmNlPy5oZWlnaHQgPz8gJzQ4MCcsXG4gICAgd2lkdGg6IHNvdXJjZT8ud2lkdGggPz8gJzY0MCcsXG4gIH07XG59O1xuY29uc3QgQnJpZ2h0Y292ZUVtYmVkID0gKHsgZW1iZWQsIGlzQ29uY2VwdCwgaGVhcnRCdXR0b246IEhlYXJ0QnV0dG9uIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IFtzaG93T3JpZ2luYWxWaWRlbywgc2V0U2hvd09yaWdpbmFsVmlkZW9dID0gdXNlU3RhdGUodHJ1ZSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgaWZyYW1lUmVmID0gdXNlUmVmPEhUTUxJRnJhbWVFbGVtZW50PihudWxsKTtcbiAgY29uc3QgeyBlbWJlZERhdGEgfSA9IGVtYmVkO1xuICBjb25zdCBmYWxsYmFja1RpdGxlID0gYCR7dCgnZW1iZWQudHlwZS52aWRlbycpfTogJHtlbWJlZERhdGEudmlkZW9pZH1gO1xuICBjb25zdCBwYXJzZWREZXNjcmlwdGlvbiA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIGlmIChlbWJlZC5lbWJlZERhdGEuY2FwdGlvbikge1xuICAgICAgcmV0dXJuIHBhcnNlKGVtYmVkLmVtYmVkRGF0YS5jYXB0aW9uKTtcbiAgICB9IGVsc2UgaWYgKGVtYmVkLnN0YXR1cyA9PT0gJ3N1Y2Nlc3MnICYmIGVtYmVkLmRhdGEuZGVzY3JpcHRpb24pIHtcbiAgICAgIHJldHVybiBwYXJzZShlbWJlZC5kYXRhLmRlc2NyaXB0aW9uKTtcbiAgICB9XG4gIH0sIFtlbWJlZF0pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaWZyYW1lID0gaWZyYW1lUmVmLmN1cnJlbnQ7XG4gICAgaWYgKGlmcmFtZSkge1xuICAgICAgY29uc3QgW3dpZHRoLCBoZWlnaHRdID0gW3BhcnNlSW50KGlmcmFtZS53aWR0aCksIHBhcnNlSW50KGlmcmFtZS5oZWlnaHQpXTtcbiAgICAgIGlmcmFtZS5zdHlsZS5hc3BlY3RSYXRpbyA9IGAke3dpZHRofS8ke2hlaWdodH1gO1xuICAgICAgaWZyYW1lLndpZHRoID0gJyc7XG4gICAgICBpZnJhbWUuaGVpZ2h0ID0gJyc7XG4gICAgfVxuICB9LCBbXSk7XG4gIGlmIChlbWJlZC5zdGF0dXMgPT09ICdlcnJvcicpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPEVtYmVkRXJyb3JQbGFjZWhvbGRlciB0eXBlPVwidmlkZW9cIj5cbiAgICAgICAgPEJyaWdodGNvdmVJZnJhbWVcbiAgICAgICAgICByZWY9e2lmcmFtZVJlZn1cbiAgICAgICAgICB0aXRsZT17ZW1iZWREYXRhLmFsdCA/PyBmYWxsYmFja1RpdGxlfVxuICAgICAgICAgIGFyaWEtbGFiZWw9e2VtYmVkRGF0YS5hbHQgPz8gZmFsbGJhY2tUaXRsZX1cbiAgICAgICAgICBmcmFtZUJvcmRlcj1cIjBcIlxuICAgICAgICAgIHsuLi5nZXRJZnJhbWVQcm9wcyhlbWJlZERhdGEsIFtdKX1cbiAgICAgICAgICBhbGxvd0Z1bGxTY3JlZW5cbiAgICAgICAgLz5cbiAgICAgIDwvRW1iZWRFcnJvclBsYWNlaG9sZGVyPlxuICAgICk7XG4gIH1cbiAgY29uc3QgeyBkYXRhIH0gPSBlbWJlZDtcblxuICBjb25zdCBsaW5rZWRWaWRlb0lkID0gaXNOdW1lcmljKGRhdGEubGluaz8udGV4dCkgPyBkYXRhLmxpbms/LnRleHQgOiB1bmRlZmluZWQ7XG5cbiAgY29uc3Qgb3JpZ2luYWxWaWRlb1Byb3BzID0gZ2V0SWZyYW1lUHJvcHMoZW1iZWREYXRhLCBkYXRhLnNvdXJjZXMpO1xuICBjb25zdCBhbHRlcm5hdGl2ZVZpZGVvUHJvcHMgPSBsaW5rZWRWaWRlb0lkXG4gICAgPyBnZXRJZnJhbWVQcm9wcyh7IC4uLmVtYmVkRGF0YSwgdmlkZW9pZDogbGlua2VkVmlkZW9JZCB9LCBkYXRhLnNvdXJjZXMpXG4gICAgOiB1bmRlZmluZWQ7XG5cbiAgcmV0dXJuIChcbiAgICA8RmlndXJlIHR5cGU9e2lzQ29uY2VwdCA/ICdmdWxsLWNvbHVtbicgOiAnZnVsbCd9IHJlc2l6ZUlmcmFtZT5cbiAgICAgIDxkaXYgY2xhc3NOYW1lPVwiYnJpZ2h0Y292ZS12aWRlb1wiPlxuICAgICAgICA8QnJpZ2h0Y292ZUlmcmFtZVxuICAgICAgICAgIHJlZj17aWZyYW1lUmVmfVxuICAgICAgICAgIGNsYXNzTmFtZT1cIm9yaWdpbmFsXCJcbiAgICAgICAgICB0aXRsZT17ZW1iZWREYXRhLmFsdCA/PyBkYXRhLm5hbWUgPz8gZmFsbGJhY2tUaXRsZX1cbiAgICAgICAgICBhcmlhLWxhYmVsPXtlbWJlZERhdGEuYWx0ID8/IGRhdGEubmFtZSA/PyBmYWxsYmFja1RpdGxlfVxuICAgICAgICAgIGZyYW1lQm9yZGVyPVwiMFwiXG4gICAgICAgICAgey4uLihhbHRlcm5hdGl2ZVZpZGVvUHJvcHMgJiYgIXNob3dPcmlnaW5hbFZpZGVvID8gYWx0ZXJuYXRpdmVWaWRlb1Byb3BzIDogb3JpZ2luYWxWaWRlb1Byb3BzKX1cbiAgICAgICAgICBhbGxvd0Z1bGxTY3JlZW5cbiAgICAgICAgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPEVtYmVkQnlsaW5lIHR5cGU9XCJ2aWRlb1wiIGNvcHlyaWdodD17ZGF0YS5jb3B5cmlnaHQhfSBkZXNjcmlwdGlvbj17cGFyc2VkRGVzY3JpcHRpb259IGJvdHRvbVJvdW5kZWQ+XG4gICAgICAgIHshIWxpbmtlZFZpZGVvSWQgJiYgKFxuICAgICAgICAgIDxMaW5rZWRWaWRlb0J1dHRvblxuICAgICAgICAgICAgdmFyaWFudD1cIm91dGxpbmVcIlxuICAgICAgICAgICAgc2hhcGU9XCJwaWxsXCJcbiAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiBzZXRTaG93T3JpZ2luYWxWaWRlbygocCkgPT4gIXApfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHt0KGBmaWd1cmUuYnV0dG9uLiR7IXNob3dPcmlnaW5hbFZpZGVvID8gJ29yaWdpbmFsJyA6ICdhbHRlcm5hdGl2ZSd9YCl9XG4gICAgICAgICAgPC9MaW5rZWRWaWRlb0J1dHRvbj5cbiAgICAgICAgKX1cbiAgICAgICAge0hlYXJ0QnV0dG9uICYmIGRhdGEuY29weXJpZ2h0Py5saWNlbnNlLmxpY2Vuc2UudG9Mb3dlckNhc2UoKSAhPT0gQ09QWVJJR0hURUQgJiYgPEhlYXJ0QnV0dG9uIGVtYmVkPXtlbWJlZH0gLz59XG4gICAgICA8L0VtYmVkQnlsaW5lPlxuICAgIDwvRmlndXJlPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQnJpZ2h0Y292ZUVtYmVkO1xuIl19 */",
52
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJyaWdodGNvdmVFbWJlZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUNzQyIsImZpbGUiOiJCcmlnaHRjb3ZlRW1iZWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjMtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgc29ydEJ5IGZyb20gJ2xvZGFzaC9zb3J0QnknO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ09QWVJJR0hURUQgfSBmcm9tICdAbmRsYS9saWNlbnNlcyc7XG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgcGFyc2UgZnJvbSAnaHRtbC1yZWFjdC1wYXJzZXInO1xuaW1wb3J0IHsgQnJpZ2h0Y292ZUVtYmVkRGF0YSwgQnJpZ2h0Y292ZU1ldGFEYXRhLCBCcmlnaHRjb3ZlVmlkZW9Tb3VyY2UgfSBmcm9tICdAbmRsYS90eXBlcy1lbWJlZCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgRmlndXJlIH0gZnJvbSAnLi4vRmlndXJlJztcbmltcG9ydCB7IEVtYmVkQnlsaW5lIH0gZnJvbSAnLi4vTGljZW5zZUJ5bGluZSc7XG5pbXBvcnQgRW1iZWRFcnJvclBsYWNlaG9sZGVyIGZyb20gJy4vRW1iZWRFcnJvclBsYWNlaG9sZGVyJztcbmltcG9ydCB7IEhlYXJ0QnV0dG9uVHlwZSwgUmVuZGVyQ29udGV4dCB9IGZyb20gJy4vdHlwZXMnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogQnJpZ2h0Y292ZU1ldGFEYXRhO1xuICBpc0NvbmNlcHQ/OiBib29sZWFuO1xuICBoZWFydEJ1dHRvbj86IEhlYXJ0QnV0dG9uVHlwZTtcbiAgcmVuZGVyQ29udGV4dD86IFJlbmRlckNvbnRleHQ7XG59XG5cbmNvbnN0IExpbmtlZFZpZGVvQnV0dG9uID0gc3R5bGVkKEJ1dHRvblYyKWBcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG5gO1xuXG5jb25zdCBCcmlnaHRjb3ZlSWZyYW1lID0gc3R5bGVkLmlmcmFtZWBcbiAgaGVpZ2h0OiBhdXRvO1xuYDtcblxuZXhwb3J0IGNvbnN0IG1ha2VJZnJhbWVTdHJpbmcgPSAodXJsOiBzdHJpbmcsIHdpZHRoOiBzdHJpbmcgfCBudW1iZXIsIGhlaWdodDogc3RyaW5nIHwgbnVtYmVyLCB0aXRsZTogc3RyaW5nID0gJycpID0+IHtcbiAgY29uc3Qgc3RyaXBwZWRXaWR0aCA9IHR5cGVvZiB3aWR0aCA9PT0gJ251bWJlcicgPyB3aWR0aCA6IHdpZHRoLnJlcGxhY2UoL1xccypweC8sICcnKTtcbiAgY29uc3Qgc3RyaXBwZWRIZWlnaHQgPSB0eXBlb2YgaGVpZ2h0ID09PSAnbnVtYmVyJyA/IGhlaWdodCA6IGhlaWdodC5yZXBsYWNlKC9cXHMqcHgvLCAnJyk7XG4gIGNvbnN0IHVybE9yVGl0bGUgPSB0aXRsZSB8fCB1cmw7XG4gIHJldHVybiBgPGlmcmFtZSB0aXRsZT1cIiR7dXJsT3JUaXRsZX1cIiBhcmlhLWxhYmVsPVwiJHt1cmxPclRpdGxlfVwiIHNyYz1cIiR7dXJsfVwiIHdpZHRoPVwiJHtzdHJpcHBlZFdpZHRofVwiIGhlaWdodD1cIiR7c3RyaXBwZWRIZWlnaHR9XCIgYWxsb3dmdWxsc2NyZWVuIHNjcm9sbGluZz1cIm5vXCIgZnJhbWVib3JkZXI9XCIwXCIgbG9hZGluZz1cImxhenlcIj48L2lmcmFtZT5gO1xufTtcblxuZXhwb3J0IGNvbnN0IGlzTnVtZXJpYyA9ICh2YWx1ZTogYW55KSA9PiAhTnVtYmVyLmlzTmFOKHZhbHVlIC0gcGFyc2VGbG9hdCh2YWx1ZSkpO1xuXG5jb25zdCBnZXRJZnJhbWVQcm9wcyA9IChkYXRhOiBCcmlnaHRjb3ZlRW1iZWREYXRhLCBzb3VyY2VzOiBCcmlnaHRjb3ZlVmlkZW9Tb3VyY2VbXSkgPT4ge1xuICBjb25zdCB7IGFjY291bnQsIHZpZGVvaWQsIHBsYXllciA9ICdkZWZhdWx0JyB9ID0gZGF0YTtcblxuICBjb25zdCBzb3VyY2UgPSBzb3J0QnkoXG4gICAgc291cmNlcy5maWx0ZXIoKHMpID0+IHMud2lkdGggJiYgcy5oZWlnaHQpLFxuICAgIChzKSA9PiBzLmhlaWdodCxcbiAgKVswXTtcblxuICByZXR1cm4ge1xuICAgIHNyYzogYGh0dHBzOi8vcGxheWVycy5icmlnaHRjb3ZlLm5ldC8ke2FjY291bnR9LyR7cGxheWVyfV9kZWZhdWx0L2luZGV4Lmh0bWw/dmlkZW9JZD0ke3ZpZGVvaWR9YCxcbiAgICBoZWlnaHQ6IHNvdXJjZT8uaGVpZ2h0ID8/ICc0ODAnLFxuICAgIHdpZHRoOiBzb3VyY2U/LndpZHRoID8/ICc2NDAnLFxuICB9O1xufTtcbmNvbnN0IEJyaWdodGNvdmVFbWJlZCA9ICh7IGVtYmVkLCBpc0NvbmNlcHQsIGhlYXJ0QnV0dG9uOiBIZWFydEJ1dHRvbiwgcmVuZGVyQ29udGV4dCA9ICdhcnRpY2xlJyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBbc2hvd09yaWdpbmFsVmlkZW8sIHNldFNob3dPcmlnaW5hbFZpZGVvXSA9IHVzZVN0YXRlKHRydWUpO1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IGlmcmFtZVJlZiA9IHVzZVJlZjxIVE1MSUZyYW1lRWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IHsgZW1iZWREYXRhIH0gPSBlbWJlZDtcbiAgY29uc3QgZmFsbGJhY2tUaXRsZSA9IGAke3QoJ2VtYmVkLnR5cGUudmlkZW8nKX06ICR7ZW1iZWREYXRhLnZpZGVvaWR9YDtcbiAgY29uc3QgcGFyc2VkRGVzY3JpcHRpb24gPSB1c2VNZW1vKCgpID0+IHtcbiAgICBpZiAoZW1iZWQuZW1iZWREYXRhLmNhcHRpb24gfHwgcmVuZGVyQ29udGV4dCA9PT0gJ2FydGljbGUnKSB7XG4gICAgICByZXR1cm4gZW1iZWQuZW1iZWREYXRhLmNhcHRpb24gPyBwYXJzZShlbWJlZC5lbWJlZERhdGEuY2FwdGlvbikgOiB1bmRlZmluZWQ7XG4gICAgfSBlbHNlIGlmIChlbWJlZC5zdGF0dXMgPT09ICdzdWNjZXNzJyAmJiBlbWJlZC5kYXRhLmRlc2NyaXB0aW9uKSB7XG4gICAgICByZXR1cm4gcGFyc2UoZW1iZWQuZGF0YS5kZXNjcmlwdGlvbik7XG4gICAgfVxuICB9LCBbZW1iZWQsIHJlbmRlckNvbnRleHRdKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGlmcmFtZSA9IGlmcmFtZVJlZi5jdXJyZW50O1xuICAgIGlmIChpZnJhbWUpIHtcbiAgICAgIGNvbnN0IFt3aWR0aCwgaGVpZ2h0XSA9IFtwYXJzZUludChpZnJhbWUud2lkdGgpLCBwYXJzZUludChpZnJhbWUuaGVpZ2h0KV07XG4gICAgICBpZnJhbWUuc3R5bGUuYXNwZWN0UmF0aW8gPSBgJHt3aWR0aH0vJHtoZWlnaHR9YDtcbiAgICAgIGlmcmFtZS53aWR0aCA9ICcnO1xuICAgICAgaWZyYW1lLmhlaWdodCA9ICcnO1xuICAgIH1cbiAgfSwgW10pO1xuICBpZiAoZW1iZWQuc3RhdHVzID09PSAnZXJyb3InKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxFbWJlZEVycm9yUGxhY2Vob2xkZXIgdHlwZT1cInZpZGVvXCI+XG4gICAgICAgIDxCcmlnaHRjb3ZlSWZyYW1lXG4gICAgICAgICAgcmVmPXtpZnJhbWVSZWZ9XG4gICAgICAgICAgdGl0bGU9e2VtYmVkRGF0YS5hbHQgPz8gZmFsbGJhY2tUaXRsZX1cbiAgICAgICAgICBhcmlhLWxhYmVsPXtlbWJlZERhdGEuYWx0ID8/IGZhbGxiYWNrVGl0bGV9XG4gICAgICAgICAgZnJhbWVCb3JkZXI9XCIwXCJcbiAgICAgICAgICB7Li4uZ2V0SWZyYW1lUHJvcHMoZW1iZWREYXRhLCBbXSl9XG4gICAgICAgICAgYWxsb3dGdWxsU2NyZWVuXG4gICAgICAgIC8+XG4gICAgICA8L0VtYmVkRXJyb3JQbGFjZWhvbGRlcj5cbiAgICApO1xuICB9XG4gIGNvbnN0IHsgZGF0YSB9ID0gZW1iZWQ7XG5cbiAgY29uc3QgbGlua2VkVmlkZW9JZCA9IGlzTnVtZXJpYyhkYXRhLmxpbms/LnRleHQpID8gZGF0YS5saW5rPy50ZXh0IDogdW5kZWZpbmVkO1xuXG4gIGNvbnN0IG9yaWdpbmFsVmlkZW9Qcm9wcyA9IGdldElmcmFtZVByb3BzKGVtYmVkRGF0YSwgZGF0YS5zb3VyY2VzKTtcbiAgY29uc3QgYWx0ZXJuYXRpdmVWaWRlb1Byb3BzID0gbGlua2VkVmlkZW9JZFxuICAgID8gZ2V0SWZyYW1lUHJvcHMoeyAuLi5lbWJlZERhdGEsIHZpZGVvaWQ6IGxpbmtlZFZpZGVvSWQgfSwgZGF0YS5zb3VyY2VzKVxuICAgIDogdW5kZWZpbmVkO1xuXG4gIHJldHVybiAoXG4gICAgPEZpZ3VyZSB0eXBlPXtpc0NvbmNlcHQgPyAnZnVsbC1jb2x1bW4nIDogJ2Z1bGwnfSByZXNpemVJZnJhbWU+XG4gICAgICA8ZGl2IGNsYXNzTmFtZT1cImJyaWdodGNvdmUtdmlkZW9cIj5cbiAgICAgICAgPEJyaWdodGNvdmVJZnJhbWVcbiAgICAgICAgICByZWY9e2lmcmFtZVJlZn1cbiAgICAgICAgICBjbGFzc05hbWU9XCJvcmlnaW5hbFwiXG4gICAgICAgICAgdGl0bGU9e2VtYmVkRGF0YS5hbHQgPz8gZGF0YS5uYW1lID8/IGZhbGxiYWNrVGl0bGV9XG4gICAgICAgICAgYXJpYS1sYWJlbD17ZW1iZWREYXRhLmFsdCA/PyBkYXRhLm5hbWUgPz8gZmFsbGJhY2tUaXRsZX1cbiAgICAgICAgICBmcmFtZUJvcmRlcj1cIjBcIlxuICAgICAgICAgIHsuLi4oYWx0ZXJuYXRpdmVWaWRlb1Byb3BzICYmICFzaG93T3JpZ2luYWxWaWRlbyA/IGFsdGVybmF0aXZlVmlkZW9Qcm9wcyA6IG9yaWdpbmFsVmlkZW9Qcm9wcyl9XG4gICAgICAgICAgYWxsb3dGdWxsU2NyZWVuXG4gICAgICAgIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxFbWJlZEJ5bGluZSB0eXBlPVwidmlkZW9cIiBjb3B5cmlnaHQ9e2RhdGEuY29weXJpZ2h0IX0gZGVzY3JpcHRpb249e3BhcnNlZERlc2NyaXB0aW9ufSBib3R0b21Sb3VuZGVkPlxuICAgICAgICB7ISFsaW5rZWRWaWRlb0lkICYmIChcbiAgICAgICAgICA8TGlua2VkVmlkZW9CdXR0b25cbiAgICAgICAgICAgIHZhcmlhbnQ9XCJvdXRsaW5lXCJcbiAgICAgICAgICAgIHNoYXBlPVwicGlsbFwiXG4gICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgb25DbGljaz17KCkgPT4gc2V0U2hvd09yaWdpbmFsVmlkZW8oKHApID0+ICFwKX1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7dChgZmlndXJlLmJ1dHRvbi4keyFzaG93T3JpZ2luYWxWaWRlbyA/ICdvcmlnaW5hbCcgOiAnYWx0ZXJuYXRpdmUnfWApfVxuICAgICAgICAgIDwvTGlua2VkVmlkZW9CdXR0b24+XG4gICAgICAgICl9XG4gICAgICAgIHtIZWFydEJ1dHRvbiAmJiBkYXRhLmNvcHlyaWdodD8ubGljZW5zZS5saWNlbnNlLnRvTG93ZXJDYXNlKCkgIT09IENPUFlSSUdIVEVEICYmIDxIZWFydEJ1dHRvbiBlbWJlZD17ZW1iZWR9IC8+fVxuICAgICAgPC9FbWJlZEJ5bGluZT5cbiAgICA8L0ZpZ3VyZT5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEJyaWdodGNvdmVFbWJlZDtcbiJdfQ== */",
53
53
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
54
54
  });
55
55
  var makeIframeString = function makeIframeString(url, width, height) {
@@ -85,7 +85,9 @@ var BrightcoveEmbed = function BrightcoveEmbed(_ref) {
85
85
  var _data$link, _data$link2, _ref3, _embedData$alt3, _ref4, _embedData$alt4, _data$copyright;
86
86
  var embed = _ref.embed,
87
87
  isConcept = _ref.isConcept,
88
- HeartButton = _ref.heartButton;
88
+ HeartButton = _ref.heartButton,
89
+ _ref$renderContext = _ref.renderContext,
90
+ renderContext = _ref$renderContext === void 0 ? 'article' : _ref$renderContext;
89
91
  var _useState = (0, _react.useState)(true),
90
92
  _useState2 = _slicedToArray(_useState, 2),
91
93
  showOriginalVideo = _useState2[0],
@@ -96,12 +98,12 @@ var BrightcoveEmbed = function BrightcoveEmbed(_ref) {
96
98
  var embedData = embed.embedData;
97
99
  var fallbackTitle = "".concat(t('embed.type.video'), ": ").concat(embedData.videoid);
98
100
  var parsedDescription = (0, _react.useMemo)(function () {
99
- if (embed.embedData.caption) {
100
- return (0, _htmlReactParser.default)(embed.embedData.caption);
101
+ if (embed.embedData.caption || renderContext === 'article') {
102
+ return embed.embedData.caption ? (0, _htmlReactParser.default)(embed.embedData.caption) : undefined;
101
103
  } else if (embed.status === 'success' && embed.data.description) {
102
104
  return (0, _htmlReactParser.default)(embed.data.description);
103
105
  }
104
- }, [embed]);
106
+ }, [embed, renderContext]);
105
107
  (0, _react.useEffect)(function () {
106
108
  var iframe = iframeRef.current;
107
109
  if (iframe) {
@@ -6,7 +6,7 @@
6
6
  *
7
7
  */
8
8
  import { ImageEmbedData, ImageMetaData } from '@ndla/types-embed';
9
- import { HeartButtonType } from './types';
9
+ import { HeartButtonType, RenderContext } from './types';
10
10
  interface Props {
11
11
  embed: ImageMetaData;
12
12
  previewAlt?: boolean;
@@ -14,6 +14,7 @@ interface Props {
14
14
  heartButton?: HeartButtonType;
15
15
  inGrid?: boolean;
16
16
  lang?: string;
17
+ renderContext?: RenderContext;
17
18
  }
18
19
  export interface Author {
19
20
  name: string;
@@ -39,5 +40,5 @@ export declare const getCrop: (data: ImageEmbedData) => {
39
40
  endX: number;
40
41
  endY: number;
41
42
  } | undefined;
42
- declare const ImageEmbed: ({ embed, previewAlt, heartButton: HeartButton, inGrid, path, lang }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
43
+ declare const ImageEmbed: ({ embed, previewAlt, heartButton: HeartButton, inGrid, path, lang, renderContext, }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
43
44
  export default ImageEmbed;
@@ -111,7 +111,9 @@ var ImageEmbed = function ImageEmbed(_ref) {
111
111
  HeartButton = _ref.heartButton,
112
112
  inGrid = _ref.inGrid,
113
113
  path = _ref.path,
114
- lang = _ref.lang;
114
+ lang = _ref.lang,
115
+ _ref$renderContext = _ref.renderContext,
116
+ renderContext = _ref$renderContext === void 0 ? 'article' : _ref$renderContext;
115
117
  var _useState = (0, _react.useState)(hideByline(embed.embedData.size)),
116
118
  _useState2 = _slicedToArray(_useState, 2),
117
119
  isBylineHidden = _useState2[0],
@@ -121,12 +123,12 @@ var ImageEmbed = function ImageEmbed(_ref) {
121
123
  imageSizes = _useState4[0],
122
124
  setImageSizes = _useState4[1];
123
125
  var parsedDescription = (0, _react.useMemo)(function () {
124
- if (embed.embedData.caption) {
125
- return (0, _htmlReactParser.default)(embed.embedData.caption);
126
+ if (embed.embedData.caption || renderContext === 'article') {
127
+ return embed.embedData.caption ? (0, _htmlReactParser.default)(embed.embedData.caption) : undefined;
126
128
  } else if (embed.status === 'success' && embed.data.caption.caption) {
127
129
  return (0, _htmlReactParser.default)(embed.data.caption.caption);
128
130
  }
129
- }, [embed]);
131
+ }, [embed, renderContext]);
130
132
  if (embed.status === 'error') {
131
133
  var _embed$embedData = embed.embedData,
132
134
  align = _embed$embedData.align,
@@ -194,7 +196,7 @@ var ImageEmbed = function ImageEmbed(_ref) {
194
196
  var HiddenSpan = /*#__PURE__*/(0, _base.default)("span", {
195
197
  target: "ened8ka0",
196
198
  label: "HiddenSpan"
197
- })(_core.utils.visuallyHidden, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageEmbed.tsx"],"names":[],"mappings":"AAwL8B","file":"ImageEmbed.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ImageEmbedData, ImageMetaData } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { MouseEventHandler, useMemo, useState } from 'react';\nimport parse from 'html-react-parser';\nimport { ExpandTwoArrows } from '@ndla/icons/action';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { ArrowCollapse, ChevronDown, ChevronUp } from '@ndla/icons/common';\nimport { utils } from '@ndla/core';\nimport styled from '@emotion/styled';\nimport { Figure, FigureType } from '../Figure';\nimport Image, { ImageLink } from '../Image';\nimport { EmbedByline } from '../LicenseByline';\nimport EmbedErrorPlaceholder from './EmbedErrorPlaceholder';\nimport { HeartButtonType } from './types';\n\ninterface Props {\n  embed: ImageMetaData;\n  previewAlt?: boolean;\n  path?: string;\n  heartButton?: HeartButtonType;\n  inGrid?: boolean;\n  lang?: string;\n}\n\nexport interface Author {\n  name: string;\n  type: string;\n}\n\nexport const getLicenseCredits = (copyright?: {\n  creators?: Author[];\n  rightsholders?: Author[];\n  processors?: Author[];\n}) => {\n  return {\n    creators: copyright?.creators ?? [],\n    rightsholders: copyright?.rightsholders ?? [],\n    processors: copyright?.processors ?? [],\n  };\n};\n\nexport const errorSvgSrc = `data:image/svg+xml;charset=UTF-8,%3Csvg fill='%238A8888' height='400' viewBox='0 0 24 12' width='100%25' xmlns='http://www.w3.org/2000/svg' style='background-color: %23EFF0F2'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath transform='scale(0.3) translate(28, 8.5)' d='M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z'/%3E%3C/svg%3E`;\nconst isSmall = (size?: string): size is 'xsmall' | 'small' => size === 'xsmall' || size === 'small';\n\nconst isAlign = (align?: string): align is 'left' | 'right' => align === 'left' || align === 'right';\n\nconst getFigureType = (size?: string, align?: string): FigureType => {\n  if (size && isSmall(size) && align && isAlign(align)) {\n    return `${size}-${align}`;\n  }\n  if (size && isSmall(size) && !align) {\n    return size as FigureType;\n  }\n  if (align && isAlign(align)) {\n    return align;\n  }\n  return 'full';\n};\n\nconst getSizes = (size?: string, align?: string) => {\n  if (align && size === 'full') {\n    return '(min-width: 1024px) 512px, (min-width: 768px) 350px, 100vw';\n  }\n  if (align && size === 'small') {\n    return '(min-width: 1024px) 350px, (min-width: 768px) 180px, 100vw';\n  }\n  if (align && size === 'xsmall') {\n    return '(min-width: 1024px) 180px, (min-width: 768px) 180px, 100vw';\n  }\n  return '(min-width: 1024px) 1024px, 100vw';\n};\n\nexport const getFocalPoint = (data: ImageEmbedData) => {\n  const focalX = parseFloat(data.focalX ?? '');\n  const focalY = parseFloat(data.focalY ?? '');\n  if (!!focalX && !!focalY) {\n    return { x: focalX, y: focalY };\n  }\n  return undefined;\n};\n\nexport const getCrop = (data: ImageEmbedData) => {\n  const lowerRightX = parseFloat(data.lowerRightX ?? '');\n  const lowerRightY = parseFloat(data.lowerRightY ?? '');\n  const upperLeftX = parseFloat(data.upperLeftX ?? '');\n  const upperLeftY = parseFloat(data.upperLeftY ?? '');\n  if (!!lowerRightX && !!lowerRightY && !!upperLeftX && !!upperLeftY) {\n    return {\n      startX: lowerRightX,\n      startY: lowerRightY,\n      endX: upperLeftX,\n      endY: upperLeftY,\n    };\n  }\n  return undefined;\n};\n\nconst expandedSizes = '(min-width: 1024px) 1024px, 100vw';\n\nconst ImageEmbed = ({ embed, previewAlt, heartButton: HeartButton, inGrid, path, lang }: Props) => {\n  const [isBylineHidden, setIsBylineHidden] = useState(hideByline(embed.embedData.size));\n  const [imageSizes, setImageSizes] = useState<string | undefined>(undefined);\n\n  const parsedDescription = useMemo(() => {\n    if (embed.embedData.caption) {\n      return parse(embed.embedData.caption);\n    } else if (embed.status === 'success' && embed.data.caption.caption) {\n      return parse(embed.data.caption.caption);\n    }\n  }, [embed]);\n\n  if (embed.status === 'error') {\n    const { align, size } = embed.embedData;\n    const figureType = getFigureType(size, align);\n    return <EmbedErrorPlaceholder type={'image'} figureType={figureType} />;\n  }\n\n  const { data, embedData } = embed;\n\n  const altText = embedData.alt || '';\n\n  const figureType = getFigureType(embedData.size, embedData.align);\n  const sizes = getSizes(embedData.size, embedData.align);\n\n  const focalPoint = getFocalPoint(embedData);\n  const crop = getCrop(embedData);\n\n  const isCopyrighted = data.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <Figure\n      type={imageSizes ? undefined : figureType}\n      className={imageSizes ? `c-figure--${embedData.align} expanded` : ''}\n    >\n      <ImageWrapper\n        src={!isCopyrighted ? embedData.pageUrl || data.image.imageUrl : undefined}\n        crop={crop}\n        size={embedData.size}\n        pagePath={path}\n      >\n        <Image\n          focalPoint={focalPoint}\n          contentType={data.image.contentType}\n          crop={crop}\n          sizes={imageSizes ?? sizes}\n          alt={altText}\n          src={data.image.imageUrl}\n          border={embedData.border}\n          expandButton={\n            <ExpandButton\n              size={embedData.size}\n              expanded={!!imageSizes}\n              bylineHidden={isBylineHidden}\n              onExpand={() => setImageSizes((p) => (p ? undefined : expandedSizes))}\n              onHideByline={() => setIsBylineHidden((p) => !p)}\n            />\n          }\n          lang={lang}\n        />\n      </ImageWrapper>\n      {isBylineHidden || (isSmall(embedData.size) && !imageSizes) ? null : (\n        <EmbedByline\n          type=\"image\"\n          copyright={data.copyright}\n          description={parsedDescription}\n          bottomRounded\n          visibleAlt={previewAlt ? embed.embedData.alt : ''}\n          inGrid={inGrid}\n        >\n          {HeartButton && !isCopyrighted && <HeartButton embed={embed} />}\n        </EmbedByline>\n      )}\n    </Figure>\n  );\n};\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ninterface ImageWrapperProps {\n  src?: string;\n  children: React.ReactNode;\n  pagePath?: string;\n  crop?: {\n    startX: number;\n    startY: number;\n    endX: number;\n    endY: number;\n  };\n  size?: string;\n}\nconst hideByline = (size?: string): boolean => {\n  return !!size && size.endsWith('-hide-byline');\n};\n\nconst ImageWrapper = ({ src, crop, size, children, pagePath }: ImageWrapperProps) => {\n  const { t } = useTranslation();\n  if (isSmall(size) || hideByline(size) || !src || (pagePath && src.endsWith(pagePath))) {\n    return <>{children}</>;\n  }\n\n  return (\n    <ImageLink src={src} crop={crop}>\n      {children}\n      <HiddenSpan>{t('license.images.itemImage.ariaLabel')}</HiddenSpan>\n    </ImageLink>\n  );\n};\n\ninterface ExpandButtonProps {\n  size?: string;\n  expanded: boolean;\n  bylineHidden: boolean;\n  onExpand: MouseEventHandler<HTMLButtonElement>;\n  onHideByline: MouseEventHandler<HTMLButtonElement>;\n}\n\nconst ExpandButton = ({ size, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isSmall(size)) {\n    return (\n      <button\n        type=\"button\"\n        className=\"c-figure__fullscreen-btn\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? 'Out' : ''}ImageButtonLabel`)}\n        onClick={onExpand}\n      >\n        {expanded ? <ArrowCollapse /> : <ExpandTwoArrows />}\n      </button>\n    );\n  } else if (hideByline(size)) {\n    return (\n      <button\n        type=\"button\"\n        className=\"c-figure__show-byline-btn\"\n        aria-label={t(`license.images.itemImage.${bylineHidden ? 'expandByline' : 'minimizeByline'}`)}\n        onClick={onHideByline}\n      >\n        {bylineHidden ? <ChevronDown /> : <ChevronUp />}\n      </button>\n    );\n  } else return null;\n};\n\nexport default ImageEmbed;\n"]} */"));
199
+ })(_core.utils.visuallyHidden, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageEmbed.tsx"],"names":[],"mappings":"AAiM8B","file":"ImageEmbed.tsx","sourcesContent":["/**\n * Copyright (c) 2023-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { ImageEmbedData, ImageMetaData } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { MouseEventHandler, useMemo, useState } from 'react';\nimport parse from 'html-react-parser';\nimport { ExpandTwoArrows } from '@ndla/icons/action';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { ArrowCollapse, ChevronDown, ChevronUp } from '@ndla/icons/common';\nimport { utils } from '@ndla/core';\nimport styled from '@emotion/styled';\nimport { Figure, FigureType } from '../Figure';\nimport Image, { ImageLink } from '../Image';\nimport { EmbedByline } from '../LicenseByline';\nimport EmbedErrorPlaceholder from './EmbedErrorPlaceholder';\nimport { HeartButtonType, RenderContext } from './types';\n\ninterface Props {\n  embed: ImageMetaData;\n  previewAlt?: boolean;\n  path?: string;\n  heartButton?: HeartButtonType;\n  inGrid?: boolean;\n  lang?: string;\n  renderContext?: RenderContext;\n}\n\nexport interface Author {\n  name: string;\n  type: string;\n}\n\nexport const getLicenseCredits = (copyright?: {\n  creators?: Author[];\n  rightsholders?: Author[];\n  processors?: Author[];\n}) => {\n  return {\n    creators: copyright?.creators ?? [],\n    rightsholders: copyright?.rightsholders ?? [],\n    processors: copyright?.processors ?? [],\n  };\n};\n\nexport const errorSvgSrc = `data:image/svg+xml;charset=UTF-8,%3Csvg fill='%238A8888' height='400' viewBox='0 0 24 12' width='100%25' xmlns='http://www.w3.org/2000/svg' style='background-color: %23EFF0F2'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath transform='scale(0.3) translate(28, 8.5)' d='M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z'/%3E%3C/svg%3E`;\nconst isSmall = (size?: string): size is 'xsmall' | 'small' => size === 'xsmall' || size === 'small';\n\nconst isAlign = (align?: string): align is 'left' | 'right' => align === 'left' || align === 'right';\n\nconst getFigureType = (size?: string, align?: string): FigureType => {\n  if (size && isSmall(size) && align && isAlign(align)) {\n    return `${size}-${align}`;\n  }\n  if (size && isSmall(size) && !align) {\n    return size as FigureType;\n  }\n  if (align && isAlign(align)) {\n    return align;\n  }\n  return 'full';\n};\n\nconst getSizes = (size?: string, align?: string) => {\n  if (align && size === 'full') {\n    return '(min-width: 1024px) 512px, (min-width: 768px) 350px, 100vw';\n  }\n  if (align && size === 'small') {\n    return '(min-width: 1024px) 350px, (min-width: 768px) 180px, 100vw';\n  }\n  if (align && size === 'xsmall') {\n    return '(min-width: 1024px) 180px, (min-width: 768px) 180px, 100vw';\n  }\n  return '(min-width: 1024px) 1024px, 100vw';\n};\n\nexport const getFocalPoint = (data: ImageEmbedData) => {\n  const focalX = parseFloat(data.focalX ?? '');\n  const focalY = parseFloat(data.focalY ?? '');\n  if (!!focalX && !!focalY) {\n    return { x: focalX, y: focalY };\n  }\n  return undefined;\n};\n\nexport const getCrop = (data: ImageEmbedData) => {\n  const lowerRightX = parseFloat(data.lowerRightX ?? '');\n  const lowerRightY = parseFloat(data.lowerRightY ?? '');\n  const upperLeftX = parseFloat(data.upperLeftX ?? '');\n  const upperLeftY = parseFloat(data.upperLeftY ?? '');\n  if (!!lowerRightX && !!lowerRightY && !!upperLeftX && !!upperLeftY) {\n    return {\n      startX: lowerRightX,\n      startY: lowerRightY,\n      endX: upperLeftX,\n      endY: upperLeftY,\n    };\n  }\n  return undefined;\n};\n\nconst expandedSizes = '(min-width: 1024px) 1024px, 100vw';\n\nconst ImageEmbed = ({\n  embed,\n  previewAlt,\n  heartButton: HeartButton,\n  inGrid,\n  path,\n  lang,\n  renderContext = 'article',\n}: Props) => {\n  const [isBylineHidden, setIsBylineHidden] = useState(hideByline(embed.embedData.size));\n  const [imageSizes, setImageSizes] = useState<string | undefined>(undefined);\n\n  const parsedDescription = useMemo(() => {\n    if (embed.embedData.caption || renderContext === 'article') {\n      return embed.embedData.caption ? parse(embed.embedData.caption) : undefined;\n    } else if (embed.status === 'success' && embed.data.caption.caption) {\n      return parse(embed.data.caption.caption);\n    }\n  }, [embed, renderContext]);\n\n  if (embed.status === 'error') {\n    const { align, size } = embed.embedData;\n    const figureType = getFigureType(size, align);\n    return <EmbedErrorPlaceholder type={'image'} figureType={figureType} />;\n  }\n\n  const { data, embedData } = embed;\n\n  const altText = embedData.alt || '';\n\n  const figureType = getFigureType(embedData.size, embedData.align);\n  const sizes = getSizes(embedData.size, embedData.align);\n\n  const focalPoint = getFocalPoint(embedData);\n  const crop = getCrop(embedData);\n\n  const isCopyrighted = data.copyright.license.license.toLowerCase() === COPYRIGHTED;\n\n  return (\n    <Figure\n      type={imageSizes ? undefined : figureType}\n      className={imageSizes ? `c-figure--${embedData.align} expanded` : ''}\n    >\n      <ImageWrapper\n        src={!isCopyrighted ? embedData.pageUrl || data.image.imageUrl : undefined}\n        crop={crop}\n        size={embedData.size}\n        pagePath={path}\n      >\n        <Image\n          focalPoint={focalPoint}\n          contentType={data.image.contentType}\n          crop={crop}\n          sizes={imageSizes ?? sizes}\n          alt={altText}\n          src={data.image.imageUrl}\n          border={embedData.border}\n          expandButton={\n            <ExpandButton\n              size={embedData.size}\n              expanded={!!imageSizes}\n              bylineHidden={isBylineHidden}\n              onExpand={() => setImageSizes((p) => (p ? undefined : expandedSizes))}\n              onHideByline={() => setIsBylineHidden((p) => !p)}\n            />\n          }\n          lang={lang}\n        />\n      </ImageWrapper>\n      {isBylineHidden || (isSmall(embedData.size) && !imageSizes) ? null : (\n        <EmbedByline\n          type=\"image\"\n          copyright={data.copyright}\n          description={parsedDescription}\n          bottomRounded\n          visibleAlt={previewAlt ? embed.embedData.alt : ''}\n          inGrid={inGrid}\n        >\n          {HeartButton && !isCopyrighted && <HeartButton embed={embed} />}\n        </EmbedByline>\n      )}\n    </Figure>\n  );\n};\n\nconst HiddenSpan = styled.span`\n  ${utils.visuallyHidden};\n`;\n\ninterface ImageWrapperProps {\n  src?: string;\n  children: React.ReactNode;\n  pagePath?: string;\n  crop?: {\n    startX: number;\n    startY: number;\n    endX: number;\n    endY: number;\n  };\n  size?: string;\n}\nconst hideByline = (size?: string): boolean => {\n  return !!size && size.endsWith('-hide-byline');\n};\n\nconst ImageWrapper = ({ src, crop, size, children, pagePath }: ImageWrapperProps) => {\n  const { t } = useTranslation();\n  if (isSmall(size) || hideByline(size) || !src || (pagePath && src.endsWith(pagePath))) {\n    return <>{children}</>;\n  }\n\n  return (\n    <ImageLink src={src} crop={crop}>\n      {children}\n      <HiddenSpan>{t('license.images.itemImage.ariaLabel')}</HiddenSpan>\n    </ImageLink>\n  );\n};\n\ninterface ExpandButtonProps {\n  size?: string;\n  expanded: boolean;\n  bylineHidden: boolean;\n  onExpand: MouseEventHandler<HTMLButtonElement>;\n  onHideByline: MouseEventHandler<HTMLButtonElement>;\n}\n\nconst ExpandButton = ({ size, expanded, bylineHidden, onExpand, onHideByline }: ExpandButtonProps) => {\n  const { t } = useTranslation();\n  if (isSmall(size)) {\n    return (\n      <button\n        type=\"button\"\n        className=\"c-figure__fullscreen-btn\"\n        aria-label={t(`license.images.itemImage.zoom${expanded ? 'Out' : ''}ImageButtonLabel`)}\n        onClick={onExpand}\n      >\n        {expanded ? <ArrowCollapse /> : <ExpandTwoArrows />}\n      </button>\n    );\n  } else if (hideByline(size)) {\n    return (\n      <button\n        type=\"button\"\n        className=\"c-figure__show-byline-btn\"\n        aria-label={t(`license.images.itemImage.${bylineHidden ? 'expandByline' : 'minimizeByline'}`)}\n        onClick={onHideByline}\n      >\n        {bylineHidden ? <ChevronDown /> : <ChevronUp />}\n      </button>\n    );\n  } else return null;\n};\n\nexport default ImageEmbed;\n"]} */"));
198
200
  var hideByline = function hideByline(size) {
199
201
  return !!size && size.endsWith('-hide-byline');
200
202
  };
@@ -19,4 +19,4 @@ export { ConceptNotionV2 } from './conceptComponents';
19
19
  export { default as ConceptListEmbed } from './ConceptListEmbed';
20
20
  export { default as UnknownEmbed } from './UnknownEmbed';
21
21
  export { InlineConcept, BlockConcept } from './ConceptEmbed';
22
- export type { HeartButtonType } from './types';
22
+ export type { HeartButtonType, RenderContext } from './types';
@@ -12,3 +12,4 @@ export type HeartButtonType = ElementType<{
12
12
  status: 'success';
13
13
  }>;
14
14
  }>;
15
+ export type RenderContext = 'article' | 'embed';
package/lib/index.d.ts CHANGED
@@ -84,7 +84,7 @@ export { BlogPostV2 } from './BlogPost';
84
84
  export { ProgrammeCard } from './ProgrammeCard';
85
85
  export { KeyFigure } from './KeyFigure';
86
86
  export { default as ContactBlock } from './ContactBlock';
87
- export type { HeartButtonType } from './Embed';
87
+ export type { HeartButtonType, RenderContext } from './Embed';
88
88
  export { CampaignBlock } from './CampaignBlock';
89
89
  export { Grid, GridParallaxItem } from './Grid';
90
90
  export type { GridType } from './Grid';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ndla/ui",
3
- "version": "49.0.0",
3
+ "version": "49.0.1",
4
4
  "description": "UI component library for NDLA.",
5
5
  "license": "GPL-3.0",
6
6
  "main": "lib/index.js",
@@ -31,23 +31,23 @@
31
31
  "types"
32
32
  ],
33
33
  "dependencies": {
34
- "@ndla/accordion": "^3.0.1",
35
- "@ndla/button": "^12.0.7",
36
- "@ndla/carousel": "^4.0.9",
37
- "@ndla/core": "^4.2.3",
38
- "@ndla/dropdown-menu": "^1.0.12",
39
- "@ndla/forms": "^5.0.9",
34
+ "@ndla/accordion": "^3.0.2",
35
+ "@ndla/button": "^12.0.8",
36
+ "@ndla/carousel": "^4.0.10",
37
+ "@ndla/core": "^4.2.4",
38
+ "@ndla/dropdown-menu": "^1.0.13",
39
+ "@ndla/forms": "^5.0.10",
40
40
  "@ndla/hooks": "^2.1.1",
41
- "@ndla/icons": "^4.1.4",
41
+ "@ndla/icons": "^4.1.5",
42
42
  "@ndla/licenses": "^7.2.2",
43
- "@ndla/modal": "^5.0.6",
44
- "@ndla/notion": "^6.0.9",
45
- "@ndla/safelink": "^4.1.32",
46
- "@ndla/select": "^3.1.4",
47
- "@ndla/switch": "^1.1.18",
48
- "@ndla/tabs": "^3.1.3",
49
- "@ndla/tooltip": "^6.0.0",
50
- "@ndla/typography": "^0.2.5",
43
+ "@ndla/modal": "^5.0.7",
44
+ "@ndla/notion": "^6.0.10",
45
+ "@ndla/safelink": "^4.1.33",
46
+ "@ndla/select": "^3.1.5",
47
+ "@ndla/switch": "^1.1.19",
48
+ "@ndla/tabs": "^3.1.4",
49
+ "@ndla/tooltip": "^6.0.1",
50
+ "@ndla/typography": "^0.2.6",
51
51
  "@ndla/util": "^4.0.0",
52
52
  "@radix-ui/react-popover": "^1.0.7",
53
53
  "@radix-ui/react-radio-group": "^1.1.3",
@@ -80,5 +80,5 @@
80
80
  "publishConfig": {
81
81
  "access": "public"
82
82
  },
83
- "gitHead": "654c24de8eb48a35d6f3127c3f373091d7350de0"
83
+ "gitHead": "613a1b7bd697142fdcee7cca42c743f4c2431a40"
84
84
  }
@@ -6,15 +6,17 @@
6
6
  *
7
7
  */
8
8
 
9
+ import { useTranslation } from 'react-i18next';
10
+ import concat from 'lodash/concat';
9
11
  import { css } from '@emotion/react';
10
12
  import styled from '@emotion/styled';
11
13
  import { IImageMetaInformationV3 } from '@ndla/types-backend/image-api';
12
14
  import { spacing, fonts, colors, mq, breakpoints, misc } from '@ndla/core';
13
15
  import { BlobPointy, BlobRound } from '@ndla/icons/common';
14
- import { useTranslation } from 'react-i18next';
15
- import concat from 'lodash/concat';
16
+ import { getLicenseByAbbreviation } from '@ndla/licenses';
16
17
  import { errorSvgSrc } from '../Embed/ImageEmbed';
17
18
  import Image from '../Image';
19
+ import LicenseLink from '../LicenseByline/LicenseLink';
18
20
 
19
21
  const BLOB_WIDTH = 90;
20
22
 
@@ -137,10 +139,13 @@ const ContactBlock = ({
137
139
  blob = 'pointy',
138
140
  lang,
139
141
  }: Props) => {
140
- const { t } = useTranslation();
142
+ const { t, i18n } = useTranslation();
141
143
  const isGreenBlob = blobColor === 'green';
142
144
  const Blob = blob === 'pointy' ? BlobPointy : BlobRound;
143
145
  const authors = concat(image?.copyright.processors, image?.copyright.creators, image?.copyright.rightsholders);
146
+ const license = image?.copyright
147
+ ? getLicenseByAbbreviation(image.copyright.license.license, i18n.language)
148
+ : undefined;
144
149
 
145
150
  return (
146
151
  <BlockWrapper>
@@ -152,9 +157,10 @@ const ContactBlock = ({
152
157
  src={image.image.imageUrl}
153
158
  sizes={`(min-width: ${breakpoints.tablet}) 240px, (max-width: ${breakpoints.tablet}) 500px`}
154
159
  />
155
- {`${t('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} ${
156
- image.copyright.license.license
157
- }`}
160
+ <span>
161
+ {`${t('photo')}: ${authors.reduce((acc, name) => (acc = `${acc} ${name?.name}`), '')} `}
162
+ {!!license && <LicenseLink license={license} asLink={!!license.url.length} />}
163
+ </span>
158
164
  </>
159
165
  ) : (
160
166
  <img alt={t('image.error.url')} src={errorSvgSrc} />
@@ -18,12 +18,13 @@ import { ButtonV2 } from '@ndla/button';
18
18
  import { Figure } from '../Figure';
19
19
  import { EmbedByline } from '../LicenseByline';
20
20
  import EmbedErrorPlaceholder from './EmbedErrorPlaceholder';
21
- import { HeartButtonType } from './types';
21
+ import { HeartButtonType, RenderContext } from './types';
22
22
 
23
23
  interface Props {
24
24
  embed: BrightcoveMetaData;
25
25
  isConcept?: boolean;
26
26
  heartButton?: HeartButtonType;
27
+ renderContext?: RenderContext;
27
28
  }
28
29
 
29
30
  const LinkedVideoButton = styled(ButtonV2)`
@@ -57,19 +58,19 @@ const getIframeProps = (data: BrightcoveEmbedData, sources: BrightcoveVideoSourc
57
58
  width: source?.width ?? '640',
58
59
  };
59
60
  };
60
- const BrightcoveEmbed = ({ embed, isConcept, heartButton: HeartButton }: Props) => {
61
+ const BrightcoveEmbed = ({ embed, isConcept, heartButton: HeartButton, renderContext = 'article' }: Props) => {
61
62
  const [showOriginalVideo, setShowOriginalVideo] = useState(true);
62
63
  const { t } = useTranslation();
63
64
  const iframeRef = useRef<HTMLIFrameElement>(null);
64
65
  const { embedData } = embed;
65
66
  const fallbackTitle = `${t('embed.type.video')}: ${embedData.videoid}`;
66
67
  const parsedDescription = useMemo(() => {
67
- if (embed.embedData.caption) {
68
- return parse(embed.embedData.caption);
68
+ if (embed.embedData.caption || renderContext === 'article') {
69
+ return embed.embedData.caption ? parse(embed.embedData.caption) : undefined;
69
70
  } else if (embed.status === 'success' && embed.data.description) {
70
71
  return parse(embed.data.description);
71
72
  }
72
- }, [embed]);
73
+ }, [embed, renderContext]);
73
74
 
74
75
  useEffect(() => {
75
76
  const iframe = iframeRef.current;
@@ -19,7 +19,7 @@ import { Figure, FigureType } from '../Figure';
19
19
  import Image, { ImageLink } from '../Image';
20
20
  import { EmbedByline } from '../LicenseByline';
21
21
  import EmbedErrorPlaceholder from './EmbedErrorPlaceholder';
22
- import { HeartButtonType } from './types';
22
+ import { HeartButtonType, RenderContext } from './types';
23
23
 
24
24
  interface Props {
25
25
  embed: ImageMetaData;
@@ -28,6 +28,7 @@ interface Props {
28
28
  heartButton?: HeartButtonType;
29
29
  inGrid?: boolean;
30
30
  lang?: string;
31
+ renderContext?: RenderContext;
31
32
  }
32
33
 
33
34
  export interface Author {
@@ -105,17 +106,25 @@ export const getCrop = (data: ImageEmbedData) => {
105
106
 
106
107
  const expandedSizes = '(min-width: 1024px) 1024px, 100vw';
107
108
 
108
- const ImageEmbed = ({ embed, previewAlt, heartButton: HeartButton, inGrid, path, lang }: Props) => {
109
+ const ImageEmbed = ({
110
+ embed,
111
+ previewAlt,
112
+ heartButton: HeartButton,
113
+ inGrid,
114
+ path,
115
+ lang,
116
+ renderContext = 'article',
117
+ }: Props) => {
109
118
  const [isBylineHidden, setIsBylineHidden] = useState(hideByline(embed.embedData.size));
110
119
  const [imageSizes, setImageSizes] = useState<string | undefined>(undefined);
111
120
 
112
121
  const parsedDescription = useMemo(() => {
113
- if (embed.embedData.caption) {
114
- return parse(embed.embedData.caption);
122
+ if (embed.embedData.caption || renderContext === 'article') {
123
+ return embed.embedData.caption ? parse(embed.embedData.caption) : undefined;
115
124
  } else if (embed.status === 'success' && embed.data.caption.caption) {
116
125
  return parse(embed.data.caption.caption);
117
126
  }
118
- }, [embed]);
127
+ }, [embed, renderContext]);
119
128
 
120
129
  if (embed.status === 'error') {
121
130
  const { align, size } = embed.embedData;
@@ -20,4 +20,4 @@ export { ConceptNotionV2 } from './conceptComponents';
20
20
  export { default as ConceptListEmbed } from './ConceptListEmbed';
21
21
  export { default as UnknownEmbed } from './UnknownEmbed';
22
22
  export { InlineConcept, BlockConcept } from './ConceptEmbed';
23
- export type { HeartButtonType } from './types';
23
+ export type { HeartButtonType, RenderContext } from './types';
@@ -10,3 +10,5 @@ import { ElementType } from 'react';
10
10
  import { EmbedMetaData } from '@ndla/types-embed';
11
11
 
12
12
  export type HeartButtonType = ElementType<{ embed: Extract<EmbedMetaData, { status: 'success' }> }>;
13
+
14
+ export type RenderContext = 'article' | 'embed';
package/src/index.ts CHANGED
@@ -213,7 +213,7 @@ export { BlogPostV2 } from './BlogPost';
213
213
  export { ProgrammeCard } from './ProgrammeCard';
214
214
  export { KeyFigure } from './KeyFigure';
215
215
  export { default as ContactBlock } from './ContactBlock';
216
- export type { HeartButtonType } from './Embed';
216
+ export type { HeartButtonType, RenderContext } from './Embed';
217
217
  export { CampaignBlock } from './CampaignBlock';
218
218
  export { Grid, GridParallaxItem } from './Grid';
219
219
  export type { GridType } from './Grid';