@plone/volto 19.0.0-alpha.18 → 19.0.0-alpha.19

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 (109) hide show
  1. package/CHANGELOG.md +22 -5
  2. package/locales/af.json +1 -1
  3. package/locales/ar.json +1 -1
  4. package/locales/bg.json +1 -1
  5. package/locales/bn.json +1 -1
  6. package/locales/ca/LC_MESSAGES/volto.po +33 -0
  7. package/locales/ca.json +1 -1
  8. package/locales/cs.json +1 -1
  9. package/locales/cy.json +1 -1
  10. package/locales/da.json +1 -1
  11. package/locales/de/LC_MESSAGES/volto.po +33 -0
  12. package/locales/de.json +1 -1
  13. package/locales/el.json +1 -1
  14. package/locales/en/LC_MESSAGES/volto.po +33 -0
  15. package/locales/en.json +1 -1
  16. package/locales/en_AU.json +1 -1
  17. package/locales/en_GB.json +1 -1
  18. package/locales/eo.json +1 -1
  19. package/locales/es/LC_MESSAGES/volto.po +33 -0
  20. package/locales/es.json +1 -1
  21. package/locales/et.json +1 -1
  22. package/locales/eu/LC_MESSAGES/volto.po +33 -0
  23. package/locales/eu.json +1 -1
  24. package/locales/fa.json +1 -1
  25. package/locales/fi/LC_MESSAGES/volto.po +33 -0
  26. package/locales/fi.json +1 -1
  27. package/locales/fr/LC_MESSAGES/volto.po +33 -0
  28. package/locales/fr.json +1 -1
  29. package/locales/fu.json +1 -1
  30. package/locales/gl.json +1 -1
  31. package/locales/he.json +1 -1
  32. package/locales/hi/LC_MESSAGES/volto.po +33 -0
  33. package/locales/hi.json +1 -1
  34. package/locales/hr.json +1 -1
  35. package/locales/hu.json +1 -1
  36. package/locales/hy.json +1 -1
  37. package/locales/id.json +1 -1
  38. package/locales/it/LC_MESSAGES/volto.po +33 -0
  39. package/locales/it.json +1 -1
  40. package/locales/ja/LC_MESSAGES/volto.po +33 -0
  41. package/locales/ja.json +1 -1
  42. package/locales/ka.json +1 -1
  43. package/locales/kn.json +1 -1
  44. package/locales/ko.json +1 -1
  45. package/locales/lt.json +1 -1
  46. package/locales/lv.json +1 -1
  47. package/locales/mi.json +1 -1
  48. package/locales/mk.json +1 -1
  49. package/locales/my.json +1 -1
  50. package/locales/nb_NO.json +1 -1
  51. package/locales/nl/LC_MESSAGES/volto.po +33 -0
  52. package/locales/nl.json +1 -1
  53. package/locales/nn.json +1 -1
  54. package/locales/pl.json +1 -1
  55. package/locales/pt/LC_MESSAGES/volto.po +33 -0
  56. package/locales/pt.json +1 -1
  57. package/locales/pt_BR/LC_MESSAGES/volto.po +33 -0
  58. package/locales/pt_BR.json +1 -1
  59. package/locales/rm.json +1 -1
  60. package/locales/ro/LC_MESSAGES/volto.po +33 -0
  61. package/locales/ro.json +1 -1
  62. package/locales/ru/LC_MESSAGES/volto.po +33 -0
  63. package/locales/ru.json +1 -1
  64. package/locales/sk.json +1 -1
  65. package/locales/sl.json +1 -1
  66. package/locales/sm.json +1 -1
  67. package/locales/sq.json +1 -1
  68. package/locales/sr.json +1 -1
  69. package/locales/sr@cyrl.json +1 -1
  70. package/locales/sr@latn.json +1 -1
  71. package/locales/sv.json +1 -1
  72. package/locales/ta.json +1 -1
  73. package/locales/te.json +1 -1
  74. package/locales/th.json +1 -1
  75. package/locales/to.json +1 -1
  76. package/locales/tr.json +1 -1
  77. package/locales/uk.json +1 -1
  78. package/locales/vi.json +1 -1
  79. package/locales/volto.pot +34 -1
  80. package/locales/zh_CN/LC_MESSAGES/volto.po +33 -0
  81. package/locales/zh_CN.json +1 -1
  82. package/locales/zh_Hant.json +1 -1
  83. package/locales/zh_Hant_HK.json +1 -1
  84. package/package.json +5 -5
  85. package/src/components/manage/BlockChooser/BlockChooser.jsx +1 -0
  86. package/src/components/manage/Contents/Contents.jsx +685 -671
  87. package/src/components/manage/Contents/DropZoneContent.jsx +323 -0
  88. package/src/components/manage/Form/ModalForm.jsx +12 -10
  89. package/src/components/manage/Form/ModalForm.test.jsx +26 -0
  90. package/src/components/manage/Sidebar/ObjectBrowser.jsx +3 -0
  91. package/src/components/manage/Sidebar/ObjectBrowserBody.jsx +13 -1
  92. package/src/components/manage/Widgets/ObjectBrowserWidget.jsx +5 -0
  93. package/src/components/manage/Widgets/QueryWidget.jsx +136 -9
  94. package/src/components/theme/Unauthorized/Unauthorized.jsx +5 -2
  95. package/src/components/theme/View/View.jsx +7 -0
  96. package/src/reducers/querystring/querystring.js +8 -1
  97. package/theme/themes/pastanaga/extras/contents.less +63 -0
  98. package/theme/themes/pastanaga/extras/widgets.less +34 -0
  99. package/types/components/manage/Contents/DropZoneContent.d.ts +2 -0
  100. package/types/components/manage/Controlpanels/Relations/RelationsMatrix.d.ts +1 -1
  101. package/types/components/manage/Multilingual/ManageTranslations.d.ts +1 -1
  102. package/types/components/manage/Sidebar/ObjectBrowser.d.ts +1 -1
  103. package/types/components/manage/Widgets/ImageWidget.d.ts +1 -1
  104. package/types/components/manage/Widgets/InternalUrlWidget.d.ts +1 -1
  105. package/types/components/manage/Widgets/ObjectBrowserWidget.d.ts +2 -0
  106. package/types/components/manage/Widgets/QueryWidget.d.ts +5 -2
  107. package/types/components/manage/Widgets/UrlWidget.d.ts +1 -1
  108. package/types/components/manage/Widgets/index.d.ts +3 -3
  109. package/types/components/theme/Unauthorized/Unauthorized.d.ts +2 -2
@@ -15,8 +15,12 @@ import groupBy from 'lodash/groupBy';
15
15
  import isEmpty from 'lodash/isEmpty';
16
16
  import map from 'lodash/map';
17
17
  import { defineMessages, injectIntl } from 'react-intl';
18
+ import { withRouter } from 'react-router';
18
19
  import { getQuerystring } from '@plone/volto/actions/querystring/querystring';
20
+ import { getQueryStringResults } from '@plone/volto/actions/querystringsearch/querystringsearch';
19
21
  import Icon from '@plone/volto/components/theme/Icon/Icon';
22
+ import ObjectBrowserWidget from '@plone/volto/components/manage/Widgets/ObjectBrowserWidget';
23
+ import NumberWidget from '@plone/volto/components/manage/Widgets/NumberWidget';
20
24
  import { injectLazyLibs } from '@plone/volto/helpers/Loadable/Loadable';
21
25
  import cx from 'classnames';
22
26
  import config from '@plone/volto/registry';
@@ -43,8 +47,27 @@ const messages = defineMessages({
43
47
  id: 'querystring-widget-select',
44
48
  defaultMessage: 'Select…',
45
49
  },
50
+ currentPath: {
51
+ id: 'query-widget-currentPath',
52
+ defaultMessage: 'Current path (./)',
53
+ },
54
+ parentPath: {
55
+ id: 'query-widget-parentPath',
56
+ defaultMessage: 'Parent path (../)',
57
+ },
46
58
  });
47
59
 
60
+ const parseUidDepth = (val) => {
61
+ if (typeof val !== 'string') return { uid: '', depth: 1 };
62
+ const lastSep = String(val).lastIndexOf('::');
63
+ if (lastSep !== -1) {
64
+ const uid = val.substring(0, lastSep);
65
+ const parsed = parseInt(val.substring(lastSep + 2), 10);
66
+ return { uid, depth: Number.isNaN(parsed) ? 1 : parsed };
67
+ }
68
+ return { uid: val, depth: 1 };
69
+ };
70
+
48
71
  /**
49
72
  * Widget for a querystring value, to define a catalog search criteria.
50
73
  */
@@ -97,6 +120,7 @@ export class QuerystringWidgetComponent extends Component {
97
120
  };
98
121
  this.onChangeValue = this.onChangeValue.bind(this);
99
122
  this.getWidget = this.getWidget.bind(this);
123
+ this.loadReferenceWidgetItem = this.loadReferenceWidgetItem.bind(this);
100
124
  }
101
125
 
102
126
  /**
@@ -111,6 +135,27 @@ export class QuerystringWidgetComponent extends Component {
111
135
  this.props.getQuerystring();
112
136
  }
113
137
 
138
+ loadReferenceWidgetItem(v) {
139
+ const loading =
140
+ this.props.reference[`${v}_query_reference`]?.loading ?? false;
141
+ if (!loading && v?.length > 0) {
142
+ this.props.getQueryStringResults(
143
+ '/',
144
+ {
145
+ b_size: 1,
146
+ query: [
147
+ {
148
+ i: 'path',
149
+ o: 'plone.app.querystring.operation.string.absolutePath',
150
+ v: v + '::0',
151
+ },
152
+ ],
153
+ },
154
+ v + '_query_reference',
155
+ );
156
+ }
157
+ }
158
+
114
159
  /**
115
160
  * Get correct widget
116
161
  * @method getWidget
@@ -118,15 +163,16 @@ export class QuerystringWidgetComponent extends Component {
118
163
  * @param {number} index Row index.
119
164
  * @returns {Object} Widget.
120
165
  */
121
- getWidget(row, index, Select) {
166
+ getWidget(row, index, Select, intl) {
122
167
  const props = {
123
168
  fluid: true,
124
169
  value: row.v,
125
170
  onChange: (data) => this.onChangeValue(index, data.target.value),
126
171
  };
127
172
  const values = this.props.indexes[row.i].values;
173
+ const operator = this.props.indexes[row.i].operators[row.o];
128
174
 
129
- switch (this.props.indexes[row.i].operators[row.o].widget) {
175
+ switch (operator.widget) {
130
176
  case null:
131
177
  return <span />;
132
178
  case 'DateWidget':
@@ -217,13 +263,92 @@ export class QuerystringWidgetComponent extends Component {
217
263
  </Form.Field>
218
264
  );
219
265
  case 'ReferenceWidget':
266
+ const { uid: uidValue, depth: depthValue } = parseUidDepth(props.value);
267
+ if (!this.props.reference[`${uidValue}_query_reference`]) {
268
+ this.loadReferenceWidgetItem(uidValue);
269
+ }
270
+ const referenceItem = this.props.reference[
271
+ `${uidValue}_query_reference`
272
+ ]
273
+ ? this.props.reference[`${uidValue}_query_reference`].items[0]
274
+ : null;
275
+ return (
276
+ <div className="location-object-browser">
277
+ <Form.Field className="object-browser-field">
278
+ <ObjectBrowserWidget
279
+ id={`query-reference-widget-${index}`}
280
+ mode="link"
281
+ onChange={(id, data) => {
282
+ const itemSelected = data.length > 0 ? data[0] : {};
283
+ const uid = itemSelected.UID ?? '';
284
+ this.onChangeValue(index, uid ? `${uid}::${depthValue}` : '');
285
+ this.loadReferenceWidgetItem(uid);
286
+ }}
287
+ value={uidValue && this.props.reference ? [referenceItem] : []}
288
+ wrapped={false}
289
+ onlyFolderishSelectable={true}
290
+ />
291
+ </Form.Field>
292
+
293
+ {uidValue && (
294
+ <Form.Field className="reference-widget-depth">
295
+ <NumberWidget
296
+ title={intl.formatMessage({
297
+ id: 'Depth',
298
+ defaultMessage: 'Depth',
299
+ })}
300
+ min={1}
301
+ step={1}
302
+ value={depthValue}
303
+ onChange={(id, value) => {
304
+ const newDepth = parseInt(value, 10) || 1;
305
+ const curUid = uidValue || '';
306
+ this.onChangeValue(index, `${curUid}::${newDepth}`);
307
+ }}
308
+ />
309
+ </Form.Field>
310
+ )}
311
+ </div>
312
+ );
313
+ case 'RelativePathWidget':
314
+ const relativePathOptions = [
315
+ {
316
+ label: intl.formatMessage(messages.currentPath),
317
+ value: './',
318
+ },
319
+ {
320
+ label: intl.formatMessage(messages.parentPath),
321
+ value: '../',
322
+ },
323
+ ];
324
+ return (
325
+ <Form.Field style={{ flex: '1 0 auto', maxWidth: '92%' }}>
326
+ <Select
327
+ {...props}
328
+ className="react-select-container"
329
+ classNamePrefix="react-select"
330
+ options={relativePathOptions}
331
+ styles={customSelectStyles}
332
+ placeholder={this.props.intl.formatMessage(messages.select)}
333
+ theme={selectTheme}
334
+ components={{ DropdownIndicator, Option }}
335
+ onChange={(data) => {
336
+ this.onChangeValue(index, data.value);
337
+ }}
338
+ isMulti={false}
339
+ value={
340
+ relativePathOptions.filter((p) => p.value === props.value)?.[0]
341
+ }
342
+ />
343
+ </Form.Field>
344
+ );
220
345
  default:
221
346
  // if (row.o === 'plone.app.querystring.operation.string.relativePath') {
222
347
  // props.onChange = data => this.onChangeValue(index, data.target.value);
223
348
  // }
224
349
  return (
225
350
  <Form.Field style={{ flex: '1 0 auto' }}>
226
- <Input {...props} />
351
+ <Input {...props} description={operator.description} />
227
352
  </Form.Field>
228
353
  );
229
354
  }
@@ -334,7 +459,7 @@ export class QuerystringWidgetComponent extends Component {
334
459
  value: row.i,
335
460
  label: indexes[row.i]?.title,
336
461
  }}
337
- onChange={(data) =>
462
+ onChange={(data) => {
338
463
  onChange(
339
464
  id,
340
465
  map(value, (curRow, curIndex) =>
@@ -346,8 +471,8 @@ export class QuerystringWidgetComponent extends Component {
346
471
  }
347
472
  : curRow,
348
473
  ),
349
- )
350
- }
474
+ );
475
+ }}
351
476
  />
352
477
  </Form.Field>
353
478
  <Form.Field style={{ flex: '1 0 auto' }}>
@@ -408,7 +533,7 @@ export class QuerystringWidgetComponent extends Component {
408
533
  </Button>
409
534
  )}
410
535
  </div>
411
- {this.getWidget(row, index, Select)}
536
+ {this.getWidget(row, index, Select, intl)}
412
537
  {this.props.indexes[row.i].operators[row.o].widget && (
413
538
  <Button
414
539
  onClick={(event) => {
@@ -500,10 +625,12 @@ export class QuerystringWidgetComponent extends Component {
500
625
  export default compose(
501
626
  injectIntl,
502
627
  injectLazyLibs(['reactSelect']),
628
+ withRouter,
503
629
  connect(
504
- (state) => ({
630
+ (state, props) => ({
505
631
  indexes: state.querystring.indexes,
632
+ reference: state.querystringsearch.subrequests,
506
633
  }),
507
- { getQuerystring },
634
+ { getQuerystring, getQueryStringResults },
508
635
  ),
509
636
  )(QuerystringWidgetComponent);
@@ -5,6 +5,7 @@ import { useSelector } from 'react-redux';
5
5
  import { useLocation } from 'react-router-dom';
6
6
  import { withServerErrorCode } from '@plone/volto/helpers/Utils/Utils';
7
7
  import { getBaseUrl } from '@plone/volto/helpers/Url/Url';
8
+ import BodyClass from '@plone/volto/helpers/BodyClass/BodyClass';
8
9
 
9
10
  const Unauthorized = () => {
10
11
  const error_message = useSelector((state) => state.apierror?.message);
@@ -12,6 +13,7 @@ const Unauthorized = () => {
12
13
 
13
14
  return (
14
15
  <Container className="view-wrapper">
16
+ <BodyClass className="view-unauthorized" />
15
17
  <h1>
16
18
  <FormattedMessage id="Unauthorized" defaultMessage="Unauthorized" />
17
19
  </h1>
@@ -62,5 +64,6 @@ const Unauthorized = () => {
62
64
  </Container>
63
65
  );
64
66
  };
65
-
66
- export default withServerErrorCode(401)(Unauthorized);
67
+ const UnauthorizedWithCode = withServerErrorCode(401)(Unauthorized);
68
+ UnauthorizedWithCode.displayName = 'unauthorized';
69
+ export default UnauthorizedWithCode;
@@ -222,6 +222,13 @@ class View extends Component {
222
222
  }
223
223
  return (
224
224
  <div id="view">
225
+ <BodyClass
226
+ className={
227
+ FoundView.displayName
228
+ ? `view-${this.cleanViewName(FoundView.displayName)}`
229
+ : null
230
+ }
231
+ />
225
232
  <FoundView {...this.props} />
226
233
  </div>
227
234
  );
@@ -30,10 +30,17 @@ export default function querystring(state = initialState, action = {}) {
30
30
  loading: true,
31
31
  };
32
32
  case `${GET_QUERYSTRING}_SUCCESS`:
33
+ let indexes = action.result.indexes;
34
+ if (indexes?.path?.operations) {
35
+ //remove path operation, to remove unhandled 'Navigation path' option from QueryWidget
36
+ indexes.path.operations = indexes.path.operations.filter(
37
+ (o) => o !== 'plone.app.querystring.operation.string.path',
38
+ );
39
+ }
33
40
  return {
34
41
  ...state,
35
42
  error: null,
36
- indexes: action.result.indexes,
43
+ indexes: indexes,
37
44
  sortable_indexes: action.result.sortable_indexes,
38
45
  loaded: true,
39
46
  loading: false,
@@ -267,3 +267,66 @@
267
267
  overflow: auto;
268
268
  max-height: 75vh;
269
269
  }
270
+
271
+ .contents-dropzone {
272
+ position: relative;
273
+
274
+ &.drag-over {
275
+ overflow: hidden;
276
+ }
277
+ }
278
+
279
+ .dropzone-overlay {
280
+ position: absolute;
281
+ z-index: 10;
282
+ display: flex;
283
+ align-items: center;
284
+ justify-content: center;
285
+ border: 3px dashed black;
286
+ animation: fadeIn 0.3s ease-in;
287
+ backdrop-filter: blur(2px);
288
+ inset: 0;
289
+ }
290
+
291
+ .dropzone-content {
292
+ animation: scaleIn 0.3s ease-out;
293
+ color: black;
294
+ text-align: center;
295
+
296
+ h3 {
297
+ margin-top: 16px;
298
+ font-size: 24px;
299
+ font-weight: 600;
300
+ }
301
+
302
+ p {
303
+ font-size: 18px;
304
+ }
305
+
306
+ h3,
307
+ p {
308
+ color: black;
309
+ }
310
+ }
311
+
312
+ @keyframes fadeIn {
313
+ from {
314
+ opacity: 0;
315
+ }
316
+
317
+ to {
318
+ opacity: 1;
319
+ }
320
+ }
321
+
322
+ @keyframes scaleIn {
323
+ from {
324
+ opacity: 0;
325
+ transform: scale(0.9);
326
+ }
327
+
328
+ to {
329
+ opacity: 1;
330
+ transform: scale(1);
331
+ }
332
+ }
@@ -337,3 +337,37 @@ body.babel-view .field.language-independent-field {
337
337
  color: var(--text-color-disabled);
338
338
  }
339
339
  }
340
+
341
+ .ui.form .query-widget {
342
+ .location-object-browser {
343
+ display: flex;
344
+ flex-flow: column;
345
+ flex-grow: 1;
346
+
347
+ .object-browser-field {
348
+ min-height: 60px;
349
+ flex: 1 0 auto;
350
+ padding-right: 1em;
351
+ padding-left: 1em;
352
+ margin-bottom: 0px;
353
+ }
354
+
355
+ .object-browser-field + .field {
356
+ margin-bottom: 0px;
357
+ }
358
+
359
+ .objectbrowser-field {
360
+ height: 100%;
361
+ }
362
+
363
+ .reference-widget-depth {
364
+ .field {
365
+ margin-bottom: 0px;
366
+ }
367
+ }
368
+ }
369
+
370
+ .location-object-browser + button.ui.button {
371
+ padding-top: 0;
372
+ }
373
+ }
@@ -0,0 +1,2 @@
1
+ export default DropZoneContent;
2
+ declare function DropZoneContent(props: any): import("react/jsx-runtime").JSX.Element;
@@ -3,7 +3,7 @@ declare const _default: {
3
3
  state: {
4
4
  isObjectBrowserOpen: boolean;
5
5
  };
6
- openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, }?: {
6
+ openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, onlyFolderishSelectable, }?: {
7
7
  mode: string;
8
8
  dataName: string;
9
9
  onSelectItem: string;
@@ -3,7 +3,7 @@ declare const _default: {
3
3
  state: {
4
4
  isObjectBrowserOpen: boolean;
5
5
  };
6
- openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, }?: {
6
+ openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, onlyFolderishSelectable, }?: {
7
7
  mode: string;
8
8
  dataName: string;
9
9
  onSelectItem: string;
@@ -31,7 +31,7 @@ declare function withObjectBrowser(WrappedComponent: any): {
31
31
  * }),
32
32
  * });
33
33
  */
34
- openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, }?: {
34
+ openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, onlyFolderishSelectable, }?: {
35
35
  mode: string;
36
36
  dataName: string;
37
37
  onSelectItem: string;
@@ -10,7 +10,7 @@ export const ImageInput: {
10
10
  state: {
11
11
  isObjectBrowserOpen: boolean;
12
12
  };
13
- openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, }?: {
13
+ openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, onlyFolderishSelectable, }?: {
14
14
  mode: string;
15
15
  dataName: string;
16
16
  onSelectItem: string;
@@ -41,7 +41,7 @@ declare const _default: {
41
41
  state: {
42
42
  isObjectBrowserOpen: boolean;
43
43
  };
44
- openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, }?: {
44
+ openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, onlyFolderishSelectable, }?: {
45
45
  mode: string;
46
46
  dataName: string;
47
47
  onSelectItem: string;
@@ -23,6 +23,7 @@ export class ObjectBrowserWidgetComponent extends React.Component<any, any, any>
23
23
  openObjectBrowser: any;
24
24
  allowExternals: any;
25
25
  placeholder: any;
26
+ onlyFolderishSelectable: any;
26
27
  };
27
28
  /**
28
29
  * Default properties
@@ -38,6 +39,7 @@ export class ObjectBrowserWidgetComponent extends React.Component<any, any, any>
38
39
  return: string;
39
40
  initialPath: string;
40
41
  allowExternals: boolean;
42
+ onlyFolderishSelectable: boolean;
41
43
  };
42
44
  constructor(props: any);
43
45
  state: {
@@ -60,7 +60,8 @@ export class QuerystringWidgetComponent extends React.Component<any, any, any> {
60
60
  * @param {number} index Row index.
61
61
  * @returns {Object} Widget.
62
62
  */
63
- getWidget(row: any, index: number, Select: any): any;
63
+ getWidget(row: any, index: number, Select: any, intl: any): any;
64
+ loadReferenceWidgetItem(v: any): void;
64
65
  /**
65
66
  * Component did mount lifecycle method
66
67
  * @method componentDidMount
@@ -74,6 +75,8 @@ export class QuerystringWidgetComponent extends React.Component<any, any, any> {
74
75
  */
75
76
  render(): string;
76
77
  }
77
- declare const _default: any;
78
+ declare const _default: React.ForwardRefExoticComponent<Omit<import("react-intl").WithIntlProps<import("react-intl").WrappedComponentProps<string>>, "ref"> & React.RefAttributes<React.ComponentType<import("react-intl").WrappedComponentProps<string>>>> & {
79
+ WrappedComponent: React.ComponentType<import("react-intl").WrappedComponentProps<string>>;
80
+ };
78
81
  export default _default;
79
82
  import React from 'react';
@@ -41,7 +41,7 @@ declare const _default: {
41
41
  state: {
42
42
  isObjectBrowserOpen: boolean;
43
43
  };
44
- openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, }?: {
44
+ openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, onlyFolderishSelectable, }?: {
45
45
  mode: string;
46
46
  dataName: string;
47
47
  onSelectItem: string;
@@ -9,7 +9,7 @@ export declare const FileWidget: import("@loadable/component").LoadableComponent
9
9
  export declare const HiddenWidget: import("@loadable/component").LoadableComponent<any>;
10
10
  export declare const IdWidget: import("@loadable/component").LoadableComponent<any>;
11
11
  export declare const PasswordWidget: import("@loadable/component").LoadableComponent<import("react-intl").WithIntlProps<any>>;
12
- export declare const QueryWidget: import("@loadable/component").LoadableClassComponent<any>;
12
+ export declare const QueryWidget: import("@loadable/component").LoadableComponent<Omit<import("react-intl").WithIntlProps<import("react-intl").WrappedComponentProps<string>>, "ref"> & import("react").RefAttributes<import("react").ComponentType<import("react-intl").WrappedComponentProps<string>>>>;
13
13
  export declare const QuerySortOnWidget: import("@loadable/component").LoadableClassComponent<any>;
14
14
  export declare const QuerystringWidget: import("@loadable/component").LoadableComponent<any>;
15
15
  export declare const RadioGroupWidget: import("@loadable/component").LoadableClassComponent<any>;
@@ -25,7 +25,7 @@ export declare const UrlWidget: import("@loadable/component").LoadableClassCompo
25
25
  state: {
26
26
  isObjectBrowserOpen: boolean;
27
27
  };
28
- openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, }?: {
28
+ openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, onlyFolderishSelectable, }?: {
29
29
  mode: string;
30
30
  dataName: string;
31
31
  onSelectItem: string;
@@ -65,7 +65,7 @@ export declare const InternalUrlWidget: import("@loadable/component").LoadableCl
65
65
  state: {
66
66
  isObjectBrowserOpen: boolean;
67
67
  };
68
- openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, }?: {
68
+ openObjectBrowser: ({ mode, onSelectItem, dataName, overlay, propDataName, searchableTypes, selectableTypes, maximumSelectionSize, currentPath, onlyFolderishSelectable, }?: {
69
69
  mode: string;
70
70
  dataName: string;
71
71
  onSelectItem: string;
@@ -1,2 +1,2 @@
1
- declare const _default: (props: any) => import("react/jsx-runtime").JSX.Element;
2
- export default _default;
1
+ export default UnauthorizedWithCode;
2
+ declare const UnauthorizedWithCode: (props: any) => import("react/jsx-runtime").JSX.Element;