@ndla/ui 30.8.2 → 30.8.3
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.
- package/es/CopyParagraphButton/CopyParagraphButton.js +18 -24
- package/es/Frontpage/FrontpageSearch.js +3 -2
- package/es/all.css +1 -1
- package/lib/CopyParagraphButton/CopyParagraphButton.js +18 -24
- package/lib/Frontpage/FrontpageSearch.js +3 -2
- package/lib/all.css +1 -1
- package/package.json +17 -17
- package/src/CopyParagraphButton/CopyParagraphButton.tsx +14 -10
- package/src/Frontpage/FrontpageSearch.tsx +1 -0
- package/src/TopicMenu/component.topic-menu.scss +16 -13
|
@@ -19,50 +19,44 @@ import { Link } from '@ndla/icons/common';
|
|
|
19
19
|
import { useTranslation } from 'react-i18next';
|
|
20
20
|
import Tooltip from '@ndla/tooltip';
|
|
21
21
|
import { copyTextToClipboard } from '@ndla/util';
|
|
22
|
+
import { colors } from '@ndla/core';
|
|
22
23
|
import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
23
24
|
import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
24
|
-
var IconButton = /*#__PURE__*/_styled("button", {
|
|
25
|
-
target: "e18czas71",
|
|
26
|
-
label: "IconButton"
|
|
27
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
28
|
-
name: "3epkb7",
|
|
29
|
-
styles: "position:absolute;left:-3em;top:0.1em;background:none;border:0;z-index:1;transition:0.2s;opacity:0;& svg{width:30px;height:30px;}"
|
|
30
|
-
} : {
|
|
31
|
-
name: "3epkb7",
|
|
32
|
-
styles: "position:absolute;left:-3em;top:0.1em;background:none;border:0;z-index:1;transition:0.2s;opacity:0;& svg{width:30px;height:30px;}",
|
|
33
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlQYXJhZ3JhcGhCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCZ0MiLCJmaWxlIjoiQ29weVBhcmFncmFwaEJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlLCBNb3VzZUV2ZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgVG9vbHRpcCBmcm9tICdAbmRsYS90b29sdGlwJztcbmltcG9ydCB7IGNvcHlUZXh0VG9DbGlwYm9hcmQgfSBmcm9tICdAbmRsYS91dGlsJztcblxuY29uc3QgSWNvbkJ1dHRvbiA9IHN0eWxlZC5idXR0b25gXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgbGVmdDogLTNlbTtcbiAgdG9wOiAwLjFlbTtcbiAgYmFja2dyb3VuZDogbm9uZTtcbiAgYm9yZGVyOiAwO1xuICB6LWluZGV4OiAxO1xuICB0cmFuc2l0aW9uOiAwLjJzO1xuICBvcGFjaXR5OiAwO1xuXG4gICYgc3ZnIHtcbiAgICB3aWR0aDogMzBweDtcbiAgICBoZWlnaHQ6IDMwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IENvbnRhaW5lckRpdiA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgJjpob3ZlciBidXR0b24ge1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICBvcGFjaXR5OiAwLjU7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIHRpdGxlPzogc3RyaW5nIHwgbnVsbDtcbiAgY29udGVudD86IHN0cmluZyB8IG51bGw7XG4gIGh5ZHJhdGU/OiBib29sZWFuO1xufVxuXG5pbnRlcmZhY2UgQ29weUJ1dHRvblByb3BzIHtcbiAgdGl0bGU6IHN0cmluZztcbiAgb25DbGljaz86IChlOiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PikgPT4gdm9pZDtcbiAgdG9vbHRpcDogc3RyaW5nO1xuICBjb250ZW50Pzogc3RyaW5nIHwgbnVsbDtcbn1cblxuY29uc3QgQ29weUJ1dHRvbiA9ICh7IG9uQ2xpY2ssIHRpdGxlLCB0b29sdGlwLCBjb250ZW50IH06IENvcHlCdXR0b25Qcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXY+XG4gICAgICA8SWNvbkJ1dHRvbiBvbkNsaWNrPXtvbkNsaWNrfSBkYXRhLXRpdGxlPXt0aXRsZX0+XG4gICAgICAgIDxUb29sdGlwIHRvb2x0aXA9e3Rvb2x0aXB9PlxuICAgICAgICAgIDxMaW5rIHRpdGxlPXsnJ30gLz5cbiAgICAgICAgPC9Ub29sdGlwPlxuICAgICAgPC9JY29uQnV0dG9uPlxuICAgICAgPGgyIGlkPXt0aXRsZX0gdGFiSW5kZXg9ezB9IGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7IF9faHRtbDogY29udGVudCB8fCAnJyB9fSAvPlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuY29uc3QgQ29weVBhcmFncmFwaEJ1dHRvbiA9ICh7IHRpdGxlLCBjb250ZW50LCBoeWRyYXRlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgW2hhc0NvcGllZCwgc2V0SGFzQ29waWVkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaGFzQ29waWVkKSB7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHNldEhhc0NvcGllZChmYWxzZSksIDMwMDApO1xuICAgIH1cbiAgfSwgW2hhc0NvcGllZF0pO1xuXG4gIGlmICghdGl0bGUpIHJldHVybiBudWxsO1xuXG4gIGNvbnN0IG9uQ29weUNsaWNrID0gKGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50Pik6IHZvaWQgPT4ge1xuICAgIHNldEhhc0NvcGllZCh0cnVlKTtcbiAgICBjb25zdCBjb3B5SWQgPSBldmVudC5jdXJyZW50VGFyZ2V0LmdldEF0dHJpYnV0ZSgnZGF0YS10aXRsZScpO1xuICAgIGNvbnN0IHsgbG9jYXRpb24gfSA9IHdpbmRvdztcbiAgICBjb25zdCBuZXdIYXNoID0gYCMke2NvcHlJZH1gO1xuICAgIGNvbnN0IHBvcnQgPSBsb2NhdGlvbi5wb3J0ID8gYDoke2xvY2F0aW9uLnBvcnR9YCA6ICcnO1xuICAgIGNvbnN0IHVybFRvQ29weSA9IGAke2xvY2F0aW9uLnByb3RvY29sfS8vJHtsb2NhdGlvbi5ob3N0bmFtZX0ke3BvcnR9JHtsb2NhdGlvbi5wYXRobmFtZX0ke2xvY2F0aW9uLnNlYXJjaH0ke25ld0hhc2h9YDtcblxuICAgIGNvcHlUZXh0VG9DbGlwYm9hcmQodXJsVG9Db3B5KTtcbiAgfTtcblxuICBjb25zdCBzYW5pdGl6ZWRUaXRsZSA9IGVuY29kZVVSSUNvbXBvbmVudCh0aXRsZS5yZXBsYWNlKC8gL2csICctJykpO1xuICBjb25zdCB0b29sdGlwID0gaGFzQ29waWVkID8gdCgnYXJ0aWNsZS5jb3B5UGFnZUxpbmtDb3BpZWQnKSA6IHQoJ2FydGljbGUuY29weUhlYWRlckxpbmsnKTtcblxuICBpZiAoaHlkcmF0ZSkge1xuICAgIHJldHVybiA8Q29weUJ1dHRvbiBvbkNsaWNrPXtvbkNvcHlDbGlja30gdGl0bGU9e3Nhbml0aXplZFRpdGxlfSB0b29sdGlwPXt0b29sdGlwfSBjb250ZW50PXtjb250ZW50fSAvPjtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPENvbnRhaW5lckRpdiBkYXRhLWhlYWRlci1jb3B5LWNvbnRhaW5lciBkYXRhLXRpdGxlPXt0aXRsZX0+XG4gICAgICA8Q29weUJ1dHRvbiBvbkNsaWNrPXtvbkNvcHlDbGlja30gdGl0bGU9e3Nhbml0aXplZFRpdGxlfSB0b29sdGlwPXt0b29sdGlwfSBjb250ZW50PXtjb250ZW50fSAvPlxuICAgIDwvQ29udGFpbmVyRGl2PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ29weVBhcmFncmFwaEJ1dHRvbjtcbiJdfQ== */",
|
|
34
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
35
|
-
});
|
|
36
25
|
var ContainerDiv = /*#__PURE__*/_styled("div", {
|
|
37
|
-
target: "
|
|
26
|
+
target: "e18czas71",
|
|
38
27
|
label: "ContainerDiv"
|
|
39
28
|
})(process.env.NODE_ENV === "production" ? {
|
|
40
|
-
name: "
|
|
41
|
-
styles: "position:relative
|
|
29
|
+
name: "bjn8wh",
|
|
30
|
+
styles: "position:relative"
|
|
42
31
|
} : {
|
|
43
|
-
name: "
|
|
44
|
-
styles: "position:relative
|
|
45
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
32
|
+
name: "bjn8wh",
|
|
33
|
+
styles: "position:relative",
|
|
34
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlQYXJhZ3JhcGhCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCK0IiLCJmaWxlIjoiQ29weVBhcmFncmFwaEJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlLCBNb3VzZUV2ZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgVG9vbHRpcCBmcm9tICdAbmRsYS90b29sdGlwJztcbmltcG9ydCB7IGNvcHlUZXh0VG9DbGlwYm9hcmQgfSBmcm9tICdAbmRsYS91dGlsJztcbmltcG9ydCB7IGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5jb25zdCBDb250YWluZXJEaXYgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5jb25zdCBJY29uQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBsZWZ0OiAtM2VtO1xuICB0b3A6IDAuMWVtO1xuICBiYWNrZ3JvdW5kOiBub25lO1xuICBib3JkZXI6IDA7XG4gIHotaW5kZXg6IDE7XG4gIHRyYW5zaXRpb246IDAuMnM7XG4gIG9wYWNpdHk6IDA7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcblxuICAmIHN2ZyB7XG4gICAgd2lkdGg6IDMwcHg7XG4gICAgaGVpZ2h0OiAzMHB4O1xuICB9XG5cbiAgJHtDb250YWluZXJEaXZ9OmhvdmVyICYsXG4gICY6Zm9jdXMsICY6Zm9jdXMtdmlzaWJsZSwgJjphY3RpdmUge1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICBvcGFjaXR5OiAxO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICB0aXRsZT86IHN0cmluZyB8IG51bGw7XG4gIGNvbnRlbnQ/OiBzdHJpbmcgfCBudWxsO1xuICBoeWRyYXRlPzogYm9vbGVhbjtcbn1cblxuaW50ZXJmYWNlIENvcHlCdXR0b25Qcm9wcyB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIG9uQ2xpY2s/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG4gIHRvb2x0aXA6IHN0cmluZztcbiAgY29udGVudD86IHN0cmluZyB8IG51bGw7XG59XG5cbmNvbnN0IENvcHlCdXR0b24gPSAoeyBvbkNsaWNrLCB0aXRsZSwgdG9vbHRpcCwgY29udGVudCB9OiBDb3B5QnV0dG9uUHJvcHMpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8ZGl2PlxuICAgICAgPFRvb2x0aXAgdG9vbHRpcD17dG9vbHRpcH0+XG4gICAgICAgIDxJY29uQnV0dG9uIG9uQ2xpY2s9e29uQ2xpY2t9IGRhdGEtdGl0bGU9e3RpdGxlfSBhcmlhLWxhYmVsPXtgJHt0b29sdGlwfTogJHt0aXRsZX1gfT5cbiAgICAgICAgICA8TGluayB0aXRsZT17Jyd9IC8+XG4gICAgICAgIDwvSWNvbkJ1dHRvbj5cbiAgICAgIDwvVG9vbHRpcD5cbiAgICAgIDxoMiBpZD17dGl0bGV9IHRhYkluZGV4PXstMX0gZGFuZ2Vyb3VzbHlTZXRJbm5lckhUTUw9e3sgX19odG1sOiBjb250ZW50IHx8ICcnIH19IC8+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5jb25zdCBDb3B5UGFyYWdyYXBoQnV0dG9uID0gKHsgdGl0bGUsIGNvbnRlbnQsIGh5ZHJhdGUgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBjb25zdCBbaGFzQ29waWVkLCBzZXRIYXNDb3BpZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChoYXNDb3BpZWQpIHtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4gc2V0SGFzQ29waWVkKGZhbHNlKSwgMzAwMCk7XG4gICAgfVxuICB9LCBbaGFzQ29waWVkXSk7XG5cbiAgaWYgKCF0aXRsZSkgcmV0dXJuIG51bGw7XG5cbiAgY29uc3Qgb25Db3B5Q2xpY2sgPSAoZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+KTogdm9pZCA9PiB7XG4gICAgc2V0SGFzQ29waWVkKHRydWUpO1xuICAgIGNvbnN0IGNvcHlJZCA9IGV2ZW50LmN1cnJlbnRUYXJnZXQuZ2V0QXR0cmlidXRlKCdkYXRhLXRpdGxlJyk7XG4gICAgY29uc3QgeyBsb2NhdGlvbiB9ID0gd2luZG93O1xuICAgIGNvbnN0IG5ld0hhc2ggPSBgIyR7Y29weUlkfWA7XG4gICAgY29uc3QgcG9ydCA9IGxvY2F0aW9uLnBvcnQgPyBgOiR7bG9jYXRpb24ucG9ydH1gIDogJyc7XG4gICAgY29uc3QgdXJsVG9Db3B5ID0gYCR7bG9jYXRpb24ucHJvdG9jb2x9Ly8ke2xvY2F0aW9uLmhvc3RuYW1lfSR7cG9ydH0ke2xvY2F0aW9uLnBhdGhuYW1lfSR7bG9jYXRpb24uc2VhcmNofSR7bmV3SGFzaH1gO1xuXG4gICAgY29weVRleHRUb0NsaXBib2FyZCh1cmxUb0NvcHkpO1xuICB9O1xuXG4gIGNvbnN0IHNhbml0aXplZFRpdGxlID0gZW5jb2RlVVJJQ29tcG9uZW50KHRpdGxlLnJlcGxhY2UoLyAvZywgJy0nKSk7XG4gIGNvbnN0IHRvb2x0aXAgPSBoYXNDb3BpZWQgPyB0KCdhcnRpY2xlLmNvcHlQYWdlTGlua0NvcGllZCcpIDogdCgnYXJ0aWNsZS5jb3B5SGVhZGVyTGluaycpO1xuXG4gIGlmIChoeWRyYXRlKSB7XG4gICAgcmV0dXJuIDxDb3B5QnV0dG9uIG9uQ2xpY2s9e29uQ29weUNsaWNrfSB0aXRsZT17c2FuaXRpemVkVGl0bGV9IHRvb2x0aXA9e3Rvb2x0aXB9IGNvbnRlbnQ9e2NvbnRlbnR9IC8+O1xuICB9XG5cbiAgcmV0dXJuIChcbiAgICA8Q29udGFpbmVyRGl2IGRhdGEtaGVhZGVyLWNvcHktY29udGFpbmVyIGRhdGEtdGl0bGU9e3RpdGxlfT5cbiAgICAgIDxDb3B5QnV0dG9uIG9uQ2xpY2s9e29uQ29weUNsaWNrfSB0aXRsZT17c2FuaXRpemVkVGl0bGV9IHRvb2x0aXA9e3Rvb2x0aXB9IGNvbnRlbnQ9e2NvbnRlbnR9IC8+XG4gICAgPC9Db250YWluZXJEaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBDb3B5UGFyYWdyYXBoQnV0dG9uO1xuIl19 */",
|
|
46
35
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
47
36
|
});
|
|
37
|
+
var IconButton = /*#__PURE__*/_styled("button", {
|
|
38
|
+
target: "e18czas70",
|
|
39
|
+
label: "IconButton"
|
|
40
|
+
})("position:absolute;left:-3em;top:0.1em;background:none;border:0;z-index:1;transition:0.2s;opacity:0;color:", colors.brand.grey, ";& svg{width:30px;height:30px;}", ContainerDiv, ":hover &,&:focus,&:focus-visible,&:active{cursor:pointer;opacity:1;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlQYXJhZ3JhcGhCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCZ0MiLCJmaWxlIjoiQ29weVBhcmFncmFwaEJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVN0YXRlLCBNb3VzZUV2ZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgVG9vbHRpcCBmcm9tICdAbmRsYS90b29sdGlwJztcbmltcG9ydCB7IGNvcHlUZXh0VG9DbGlwYm9hcmQgfSBmcm9tICdAbmRsYS91dGlsJztcbmltcG9ydCB7IGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5jb25zdCBDb250YWluZXJEaXYgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5jb25zdCBJY29uQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBsZWZ0OiAtM2VtO1xuICB0b3A6IDAuMWVtO1xuICBiYWNrZ3JvdW5kOiBub25lO1xuICBib3JkZXI6IDA7XG4gIHotaW5kZXg6IDE7XG4gIHRyYW5zaXRpb246IDAuMnM7XG4gIG9wYWNpdHk6IDA7XG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcblxuICAmIHN2ZyB7XG4gICAgd2lkdGg6IDMwcHg7XG4gICAgaGVpZ2h0OiAzMHB4O1xuICB9XG5cbiAgJHtDb250YWluZXJEaXZ9OmhvdmVyICYsXG4gICY6Zm9jdXMsICY6Zm9jdXMtdmlzaWJsZSwgJjphY3RpdmUge1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICBvcGFjaXR5OiAxO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICB0aXRsZT86IHN0cmluZyB8IG51bGw7XG4gIGNvbnRlbnQ/OiBzdHJpbmcgfCBudWxsO1xuICBoeWRyYXRlPzogYm9vbGVhbjtcbn1cblxuaW50ZXJmYWNlIENvcHlCdXR0b25Qcm9wcyB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIG9uQ2xpY2s/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG4gIHRvb2x0aXA6IHN0cmluZztcbiAgY29udGVudD86IHN0cmluZyB8IG51bGw7XG59XG5cbmNvbnN0IENvcHlCdXR0b24gPSAoeyBvbkNsaWNrLCB0aXRsZSwgdG9vbHRpcCwgY29udGVudCB9OiBDb3B5QnV0dG9uUHJvcHMpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8ZGl2PlxuICAgICAgPFRvb2x0aXAgdG9vbHRpcD17dG9vbHRpcH0+XG4gICAgICAgIDxJY29uQnV0dG9uIG9uQ2xpY2s9e29uQ2xpY2t9IGRhdGEtdGl0bGU9e3RpdGxlfSBhcmlhLWxhYmVsPXtgJHt0b29sdGlwfTogJHt0aXRsZX1gfT5cbiAgICAgICAgICA8TGluayB0aXRsZT17Jyd9IC8+XG4gICAgICAgIDwvSWNvbkJ1dHRvbj5cbiAgICAgIDwvVG9vbHRpcD5cbiAgICAgIDxoMiBpZD17dGl0bGV9IHRhYkluZGV4PXstMX0gZGFuZ2Vyb3VzbHlTZXRJbm5lckhUTUw9e3sgX19odG1sOiBjb250ZW50IHx8ICcnIH19IC8+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5jb25zdCBDb3B5UGFyYWdyYXBoQnV0dG9uID0gKHsgdGl0bGUsIGNvbnRlbnQsIGh5ZHJhdGUgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBjb25zdCBbaGFzQ29waWVkLCBzZXRIYXNDb3BpZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChoYXNDb3BpZWQpIHtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4gc2V0SGFzQ29waWVkKGZhbHNlKSwgMzAwMCk7XG4gICAgfVxuICB9LCBbaGFzQ29waWVkXSk7XG5cbiAgaWYgKCF0aXRsZSkgcmV0dXJuIG51bGw7XG5cbiAgY29uc3Qgb25Db3B5Q2xpY2sgPSAoZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+KTogdm9pZCA9PiB7XG4gICAgc2V0SGFzQ29waWVkKHRydWUpO1xuICAgIGNvbnN0IGNvcHlJZCA9IGV2ZW50LmN1cnJlbnRUYXJnZXQuZ2V0QXR0cmlidXRlKCdkYXRhLXRpdGxlJyk7XG4gICAgY29uc3QgeyBsb2NhdGlvbiB9ID0gd2luZG93O1xuICAgIGNvbnN0IG5ld0hhc2ggPSBgIyR7Y29weUlkfWA7XG4gICAgY29uc3QgcG9ydCA9IGxvY2F0aW9uLnBvcnQgPyBgOiR7bG9jYXRpb24ucG9ydH1gIDogJyc7XG4gICAgY29uc3QgdXJsVG9Db3B5ID0gYCR7bG9jYXRpb24ucHJvdG9jb2x9Ly8ke2xvY2F0aW9uLmhvc3RuYW1lfSR7cG9ydH0ke2xvY2F0aW9uLnBhdGhuYW1lfSR7bG9jYXRpb24uc2VhcmNofSR7bmV3SGFzaH1gO1xuXG4gICAgY29weVRleHRUb0NsaXBib2FyZCh1cmxUb0NvcHkpO1xuICB9O1xuXG4gIGNvbnN0IHNhbml0aXplZFRpdGxlID0gZW5jb2RlVVJJQ29tcG9uZW50KHRpdGxlLnJlcGxhY2UoLyAvZywgJy0nKSk7XG4gIGNvbnN0IHRvb2x0aXAgPSBoYXNDb3BpZWQgPyB0KCdhcnRpY2xlLmNvcHlQYWdlTGlua0NvcGllZCcpIDogdCgnYXJ0aWNsZS5jb3B5SGVhZGVyTGluaycpO1xuXG4gIGlmIChoeWRyYXRlKSB7XG4gICAgcmV0dXJuIDxDb3B5QnV0dG9uIG9uQ2xpY2s9e29uQ29weUNsaWNrfSB0aXRsZT17c2FuaXRpemVkVGl0bGV9IHRvb2x0aXA9e3Rvb2x0aXB9IGNvbnRlbnQ9e2NvbnRlbnR9IC8+O1xuICB9XG5cbiAgcmV0dXJuIChcbiAgICA8Q29udGFpbmVyRGl2IGRhdGEtaGVhZGVyLWNvcHktY29udGFpbmVyIGRhdGEtdGl0bGU9e3RpdGxlfT5cbiAgICAgIDxDb3B5QnV0dG9uIG9uQ2xpY2s9e29uQ29weUNsaWNrfSB0aXRsZT17c2FuaXRpemVkVGl0bGV9IHRvb2x0aXA9e3Rvb2x0aXB9IGNvbnRlbnQ9e2NvbnRlbnR9IC8+XG4gICAgPC9Db250YWluZXJEaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBDb3B5UGFyYWdyYXBoQnV0dG9uO1xuIl19 */"));
|
|
48
41
|
var CopyButton = function CopyButton(_ref) {
|
|
49
42
|
var onClick = _ref.onClick,
|
|
50
43
|
title = _ref.title,
|
|
51
44
|
tooltip = _ref.tooltip,
|
|
52
45
|
content = _ref.content;
|
|
53
46
|
return _jsxs("div", {
|
|
54
|
-
children: [_jsx(
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
47
|
+
children: [_jsx(Tooltip, {
|
|
48
|
+
tooltip: tooltip,
|
|
49
|
+
children: _jsx(IconButton, {
|
|
50
|
+
onClick: onClick,
|
|
51
|
+
"data-title": title,
|
|
52
|
+
"aria-label": "".concat(tooltip, ": ").concat(title),
|
|
59
53
|
children: _jsx(Link, {
|
|
60
54
|
title: ''
|
|
61
55
|
})
|
|
62
56
|
})
|
|
63
57
|
}), _jsx("h2", {
|
|
64
58
|
id: title,
|
|
65
|
-
tabIndex:
|
|
59
|
+
tabIndex: -1,
|
|
66
60
|
dangerouslySetInnerHTML: {
|
|
67
61
|
__html: content || ''
|
|
68
62
|
}
|
|
@@ -19,11 +19,11 @@ var StyledWrapper = /*#__PURE__*/_styled("section", {
|
|
|
19
19
|
from: breakpoints.tablet
|
|
20
20
|
}), "{width:550px;}", mq.range({
|
|
21
21
|
from: breakpoints.desktop
|
|
22
|
-
}), "{width:750px;}input{border-color:", colors.brand.tertiary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyb250cGFnZVNlYXJjaC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWW9DIiwiZmlsZSI6IkZyb250cGFnZVNlYXJjaC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgRm9ybUV2ZW50LCB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGlzSUUsIGJyb3dzZXJWZXJzaW9uLCBpc01vYmlsZVNhZmFyaSB9IGZyb20gJ3JlYWN0LWRldmljZS1kZXRlY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY29sb3JzLCBzcGFjaW5nLCBtcSwgYnJlYWtwb2ludHMsIGFuaW1hdGlvbnMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IG5vU2Nyb2xsIH0gZnJvbSAnQG5kbGEvdXRpbCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgU2VhcmNoRmllbGQgfSBmcm9tICcuLi9TZWFyY2gnO1xuaW1wb3J0IHsgU2VhcmNoRmllbGRGb3JtIH0gZnJvbSAnLi4vU2VhcmNoL1NlYXJjaEZpZWxkRm9ybSc7XG5pbXBvcnQgU2VhcmNoUmVzdWx0U2xlZXZlIGZyb20gJy4uL1NlYXJjaC9TZWFyY2hSZXN1bHRTbGVldmUnO1xuaW1wb3J0IHsgQ29udGVudFR5cGVSZXN1bHRUeXBlLCBSZXNvdXJjZSB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IGdldE1hc3RoZWFkSGVpZ2h0IH0gZnJvbSAnLi4vTWFzdGhlYWQnO1xuXG5jb25zdCBTdHlsZWRXcmFwcGVyID0gc3R5bGVkLnNlY3Rpb25gXG4gIGJvcmRlci1yYWRpdXM6IDJweDtcbiAgd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmc6ICR7c3BhY2luZy5ub3JtYWx9IDA7XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy5tb2JpbGVXaWRlIH0pfSB7XG4gICAgd2lkdGg6IDQ1MHB4O1xuICB9XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICB3aWR0aDogNTUwcHg7XG4gIH1cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICB3aWR0aDogNzUwcHg7XG4gIH1cbiAgaW5wdXQge1xuICAgIGJvcmRlci1jb2xvcjogJHtjb2xvcnMuYnJhbmQudGVydGlhcnl9O1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRTZWFyY2hCYWNrZHJvcCA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBmaXhlZDtcbiAgei1pbmRleDogMTtcbiAgdG9wOiAwO1xuICBsZWZ0OiAwO1xuICByaWdodDogMDtcbiAgYm90dG9tOiAwO1xuICBiYWNrZ3JvdW5kOiByZ2JhKDEsIDEsIDEsIDAuMyk7XG4gICR7YW5pbWF0aW9ucy5mYWRlSW4oYW5pbWF0aW9ucy5kdXJhdGlvbnMuZmFzdCl9O1xuYDtcblxudHlwZSBQcm9wcyA9IHtcbiAgaW5wdXRIYXNGb2N1czogYm9vbGVhbjtcbiAgc2VhcmNoRmllbGRWYWx1ZTogc3RyaW5nO1xuICBvblNlYXJjaEZpZWxkQ2hhbmdlOiAoc2VhcmNoVmFsdWU6IHN0cmluZykgPT4gdm9pZDtcbiAgc2VhcmNoRmllbGRQbGFjZWhvbGRlcjogc3RyaW5nO1xuICBvbklucHV0Qmx1cjogVm9pZEZ1bmN0aW9uO1xuICBvblNlYXJjaElucHV0Rm9jdXM6IFZvaWRGdW5jdGlvbjtcbiAgcmVzb3VyY2VUb0xpbmtQcm9wczogKHJlc291cmNlOiBSZXNvdXJjZSkgPT4ge1xuICAgIHRvOiBzdHJpbmc7XG4gIH07XG4gIG9uU2VhcmNoOiAoZXZlbnQ6IEZvcm1FdmVudCkgPT4gdm9pZDtcbiAgYWxsUmVzdWx0VXJsOiBzdHJpbmc7XG4gIHNlYXJjaFJlc3VsdD86IEFycmF5PENvbnRlbnRUeXBlUmVzdWx0VHlwZT47XG4gIGxvYWRpbmc6IGJvb2xlYW47XG4gIHN1Z2dlc3Rpb24/OiBzdHJpbmc7XG4gIHN1Z2dlc3Rpb25Vcmw/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBGcm9udHBhZ2VTZWFyY2ggPSAoe1xuICByZXNvdXJjZVRvTGlua1Byb3BzLFxuICBpbnB1dEhhc0ZvY3VzLFxuICBzZWFyY2hGaWVsZFZhbHVlLFxuICBvblNlYXJjaEZpZWxkQ2hhbmdlLFxuICBzZWFyY2hGaWVsZFBsYWNlaG9sZGVyLFxuICBvbklucHV0Qmx1cixcbiAgb25TZWFyY2hJbnB1dEZvY3VzLFxuICBvblNlYXJjaCxcbiAgYWxsUmVzdWx0VXJsLFxuICBzZWFyY2hSZXN1bHQsXG4gIGxvYWRpbmcsXG4gIHN1Z2dlc3Rpb24sXG4gIHN1Z2dlc3Rpb25VcmwsXG59OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IGlucHV0UmVmID0gdXNlUmVmPEhUTUxJbnB1dEVsZW1lbnQ+KG51bGwpO1xuICBjb25zdCBzZWFyY2hGaWVsZFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IGlucHV0SGFzRm9jdXNSZWYgPSB1c2VSZWYoaW5wdXRIYXNGb2N1cyk7XG4gIGlucHV0SGFzRm9jdXNSZWYuY3VycmVudCA9IGlucHV0SGFzRm9jdXM7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBvbktleUVzYyA9IChlOiBLZXlib2FyZEV2ZW50KSA9PiB7XG4gICAgICBpZiAoZS5jb2RlID09PSAnRXNjYXBlJykge1xuICAgICAgICBvbklucHV0Qmx1cigpO1xuICAgICAgICBpZiAoaW5wdXRSZWYgJiYgaW5wdXRSZWYuY3VycmVudCkge1xuICAgICAgICAgIGlucHV0UmVmLmN1cnJlbnQhLmJsdXIoKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH07XG4gICAgd2luZG93LmFkZEV2ZW50TGlzdGVuZXIoJ2tleWRvd24nLCBvbktleUVzYyk7XG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIHdpbmRvdy5yZW1vdmVFdmVudExpc3RlbmVyKCdrZXlkb3duJywgb25LZXlFc2MpO1xuICAgIH07XG4gIH0sIFtvbklucHV0Qmx1cl0pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgbGV0IHlDb29yZGluYXRlID0gMDtcbiAgICBjb25zdCBtYXN0aGVhZEhlaWdodCA9IGdldE1hc3RoZWFkSGVpZ2h0KCkgfHwgODQ7XG4gICAgY29uc3QgcmVzZXRTY3JvbGwgPSAoKSA9PiB7XG4gICAgICB3aW5kb3cuc2Nyb2xsVG8oeyB0b3A6IHlDb29yZGluYXRlIH0pO1xuICAgIH07XG4gICAgaWYgKGlucHV0SGFzRm9jdXMgJiYgc2VhcmNoRmllbGRSZWYgJiYgc2VhcmNoRmllbGRSZWYuY3VycmVudCkge1xuICAgICAgeUNvb3JkaW5hdGUgPSBzZWFyY2hGaWVsZFJlZi5jdXJyZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpLnRvcCArIHdpbmRvdy5wYWdlWU9mZnNldCAtIG1hc3RoZWFkSGVpZ2h0O1xuICAgICAgY29uc3QgaXNJRTExID0gaXNJRSAmJiBwYXJzZUludChicm93c2VyVmVyc2lvbikgPCAxMjtcbiAgICAgIGlmIChpc0lFMTEpIHtcbiAgICAgICAgLy8gaW5zdGEgbW92ZSBvbiBJRVxuICAgICAgICB3aW5kb3cuc2Nyb2xsVG8oMCwgeUNvb3JkaW5hdGUpO1xuICAgICAgfSBlbHNlIGlmIChpc01vYmlsZVNhZmFyaSkge1xuICAgICAgICAvLyBCZWNhdXNlIHNhZmFyaSBvbiBpT1Mgc2V0IHBvc2l0aW9uOmZpeGVkIHRvIHN0YXRpYyB3aGVuIGtleWJvYXJkIGlzIG9wZW4sIHdlIG5lZWQgdG8gc2Nyb2xsIHRvIHRvcC5cbiAgICAgICAgeUNvb3JkaW5hdGUgPSAwO1xuICAgICAgICAvLyBTdHJhbmdlIHNjcm9sbGluZyBpcyBoYXBwZW5pbmcgd2hlbiBrZXlib2FyZCBvcGVucyBpbiBpT1MsIG1ha2luZyBzY3JvbGxwb3Mgbm90IHRvIHRvcC5cbiAgICAgICAgLy8gVXNlIGEgc21hbGwgdGltZW91dCBzbyB0aGUgc2Nyb2xsaW5nIHN0YXJ0cyBhZnRlclxuICAgICAgICBzZXRUaW1lb3V0KFxuICAgICAgICAgICgpID0+
|
|
22
|
+
}), "{width:750px;}input{border-color:", colors.brand.tertiary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageSearch.tsx"],"names":[],"mappings":"AAYoC","file":"FrontpageSearch.tsx","sourcesContent":["import React, { FormEvent, useEffect, useRef } from 'react';\nimport { isIE, browserVersion, isMobileSafari } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { colors, spacing, mq, breakpoints, animations } from '@ndla/core';\nimport { noScroll } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { SearchField } from '../Search';\nimport { SearchFieldForm } from '../Search/SearchFieldForm';\nimport SearchResultSleeve from '../Search/SearchResultSleeve';\nimport { ContentTypeResultType, Resource } from '../types';\nimport { getMastheadHeight } from '../Masthead';\n\nconst StyledWrapper = styled.section`\n  border-radius: 2px;\n  width: 100%;\n  padding: ${spacing.normal} 0;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 450px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 550px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 750px;\n  }\n  input {\n    border-color: ${colors.brand.tertiary};\n  }\n`;\n\nconst StyledSearchBackdrop = styled.div`\n  position: fixed;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  background: rgba(1, 1, 1, 0.3);\n  ${animations.fadeIn(animations.durations.fast)};\n`;\n\ntype Props = {\n  inputHasFocus: boolean;\n  searchFieldValue: string;\n  onSearchFieldChange: (searchValue: string) => void;\n  searchFieldPlaceholder: string;\n  onInputBlur: VoidFunction;\n  onSearchInputFocus: VoidFunction;\n  resourceToLinkProps: (resource: Resource) => {\n    to: string;\n  };\n  onSearch: (event: FormEvent) => void;\n  allResultUrl: string;\n  searchResult?: Array<ContentTypeResultType>;\n  loading: boolean;\n  suggestion?: string;\n  suggestionUrl?: string;\n};\n\nconst FrontpageSearch = ({\n  resourceToLinkProps,\n  inputHasFocus,\n  searchFieldValue,\n  onSearchFieldChange,\n  searchFieldPlaceholder,\n  onInputBlur,\n  onSearchInputFocus,\n  onSearch,\n  allResultUrl,\n  searchResult,\n  loading,\n  suggestion,\n  suggestionUrl,\n}: Props) => {\n  const { t } = useTranslation();\n  const inputRef = useRef<HTMLInputElement>(null);\n  const searchFieldRef = useRef<HTMLDivElement>(null);\n  const inputHasFocusRef = useRef(inputHasFocus);\n  inputHasFocusRef.current = inputHasFocus;\n\n  useEffect(() => {\n    const onKeyEsc = (e: KeyboardEvent) => {\n      if (e.code === 'Escape') {\n        onInputBlur();\n        if (inputRef && inputRef.current) {\n          inputRef.current!.blur();\n        }\n      }\n    };\n    window.addEventListener('keydown', onKeyEsc);\n    return () => {\n      window.removeEventListener('keydown', onKeyEsc);\n    };\n  }, [onInputBlur]);\n\n  useEffect(() => {\n    let yCoordinate = 0;\n    const mastheadHeight = getMastheadHeight() || 84;\n    const resetScroll = () => {\n      window.scrollTo({ top: yCoordinate });\n    };\n    if (inputHasFocus && searchFieldRef && searchFieldRef.current) {\n      yCoordinate = searchFieldRef.current.getBoundingClientRect().top + window.pageYOffset - mastheadHeight;\n      const isIE11 = isIE && parseInt(browserVersion) < 12;\n      if (isIE11) {\n        // insta move on IE\n        window.scrollTo(0, yCoordinate);\n      } else if (isMobileSafari) {\n        // Because safari on iOS set position:fixed to static when keyboard is open, we need to scroll to top.\n        yCoordinate = 0;\n        // Strange scrolling is happening when keyboard opens in iOS, making scrollpos not to top.\n        // Use a small timeout so the scrolling starts after\n        setTimeout(\n          () =>\n            window.scrollTo({\n              top: yCoordinate,\n              behavior: 'smooth',\n            }),\n          100,\n        );\n      } else {\n        window.scrollTo({\n          top: yCoordinate,\n          behavior: 'smooth',\n        });\n      }\n      noScroll(true, 'preventPageScroll');\n      // Because change in content(click on show more elements button) triggers some strange scroll in browser,\n      // we must ensure that the scrollPos is the same all the time\n      // setTimeout is used so the 'smooth' scroll effect can finish\n      setTimeout(() => {\n        // If user has closed modal search before timeout. Don't add event-listener\n        if (inputHasFocusRef.current) {\n          window.addEventListener('scroll', resetScroll);\n        }\n      }, 1000);\n    } else {\n      noScroll(false, 'preventPageScroll');\n      window.removeEventListener('scroll', resetScroll);\n    }\n    return () => {\n      noScroll(false, 'preventPageScroll');\n      window.removeEventListener('scroll', resetScroll);\n      inputHasFocusRef.current = false;\n    };\n  }, [inputHasFocus]);\n\n  const onBlur = () => {\n    setTimeout(() => {\n      if (searchFieldRef.current) {\n        if (!searchFieldRef.current.contains(document.activeElement)) {\n          onInputBlur();\n        }\n      }\n    }, 0);\n    // This is needed when user tabs out of field\n    if (!searchFieldValue) {\n      onInputBlur();\n    }\n  };\n\n  return (\n    <div ref={searchFieldRef}>\n      <StyledWrapper>\n        {inputHasFocus && (\n          <StyledSearchBackdrop\n            role=\"button\"\n            onClick={() => {\n              onInputBlur();\n              if (inputRef && inputRef.current) {\n                inputRef.current!.blur();\n              }\n            }}\n          />\n        )}\n        <SearchFieldForm inputHasFocus={inputHasFocus} onSubmit={onSearch}>\n          <SearchField\n            frontPageSearch={true}\n            inputRef={inputRef}\n            onFocus={onSearchInputFocus}\n            value={searchFieldValue}\n            onChange={onSearchFieldChange}\n            placeholder={searchFieldPlaceholder}\n            loading={loading}\n            onBlur={onBlur}\n          />\n          {searchFieldValue !== '' && inputHasFocus && (\n            <SearchResultSleeve\n              frontpage\n              loading={loading}\n              ignoreContentTypeBadge\n              result={searchResult || []}\n              searchString={searchFieldValue}\n              allResultUrl={allResultUrl}\n              resourceToLinkProps={resourceToLinkProps}\n              infoText={t('welcomePage.searchDisclaimer')}\n              suggestion={suggestion}\n              suggestionUrl={suggestionUrl}\n            />\n          )}\n        </SearchFieldForm>\n      </StyledWrapper>\n    </div>\n  );\n};\n\nexport default FrontpageSearch;\n"]} */"));
|
|
23
23
|
var StyledSearchBackdrop = /*#__PURE__*/_styled("div", {
|
|
24
24
|
target: "e8xkl600",
|
|
25
25
|
label: "StyledSearchBackdrop"
|
|
26
|
-
})("position:fixed;z-index:1;top:0;left:0;right:0;bottom:0;background:rgba(1, 1, 1, 0.3);", animations.fadeIn(animations.durations.fast), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyb250cGFnZVNlYXJjaC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJ1QyIsImZpbGUiOiJGcm9udHBhZ2VTZWFyY2gudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZvcm1FdmVudCwgdXNlRWZmZWN0LCB1c2VSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBpc0lFLCBicm93c2VyVmVyc2lvbiwgaXNNb2JpbGVTYWZhcmkgfSBmcm9tICdyZWFjdC1kZXZpY2UtZGV0ZWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZywgbXEsIGJyZWFrcG9pbnRzLCBhbmltYXRpb25zIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBub1Njcm9sbCB9IGZyb20gJ0BuZGxhL3V0aWwnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCB7IFNlYXJjaEZpZWxkIH0gZnJvbSAnLi4vU2VhcmNoJztcbmltcG9ydCB7IFNlYXJjaEZpZWxkRm9ybSB9IGZyb20gJy4uL1NlYXJjaC9TZWFyY2hGaWVsZEZvcm0nO1xuaW1wb3J0IFNlYXJjaFJlc3VsdFNsZWV2ZSBmcm9tICcuLi9TZWFyY2gvU2VhcmNoUmVzdWx0U2xlZXZlJztcbmltcG9ydCB7IENvbnRlbnRUeXBlUmVzdWx0VHlwZSwgUmVzb3VyY2UgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBnZXRNYXN0aGVhZEhlaWdodCB9IGZyb20gJy4uL01hc3RoZWFkJztcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5zZWN0aW9uYFxuICBib3JkZXItcmFkaXVzOiAycHg7XG4gIHdpZHRoOiAxMDAlO1xuICBwYWRkaW5nOiAke3NwYWNpbmcubm9ybWFsfSAwO1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIHdpZHRoOiA0NTBweDtcbiAgfVxuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgd2lkdGg6IDU1MHB4O1xuICB9XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgd2lkdGg6IDc1MHB4O1xuICB9XG4gIGlucHV0IHtcbiAgICBib3JkZXItY29sb3I6ICR7Y29sb3JzLmJyYW5kLnRlcnRpYXJ5fTtcbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkU2VhcmNoQmFja2Ryb3AgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogZml4ZWQ7XG4gIHotaW5kZXg6IDE7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbiAgcmlnaHQ6IDA7XG4gIGJvdHRvbTogMDtcbiAgYmFja2dyb3VuZDogcmdiYSgxLCAxLCAxLCAwLjMpO1xuICAke2FuaW1hdGlvbnMuZmFkZUluKGFuaW1hdGlvbnMuZHVyYXRpb25zLmZhc3QpfTtcbmA7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGlucHV0SGFzRm9jdXM6IGJvb2xlYW47XG4gIHNlYXJjaEZpZWxkVmFsdWU6IHN0cmluZztcbiAgb25TZWFyY2hGaWVsZENoYW5nZTogKHNlYXJjaFZhbHVlOiBzdHJpbmcpID0+IHZvaWQ7XG4gIHNlYXJjaEZpZWxkUGxhY2Vob2xkZXI6IHN0cmluZztcbiAgb25JbnB1dEJsdXI6IFZvaWRGdW5jdGlvbjtcbiAgb25TZWFyY2hJbnB1dEZvY3VzOiBWb2lkRnVuY3Rpb247XG4gIHJlc291cmNlVG9MaW5rUHJvcHM6IChyZXNvdXJjZTogUmVzb3VyY2UpID0+IHtcbiAgICB0bzogc3RyaW5nO1xuICB9O1xuICBvblNlYXJjaDogKGV2ZW50OiBGb3JtRXZlbnQpID0+IHZvaWQ7XG4gIGFsbFJlc3VsdFVybDogc3RyaW5nO1xuICBzZWFyY2hSZXN1bHQ/OiBBcnJheTxDb250ZW50VHlwZVJlc3VsdFR5cGU+O1xuICBsb2FkaW5nOiBib29sZWFuO1xuICBzdWdnZXN0aW9uPzogc3RyaW5nO1xuICBzdWdnZXN0aW9uVXJsPzogc3RyaW5nO1xufTtcblxuY29uc3QgRnJvbnRwYWdlU2VhcmNoID0gKHtcbiAgcmVzb3VyY2VUb0xpbmtQcm9wcyxcbiAgaW5wdXRIYXNGb2N1cyxcbiAgc2VhcmNoRmllbGRWYWx1ZSxcbiAgb25TZWFyY2hGaWVsZENoYW5nZSxcbiAgc2VhcmNoRmllbGRQbGFjZWhvbGRlcixcbiAgb25JbnB1dEJsdXIsXG4gIG9uU2VhcmNoSW5wdXRGb2N1cyxcbiAgb25TZWFyY2gsXG4gIGFsbFJlc3VsdFVybCxcbiAgc2VhcmNoUmVzdWx0LFxuICBsb2FkaW5nLFxuICBzdWdnZXN0aW9uLFxuICBzdWdnZXN0aW9uVXJsLFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBjb25zdCBpbnB1dFJlZiA9IHVzZVJlZjxIVE1MSW5wdXRFbGVtZW50PihudWxsKTtcbiAgY29uc3Qgc2VhcmNoRmllbGRSZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+
|
|
26
|
+
})("position:fixed;z-index:1;top:0;left:0;right:0;bottom:0;background:rgba(1, 1, 1, 0.3);", animations.fadeIn(animations.durations.fast), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageSearch.tsx"],"names":[],"mappings":"AA8BuC","file":"FrontpageSearch.tsx","sourcesContent":["import React, { FormEvent, useEffect, useRef } from 'react';\nimport { isIE, browserVersion, isMobileSafari } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { colors, spacing, mq, breakpoints, animations } from '@ndla/core';\nimport { noScroll } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\nimport { SearchField } from '../Search';\nimport { SearchFieldForm } from '../Search/SearchFieldForm';\nimport SearchResultSleeve from '../Search/SearchResultSleeve';\nimport { ContentTypeResultType, Resource } from '../types';\nimport { getMastheadHeight } from '../Masthead';\n\nconst StyledWrapper = styled.section`\n  border-radius: 2px;\n  width: 100%;\n  padding: ${spacing.normal} 0;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    width: 450px;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 550px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 750px;\n  }\n  input {\n    border-color: ${colors.brand.tertiary};\n  }\n`;\n\nconst StyledSearchBackdrop = styled.div`\n  position: fixed;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  background: rgba(1, 1, 1, 0.3);\n  ${animations.fadeIn(animations.durations.fast)};\n`;\n\ntype Props = {\n  inputHasFocus: boolean;\n  searchFieldValue: string;\n  onSearchFieldChange: (searchValue: string) => void;\n  searchFieldPlaceholder: string;\n  onInputBlur: VoidFunction;\n  onSearchInputFocus: VoidFunction;\n  resourceToLinkProps: (resource: Resource) => {\n    to: string;\n  };\n  onSearch: (event: FormEvent) => void;\n  allResultUrl: string;\n  searchResult?: Array<ContentTypeResultType>;\n  loading: boolean;\n  suggestion?: string;\n  suggestionUrl?: string;\n};\n\nconst FrontpageSearch = ({\n  resourceToLinkProps,\n  inputHasFocus,\n  searchFieldValue,\n  onSearchFieldChange,\n  searchFieldPlaceholder,\n  onInputBlur,\n  onSearchInputFocus,\n  onSearch,\n  allResultUrl,\n  searchResult,\n  loading,\n  suggestion,\n  suggestionUrl,\n}: Props) => {\n  const { t } = useTranslation();\n  const inputRef = useRef<HTMLInputElement>(null);\n  const searchFieldRef = useRef<HTMLDivElement>(null);\n  const inputHasFocusRef = useRef(inputHasFocus);\n  inputHasFocusRef.current = inputHasFocus;\n\n  useEffect(() => {\n    const onKeyEsc = (e: KeyboardEvent) => {\n      if (e.code === 'Escape') {\n        onInputBlur();\n        if (inputRef && inputRef.current) {\n          inputRef.current!.blur();\n        }\n      }\n    };\n    window.addEventListener('keydown', onKeyEsc);\n    return () => {\n      window.removeEventListener('keydown', onKeyEsc);\n    };\n  }, [onInputBlur]);\n\n  useEffect(() => {\n    let yCoordinate = 0;\n    const mastheadHeight = getMastheadHeight() || 84;\n    const resetScroll = () => {\n      window.scrollTo({ top: yCoordinate });\n    };\n    if (inputHasFocus && searchFieldRef && searchFieldRef.current) {\n      yCoordinate = searchFieldRef.current.getBoundingClientRect().top + window.pageYOffset - mastheadHeight;\n      const isIE11 = isIE && parseInt(browserVersion) < 12;\n      if (isIE11) {\n        // insta move on IE\n        window.scrollTo(0, yCoordinate);\n      } else if (isMobileSafari) {\n        // Because safari on iOS set position:fixed to static when keyboard is open, we need to scroll to top.\n        yCoordinate = 0;\n        // Strange scrolling is happening when keyboard opens in iOS, making scrollpos not to top.\n        // Use a small timeout so the scrolling starts after\n        setTimeout(\n          () =>\n            window.scrollTo({\n              top: yCoordinate,\n              behavior: 'smooth',\n            }),\n          100,\n        );\n      } else {\n        window.scrollTo({\n          top: yCoordinate,\n          behavior: 'smooth',\n        });\n      }\n      noScroll(true, 'preventPageScroll');\n      // Because change in content(click on show more elements button) triggers some strange scroll in browser,\n      // we must ensure that the scrollPos is the same all the time\n      // setTimeout is used so the 'smooth' scroll effect can finish\n      setTimeout(() => {\n        // If user has closed modal search before timeout. Don't add event-listener\n        if (inputHasFocusRef.current) {\n          window.addEventListener('scroll', resetScroll);\n        }\n      }, 1000);\n    } else {\n      noScroll(false, 'preventPageScroll');\n      window.removeEventListener('scroll', resetScroll);\n    }\n    return () => {\n      noScroll(false, 'preventPageScroll');\n      window.removeEventListener('scroll', resetScroll);\n      inputHasFocusRef.current = false;\n    };\n  }, [inputHasFocus]);\n\n  const onBlur = () => {\n    setTimeout(() => {\n      if (searchFieldRef.current) {\n        if (!searchFieldRef.current.contains(document.activeElement)) {\n          onInputBlur();\n        }\n      }\n    }, 0);\n    // This is needed when user tabs out of field\n    if (!searchFieldValue) {\n      onInputBlur();\n    }\n  };\n\n  return (\n    <div ref={searchFieldRef}>\n      <StyledWrapper>\n        {inputHasFocus && (\n          <StyledSearchBackdrop\n            role=\"button\"\n            onClick={() => {\n              onInputBlur();\n              if (inputRef && inputRef.current) {\n                inputRef.current!.blur();\n              }\n            }}\n          />\n        )}\n        <SearchFieldForm inputHasFocus={inputHasFocus} onSubmit={onSearch}>\n          <SearchField\n            frontPageSearch={true}\n            inputRef={inputRef}\n            onFocus={onSearchInputFocus}\n            value={searchFieldValue}\n            onChange={onSearchFieldChange}\n            placeholder={searchFieldPlaceholder}\n            loading={loading}\n            onBlur={onBlur}\n          />\n          {searchFieldValue !== '' && inputHasFocus && (\n            <SearchResultSleeve\n              frontpage\n              loading={loading}\n              ignoreContentTypeBadge\n              result={searchResult || []}\n              searchString={searchFieldValue}\n              allResultUrl={allResultUrl}\n              resourceToLinkProps={resourceToLinkProps}\n              infoText={t('welcomePage.searchDisclaimer')}\n              suggestion={suggestion}\n              suggestionUrl={suggestionUrl}\n            />\n          )}\n        </SearchFieldForm>\n      </StyledWrapper>\n    </div>\n  );\n};\n\nexport default FrontpageSearch;\n"]} */"));
|
|
27
27
|
var FrontpageSearch = function FrontpageSearch(_ref) {
|
|
28
28
|
var resourceToLinkProps = _ref.resourceToLinkProps,
|
|
29
29
|
inputHasFocus = _ref.inputHasFocus,
|
|
@@ -106,6 +106,7 @@ var FrontpageSearch = function FrontpageSearch(_ref) {
|
|
|
106
106
|
return function () {
|
|
107
107
|
noScroll(false, 'preventPageScroll');
|
|
108
108
|
window.removeEventListener('scroll', resetScroll);
|
|
109
|
+
inputHasFocusRef.current = false;
|
|
109
110
|
};
|
|
110
111
|
}, [inputHasFocus]);
|
|
111
112
|
var onBlur = function onBlur() {
|