@wordpress/dataviews 4.2.0 → 4.3.1-next.5368f64a9.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 (125) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/README.md +47 -7
  3. package/build/components/dataviews/index.js +3 -5
  4. package/build/components/dataviews/index.js.map +1 -1
  5. package/build/components/dataviews-bulk-actions/index.js +145 -141
  6. package/build/components/dataviews-bulk-actions/index.js.map +1 -1
  7. package/build/components/dataviews-filters/add-filter.js +4 -6
  8. package/build/components/dataviews-filters/add-filter.js.map +1 -1
  9. package/build/components/dataviews-filters/search-widget.js +27 -25
  10. package/build/components/dataviews-filters/search-widget.js.map +1 -1
  11. package/build/components/dataviews-footer/index.js +45 -0
  12. package/build/components/dataviews-footer/index.js.map +1 -0
  13. package/build/components/dataviews-item-actions/index.js +5 -8
  14. package/build/components/dataviews-item-actions/index.js.map +1 -1
  15. package/build/components/dataviews-pagination/index.js +4 -4
  16. package/build/components/dataviews-pagination/index.js.map +1 -1
  17. package/build/components/dataviews-view-config/index.js +171 -32
  18. package/build/components/dataviews-view-config/index.js.map +1 -1
  19. package/build/dataforms-layouts/panel/index.js +4 -1
  20. package/build/dataforms-layouts/panel/index.js.map +1 -1
  21. package/build/dataviews-layouts/index.js +48 -2
  22. package/build/dataviews-layouts/index.js.map +1 -1
  23. package/build/dataviews-layouts/list/index.js +131 -91
  24. package/build/dataviews-layouts/list/index.js.map +1 -1
  25. package/build/dataviews-layouts/table/column-header-menu.js +52 -54
  26. package/build/dataviews-layouts/table/column-header-menu.js.map +1 -1
  27. package/build/dataviews-layouts/table/index.js +7 -35
  28. package/build/dataviews-layouts/table/index.js.map +1 -1
  29. package/build/normalize-fields.js +4 -2
  30. package/build/normalize-fields.js.map +1 -1
  31. package/build/types.js.map +1 -1
  32. package/build-module/components/dataviews/index.js +3 -5
  33. package/build-module/components/dataviews/index.js.map +1 -1
  34. package/build-module/components/dataviews-bulk-actions/index.js +145 -143
  35. package/build-module/components/dataviews-bulk-actions/index.js.map +1 -1
  36. package/build-module/components/dataviews-filters/add-filter.js +4 -6
  37. package/build-module/components/dataviews-filters/add-filter.js.map +1 -1
  38. package/build-module/components/dataviews-filters/search-widget.js +27 -25
  39. package/build-module/components/dataviews-filters/search-widget.js.map +1 -1
  40. package/build-module/components/dataviews-footer/index.js +38 -0
  41. package/build-module/components/dataviews-footer/index.js.map +1 -0
  42. package/build-module/components/dataviews-item-actions/index.js +5 -8
  43. package/build-module/components/dataviews-item-actions/index.js.map +1 -1
  44. package/build-module/components/dataviews-pagination/index.js +5 -5
  45. package/build-module/components/dataviews-pagination/index.js.map +1 -1
  46. package/build-module/components/dataviews-view-config/index.js +177 -38
  47. package/build-module/components/dataviews-view-config/index.js.map +1 -1
  48. package/build-module/dataforms-layouts/panel/index.js +4 -1
  49. package/build-module/dataforms-layouts/panel/index.js.map +1 -1
  50. package/build-module/dataviews-layouts/index.js +45 -1
  51. package/build-module/dataviews-layouts/index.js.map +1 -1
  52. package/build-module/dataviews-layouts/list/index.js +132 -90
  53. package/build-module/dataviews-layouts/list/index.js.map +1 -1
  54. package/build-module/dataviews-layouts/table/column-header-menu.js +52 -54
  55. package/build-module/dataviews-layouts/table/column-header-menu.js.map +1 -1
  56. package/build-module/dataviews-layouts/table/index.js +9 -37
  57. package/build-module/dataviews-layouts/table/index.js.map +1 -1
  58. package/build-module/normalize-fields.js +4 -2
  59. package/build-module/normalize-fields.js.map +1 -1
  60. package/build-module/types.js.map +1 -1
  61. package/build-style/style-rtl.css +79 -67
  62. package/build-style/style.css +79 -67
  63. package/build-types/components/dataviews/index.d.ts.map +1 -1
  64. package/build-types/components/dataviews/stories/fixtures.d.ts +27 -131
  65. package/build-types/components/dataviews/stories/fixtures.d.ts.map +1 -1
  66. package/build-types/components/dataviews/stories/index.story.d.ts +13 -53
  67. package/build-types/components/dataviews/stories/index.story.d.ts.map +1 -1
  68. package/build-types/components/dataviews-bulk-actions/index.d.ts +11 -1
  69. package/build-types/components/dataviews-bulk-actions/index.d.ts.map +1 -1
  70. package/build-types/components/dataviews-filters/add-filter.d.ts.map +1 -1
  71. package/build-types/components/dataviews-filters/search-widget.d.ts +3 -0
  72. package/build-types/components/dataviews-filters/search-widget.d.ts.map +1 -1
  73. package/build-types/components/dataviews-footer/index.d.ts +2 -0
  74. package/build-types/components/dataviews-footer/index.d.ts.map +1 -0
  75. package/build-types/components/dataviews-item-actions/index.d.ts.map +1 -1
  76. package/build-types/components/dataviews-view-config/index.d.ts.map +1 -1
  77. package/build-types/dataforms-layouts/panel/index.d.ts.map +1 -1
  78. package/build-types/dataviews-layouts/index.d.ts +4 -2
  79. package/build-types/dataviews-layouts/index.d.ts.map +1 -1
  80. package/build-types/dataviews-layouts/list/index.d.ts.map +1 -1
  81. package/build-types/dataviews-layouts/table/column-header-menu.d.ts.map +1 -1
  82. package/build-types/dataviews-layouts/table/index.d.ts.map +1 -1
  83. package/build-types/normalize-fields.d.ts.map +1 -1
  84. package/build-types/types.d.ts +2 -0
  85. package/build-types/types.d.ts.map +1 -1
  86. package/package.json +11 -11
  87. package/src/components/dataviews/index.tsx +2 -6
  88. package/src/components/dataviews/stories/fixtures.tsx +698 -0
  89. package/src/components/dataviews/stories/index.story.tsx +186 -0
  90. package/src/components/dataviews/stories/style.css +4 -0
  91. package/src/components/dataviews/style.scss +2 -0
  92. package/src/components/dataviews-bulk-actions/index.tsx +264 -213
  93. package/src/components/dataviews-bulk-actions/style.scss +9 -4
  94. package/src/components/dataviews-filters/add-filter.tsx +7 -11
  95. package/src/components/dataviews-filters/search-widget.tsx +44 -29
  96. package/src/components/dataviews-filters/style.scss +12 -2
  97. package/src/components/dataviews-footer/index.tsx +50 -0
  98. package/src/components/dataviews-footer/style.scss +40 -0
  99. package/src/components/dataviews-item-actions/index.tsx +8 -14
  100. package/src/components/dataviews-pagination/index.tsx +5 -5
  101. package/src/components/dataviews-pagination/style.scss +0 -19
  102. package/src/components/dataviews-view-config/index.tsx +252 -53
  103. package/src/components/dataviews-view-config/style.scss +25 -0
  104. package/src/dataforms-layouts/panel/index.tsx +2 -0
  105. package/src/dataviews-layouts/grid/style.scss +1 -1
  106. package/src/dataviews-layouts/index.ts +63 -2
  107. package/src/dataviews-layouts/list/index.tsx +210 -139
  108. package/src/dataviews-layouts/list/style.scss +10 -4
  109. package/src/dataviews-layouts/table/column-header-menu.tsx +85 -87
  110. package/src/dataviews-layouts/table/index.tsx +8 -65
  111. package/src/dataviews-layouts/table/style.scss +0 -9
  112. package/src/normalize-fields.ts +2 -0
  113. package/src/style.scss +1 -1
  114. package/src/types.ts +2 -0
  115. package/tsconfig.tsbuildinfo +1 -1
  116. package/build/components/dataviews-bulk-actions-toolbar/index.js +0 -207
  117. package/build/components/dataviews-bulk-actions-toolbar/index.js.map +0 -1
  118. package/build-module/components/dataviews-bulk-actions-toolbar/index.js +0 -201
  119. package/build-module/components/dataviews-bulk-actions-toolbar/index.js.map +0 -1
  120. package/build-types/components/dataviews-bulk-actions-toolbar/index.d.ts +0 -2
  121. package/build-types/components/dataviews-bulk-actions-toolbar/index.d.ts.map +0 -1
  122. package/src/components/dataviews/stories/fixtures.js +0 -250
  123. package/src/components/dataviews/stories/index.story.js +0 -71
  124. package/src/components/dataviews-bulk-actions-toolbar/index.tsx +0 -288
  125. package/src/components/dataviews-bulk-actions-toolbar/style.scss +0 -45
@@ -2,17 +2,12 @@
2
2
  * External dependencies
3
3
  */
4
4
  import clsx from 'clsx';
5
- // TODO: use the @wordpress/components one once public
6
- // eslint-disable-next-line no-restricted-imports
7
- import { useStoreState } from '@ariakit/react';
8
- // Import CompositeStore type, which is not exported from @wordpress/components.
9
- // eslint-disable-next-line no-restricted-imports
10
5
 
11
6
  /**
12
7
  * WordPress dependencies
13
8
  */
14
- import { useInstanceId } from '@wordpress/compose';
15
- import { __experimentalHStack as HStack, __experimentalVStack as VStack, Button, privateApis as componentsPrivateApis, Spinner, VisuallyHidden } from '@wordpress/components';
9
+ import { useInstanceId, usePrevious } from '@wordpress/compose';
10
+ import { __experimentalHStack as HStack, __experimentalVStack as VStack, Button, privateApis as componentsPrivateApis, Spinner, VisuallyHidden, Composite } from '@wordpress/components';
16
11
  import { useCallback, useEffect, useMemo, useRef, useState } from '@wordpress/element';
17
12
  import { __ } from '@wordpress/i18n';
18
13
  import { moreVertical } from '@wordpress/icons';
@@ -26,27 +21,75 @@ import { ActionsDropdownMenuGroup, ActionModal } from '../../components/dataview
26
21
  import { jsx as _jsx } from "react/jsx-runtime";
27
22
  import { jsxs as _jsxs } from "react/jsx-runtime";
28
23
  const {
29
- useCompositeStoreV2: useCompositeStore,
30
- CompositeV2: Composite,
31
- CompositeItemV2: CompositeItem,
32
- CompositeRowV2: CompositeRow,
33
24
  DropdownMenuV2: DropdownMenu
34
25
  } = unlock(componentsPrivateApis);
26
+ function generateItemWrapperCompositeId(idPrefix) {
27
+ return `${idPrefix}-item-wrapper`;
28
+ }
29
+ function generatePrimaryActionCompositeId(idPrefix, primaryActionId) {
30
+ return `${idPrefix}-primary-action-${primaryActionId}`;
31
+ }
32
+ function generateDropdownTriggerCompositeId(idPrefix) {
33
+ return `${idPrefix}-dropdown`;
34
+ }
35
+ function PrimaryActionGridCell({
36
+ idPrefix,
37
+ primaryAction,
38
+ item
39
+ }) {
40
+ const registry = useRegistry();
41
+ const [isModalOpen, setIsModalOpen] = useState(false);
42
+ const compositeItemId = generatePrimaryActionCompositeId(idPrefix, primaryAction.id);
43
+ const label = typeof primaryAction.label === 'string' ? primaryAction.label : primaryAction.label([item]);
44
+ return 'RenderModal' in primaryAction ? /*#__PURE__*/_jsx("div", {
45
+ role: "gridcell",
46
+ children: /*#__PURE__*/_jsx(Composite.Item, {
47
+ id: compositeItemId,
48
+ render: /*#__PURE__*/_jsx(Button, {
49
+ label: label,
50
+ icon: primaryAction.icon,
51
+ isDestructive: primaryAction.isDestructive,
52
+ size: "small",
53
+ onClick: () => setIsModalOpen(true)
54
+ }),
55
+ children: isModalOpen && /*#__PURE__*/_jsx(ActionModal, {
56
+ action: primaryAction,
57
+ items: [item],
58
+ closeModal: () => setIsModalOpen(false)
59
+ })
60
+ })
61
+ }, primaryAction.id) : /*#__PURE__*/_jsx("div", {
62
+ role: "gridcell",
63
+ children: /*#__PURE__*/_jsx(Composite.Item, {
64
+ id: compositeItemId,
65
+ render: /*#__PURE__*/_jsx(Button, {
66
+ label: label,
67
+ icon: primaryAction.icon,
68
+ isDestructive: primaryAction.isDestructive,
69
+ size: "small",
70
+ onClick: () => {
71
+ primaryAction.callback([item], {
72
+ registry
73
+ });
74
+ }
75
+ })
76
+ })
77
+ }, primaryAction.id);
78
+ }
35
79
  function ListItem({
36
80
  actions,
37
- id,
81
+ idPrefix,
38
82
  isSelected,
39
83
  item,
40
84
  mediaField,
41
85
  onSelect,
42
86
  primaryField,
43
- store,
44
- visibleFields
87
+ visibleFields,
88
+ onDropdownTriggerKeyDown
45
89
  }) {
46
- const registry = useRegistry();
47
90
  const itemRef = useRef(null);
48
- const labelId = `${id}-label`;
49
- const descriptionId = `${id}-description`;
91
+ const labelId = `${idPrefix}-label`;
92
+ const descriptionId = `${idPrefix}-description`;
50
93
  const [isHovered, setIsHovered] = useState(false);
51
94
  const handleMouseEnter = () => {
52
95
  setIsHovered(true);
@@ -76,8 +119,6 @@ function ListItem({
76
119
  eligibleActions: _eligibleActions
77
120
  };
78
121
  }, [actions, item]);
79
- const [isModalOpen, setIsModalOpen] = useState(false);
80
- const primaryActionLabel = primaryAction && (typeof primaryAction.label === 'string' ? primaryAction.label : primaryAction.label([item]));
81
122
  const renderedMediaField = mediaField?.render ? /*#__PURE__*/_jsx(mediaField.render, {
82
123
  item: item
83
124
  }) : /*#__PURE__*/_jsx("div", {
@@ -86,7 +127,7 @@ function ListItem({
86
127
  const renderedPrimaryField = primaryField?.render ? /*#__PURE__*/_jsx(primaryField.render, {
87
128
  item: item
88
129
  }) : null;
89
- return /*#__PURE__*/_jsx(CompositeRow, {
130
+ return /*#__PURE__*/_jsx(Composite.Row, {
90
131
  ref: itemRef,
91
132
  render: /*#__PURE__*/_jsx("li", {}),
92
133
  role: "row",
@@ -102,11 +143,10 @@ function ListItem({
102
143
  spacing: 0,
103
144
  children: [/*#__PURE__*/_jsx("div", {
104
145
  role: "gridcell",
105
- children: /*#__PURE__*/_jsx(CompositeItem, {
106
- store: store,
146
+ children: /*#__PURE__*/_jsx(Composite.Item, {
107
147
  render: /*#__PURE__*/_jsx("div", {}),
108
148
  role: "button",
109
- id: id,
149
+ id: generateItemWrapperCompositeId(idPrefix),
110
150
  "aria-pressed": isSelected,
111
151
  "aria-labelledby": labelId,
112
152
  "aria-describedby": descriptionId,
@@ -154,62 +194,22 @@ function ListItem({
154
194
  flexShrink: '0',
155
195
  width: 'auto'
156
196
  },
157
- children: [primaryAction && 'RenderModal' in primaryAction && /*#__PURE__*/_jsx("div", {
158
- role: "gridcell",
159
- children: /*#__PURE__*/_jsx(CompositeItem, {
160
- store: store,
161
- render: /*#__PURE__*/_jsx(Button, {
162
- label: primaryActionLabel,
163
- icon: primaryAction.icon,
164
- isDestructive: primaryAction.isDestructive,
165
- size: "small",
166
- onClick: () => setIsModalOpen(true)
167
- }),
168
- children: isModalOpen && /*#__PURE__*/_jsx(ActionModal, {
169
- action: primaryAction,
170
- items: [item],
171
- closeModal: () => setIsModalOpen(false)
172
- })
173
- })
174
- }), primaryAction && !('RenderModal' in primaryAction) && /*#__PURE__*/_jsx("div", {
175
- role: "gridcell",
176
- children: /*#__PURE__*/_jsx(CompositeItem, {
177
- store: store,
178
- render: /*#__PURE__*/_jsx(Button, {
179
- label: primaryActionLabel,
180
- icon: primaryAction.icon,
181
- isDestructive: primaryAction.isDestructive,
182
- size: "small",
183
- onClick: () => {
184
- primaryAction.callback([item], {
185
- registry
186
- });
187
- }
188
- })
189
- })
190
- }, primaryAction.id), /*#__PURE__*/_jsx("div", {
197
+ children: [primaryAction && /*#__PURE__*/_jsx(PrimaryActionGridCell, {
198
+ idPrefix: idPrefix,
199
+ primaryAction: primaryAction,
200
+ item: item
201
+ }), /*#__PURE__*/_jsx("div", {
191
202
  role: "gridcell",
192
203
  children: /*#__PURE__*/_jsx(DropdownMenu, {
193
- trigger: /*#__PURE__*/_jsx(CompositeItem, {
194
- store: store,
204
+ trigger: /*#__PURE__*/_jsx(Composite.Item, {
205
+ id: generateDropdownTriggerCompositeId(idPrefix),
195
206
  render: /*#__PURE__*/_jsx(Button, {
196
207
  size: "small",
197
208
  icon: moreVertical,
198
209
  label: __('Actions'),
199
210
  accessibleWhenDisabled: true,
200
211
  disabled: !actions.length,
201
- onKeyDown: event => {
202
- if (event.key === 'ArrowDown') {
203
- // Prevent the default behaviour (open dropdown menu) and go down.
204
- event.preventDefault();
205
- store.move(store.down());
206
- }
207
- if (event.key === 'ArrowUp') {
208
- // Prevent the default behavior (open dropdown menu) and go up.
209
- event.preventDefault();
210
- store.move(store.up());
211
- }
212
- }
212
+ onKeyDown: onDropdownTriggerKeyDown
213
213
  })
214
214
  }),
215
215
  placement: "bottom-end",
@@ -241,23 +241,64 @@ export default function ViewList(props) {
241
241
  const viewFields = view.fields || fields.map(field => field.id);
242
242
  const visibleFields = fields.filter(field => viewFields.includes(field.id) && ![view.layout?.primaryField, view.layout?.mediaField].includes(field.id));
243
243
  const onSelect = item => onChangeSelection([getItemId(item)]);
244
- const getItemDomId = useCallback(item => item ? `${baseId}-${getItemId(item)}` : undefined, [baseId, getItemId]);
245
- const store = useCompositeStore({
246
- defaultActiveId: getItemDomId(selectedItem)
247
- }); // TODO, remove once composite APIs are public
244
+ const generateCompositeItemIdPrefix = useCallback(item => `${baseId}-${getItemId(item)}`, [baseId, getItemId]);
245
+ const isActiveCompositeItem = useCallback((item, idToCheck) => {
246
+ // All composite items use the same prefix in their IDs.
247
+ return idToCheck.startsWith(generateCompositeItemIdPrefix(item));
248
+ }, [generateCompositeItemIdPrefix]);
249
+
250
+ // Controlled state for the active composite item.
251
+ const [activeCompositeId, setActiveCompositeId] = useState(undefined);
248
252
 
249
- // Manage focused item, when the active one is removed from the list.
250
- const isActiveIdInList = useStoreState(store, state => state.items.some(item => item.id === state.activeId));
253
+ // Update the active composite item when the selected item changes.
251
254
  useEffect(() => {
252
- if (!isActiveIdInList) {
253
- // Prefer going down, except if there is no item below (last item), then go up (last item in list).
254
- if (store.down()) {
255
- store.move(store.down());
256
- } else if (store.up()) {
257
- store.move(store.up());
258
- }
255
+ if (selectedItem) {
256
+ setActiveCompositeId(generateItemWrapperCompositeId(generateCompositeItemIdPrefix(selectedItem)));
257
+ }
258
+ }, [selectedItem, generateCompositeItemIdPrefix]);
259
+ const activeItemIndex = data.findIndex(item => isActiveCompositeItem(item, activeCompositeId !== null && activeCompositeId !== void 0 ? activeCompositeId : ''));
260
+ const previousActiveItemIndex = usePrevious(activeItemIndex);
261
+ const isActiveIdInList = activeItemIndex !== -1;
262
+ const selectCompositeItem = useCallback((targetIndex, generateCompositeId) => {
263
+ // Clamping between 0 and data.length - 1 to avoid out of bounds.
264
+ const clampedIndex = Math.min(data.length - 1, Math.max(0, targetIndex));
265
+ if (!data[clampedIndex]) {
266
+ return;
267
+ }
268
+ const itemIdPrefix = generateCompositeItemIdPrefix(data[clampedIndex]);
269
+ const targetCompositeItemId = generateCompositeId(itemIdPrefix);
270
+ setActiveCompositeId(targetCompositeItemId);
271
+ document.getElementById(targetCompositeItemId)?.focus();
272
+ }, [data, generateCompositeItemIdPrefix]);
273
+
274
+ // Select a new active composite item when the current active item
275
+ // is removed from the list.
276
+ useEffect(() => {
277
+ const wasActiveIdInList = previousActiveItemIndex !== undefined && previousActiveItemIndex !== -1;
278
+ if (!isActiveIdInList && wasActiveIdInList) {
279
+ // By picking `previousActiveItemIndex` as the next item index, we are
280
+ // basically picking the item that would have been after the deleted one.
281
+ // If the previously active (and removed) item was the last of the list,
282
+ // we will select the item before it — which is the new last item.
283
+ selectCompositeItem(previousActiveItemIndex, generateItemWrapperCompositeId);
284
+ }
285
+ }, [isActiveIdInList, selectCompositeItem, previousActiveItemIndex]);
286
+
287
+ // Prevent the default behavior (open dropdown menu) and instead select the
288
+ // dropdown menu trigger on the previous/next row.
289
+ // https://github.com/ariakit/ariakit/issues/3768
290
+ const onDropdownTriggerKeyDown = useCallback(event => {
291
+ if (event.key === 'ArrowDown') {
292
+ // Select the dropdown menu trigger item in the next row.
293
+ event.preventDefault();
294
+ selectCompositeItem(activeItemIndex + 1, generateDropdownTriggerCompositeId);
295
+ }
296
+ if (event.key === 'ArrowUp') {
297
+ // Select the dropdown menu trigger item in the previous row.
298
+ event.preventDefault();
299
+ selectCompositeItem(activeItemIndex - 1, generateDropdownTriggerCompositeId);
259
300
  }
260
- }, [isActiveIdInList]);
301
+ }, [selectCompositeItem, activeItemIndex]);
261
302
  const hasData = data?.length;
262
303
  if (!hasData) {
263
304
  return /*#__PURE__*/_jsx("div", {
@@ -275,19 +316,20 @@ export default function ViewList(props) {
275
316
  render: /*#__PURE__*/_jsx("ul", {}),
276
317
  className: "dataviews-view-list",
277
318
  role: "grid",
278
- store: store,
319
+ activeId: activeCompositeId,
320
+ setActiveId: setActiveCompositeId,
279
321
  children: data.map(item => {
280
- const id = getItemDomId(item);
322
+ const id = generateCompositeItemIdPrefix(item);
281
323
  return /*#__PURE__*/_jsx(ListItem, {
282
- id: id,
324
+ idPrefix: id,
283
325
  actions: actions,
284
326
  item: item,
285
327
  isSelected: item === selectedItem,
286
328
  onSelect: onSelect,
287
329
  mediaField: mediaField,
288
330
  primaryField: primaryField,
289
- store: store,
290
- visibleFields: visibleFields
331
+ visibleFields: visibleFields,
332
+ onDropdownTriggerKeyDown: onDropdownTriggerKeyDown
291
333
  }, id);
292
334
  })
293
335
  });
@@ -1 +1 @@
1
- {"version":3,"names":["clsx","useStoreState","useInstanceId","__experimentalHStack","HStack","__experimentalVStack","VStack","Button","privateApis","componentsPrivateApis","Spinner","VisuallyHidden","useCallback","useEffect","useMemo","useRef","useState","__","moreVertical","useRegistry","unlock","ActionsDropdownMenuGroup","ActionModal","jsx","_jsx","jsxs","_jsxs","useCompositeStoreV2","useCompositeStore","CompositeV2","Composite","CompositeItemV2","CompositeItem","CompositeRowV2","CompositeRow","DropdownMenuV2","DropdownMenu","ListItem","actions","id","isSelected","item","mediaField","onSelect","primaryField","store","visibleFields","registry","itemRef","labelId","descriptionId","isHovered","setIsHovered","handleMouseEnter","handleMouseLeave","current","scrollIntoView","behavior","block","inline","primaryAction","eligibleActions","_eligibleActions","filter","action","isEligible","_primaryActions","isPrimary","icon","isModalOpen","setIsModalOpen","primaryActionLabel","label","renderedMediaField","render","className","renderedPrimaryField","ref","role","onMouseEnter","onMouseLeave","children","alignment","spacing","onClick","justify","map","field","as","length","style","flexShrink","width","isDestructive","size","items","closeModal","callback","trigger","accessibleWhenDisabled","disabled","onKeyDown","event","key","preventDefault","move","down","up","placement","ViewList","props","data","fields","getItemId","isLoading","onChangeSelection","selection","view","baseId","selectedItem","findLast","includes","find","layout","viewFields","getItemDomId","undefined","defaultActiveId","isActiveIdInList","state","some","activeId","hasData"],"sources":["@wordpress/dataviews/src/dataviews-layouts/list/index.tsx"],"sourcesContent":["/**\n * External dependencies\n */\nimport clsx from 'clsx';\n// TODO: use the @wordpress/components one once public\n// eslint-disable-next-line no-restricted-imports\nimport { useStoreState } from '@ariakit/react';\n// Import CompositeStore type, which is not exported from @wordpress/components.\n// eslint-disable-next-line no-restricted-imports\nimport type { CompositeStore } from '@ariakit/react';\n\n/**\n * WordPress dependencies\n */\nimport { useInstanceId } from '@wordpress/compose';\nimport {\n\t__experimentalHStack as HStack,\n\t__experimentalVStack as VStack,\n\tButton,\n\tprivateApis as componentsPrivateApis,\n\tSpinner,\n\tVisuallyHidden,\n} from '@wordpress/components';\nimport {\n\tuseCallback,\n\tuseEffect,\n\tuseMemo,\n\tuseRef,\n\tuseState,\n} from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { moreVertical } from '@wordpress/icons';\nimport { useRegistry } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport { unlock } from '../../lock-unlock';\nimport {\n\tActionsDropdownMenuGroup,\n\tActionModal,\n} from '../../components/dataviews-item-actions';\nimport type { Action, NormalizedField, ViewListProps } from '../../types';\n\ninterface ListViewItemProps< Item > {\n\tactions: Action< Item >[];\n\tid?: string;\n\tisSelected: boolean;\n\titem: Item;\n\tmediaField?: NormalizedField< Item >;\n\tonSelect: ( item: Item ) => void;\n\tprimaryField?: NormalizedField< Item >;\n\tstore: CompositeStore;\n\tvisibleFields: NormalizedField< Item >[];\n}\n\nconst {\n\tuseCompositeStoreV2: useCompositeStore,\n\tCompositeV2: Composite,\n\tCompositeItemV2: CompositeItem,\n\tCompositeRowV2: CompositeRow,\n\tDropdownMenuV2: DropdownMenu,\n} = unlock( componentsPrivateApis );\n\nfunction ListItem< Item >( {\n\tactions,\n\tid,\n\tisSelected,\n\titem,\n\tmediaField,\n\tonSelect,\n\tprimaryField,\n\tstore,\n\tvisibleFields,\n}: ListViewItemProps< Item > ) {\n\tconst registry = useRegistry();\n\tconst itemRef = useRef< HTMLElement >( null );\n\tconst labelId = `${ id }-label`;\n\tconst descriptionId = `${ id }-description`;\n\n\tconst [ isHovered, setIsHovered ] = useState( false );\n\tconst handleMouseEnter = () => {\n\t\tsetIsHovered( true );\n\t};\n\tconst handleMouseLeave = () => {\n\t\tsetIsHovered( false );\n\t};\n\n\tuseEffect( () => {\n\t\tif ( isSelected ) {\n\t\t\titemRef.current?.scrollIntoView( {\n\t\t\t\tbehavior: 'auto',\n\t\t\t\tblock: 'nearest',\n\t\t\t\tinline: 'nearest',\n\t\t\t} );\n\t\t}\n\t}, [ isSelected ] );\n\n\tconst { primaryAction, eligibleActions } = useMemo( () => {\n\t\t// If an action is eligible for all items, doesn't need\n\t\t// to provide the `isEligible` function.\n\t\tconst _eligibleActions = actions.filter(\n\t\t\t( action ) => ! action.isEligible || action.isEligible( item )\n\t\t);\n\t\tconst _primaryActions = _eligibleActions.filter(\n\t\t\t( action ) => action.isPrimary && !! action.icon\n\t\t);\n\t\treturn {\n\t\t\tprimaryAction: _primaryActions?.[ 0 ],\n\t\t\teligibleActions: _eligibleActions,\n\t\t};\n\t}, [ actions, item ] );\n\n\tconst [ isModalOpen, setIsModalOpen ] = useState( false );\n\tconst primaryActionLabel =\n\t\tprimaryAction &&\n\t\t( typeof primaryAction.label === 'string'\n\t\t\t? primaryAction.label\n\t\t\t: primaryAction.label( [ item ] ) );\n\n\tconst renderedMediaField = mediaField?.render ? (\n\t\t<mediaField.render item={ item } />\n\t) : (\n\t\t<div className=\"dataviews-view-list__media-placeholder\"></div>\n\t);\n\n\tconst renderedPrimaryField = primaryField?.render ? (\n\t\t<primaryField.render item={ item } />\n\t) : null;\n\n\treturn (\n\t\t<CompositeRow\n\t\t\tref={ itemRef }\n\t\t\trender={ <li /> }\n\t\t\trole=\"row\"\n\t\t\tclassName={ clsx( {\n\t\t\t\t'is-selected': isSelected,\n\t\t\t\t'is-hovered': isHovered,\n\t\t\t} ) }\n\t\t\tonMouseEnter={ handleMouseEnter }\n\t\t\tonMouseLeave={ handleMouseLeave }\n\t\t>\n\t\t\t<HStack\n\t\t\t\tclassName=\"dataviews-view-list__item-wrapper\"\n\t\t\t\talignment=\"center\"\n\t\t\t\tspacing={ 0 }\n\t\t\t>\n\t\t\t\t<div role=\"gridcell\">\n\t\t\t\t\t<CompositeItem\n\t\t\t\t\t\tstore={ store }\n\t\t\t\t\t\trender={ <div /> }\n\t\t\t\t\t\trole=\"button\"\n\t\t\t\t\t\tid={ id }\n\t\t\t\t\t\taria-pressed={ isSelected }\n\t\t\t\t\t\taria-labelledby={ labelId }\n\t\t\t\t\t\taria-describedby={ descriptionId }\n\t\t\t\t\t\tclassName=\"dataviews-view-list__item\"\n\t\t\t\t\t\tonClick={ () => onSelect( item ) }\n\t\t\t\t\t>\n\t\t\t\t\t\t<HStack\n\t\t\t\t\t\t\tspacing={ 3 }\n\t\t\t\t\t\t\tjustify=\"start\"\n\t\t\t\t\t\t\talignment=\"flex-start\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<div className=\"dataviews-view-list__media-wrapper\">\n\t\t\t\t\t\t\t\t{ renderedMediaField }\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t<VStack\n\t\t\t\t\t\t\t\tspacing={ 1 }\n\t\t\t\t\t\t\t\tclassName=\"dataviews-view-list__field-wrapper\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<span\n\t\t\t\t\t\t\t\t\tclassName=\"dataviews-view-list__primary-field\"\n\t\t\t\t\t\t\t\t\tid={ labelId }\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t{ renderedPrimaryField }\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\tclassName=\"dataviews-view-list__fields\"\n\t\t\t\t\t\t\t\t\tid={ descriptionId }\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t{ visibleFields.map( ( field ) => (\n\t\t\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\t\t\tkey={ field.id }\n\t\t\t\t\t\t\t\t\t\t\tclassName=\"dataviews-view-list__field\"\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t<VisuallyHidden\n\t\t\t\t\t\t\t\t\t\t\t\tas=\"span\"\n\t\t\t\t\t\t\t\t\t\t\t\tclassName=\"dataviews-view-list__field-label\"\n\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t{ field.label }\n\t\t\t\t\t\t\t\t\t\t\t</VisuallyHidden>\n\t\t\t\t\t\t\t\t\t\t\t<span className=\"dataviews-view-list__field-value\">\n\t\t\t\t\t\t\t\t\t\t\t\t<field.render item={ item } />\n\t\t\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t\t) ) }\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</VStack>\n\t\t\t\t\t\t</HStack>\n\t\t\t\t\t</CompositeItem>\n\t\t\t\t</div>\n\t\t\t\t{ eligibleActions?.length > 0 && (\n\t\t\t\t\t<HStack\n\t\t\t\t\t\tspacing={ 3 }\n\t\t\t\t\t\tjustify=\"flex-end\"\n\t\t\t\t\t\tclassName=\"dataviews-view-list__item-actions\"\n\t\t\t\t\t\tstyle={ {\n\t\t\t\t\t\t\tflexShrink: '0',\n\t\t\t\t\t\t\twidth: 'auto',\n\t\t\t\t\t\t} }\n\t\t\t\t\t>\n\t\t\t\t\t\t{ primaryAction && 'RenderModal' in primaryAction && (\n\t\t\t\t\t\t\t<div role=\"gridcell\">\n\t\t\t\t\t\t\t\t<CompositeItem\n\t\t\t\t\t\t\t\t\tstore={ store }\n\t\t\t\t\t\t\t\t\trender={\n\t\t\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t\t\tlabel={ primaryActionLabel }\n\t\t\t\t\t\t\t\t\t\t\ticon={ primaryAction.icon }\n\t\t\t\t\t\t\t\t\t\t\tisDestructive={\n\t\t\t\t\t\t\t\t\t\t\t\tprimaryAction.isDestructive\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\tsize=\"small\"\n\t\t\t\t\t\t\t\t\t\t\tonClick={ () =>\n\t\t\t\t\t\t\t\t\t\t\t\tsetIsModalOpen( true )\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t{ isModalOpen && (\n\t\t\t\t\t\t\t\t\t\t<ActionModal< Item >\n\t\t\t\t\t\t\t\t\t\t\taction={ primaryAction }\n\t\t\t\t\t\t\t\t\t\t\titems={ [ item ] }\n\t\t\t\t\t\t\t\t\t\t\tcloseModal={ () =>\n\t\t\t\t\t\t\t\t\t\t\t\tsetIsModalOpen( false )\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t\t</CompositeItem>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t) }\n\t\t\t\t\t\t{ primaryAction &&\n\t\t\t\t\t\t\t! ( 'RenderModal' in primaryAction ) && (\n\t\t\t\t\t\t\t\t<div role=\"gridcell\" key={ primaryAction.id }>\n\t\t\t\t\t\t\t\t\t<CompositeItem\n\t\t\t\t\t\t\t\t\t\tstore={ store }\n\t\t\t\t\t\t\t\t\t\trender={\n\t\t\t\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t\t\t\tlabel={ primaryActionLabel }\n\t\t\t\t\t\t\t\t\t\t\t\ticon={ primaryAction.icon }\n\t\t\t\t\t\t\t\t\t\t\t\tisDestructive={\n\t\t\t\t\t\t\t\t\t\t\t\t\tprimaryAction.isDestructive\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\tsize=\"small\"\n\t\t\t\t\t\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tprimaryAction.callback(\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t[ item ],\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{ registry }\n\t\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t<div role=\"gridcell\">\n\t\t\t\t\t\t\t<DropdownMenu\n\t\t\t\t\t\t\t\ttrigger={\n\t\t\t\t\t\t\t\t\t<CompositeItem\n\t\t\t\t\t\t\t\t\t\tstore={ store }\n\t\t\t\t\t\t\t\t\t\trender={\n\t\t\t\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t\t\t\tsize=\"small\"\n\t\t\t\t\t\t\t\t\t\t\t\ticon={ moreVertical }\n\t\t\t\t\t\t\t\t\t\t\t\tlabel={ __( 'Actions' ) }\n\t\t\t\t\t\t\t\t\t\t\t\taccessibleWhenDisabled\n\t\t\t\t\t\t\t\t\t\t\t\tdisabled={ ! actions.length }\n\t\t\t\t\t\t\t\t\t\t\t\tonKeyDown={ ( event: {\n\t\t\t\t\t\t\t\t\t\t\t\t\tkey: string;\n\t\t\t\t\t\t\t\t\t\t\t\t\tpreventDefault: () => void;\n\t\t\t\t\t\t\t\t\t\t\t\t} ) => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tevent.key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t'ArrowDown'\n\t\t\t\t\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t// Prevent the default behaviour (open dropdown menu) and go down.\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstore.move(\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tstore.down()\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tevent.key === 'ArrowUp'\n\t\t\t\t\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t// Prevent the default behavior (open dropdown menu) and go up.\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstore.move(\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tstore.up()\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tplacement=\"bottom-end\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<ActionsDropdownMenuGroup\n\t\t\t\t\t\t\t\t\tactions={ eligibleActions }\n\t\t\t\t\t\t\t\t\titem={ item }\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</DropdownMenu>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</HStack>\n\t\t\t\t) }\n\t\t\t</HStack>\n\t\t</CompositeRow>\n\t);\n}\n\nexport default function ViewList< Item >( props: ViewListProps< Item > ) {\n\tconst {\n\t\tactions,\n\t\tdata,\n\t\tfields,\n\t\tgetItemId,\n\t\tisLoading,\n\t\tonChangeSelection,\n\t\tselection,\n\t\tview,\n\t} = props;\n\tconst baseId = useInstanceId( ViewList, 'view-list' );\n\tconst selectedItem = data?.findLast( ( item ) =>\n\t\tselection.includes( getItemId( item ) )\n\t);\n\n\tconst mediaField = fields.find(\n\t\t( field ) => field.id === view.layout?.mediaField\n\t);\n\tconst primaryField = fields.find(\n\t\t( field ) => field.id === view.layout?.primaryField\n\t);\n\tconst viewFields = view.fields || fields.map( ( field ) => field.id );\n\tconst visibleFields = fields.filter(\n\t\t( field ) =>\n\t\t\tviewFields.includes( field.id ) &&\n\t\t\t! [ view.layout?.primaryField, view.layout?.mediaField ].includes(\n\t\t\t\tfield.id\n\t\t\t)\n\t);\n\n\tconst onSelect = ( item: Item ) =>\n\t\tonChangeSelection( [ getItemId( item ) ] );\n\n\tconst getItemDomId = useCallback(\n\t\t( item?: Item ) =>\n\t\t\titem ? `${ baseId }-${ getItemId( item ) }` : undefined,\n\t\t[ baseId, getItemId ]\n\t);\n\n\tconst store = useCompositeStore( {\n\t\tdefaultActiveId: getItemDomId( selectedItem ),\n\t} ) as CompositeStore; // TODO, remove once composite APIs are public\n\n\t// Manage focused item, when the active one is removed from the list.\n\tconst isActiveIdInList = useStoreState(\n\t\tstore,\n\t\t( state: { items: any[]; activeId: any } ) =>\n\t\t\tstate.items.some(\n\t\t\t\t( item: { id: any } ) => item.id === state.activeId\n\t\t\t)\n\t);\n\tuseEffect( () => {\n\t\tif ( ! isActiveIdInList ) {\n\t\t\t// Prefer going down, except if there is no item below (last item), then go up (last item in list).\n\t\t\tif ( store.down() ) {\n\t\t\t\tstore.move( store.down() );\n\t\t\t} else if ( store.up() ) {\n\t\t\t\tstore.move( store.up() );\n\t\t\t}\n\t\t}\n\t}, [ isActiveIdInList ] );\n\n\tconst hasData = data?.length;\n\tif ( ! hasData ) {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tclassName={ clsx( {\n\t\t\t\t\t'dataviews-loading': isLoading,\n\t\t\t\t\t'dataviews-no-results': ! hasData && ! isLoading,\n\t\t\t\t} ) }\n\t\t\t>\n\t\t\t\t{ ! hasData && (\n\t\t\t\t\t<p>{ isLoading ? <Spinner /> : __( 'No results' ) }</p>\n\t\t\t\t) }\n\t\t\t</div>\n\t\t);\n\t}\n\n\treturn (\n\t\t<Composite\n\t\t\tid={ baseId }\n\t\t\trender={ <ul /> }\n\t\t\tclassName=\"dataviews-view-list\"\n\t\t\trole=\"grid\"\n\t\t\tstore={ store }\n\t\t>\n\t\t\t{ data.map( ( item ) => {\n\t\t\t\tconst id = getItemDomId( item );\n\t\t\t\treturn (\n\t\t\t\t\t<ListItem\n\t\t\t\t\t\tkey={ id }\n\t\t\t\t\t\tid={ id }\n\t\t\t\t\t\tactions={ actions }\n\t\t\t\t\t\titem={ item }\n\t\t\t\t\t\tisSelected={ item === selectedItem }\n\t\t\t\t\t\tonSelect={ onSelect }\n\t\t\t\t\t\tmediaField={ mediaField }\n\t\t\t\t\t\tprimaryField={ primaryField }\n\t\t\t\t\t\tstore={ store }\n\t\t\t\t\t\tvisibleFields={ visibleFields }\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\t} ) }\n\t\t</Composite>\n\t);\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["clsx","useInstanceId","usePrevious","__experimentalHStack","HStack","__experimentalVStack","VStack","Button","privateApis","componentsPrivateApis","Spinner","VisuallyHidden","Composite","useCallback","useEffect","useMemo","useRef","useState","__","moreVertical","useRegistry","unlock","ActionsDropdownMenuGroup","ActionModal","jsx","_jsx","jsxs","_jsxs","DropdownMenuV2","DropdownMenu","generateItemWrapperCompositeId","idPrefix","generatePrimaryActionCompositeId","primaryActionId","generateDropdownTriggerCompositeId","PrimaryActionGridCell","primaryAction","item","registry","isModalOpen","setIsModalOpen","compositeItemId","id","label","role","children","Item","render","icon","isDestructive","size","onClick","action","items","closeModal","callback","ListItem","actions","isSelected","mediaField","onSelect","primaryField","visibleFields","onDropdownTriggerKeyDown","itemRef","labelId","descriptionId","isHovered","setIsHovered","handleMouseEnter","handleMouseLeave","current","scrollIntoView","behavior","block","inline","eligibleActions","_eligibleActions","filter","isEligible","_primaryActions","isPrimary","renderedMediaField","className","renderedPrimaryField","Row","ref","onMouseEnter","onMouseLeave","alignment","spacing","justify","map","field","as","length","style","flexShrink","width","trigger","accessibleWhenDisabled","disabled","onKeyDown","placement","ViewList","props","data","fields","getItemId","isLoading","onChangeSelection","selection","view","baseId","selectedItem","findLast","includes","find","layout","viewFields","generateCompositeItemIdPrefix","isActiveCompositeItem","idToCheck","startsWith","activeCompositeId","setActiveCompositeId","undefined","activeItemIndex","findIndex","previousActiveItemIndex","isActiveIdInList","selectCompositeItem","targetIndex","generateCompositeId","clampedIndex","Math","min","max","itemIdPrefix","targetCompositeItemId","document","getElementById","focus","wasActiveIdInList","event","key","preventDefault","hasData","activeId","setActiveId"],"sources":["@wordpress/dataviews/src/dataviews-layouts/list/index.tsx"],"sourcesContent":["/**\n * External dependencies\n */\nimport clsx from 'clsx';\n\n/**\n * WordPress dependencies\n */\nimport { useInstanceId, usePrevious } from '@wordpress/compose';\nimport {\n\t__experimentalHStack as HStack,\n\t__experimentalVStack as VStack,\n\tButton,\n\tprivateApis as componentsPrivateApis,\n\tSpinner,\n\tVisuallyHidden,\n\tComposite,\n} from '@wordpress/components';\nimport {\n\tuseCallback,\n\tuseEffect,\n\tuseMemo,\n\tuseRef,\n\tuseState,\n} from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { moreVertical } from '@wordpress/icons';\nimport { useRegistry } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport { unlock } from '../../lock-unlock';\nimport {\n\tActionsDropdownMenuGroup,\n\tActionModal,\n} from '../../components/dataviews-item-actions';\nimport type { Action, NormalizedField, ViewListProps } from '../../types';\n\ninterface ListViewItemProps< Item > {\n\tactions: Action< Item >[];\n\tidPrefix: string;\n\tisSelected: boolean;\n\titem: Item;\n\tmediaField?: NormalizedField< Item >;\n\tonSelect: ( item: Item ) => void;\n\tprimaryField?: NormalizedField< Item >;\n\tvisibleFields: NormalizedField< Item >[];\n\tonDropdownTriggerKeyDown: React.KeyboardEventHandler< HTMLButtonElement >;\n}\n\nconst { DropdownMenuV2: DropdownMenu } = unlock( componentsPrivateApis );\n\nfunction generateItemWrapperCompositeId( idPrefix: string ) {\n\treturn `${ idPrefix }-item-wrapper`;\n}\nfunction generatePrimaryActionCompositeId(\n\tidPrefix: string,\n\tprimaryActionId: string\n) {\n\treturn `${ idPrefix }-primary-action-${ primaryActionId }`;\n}\nfunction generateDropdownTriggerCompositeId( idPrefix: string ) {\n\treturn `${ idPrefix }-dropdown`;\n}\n\nfunction PrimaryActionGridCell< Item >( {\n\tidPrefix,\n\tprimaryAction,\n\titem,\n}: {\n\tidPrefix: string;\n\tprimaryAction: Action< Item >;\n\titem: Item;\n} ) {\n\tconst registry = useRegistry();\n\tconst [ isModalOpen, setIsModalOpen ] = useState( false );\n\n\tconst compositeItemId = generatePrimaryActionCompositeId(\n\t\tidPrefix,\n\t\tprimaryAction.id\n\t);\n\n\tconst label =\n\t\ttypeof primaryAction.label === 'string'\n\t\t\t? primaryAction.label\n\t\t\t: primaryAction.label( [ item ] );\n\n\treturn 'RenderModal' in primaryAction ? (\n\t\t<div role=\"gridcell\" key={ primaryAction.id }>\n\t\t\t<Composite.Item\n\t\t\t\tid={ compositeItemId }\n\t\t\t\trender={\n\t\t\t\t\t<Button\n\t\t\t\t\t\tlabel={ label }\n\t\t\t\t\t\ticon={ primaryAction.icon }\n\t\t\t\t\t\tisDestructive={ primaryAction.isDestructive }\n\t\t\t\t\t\tsize=\"small\"\n\t\t\t\t\t\tonClick={ () => setIsModalOpen( true ) }\n\t\t\t\t\t/>\n\t\t\t\t}\n\t\t\t>\n\t\t\t\t{ isModalOpen && (\n\t\t\t\t\t<ActionModal< Item >\n\t\t\t\t\t\taction={ primaryAction }\n\t\t\t\t\t\titems={ [ item ] }\n\t\t\t\t\t\tcloseModal={ () => setIsModalOpen( false ) }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t</Composite.Item>\n\t\t</div>\n\t) : (\n\t\t<div role=\"gridcell\" key={ primaryAction.id }>\n\t\t\t<Composite.Item\n\t\t\t\tid={ compositeItemId }\n\t\t\t\trender={\n\t\t\t\t\t<Button\n\t\t\t\t\t\tlabel={ label }\n\t\t\t\t\t\ticon={ primaryAction.icon }\n\t\t\t\t\t\tisDestructive={ primaryAction.isDestructive }\n\t\t\t\t\t\tsize=\"small\"\n\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\tprimaryAction.callback( [ item ], { registry } );\n\t\t\t\t\t\t} }\n\t\t\t\t\t/>\n\t\t\t\t}\n\t\t\t/>\n\t\t</div>\n\t);\n}\n\nfunction ListItem< Item >( {\n\tactions,\n\tidPrefix,\n\tisSelected,\n\titem,\n\tmediaField,\n\tonSelect,\n\tprimaryField,\n\tvisibleFields,\n\tonDropdownTriggerKeyDown,\n}: ListViewItemProps< Item > ) {\n\tconst itemRef = useRef< HTMLDivElement >( null );\n\tconst labelId = `${ idPrefix }-label`;\n\tconst descriptionId = `${ idPrefix }-description`;\n\n\tconst [ isHovered, setIsHovered ] = useState( false );\n\tconst handleMouseEnter = () => {\n\t\tsetIsHovered( true );\n\t};\n\tconst handleMouseLeave = () => {\n\t\tsetIsHovered( false );\n\t};\n\n\tuseEffect( () => {\n\t\tif ( isSelected ) {\n\t\t\titemRef.current?.scrollIntoView( {\n\t\t\t\tbehavior: 'auto',\n\t\t\t\tblock: 'nearest',\n\t\t\t\tinline: 'nearest',\n\t\t\t} );\n\t\t}\n\t}, [ isSelected ] );\n\n\tconst { primaryAction, eligibleActions } = useMemo( () => {\n\t\t// If an action is eligible for all items, doesn't need\n\t\t// to provide the `isEligible` function.\n\t\tconst _eligibleActions = actions.filter(\n\t\t\t( action ) => ! action.isEligible || action.isEligible( item )\n\t\t);\n\t\tconst _primaryActions = _eligibleActions.filter(\n\t\t\t( action ) => action.isPrimary && !! action.icon\n\t\t);\n\t\treturn {\n\t\t\tprimaryAction: _primaryActions?.[ 0 ],\n\t\t\teligibleActions: _eligibleActions,\n\t\t};\n\t}, [ actions, item ] );\n\n\tconst renderedMediaField = mediaField?.render ? (\n\t\t<mediaField.render item={ item } />\n\t) : (\n\t\t<div className=\"dataviews-view-list__media-placeholder\"></div>\n\t);\n\n\tconst renderedPrimaryField = primaryField?.render ? (\n\t\t<primaryField.render item={ item } />\n\t) : null;\n\n\treturn (\n\t\t<Composite.Row\n\t\t\tref={ itemRef }\n\t\t\trender={ <li /> }\n\t\t\trole=\"row\"\n\t\t\tclassName={ clsx( {\n\t\t\t\t'is-selected': isSelected,\n\t\t\t\t'is-hovered': isHovered,\n\t\t\t} ) }\n\t\t\tonMouseEnter={ handleMouseEnter }\n\t\t\tonMouseLeave={ handleMouseLeave }\n\t\t>\n\t\t\t<HStack\n\t\t\t\tclassName=\"dataviews-view-list__item-wrapper\"\n\t\t\t\talignment=\"center\"\n\t\t\t\tspacing={ 0 }\n\t\t\t>\n\t\t\t\t<div role=\"gridcell\">\n\t\t\t\t\t<Composite.Item\n\t\t\t\t\t\trender={ <div /> }\n\t\t\t\t\t\trole=\"button\"\n\t\t\t\t\t\tid={ generateItemWrapperCompositeId( idPrefix ) }\n\t\t\t\t\t\taria-pressed={ isSelected }\n\t\t\t\t\t\taria-labelledby={ labelId }\n\t\t\t\t\t\taria-describedby={ descriptionId }\n\t\t\t\t\t\tclassName=\"dataviews-view-list__item\"\n\t\t\t\t\t\tonClick={ () => onSelect( item ) }\n\t\t\t\t\t>\n\t\t\t\t\t\t<HStack\n\t\t\t\t\t\t\tspacing={ 3 }\n\t\t\t\t\t\t\tjustify=\"start\"\n\t\t\t\t\t\t\talignment=\"flex-start\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<div className=\"dataviews-view-list__media-wrapper\">\n\t\t\t\t\t\t\t\t{ renderedMediaField }\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t<VStack\n\t\t\t\t\t\t\t\tspacing={ 1 }\n\t\t\t\t\t\t\t\tclassName=\"dataviews-view-list__field-wrapper\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<span\n\t\t\t\t\t\t\t\t\tclassName=\"dataviews-view-list__primary-field\"\n\t\t\t\t\t\t\t\t\tid={ labelId }\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t{ renderedPrimaryField }\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\tclassName=\"dataviews-view-list__fields\"\n\t\t\t\t\t\t\t\t\tid={ descriptionId }\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t{ visibleFields.map( ( field ) => (\n\t\t\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\t\t\tkey={ field.id }\n\t\t\t\t\t\t\t\t\t\t\tclassName=\"dataviews-view-list__field\"\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t<VisuallyHidden\n\t\t\t\t\t\t\t\t\t\t\t\tas=\"span\"\n\t\t\t\t\t\t\t\t\t\t\t\tclassName=\"dataviews-view-list__field-label\"\n\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t{ field.label }\n\t\t\t\t\t\t\t\t\t\t\t</VisuallyHidden>\n\t\t\t\t\t\t\t\t\t\t\t<span className=\"dataviews-view-list__field-value\">\n\t\t\t\t\t\t\t\t\t\t\t\t<field.render item={ item } />\n\t\t\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t\t) ) }\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</VStack>\n\t\t\t\t\t\t</HStack>\n\t\t\t\t\t</Composite.Item>\n\t\t\t\t</div>\n\t\t\t\t{ eligibleActions?.length > 0 && (\n\t\t\t\t\t<HStack\n\t\t\t\t\t\tspacing={ 3 }\n\t\t\t\t\t\tjustify=\"flex-end\"\n\t\t\t\t\t\tclassName=\"dataviews-view-list__item-actions\"\n\t\t\t\t\t\tstyle={ {\n\t\t\t\t\t\t\tflexShrink: '0',\n\t\t\t\t\t\t\twidth: 'auto',\n\t\t\t\t\t\t} }\n\t\t\t\t\t>\n\t\t\t\t\t\t{ primaryAction && (\n\t\t\t\t\t\t\t<PrimaryActionGridCell\n\t\t\t\t\t\t\t\tidPrefix={ idPrefix }\n\t\t\t\t\t\t\t\tprimaryAction={ primaryAction }\n\t\t\t\t\t\t\t\titem={ item }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t) }\n\t\t\t\t\t\t<div role=\"gridcell\">\n\t\t\t\t\t\t\t<DropdownMenu\n\t\t\t\t\t\t\t\ttrigger={\n\t\t\t\t\t\t\t\t\t<Composite.Item\n\t\t\t\t\t\t\t\t\t\tid={ generateDropdownTriggerCompositeId(\n\t\t\t\t\t\t\t\t\t\t\tidPrefix\n\t\t\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t\t\t\trender={\n\t\t\t\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t\t\t\tsize=\"small\"\n\t\t\t\t\t\t\t\t\t\t\t\ticon={ moreVertical }\n\t\t\t\t\t\t\t\t\t\t\t\tlabel={ __( 'Actions' ) }\n\t\t\t\t\t\t\t\t\t\t\t\taccessibleWhenDisabled\n\t\t\t\t\t\t\t\t\t\t\t\tdisabled={ ! actions.length }\n\t\t\t\t\t\t\t\t\t\t\t\tonKeyDown={\n\t\t\t\t\t\t\t\t\t\t\t\t\tonDropdownTriggerKeyDown\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tplacement=\"bottom-end\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<ActionsDropdownMenuGroup\n\t\t\t\t\t\t\t\t\tactions={ eligibleActions }\n\t\t\t\t\t\t\t\t\titem={ item }\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</DropdownMenu>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</HStack>\n\t\t\t\t) }\n\t\t\t</HStack>\n\t\t</Composite.Row>\n\t);\n}\n\nexport default function ViewList< Item >( props: ViewListProps< Item > ) {\n\tconst {\n\t\tactions,\n\t\tdata,\n\t\tfields,\n\t\tgetItemId,\n\t\tisLoading,\n\t\tonChangeSelection,\n\t\tselection,\n\t\tview,\n\t} = props;\n\tconst baseId = useInstanceId( ViewList, 'view-list' );\n\n\tconst selectedItem = data?.findLast( ( item ) =>\n\t\tselection.includes( getItemId( item ) )\n\t);\n\n\tconst mediaField = fields.find(\n\t\t( field ) => field.id === view.layout?.mediaField\n\t);\n\tconst primaryField = fields.find(\n\t\t( field ) => field.id === view.layout?.primaryField\n\t);\n\tconst viewFields = view.fields || fields.map( ( field ) => field.id );\n\tconst visibleFields = fields.filter(\n\t\t( field ) =>\n\t\t\tviewFields.includes( field.id ) &&\n\t\t\t! [ view.layout?.primaryField, view.layout?.mediaField ].includes(\n\t\t\t\tfield.id\n\t\t\t)\n\t);\n\n\tconst onSelect = ( item: Item ) =>\n\t\tonChangeSelection( [ getItemId( item ) ] );\n\n\tconst generateCompositeItemIdPrefix = useCallback(\n\t\t( item: Item ) => `${ baseId }-${ getItemId( item ) }`,\n\t\t[ baseId, getItemId ]\n\t);\n\n\tconst isActiveCompositeItem = useCallback(\n\t\t( item: Item, idToCheck: string ) => {\n\t\t\t// All composite items use the same prefix in their IDs.\n\t\t\treturn idToCheck.startsWith(\n\t\t\t\tgenerateCompositeItemIdPrefix( item )\n\t\t\t);\n\t\t},\n\t\t[ generateCompositeItemIdPrefix ]\n\t);\n\n\t// Controlled state for the active composite item.\n\tconst [ activeCompositeId, setActiveCompositeId ] = useState<\n\t\tstring | null | undefined\n\t>( undefined );\n\n\t// Update the active composite item when the selected item changes.\n\tuseEffect( () => {\n\t\tif ( selectedItem ) {\n\t\t\tsetActiveCompositeId(\n\t\t\t\tgenerateItemWrapperCompositeId(\n\t\t\t\t\tgenerateCompositeItemIdPrefix( selectedItem )\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t}, [ selectedItem, generateCompositeItemIdPrefix ] );\n\n\tconst activeItemIndex = data.findIndex( ( item ) =>\n\t\tisActiveCompositeItem( item, activeCompositeId ?? '' )\n\t);\n\tconst previousActiveItemIndex = usePrevious( activeItemIndex );\n\tconst isActiveIdInList = activeItemIndex !== -1;\n\n\tconst selectCompositeItem = useCallback(\n\t\t(\n\t\t\ttargetIndex: number,\n\t\t\t// Allows invokers to specify a custom function to generate the\n\t\t\t// target composite item ID\n\t\t\tgenerateCompositeId: ( idPrefix: string ) => string\n\t\t) => {\n\t\t\t// Clamping between 0 and data.length - 1 to avoid out of bounds.\n\t\t\tconst clampedIndex = Math.min(\n\t\t\t\tdata.length - 1,\n\t\t\t\tMath.max( 0, targetIndex )\n\t\t\t);\n\t\t\tif ( ! data[ clampedIndex ] ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconst itemIdPrefix = generateCompositeItemIdPrefix(\n\t\t\t\tdata[ clampedIndex ]\n\t\t\t);\n\t\t\tconst targetCompositeItemId = generateCompositeId( itemIdPrefix );\n\n\t\t\tsetActiveCompositeId( targetCompositeItemId );\n\t\t\tdocument.getElementById( targetCompositeItemId )?.focus();\n\t\t},\n\t\t[ data, generateCompositeItemIdPrefix ]\n\t);\n\n\t// Select a new active composite item when the current active item\n\t// is removed from the list.\n\tuseEffect( () => {\n\t\tconst wasActiveIdInList =\n\t\t\tpreviousActiveItemIndex !== undefined &&\n\t\t\tpreviousActiveItemIndex !== -1;\n\t\tif ( ! isActiveIdInList && wasActiveIdInList ) {\n\t\t\t// By picking `previousActiveItemIndex` as the next item index, we are\n\t\t\t// basically picking the item that would have been after the deleted one.\n\t\t\t// If the previously active (and removed) item was the last of the list,\n\t\t\t// we will select the item before it — which is the new last item.\n\t\t\tselectCompositeItem(\n\t\t\t\tpreviousActiveItemIndex,\n\t\t\t\tgenerateItemWrapperCompositeId\n\t\t\t);\n\t\t}\n\t}, [ isActiveIdInList, selectCompositeItem, previousActiveItemIndex ] );\n\n\t// Prevent the default behavior (open dropdown menu) and instead select the\n\t// dropdown menu trigger on the previous/next row.\n\t// https://github.com/ariakit/ariakit/issues/3768\n\tconst onDropdownTriggerKeyDown = useCallback(\n\t\t( event: React.KeyboardEvent< HTMLButtonElement > ) => {\n\t\t\tif ( event.key === 'ArrowDown' ) {\n\t\t\t\t// Select the dropdown menu trigger item in the next row.\n\t\t\t\tevent.preventDefault();\n\t\t\t\tselectCompositeItem(\n\t\t\t\t\tactiveItemIndex + 1,\n\t\t\t\t\tgenerateDropdownTriggerCompositeId\n\t\t\t\t);\n\t\t\t}\n\t\t\tif ( event.key === 'ArrowUp' ) {\n\t\t\t\t// Select the dropdown menu trigger item in the previous row.\n\t\t\t\tevent.preventDefault();\n\t\t\t\tselectCompositeItem(\n\t\t\t\t\tactiveItemIndex - 1,\n\t\t\t\t\tgenerateDropdownTriggerCompositeId\n\t\t\t\t);\n\t\t\t}\n\t\t},\n\t\t[ selectCompositeItem, activeItemIndex ]\n\t);\n\n\tconst hasData = data?.length;\n\tif ( ! hasData ) {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tclassName={ clsx( {\n\t\t\t\t\t'dataviews-loading': isLoading,\n\t\t\t\t\t'dataviews-no-results': ! hasData && ! isLoading,\n\t\t\t\t} ) }\n\t\t\t>\n\t\t\t\t{ ! hasData && (\n\t\t\t\t\t<p>{ isLoading ? <Spinner /> : __( 'No results' ) }</p>\n\t\t\t\t) }\n\t\t\t</div>\n\t\t);\n\t}\n\n\treturn (\n\t\t<Composite\n\t\t\tid={ baseId }\n\t\t\trender={ <ul /> }\n\t\t\tclassName=\"dataviews-view-list\"\n\t\t\trole=\"grid\"\n\t\t\tactiveId={ activeCompositeId }\n\t\t\tsetActiveId={ setActiveCompositeId }\n\t\t>\n\t\t\t{ data.map( ( item ) => {\n\t\t\t\tconst id = generateCompositeItemIdPrefix( item );\n\t\t\t\treturn (\n\t\t\t\t\t<ListItem\n\t\t\t\t\t\tkey={ id }\n\t\t\t\t\t\tidPrefix={ id }\n\t\t\t\t\t\tactions={ actions }\n\t\t\t\t\t\titem={ item }\n\t\t\t\t\t\tisSelected={ item === selectedItem }\n\t\t\t\t\t\tonSelect={ onSelect }\n\t\t\t\t\t\tmediaField={ mediaField }\n\t\t\t\t\t\tprimaryField={ primaryField }\n\t\t\t\t\t\tvisibleFields={ visibleFields }\n\t\t\t\t\t\tonDropdownTriggerKeyDown={ onDropdownTriggerKeyDown }\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\t} ) }\n\t\t</Composite>\n\t);\n}\n"],"mappings":"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","ignoreList":[]}
@@ -16,21 +16,17 @@ import { forwardRef, Children, Fragment } from '@wordpress/element';
16
16
  import { unlock } from '../../lock-unlock';
17
17
  import { sanitizeOperators } from '../../utils';
18
18
  import { SORTING_DIRECTIONS, sortArrows, sortLabels } from '../../constants';
19
+ import { getVisibleFieldIds } from '../index';
19
20
  import { jsx as _jsx } from "react/jsx-runtime";
20
21
  import { jsxs as _jsxs } from "react/jsx-runtime";
21
22
  const {
22
- DropdownMenuV2: DropdownMenu,
23
- DropdownMenuGroupV2: DropdownMenuGroup,
24
- DropdownMenuItemV2: DropdownMenuItem,
25
- DropdownMenuRadioItemV2: DropdownMenuRadioItem,
26
- DropdownMenuItemLabelV2: DropdownMenuItemLabel,
27
- DropdownMenuSeparatorV2: DropdownMenuSeparator
23
+ DropdownMenuV2
28
24
  } = unlock(componentsPrivateApis);
29
25
  function WithDropDownMenuSeparators({
30
26
  children
31
27
  }) {
32
28
  return Children.toArray(children).filter(Boolean).map((child, i) => /*#__PURE__*/_jsxs(Fragment, {
33
- children: [i > 0 && /*#__PURE__*/_jsx(DropdownMenuSeparator, {}), child]
29
+ children: [i > 0 && /*#__PURE__*/_jsx(DropdownMenuV2.Separator, {}), child]
34
30
  }, i));
35
31
  }
36
32
  const _HeaderMenu = forwardRef(function HeaderMenu({
@@ -41,32 +37,41 @@ const _HeaderMenu = forwardRef(function HeaderMenu({
41
37
  onHide,
42
38
  setOpenedFilter
43
39
  }, ref) {
40
+ const visibleFieldIds = getVisibleFieldIds(view, fields);
41
+ const index = visibleFieldIds?.indexOf(fieldId);
42
+ const isSorted = view.sort?.field === fieldId;
43
+ let isHidable = false;
44
+ let isSortable = false;
45
+ let canAddFilter = false;
46
+ let header;
47
+ let operators = [];
44
48
  const combinedField = view.layout?.combinedFields?.find(f => f.id === fieldId);
45
- const index = view.fields?.indexOf(fieldId);
46
- if (!!combinedField) {
47
- return combinedField.header || combinedField.label;
48
- }
49
49
  const field = fields.find(f => f.id === fieldId);
50
- if (!field) {
51
- return null;
50
+ if (!combinedField) {
51
+ if (!field) {
52
+ // No combined or regular field found.
53
+ return null;
54
+ }
55
+ isHidable = field.enableHiding !== false;
56
+ isSortable = field.enableSorting !== false;
57
+ header = field.header;
58
+ operators = sanitizeOperators(field);
59
+ // Filter can be added:
60
+ // 1. If the field is not already part of a view's filters.
61
+ // 2. If the field meets the type and operator requirements.
62
+ // 3. If it's not primary. If it is, it should be already visible.
63
+ canAddFilter = !view.filters?.some(_filter => fieldId === _filter.field) && !!field.elements?.length && !!operators.length && !field.filterBy?.isPrimary;
64
+ } else {
65
+ header = combinedField.header || combinedField.label;
52
66
  }
53
- const isHidable = field.enableHiding !== false;
54
- const isSortable = field.enableSorting !== false;
55
- const isSorted = view.sort?.field === field.id;
56
- const operators = sanitizeOperators(field);
57
- // Filter can be added:
58
- // 1. If the field is not already part of a view's filters.
59
- // 2. If the field meets the type and operator requirements.
60
- // 3. If it's not primary. If it is, it should be already visible.
61
- const canAddFilter = !view.filters?.some(_filter => field.id === _filter.field) && !!field.elements?.length && !!operators.length && !field.filterBy?.isPrimary;
62
- return /*#__PURE__*/_jsx(DropdownMenu, {
67
+ return /*#__PURE__*/_jsx(DropdownMenuV2, {
63
68
  align: "start",
64
69
  trigger: /*#__PURE__*/_jsxs(Button, {
65
70
  size: "compact",
66
71
  className: "dataviews-view-table-header-button",
67
72
  ref: ref,
68
73
  variant: "tertiary",
69
- children: [field.header, view.sort && isSorted && /*#__PURE__*/_jsx("span", {
74
+ children: [header, view.sort && isSorted && /*#__PURE__*/_jsx("span", {
70
75
  "aria-hidden": "true",
71
76
  children: sortArrows[view.sort.direction]
72
77
  })]
@@ -75,11 +80,11 @@ const _HeaderMenu = forwardRef(function HeaderMenu({
75
80
  minWidth: '240px'
76
81
  },
77
82
  children: /*#__PURE__*/_jsxs(WithDropDownMenuSeparators, {
78
- children: [isSortable && /*#__PURE__*/_jsx(DropdownMenuGroup, {
83
+ children: [isSortable && /*#__PURE__*/_jsx(DropdownMenuV2.Group, {
79
84
  children: SORTING_DIRECTIONS.map(direction => {
80
85
  const isChecked = view.sort && isSorted && view.sort.direction === direction;
81
- const value = `${field.id}-${direction}`;
82
- return /*#__PURE__*/_jsx(DropdownMenuRadioItem, {
86
+ const value = `${fieldId}-${direction}`;
87
+ return /*#__PURE__*/_jsx(DropdownMenuV2.RadioItem, {
83
88
  // All sorting radio items share the same name, so that
84
89
  // selecting a sorting option automatically deselects the
85
90
  // previously selected one, even if it is displayed in
@@ -92,87 +97,80 @@ const _HeaderMenu = forwardRef(function HeaderMenu({
92
97
  onChangeView({
93
98
  ...view,
94
99
  sort: {
95
- field: field.id,
100
+ field: fieldId,
96
101
  direction
97
102
  }
98
103
  });
99
104
  },
100
- children: /*#__PURE__*/_jsx(DropdownMenuItemLabel, {
105
+ children: /*#__PURE__*/_jsx(DropdownMenuV2.ItemLabel, {
101
106
  children: sortLabels[direction]
102
107
  })
103
108
  }, value);
104
109
  })
105
- }), canAddFilter && /*#__PURE__*/_jsx(DropdownMenuGroup, {
106
- children: /*#__PURE__*/_jsx(DropdownMenuItem, {
110
+ }), canAddFilter && /*#__PURE__*/_jsx(DropdownMenuV2.Group, {
111
+ children: /*#__PURE__*/_jsx(DropdownMenuV2.Item, {
107
112
  prefix: /*#__PURE__*/_jsx(Icon, {
108
113
  icon: funnel
109
114
  }),
110
115
  onClick: () => {
111
- setOpenedFilter(field.id);
116
+ setOpenedFilter(fieldId);
112
117
  onChangeView({
113
118
  ...view,
114
119
  page: 1,
115
120
  filters: [...(view.filters || []), {
116
- field: field.id,
121
+ field: fieldId,
117
122
  value: undefined,
118
123
  operator: operators[0]
119
124
  }]
120
125
  });
121
126
  },
122
- children: /*#__PURE__*/_jsx(DropdownMenuItemLabel, {
127
+ children: /*#__PURE__*/_jsx(DropdownMenuV2.ItemLabel, {
123
128
  children: __('Add filter')
124
129
  })
125
130
  })
126
- }), /*#__PURE__*/_jsxs(DropdownMenuGroup, {
127
- children: [/*#__PURE__*/_jsx(DropdownMenuItem, {
131
+ }), /*#__PURE__*/_jsxs(DropdownMenuV2.Group, {
132
+ children: [/*#__PURE__*/_jsx(DropdownMenuV2.Item, {
128
133
  prefix: /*#__PURE__*/_jsx(Icon, {
129
134
  icon: arrowLeft
130
135
  }),
131
136
  disabled: index < 1,
132
137
  onClick: () => {
133
- var _view$fields$slice;
134
- if (!view.fields || index < 1) {
135
- return;
136
- }
138
+ var _visibleFieldIds$slic;
137
139
  onChangeView({
138
140
  ...view,
139
- fields: [...((_view$fields$slice = view.fields.slice(0, index - 1)) !== null && _view$fields$slice !== void 0 ? _view$fields$slice : []), field.id, view.fields[index - 1], ...view.fields.slice(index + 1)]
141
+ fields: [...((_visibleFieldIds$slic = visibleFieldIds.slice(0, index - 1)) !== null && _visibleFieldIds$slic !== void 0 ? _visibleFieldIds$slic : []), fieldId, visibleFieldIds[index - 1], ...visibleFieldIds.slice(index + 1)]
140
142
  });
141
143
  },
142
- children: /*#__PURE__*/_jsx(DropdownMenuItemLabel, {
144
+ children: /*#__PURE__*/_jsx(DropdownMenuV2.ItemLabel, {
143
145
  children: __('Move left')
144
146
  })
145
- }), /*#__PURE__*/_jsx(DropdownMenuItem, {
147
+ }), /*#__PURE__*/_jsx(DropdownMenuV2.Item, {
146
148
  prefix: /*#__PURE__*/_jsx(Icon, {
147
149
  icon: arrowRight
148
150
  }),
149
- disabled: !view.fields || index >= view.fields.length - 1,
151
+ disabled: index >= visibleFieldIds.length - 1,
150
152
  onClick: () => {
151
- var _view$fields$slice2;
152
- if (!view.fields || index >= view.fields.length - 1) {
153
- return;
154
- }
153
+ var _visibleFieldIds$slic2;
155
154
  onChangeView({
156
155
  ...view,
157
- fields: [...((_view$fields$slice2 = view.fields.slice(0, index)) !== null && _view$fields$slice2 !== void 0 ? _view$fields$slice2 : []), view.fields[index + 1], field.id, ...view.fields.slice(index + 2)]
156
+ fields: [...((_visibleFieldIds$slic2 = visibleFieldIds.slice(0, index)) !== null && _visibleFieldIds$slic2 !== void 0 ? _visibleFieldIds$slic2 : []), visibleFieldIds[index + 1], fieldId, ...visibleFieldIds.slice(index + 2)]
158
157
  });
159
158
  },
160
- children: /*#__PURE__*/_jsx(DropdownMenuItemLabel, {
159
+ children: /*#__PURE__*/_jsx(DropdownMenuV2.ItemLabel, {
161
160
  children: __('Move right')
162
161
  })
163
- }), isHidable && /*#__PURE__*/_jsx(DropdownMenuItem, {
162
+ }), isHidable && field && /*#__PURE__*/_jsx(DropdownMenuV2.Item, {
164
163
  prefix: /*#__PURE__*/_jsx(Icon, {
165
164
  icon: unseen
166
165
  }),
167
166
  onClick: () => {
168
- const viewFields = view.fields || fields.map(f => f.id);
169
167
  onHide(field);
170
168
  onChangeView({
171
169
  ...view,
172
- fields: viewFields.filter(id => id !== field.id)
170
+ fields: visibleFieldIds.filter(id => id !== fieldId)
173
171
  });
174
172
  },
175
- children: /*#__PURE__*/_jsx(DropdownMenuItemLabel, {
173
+ children: /*#__PURE__*/_jsx(DropdownMenuV2.ItemLabel, {
176
174
  children: __('Hide column')
177
175
  })
178
176
  })]