@ndla/ui 19.2.0 → 20.0.0
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/MyNdla/Resource/FolderInput.js +29 -36
- package/es/NDLAFilm/FilmSlideshow.js +8 -8
- package/es/Search/LoadingWrapper.js +2 -2
- package/es/Search/SearchResult.js +1 -1
- package/es/SearchTypeResult/SearchTypeResult.js +3 -3
- package/es/TreeStructure/FolderNameInput.js +5 -5
- package/es/index.js +0 -1
- package/es/locale/messages-en.js +4 -1
- package/es/locale/messages-nb.js +4 -1
- package/es/locale/messages-nn.js +4 -1
- package/es/locale/messages-se.js +4 -1
- package/es/locale/messages-sma.js +4 -1
- package/lib/MyNdla/Resource/FolderInput.d.ts +2 -2
- package/lib/MyNdla/Resource/FolderInput.js +26 -33
- package/lib/NDLAFilm/FilmSlideshow.js +10 -10
- package/lib/Search/LoadingWrapper.js +3 -3
- package/lib/Search/SearchResult.js +2 -2
- package/lib/SearchTypeResult/SearchTypeResult.js +4 -4
- package/lib/TreeStructure/FolderNameInput.js +6 -6
- package/lib/index.d.ts +0 -1
- package/lib/index.js +0 -9
- package/lib/locale/messages-en.d.ts +3 -0
- package/lib/locale/messages-en.js +4 -1
- package/lib/locale/messages-nb.d.ts +3 -0
- package/lib/locale/messages-nb.js +4 -1
- package/lib/locale/messages-nn.d.ts +3 -0
- package/lib/locale/messages-nn.js +4 -1
- package/lib/locale/messages-se.d.ts +3 -0
- package/lib/locale/messages-se.js +4 -1
- package/lib/locale/messages-sma.d.ts +3 -0
- package/lib/locale/messages-sma.js +4 -1
- package/package.json +11 -10
- package/src/MyNdla/Resource/FolderInput.tsx +41 -44
- package/src/NDLAFilm/FilmSlideshow.tsx +1 -1
- package/src/Search/LoadingWrapper.tsx +1 -1
- package/src/Search/SearchResult.jsx +1 -1
- package/src/SearchTypeResult/SearchTypeResult.tsx +1 -1
- package/src/TreeStructure/FolderNameInput.tsx +1 -1
- package/src/index.ts +0 -2
- package/src/locale/messages-en.ts +3 -0
- package/src/locale/messages-nb.ts +3 -0
- package/src/locale/messages-nn.ts +3 -0
- package/src/locale/messages-se.ts +3 -0
- package/src/locale/messages-sma.ts +3 -0
- package/es/Spinner/Spinner.js +0 -42
- package/es/Spinner/index.js +0 -2
- package/lib/Spinner/Spinner.d.ts +0 -16
- package/lib/Spinner/Spinner.js +0 -54
- package/lib/Spinner/index.d.ts +0 -2
- package/lib/Spinner/index.js +0 -13
- package/src/Spinner/Spinner.tsx +0 -46
- package/src/Spinner/index.ts +0 -3
|
@@ -10,24 +10,17 @@ import styled from '@emotion/styled';
|
|
|
10
10
|
import { IconButton } from '@ndla/button';
|
|
11
11
|
import { FolderOutlined } from '@ndla/icons/contentType';
|
|
12
12
|
import { Cross } from '@ndla/icons/action';
|
|
13
|
-
import React, { ChangeEvent, KeyboardEvent,
|
|
13
|
+
import React, { ChangeEvent, KeyboardEvent, useRef, useState } from 'react';
|
|
14
14
|
import { useTranslation } from 'react-i18next';
|
|
15
15
|
import { colors, spacing } from '@ndla/core';
|
|
16
|
+
import { Input } from '@ndla/forms';
|
|
17
|
+
import { css } from '@emotion/core';
|
|
16
18
|
|
|
17
19
|
// Source: https://kovart.github.io/dashed-border-generator/
|
|
18
20
|
const borderStyle = `url("data:image/svg+xml,%3csvg width='100%25' height='100%25' xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%25' height='100%25' fill='none' stroke='${encodeURIComponent(
|
|
19
21
|
colors.brand.tertiary,
|
|
20
22
|
)}' stroke-width='2' stroke-dasharray='8%2c8' stroke-dashoffset='4' stroke-linecap='square'/%3e%3c/svg%3e")`;
|
|
21
23
|
|
|
22
|
-
const FolderInputWrapper = styled.div`
|
|
23
|
-
display: flex;
|
|
24
|
-
flex-direction: row;
|
|
25
|
-
align-items: center;
|
|
26
|
-
padding: ${spacing.small};
|
|
27
|
-
|
|
28
|
-
background-image: ${borderStyle};
|
|
29
|
-
`;
|
|
30
|
-
|
|
31
24
|
const StyledFolderIcon = styled.span`
|
|
32
25
|
display: flex;
|
|
33
26
|
padding: ${spacing.small};
|
|
@@ -38,29 +31,33 @@ const StyledFolderIcon = styled.span`
|
|
|
38
31
|
}
|
|
39
32
|
`;
|
|
40
33
|
|
|
41
|
-
const
|
|
42
|
-
|
|
43
|
-
|
|
34
|
+
const inputWrapperStyle = css`
|
|
35
|
+
padding: ${spacing.small};
|
|
36
|
+
background: none;
|
|
37
|
+
background-image: ${borderStyle};
|
|
44
38
|
border: none;
|
|
45
|
-
|
|
46
|
-
line-height: 1.75em;
|
|
39
|
+
`;
|
|
47
40
|
|
|
48
|
-
|
|
49
|
-
|
|
41
|
+
const StyledInput = styled(Input)`
|
|
42
|
+
&& {
|
|
43
|
+
line-height: 1.75em;
|
|
44
|
+
color: ${colors.brand.primary};
|
|
45
|
+
::selection {
|
|
46
|
+
background: ${colors.brand.lighter};
|
|
47
|
+
}
|
|
50
48
|
}
|
|
51
49
|
`;
|
|
52
50
|
|
|
53
51
|
interface Props {
|
|
54
52
|
onAddFolder: (name: string) => void;
|
|
55
53
|
onClose: () => void;
|
|
56
|
-
|
|
54
|
+
autoSelect?: boolean;
|
|
57
55
|
}
|
|
58
56
|
|
|
59
|
-
const FolderInput = ({ onAddFolder, onClose,
|
|
57
|
+
const FolderInput = ({ onAddFolder, onClose, autoSelect }: Props) => {
|
|
60
58
|
const { t } = useTranslation();
|
|
61
59
|
const newFolderText = t('treeStructure.newFolder.defaultName');
|
|
62
60
|
const [input, setInput] = useState<string>(newFolderText);
|
|
63
|
-
const [mounted, setMounted] = useState(false);
|
|
64
61
|
const inputRef = useRef<HTMLInputElement>(null);
|
|
65
62
|
|
|
66
63
|
const handleInputChange = (e: ChangeEvent<HTMLInputElement>) => {
|
|
@@ -68,36 +65,36 @@ const FolderInput = ({ onAddFolder, onClose, autoFocus }: Props) => {
|
|
|
68
65
|
};
|
|
69
66
|
|
|
70
67
|
const onKeydown = (e: KeyboardEvent<HTMLInputElement>) => {
|
|
71
|
-
if (e.key === 'Enter' && input) {
|
|
68
|
+
if (e.key === 'Enter' && input.trim()) {
|
|
72
69
|
e.preventDefault();
|
|
73
70
|
onAddFolder(input);
|
|
71
|
+
} else if (e.key === 'Escape') {
|
|
72
|
+
e.preventDefault();
|
|
73
|
+
onClose();
|
|
74
74
|
}
|
|
75
75
|
};
|
|
76
76
|
|
|
77
|
-
useEffect(() => {
|
|
78
|
-
if (mounted && autoFocus) {
|
|
79
|
-
inputRef.current?.select();
|
|
80
|
-
} else {
|
|
81
|
-
setMounted(true);
|
|
82
|
-
}
|
|
83
|
-
}, [mounted, autoFocus]);
|
|
84
|
-
|
|
85
77
|
return (
|
|
86
|
-
<
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
78
|
+
<StyledInput
|
|
79
|
+
autoSelect={autoSelect}
|
|
80
|
+
customCss={inputWrapperStyle}
|
|
81
|
+
warningText={!input.trim() ? t('myNdla.folder.missingName') : undefined}
|
|
82
|
+
ref={inputRef}
|
|
83
|
+
value={input}
|
|
84
|
+
onChange={handleInputChange}
|
|
85
|
+
onKeyDown={onKeydown}
|
|
86
|
+
aria-label={newFolderText}
|
|
87
|
+
iconLeft={
|
|
88
|
+
<StyledFolderIcon>
|
|
89
|
+
<FolderOutlined />
|
|
90
|
+
</StyledFolderIcon>
|
|
91
|
+
}
|
|
92
|
+
iconRight={
|
|
93
|
+
<IconButton aria-label={t('close')} size="small" ghostPill onClick={onClose}>
|
|
94
|
+
<Cross />
|
|
95
|
+
</IconButton>
|
|
96
|
+
}
|
|
97
|
+
/>
|
|
101
98
|
);
|
|
102
99
|
};
|
|
103
100
|
|
|
@@ -12,8 +12,8 @@ import styled from '@emotion/styled';
|
|
|
12
12
|
import { css } from '@emotion/core';
|
|
13
13
|
import { breakpoints, mq, spacing, spacingUnit, fonts, colors } from '@ndla/core';
|
|
14
14
|
import SafeLink from '@ndla/safelink';
|
|
15
|
+
import { Spinner } from '@ndla/icons';
|
|
15
16
|
import { OneColumn } from '../Layout';
|
|
16
|
-
import Spinner from '../Spinner';
|
|
17
17
|
import NavigationArrow, { StyledNavigationArrow } from './NavigationArrow';
|
|
18
18
|
import SlideshowIndicator from './SlideshowIndicator';
|
|
19
19
|
import { MovieType } from './types';
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import styled from '@emotion/styled';
|
|
3
3
|
import { spacing, spacingUnit, animations } from '@ndla/core';
|
|
4
|
-
import Spinner from '
|
|
4
|
+
import { Spinner } from '@ndla/icons';
|
|
5
5
|
|
|
6
6
|
const StyledWrapper = styled.div`
|
|
7
7
|
position: absolute;
|
|
@@ -9,7 +9,7 @@ import Button from '@ndla/button';
|
|
|
9
9
|
import { FilterTabs } from '@ndla/tabs';
|
|
10
10
|
import Tooltip from '@ndla/tooltip';
|
|
11
11
|
import SafeLink from '@ndla/safelink';
|
|
12
|
-
import Spinner from '
|
|
12
|
+
import { Spinner } from '@ndla/icons';
|
|
13
13
|
|
|
14
14
|
const resultClasses = BEMHelper('c-search-result');
|
|
15
15
|
|
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
import React, { memo, ReactNode } from 'react';
|
|
10
10
|
import styled from '@emotion/styled';
|
|
11
11
|
import { spacing } from '@ndla/core';
|
|
12
|
-
import Spinner from '
|
|
12
|
+
import { Spinner } from '@ndla/icons';
|
|
13
13
|
import constants from '../model';
|
|
14
14
|
import SearchTypeHeader, { FilterOptionsType } from './SearchTypeHeader';
|
|
15
15
|
import SearchItems from './SearchItems';
|
|
@@ -13,7 +13,7 @@ import { ArrowDropDown as ArrowDropDownRaw } from '@ndla/icons/common';
|
|
|
13
13
|
import { spacing, colors, misc, animations } from '@ndla/core';
|
|
14
14
|
import { useTranslation } from 'react-i18next';
|
|
15
15
|
import { isMobile } from 'react-device-detect';
|
|
16
|
-
import Spinner from '
|
|
16
|
+
import { Spinner } from '@ndla/icons';
|
|
17
17
|
|
|
18
18
|
const ArrowRight = styled(ArrowDropDownRaw)`
|
|
19
19
|
color: ${colors.text.primary};
|
package/src/index.ts
CHANGED
|
@@ -109,8 +109,6 @@ export {
|
|
|
109
109
|
} from './LearningPaths';
|
|
110
110
|
export { Translation, TranslationLine, TranslationBox } from './Translation';
|
|
111
111
|
|
|
112
|
-
export { default as Spinner } from './Spinner';
|
|
113
|
-
|
|
114
112
|
export { default as SearchResultSleeve } from './Search/SearchResultSleeve';
|
|
115
113
|
|
|
116
114
|
export { default as ContentTypeResult } from './Search/ContentTypeResult';
|
|
@@ -861,8 +861,10 @@ const messages = {
|
|
|
861
861
|
open: 'Open menu',
|
|
862
862
|
close: 'Close menu',
|
|
863
863
|
},
|
|
864
|
+
cancel: 'Cancel',
|
|
864
865
|
close: 'Close',
|
|
865
866
|
title: 'Title',
|
|
867
|
+
save: 'Save',
|
|
866
868
|
image: {
|
|
867
869
|
altText: 'Alt-text',
|
|
868
870
|
caption: 'Caption',
|
|
@@ -993,6 +995,7 @@ const messages = {
|
|
|
993
995
|
folder: 'Folder',
|
|
994
996
|
delete: 'Delete',
|
|
995
997
|
edit: 'Edit',
|
|
998
|
+
missingName: 'Folder name required',
|
|
996
999
|
},
|
|
997
1000
|
confirmDeleteFolder: 'Are you sure you want to delete this folder? This process cannot be undone.',
|
|
998
1001
|
confirmDeleteTag: 'Are you sure you want to delete this tag? This process cannot be undone.',
|
|
@@ -861,6 +861,8 @@ const messages = {
|
|
|
861
861
|
},
|
|
862
862
|
close: 'Lukk',
|
|
863
863
|
title: 'Tittel',
|
|
864
|
+
cancel: 'Avbryt',
|
|
865
|
+
save: 'Lagre',
|
|
864
866
|
image: {
|
|
865
867
|
altText: 'Alt-tekst',
|
|
866
868
|
caption: 'Bildetekst',
|
|
@@ -991,6 +993,7 @@ const messages = {
|
|
|
991
993
|
folder: 'Mappe',
|
|
992
994
|
delete: 'Slett',
|
|
993
995
|
edit: 'Rediger',
|
|
996
|
+
missingName: 'Mappenavn er påkrevd',
|
|
994
997
|
},
|
|
995
998
|
confirmDeleteFolder: 'Er du sikker på at du vil slette mappen? Denne handlingen kan ikke angres.',
|
|
996
999
|
confirmDeleteTag: 'Er du sikker på at du vil slette tag? Denne handlingen kan ikke angres.',
|
|
@@ -860,8 +860,10 @@ const messages = {
|
|
|
860
860
|
open: 'Åpne meny',
|
|
861
861
|
close: 'Lukk meny',
|
|
862
862
|
},
|
|
863
|
+
cancel: 'Avbryt',
|
|
863
864
|
close: 'Lukk',
|
|
864
865
|
title: 'Tittel',
|
|
866
|
+
save: 'Lagre',
|
|
865
867
|
image: {
|
|
866
868
|
altText: 'Alt-tekst',
|
|
867
869
|
caption: 'Bilettekst',
|
|
@@ -992,6 +994,7 @@ const messages = {
|
|
|
992
994
|
folder: 'Mappe',
|
|
993
995
|
delete: 'Slett',
|
|
994
996
|
edit: 'Rediger',
|
|
997
|
+
missingName: 'Mappenavn er påkrevd',
|
|
995
998
|
},
|
|
996
999
|
confirmDeleteFolder: 'Er du sikker på at du vil slette mappa? Denne handlinga kan ikkje angres.',
|
|
997
1000
|
confirmDeleteTag: 'Er du sikker på at du vil slette tag? Denne handlinga kan ikkje angres.',
|
|
@@ -859,8 +859,10 @@ const messages = {
|
|
|
859
859
|
open: 'Åpne meny',
|
|
860
860
|
close: 'Lukk meny',
|
|
861
861
|
},
|
|
862
|
+
cancel: 'Avbryt',
|
|
862
863
|
close: 'Lukk',
|
|
863
864
|
title: 'Tittel',
|
|
865
|
+
save: 'Lagre',
|
|
864
866
|
image: {
|
|
865
867
|
altText: 'Alt-tekst',
|
|
866
868
|
caption: 'Bilettekst',
|
|
@@ -991,6 +993,7 @@ const messages = {
|
|
|
991
993
|
folder: 'Mappe',
|
|
992
994
|
delete: 'Slett',
|
|
993
995
|
edit: 'Rediger',
|
|
996
|
+
missingName: 'Mappenavn er påkrevd',
|
|
994
997
|
},
|
|
995
998
|
confirmDeleteFolder: 'Er du sikker på at du vil slette mappen? Denne handlingen kan ikke angres.',
|
|
996
999
|
confirmDeleteTag: 'Er du sikker på at du vil slette tag? Denne handlingen kan ikke angres.',
|
|
@@ -859,8 +859,10 @@ const messages = {
|
|
|
859
859
|
open: 'Åpne meny',
|
|
860
860
|
close: 'Lukk meny',
|
|
861
861
|
},
|
|
862
|
+
cancel: 'Avbryt',
|
|
862
863
|
close: 'Lukk',
|
|
863
864
|
title: 'Tittel',
|
|
865
|
+
save: 'Lagre',
|
|
864
866
|
image: {
|
|
865
867
|
altText: 'Alt-tekst',
|
|
866
868
|
caption: 'Bilettekst',
|
|
@@ -991,6 +993,7 @@ const messages = {
|
|
|
991
993
|
folder: 'Mappe',
|
|
992
994
|
delete: 'Slett',
|
|
993
995
|
edit: 'Rediger',
|
|
996
|
+
missingName: 'Mappenavn er påkrevd',
|
|
994
997
|
},
|
|
995
998
|
confirmDeleteFolder: 'Er du sikker på at du vil slette mappen? Denne handlingen kan ikke angres.',
|
|
996
999
|
confirmDeleteTag: 'Er du sikker på at du vil slette tag? Denne handlingen kan ikke angres.',
|
package/es/Spinner/Spinner.js
DELETED
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import _styled from "@emotion/styled-base";
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Copyright (c) 2018-present, NDLA.
|
|
5
|
-
*
|
|
6
|
-
* This source code is licensed under the GPLv3 license found in the
|
|
7
|
-
* LICENSE file in the root directory of this source tree.
|
|
8
|
-
*
|
|
9
|
-
*/
|
|
10
|
-
import React from 'react';
|
|
11
|
-
import { colors, spacing } from '@ndla/core';
|
|
12
|
-
import { jsx as ___EmotionJSX } from "@emotion/core";
|
|
13
|
-
|
|
14
|
-
var SpinnerDiv = /*#__PURE__*/_styled('div', {
|
|
15
|
-
target: "eecx2hs0",
|
|
16
|
-
label: "SpinnerDiv"
|
|
17
|
-
})("border:calc(", function (props) {
|
|
18
|
-
return spacing[props.size];
|
|
19
|
-
}, " / 6.5) solid rgba(0,0,0,0.1);border-bottom-color:", function (props) {
|
|
20
|
-
return props.inverted ? '#fff' : colors.brand.primary;
|
|
21
|
-
}, ";border-radius:50%;animation:spinnerAnimation 0.7s linear infinite;height:", function (props) {
|
|
22
|
-
return spacing[props.size];
|
|
23
|
-
}, ";width:", function (props) {
|
|
24
|
-
return spacing[props.size];
|
|
25
|
-
}, ";margin:", function (props) {
|
|
26
|
-
return props.margin;
|
|
27
|
-
}, ";display:block;@keyframes spinnerAnimation{0%{transform:rotate(0deg);}100%{transform:rotate(360deg);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNwaW5uZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCNkMiLCJmaWxlIjoiU3Bpbm5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIHNwYWNpbmcsIFNwYWNpbmdOYW1lcyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBzaXplPzogU3BhY2luZ05hbWVzO1xuICBtYXJnaW4/OiBzdHJpbmc7XG4gIGludmVydGVkPzogYm9vbGVhbjtcbn1cblxuaW50ZXJmYWNlIFN0eWxlZFByb3BzIGV4dGVuZHMgUHJvcHMge1xuICBzaXplOiBTcGFjaW5nTmFtZXM7XG59XG5cbmNvbnN0IFNwaW5uZXJEaXYgPSBzdHlsZWQoJ2RpdicpPFN0eWxlZFByb3BzPmBcbiAgYm9yZGVyOiBjYWxjKCR7KHByb3BzKSA9PiBzcGFjaW5nW3Byb3BzLnNpemVdfSAvIDYuNSkgc29saWQgcmdiYSgwLCAwLCAwLCAwLjEpO1xuICBib3JkZXItYm90dG9tLWNvbG9yOiAkeyhwcm9wcykgPT4gKHByb3BzLmludmVydGVkID8gJyNmZmYnIDogY29sb3JzLmJyYW5kLnByaW1hcnkpfTtcbiAgYm9yZGVyLXJhZGl1czogNTAlO1xuICBhbmltYXRpb246IHNwaW5uZXJBbmltYXRpb24gMC43cyBsaW5lYXIgaW5maW5pdGU7XG4gIGhlaWdodDogJHsocHJvcHMpID0+IHNwYWNpbmdbcHJvcHMuc2l6ZV19O1xuICB3aWR0aDogJHsocHJvcHMpID0+IHNwYWNpbmdbcHJvcHMuc2l6ZV19O1xuICBtYXJnaW46ICR7KHByb3BzKSA9PiBwcm9wcy5tYXJnaW59O1xuICBkaXNwbGF5OiBibG9jaztcbiAgQGtleWZyYW1lcyBzcGlubmVyQW5pbWF0aW9uIHtcbiAgICAwJSB7XG4gICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgwZGVnKTtcbiAgICB9XG4gICAgMTAwJSB7XG4gICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgzNjBkZWcpO1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgU3Bpbm5lciA9ICh7IHNpemUgPSAnbGFyZ2UnLCBtYXJnaW4gPSBgJHtzcGFjaW5nLm5vcm1hbH0gYXV0b2AsIGludmVydGVkIH06IFBhcnRpYWw8UHJvcHM+KSA9PiAoXG4gIDxTcGlubmVyRGl2IHNpemU9e3NpemV9IG1hcmdpbj17bWFyZ2lufSBpbnZlcnRlZD17ISFpbnZlcnRlZH0gLz5cbik7XG5cbmV4cG9ydCBkZWZhdWx0IFNwaW5uZXI7XG4iXX0= */"));
|
|
28
|
-
|
|
29
|
-
var Spinner = function Spinner(_ref) {
|
|
30
|
-
var _ref$size = _ref.size,
|
|
31
|
-
size = _ref$size === void 0 ? 'large' : _ref$size,
|
|
32
|
-
_ref$margin = _ref.margin,
|
|
33
|
-
margin = _ref$margin === void 0 ? "".concat(spacing.normal, " auto") : _ref$margin,
|
|
34
|
-
inverted = _ref.inverted;
|
|
35
|
-
return ___EmotionJSX(SpinnerDiv, {
|
|
36
|
-
size: size,
|
|
37
|
-
margin: margin,
|
|
38
|
-
inverted: !!inverted
|
|
39
|
-
});
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
export default Spinner;
|
package/es/Spinner/index.js
DELETED
package/lib/Spinner/Spinner.d.ts
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Copyright (c) 2018-present, NDLA.
|
|
3
|
-
*
|
|
4
|
-
* This source code is licensed under the GPLv3 license found in the
|
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
|
6
|
-
*
|
|
7
|
-
*/
|
|
8
|
-
/// <reference types="react" />
|
|
9
|
-
import { SpacingNames } from '@ndla/core';
|
|
10
|
-
interface Props {
|
|
11
|
-
size?: SpacingNames;
|
|
12
|
-
margin?: string;
|
|
13
|
-
inverted?: boolean;
|
|
14
|
-
}
|
|
15
|
-
declare const Spinner: ({ size, margin, inverted }: Partial<Props>) => JSX.Element;
|
|
16
|
-
export default Spinner;
|
package/lib/Spinner/Spinner.js
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports["default"] = void 0;
|
|
7
|
-
|
|
8
|
-
var _styledBase = _interopRequireDefault(require("@emotion/styled-base"));
|
|
9
|
-
|
|
10
|
-
var _react = _interopRequireDefault(require("react"));
|
|
11
|
-
|
|
12
|
-
var _core = require("@ndla/core");
|
|
13
|
-
|
|
14
|
-
var _core2 = require("@emotion/core");
|
|
15
|
-
|
|
16
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* Copyright (c) 2018-present, NDLA.
|
|
20
|
-
*
|
|
21
|
-
* This source code is licensed under the GPLv3 license found in the
|
|
22
|
-
* LICENSE file in the root directory of this source tree.
|
|
23
|
-
*
|
|
24
|
-
*/
|
|
25
|
-
var SpinnerDiv = ( /*#__PURE__*/0, _styledBase["default"])('div', {
|
|
26
|
-
target: "eecx2hs0",
|
|
27
|
-
label: "SpinnerDiv"
|
|
28
|
-
})("border:calc(", function (props) {
|
|
29
|
-
return _core.spacing[props.size];
|
|
30
|
-
}, " / 6.5) solid rgba(0,0,0,0.1);border-bottom-color:", function (props) {
|
|
31
|
-
return props.inverted ? '#fff' : _core.colors.brand.primary;
|
|
32
|
-
}, ";border-radius:50%;animation:spinnerAnimation 0.7s linear infinite;height:", function (props) {
|
|
33
|
-
return _core.spacing[props.size];
|
|
34
|
-
}, ";width:", function (props) {
|
|
35
|
-
return _core.spacing[props.size];
|
|
36
|
-
}, ";margin:", function (props) {
|
|
37
|
-
return props.margin;
|
|
38
|
-
}, ";display:block;@keyframes spinnerAnimation{0%{transform:rotate(0deg);}100%{transform:rotate(360deg);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNwaW5uZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCNkMiLCJmaWxlIjoiU3Bpbm5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIHNwYWNpbmcsIFNwYWNpbmdOYW1lcyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBzaXplPzogU3BhY2luZ05hbWVzO1xuICBtYXJnaW4/OiBzdHJpbmc7XG4gIGludmVydGVkPzogYm9vbGVhbjtcbn1cblxuaW50ZXJmYWNlIFN0eWxlZFByb3BzIGV4dGVuZHMgUHJvcHMge1xuICBzaXplOiBTcGFjaW5nTmFtZXM7XG59XG5cbmNvbnN0IFNwaW5uZXJEaXYgPSBzdHlsZWQoJ2RpdicpPFN0eWxlZFByb3BzPmBcbiAgYm9yZGVyOiBjYWxjKCR7KHByb3BzKSA9PiBzcGFjaW5nW3Byb3BzLnNpemVdfSAvIDYuNSkgc29saWQgcmdiYSgwLCAwLCAwLCAwLjEpO1xuICBib3JkZXItYm90dG9tLWNvbG9yOiAkeyhwcm9wcykgPT4gKHByb3BzLmludmVydGVkID8gJyNmZmYnIDogY29sb3JzLmJyYW5kLnByaW1hcnkpfTtcbiAgYm9yZGVyLXJhZGl1czogNTAlO1xuICBhbmltYXRpb246IHNwaW5uZXJBbmltYXRpb24gMC43cyBsaW5lYXIgaW5maW5pdGU7XG4gIGhlaWdodDogJHsocHJvcHMpID0+IHNwYWNpbmdbcHJvcHMuc2l6ZV19O1xuICB3aWR0aDogJHsocHJvcHMpID0+IHNwYWNpbmdbcHJvcHMuc2l6ZV19O1xuICBtYXJnaW46ICR7KHByb3BzKSA9PiBwcm9wcy5tYXJnaW59O1xuICBkaXNwbGF5OiBibG9jaztcbiAgQGtleWZyYW1lcyBzcGlubmVyQW5pbWF0aW9uIHtcbiAgICAwJSB7XG4gICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgwZGVnKTtcbiAgICB9XG4gICAgMTAwJSB7XG4gICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgzNjBkZWcpO1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgU3Bpbm5lciA9ICh7IHNpemUgPSAnbGFyZ2UnLCBtYXJnaW4gPSBgJHtzcGFjaW5nLm5vcm1hbH0gYXV0b2AsIGludmVydGVkIH06IFBhcnRpYWw8UHJvcHM+KSA9PiAoXG4gIDxTcGlubmVyRGl2IHNpemU9e3NpemV9IG1hcmdpbj17bWFyZ2lufSBpbnZlcnRlZD17ISFpbnZlcnRlZH0gLz5cbik7XG5cbmV4cG9ydCBkZWZhdWx0IFNwaW5uZXI7XG4iXX0= */"));
|
|
39
|
-
|
|
40
|
-
var Spinner = function Spinner(_ref) {
|
|
41
|
-
var _ref$size = _ref.size,
|
|
42
|
-
size = _ref$size === void 0 ? 'large' : _ref$size,
|
|
43
|
-
_ref$margin = _ref.margin,
|
|
44
|
-
margin = _ref$margin === void 0 ? "".concat(_core.spacing.normal, " auto") : _ref$margin,
|
|
45
|
-
inverted = _ref.inverted;
|
|
46
|
-
return (0, _core2.jsx)(SpinnerDiv, {
|
|
47
|
-
size: size,
|
|
48
|
-
margin: margin,
|
|
49
|
-
inverted: !!inverted
|
|
50
|
-
});
|
|
51
|
-
};
|
|
52
|
-
|
|
53
|
-
var _default = Spinner;
|
|
54
|
-
exports["default"] = _default;
|
package/lib/Spinner/index.d.ts
DELETED
package/lib/Spinner/index.js
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports["default"] = void 0;
|
|
7
|
-
|
|
8
|
-
var _Spinner = _interopRequireDefault(require("./Spinner"));
|
|
9
|
-
|
|
10
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
11
|
-
|
|
12
|
-
var _default = _Spinner["default"];
|
|
13
|
-
exports["default"] = _default;
|
package/src/Spinner/Spinner.tsx
DELETED
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Copyright (c) 2018-present, NDLA.
|
|
3
|
-
*
|
|
4
|
-
* This source code is licensed under the GPLv3 license found in the
|
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
|
6
|
-
*
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
import React from 'react';
|
|
10
|
-
import styled from '@emotion/styled';
|
|
11
|
-
import { colors, spacing, SpacingNames } from '@ndla/core';
|
|
12
|
-
|
|
13
|
-
interface Props {
|
|
14
|
-
size?: SpacingNames;
|
|
15
|
-
margin?: string;
|
|
16
|
-
inverted?: boolean;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
interface StyledProps extends Props {
|
|
20
|
-
size: SpacingNames;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const SpinnerDiv = styled('div')<StyledProps>`
|
|
24
|
-
border: calc(${(props) => spacing[props.size]} / 6.5) solid rgba(0, 0, 0, 0.1);
|
|
25
|
-
border-bottom-color: ${(props) => (props.inverted ? '#fff' : colors.brand.primary)};
|
|
26
|
-
border-radius: 50%;
|
|
27
|
-
animation: spinnerAnimation 0.7s linear infinite;
|
|
28
|
-
height: ${(props) => spacing[props.size]};
|
|
29
|
-
width: ${(props) => spacing[props.size]};
|
|
30
|
-
margin: ${(props) => props.margin};
|
|
31
|
-
display: block;
|
|
32
|
-
@keyframes spinnerAnimation {
|
|
33
|
-
0% {
|
|
34
|
-
transform: rotate(0deg);
|
|
35
|
-
}
|
|
36
|
-
100% {
|
|
37
|
-
transform: rotate(360deg);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
`;
|
|
41
|
-
|
|
42
|
-
const Spinner = ({ size = 'large', margin = `${spacing.normal} auto`, inverted }: Partial<Props>) => (
|
|
43
|
-
<SpinnerDiv size={size} margin={margin} inverted={!!inverted} />
|
|
44
|
-
);
|
|
45
|
-
|
|
46
|
-
export default Spinner;
|
package/src/Spinner/index.ts
DELETED