@aarhus-university/au-lib-react-components 8.20.1 → 8.81.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 (167) hide show
  1. package/.eslintrc.js +44 -0
  2. package/README.md +19 -20
  3. package/babel.config.js +7 -0
  4. package/build/umd/all.css +1 -2
  5. package/build/umd/all.css.map +1 -1
  6. package/build/umd/all.js +1 -1
  7. package/build/umd/all.js.map +1 -1
  8. package/build/umd/alphabox.js +1 -1
  9. package/build/umd/alphabox.js.map +1 -1
  10. package/build/umd/databox.js +1 -6
  11. package/build/umd/databox.js.map +1 -1
  12. package/build/umd/diagramme.js +1 -1
  13. package/build/umd/diagramme.js.map +1 -1
  14. package/build/umd/flowbox.js +1 -1
  15. package/build/umd/flowbox.js.map +1 -1
  16. package/build/umd/universe.js +1 -1
  17. package/build/umd/universe.js.map +1 -1
  18. package/package.json +66 -65
  19. package/src/components/AUAlertComponent.tsx +70 -0
  20. package/src/components/{AutoSuggestComponent.js → AUAutoSuggestComponent.js} +45 -19
  21. package/src/components/AUCalendarComponent.tsx +493 -0
  22. package/src/components/AUContentToggleComponent.tsx +33 -0
  23. package/src/components/AUDatepickerComponent.tsx +117 -0
  24. package/src/components/AUMobilePrefixComponent.tsx +15 -0
  25. package/src/components/{delphinus/AUModalComponent.js → AUModalComponent.tsx} +78 -76
  26. package/src/components/{form/AUReceiptComponent.js → AUReceiptComponent.tsx} +33 -40
  27. package/src/components/AUSpinnerComponent.tsx +64 -0
  28. package/src/components/{delphinus/AUSubNavComponent.js → AUSubNavComponent.tsx} +38 -53
  29. package/src/components/{form/AUSubmitButtonContainerComponent.js → AUSubmitButtonContainerComponent.tsx} +31 -39
  30. package/src/components/AUTabbedContentComponent.tsx +145 -0
  31. package/src/components/{delphinus/AUTableComponent.js → AUTableComponent.tsx} +24 -28
  32. package/src/components/{delphinus/AUToastComponent.js → AUToastComponent.tsx} +104 -91
  33. package/src/components/{delphinus/AUToolbarComponent.js → AUToolbarComponent.tsx} +45 -48
  34. package/src/components/profile/AUProfileActions.js +128 -113
  35. package/src/components/profile/AUProfileAvatarComponent.js +83 -83
  36. package/src/components/profile/AUProfileAvatarV2Component.js +91 -0
  37. package/src/components/profile/AUProfileAvatarV3Component.tsx +42 -0
  38. package/src/components/profile/AUProfileContainerComponent.js +283 -285
  39. package/src/components/profile/AUProfileHooks.js +30 -30
  40. package/src/components/profile/AUProfileItemComponent.js +54 -54
  41. package/src/components/profile/AUProfileLanguageComponent.js +131 -131
  42. package/src/components/profile/AUProfileLoginComponent.js +0 -2
  43. package/src/components/profile/AUProfileMailComponent.js +307 -299
  44. package/src/components/profile/AUProfileMobileComponent.js +164 -164
  45. package/src/components/profile/AUProfileNameComponent.js +253 -253
  46. package/src/components/profile/AUProfileNextOfKinComponent.js +216 -216
  47. package/src/components/profile/AUProfileReducer.js +230 -210
  48. package/src/components/profile/AUProfileWidgetComponent.js +95 -95
  49. package/src/components/profile/AUProfileWidgetV2Component.js +116 -0
  50. package/src/components/profile/AUProfileWidgetV3Component.tsx +118 -0
  51. package/src/components/wrapping/AUEmbedComponent.js +47 -47
  52. package/src/{components → layout-2016/components}/alphabox/AlphaBoxComponent.js +29 -28
  53. package/src/{components → layout-2016/components}/alphabox/AlphaBoxContentComponent.js +25 -14
  54. package/src/{components → layout-2016/components/common}/AUCollapsibleComponent.js +1 -22
  55. package/src/{components → layout-2016/components/common}/AUSpinnerComponent.js +2 -24
  56. package/src/{components → layout-2016/components}/databox/DataBoxAlphabetComponent.js +1 -1
  57. package/src/{components → layout-2016/components}/databox/DataBoxAssociationComponent.js +2 -2
  58. package/src/{components → layout-2016/components}/databox/DataBoxButtonComponent.js +7 -3
  59. package/src/{components → layout-2016/components}/databox/DataBoxComponent.js +2 -2
  60. package/src/{components → layout-2016/components}/databox/DataBoxGroupingComponent.js +2 -0
  61. package/src/{components → layout-2016/components}/databox/DataBoxSearchResultComponent.js +1 -5
  62. package/src/{components → layout-2016/components}/databox/DataBoxStackedAssociationComponent.js +1 -5
  63. package/src/{components → layout-2016/components}/databox/DataBoxSuggestionComponent.js +0 -0
  64. package/src/{components → layout-2016/components/diagramme}/AUDiagrammeComponent.js +5 -6
  65. package/src/{components → layout-2016/components}/flowbox/FlowBoxComponent.js +8 -8
  66. package/src/{components → layout-2016/components}/flowbox/FlowBoxPhoneComponent.js +3 -5
  67. package/src/{components → layout-2016/components}/profile/AUProfileAvatar2016Component.js +6 -2
  68. package/src/{components → layout-2016/components}/universe/StaffTopComponent.js +4 -3
  69. package/src/{components → layout-2016/components}/universe/StudentTopComponent.js +0 -0
  70. package/src/{components → layout-2016/components}/universe/UniverseContainerComponent.js +11 -8
  71. package/src/layout-2016/lib/all.js +3 -0
  72. package/src/{lib → layout-2016/lib}/au-alphabox.js +1 -3
  73. package/src/{lib → layout-2016/lib}/au-databox.js +6 -9
  74. package/src/{lib → layout-2016/lib}/au-diagramme.js +2 -4
  75. package/src/{lib → layout-2016/lib}/au-flowbox.js +1 -3
  76. package/src/{lib → layout-2016/lib}/universe.js +0 -0
  77. package/src/lib/{helpers.js → helpers.ts} +41 -66
  78. package/src/{components/delphinus/hooks.js → lib/hooks.ts} +33 -26
  79. package/src/lib/{i18n.js → i18n.ts} +600 -595
  80. package/src/lib/tracking.ts +69 -0
  81. package/src/lib/{wrapping.js → wrapping.ts} +21 -16
  82. package/src/styles/_settings.scss +11 -11
  83. package/src/styles/alphabox.scss +222 -209
  84. package/src/styles/app.scss +7 -12
  85. package/src/styles/autosuggest.scss +57 -57
  86. package/src/styles/databox.scss +563 -563
  87. package/src/styles/diagramme.scss +119 -119
  88. package/src/styles/flowbox.scss +72 -72
  89. package/src/styles/maps.scss +396 -0
  90. package/tsconfig.json +47 -0
  91. package/types/common/interfaces.d.ts +83 -0
  92. package/types/common/main.d.ts +4 -0
  93. package/types/common/package.json +5 -0
  94. package/types/common/payloads.d.ts +0 -0
  95. package/types/common/props.d.ts +158 -0
  96. package/webpack.config.js +89 -0
  97. package/.eslintrc +0 -19
  98. package/DOCUMENTATION.md +0 -369
  99. package/build/cjs/auAuth.js +0 -2
  100. package/build/cjs/auAuth.js.map +0 -1
  101. package/build/dev.html +0 -329
  102. package/build/umd/auAuth.js +0 -2
  103. package/build/umd/auAuth.js.map +0 -1
  104. package/build/umd/news.js +0 -2
  105. package/build/umd/news.js.map +0 -1
  106. package/src/all.js +0 -3
  107. package/src/app.js +0 -263
  108. package/src/components/AUAlertComponent.js +0 -158
  109. package/src/components/AUAmountComponent.js +0 -84
  110. package/src/components/AUBannerComponent.js +0 -99
  111. package/src/components/AUCalendarComponent.js +0 -393
  112. package/src/components/AUDatepickerComponent.js +0 -105
  113. package/src/components/AUFilterCheckboxComponent.js +0 -122
  114. package/src/components/AUFocusComponent.js +0 -55
  115. package/src/components/AUModalComponent.js +0 -94
  116. package/src/components/AUPaginationComponent.js +0 -103
  117. package/src/components/context/AUUserContextComponent.js +0 -91
  118. package/src/components/context/ImpersonateComponent.js +0 -54
  119. package/src/components/delphinus/AUCalendarComponent.js +0 -422
  120. package/src/components/delphinus/AUContentToggleComponent.js +0 -32
  121. package/src/components/delphinus/AUDatepickerComponent.js +0 -113
  122. package/src/components/delphinus/AULoginComponent.js +0 -65
  123. package/src/components/delphinus/AUSpinnerComponent.js +0 -114
  124. package/src/components/delphinus/AUTabbedContentComponent.js +0 -53
  125. package/src/components/form/AUMobilePrefixComponent.js +0 -18
  126. package/src/components/news/EventLayout1Component.js +0 -94
  127. package/src/components/news/EventLayout2Component.js +0 -90
  128. package/src/components/news/EventLayout3Component.js +0 -68
  129. package/src/components/news/NewsCategoriesComponent.js +0 -21
  130. package/src/components/news/NewsCollageBannerComponent.js +0 -71
  131. package/src/components/news/NewsColumnsComponent.js +0 -125
  132. package/src/components/news/NewsLanguageChangeComponent.js +0 -74
  133. package/src/components/news/NewsLayout1Component.js +0 -80
  134. package/src/components/news/NewsLayout2Component.js +0 -80
  135. package/src/components/news/NewsLayout3Component.js +0 -81
  136. package/src/components/news/NewsLayout4Component.js +0 -80
  137. package/src/components/news/NewsLayout5Component.js +0 -61
  138. package/src/components/news/NewsLayout6Component.js +0 -55
  139. package/src/components/news/NewsLayout7Component.js +0 -58
  140. package/src/components/news/NewsLayout8Component.js +0 -57
  141. package/src/components/news/NewsListComponent.js +0 -291
  142. package/src/components/news/NewsPopUpComponent.js +0 -591
  143. package/src/components/news/NewsRSSComponent.js +0 -74
  144. package/src/components/news/NewsSocialComponent.js +0 -104
  145. package/src/components/news/NewsSubHeaderComponent.js +0 -19
  146. package/src/components/password/AUChangePasswordComponent.js +0 -177
  147. package/src/components/password/AUCurrentPasswordComponent.js +0 -72
  148. package/src/components/password/AUNewPasswordComponent.js +0 -143
  149. package/src/components/password/AUPasswordActions.js +0 -101
  150. package/src/components/password/AUPasswordHooks.js +0 -47
  151. package/src/components/password/AUPasswordReducer.js +0 -78
  152. package/src/components/password/AUPasswordRequirementsComponent.js +0 -29
  153. package/src/config/webpack.cjs.config.js +0 -75
  154. package/src/config/webpack.dev.config.js +0 -61
  155. package/src/config/webpack.umd.config.js +0 -107
  156. package/src/index.js +0 -6
  157. package/src/lib/au-auth.js +0 -221
  158. package/src/lib/au-news.js +0 -306
  159. package/src/lib/menu.js +0 -10
  160. package/src/lib/urlHandler.js +0 -63
  161. package/src/lib/validation.js +0 -181
  162. package/src/styles/alert.scss +0 -39
  163. package/src/styles/calendar.scss +0 -112
  164. package/src/styles/filtercheckbox.scss +0 -5
  165. package/src/styles/modal.scss +0 -35
  166. package/src/styles/pagination.scss +0 -11
  167. package/src/styles/spinner.scss +0 -30
@@ -1,83 +1,83 @@
1
- /* eslint-env browser */
2
- import React, { useEffect } from 'react';
3
- // eslint-disable-next-line import/extensions
4
- // import whyDidYouRender from '@welldone-software/
5
- // why-did-you-render/dist/no-classes-transpile/umd/whyDidYouRender.min.js';
6
- import PropTypes from 'prop-types';
7
- import AUProfileWidgetComponent from './AUProfileWidgetComponent';
8
- import AUSubNavComponent from '../delphinus/AUSubNavComponent';
9
-
10
- // whyDidYouRender(React);
11
-
12
- const AUProfileAvatarComponent = React.memo(({
13
- user,
14
- settings,
15
- onLoad,
16
- onLoadAction,
17
- profileLabels,
18
- logoutUri,
19
- changeLanguageUrl,
20
- }) => {
21
- const {
22
- chosenFirstNames,
23
- chosenLastName,
24
- preferredLanguage,
25
- auId,
26
- studentNumber,
27
- } = user;
28
-
29
- useEffect(() => {
30
- onLoad(onLoadAction);
31
- }, []);
32
-
33
- return (
34
- <AUSubNavComponent
35
- id="profile-menu-toggle"
36
- className="nav__item nav__item--icon nav__item--icon--right"
37
- dataIcon=""
38
- text={chosenFirstNames}
39
- ariaLabel={`${profileLabels[preferredLanguage].profileFor} ${chosenFirstNames} ${chosenLastName}`}
40
- >
41
- <AUProfileWidgetComponent
42
- lang={preferredLanguage}
43
- name={`${chosenFirstNames} ${chosenLastName}`}
44
- auid={auId}
45
- studentNumber={studentNumber}
46
- settings={settings}
47
- profileLabels={profileLabels}
48
- changeLanguageUrl={changeLanguageUrl}
49
- logoutUri={logoutUri}
50
- />
51
- </AUSubNavComponent>
52
- );
53
- });
54
-
55
- // AUProfileAvatarComponent.whyDidYouRender = true;
56
-
57
- AUProfileAvatarComponent.defaultProps = {
58
- onLoadAction: () => {
59
-
60
- },
61
- };
62
-
63
- AUProfileAvatarComponent.propTypes = {
64
- user: PropTypes.shape({
65
- chosenFirstNames: PropTypes.string.isRequired,
66
- chosenLastName: PropTypes.string.isRequired,
67
- preferredLanguage: PropTypes.string.isRequired,
68
- auId: PropTypes.number.isRequired,
69
- studentNumber: PropTypes.string.isRequired,
70
- }).isRequired,
71
- settings: PropTypes.arrayOf(PropTypes.shape({
72
- url: PropTypes.string.isRequired,
73
- text: PropTypes.string.isRequired,
74
- })).isRequired,
75
- onLoad: PropTypes.func.isRequired,
76
- onLoadAction: PropTypes.func,
77
- profileLabels: PropTypes.shape({}).isRequired,
78
- logoutUri: PropTypes.string.isRequired,
79
- changeLanguageUrl: PropTypes.string.isRequired,
80
- };
81
-
82
- AUProfileAvatarComponent.displayName = 'AUProfileAvatarComponent';
83
- export default AUProfileAvatarComponent;
1
+ /* eslint-env browser */
2
+ import React, { useEffect } from 'react';
3
+ // eslint-disable-next-line import/extensions
4
+ // import whyDidYouRender from '@welldone-software/
5
+ // why-did-you-render/dist/no-classes-transpile/umd/whyDidYouRender.min.js';
6
+ import PropTypes from 'prop-types';
7
+ import AUProfileWidgetComponent from './AUProfileWidgetComponent';
8
+ import AUSubNavComponent from '../delphinus/AUSubNavComponent';
9
+
10
+ // whyDidYouRender(React);
11
+
12
+ const AUProfileAvatarComponent = React.memo(({
13
+ user,
14
+ settings,
15
+ onLoad,
16
+ onLoadAction,
17
+ profileLabels,
18
+ logoutUri,
19
+ changeLanguageUrl,
20
+ }) => {
21
+ const {
22
+ chosenFirstNames,
23
+ chosenLastName,
24
+ preferredLanguage,
25
+ auId,
26
+ studentNumber,
27
+ } = user;
28
+
29
+ useEffect(() => {
30
+ onLoad(onLoadAction);
31
+ }, []);
32
+
33
+ return (
34
+ <AUSubNavComponent
35
+ id="profile-menu-toggle"
36
+ className="nav__item nav__item--icon nav__item--icon--right"
37
+ dataIcon=""
38
+ text={chosenFirstNames}
39
+ ariaLabel={`${profileLabels[preferredLanguage].profileFor} ${chosenFirstNames} ${chosenLastName}`}
40
+ >
41
+ <AUProfileWidgetComponent
42
+ lang={preferredLanguage}
43
+ name={`${chosenFirstNames} ${chosenLastName}`}
44
+ auid={auId}
45
+ studentNumber={studentNumber}
46
+ settings={settings}
47
+ profileLabels={profileLabels}
48
+ changeLanguageUrl={changeLanguageUrl}
49
+ logoutUri={logoutUri}
50
+ />
51
+ </AUSubNavComponent>
52
+ );
53
+ });
54
+
55
+ // AUProfileAvatarComponent.whyDidYouRender = true;
56
+
57
+ AUProfileAvatarComponent.defaultProps = {
58
+ onLoadAction: () => {
59
+
60
+ },
61
+ };
62
+
63
+ AUProfileAvatarComponent.propTypes = {
64
+ user: PropTypes.shape({
65
+ chosenFirstNames: PropTypes.string.isRequired,
66
+ chosenLastName: PropTypes.string.isRequired,
67
+ preferredLanguage: PropTypes.string.isRequired,
68
+ auId: PropTypes.number.isRequired,
69
+ studentNumber: PropTypes.string.isRequired,
70
+ }).isRequired,
71
+ settings: PropTypes.arrayOf(PropTypes.shape({
72
+ url: PropTypes.string.isRequired,
73
+ text: PropTypes.string.isRequired,
74
+ })).isRequired,
75
+ onLoad: PropTypes.func.isRequired,
76
+ onLoadAction: PropTypes.func,
77
+ profileLabels: PropTypes.shape({}).isRequired,
78
+ logoutUri: PropTypes.string.isRequired,
79
+ changeLanguageUrl: PropTypes.string.isRequired,
80
+ };
81
+
82
+ AUProfileAvatarComponent.displayName = 'AUProfileAvatarComponent';
83
+ export default AUProfileAvatarComponent;
@@ -0,0 +1,91 @@
1
+ /* eslint-env browser */
2
+ import React, { useEffect } from 'react';
3
+ import PropTypes from 'prop-types';
4
+ import AUProfileWidgetComponent from './AUProfileWidgetV2Component';
5
+ import AUSubNavComponent from '../delphinus/AUSubNavComponent';
6
+
7
+ const AUProfileAvatarComponent = React.memo(({
8
+ user,
9
+ settings,
10
+ onLoad,
11
+ onLoadAction,
12
+ profileLabels,
13
+ logoutUri,
14
+ changeLanguageUrl,
15
+ }) => {
16
+ const {
17
+ person: {
18
+ auPerson: {
19
+ auId, foretrukketSprog, kaldeFornavne, kaldeEfternavn,
20
+ },
21
+ },
22
+ } = user;
23
+ const studentNumber = user.studerende?.auUddannelsesidentitet?.studienr;
24
+
25
+ useEffect(() => {
26
+ if (typeof onLoad === 'function') {
27
+ onLoad(onLoadAction);
28
+ }
29
+ }, []);
30
+
31
+ return (
32
+ <AUSubNavComponent
33
+ id="profile-menu-toggle"
34
+ className="nav__item nav__item--icon nav__item--icon--right"
35
+ dataIcon=""
36
+ text={kaldeFornavne}
37
+ ariaLabel={`${profileLabels[foretrukketSprog].profileFor} ${kaldeFornavne} ${kaldeEfternavn}`}
38
+ >
39
+ <AUProfileWidgetComponent
40
+ lang={foretrukketSprog}
41
+ name={`${kaldeFornavne} ${kaldeEfternavn}`}
42
+ auid={auId}
43
+ studentNumber={studentNumber}
44
+ settings={settings}
45
+ profileLabels={profileLabels}
46
+ changeLanguageUrl={changeLanguageUrl}
47
+ logoutUri={logoutUri}
48
+ />
49
+ </AUSubNavComponent>
50
+ );
51
+ });
52
+
53
+ AUProfileAvatarComponent.defaultProps = {
54
+ onLoad: null,
55
+ onLoadAction: () => {
56
+
57
+ },
58
+ changeLanguageUrl: '',
59
+ };
60
+
61
+ AUProfileAvatarComponent.propTypes = {
62
+ user: PropTypes.shape({
63
+ person: PropTypes.shape({
64
+ auPerson: PropTypes.shape({
65
+ kaldeFornavne: PropTypes.string.isRequired,
66
+ kaldeEfternavn: PropTypes.string.isRequired,
67
+ auId: PropTypes.number.isRequired,
68
+ foretrukketSprog: PropTypes.string.isRequired,
69
+ }).isRequired,
70
+ }).isRequired,
71
+ studerende: PropTypes.shape({
72
+ auUddannelsesidentitet: PropTypes.shape({
73
+ studienr: PropTypes.number.isRequired,
74
+ }),
75
+ }),
76
+ }).isRequired,
77
+ settings: PropTypes.arrayOf(PropTypes.shape({
78
+ type: PropTypes.string.isRequired,
79
+ url: PropTypes.string,
80
+ text: PropTypes.string.isRequired,
81
+ onClick: PropTypes.func,
82
+ })).isRequired,
83
+ onLoad: PropTypes.func,
84
+ onLoadAction: PropTypes.func,
85
+ profileLabels: PropTypes.shape({}).isRequired,
86
+ logoutUri: PropTypes.string.isRequired,
87
+ changeLanguageUrl: PropTypes.string,
88
+ };
89
+
90
+ AUProfileAvatarComponent.displayName = 'AUProfileAvatarComponent';
91
+ export default AUProfileAvatarComponent;
@@ -0,0 +1,42 @@
1
+ /* eslint-env browser */
2
+ import React, { FC, memo } from 'react';
3
+ import AUProfileWidgetComponent from './AUProfileWidgetV3Component';
4
+ import AUSubNavComponent from '../AUSubNavComponent';
5
+
6
+ const AUProfileAvatarComponent: FC<AUProfileAvatarComponentProps> = memo(({
7
+ user,
8
+ settings,
9
+ profileLabels,
10
+ logoutUri,
11
+ changeLanguageUri,
12
+ lang,
13
+ }: AUProfileAvatarComponentProps) => {
14
+ const {
15
+ auId,
16
+ firstNames,
17
+ lastName,
18
+ } = user;
19
+
20
+ return (
21
+ <AUSubNavComponent
22
+ id="profile-menu-toggle"
23
+ className="nav__item nav__item--icon nav__item--icon--right"
24
+ dataIcon=""
25
+ text={firstNames}
26
+ ariaLabel={`${profileLabels[lang].profileFor} ${firstNames} ${lastName}`}
27
+ >
28
+ <AUProfileWidgetComponent
29
+ lang={lang}
30
+ name={`${firstNames} ${lastName}`}
31
+ auId={auId}
32
+ settings={settings}
33
+ profileLabels={profileLabels}
34
+ changeLanguageUri={changeLanguageUri}
35
+ logoutUri={logoutUri}
36
+ />
37
+ </AUSubNavComponent>
38
+ );
39
+ });
40
+
41
+ AUProfileAvatarComponent.displayName = 'AUProfileAvatarComponent';
42
+ export default AUProfileAvatarComponent;