@ndla/ui 3.3.3 → 3.3.4

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.
@@ -33,12 +33,12 @@ var IconButton = _styled("button", {
33
33
  target: "e18czas70",
34
34
  label: "IconButton"
35
35
  })(process.env.NODE_ENV === "production" ? {
36
- name: "1eoah0f",
37
- styles: "float:left;position:relative;left:-3em;top:0.1em;background:none;border:0;z-index:1;transition:0.2s;opacity:0;& svg{width:30px;height:30px;}"
36
+ name: "3epkb7",
37
+ 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;}"
38
38
  } : {
39
- name: "1eoah0f",
40
- styles: "float:left;position:relative;left:-3em;top:0.1em;background:none;border:0;z-index:1;transition:0.2s;opacity:0;& svg{width:30px;height:30px;}",
41
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlQYXJhZ3JhcGhCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCZ0MiLCJmaWxlIjoiQ29weVBhcmFncmFwaEJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUsIHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IExpbmsgfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0Jztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBUb29sdGlwIGZyb20gJ0BuZGxhL3Rvb2x0aXAnO1xuaW1wb3J0IHsgY29weVRleHRUb0NsaXBib2FyZCB9IGZyb20gJ0BuZGxhL3V0aWwnO1xuXG5jb25zdCBJY29uQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgZmxvYXQ6IGxlZnQ7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbGVmdDogLTNlbTtcbiAgdG9wOiAwLjFlbTtcbiAgYmFja2dyb3VuZDogbm9uZTtcbiAgYm9yZGVyOiAwO1xuICB6LWluZGV4OiAxO1xuICB0cmFuc2l0aW9uOiAwLjJzO1xuICBvcGFjaXR5OiAwO1xuXG4gICYgc3ZnIHtcbiAgICB3aWR0aDogMzBweDtcbiAgICBoZWlnaHQ6IDMwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IENvbnRhaW5lckRpdiA9IHN0eWxlZC5kaXZgXG4gICY6aG92ZXIgYnV0dG9uIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgb3BhY2l0eTogMC41O1xuICB9XG5cbiAgJiBoMiB7XG4gICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgIGxlZnQ6IC0yZW07XG4gIH1cbmA7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIHRpdGxlPzogc3RyaW5nIHwgbnVsbDtcbiAgY29udGVudD86IHN0cmluZyB8IG51bGw7XG4gIGh5ZHJhdGU/OiBib29sZWFuO1xufVxuXG5pbnRlcmZhY2UgV3JhcHBlclByb3BzIHtcbiAgdGl0bGU6IHN0cmluZztcbiAgaHlkcmF0ZT86IGJvb2xlYW47XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59XG5cbmNvbnN0IFdyYXBwZXJDb21wb25lbnQgPSAoeyB0aXRsZSwgaHlkcmF0ZSwgY2hpbGRyZW4gfTogV3JhcHBlclByb3BzKSA9PiB7XG4gIGlmIChoeWRyYXRlKSB7XG4gICAgcmV0dXJuIDw+e2NoaWxkcmVufTwvPjtcbiAgfVxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXJEaXYgZGF0YS1oZWFkZXItY29weS1jb250YWluZXIgZGF0YS10aXRsZT17dGl0bGV9PlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvQ29udGFpbmVyRGl2PlxuICApO1xufTtcblxuY29uc3QgQ29weVBhcmFncmFwaEJ1dHRvbiA9ICh7IHRpdGxlLCBjb250ZW50LCBoeWRyYXRlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgW2hhc0NvcGllZCwgc2V0SGFzQ29waWVkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaGFzQ29waWVkKSB7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHNldEhhc0NvcGllZChmYWxzZSksIDMwMDApO1xuICAgIH1cbiAgfSwgW2hhc0NvcGllZF0pO1xuXG4gIGlmICghdGl0bGUpIHJldHVybiBudWxsO1xuXG4gIGNvbnN0IG9uQ29weUNsaWNrID0gKGV2ZW50OiBSZWFjdC5Nb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50LCBNb3VzZUV2ZW50Pik6IHZvaWQgPT4ge1xuICAgIHNldEhhc0NvcGllZCh0cnVlKTtcbiAgICBjb25zdCBjb3B5SWQgPSBldmVudC5jdXJyZW50VGFyZ2V0LmdldEF0dHJpYnV0ZSgnZGF0YS10aXRsZScpO1xuICAgIGNvbnN0IHsgbG9jYXRpb24gfSA9IHdpbmRvdztcbiAgICBjb25zdCBuZXdIYXNoID0gYCMke2NvcHlJZH1gO1xuICAgIGNvbnN0IHBvcnQgPSBsb2NhdGlvbi5wb3J0ID8gYDoke2xvY2F0aW9uLnBvcnR9YCA6ICcnO1xuICAgIGNvbnN0IHVybFRvQ29weSA9IGAke2xvY2F0aW9uLnByb3RvY29sfS8vJHtsb2NhdGlvbi5ob3N0bmFtZX0ke3BvcnR9JHtsb2NhdGlvbi5wYXRobmFtZX0ke2xvY2F0aW9uLnNlYXJjaH0ke25ld0hhc2h9YDtcblxuICAgIGNvcHlUZXh0VG9DbGlwYm9hcmQodXJsVG9Db3B5KTtcbiAgfTtcblxuICBjb25zdCBzYW5pdGl6ZWRUaXRsZSA9IGVuY29kZVVSSUNvbXBvbmVudCh0aXRsZS5yZXBsYWNlKC8gL2csICctJykpO1xuICBjb25zdCB0b29sdGlwID0gaGFzQ29waWVkID8gdCgnYXJ0aWNsZS5jb3B5UGFnZUxpbmtDb3BpZWQnKSA6IHQoJ2FydGljbGUuY29weUhlYWRlckxpbmsnKTtcblxuICByZXR1cm4gKFxuICAgIDxXcmFwcGVyQ29tcG9uZW50IGh5ZHJhdGU9e2h5ZHJhdGV9IHRpdGxlPXt0aXRsZX0+XG4gICAgICA8SWNvbkJ1dHRvbiBvbkNsaWNrPXtvbkNvcHlDbGlja30gZGF0YS10aXRsZT17c2FuaXRpemVkVGl0bGV9PlxuICAgICAgICA8VG9vbHRpcCB0b29sdGlwPXt0b29sdGlwfT5cbiAgICAgICAgICA8TGluayB0aXRsZT17Jyd9IC8+XG4gICAgICAgIDwvVG9vbHRpcD5cbiAgICAgIDwvSWNvbkJ1dHRvbj5cbiAgICAgIDxoMiBpZD17c2FuaXRpemVkVGl0bGV9IHRhYkluZGV4PXswfSBkYW5nZXJvdXNseVNldElubmVySFRNTD17eyBfX2h0bWw6IGNvbnRlbnQgfHwgJycgfX0+PC9oMj5cbiAgICA8L1dyYXBwZXJDb21wb25lbnQ+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBDb3B5UGFyYWdyYXBoQnV0dG9uO1xuIl19 */",
39
+ name: "3epkb7",
40
+ 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;}",
41
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlQYXJhZ3JhcGhCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCZ0MiLCJmaWxlIjoiQ29weVBhcmFncmFwaEJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUsIHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IExpbmsgfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0Jztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBUb29sdGlwIGZyb20gJ0BuZGxhL3Rvb2x0aXAnO1xuaW1wb3J0IHsgY29weVRleHRUb0NsaXBib2FyZCB9IGZyb20gJ0BuZGxhL3V0aWwnO1xuXG5jb25zdCBJY29uQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBsZWZ0OiAtM2VtO1xuICB0b3A6IDAuMWVtO1xuICBiYWNrZ3JvdW5kOiBub25lO1xuICBib3JkZXI6IDA7XG4gIHotaW5kZXg6IDE7XG4gIHRyYW5zaXRpb246IDAuMnM7XG4gIG9wYWNpdHk6IDA7XG5cbiAgJiBzdmcge1xuICAgIHdpZHRoOiAzMHB4O1xuICAgIGhlaWdodDogMzBweDtcbiAgfVxuYDtcblxuY29uc3QgQ29udGFpbmVyRGl2ID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAmOmhvdmVyIGJ1dHRvbiB7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIG9wYWNpdHk6IDAuNTtcbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgdGl0bGU/OiBzdHJpbmcgfCBudWxsO1xuICBjb250ZW50Pzogc3RyaW5nIHwgbnVsbDtcbiAgaHlkcmF0ZT86IGJvb2xlYW47XG59XG5cbmludGVyZmFjZSBXcmFwcGVyUHJvcHMge1xuICB0aXRsZTogc3RyaW5nO1xuICBoeWRyYXRlPzogYm9vbGVhbjtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn1cblxuY29uc3QgV3JhcHBlckNvbXBvbmVudCA9ICh7IHRpdGxlLCBoeWRyYXRlLCBjaGlsZHJlbiB9OiBXcmFwcGVyUHJvcHMpID0+IHtcbiAgaWYgKGh5ZHJhdGUpIHtcbiAgICByZXR1cm4gPD57Y2hpbGRyZW59PC8+O1xuICB9XG4gIHJldHVybiAoXG4gICAgPENvbnRhaW5lckRpdiBkYXRhLWhlYWRlci1jb3B5LWNvbnRhaW5lciBkYXRhLXRpdGxlPXt0aXRsZX0+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9Db250YWluZXJEaXY+XG4gICk7XG59O1xuXG5jb25zdCBDb3B5UGFyYWdyYXBoQnV0dG9uID0gKHsgdGl0bGUsIGNvbnRlbnQsIGh5ZHJhdGUgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBjb25zdCBbaGFzQ29waWVkLCBzZXRIYXNDb3BpZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChoYXNDb3BpZWQpIHtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4gc2V0SGFzQ29waWVkKGZhbHNlKSwgMzAwMCk7XG4gICAgfVxuICB9LCBbaGFzQ29waWVkXSk7XG5cbiAgaWYgKCF0aXRsZSkgcmV0dXJuIG51bGw7XG5cbiAgY29uc3Qgb25Db3B5Q2xpY2sgPSAoZXZlbnQ6IFJlYWN0Lk1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQsIE1vdXNlRXZlbnQ+KTogdm9pZCA9PiB7XG4gICAgc2V0SGFzQ29waWVkKHRydWUpO1xuICAgIGNvbnN0IGNvcHlJZCA9IGV2ZW50LmN1cnJlbnRUYXJnZXQuZ2V0QXR0cmlidXRlKCdkYXRhLXRpdGxlJyk7XG4gICAgY29uc3QgeyBsb2NhdGlvbiB9ID0gd2luZG93O1xuICAgIGNvbnN0IG5ld0hhc2ggPSBgIyR7Y29weUlkfWA7XG4gICAgY29uc3QgcG9ydCA9IGxvY2F0aW9uLnBvcnQgPyBgOiR7bG9jYXRpb24ucG9ydH1gIDogJyc7XG4gICAgY29uc3QgdXJsVG9Db3B5ID0gYCR7bG9jYXRpb24ucHJvdG9jb2x9Ly8ke2xvY2F0aW9uLmhvc3RuYW1lfSR7cG9ydH0ke2xvY2F0aW9uLnBhdGhuYW1lfSR7bG9jYXRpb24uc2VhcmNofSR7bmV3SGFzaH1gO1xuXG4gICAgY29weVRleHRUb0NsaXBib2FyZCh1cmxUb0NvcHkpO1xuICB9O1xuXG4gIGNvbnN0IHNhbml0aXplZFRpdGxlID0gZW5jb2RlVVJJQ29tcG9uZW50KHRpdGxlLnJlcGxhY2UoLyAvZywgJy0nKSk7XG4gIGNvbnN0IHRvb2x0aXAgPSBoYXNDb3BpZWQgPyB0KCdhcnRpY2xlLmNvcHlQYWdlTGlua0NvcGllZCcpIDogdCgnYXJ0aWNsZS5jb3B5SGVhZGVyTGluaycpO1xuXG4gIHJldHVybiAoXG4gICAgPFdyYXBwZXJDb21wb25lbnQgaHlkcmF0ZT17aHlkcmF0ZX0gdGl0bGU9e3RpdGxlfT5cbiAgICAgIDxJY29uQnV0dG9uIG9uQ2xpY2s9e29uQ29weUNsaWNrfSBkYXRhLXRpdGxlPXtzYW5pdGl6ZWRUaXRsZX0+XG4gICAgICAgIDxUb29sdGlwIHRvb2x0aXA9e3Rvb2x0aXB9PlxuICAgICAgICAgIDxMaW5rIHRpdGxlPXsnJ30gLz5cbiAgICAgICAgPC9Ub29sdGlwPlxuICAgICAgPC9JY29uQnV0dG9uPlxuICAgICAgPGgyIGlkPXtzYW5pdGl6ZWRUaXRsZX0gdGFiSW5kZXg9ezB9IGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7IF9faHRtbDogY29udGVudCB8fCAnJyB9fT48L2gyPlxuICAgIDwvV3JhcHBlckNvbXBvbmVudD5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENvcHlQYXJhZ3JhcGhCdXR0b247XG4iXX0= */",
42
42
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
43
43
  });
44
44
 
@@ -46,12 +46,12 @@ var ContainerDiv = _styled("div", {
46
46
  target: "e18czas71",
47
47
  label: "ContainerDiv"
48
48
  })(process.env.NODE_ENV === "production" ? {
49
- name: "25spe5",
50
- styles: "&:hover button{cursor:pointer;opacity:0.5;}& h2{position:relative;left:-2em;}"
49
+ name: "1b7r8js",
50
+ styles: "position:relative;&:hover button{cursor:pointer;opacity:0.5;}"
51
51
  } : {
52
- name: "25spe5",
53
- styles: "&:hover button{cursor:pointer;opacity:0.5;}& h2{position:relative;left:-2em;}",
54
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlQYXJhZ3JhcGhCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtDK0IiLCJmaWxlIjoiQ29weVBhcmFncmFwaEJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUsIHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IExpbmsgfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0Jztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBUb29sdGlwIGZyb20gJ0BuZGxhL3Rvb2x0aXAnO1xuaW1wb3J0IHsgY29weVRleHRUb0NsaXBib2FyZCB9IGZyb20gJ0BuZGxhL3V0aWwnO1xuXG5jb25zdCBJY29uQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgZmxvYXQ6IGxlZnQ7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbGVmdDogLTNlbTtcbiAgdG9wOiAwLjFlbTtcbiAgYmFja2dyb3VuZDogbm9uZTtcbiAgYm9yZGVyOiAwO1xuICB6LWluZGV4OiAxO1xuICB0cmFuc2l0aW9uOiAwLjJzO1xuICBvcGFjaXR5OiAwO1xuXG4gICYgc3ZnIHtcbiAgICB3aWR0aDogMzBweDtcbiAgICBoZWlnaHQ6IDMwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IENvbnRhaW5lckRpdiA9IHN0eWxlZC5kaXZgXG4gICY6aG92ZXIgYnV0dG9uIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgb3BhY2l0eTogMC41O1xuICB9XG5cbiAgJiBoMiB7XG4gICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgIGxlZnQ6IC0yZW07XG4gIH1cbmA7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIHRpdGxlPzogc3RyaW5nIHwgbnVsbDtcbiAgY29udGVudD86IHN0cmluZyB8IG51bGw7XG4gIGh5ZHJhdGU/OiBib29sZWFuO1xufVxuXG5pbnRlcmZhY2UgV3JhcHBlclByb3BzIHtcbiAgdGl0bGU6IHN0cmluZztcbiAgaHlkcmF0ZT86IGJvb2xlYW47XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59XG5cbmNvbnN0IFdyYXBwZXJDb21wb25lbnQgPSAoeyB0aXRsZSwgaHlkcmF0ZSwgY2hpbGRyZW4gfTogV3JhcHBlclByb3BzKSA9PiB7XG4gIGlmIChoeWRyYXRlKSB7XG4gICAgcmV0dXJuIDw+e2NoaWxkcmVufTwvPjtcbiAgfVxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXJEaXYgZGF0YS1oZWFkZXItY29weS1jb250YWluZXIgZGF0YS10aXRsZT17dGl0bGV9PlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvQ29udGFpbmVyRGl2PlxuICApO1xufTtcblxuY29uc3QgQ29weVBhcmFncmFwaEJ1dHRvbiA9ICh7IHRpdGxlLCBjb250ZW50LCBoeWRyYXRlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgW2hhc0NvcGllZCwgc2V0SGFzQ29waWVkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaGFzQ29waWVkKSB7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHNldEhhc0NvcGllZChmYWxzZSksIDMwMDApO1xuICAgIH1cbiAgfSwgW2hhc0NvcGllZF0pO1xuXG4gIGlmICghdGl0bGUpIHJldHVybiBudWxsO1xuXG4gIGNvbnN0IG9uQ29weUNsaWNrID0gKGV2ZW50OiBSZWFjdC5Nb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50LCBNb3VzZUV2ZW50Pik6IHZvaWQgPT4ge1xuICAgIHNldEhhc0NvcGllZCh0cnVlKTtcbiAgICBjb25zdCBjb3B5SWQgPSBldmVudC5jdXJyZW50VGFyZ2V0LmdldEF0dHJpYnV0ZSgnZGF0YS10aXRsZScpO1xuICAgIGNvbnN0IHsgbG9jYXRpb24gfSA9IHdpbmRvdztcbiAgICBjb25zdCBuZXdIYXNoID0gYCMke2NvcHlJZH1gO1xuICAgIGNvbnN0IHBvcnQgPSBsb2NhdGlvbi5wb3J0ID8gYDoke2xvY2F0aW9uLnBvcnR9YCA6ICcnO1xuICAgIGNvbnN0IHVybFRvQ29weSA9IGAke2xvY2F0aW9uLnByb3RvY29sfS8vJHtsb2NhdGlvbi5ob3N0bmFtZX0ke3BvcnR9JHtsb2NhdGlvbi5wYXRobmFtZX0ke2xvY2F0aW9uLnNlYXJjaH0ke25ld0hhc2h9YDtcblxuICAgIGNvcHlUZXh0VG9DbGlwYm9hcmQodXJsVG9Db3B5KTtcbiAgfTtcblxuICBjb25zdCBzYW5pdGl6ZWRUaXRsZSA9IGVuY29kZVVSSUNvbXBvbmVudCh0aXRsZS5yZXBsYWNlKC8gL2csICctJykpO1xuICBjb25zdCB0b29sdGlwID0gaGFzQ29waWVkID8gdCgnYXJ0aWNsZS5jb3B5UGFnZUxpbmtDb3BpZWQnKSA6IHQoJ2FydGljbGUuY29weUhlYWRlckxpbmsnKTtcblxuICByZXR1cm4gKFxuICAgIDxXcmFwcGVyQ29tcG9uZW50IGh5ZHJhdGU9e2h5ZHJhdGV9IHRpdGxlPXt0aXRsZX0+XG4gICAgICA8SWNvbkJ1dHRvbiBvbkNsaWNrPXtvbkNvcHlDbGlja30gZGF0YS10aXRsZT17c2FuaXRpemVkVGl0bGV9PlxuICAgICAgICA8VG9vbHRpcCB0b29sdGlwPXt0b29sdGlwfT5cbiAgICAgICAgICA8TGluayB0aXRsZT17Jyd9IC8+XG4gICAgICAgIDwvVG9vbHRpcD5cbiAgICAgIDwvSWNvbkJ1dHRvbj5cbiAgICAgIDxoMiBpZD17c2FuaXRpemVkVGl0bGV9IHRhYkluZGV4PXswfSBkYW5nZXJvdXNseVNldElubmVySFRNTD17eyBfX2h0bWw6IGNvbnRlbnQgfHwgJycgfX0+PC9oMj5cbiAgICA8L1dyYXBwZXJDb21wb25lbnQ+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBDb3B5UGFyYWdyYXBoQnV0dG9uO1xuIl19 */",
52
+ name: "1b7r8js",
53
+ styles: "position:relative;&:hover button{cursor:pointer;opacity:0.5;}",
54
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlQYXJhZ3JhcGhCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlDK0IiLCJmaWxlIjoiQ29weVBhcmFncmFwaEJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUsIHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IExpbmsgfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0Jztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBUb29sdGlwIGZyb20gJ0BuZGxhL3Rvb2x0aXAnO1xuaW1wb3J0IHsgY29weVRleHRUb0NsaXBib2FyZCB9IGZyb20gJ0BuZGxhL3V0aWwnO1xuXG5jb25zdCBJY29uQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBsZWZ0OiAtM2VtO1xuICB0b3A6IDAuMWVtO1xuICBiYWNrZ3JvdW5kOiBub25lO1xuICBib3JkZXI6IDA7XG4gIHotaW5kZXg6IDE7XG4gIHRyYW5zaXRpb246IDAuMnM7XG4gIG9wYWNpdHk6IDA7XG5cbiAgJiBzdmcge1xuICAgIHdpZHRoOiAzMHB4O1xuICAgIGhlaWdodDogMzBweDtcbiAgfVxuYDtcblxuY29uc3QgQ29udGFpbmVyRGl2ID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAmOmhvdmVyIGJ1dHRvbiB7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIG9wYWNpdHk6IDAuNTtcbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgdGl0bGU/OiBzdHJpbmcgfCBudWxsO1xuICBjb250ZW50Pzogc3RyaW5nIHwgbnVsbDtcbiAgaHlkcmF0ZT86IGJvb2xlYW47XG59XG5cbmludGVyZmFjZSBXcmFwcGVyUHJvcHMge1xuICB0aXRsZTogc3RyaW5nO1xuICBoeWRyYXRlPzogYm9vbGVhbjtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn1cblxuY29uc3QgV3JhcHBlckNvbXBvbmVudCA9ICh7IHRpdGxlLCBoeWRyYXRlLCBjaGlsZHJlbiB9OiBXcmFwcGVyUHJvcHMpID0+IHtcbiAgaWYgKGh5ZHJhdGUpIHtcbiAgICByZXR1cm4gPD57Y2hpbGRyZW59PC8+O1xuICB9XG4gIHJldHVybiAoXG4gICAgPENvbnRhaW5lckRpdiBkYXRhLWhlYWRlci1jb3B5LWNvbnRhaW5lciBkYXRhLXRpdGxlPXt0aXRsZX0+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9Db250YWluZXJEaXY+XG4gICk7XG59O1xuXG5jb25zdCBDb3B5UGFyYWdyYXBoQnV0dG9uID0gKHsgdGl0bGUsIGNvbnRlbnQsIGh5ZHJhdGUgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBjb25zdCBbaGFzQ29waWVkLCBzZXRIYXNDb3BpZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChoYXNDb3BpZWQpIHtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4gc2V0SGFzQ29waWVkKGZhbHNlKSwgMzAwMCk7XG4gICAgfVxuICB9LCBbaGFzQ29waWVkXSk7XG5cbiAgaWYgKCF0aXRsZSkgcmV0dXJuIG51bGw7XG5cbiAgY29uc3Qgb25Db3B5Q2xpY2sgPSAoZXZlbnQ6IFJlYWN0Lk1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQsIE1vdXNlRXZlbnQ+KTogdm9pZCA9PiB7XG4gICAgc2V0SGFzQ29waWVkKHRydWUpO1xuICAgIGNvbnN0IGNvcHlJZCA9IGV2ZW50LmN1cnJlbnRUYXJnZXQuZ2V0QXR0cmlidXRlKCdkYXRhLXRpdGxlJyk7XG4gICAgY29uc3QgeyBsb2NhdGlvbiB9ID0gd2luZG93O1xuICAgIGNvbnN0IG5ld0hhc2ggPSBgIyR7Y29weUlkfWA7XG4gICAgY29uc3QgcG9ydCA9IGxvY2F0aW9uLnBvcnQgPyBgOiR7bG9jYXRpb24ucG9ydH1gIDogJyc7XG4gICAgY29uc3QgdXJsVG9Db3B5ID0gYCR7bG9jYXRpb24ucHJvdG9jb2x9Ly8ke2xvY2F0aW9uLmhvc3RuYW1lfSR7cG9ydH0ke2xvY2F0aW9uLnBhdGhuYW1lfSR7bG9jYXRpb24uc2VhcmNofSR7bmV3SGFzaH1gO1xuXG4gICAgY29weVRleHRUb0NsaXBib2FyZCh1cmxUb0NvcHkpO1xuICB9O1xuXG4gIGNvbnN0IHNhbml0aXplZFRpdGxlID0gZW5jb2RlVVJJQ29tcG9uZW50KHRpdGxlLnJlcGxhY2UoLyAvZywgJy0nKSk7XG4gIGNvbnN0IHRvb2x0aXAgPSBoYXNDb3BpZWQgPyB0KCdhcnRpY2xlLmNvcHlQYWdlTGlua0NvcGllZCcpIDogdCgnYXJ0aWNsZS5jb3B5SGVhZGVyTGluaycpO1xuXG4gIHJldHVybiAoXG4gICAgPFdyYXBwZXJDb21wb25lbnQgaHlkcmF0ZT17aHlkcmF0ZX0gdGl0bGU9e3RpdGxlfT5cbiAgICAgIDxJY29uQnV0dG9uIG9uQ2xpY2s9e29uQ29weUNsaWNrfSBkYXRhLXRpdGxlPXtzYW5pdGl6ZWRUaXRsZX0+XG4gICAgICAgIDxUb29sdGlwIHRvb2x0aXA9e3Rvb2x0aXB9PlxuICAgICAgICAgIDxMaW5rIHRpdGxlPXsnJ30gLz5cbiAgICAgICAgPC9Ub29sdGlwPlxuICAgICAgPC9JY29uQnV0dG9uPlxuICAgICAgPGgyIGlkPXtzYW5pdGl6ZWRUaXRsZX0gdGFiSW5kZXg9ezB9IGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7IF9faHRtbDogY29udGVudCB8fCAnJyB9fT48L2gyPlxuICAgIDwvV3JhcHBlckNvbXBvbmVudD5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENvcHlQYXJhZ3JhcGhCdXR0b247XG4iXX0= */",
55
55
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
56
56
  });
57
57
 
@@ -21,12 +21,12 @@ var StyledWrapper = _styled("section", {
21
21
  from: breakpoints.tablet
22
22
  }), "{width:550px;}", mq.range({
23
23
  from: breakpoints.desktop
24
- }), "{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":"AAeoC","file":"FrontpageSearch.tsx","sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport { isIE, browserVersion, isMobileSafari } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { History } from 'history';\nimport { colors, spacing, mq, breakpoints, animations } from '@ndla/core';\n// @ts-ignore\nimport { noScroll } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { SearchField } from '../Search';\nimport { SearchFieldForm } from '../Search/SearchFieldForm';\n// @ts-ignore\nimport SearchResultSleeve from '../Search/SearchResultSleeve';\nimport { ContentTypeResultType, Resource } from '../types';\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: React.FormEvent) => void;\n  allResultUrl: string;\n  searchResult: Array<ContentTypeResultType>;\n  infoText: string;\n  loading: boolean;\n  history: History;\n  suggestion: string;\n  suggestionUrl: string;\n};\n\nconst FrontpageSearch: React.FunctionComponent<Props> = ({\n  resourceToLinkProps,\n  inputHasFocus,\n  searchFieldValue,\n  onSearchFieldChange,\n  searchFieldPlaceholder,\n  onInputBlur,\n  onSearchInputFocus,\n  onSearch,\n  allResultUrl,\n  searchResult,\n  loading,\n  history,\n  suggestion,\n  suggestionUrl,\n}) => {\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 resetScroll = () => {\n      window.scrollTo({ top: yCoordinate });\n    };\n    if (inputHasFocus && searchFieldRef && searchFieldRef.current) {\n      yCoordinate = searchFieldRef.current.getBoundingClientRect().top + window.pageYOffset;\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    };\n  }, [inputHasFocus]);\n\n  const onBlur = () => {\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              history={history}\n              suggestion={suggestion}\n              suggestionUrl={suggestionUrl}\n            />\n          )}\n        </SearchFieldForm>\n      </StyledWrapper>\n    </div>\n  );\n};\n\nexport default FrontpageSearch;\n"]} */"));
24
+ }), "{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":"AAeoC","file":"FrontpageSearch.tsx","sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport { isIE, browserVersion, isMobileSafari } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { History } from 'history';\nimport { colors, spacing, mq, breakpoints, animations } from '@ndla/core';\n// @ts-ignore\nimport { noScroll } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { SearchField } from '../Search';\nimport { SearchFieldForm } from '../Search/SearchFieldForm';\n// @ts-ignore\nimport SearchResultSleeve from '../Search/SearchResultSleeve';\nimport { ContentTypeResultType, Resource } from '../types';\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: React.FormEvent) => void;\n  allResultUrl: string;\n  searchResult: Array<ContentTypeResultType>;\n  loading: boolean;\n  history: History;\n  suggestion: string;\n  suggestionUrl: string;\n};\n\nconst FrontpageSearch: React.FunctionComponent<Props> = ({\n  resourceToLinkProps,\n  inputHasFocus,\n  searchFieldValue,\n  onSearchFieldChange,\n  searchFieldPlaceholder,\n  onInputBlur,\n  onSearchInputFocus,\n  onSearch,\n  allResultUrl,\n  searchResult,\n  loading,\n  history,\n  suggestion,\n  suggestionUrl,\n}) => {\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 resetScroll = () => {\n      window.scrollTo({ top: yCoordinate });\n    };\n    if (inputHasFocus && searchFieldRef && searchFieldRef.current) {\n      yCoordinate = searchFieldRef.current.getBoundingClientRect().top + window.pageYOffset;\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    };\n  }, [inputHasFocus]);\n\n  const onBlur = () => {\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              history={history}\n              suggestion={suggestion}\n              suggestionUrl={suggestionUrl}\n            />\n          )}\n        </SearchFieldForm>\n      </StyledWrapper>\n    </div>\n  );\n};\n\nexport default FrontpageSearch;\n"]} */"));
25
25
 
26
26
  var StyledSearchBackdrop = _styled("div", {
27
27
  target: "e8xkl601",
28
28
  label: "StyledSearchBackdrop"
29
- })("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":"AAiCuC","file":"FrontpageSearch.tsx","sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport { isIE, browserVersion, isMobileSafari } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { History } from 'history';\nimport { colors, spacing, mq, breakpoints, animations } from '@ndla/core';\n// @ts-ignore\nimport { noScroll } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { SearchField } from '../Search';\nimport { SearchFieldForm } from '../Search/SearchFieldForm';\n// @ts-ignore\nimport SearchResultSleeve from '../Search/SearchResultSleeve';\nimport { ContentTypeResultType, Resource } from '../types';\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: React.FormEvent) => void;\n  allResultUrl: string;\n  searchResult: Array<ContentTypeResultType>;\n  infoText: string;\n  loading: boolean;\n  history: History;\n  suggestion: string;\n  suggestionUrl: string;\n};\n\nconst FrontpageSearch: React.FunctionComponent<Props> = ({\n  resourceToLinkProps,\n  inputHasFocus,\n  searchFieldValue,\n  onSearchFieldChange,\n  searchFieldPlaceholder,\n  onInputBlur,\n  onSearchInputFocus,\n  onSearch,\n  allResultUrl,\n  searchResult,\n  loading,\n  history,\n  suggestion,\n  suggestionUrl,\n}) => {\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 resetScroll = () => {\n      window.scrollTo({ top: yCoordinate });\n    };\n    if (inputHasFocus && searchFieldRef && searchFieldRef.current) {\n      yCoordinate = searchFieldRef.current.getBoundingClientRect().top + window.pageYOffset;\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    };\n  }, [inputHasFocus]);\n\n  const onBlur = () => {\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              history={history}\n              suggestion={suggestion}\n              suggestionUrl={suggestionUrl}\n            />\n          )}\n        </SearchFieldForm>\n      </StyledWrapper>\n    </div>\n  );\n};\n\nexport default FrontpageSearch;\n"]} */"));
29
+ })("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":"AAiCuC","file":"FrontpageSearch.tsx","sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport { isIE, browserVersion, isMobileSafari } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { History } from 'history';\nimport { colors, spacing, mq, breakpoints, animations } from '@ndla/core';\n// @ts-ignore\nimport { noScroll } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { SearchField } from '../Search';\nimport { SearchFieldForm } from '../Search/SearchFieldForm';\n// @ts-ignore\nimport SearchResultSleeve from '../Search/SearchResultSleeve';\nimport { ContentTypeResultType, Resource } from '../types';\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: React.FormEvent) => void;\n  allResultUrl: string;\n  searchResult: Array<ContentTypeResultType>;\n  loading: boolean;\n  history: History;\n  suggestion: string;\n  suggestionUrl: string;\n};\n\nconst FrontpageSearch: React.FunctionComponent<Props> = ({\n  resourceToLinkProps,\n  inputHasFocus,\n  searchFieldValue,\n  onSearchFieldChange,\n  searchFieldPlaceholder,\n  onInputBlur,\n  onSearchInputFocus,\n  onSearch,\n  allResultUrl,\n  searchResult,\n  loading,\n  history,\n  suggestion,\n  suggestionUrl,\n}) => {\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 resetScroll = () => {\n      window.scrollTo({ top: yCoordinate });\n    };\n    if (inputHasFocus && searchFieldRef && searchFieldRef.current) {\n      yCoordinate = searchFieldRef.current.getBoundingClientRect().top + window.pageYOffset;\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    };\n  }, [inputHasFocus]);\n\n  const onBlur = () => {\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              history={history}\n              suggestion={suggestion}\n              suggestionUrl={suggestionUrl}\n            />\n          )}\n        </SearchFieldForm>\n      </StyledWrapper>\n    </div>\n  );\n};\n\nexport default FrontpageSearch;\n"]} */"));
30
30
 
31
31
  var FrontpageSearch = function FrontpageSearch(_ref) {
32
32
  var resourceToLinkProps = _ref.resourceToLinkProps,
@@ -45,24 +45,24 @@ var IconButton = (0, _styledBase["default"])("button", {
45
45
  target: "e18czas70",
46
46
  label: "IconButton"
47
47
  })(process.env.NODE_ENV === "production" ? {
48
- name: "1eoah0f",
49
- styles: "float:left;position:relative;left:-3em;top:0.1em;background:none;border:0;z-index:1;transition:0.2s;opacity:0;& svg{width:30px;height:30px;}"
48
+ name: "3epkb7",
49
+ 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;}"
50
50
  } : {
51
- name: "1eoah0f",
52
- styles: "float:left;position:relative;left:-3em;top:0.1em;background:none;border:0;z-index:1;transition:0.2s;opacity:0;& svg{width:30px;height:30px;}",
53
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlQYXJhZ3JhcGhCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCZ0MiLCJmaWxlIjoiQ29weVBhcmFncmFwaEJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUsIHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IExpbmsgfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0Jztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBUb29sdGlwIGZyb20gJ0BuZGxhL3Rvb2x0aXAnO1xuaW1wb3J0IHsgY29weVRleHRUb0NsaXBib2FyZCB9IGZyb20gJ0BuZGxhL3V0aWwnO1xuXG5jb25zdCBJY29uQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgZmxvYXQ6IGxlZnQ7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbGVmdDogLTNlbTtcbiAgdG9wOiAwLjFlbTtcbiAgYmFja2dyb3VuZDogbm9uZTtcbiAgYm9yZGVyOiAwO1xuICB6LWluZGV4OiAxO1xuICB0cmFuc2l0aW9uOiAwLjJzO1xuICBvcGFjaXR5OiAwO1xuXG4gICYgc3ZnIHtcbiAgICB3aWR0aDogMzBweDtcbiAgICBoZWlnaHQ6IDMwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IENvbnRhaW5lckRpdiA9IHN0eWxlZC5kaXZgXG4gICY6aG92ZXIgYnV0dG9uIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgb3BhY2l0eTogMC41O1xuICB9XG5cbiAgJiBoMiB7XG4gICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgIGxlZnQ6IC0yZW07XG4gIH1cbmA7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIHRpdGxlPzogc3RyaW5nIHwgbnVsbDtcbiAgY29udGVudD86IHN0cmluZyB8IG51bGw7XG4gIGh5ZHJhdGU/OiBib29sZWFuO1xufVxuXG5pbnRlcmZhY2UgV3JhcHBlclByb3BzIHtcbiAgdGl0bGU6IHN0cmluZztcbiAgaHlkcmF0ZT86IGJvb2xlYW47XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59XG5cbmNvbnN0IFdyYXBwZXJDb21wb25lbnQgPSAoeyB0aXRsZSwgaHlkcmF0ZSwgY2hpbGRyZW4gfTogV3JhcHBlclByb3BzKSA9PiB7XG4gIGlmIChoeWRyYXRlKSB7XG4gICAgcmV0dXJuIDw+e2NoaWxkcmVufTwvPjtcbiAgfVxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXJEaXYgZGF0YS1oZWFkZXItY29weS1jb250YWluZXIgZGF0YS10aXRsZT17dGl0bGV9PlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvQ29udGFpbmVyRGl2PlxuICApO1xufTtcblxuY29uc3QgQ29weVBhcmFncmFwaEJ1dHRvbiA9ICh7IHRpdGxlLCBjb250ZW50LCBoeWRyYXRlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgW2hhc0NvcGllZCwgc2V0SGFzQ29waWVkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaGFzQ29waWVkKSB7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHNldEhhc0NvcGllZChmYWxzZSksIDMwMDApO1xuICAgIH1cbiAgfSwgW2hhc0NvcGllZF0pO1xuXG4gIGlmICghdGl0bGUpIHJldHVybiBudWxsO1xuXG4gIGNvbnN0IG9uQ29weUNsaWNrID0gKGV2ZW50OiBSZWFjdC5Nb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50LCBNb3VzZUV2ZW50Pik6IHZvaWQgPT4ge1xuICAgIHNldEhhc0NvcGllZCh0cnVlKTtcbiAgICBjb25zdCBjb3B5SWQgPSBldmVudC5jdXJyZW50VGFyZ2V0LmdldEF0dHJpYnV0ZSgnZGF0YS10aXRsZScpO1xuICAgIGNvbnN0IHsgbG9jYXRpb24gfSA9IHdpbmRvdztcbiAgICBjb25zdCBuZXdIYXNoID0gYCMke2NvcHlJZH1gO1xuICAgIGNvbnN0IHBvcnQgPSBsb2NhdGlvbi5wb3J0ID8gYDoke2xvY2F0aW9uLnBvcnR9YCA6ICcnO1xuICAgIGNvbnN0IHVybFRvQ29weSA9IGAke2xvY2F0aW9uLnByb3RvY29sfS8vJHtsb2NhdGlvbi5ob3N0bmFtZX0ke3BvcnR9JHtsb2NhdGlvbi5wYXRobmFtZX0ke2xvY2F0aW9uLnNlYXJjaH0ke25ld0hhc2h9YDtcblxuICAgIGNvcHlUZXh0VG9DbGlwYm9hcmQodXJsVG9Db3B5KTtcbiAgfTtcblxuICBjb25zdCBzYW5pdGl6ZWRUaXRsZSA9IGVuY29kZVVSSUNvbXBvbmVudCh0aXRsZS5yZXBsYWNlKC8gL2csICctJykpO1xuICBjb25zdCB0b29sdGlwID0gaGFzQ29waWVkID8gdCgnYXJ0aWNsZS5jb3B5UGFnZUxpbmtDb3BpZWQnKSA6IHQoJ2FydGljbGUuY29weUhlYWRlckxpbmsnKTtcblxuICByZXR1cm4gKFxuICAgIDxXcmFwcGVyQ29tcG9uZW50IGh5ZHJhdGU9e2h5ZHJhdGV9IHRpdGxlPXt0aXRsZX0+XG4gICAgICA8SWNvbkJ1dHRvbiBvbkNsaWNrPXtvbkNvcHlDbGlja30gZGF0YS10aXRsZT17c2FuaXRpemVkVGl0bGV9PlxuICAgICAgICA8VG9vbHRpcCB0b29sdGlwPXt0b29sdGlwfT5cbiAgICAgICAgICA8TGluayB0aXRsZT17Jyd9IC8+XG4gICAgICAgIDwvVG9vbHRpcD5cbiAgICAgIDwvSWNvbkJ1dHRvbj5cbiAgICAgIDxoMiBpZD17c2FuaXRpemVkVGl0bGV9IHRhYkluZGV4PXswfSBkYW5nZXJvdXNseVNldElubmVySFRNTD17eyBfX2h0bWw6IGNvbnRlbnQgfHwgJycgfX0+PC9oMj5cbiAgICA8L1dyYXBwZXJDb21wb25lbnQ+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBDb3B5UGFyYWdyYXBoQnV0dG9uO1xuIl19 */",
51
+ name: "3epkb7",
52
+ 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;}",
53
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlQYXJhZ3JhcGhCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCZ0MiLCJmaWxlIjoiQ29weVBhcmFncmFwaEJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUsIHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IExpbmsgfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0Jztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBUb29sdGlwIGZyb20gJ0BuZGxhL3Rvb2x0aXAnO1xuaW1wb3J0IHsgY29weVRleHRUb0NsaXBib2FyZCB9IGZyb20gJ0BuZGxhL3V0aWwnO1xuXG5jb25zdCBJY29uQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBsZWZ0OiAtM2VtO1xuICB0b3A6IDAuMWVtO1xuICBiYWNrZ3JvdW5kOiBub25lO1xuICBib3JkZXI6IDA7XG4gIHotaW5kZXg6IDE7XG4gIHRyYW5zaXRpb246IDAuMnM7XG4gIG9wYWNpdHk6IDA7XG5cbiAgJiBzdmcge1xuICAgIHdpZHRoOiAzMHB4O1xuICAgIGhlaWdodDogMzBweDtcbiAgfVxuYDtcblxuY29uc3QgQ29udGFpbmVyRGl2ID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAmOmhvdmVyIGJ1dHRvbiB7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIG9wYWNpdHk6IDAuNTtcbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgdGl0bGU/OiBzdHJpbmcgfCBudWxsO1xuICBjb250ZW50Pzogc3RyaW5nIHwgbnVsbDtcbiAgaHlkcmF0ZT86IGJvb2xlYW47XG59XG5cbmludGVyZmFjZSBXcmFwcGVyUHJvcHMge1xuICB0aXRsZTogc3RyaW5nO1xuICBoeWRyYXRlPzogYm9vbGVhbjtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn1cblxuY29uc3QgV3JhcHBlckNvbXBvbmVudCA9ICh7IHRpdGxlLCBoeWRyYXRlLCBjaGlsZHJlbiB9OiBXcmFwcGVyUHJvcHMpID0+IHtcbiAgaWYgKGh5ZHJhdGUpIHtcbiAgICByZXR1cm4gPD57Y2hpbGRyZW59PC8+O1xuICB9XG4gIHJldHVybiAoXG4gICAgPENvbnRhaW5lckRpdiBkYXRhLWhlYWRlci1jb3B5LWNvbnRhaW5lciBkYXRhLXRpdGxlPXt0aXRsZX0+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9Db250YWluZXJEaXY+XG4gICk7XG59O1xuXG5jb25zdCBDb3B5UGFyYWdyYXBoQnV0dG9uID0gKHsgdGl0bGUsIGNvbnRlbnQsIGh5ZHJhdGUgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBjb25zdCBbaGFzQ29waWVkLCBzZXRIYXNDb3BpZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChoYXNDb3BpZWQpIHtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4gc2V0SGFzQ29waWVkKGZhbHNlKSwgMzAwMCk7XG4gICAgfVxuICB9LCBbaGFzQ29waWVkXSk7XG5cbiAgaWYgKCF0aXRsZSkgcmV0dXJuIG51bGw7XG5cbiAgY29uc3Qgb25Db3B5Q2xpY2sgPSAoZXZlbnQ6IFJlYWN0Lk1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQsIE1vdXNlRXZlbnQ+KTogdm9pZCA9PiB7XG4gICAgc2V0SGFzQ29waWVkKHRydWUpO1xuICAgIGNvbnN0IGNvcHlJZCA9IGV2ZW50LmN1cnJlbnRUYXJnZXQuZ2V0QXR0cmlidXRlKCdkYXRhLXRpdGxlJyk7XG4gICAgY29uc3QgeyBsb2NhdGlvbiB9ID0gd2luZG93O1xuICAgIGNvbnN0IG5ld0hhc2ggPSBgIyR7Y29weUlkfWA7XG4gICAgY29uc3QgcG9ydCA9IGxvY2F0aW9uLnBvcnQgPyBgOiR7bG9jYXRpb24ucG9ydH1gIDogJyc7XG4gICAgY29uc3QgdXJsVG9Db3B5ID0gYCR7bG9jYXRpb24ucHJvdG9jb2x9Ly8ke2xvY2F0aW9uLmhvc3RuYW1lfSR7cG9ydH0ke2xvY2F0aW9uLnBhdGhuYW1lfSR7bG9jYXRpb24uc2VhcmNofSR7bmV3SGFzaH1gO1xuXG4gICAgY29weVRleHRUb0NsaXBib2FyZCh1cmxUb0NvcHkpO1xuICB9O1xuXG4gIGNvbnN0IHNhbml0aXplZFRpdGxlID0gZW5jb2RlVVJJQ29tcG9uZW50KHRpdGxlLnJlcGxhY2UoLyAvZywgJy0nKSk7XG4gIGNvbnN0IHRvb2x0aXAgPSBoYXNDb3BpZWQgPyB0KCdhcnRpY2xlLmNvcHlQYWdlTGlua0NvcGllZCcpIDogdCgnYXJ0aWNsZS5jb3B5SGVhZGVyTGluaycpO1xuXG4gIHJldHVybiAoXG4gICAgPFdyYXBwZXJDb21wb25lbnQgaHlkcmF0ZT17aHlkcmF0ZX0gdGl0bGU9e3RpdGxlfT5cbiAgICAgIDxJY29uQnV0dG9uIG9uQ2xpY2s9e29uQ29weUNsaWNrfSBkYXRhLXRpdGxlPXtzYW5pdGl6ZWRUaXRsZX0+XG4gICAgICAgIDxUb29sdGlwIHRvb2x0aXA9e3Rvb2x0aXB9PlxuICAgICAgICAgIDxMaW5rIHRpdGxlPXsnJ30gLz5cbiAgICAgICAgPC9Ub29sdGlwPlxuICAgICAgPC9JY29uQnV0dG9uPlxuICAgICAgPGgyIGlkPXtzYW5pdGl6ZWRUaXRsZX0gdGFiSW5kZXg9ezB9IGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7IF9faHRtbDogY29udGVudCB8fCAnJyB9fT48L2gyPlxuICAgIDwvV3JhcHBlckNvbXBvbmVudD5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENvcHlQYXJhZ3JhcGhCdXR0b247XG4iXX0= */",
54
54
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
55
55
  });
56
56
  var ContainerDiv = (0, _styledBase["default"])("div", {
57
57
  target: "e18czas71",
58
58
  label: "ContainerDiv"
59
59
  })(process.env.NODE_ENV === "production" ? {
60
- name: "25spe5",
61
- styles: "&:hover button{cursor:pointer;opacity:0.5;}& h2{position:relative;left:-2em;}"
60
+ name: "1b7r8js",
61
+ styles: "position:relative;&:hover button{cursor:pointer;opacity:0.5;}"
62
62
  } : {
63
- name: "25spe5",
64
- styles: "&:hover button{cursor:pointer;opacity:0.5;}& h2{position:relative;left:-2em;}",
65
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlQYXJhZ3JhcGhCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtDK0IiLCJmaWxlIjoiQ29weVBhcmFncmFwaEJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUsIHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IExpbmsgfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0Jztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBUb29sdGlwIGZyb20gJ0BuZGxhL3Rvb2x0aXAnO1xuaW1wb3J0IHsgY29weVRleHRUb0NsaXBib2FyZCB9IGZyb20gJ0BuZGxhL3V0aWwnO1xuXG5jb25zdCBJY29uQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgZmxvYXQ6IGxlZnQ7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgbGVmdDogLTNlbTtcbiAgdG9wOiAwLjFlbTtcbiAgYmFja2dyb3VuZDogbm9uZTtcbiAgYm9yZGVyOiAwO1xuICB6LWluZGV4OiAxO1xuICB0cmFuc2l0aW9uOiAwLjJzO1xuICBvcGFjaXR5OiAwO1xuXG4gICYgc3ZnIHtcbiAgICB3aWR0aDogMzBweDtcbiAgICBoZWlnaHQ6IDMwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IENvbnRhaW5lckRpdiA9IHN0eWxlZC5kaXZgXG4gICY6aG92ZXIgYnV0dG9uIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgb3BhY2l0eTogMC41O1xuICB9XG5cbiAgJiBoMiB7XG4gICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgIGxlZnQ6IC0yZW07XG4gIH1cbmA7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIHRpdGxlPzogc3RyaW5nIHwgbnVsbDtcbiAgY29udGVudD86IHN0cmluZyB8IG51bGw7XG4gIGh5ZHJhdGU/OiBib29sZWFuO1xufVxuXG5pbnRlcmZhY2UgV3JhcHBlclByb3BzIHtcbiAgdGl0bGU6IHN0cmluZztcbiAgaHlkcmF0ZT86IGJvb2xlYW47XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG59XG5cbmNvbnN0IFdyYXBwZXJDb21wb25lbnQgPSAoeyB0aXRsZSwgaHlkcmF0ZSwgY2hpbGRyZW4gfTogV3JhcHBlclByb3BzKSA9PiB7XG4gIGlmIChoeWRyYXRlKSB7XG4gICAgcmV0dXJuIDw+e2NoaWxkcmVufTwvPjtcbiAgfVxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXJEaXYgZGF0YS1oZWFkZXItY29weS1jb250YWluZXIgZGF0YS10aXRsZT17dGl0bGV9PlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvQ29udGFpbmVyRGl2PlxuICApO1xufTtcblxuY29uc3QgQ29weVBhcmFncmFwaEJ1dHRvbiA9ICh7IHRpdGxlLCBjb250ZW50LCBoeWRyYXRlIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgW2hhc0NvcGllZCwgc2V0SGFzQ29waWVkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaGFzQ29waWVkKSB7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHNldEhhc0NvcGllZChmYWxzZSksIDMwMDApO1xuICAgIH1cbiAgfSwgW2hhc0NvcGllZF0pO1xuXG4gIGlmICghdGl0bGUpIHJldHVybiBudWxsO1xuXG4gIGNvbnN0IG9uQ29weUNsaWNrID0gKGV2ZW50OiBSZWFjdC5Nb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50LCBNb3VzZUV2ZW50Pik6IHZvaWQgPT4ge1xuICAgIHNldEhhc0NvcGllZCh0cnVlKTtcbiAgICBjb25zdCBjb3B5SWQgPSBldmVudC5jdXJyZW50VGFyZ2V0LmdldEF0dHJpYnV0ZSgnZGF0YS10aXRsZScpO1xuICAgIGNvbnN0IHsgbG9jYXRpb24gfSA9IHdpbmRvdztcbiAgICBjb25zdCBuZXdIYXNoID0gYCMke2NvcHlJZH1gO1xuICAgIGNvbnN0IHBvcnQgPSBsb2NhdGlvbi5wb3J0ID8gYDoke2xvY2F0aW9uLnBvcnR9YCA6ICcnO1xuICAgIGNvbnN0IHVybFRvQ29weSA9IGAke2xvY2F0aW9uLnByb3RvY29sfS8vJHtsb2NhdGlvbi5ob3N0bmFtZX0ke3BvcnR9JHtsb2NhdGlvbi5wYXRobmFtZX0ke2xvY2F0aW9uLnNlYXJjaH0ke25ld0hhc2h9YDtcblxuICAgIGNvcHlUZXh0VG9DbGlwYm9hcmQodXJsVG9Db3B5KTtcbiAgfTtcblxuICBjb25zdCBzYW5pdGl6ZWRUaXRsZSA9IGVuY29kZVVSSUNvbXBvbmVudCh0aXRsZS5yZXBsYWNlKC8gL2csICctJykpO1xuICBjb25zdCB0b29sdGlwID0gaGFzQ29waWVkID8gdCgnYXJ0aWNsZS5jb3B5UGFnZUxpbmtDb3BpZWQnKSA6IHQoJ2FydGljbGUuY29weUhlYWRlckxpbmsnKTtcblxuICByZXR1cm4gKFxuICAgIDxXcmFwcGVyQ29tcG9uZW50IGh5ZHJhdGU9e2h5ZHJhdGV9IHRpdGxlPXt0aXRsZX0+XG4gICAgICA8SWNvbkJ1dHRvbiBvbkNsaWNrPXtvbkNvcHlDbGlja30gZGF0YS10aXRsZT17c2FuaXRpemVkVGl0bGV9PlxuICAgICAgICA8VG9vbHRpcCB0b29sdGlwPXt0b29sdGlwfT5cbiAgICAgICAgICA8TGluayB0aXRsZT17Jyd9IC8+XG4gICAgICAgIDwvVG9vbHRpcD5cbiAgICAgIDwvSWNvbkJ1dHRvbj5cbiAgICAgIDxoMiBpZD17c2FuaXRpemVkVGl0bGV9IHRhYkluZGV4PXswfSBkYW5nZXJvdXNseVNldElubmVySFRNTD17eyBfX2h0bWw6IGNvbnRlbnQgfHwgJycgfX0+PC9oMj5cbiAgICA8L1dyYXBwZXJDb21wb25lbnQ+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBDb3B5UGFyYWdyYXBoQnV0dG9uO1xuIl19 */",
63
+ name: "1b7r8js",
64
+ styles: "position:relative;&:hover button{cursor:pointer;opacity:0.5;}",
65
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlQYXJhZ3JhcGhCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlDK0IiLCJmaWxlIjoiQ29weVBhcmFncmFwaEJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUsIHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IExpbmsgfSBmcm9tICdAbmRsYS9pY29ucy9jb21tb24nO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0Jztcbi8vIEB0cy1pZ25vcmVcbmltcG9ydCBUb29sdGlwIGZyb20gJ0BuZGxhL3Rvb2x0aXAnO1xuaW1wb3J0IHsgY29weVRleHRUb0NsaXBib2FyZCB9IGZyb20gJ0BuZGxhL3V0aWwnO1xuXG5jb25zdCBJY29uQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBsZWZ0OiAtM2VtO1xuICB0b3A6IDAuMWVtO1xuICBiYWNrZ3JvdW5kOiBub25lO1xuICBib3JkZXI6IDA7XG4gIHotaW5kZXg6IDE7XG4gIHRyYW5zaXRpb246IDAuMnM7XG4gIG9wYWNpdHk6IDA7XG5cbiAgJiBzdmcge1xuICAgIHdpZHRoOiAzMHB4O1xuICAgIGhlaWdodDogMzBweDtcbiAgfVxuYDtcblxuY29uc3QgQ29udGFpbmVyRGl2ID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAmOmhvdmVyIGJ1dHRvbiB7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIG9wYWNpdHk6IDAuNTtcbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgdGl0bGU/OiBzdHJpbmcgfCBudWxsO1xuICBjb250ZW50Pzogc3RyaW5nIHwgbnVsbDtcbiAgaHlkcmF0ZT86IGJvb2xlYW47XG59XG5cbmludGVyZmFjZSBXcmFwcGVyUHJvcHMge1xuICB0aXRsZTogc3RyaW5nO1xuICBoeWRyYXRlPzogYm9vbGVhbjtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn1cblxuY29uc3QgV3JhcHBlckNvbXBvbmVudCA9ICh7IHRpdGxlLCBoeWRyYXRlLCBjaGlsZHJlbiB9OiBXcmFwcGVyUHJvcHMpID0+IHtcbiAgaWYgKGh5ZHJhdGUpIHtcbiAgICByZXR1cm4gPD57Y2hpbGRyZW59PC8+O1xuICB9XG4gIHJldHVybiAoXG4gICAgPENvbnRhaW5lckRpdiBkYXRhLWhlYWRlci1jb3B5LWNvbnRhaW5lciBkYXRhLXRpdGxlPXt0aXRsZX0+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9Db250YWluZXJEaXY+XG4gICk7XG59O1xuXG5jb25zdCBDb3B5UGFyYWdyYXBoQnV0dG9uID0gKHsgdGl0bGUsIGNvbnRlbnQsIGh5ZHJhdGUgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBjb25zdCBbaGFzQ29waWVkLCBzZXRIYXNDb3BpZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChoYXNDb3BpZWQpIHtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4gc2V0SGFzQ29waWVkKGZhbHNlKSwgMzAwMCk7XG4gICAgfVxuICB9LCBbaGFzQ29waWVkXSk7XG5cbiAgaWYgKCF0aXRsZSkgcmV0dXJuIG51bGw7XG5cbiAgY29uc3Qgb25Db3B5Q2xpY2sgPSAoZXZlbnQ6IFJlYWN0Lk1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQsIE1vdXNlRXZlbnQ+KTogdm9pZCA9PiB7XG4gICAgc2V0SGFzQ29waWVkKHRydWUpO1xuICAgIGNvbnN0IGNvcHlJZCA9IGV2ZW50LmN1cnJlbnRUYXJnZXQuZ2V0QXR0cmlidXRlKCdkYXRhLXRpdGxlJyk7XG4gICAgY29uc3QgeyBsb2NhdGlvbiB9ID0gd2luZG93O1xuICAgIGNvbnN0IG5ld0hhc2ggPSBgIyR7Y29weUlkfWA7XG4gICAgY29uc3QgcG9ydCA9IGxvY2F0aW9uLnBvcnQgPyBgOiR7bG9jYXRpb24ucG9ydH1gIDogJyc7XG4gICAgY29uc3QgdXJsVG9Db3B5ID0gYCR7bG9jYXRpb24ucHJvdG9jb2x9Ly8ke2xvY2F0aW9uLmhvc3RuYW1lfSR7cG9ydH0ke2xvY2F0aW9uLnBhdGhuYW1lfSR7bG9jYXRpb24uc2VhcmNofSR7bmV3SGFzaH1gO1xuXG4gICAgY29weVRleHRUb0NsaXBib2FyZCh1cmxUb0NvcHkpO1xuICB9O1xuXG4gIGNvbnN0IHNhbml0aXplZFRpdGxlID0gZW5jb2RlVVJJQ29tcG9uZW50KHRpdGxlLnJlcGxhY2UoLyAvZywgJy0nKSk7XG4gIGNvbnN0IHRvb2x0aXAgPSBoYXNDb3BpZWQgPyB0KCdhcnRpY2xlLmNvcHlQYWdlTGlua0NvcGllZCcpIDogdCgnYXJ0aWNsZS5jb3B5SGVhZGVyTGluaycpO1xuXG4gIHJldHVybiAoXG4gICAgPFdyYXBwZXJDb21wb25lbnQgaHlkcmF0ZT17aHlkcmF0ZX0gdGl0bGU9e3RpdGxlfT5cbiAgICAgIDxJY29uQnV0dG9uIG9uQ2xpY2s9e29uQ29weUNsaWNrfSBkYXRhLXRpdGxlPXtzYW5pdGl6ZWRUaXRsZX0+XG4gICAgICAgIDxUb29sdGlwIHRvb2x0aXA9e3Rvb2x0aXB9PlxuICAgICAgICAgIDxMaW5rIHRpdGxlPXsnJ30gLz5cbiAgICAgICAgPC9Ub29sdGlwPlxuICAgICAgPC9JY29uQnV0dG9uPlxuICAgICAgPGgyIGlkPXtzYW5pdGl6ZWRUaXRsZX0gdGFiSW5kZXg9ezB9IGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MPXt7IF9faHRtbDogY29udGVudCB8fCAnJyB9fT48L2gyPlxuICAgIDwvV3JhcHBlckNvbXBvbmVudD5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENvcHlQYXJhZ3JhcGhCdXR0b247XG4iXX0= */",
66
66
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
67
67
  });
68
68
 
@@ -14,7 +14,6 @@ declare type Props = {
14
14
  onSearch: (event: React.FormEvent) => void;
15
15
  allResultUrl: string;
16
16
  searchResult: Array<ContentTypeResultType>;
17
- infoText: string;
18
17
  loading: boolean;
19
18
  history: History;
20
19
  suggestion: string;
@@ -45,11 +45,11 @@ var StyledWrapper = (0, _styledBase["default"])("section", {
45
45
  from: _core.breakpoints.tablet
46
46
  }), "{width:550px;}", _core.mq.range({
47
47
  from: _core.breakpoints.desktop
48
- }), "{width:750px;}input{border-color:", _core.colors.brand.tertiary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageSearch.tsx"],"names":[],"mappings":"AAeoC","file":"FrontpageSearch.tsx","sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport { isIE, browserVersion, isMobileSafari } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { History } from 'history';\nimport { colors, spacing, mq, breakpoints, animations } from '@ndla/core';\n// @ts-ignore\nimport { noScroll } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { SearchField } from '../Search';\nimport { SearchFieldForm } from '../Search/SearchFieldForm';\n// @ts-ignore\nimport SearchResultSleeve from '../Search/SearchResultSleeve';\nimport { ContentTypeResultType, Resource } from '../types';\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: React.FormEvent) => void;\n  allResultUrl: string;\n  searchResult: Array<ContentTypeResultType>;\n  infoText: string;\n  loading: boolean;\n  history: History;\n  suggestion: string;\n  suggestionUrl: string;\n};\n\nconst FrontpageSearch: React.FunctionComponent<Props> = ({\n  resourceToLinkProps,\n  inputHasFocus,\n  searchFieldValue,\n  onSearchFieldChange,\n  searchFieldPlaceholder,\n  onInputBlur,\n  onSearchInputFocus,\n  onSearch,\n  allResultUrl,\n  searchResult,\n  loading,\n  history,\n  suggestion,\n  suggestionUrl,\n}) => {\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 resetScroll = () => {\n      window.scrollTo({ top: yCoordinate });\n    };\n    if (inputHasFocus && searchFieldRef && searchFieldRef.current) {\n      yCoordinate = searchFieldRef.current.getBoundingClientRect().top + window.pageYOffset;\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    };\n  }, [inputHasFocus]);\n\n  const onBlur = () => {\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              history={history}\n              suggestion={suggestion}\n              suggestionUrl={suggestionUrl}\n            />\n          )}\n        </SearchFieldForm>\n      </StyledWrapper>\n    </div>\n  );\n};\n\nexport default FrontpageSearch;\n"]} */"));
48
+ }), "{width:750px;}input{border-color:", _core.colors.brand.tertiary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageSearch.tsx"],"names":[],"mappings":"AAeoC","file":"FrontpageSearch.tsx","sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport { isIE, browserVersion, isMobileSafari } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { History } from 'history';\nimport { colors, spacing, mq, breakpoints, animations } from '@ndla/core';\n// @ts-ignore\nimport { noScroll } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { SearchField } from '../Search';\nimport { SearchFieldForm } from '../Search/SearchFieldForm';\n// @ts-ignore\nimport SearchResultSleeve from '../Search/SearchResultSleeve';\nimport { ContentTypeResultType, Resource } from '../types';\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: React.FormEvent) => void;\n  allResultUrl: string;\n  searchResult: Array<ContentTypeResultType>;\n  loading: boolean;\n  history: History;\n  suggestion: string;\n  suggestionUrl: string;\n};\n\nconst FrontpageSearch: React.FunctionComponent<Props> = ({\n  resourceToLinkProps,\n  inputHasFocus,\n  searchFieldValue,\n  onSearchFieldChange,\n  searchFieldPlaceholder,\n  onInputBlur,\n  onSearchInputFocus,\n  onSearch,\n  allResultUrl,\n  searchResult,\n  loading,\n  history,\n  suggestion,\n  suggestionUrl,\n}) => {\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 resetScroll = () => {\n      window.scrollTo({ top: yCoordinate });\n    };\n    if (inputHasFocus && searchFieldRef && searchFieldRef.current) {\n      yCoordinate = searchFieldRef.current.getBoundingClientRect().top + window.pageYOffset;\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    };\n  }, [inputHasFocus]);\n\n  const onBlur = () => {\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              history={history}\n              suggestion={suggestion}\n              suggestionUrl={suggestionUrl}\n            />\n          )}\n        </SearchFieldForm>\n      </StyledWrapper>\n    </div>\n  );\n};\n\nexport default FrontpageSearch;\n"]} */"));
49
49
  var StyledSearchBackdrop = (0, _styledBase["default"])("div", {
50
50
  target: "e8xkl601",
51
51
  label: "StyledSearchBackdrop"
52
- })("position:fixed;z-index:1;top:0;left:0;right:0;bottom:0;background:rgba(1,1,1,0.3);", _core.animations.fadeIn(_core.animations.durations.fast), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageSearch.tsx"],"names":[],"mappings":"AAiCuC","file":"FrontpageSearch.tsx","sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport { isIE, browserVersion, isMobileSafari } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { History } from 'history';\nimport { colors, spacing, mq, breakpoints, animations } from '@ndla/core';\n// @ts-ignore\nimport { noScroll } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { SearchField } from '../Search';\nimport { SearchFieldForm } from '../Search/SearchFieldForm';\n// @ts-ignore\nimport SearchResultSleeve from '../Search/SearchResultSleeve';\nimport { ContentTypeResultType, Resource } from '../types';\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: React.FormEvent) => void;\n  allResultUrl: string;\n  searchResult: Array<ContentTypeResultType>;\n  infoText: string;\n  loading: boolean;\n  history: History;\n  suggestion: string;\n  suggestionUrl: string;\n};\n\nconst FrontpageSearch: React.FunctionComponent<Props> = ({\n  resourceToLinkProps,\n  inputHasFocus,\n  searchFieldValue,\n  onSearchFieldChange,\n  searchFieldPlaceholder,\n  onInputBlur,\n  onSearchInputFocus,\n  onSearch,\n  allResultUrl,\n  searchResult,\n  loading,\n  history,\n  suggestion,\n  suggestionUrl,\n}) => {\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 resetScroll = () => {\n      window.scrollTo({ top: yCoordinate });\n    };\n    if (inputHasFocus && searchFieldRef && searchFieldRef.current) {\n      yCoordinate = searchFieldRef.current.getBoundingClientRect().top + window.pageYOffset;\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    };\n  }, [inputHasFocus]);\n\n  const onBlur = () => {\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              history={history}\n              suggestion={suggestion}\n              suggestionUrl={suggestionUrl}\n            />\n          )}\n        </SearchFieldForm>\n      </StyledWrapper>\n    </div>\n  );\n};\n\nexport default FrontpageSearch;\n"]} */"));
52
+ })("position:fixed;z-index:1;top:0;left:0;right:0;bottom:0;background:rgba(1,1,1,0.3);", _core.animations.fadeIn(_core.animations.durations.fast), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageSearch.tsx"],"names":[],"mappings":"AAiCuC","file":"FrontpageSearch.tsx","sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport { isIE, browserVersion, isMobileSafari } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { History } from 'history';\nimport { colors, spacing, mq, breakpoints, animations } from '@ndla/core';\n// @ts-ignore\nimport { noScroll } from '@ndla/util';\nimport { useTranslation } from 'react-i18next';\n// @ts-ignore\nimport { SearchField } from '../Search';\nimport { SearchFieldForm } from '../Search/SearchFieldForm';\n// @ts-ignore\nimport SearchResultSleeve from '../Search/SearchResultSleeve';\nimport { ContentTypeResultType, Resource } from '../types';\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: React.FormEvent) => void;\n  allResultUrl: string;\n  searchResult: Array<ContentTypeResultType>;\n  loading: boolean;\n  history: History;\n  suggestion: string;\n  suggestionUrl: string;\n};\n\nconst FrontpageSearch: React.FunctionComponent<Props> = ({\n  resourceToLinkProps,\n  inputHasFocus,\n  searchFieldValue,\n  onSearchFieldChange,\n  searchFieldPlaceholder,\n  onInputBlur,\n  onSearchInputFocus,\n  onSearch,\n  allResultUrl,\n  searchResult,\n  loading,\n  history,\n  suggestion,\n  suggestionUrl,\n}) => {\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 resetScroll = () => {\n      window.scrollTo({ top: yCoordinate });\n    };\n    if (inputHasFocus && searchFieldRef && searchFieldRef.current) {\n      yCoordinate = searchFieldRef.current.getBoundingClientRect().top + window.pageYOffset;\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    };\n  }, [inputHasFocus]);\n\n  const onBlur = () => {\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              history={history}\n              suggestion={suggestion}\n              suggestionUrl={suggestionUrl}\n            />\n          )}\n        </SearchFieldForm>\n      </StyledWrapper>\n    </div>\n  );\n};\n\nexport default FrontpageSearch;\n"]} */"));
53
53
 
54
54
  var FrontpageSearch = function FrontpageSearch(_ref) {
55
55
  var resourceToLinkProps = _ref.resourceToLinkProps,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ndla/ui",
3
- "version": "3.3.3",
3
+ "version": "3.3.4",
4
4
  "description": "UI component library for NDLA.",
5
5
  "license": "GPL-3.0",
6
6
  "main": "lib/index.js",
@@ -36,7 +36,7 @@
36
36
  "@ndla/core": "^0.7.2",
37
37
  "@ndla/hooks": "^1.0.7",
38
38
  "@ndla/icons": "^1.3.1",
39
- "@ndla/licenses": "^1.1.1",
39
+ "@ndla/licenses": "^1.1.2",
40
40
  "@ndla/modal": "^1.1.15",
41
41
  "@ndla/safelink": "^1.0.6",
42
42
  "@ndla/switch": "^0.0.32",
@@ -92,5 +92,5 @@
92
92
  "publishConfig": {
93
93
  "access": "public"
94
94
  },
95
- "gitHead": "5ec937851624b9d911db185f20ecc19d87799a35"
95
+ "gitHead": "b942d7a2961b0f8961a95dd4578b3fb589db82a5"
96
96
  }
@@ -16,8 +16,7 @@ import Tooltip from '@ndla/tooltip';
16
16
  import { copyTextToClipboard } from '@ndla/util';
17
17
 
18
18
  const IconButton = styled.button`
19
- float: left;
20
- position: relative;
19
+ position: absolute;
21
20
  left: -3em;
22
21
  top: 0.1em;
23
22
  background: none;
@@ -33,15 +32,11 @@ const IconButton = styled.button`
33
32
  `;
34
33
 
35
34
  const ContainerDiv = styled.div`
35
+ position: relative;
36
36
  &:hover button {
37
37
  cursor: pointer;
38
38
  opacity: 0.5;
39
39
  }
40
-
41
- & h2 {
42
- position: relative;
43
- left: -2em;
44
- }
45
40
  `;
46
41
 
47
42
  interface Props {
@@ -55,7 +55,6 @@ type Props = {
55
55
  onSearch: (event: React.FormEvent) => void;
56
56
  allResultUrl: string;
57
57
  searchResult: Array<ContentTypeResultType>;
58
- infoText: string;
59
58
  loading: boolean;
60
59
  history: History;
61
60
  suggestion: string;