@aarhus-university/au-lib-react-components 10.0.1 → 10.0.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.
Files changed (44) hide show
  1. package/build/umd/all.css +2 -2
  2. package/build/umd/all.js +1 -1
  3. package/build/umd/alphabox.js +1 -1
  4. package/build/umd/databox.js +1 -1
  5. package/build/umd/diagramme.js +1 -1
  6. package/build/umd/flowbox.js +1 -1
  7. package/build/umd/universe.js +1 -1
  8. package/package.json +3 -3
  9. package/src/components/AUAutoSuggestComponent.js +158 -158
  10. package/src/components/AUSpinnerComponent.tsx +91 -67
  11. package/src/components/AUTabbedContentComponent.tsx +1 -1
  12. package/src/components/AUToastComponent.tsx +11 -12
  13. package/src/components/profile/AUProfileLoginComponent.tsx +26 -26
  14. package/src/layout-2016/components/alphabox/AlphaBoxComponent.js +143 -143
  15. package/src/layout-2016/components/alphabox/AlphaBoxContentComponent.js +136 -136
  16. package/src/layout-2016/components/common/AUCollapsibleComponent.js +152 -152
  17. package/src/layout-2016/components/common/AUSpinnerComponent.js +103 -103
  18. package/src/layout-2016/components/databox/DataBoxAlphabetComponent.js +144 -144
  19. package/src/layout-2016/components/databox/DataBoxAssociationComponent.js +122 -122
  20. package/src/layout-2016/components/databox/DataBoxButtonComponent.js +157 -157
  21. package/src/layout-2016/components/databox/DataBoxComponent.js +297 -297
  22. package/src/layout-2016/components/databox/DataBoxGroupingComponent.js +64 -64
  23. package/src/layout-2016/components/databox/DataBoxSearchResultComponent.js +36 -36
  24. package/src/layout-2016/components/databox/DataBoxStackedAssociationComponent.js +54 -54
  25. package/src/layout-2016/components/databox/DataBoxSuggestionComponent.js +39 -39
  26. package/src/layout-2016/components/diagramme/AUDiagrammeComponent.js +309 -309
  27. package/src/layout-2016/components/flowbox/FlowBoxComponent.js +126 -126
  28. package/src/layout-2016/components/flowbox/FlowBoxPhoneComponent.js +104 -104
  29. package/src/layout-2016/components/profile/AUProfileAvatar2016Component.js +103 -103
  30. package/src/layout-2016/components/universe/StaffTopComponent.js +363 -363
  31. package/src/layout-2016/components/universe/StudentTopComponent.js +137 -137
  32. package/src/layout-2016/components/universe/UniverseContainerComponent.js +65 -65
  33. package/src/layout-2016/lib/all.js +3 -3
  34. package/src/layout-2016/lib/au-alphabox.js +100 -100
  35. package/src/layout-2016/lib/au-databox.js +400 -400
  36. package/src/layout-2016/lib/au-diagramme.js +85 -85
  37. package/src/layout-2016/lib/au-flowbox.js +93 -93
  38. package/src/layout-2016/lib/universe.js +9 -9
  39. package/src/lib/helpers.ts +194 -194
  40. package/tsconfig.json +46 -46
  41. package/types/common/interfaces/gui.d.ts +13 -1
  42. package/types/common/interfaces/model.d.ts +29 -29
  43. package/types/common/props.d.ts +166 -165
  44. package/webpack.config.js +89 -89
@@ -1,297 +1,297 @@
1
- /* eslint-env browser */
2
- /* eslint react/no-danger: 0 */
3
- import React from 'react';
4
- import PropTypes from 'prop-types';
5
- import { parse as qsParse } from 'query-string';
6
- import DataBoxButtonComponent from './DataBoxButtonComponent';
7
- import DataBoxGroupingComponent from './DataBoxGroupingComponent';
8
- import DataBoxSearchResultComponent from './DataBoxSearchResultComponent';
9
- import DataBoxAlphabetComponent from './DataBoxAlphabetComponent';
10
- import AUSpinnerComponent from '../common/AUSpinnerComponent';
11
- import { sortAlphaObj } from '../../../lib/helpers';
12
-
13
- class DataBoxComponent extends React.Component {
14
- constructor(props) {
15
- super(props);
16
-
17
- const qs = qsParse(window.location.search);
18
-
19
- const conf = props.box.config;
20
- const { stacked } = conf;
21
- const active = conf.rememberState && sessionStorage.getItem(`box-header-${props.box.id}`) ? parseInt(sessionStorage.getItem(`box-header-${props.box.id}`), 10) : props.box.config.trigger;
22
- this.state = {
23
- active,
24
- rawData: null,
25
- items: [],
26
- groupings: [],
27
- stacked,
28
- searchValue: typeof qs.initval === 'undefined' ? '' : decodeURIComponent(qs.initval),
29
- };
30
-
31
- this.setActive = this.setActive.bind(this);
32
- this.setSearchValue = this.setSearchValue.bind(this);
33
- this.getSuggestions = this.getSuggestions.bind(this);
34
- }
35
-
36
- componentDidMount() {
37
- const { parse, box } = this.props;
38
- const { searchValue } = this.state;
39
- parse(box.data.source, (data) => {
40
- const { items, groupings, rawData } = data;
41
- this.setState({
42
- items,
43
- groupings: groupings || [],
44
- rawData,
45
- });
46
- // this.setSearch(items);
47
- });
48
-
49
- if (searchValue !== '') {
50
- this.setSearchValue(searchValue);
51
- }
52
- }
53
-
54
- componentDidUpdate() {
55
- const { box } = this.props;
56
- const { rawData, items, groupings } = this.state;
57
- const d = box.data;
58
- if (typeof d.callback === 'function') {
59
- d.callback(rawData || {
60
- items,
61
- groupings,
62
- });
63
- }
64
- }
65
-
66
- setActive(active) {
67
- const { box } = this.props;
68
- this.setState({ active });
69
- if (box.config.rememberState) {
70
- sessionStorage.setItem(`box-header-${box.id}`, active);
71
- }
72
- }
73
-
74
- setSearchValue(searchValue) {
75
- const { box } = this.props;
76
- if (!box.search.autocomplete) {
77
- this.setState({ searchValue, active: searchValue === '' ? 0 : box.search.index });
78
- }
79
- }
80
-
81
- getSuggestions(value, collection, callback) {
82
- const { items } = this.state;
83
- const inputValue = value.trim().toLowerCase();
84
- const inputLength = inputValue.length;
85
- callback(inputLength < 2 ? []
86
- : items.filter((x) => x.name.toLowerCase().indexOf(inputValue) > -1)
87
- .sort(sortAlphaObj));
88
- }
89
-
90
- render() {
91
- const { box } = this.props;
92
- const {
93
- active,
94
- items,
95
- searchValue,
96
- groupings,
97
- stacked,
98
- } = this.state;
99
- const conf = box.config;
100
- const bg = box.background;
101
-
102
- const renderContent = (
103
- <div className="content">
104
- {(() => {
105
- const searchIndex = box.search.index;
106
- const alphaIndex = box.config.alphabet;
107
- const initLetter = box.config.rememberState && sessionStorage.getItem(`box-alphabet-${box.id}`)
108
- ? sessionStorage.getItem(`box-alphabet-${box.id}`) : box.config.initLetter;
109
- if (active === alphaIndex) {
110
- return (
111
- <DataBoxAlphabetComponent
112
- boxID={box.id}
113
- rememberState={box.config.rememberState}
114
- initLetter={initLetter}
115
- color={box.background.color}
116
- linkColor={box.background.linkColor}
117
- items={items}
118
- />
119
- );
120
- }
121
-
122
- if (searchValue !== '' && !box.search.autocomplete) {
123
- return (
124
- <DataBoxSearchResultComponent
125
- items={items}
126
- searchValue={searchValue}
127
- />
128
- );
129
- }
130
-
131
- let searchSubtract = 0;
132
- if (searchIndex > 0) {
133
- searchSubtract = searchIndex > active ? 0 : 1;
134
- }
135
-
136
- let alphaSubtract = 0;
137
- if (alphaIndex > 0) {
138
- alphaSubtract = alphaIndex > active ? 0 : 1;
139
- }
140
-
141
- const grouping = groupings[active - searchSubtract - alphaSubtract - 1];
142
- if (grouping) {
143
- return (
144
- <DataBoxGroupingComponent
145
- boxID={box.id}
146
- rememberState={box.config.rememberState}
147
- stacked={stacked}
148
- grouping={grouping}
149
- expand={box.config.expand}
150
- />
151
- );
152
- }
153
- // For callback purposes
154
- return <div className={`box-${box.id}-empty`} />;
155
- })()}
156
- </div>
157
- );
158
-
159
- const renderButtons = conf.buttons.map((b, i) => {
160
- const key = i;
161
- if (stacked) {
162
- return (
163
- <div key={key}>
164
- <DataBoxButtonComponent
165
- box={box}
166
- button={b}
167
- index={i}
168
- active={i + 1 === active}
169
- setActive={this.setActive}
170
- setSearchValue={this.setSearchValue}
171
- getSuggestions={this.getSuggestions}
172
- />
173
- {(() => {
174
- if (active > 0 && i + 1 === active) {
175
- return renderContent;
176
- }
177
- return null;
178
- })()}
179
- </div>
180
- );
181
- }
182
-
183
- return (
184
- <DataBoxButtonComponent
185
- key={key}
186
- box={box}
187
- button={b}
188
- index={i}
189
- active={i + 1 === active}
190
- searchValue={searchValue}
191
- setActive={this.setActive}
192
- setSearchValue={this.setSearchValue}
193
- getSuggestions={this.getSuggestions}
194
- />
195
- );
196
- });
197
-
198
- let classNames = `au_databox collapse buttons-${conf.buttons.length}`;
199
-
200
- if (conf.firstline) {
201
- classNames += ' first-line-full';
202
- }
203
-
204
- if (stacked) {
205
- classNames += ' stacked';
206
- }
207
-
208
- const style = {
209
- backgroundColor: bg.color,
210
- };
211
-
212
- if (bg.src !== '') {
213
- style.backgroundImage = `url('${bg.src}')`;
214
- }
215
-
216
- if (bg.height > 0) {
217
- style.height = bg.height;
218
- }
219
-
220
- const innerContent = (
221
- <div className={classNames}>
222
- <div className="button-wrapper" style={style}>
223
- {(() => {
224
- if (bg.text !== '') {
225
- return <div className="au_focus" dangerouslySetInnerHTML={{ __html: bg.text }} />;
226
- }
227
- return null;
228
- })()}
229
- <div>
230
- {renderButtons}
231
- </div>
232
- </div>
233
- {(() => {
234
- if (active > 0 && !stacked) {
235
- return renderContent;
236
- }
237
- return null;
238
- })()}
239
- </div>
240
- );
241
-
242
- return (
243
- <AUSpinnerComponent
244
- domID={`spinner-${box.config.container}`}
245
- loadingCondition={items.length === 0}
246
- loaded={items.length > 0}
247
- onLoad={() => {
248
- box.loaded = true;
249
- }}
250
- >
251
- {innerContent}
252
- </AUSpinnerComponent>
253
- );
254
- }
255
- }
256
-
257
- DataBoxComponent.defaultProps = {
258
-
259
- };
260
-
261
- DataBoxComponent.propTypes = {
262
- box: PropTypes.shape({
263
- id: PropTypes.number.isRequired,
264
- data: PropTypes.shape({
265
- source: PropTypes.string.isRequired,
266
- mode: PropTypes.string.isRequired,
267
- callback: PropTypes.func.isRequired,
268
- }),
269
- config: PropTypes.shape({
270
- expand: PropTypes.bool.isRequired,
271
- initLetter: PropTypes.string.isRequired,
272
- alphabet: PropTypes.number.isRequired,
273
- rememberState: PropTypes.bool.isRequired,
274
- trigger: PropTypes.number.isRequired,
275
- stacked: PropTypes.bool.isRequired,
276
- buttons: PropTypes.arrayOf(PropTypes.shape({})).isRequired,
277
- firstline: PropTypes.bool.isRequired,
278
- container: PropTypes.string.isRequired,
279
- }).isRequired,
280
- background: PropTypes.shape({
281
- color: PropTypes.string.isRequired,
282
- linkColor: PropTypes.string.isRequired,
283
- src: PropTypes.string.isRequired,
284
- height: PropTypes.string.isRequired,
285
- text: PropTypes.string.isRequired,
286
- }).isRequired,
287
- search: PropTypes.shape({
288
- autocomplete: PropTypes.bool.isRequired,
289
- index: PropTypes.number.isRequired,
290
- }).isRequired,
291
- loaded: PropTypes.bool.isRequired,
292
- }).isRequired,
293
- parse: PropTypes.func.isRequired,
294
- };
295
-
296
- DataBoxComponent.displayName = 'DataBoxComponent';
297
- export default DataBoxComponent;
1
+ /* eslint-env browser */
2
+ /* eslint react/no-danger: 0 */
3
+ import React from 'react';
4
+ import PropTypes from 'prop-types';
5
+ import { parse as qsParse } from 'query-string';
6
+ import DataBoxButtonComponent from './DataBoxButtonComponent';
7
+ import DataBoxGroupingComponent from './DataBoxGroupingComponent';
8
+ import DataBoxSearchResultComponent from './DataBoxSearchResultComponent';
9
+ import DataBoxAlphabetComponent from './DataBoxAlphabetComponent';
10
+ import AUSpinnerComponent from '../common/AUSpinnerComponent';
11
+ import { sortAlphaObj } from '../../../lib/helpers';
12
+
13
+ class DataBoxComponent extends React.Component {
14
+ constructor(props) {
15
+ super(props);
16
+
17
+ const qs = qsParse(window.location.search);
18
+
19
+ const conf = props.box.config;
20
+ const { stacked } = conf;
21
+ const active = conf.rememberState && sessionStorage.getItem(`box-header-${props.box.id}`) ? parseInt(sessionStorage.getItem(`box-header-${props.box.id}`), 10) : props.box.config.trigger;
22
+ this.state = {
23
+ active,
24
+ rawData: null,
25
+ items: [],
26
+ groupings: [],
27
+ stacked,
28
+ searchValue: typeof qs.initval === 'undefined' ? '' : decodeURIComponent(qs.initval),
29
+ };
30
+
31
+ this.setActive = this.setActive.bind(this);
32
+ this.setSearchValue = this.setSearchValue.bind(this);
33
+ this.getSuggestions = this.getSuggestions.bind(this);
34
+ }
35
+
36
+ componentDidMount() {
37
+ const { parse, box } = this.props;
38
+ const { searchValue } = this.state;
39
+ parse(box.data.source, (data) => {
40
+ const { items, groupings, rawData } = data;
41
+ this.setState({
42
+ items,
43
+ groupings: groupings || [],
44
+ rawData,
45
+ });
46
+ // this.setSearch(items);
47
+ });
48
+
49
+ if (searchValue !== '') {
50
+ this.setSearchValue(searchValue);
51
+ }
52
+ }
53
+
54
+ componentDidUpdate() {
55
+ const { box } = this.props;
56
+ const { rawData, items, groupings } = this.state;
57
+ const d = box.data;
58
+ if (typeof d.callback === 'function') {
59
+ d.callback(rawData || {
60
+ items,
61
+ groupings,
62
+ });
63
+ }
64
+ }
65
+
66
+ setActive(active) {
67
+ const { box } = this.props;
68
+ this.setState({ active });
69
+ if (box.config.rememberState) {
70
+ sessionStorage.setItem(`box-header-${box.id}`, active);
71
+ }
72
+ }
73
+
74
+ setSearchValue(searchValue) {
75
+ const { box } = this.props;
76
+ if (!box.search.autocomplete) {
77
+ this.setState({ searchValue, active: searchValue === '' ? 0 : box.search.index });
78
+ }
79
+ }
80
+
81
+ getSuggestions(value, collection, callback) {
82
+ const { items } = this.state;
83
+ const inputValue = value.trim().toLowerCase();
84
+ const inputLength = inputValue.length;
85
+ callback(inputLength < 2 ? []
86
+ : items.filter((x) => x.name.toLowerCase().indexOf(inputValue) > -1)
87
+ .sort(sortAlphaObj));
88
+ }
89
+
90
+ render() {
91
+ const { box } = this.props;
92
+ const {
93
+ active,
94
+ items,
95
+ searchValue,
96
+ groupings,
97
+ stacked,
98
+ } = this.state;
99
+ const conf = box.config;
100
+ const bg = box.background;
101
+
102
+ const renderContent = (
103
+ <div className="content">
104
+ {(() => {
105
+ const searchIndex = box.search.index;
106
+ const alphaIndex = box.config.alphabet;
107
+ const initLetter = box.config.rememberState && sessionStorage.getItem(`box-alphabet-${box.id}`)
108
+ ? sessionStorage.getItem(`box-alphabet-${box.id}`) : box.config.initLetter;
109
+ if (active === alphaIndex) {
110
+ return (
111
+ <DataBoxAlphabetComponent
112
+ boxID={box.id}
113
+ rememberState={box.config.rememberState}
114
+ initLetter={initLetter}
115
+ color={box.background.color}
116
+ linkColor={box.background.linkColor}
117
+ items={items}
118
+ />
119
+ );
120
+ }
121
+
122
+ if (searchValue !== '' && !box.search.autocomplete) {
123
+ return (
124
+ <DataBoxSearchResultComponent
125
+ items={items}
126
+ searchValue={searchValue}
127
+ />
128
+ );
129
+ }
130
+
131
+ let searchSubtract = 0;
132
+ if (searchIndex > 0) {
133
+ searchSubtract = searchIndex > active ? 0 : 1;
134
+ }
135
+
136
+ let alphaSubtract = 0;
137
+ if (alphaIndex > 0) {
138
+ alphaSubtract = alphaIndex > active ? 0 : 1;
139
+ }
140
+
141
+ const grouping = groupings[active - searchSubtract - alphaSubtract - 1];
142
+ if (grouping) {
143
+ return (
144
+ <DataBoxGroupingComponent
145
+ boxID={box.id}
146
+ rememberState={box.config.rememberState}
147
+ stacked={stacked}
148
+ grouping={grouping}
149
+ expand={box.config.expand}
150
+ />
151
+ );
152
+ }
153
+ // For callback purposes
154
+ return <div className={`box-${box.id}-empty`} />;
155
+ })()}
156
+ </div>
157
+ );
158
+
159
+ const renderButtons = conf.buttons.map((b, i) => {
160
+ const key = i;
161
+ if (stacked) {
162
+ return (
163
+ <div key={key}>
164
+ <DataBoxButtonComponent
165
+ box={box}
166
+ button={b}
167
+ index={i}
168
+ active={i + 1 === active}
169
+ setActive={this.setActive}
170
+ setSearchValue={this.setSearchValue}
171
+ getSuggestions={this.getSuggestions}
172
+ />
173
+ {(() => {
174
+ if (active > 0 && i + 1 === active) {
175
+ return renderContent;
176
+ }
177
+ return null;
178
+ })()}
179
+ </div>
180
+ );
181
+ }
182
+
183
+ return (
184
+ <DataBoxButtonComponent
185
+ key={key}
186
+ box={box}
187
+ button={b}
188
+ index={i}
189
+ active={i + 1 === active}
190
+ searchValue={searchValue}
191
+ setActive={this.setActive}
192
+ setSearchValue={this.setSearchValue}
193
+ getSuggestions={this.getSuggestions}
194
+ />
195
+ );
196
+ });
197
+
198
+ let classNames = `au_databox collapse buttons-${conf.buttons.length}`;
199
+
200
+ if (conf.firstline) {
201
+ classNames += ' first-line-full';
202
+ }
203
+
204
+ if (stacked) {
205
+ classNames += ' stacked';
206
+ }
207
+
208
+ const style = {
209
+ backgroundColor: bg.color,
210
+ };
211
+
212
+ if (bg.src !== '') {
213
+ style.backgroundImage = `url('${bg.src}')`;
214
+ }
215
+
216
+ if (bg.height > 0) {
217
+ style.height = bg.height;
218
+ }
219
+
220
+ const innerContent = (
221
+ <div className={classNames}>
222
+ <div className="button-wrapper" style={style}>
223
+ {(() => {
224
+ if (bg.text !== '') {
225
+ return <div className="au_focus" dangerouslySetInnerHTML={{ __html: bg.text }} />;
226
+ }
227
+ return null;
228
+ })()}
229
+ <div>
230
+ {renderButtons}
231
+ </div>
232
+ </div>
233
+ {(() => {
234
+ if (active > 0 && !stacked) {
235
+ return renderContent;
236
+ }
237
+ return null;
238
+ })()}
239
+ </div>
240
+ );
241
+
242
+ return (
243
+ <AUSpinnerComponent
244
+ domID={`spinner-${box.config.container}`}
245
+ loadingCondition={items.length === 0}
246
+ loaded={items.length > 0}
247
+ onLoad={() => {
248
+ box.loaded = true;
249
+ }}
250
+ >
251
+ {innerContent}
252
+ </AUSpinnerComponent>
253
+ );
254
+ }
255
+ }
256
+
257
+ DataBoxComponent.defaultProps = {
258
+
259
+ };
260
+
261
+ DataBoxComponent.propTypes = {
262
+ box: PropTypes.shape({
263
+ id: PropTypes.number.isRequired,
264
+ data: PropTypes.shape({
265
+ source: PropTypes.string.isRequired,
266
+ mode: PropTypes.string.isRequired,
267
+ callback: PropTypes.func.isRequired,
268
+ }),
269
+ config: PropTypes.shape({
270
+ expand: PropTypes.bool.isRequired,
271
+ initLetter: PropTypes.string.isRequired,
272
+ alphabet: PropTypes.number.isRequired,
273
+ rememberState: PropTypes.bool.isRequired,
274
+ trigger: PropTypes.number.isRequired,
275
+ stacked: PropTypes.bool.isRequired,
276
+ buttons: PropTypes.arrayOf(PropTypes.shape({})).isRequired,
277
+ firstline: PropTypes.bool.isRequired,
278
+ container: PropTypes.string.isRequired,
279
+ }).isRequired,
280
+ background: PropTypes.shape({
281
+ color: PropTypes.string.isRequired,
282
+ linkColor: PropTypes.string.isRequired,
283
+ src: PropTypes.string.isRequired,
284
+ height: PropTypes.string.isRequired,
285
+ text: PropTypes.string.isRequired,
286
+ }).isRequired,
287
+ search: PropTypes.shape({
288
+ autocomplete: PropTypes.bool.isRequired,
289
+ index: PropTypes.number.isRequired,
290
+ }).isRequired,
291
+ loaded: PropTypes.bool.isRequired,
292
+ }).isRequired,
293
+ parse: PropTypes.func.isRequired,
294
+ };
295
+
296
+ DataBoxComponent.displayName = 'DataBoxComponent';
297
+ export default DataBoxComponent;