@aarhus-university/au-lib-react-components 10.3.3 → 10.6.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.
Files changed (113) hide show
  1. package/.eslintrc.js +34 -44
  2. package/.storybook/main.js +8 -0
  3. package/{types/common/payloads.d.ts → .storybook/preview-head.html} +0 -0
  4. package/.storybook/preview.js +11 -0
  5. package/README.md +19 -19
  6. package/__tests__/jest/AUButtonComponent.test.tsx +163 -0
  7. package/__tests__/jest/AUSpinnerComponent.test.tsx +57 -0
  8. package/__tests__/jest/helpers.test.ts +15 -0
  9. package/__tests__/jest/setupTests.ts +2 -0
  10. package/babel.config.js +8 -7
  11. package/build/umd/all.css +2 -2
  12. package/build/umd/all.js +1 -1
  13. package/build/umd/alphabox.js +1 -1
  14. package/build/umd/alphabox.js.map +1 -1
  15. package/build/umd/databox.js +1 -1
  16. package/build/umd/databox.js.map +1 -1
  17. package/build/umd/diagramme.js +1 -1
  18. package/build/umd/diagramme.js.map +1 -1
  19. package/build/umd/flowbox.js +1 -1
  20. package/build/umd/flowbox.js.map +1 -1
  21. package/build/umd/universe.js +1 -1
  22. package/build/umd/universe.js.map +1 -1
  23. package/package.json +107 -66
  24. package/src/components/AUAlertComponent.tsx +70 -70
  25. package/src/components/AUAutoSuggestComponent.js +158 -158
  26. package/src/components/AUButtonComponent.tsx +77 -0
  27. package/src/components/AUCalendarComponent.tsx +493 -493
  28. package/src/components/AUContentToggleComponent.tsx +33 -33
  29. package/src/components/AUDatepickerComponent.tsx +117 -117
  30. package/src/components/AUMobilePrefixComponent.tsx +15 -15
  31. package/src/components/AUModalComponent.tsx +80 -80
  32. package/src/components/AUReceiptComponent.tsx +33 -33
  33. package/src/components/AUSpinnerComponent.tsx +33 -91
  34. package/src/components/AUSubNavComponent.tsx +48 -48
  35. package/src/components/AUSubmitButtonContainerComponent.tsx +31 -31
  36. package/src/components/AUTabbedContentComponent.tsx +145 -145
  37. package/src/components/AUTableComponent.tsx +24 -24
  38. package/src/components/AUToastComponent.tsx +103 -103
  39. package/src/components/AUToolbarComponent.tsx +45 -45
  40. package/src/components/profile/AUProfileActions.js +128 -128
  41. package/src/components/profile/AUProfileAvatarComponent.js +83 -83
  42. package/src/components/profile/AUProfileAvatarV2Component.js +91 -91
  43. package/src/components/profile/AUProfileAvatarV3Component.tsx +42 -42
  44. package/src/components/profile/AUProfileContainerComponent.js +283 -283
  45. package/src/components/profile/AUProfileHooks.js +30 -30
  46. package/src/components/profile/AUProfileItemComponent.js +54 -54
  47. package/src/components/profile/AUProfileLanguageComponent.js +131 -131
  48. package/src/components/profile/AUProfileLoginComponent.tsx +26 -26
  49. package/src/components/profile/AUProfileMailComponent.js +307 -307
  50. package/src/components/profile/AUProfileMobileComponent.js +164 -164
  51. package/src/components/profile/AUProfileNameComponent.js +253 -253
  52. package/src/components/profile/AUProfileNextOfKinComponent.js +216 -216
  53. package/src/components/profile/AUProfileReducer.js +230 -230
  54. package/src/components/profile/AUProfileWidgetComponent.js +95 -95
  55. package/src/components/profile/AUProfileWidgetV2Component.js +116 -116
  56. package/src/components/profile/AUProfileWidgetV3Component.tsx +122 -122
  57. package/src/components/wrapping/AUEmbedComponent.js +47 -47
  58. package/src/layout-2016/components/alphabox/AlphaBoxComponent.js +143 -143
  59. package/src/layout-2016/components/alphabox/AlphaBoxContentComponent.js +136 -136
  60. package/src/layout-2016/components/common/AUCollapsibleComponent.js +152 -152
  61. package/src/layout-2016/components/common/AUSpinnerComponent.js +103 -103
  62. package/src/layout-2016/components/databox/DataBoxAlphabetComponent.js +144 -144
  63. package/src/layout-2016/components/databox/DataBoxAssociationComponent.js +122 -122
  64. package/src/layout-2016/components/databox/DataBoxButtonComponent.js +157 -157
  65. package/src/layout-2016/components/databox/DataBoxComponent.js +297 -297
  66. package/src/layout-2016/components/databox/DataBoxGroupingComponent.js +64 -64
  67. package/src/layout-2016/components/databox/DataBoxSearchResultComponent.js +36 -36
  68. package/src/layout-2016/components/databox/DataBoxStackedAssociationComponent.js +54 -54
  69. package/src/layout-2016/components/databox/DataBoxSuggestionComponent.js +39 -39
  70. package/src/layout-2016/components/diagramme/AUDiagrammeComponent.js +309 -309
  71. package/src/layout-2016/components/flowbox/FlowBoxComponent.js +126 -126
  72. package/src/layout-2016/components/flowbox/FlowBoxPhoneComponent.js +104 -104
  73. package/src/layout-2016/components/profile/AUProfileAvatar2016Component.js +103 -103
  74. package/src/layout-2016/components/universe/StaffTopComponent.js +363 -363
  75. package/src/layout-2016/components/universe/StudentTopComponent.js +137 -137
  76. package/src/layout-2016/components/universe/UniverseContainerComponent.js +65 -65
  77. package/src/layout-2016/lib/all.js +3 -3
  78. package/src/layout-2016/lib/au-alphabox.js +100 -100
  79. package/src/layout-2016/lib/au-databox.js +400 -400
  80. package/src/layout-2016/lib/au-diagramme.js +85 -85
  81. package/src/layout-2016/lib/au-flowbox.js +93 -93
  82. package/src/layout-2016/lib/universe.js +9 -9
  83. package/src/lib/helpers.ts +194 -194
  84. package/src/lib/hooks.ts +33 -33
  85. package/src/lib/i18n.ts +600 -600
  86. package/src/lib/tracking.ts +69 -69
  87. package/src/lib/wrapping.ts +21 -21
  88. package/src/styles/_settings.scss +10 -10
  89. package/src/styles/alphabox.scss +222 -222
  90. package/src/styles/app.scss +7 -7
  91. package/src/styles/autosuggest.scss +57 -57
  92. package/src/styles/databox.scss +563 -563
  93. package/src/styles/diagramme.scss +119 -119
  94. package/src/styles/flowbox.scss +72 -72
  95. package/src/styles/maps.scss +395 -395
  96. package/stories/AUButtonComponent.stories.tsx +86 -0
  97. package/stories/AUSpinnerComponent.stories.tsx +41 -0
  98. package/stories/assets/code-brackets.svg +1 -0
  99. package/stories/assets/colors.svg +1 -0
  100. package/stories/assets/comments.svg +1 -0
  101. package/stories/assets/direction.svg +1 -0
  102. package/stories/assets/flow.svg +1 -0
  103. package/stories/assets/plugin.svg +1 -0
  104. package/stories/assets/repo.svg +1 -0
  105. package/stories/assets/stackalt.svg +1 -0
  106. package/tsconfig.json +46 -46
  107. package/webpack.config.js +89 -89
  108. package/types/common/delphinus-duplicates.d.ts +0 -40
  109. package/types/common/interfaces/gui.d.ts +0 -52
  110. package/types/common/interfaces/model.d.ts +0 -29
  111. package/types/common/main.d.ts +0 -6
  112. package/types/common/package.json +0 -5
  113. package/types/common/props.d.ts +0 -166
@@ -1,116 +1,116 @@
1
- /* eslint-env browser */
2
- import React, { useEffect, useState, useRef } from 'react';
3
- import PropTypes from 'prop-types';
4
- import { setCopyToClipboard } from '@aarhus-university/au-designsystem-delphinus/source/js/components/nav';
5
-
6
- const AUProfileWidgetComponent = React.memo(({
7
- lang,
8
- name,
9
- auid,
10
- studentNumber,
11
- settings,
12
- changeLanguageUrl,
13
- logoutUri,
14
- profileLabels,
15
- }) => {
16
- const [ctcSet, setCtcSet] = useState(false);
17
- const renderSettings = settings.map((s) => {
18
- const btnRef = useRef();
19
- if (s.type === 'anchor') {
20
- return <a key={s.url} className="sub-nav__item" href={s.url}>{s.text}</a>;
21
- }
22
- return (
23
- <button
24
- key={s.text}
25
- ref={btnRef}
26
- type="button"
27
- className={`sub-nav__item ${s.classNames}`}
28
- onClick={() => s.onClick(btnRef.current)}
29
- data-icon={s.icon}
30
- >
31
- {s.text}
32
- </button>
33
- );
34
- });
35
-
36
- useEffect(() => {
37
- if (auid > 0 && !ctcSet) {
38
- setCopyToClipboard(lang);
39
- setCtcSet(true);
40
- }
41
- });
42
-
43
- return (
44
- <div className="sub-nav__content theme--normal" aria-labelledby="profile-menu-toggle">
45
- <div className="sub-nav__user">
46
- <h2 className="sub-nav__user-name">{name}</h2>
47
- <button
48
- type="button"
49
- className="copy-to-clipboard"
50
- title={profileLabels[lang].copyAuid}
51
- aria-label={`${profileLabels[lang].auId}: AU${auid}`}
52
- >
53
- {`${profileLabels[lang].auId}: `}
54
- <span className="copy-to-clipboard__this">{`AU${auid}`}</span>
55
- </button>
56
- {
57
- studentNumber && (
58
- <button
59
- type="button"
60
- className="copy-to-clipboard"
61
- title={profileLabels[lang].copyStudentNumber}
62
- aria-label={`${profileLabels[lang].studentNumber}: ${studentNumber}`}
63
- >
64
- {`${profileLabels[lang].studentNumber}: `}
65
- <span className="copy-to-clipboard__this">{studentNumber}</span>
66
- </button>
67
- )
68
- }
69
- </div>
70
- <hr />
71
- {renderSettings}
72
- <hr />
73
- {
74
- changeLanguageUrl && (
75
- <>
76
- <a className="sub-nav__item sub-nav__item--icon" href={changeLanguageUrl} data-icon="">{profileLabels[lang].changeLanguage}</a>
77
- <hr />
78
- </>
79
- )
80
- }
81
- <a
82
- className="sub-nav__item sub-nav__item--icon"
83
- data-icon=""
84
- href={logoutUri}
85
- >
86
- {profileLabels[lang].logout}
87
- </a>
88
- </div>
89
- );
90
- });
91
-
92
- AUProfileWidgetComponent.defaultProps = {
93
- studentNumber: null,
94
- changeLanguageUrl: '',
95
- };
96
-
97
- AUProfileWidgetComponent.propTypes = {
98
- lang: PropTypes.string.isRequired,
99
- name: PropTypes.string.isRequired,
100
- auid: PropTypes.number.isRequired,
101
- studentNumber: PropTypes.string,
102
- settings: PropTypes.arrayOf(PropTypes.shape({
103
- type: PropTypes.string.isRequired,
104
- url: PropTypes.string,
105
- text: PropTypes.string.isRequired,
106
- onClick: PropTypes.func,
107
- classNames: PropTypes.string,
108
- icon: PropTypes.string,
109
- })).isRequired,
110
- profileLabels: PropTypes.shape({}).isRequired,
111
- changeLanguageUrl: PropTypes.string,
112
- logoutUri: PropTypes.string.isRequired,
113
- };
114
-
115
- AUProfileWidgetComponent.displayName = 'AUProfileWidgetComponent';
116
- export default AUProfileWidgetComponent;
1
+ /* eslint-env browser */
2
+ import React, { useEffect, useState, useRef } from 'react';
3
+ import PropTypes from 'prop-types';
4
+ import { setCopyToClipboard } from '@aarhus-university/au-designsystem-delphinus/source/js/components/nav';
5
+
6
+ const AUProfileWidgetComponent = React.memo(({
7
+ lang,
8
+ name,
9
+ auid,
10
+ studentNumber,
11
+ settings,
12
+ changeLanguageUrl,
13
+ logoutUri,
14
+ profileLabels,
15
+ }) => {
16
+ const [ctcSet, setCtcSet] = useState(false);
17
+ const renderSettings = settings.map((s) => {
18
+ const btnRef = useRef();
19
+ if (s.type === 'anchor') {
20
+ return <a key={s.url} className="sub-nav__item" href={s.url}>{s.text}</a>;
21
+ }
22
+ return (
23
+ <button
24
+ key={s.text}
25
+ ref={btnRef}
26
+ type="button"
27
+ className={`sub-nav__item ${s.classNames}`}
28
+ onClick={() => s.onClick(btnRef.current)}
29
+ data-icon={s.icon}
30
+ >
31
+ {s.text}
32
+ </button>
33
+ );
34
+ });
35
+
36
+ useEffect(() => {
37
+ if (auid > 0 && !ctcSet) {
38
+ setCopyToClipboard(lang);
39
+ setCtcSet(true);
40
+ }
41
+ });
42
+
43
+ return (
44
+ <div className="sub-nav__content theme--normal" aria-labelledby="profile-menu-toggle">
45
+ <div className="sub-nav__user">
46
+ <h2 className="sub-nav__user-name">{name}</h2>
47
+ <button
48
+ type="button"
49
+ className="copy-to-clipboard"
50
+ title={profileLabels[lang].copyAuid}
51
+ aria-label={`${profileLabels[lang].auId}: AU${auid}`}
52
+ >
53
+ {`${profileLabels[lang].auId}: `}
54
+ <span className="copy-to-clipboard__this">{`AU${auid}`}</span>
55
+ </button>
56
+ {
57
+ studentNumber && (
58
+ <button
59
+ type="button"
60
+ className="copy-to-clipboard"
61
+ title={profileLabels[lang].copyStudentNumber}
62
+ aria-label={`${profileLabels[lang].studentNumber}: ${studentNumber}`}
63
+ >
64
+ {`${profileLabels[lang].studentNumber}: `}
65
+ <span className="copy-to-clipboard__this">{studentNumber}</span>
66
+ </button>
67
+ )
68
+ }
69
+ </div>
70
+ <hr />
71
+ {renderSettings}
72
+ <hr />
73
+ {
74
+ changeLanguageUrl && (
75
+ <>
76
+ <a className="sub-nav__item sub-nav__item--icon" href={changeLanguageUrl} data-icon="">{profileLabels[lang].changeLanguage}</a>
77
+ <hr />
78
+ </>
79
+ )
80
+ }
81
+ <a
82
+ className="sub-nav__item sub-nav__item--icon"
83
+ data-icon=""
84
+ href={logoutUri}
85
+ >
86
+ {profileLabels[lang].logout}
87
+ </a>
88
+ </div>
89
+ );
90
+ });
91
+
92
+ AUProfileWidgetComponent.defaultProps = {
93
+ studentNumber: null,
94
+ changeLanguageUrl: '',
95
+ };
96
+
97
+ AUProfileWidgetComponent.propTypes = {
98
+ lang: PropTypes.string.isRequired,
99
+ name: PropTypes.string.isRequired,
100
+ auid: PropTypes.number.isRequired,
101
+ studentNumber: PropTypes.string,
102
+ settings: PropTypes.arrayOf(PropTypes.shape({
103
+ type: PropTypes.string.isRequired,
104
+ url: PropTypes.string,
105
+ text: PropTypes.string.isRequired,
106
+ onClick: PropTypes.func,
107
+ classNames: PropTypes.string,
108
+ icon: PropTypes.string,
109
+ })).isRequired,
110
+ profileLabels: PropTypes.shape({}).isRequired,
111
+ changeLanguageUrl: PropTypes.string,
112
+ logoutUri: PropTypes.string.isRequired,
113
+ };
114
+
115
+ AUProfileWidgetComponent.displayName = 'AUProfileWidgetComponent';
116
+ export default AUProfileWidgetComponent;
@@ -1,122 +1,122 @@
1
- /* eslint-env browser */
2
- import React, {
3
- FC, useEffect, useState, useRef, memo,
4
- } from 'react';
5
- import { setCopyToClipboard } from '@aarhus-university/au-designsystem-delphinus/source/js/components/nav';
6
-
7
- const AUProfileWidgetComponent: FC<AUProfileWidgetComponentProps> = memo(({
8
- lang,
9
- name,
10
- auId,
11
- studentNumber,
12
- settings,
13
- changeLanguageUri,
14
- logoutUri,
15
- profileLabels,
16
- }: AUProfileWidgetComponentProps) => {
17
- const [ctcSet, setCtcSet] = useState<boolean>(false);
18
- const btnRefs = useRef<HTMLButtonElement[]>([]);
19
- btnRefs.current = [];
20
- const addToRefs = (el: HTMLButtonElement) => {
21
- if (el && !btnRefs.current.includes(el)) {
22
- btnRefs.current.push(el);
23
- }
24
- };
25
- const renderSettings = settings.map((s, i) => {
26
- if (s.type === 'anchor') {
27
- return (
28
- <a
29
- key={s.url}
30
- className={`sub-nav__item ${s.classNames}`}
31
- href={s.url}
32
- data-icon={s.icon}
33
- data-gtm={s.dataGtm}
34
- >
35
- {s.text}
36
- </a>
37
- );
38
- }
39
- return (
40
- <button
41
- key={s.text}
42
- ref={addToRefs}
43
- type="button"
44
- disabled={s.disabled}
45
- className={`sub-nav__item ${s.classNames}`}
46
- onClick={() => {
47
- if (typeof s.onClick === 'function') {
48
- s.onClick(btnRefs.current[i]);
49
- }
50
- }}
51
- data-icon={s.icon}
52
- data-gtm={s.dataGtm}
53
- >
54
- {s.text}
55
- </button>
56
- );
57
- });
58
-
59
- useEffect(() => {
60
- if (auId > 0 && !ctcSet) {
61
- setCopyToClipboard(lang);
62
- setCtcSet(true);
63
- }
64
- });
65
-
66
- return (
67
- <div className="sub-nav__content theme--normal" aria-labelledby="profile-menu-toggle">
68
- <div className="sub-nav__user">
69
- <h2 className="sub-nav__user-name">{name}</h2>
70
- <button
71
- type="button"
72
- className="copy-to-clipboard"
73
- title={profileLabels[lang].copyAuid}
74
- aria-label={`${profileLabels[lang].auId}: AU${auId}`}
75
- data-gtm="au-btn-header-copy-auid"
76
- >
77
- {`${profileLabels[lang].auId}: `}
78
- <span className="copy-to-clipboard__this">{`AU${auId}`}</span>
79
- </button>
80
- {
81
- studentNumber && (
82
- <button
83
- type="button"
84
- className="copy-to-clipboard"
85
- title={profileLabels[lang].copyStudentNumber}
86
- aria-label={`${profileLabels[lang].studentNumber}: ${studentNumber}`}
87
- >
88
- {`${profileLabels[lang].studentNumber}: `}
89
- <span className="copy-to-clipboard__this">{studentNumber}</span>
90
- </button>
91
- )
92
- }
93
- </div>
94
- <hr />
95
- {renderSettings}
96
- <hr />
97
- {
98
- changeLanguageUri && (
99
- <>
100
- <a className="sub-nav__item sub-nav__item--icon" href={changeLanguageUri} data-icon="" data-gtm="au-btn-header-profile-changelanguage">{profileLabels[lang].changeLanguage}</a>
101
- <hr />
102
- </>
103
- )
104
- }
105
- <a
106
- className="sub-nav__item sub-nav__item--icon"
107
- data-icon=""
108
- data-gtm="au-a-header-signout"
109
- href={logoutUri}
110
- >
111
- {profileLabels[lang].logout}
112
- </a>
113
- </div>
114
- );
115
- });
116
-
117
- AUProfileWidgetComponent.defaultProps = {
118
- studentNumber: '',
119
- };
120
-
121
- AUProfileWidgetComponent.displayName = 'AUProfileWidgetComponent';
122
- export default AUProfileWidgetComponent;
1
+ /* eslint-env browser */
2
+ import React, {
3
+ FC, useEffect, useState, useRef, memo,
4
+ } from 'react';
5
+ import { setCopyToClipboard } from '@aarhus-university/au-designsystem-delphinus/source/js/components/nav';
6
+
7
+ const AUProfileWidgetComponent: FC<AUProfileWidgetComponentProps> = memo(({
8
+ lang,
9
+ name,
10
+ auId,
11
+ studentNumber,
12
+ settings,
13
+ changeLanguageUri,
14
+ logoutUri,
15
+ profileLabels,
16
+ }: AUProfileWidgetComponentProps) => {
17
+ const [ctcSet, setCtcSet] = useState<boolean>(false);
18
+ const btnRefs = useRef<HTMLButtonElement[]>([]);
19
+ btnRefs.current = [];
20
+ const addToRefs = (el: HTMLButtonElement) => {
21
+ if (el && !btnRefs.current.includes(el)) {
22
+ btnRefs.current.push(el);
23
+ }
24
+ };
25
+ const renderSettings = settings.map((s, i) => {
26
+ if (s.type === 'anchor') {
27
+ return (
28
+ <a
29
+ key={s.url}
30
+ className={`sub-nav__item ${s.classNames}`}
31
+ href={s.url}
32
+ data-icon={s.icon}
33
+ data-gtm={s.dataGtm}
34
+ >
35
+ {s.text}
36
+ </a>
37
+ );
38
+ }
39
+ return (
40
+ <button
41
+ key={s.text}
42
+ ref={addToRefs}
43
+ type="button"
44
+ disabled={s.disabled}
45
+ className={`sub-nav__item ${s.classNames}`}
46
+ onClick={() => {
47
+ if (typeof s.onClick === 'function') {
48
+ s.onClick(btnRefs.current[i]);
49
+ }
50
+ }}
51
+ data-icon={s.icon}
52
+ data-gtm={s.dataGtm}
53
+ >
54
+ {s.text}
55
+ </button>
56
+ );
57
+ });
58
+
59
+ useEffect(() => {
60
+ if (auId > 0 && !ctcSet) {
61
+ setCopyToClipboard(lang);
62
+ setCtcSet(true);
63
+ }
64
+ });
65
+
66
+ return (
67
+ <div className="sub-nav__content theme--normal" aria-labelledby="profile-menu-toggle">
68
+ <div className="sub-nav__user">
69
+ <h2 className="sub-nav__user-name">{name}</h2>
70
+ <button
71
+ type="button"
72
+ className="copy-to-clipboard"
73
+ title={profileLabels[lang].copyAuid}
74
+ aria-label={`${profileLabels[lang].auId}: AU${auId}`}
75
+ data-gtm="au-btn-header-copy-auid"
76
+ >
77
+ {`${profileLabels[lang].auId}: `}
78
+ <span className="copy-to-clipboard__this">{`AU${auId}`}</span>
79
+ </button>
80
+ {
81
+ studentNumber && (
82
+ <button
83
+ type="button"
84
+ className="copy-to-clipboard"
85
+ title={profileLabels[lang].copyStudentNumber}
86
+ aria-label={`${profileLabels[lang].studentNumber}: ${studentNumber}`}
87
+ >
88
+ {`${profileLabels[lang].studentNumber}: `}
89
+ <span className="copy-to-clipboard__this">{studentNumber}</span>
90
+ </button>
91
+ )
92
+ }
93
+ </div>
94
+ <hr />
95
+ {renderSettings}
96
+ <hr />
97
+ {
98
+ changeLanguageUri && (
99
+ <>
100
+ <a className="sub-nav__item sub-nav__item--icon" href={changeLanguageUri} data-icon="" data-gtm="au-btn-header-profile-changelanguage">{profileLabels[lang].changeLanguage}</a>
101
+ <hr />
102
+ </>
103
+ )
104
+ }
105
+ <a
106
+ className="sub-nav__item sub-nav__item--icon"
107
+ data-icon=""
108
+ data-gtm="au-a-header-signout"
109
+ href={logoutUri}
110
+ >
111
+ {profileLabels[lang].logout}
112
+ </a>
113
+ </div>
114
+ );
115
+ });
116
+
117
+ AUProfileWidgetComponent.defaultProps = {
118
+ studentNumber: '',
119
+ };
120
+
121
+ AUProfileWidgetComponent.displayName = 'AUProfileWidgetComponent';
122
+ export default AUProfileWidgetComponent;
@@ -1,47 +1,47 @@
1
- /* eslint-env browser */
2
- import React, { useState } from 'react';
3
- import PropTypes from 'prop-types';
4
- import AUSpinnerComponent from '../delphinus/AUSpinnerComponent';
5
- import getSourceForFrame from '../../lib/wrapping';
6
-
7
- const AUEmbedComponent = ({
8
- api,
9
- path,
10
- referrer,
11
- }) => {
12
- const [source, setSource] = useState(null);
13
- const [frameLoaded, setFrameLoaded] = useState(false);
14
-
15
- return (
16
- <AUSpinnerComponent
17
- loaded={frameLoaded}
18
- loadingCondition={!frameLoaded}
19
- onLoad={() => {
20
- getSourceForFrame(api, path, referrer, (frameSrc) => {
21
- setSource(frameSrc.url);
22
- setFrameLoaded(true);
23
- });
24
- }}
25
- >
26
- <iframe
27
- id="AUEmbedIframe"
28
- title="AUEmbed"
29
- src={source}
30
- onLoad={() => {
31
- if (window.iFrameResize) {
32
- window.iFrameResize({ heightCalculationMethods: 'taggedElement', log: false }, '#AUEmbedIframe');
33
- }
34
- }}
35
- />
36
- </AUSpinnerComponent>
37
- );
38
- };
39
-
40
- AUEmbedComponent.propTypes = {
41
- path: PropTypes.string.isRequired,
42
- api: PropTypes.string.isRequired,
43
- referrer: PropTypes.string.isRequired,
44
- };
45
-
46
- AUEmbedComponent.displayName = 'AUEmbedComponent';
47
- export default AUEmbedComponent;
1
+ /* eslint-env browser */
2
+ import React, { useState } from 'react';
3
+ import PropTypes from 'prop-types';
4
+ import AUSpinnerComponent from '../delphinus/AUSpinnerComponent';
5
+ import getSourceForFrame from '../../lib/wrapping';
6
+
7
+ const AUEmbedComponent = ({
8
+ api,
9
+ path,
10
+ referrer,
11
+ }) => {
12
+ const [source, setSource] = useState(null);
13
+ const [frameLoaded, setFrameLoaded] = useState(false);
14
+
15
+ return (
16
+ <AUSpinnerComponent
17
+ loaded={frameLoaded}
18
+ loadingCondition={!frameLoaded}
19
+ onLoad={() => {
20
+ getSourceForFrame(api, path, referrer, (frameSrc) => {
21
+ setSource(frameSrc.url);
22
+ setFrameLoaded(true);
23
+ });
24
+ }}
25
+ >
26
+ <iframe
27
+ id="AUEmbedIframe"
28
+ title="AUEmbed"
29
+ src={source}
30
+ onLoad={() => {
31
+ if (window.iFrameResize) {
32
+ window.iFrameResize({ heightCalculationMethods: 'taggedElement', log: false }, '#AUEmbedIframe');
33
+ }
34
+ }}
35
+ />
36
+ </AUSpinnerComponent>
37
+ );
38
+ };
39
+
40
+ AUEmbedComponent.propTypes = {
41
+ path: PropTypes.string.isRequired,
42
+ api: PropTypes.string.isRequired,
43
+ referrer: PropTypes.string.isRequired,
44
+ };
45
+
46
+ AUEmbedComponent.displayName = 'AUEmbedComponent';
47
+ export default AUEmbedComponent;