@wordpress/dataviews 0.3.0 → 0.4.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 (45) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/build/bulk-actions.js +143 -0
  3. package/build/bulk-actions.js.map +1 -0
  4. package/build/dataviews.js +15 -1
  5. package/build/dataviews.js.map +1 -1
  6. package/build/item-actions.js +4 -4
  7. package/build/item-actions.js.map +1 -1
  8. package/build/pagination.js +2 -2
  9. package/build/pagination.js.map +1 -1
  10. package/build/view-actions.js +3 -2
  11. package/build/view-actions.js.map +1 -1
  12. package/build/view-grid.js +11 -8
  13. package/build/view-grid.js.map +1 -1
  14. package/build/view-list.js +13 -1
  15. package/build/view-list.js.map +1 -1
  16. package/build/view-table.js +116 -9
  17. package/build/view-table.js.map +1 -1
  18. package/build-module/bulk-actions.js +136 -0
  19. package/build-module/bulk-actions.js.map +1 -0
  20. package/build-module/dataviews.js +17 -3
  21. package/build-module/dataviews.js.map +1 -1
  22. package/build-module/item-actions.js +4 -4
  23. package/build-module/item-actions.js.map +1 -1
  24. package/build-module/pagination.js +2 -2
  25. package/build-module/pagination.js.map +1 -1
  26. package/build-module/view-actions.js +4 -3
  27. package/build-module/view-actions.js.map +1 -1
  28. package/build-module/view-grid.js +12 -9
  29. package/build-module/view-grid.js.map +1 -1
  30. package/build-module/view-list.js +13 -1
  31. package/build-module/view-list.js.map +1 -1
  32. package/build-module/view-table.js +120 -13
  33. package/build-module/view-table.js.map +1 -1
  34. package/build-style/style-rtl.css +143 -26
  35. package/build-style/style.css +143 -26
  36. package/package.json +11 -11
  37. package/src/bulk-actions.js +187 -0
  38. package/src/dataviews.js +29 -2
  39. package/src/item-actions.js +4 -7
  40. package/src/pagination.js +2 -6
  41. package/src/style.scss +152 -29
  42. package/src/view-actions.js +8 -14
  43. package/src/view-grid.js +14 -12
  44. package/src/view-list.js +20 -1
  45. package/src/view-table.js +161 -15
@@ -2,15 +2,15 @@ import { createElement } from "react";
2
2
  /**
3
3
  * External dependencies
4
4
  */
5
- import classNames from 'classnames';
5
+ import classnames from 'classnames';
6
6
 
7
7
  /**
8
8
  * WordPress dependencies
9
9
  */
10
- import { __ } from '@wordpress/i18n';
10
+ import { __, sprintf } from '@wordpress/i18n';
11
11
  import { useAsyncList } from '@wordpress/compose';
12
12
  import { unseen, funnel } from '@wordpress/icons';
13
- import { Button, Icon, privateApis as componentsPrivateApis } from '@wordpress/components';
13
+ import { Button, Icon, privateApis as componentsPrivateApis, CheckboxControl } from '@wordpress/components';
14
14
  import { Children, Fragment, forwardRef, useEffect, useId, useRef, useState } from '@wordpress/element';
15
15
 
16
16
  /**
@@ -175,6 +175,67 @@ function WithSeparators({
175
175
  key: i
176
176
  }, i > 0 && createElement(DropdownMenuSeparator, null), child));
177
177
  }
178
+ function BulkSelectionCheckbox({
179
+ selection,
180
+ onSelectionChange,
181
+ data
182
+ }) {
183
+ const areAllSelected = selection.length === data.length;
184
+ return createElement(CheckboxControl, {
185
+ className: "dataviews-view-table-selection-checkbox",
186
+ __nextHasNoMarginBottom: true,
187
+ checked: areAllSelected,
188
+ indeterminate: !areAllSelected && selection.length,
189
+ onChange: () => {
190
+ if (areAllSelected) {
191
+ onSelectionChange([]);
192
+ } else {
193
+ onSelectionChange(data);
194
+ }
195
+ },
196
+ label: areAllSelected ? __('Deselect all') : __('Select all')
197
+ });
198
+ }
199
+ function SingleSelectionCheckbox({
200
+ selection,
201
+ onSelectionChange,
202
+ item,
203
+ data,
204
+ getItemId,
205
+ primaryField
206
+ }) {
207
+ const id = getItemId(item);
208
+ const isSelected = selection.includes(id);
209
+ let selectionLabel;
210
+ if (primaryField?.getValue && item) {
211
+ // eslint-disable-next-line @wordpress/valid-sprintf
212
+ selectionLabel = sprintf( /* translators: %s: item title. */
213
+ isSelected ? __('Deselect item: %s') : __('Select item: %s'), primaryField.getValue({
214
+ item
215
+ }));
216
+ } else {
217
+ selectionLabel = isSelected ? __('Select a new item') : __('Deselect item');
218
+ }
219
+ return createElement(CheckboxControl, {
220
+ className: "dataviews-view-table-selection-checkbox",
221
+ __nextHasNoMarginBottom: true,
222
+ checked: isSelected,
223
+ label: selectionLabel,
224
+ onChange: () => {
225
+ if (!isSelected) {
226
+ onSelectionChange(data.filter(_item => {
227
+ const itemId = getItemId?.(_item);
228
+ return itemId === id || selection.includes(itemId);
229
+ }));
230
+ } else {
231
+ onSelectionChange(data.filter(_item => {
232
+ const itemId = getItemId?.(_item);
233
+ return itemId !== id && selection.includes(itemId);
234
+ }));
235
+ }
236
+ }
237
+ });
238
+ }
178
239
  function ViewTable({
179
240
  view,
180
241
  onChangeView,
@@ -183,8 +244,11 @@ function ViewTable({
183
244
  data,
184
245
  getItemId,
185
246
  isLoading = false,
186
- deferredRendering
247
+ deferredRendering,
248
+ selection,
249
+ onSelectionChange
187
250
  }) {
251
+ const hasBulkActions = actions?.some(action => action.supportsBulk);
188
252
  const headerMenuRefs = useRef(new Map());
189
253
  const headerMenuToFocusRef = useRef();
190
254
  const [nextHeaderMenuToFocus, setNextHeaderMenuToFocus] = useState();
@@ -210,18 +274,35 @@ function ViewTable({
210
274
  const fallback = headerMenuRefs.current.get(hidden.fallback);
211
275
  setNextHeaderMenuToFocus(fallback?.node);
212
276
  };
213
- const visibleFields = fields.filter(field => !view.hiddenFields.includes(field.id) && ![view.layout.mediaField, view.layout.primaryField].includes(field.id));
277
+ const visibleFields = fields.filter(field => !view.hiddenFields.includes(field.id) && ![view.layout.mediaField].includes(field.id));
214
278
  const usedData = deferredRendering ? asyncData : data;
215
279
  const hasData = !!usedData?.length;
216
280
  const sortValues = {
217
281
  asc: 'ascending',
218
282
  desc: 'descending'
219
283
  };
220
- return createElement("div", null, createElement("table", {
284
+ const primaryField = fields.find(field => field.id === view.layout.primaryField);
285
+ return createElement("div", {
286
+ className: "dataviews-view-table-wrapper"
287
+ }, createElement("table", {
221
288
  className: "dataviews-view-table",
222
289
  "aria-busy": isLoading,
223
290
  "aria-describedby": tableNoticeId
224
- }, createElement("thead", null, createElement("tr", null, visibleFields.map((field, index) => createElement("th", {
291
+ }, createElement("thead", null, createElement("tr", {
292
+ className: "dataviews-view-table__row"
293
+ }, hasBulkActions && createElement("th", {
294
+ className: "dataviews-view-table__checkbox-column",
295
+ style: {
296
+ width: 20,
297
+ minWidth: 20
298
+ },
299
+ "data-field-id": "selection",
300
+ scope: "col"
301
+ }, createElement(BulkSelectionCheckbox, {
302
+ selection: selection,
303
+ onSelectionChange: onSelectionChange,
304
+ data: data
305
+ })), visibleFields.map((field, index) => createElement("th", {
225
306
  key: field.id,
226
307
  style: {
227
308
  width: field.width || undefined,
@@ -247,25 +328,51 @@ function ViewTable({
247
328
  onChangeView: onChangeView,
248
329
  onHide: onHide
249
330
  }))), !!actions?.length && createElement("th", {
250
- "data-field-id": "actions"
331
+ "data-field-id": "actions",
332
+ className: "dataviews-view-table__actions-column"
251
333
  }, createElement("span", {
252
334
  className: "dataviews-view-table-header"
253
- }, __('Actions'))))), createElement("tbody", null, hasData && usedData.map(item => createElement("tr", {
254
- key: getItemId(item)
255
- }, visibleFields.map(field => createElement("td", {
335
+ }, __('Actions'))))), createElement("tbody", null, hasData && usedData.map((item, index) => createElement("tr", {
336
+ key: getItemId(item),
337
+ className: classnames('dataviews-view-table__row', {
338
+ 'is-selected': selection.includes(getItemId(item) || index)
339
+ })
340
+ }, hasBulkActions && createElement("td", {
341
+ className: "dataviews-view-table__checkbox-column",
342
+ style: {
343
+ width: 20,
344
+ minWidth: 20
345
+ }
346
+ }, createElement("span", {
347
+ className: "dataviews-view-table__cell-content-wrapper"
348
+ }, createElement(SingleSelectionCheckbox, {
349
+ id: getItemId(item) || index,
350
+ item: item,
351
+ selection: selection,
352
+ onSelectionChange: onSelectionChange,
353
+ getItemId: getItemId,
354
+ data: data,
355
+ primaryField: primaryField
356
+ }))), visibleFields.map(field => createElement("td", {
256
357
  key: field.id,
257
358
  style: {
258
359
  width: field.width || undefined,
259
360
  minWidth: field.minWidth || undefined,
260
361
  maxWidth: field.maxWidth || undefined
261
362
  }
363
+ }, createElement("span", {
364
+ className: classnames('dataviews-view-table__cell-content-wrapper', {
365
+ 'dataviews-view-table__primary-field': primaryField?.id === field.id
366
+ })
262
367
  }, field.render({
263
368
  item
264
- }))), !!actions?.length && createElement("td", null, createElement(ItemActions, {
369
+ })))), !!actions?.length && createElement("td", {
370
+ className: "dataviews-view-table__actions-column"
371
+ }, createElement(ItemActions, {
265
372
  item: item,
266
373
  actions: actions
267
374
  })))))), createElement("div", {
268
- className: classNames({
375
+ className: classnames({
269
376
  'dataviews-loading': isLoading,
270
377
  'dataviews-no-results': !hasData && !isLoading
271
378
  }),
@@ -1 +1 @@
1
- {"version":3,"names":["classNames","__","useAsyncList","unseen","funnel","Button","Icon","privateApis","componentsPrivateApis","Children","Fragment","forwardRef","useEffect","useId","useRef","useState","unlock","ItemActions","ENUMERATION_TYPE","OPERATORS","SORTING_DIRECTIONS","DropdownMenuRadioItemCustom","DropdownMenuV2","DropdownMenu","DropdownMenuGroupV2","DropdownMenuGroup","DropdownMenuItemV2","DropdownMenuItem","DropdownMenuRadioItemV2","DropdownMenuRadioItem","DropdownMenuSeparatorV2","DropdownMenuSeparator","DropdownMenuItemLabelV2","DropdownMenuItemLabel","DropdownMenuItemHelpTextV2","DropdownMenuItemHelpText","sortArrows","asc","desc","sanitizeOperators","field","operators","filterBy","Array","isArray","Object","keys","filter","operator","includes","HeaderMenu","view","onChangeView","onHide","ref","isHidable","enableHiding","isSortable","enableSorting","isSorted","sort","id","filterInView","activeElement","activeOperator","otherFilters","type","length","elements","filters","find","f","element","value","isFilterable","header","createElement","align","trigger","size","className","variant","direction","style","minWidth","WithSeparators","entries","map","info","isChecked","key","name","checked","onChange","label","prefix","icon","onClick","hiddenFields","concat","suffix","isActive","page","undefined","description","e","target","children","toArray","Boolean","child","i","ViewTable","fields","actions","data","getItemId","isLoading","deferredRendering","headerMenuRefs","Map","headerMenuToFocusRef","nextHeaderMenuToFocus","setNextHeaderMenuToFocus","current","focus","asyncData","tableNoticeId","hidden","get","fallback","node","visibleFields","layout","mediaField","primaryField","usedData","hasData","sortValues","index","width","maxWidth","scope","set","delete","item","render"],"sources":["@wordpress/dataviews/src/view-table.js"],"sourcesContent":["/**\n * External dependencies\n */\nimport classNames from 'classnames';\n\n/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { useAsyncList } from '@wordpress/compose';\nimport { unseen, funnel } from '@wordpress/icons';\nimport {\n\tButton,\n\tIcon,\n\tprivateApis as componentsPrivateApis,\n} from '@wordpress/components';\nimport {\n\tChildren,\n\tFragment,\n\tforwardRef,\n\tuseEffect,\n\tuseId,\n\tuseRef,\n\tuseState,\n} from '@wordpress/element';\n\n/**\n * Internal dependencies\n */\nimport { unlock } from './lock-unlock';\nimport ItemActions from './item-actions';\nimport { ENUMERATION_TYPE, OPERATORS, SORTING_DIRECTIONS } from './constants';\nimport { DropdownMenuRadioItemCustom } from './dropdown-menu-helper';\n\nconst {\n\tDropdownMenuV2: DropdownMenu,\n\tDropdownMenuGroupV2: DropdownMenuGroup,\n\tDropdownMenuItemV2: DropdownMenuItem,\n\tDropdownMenuRadioItemV2: DropdownMenuRadioItem,\n\tDropdownMenuSeparatorV2: DropdownMenuSeparator,\n\tDropdownMenuItemLabelV2: DropdownMenuItemLabel,\n\tDropdownMenuItemHelpTextV2: DropdownMenuItemHelpText,\n} = unlock( componentsPrivateApis );\n\nconst sortArrows = { asc: '↑', desc: '↓' };\n\nconst sanitizeOperators = ( field ) => {\n\tlet operators = field.filterBy?.operators;\n\tif ( ! operators || ! Array.isArray( operators ) ) {\n\t\toperators = Object.keys( OPERATORS );\n\t}\n\treturn operators.filter( ( operator ) =>\n\t\tObject.keys( OPERATORS ).includes( operator )\n\t);\n};\n\nconst HeaderMenu = forwardRef( function HeaderMenu(\n\t{ field, view, onChangeView, onHide },\n\tref\n) {\n\tconst isHidable = field.enableHiding !== false;\n\n\tconst isSortable = field.enableSorting !== false;\n\tconst isSorted = view.sort?.field === field.id;\n\n\tlet filter, filterInView, activeElement, activeOperator, otherFilters;\n\tconst operators = sanitizeOperators( field );\n\tif ( field.type === ENUMERATION_TYPE && operators.length > 0 ) {\n\t\tfilter = {\n\t\t\tfield: field.id,\n\t\t\toperators,\n\t\t\telements: field.elements || [],\n\t\t};\n\t\tfilterInView = view.filters.find( ( f ) => f.field === filter.field );\n\t\totherFilters = view.filters.filter( ( f ) => f.field !== filter.field );\n\t\tactiveElement = filter.elements.find(\n\t\t\t( element ) => element.value === filterInView?.value\n\t\t);\n\t\tactiveOperator = filterInView?.operator || filter.operators[ 0 ];\n\t}\n\tconst isFilterable = !! filter;\n\n\tif ( ! isSortable && ! isHidable && ! isFilterable ) {\n\t\treturn field.header;\n\t}\n\n\treturn (\n\t\t<DropdownMenu\n\t\t\talign=\"start\"\n\t\t\ttrigger={\n\t\t\t\t<Button\n\t\t\t\t\tsize=\"compact\"\n\t\t\t\t\tclassName=\"dataviews-view-table-header-button\"\n\t\t\t\t\tref={ ref }\n\t\t\t\t\tvariant=\"tertiary\"\n\t\t\t\t>\n\t\t\t\t\t{ field.header }\n\t\t\t\t\t{ isSorted && (\n\t\t\t\t\t\t<span aria-hidden=\"true\">\n\t\t\t\t\t\t\t{ isSorted && sortArrows[ view.sort.direction ] }\n\t\t\t\t\t\t</span>\n\t\t\t\t\t) }\n\t\t\t\t</Button>\n\t\t\t}\n\t\t\tstyle={ { minWidth: '240px' } }\n\t\t>\n\t\t\t<WithSeparators>\n\t\t\t\t{ isSortable && (\n\t\t\t\t\t<DropdownMenuGroup>\n\t\t\t\t\t\t{ Object.entries( SORTING_DIRECTIONS ).map(\n\t\t\t\t\t\t\t( [ direction, info ] ) => {\n\t\t\t\t\t\t\t\tconst isChecked =\n\t\t\t\t\t\t\t\t\tisSorted &&\n\t\t\t\t\t\t\t\t\tview.sort.direction === direction;\n\n\t\t\t\t\t\t\t\tconst value = `${ field.id }-${ direction }`;\n\n\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t<DropdownMenuRadioItem\n\t\t\t\t\t\t\t\t\t\tkey={ value }\n\t\t\t\t\t\t\t\t\t\t// All sorting radio items share the same name, so that\n\t\t\t\t\t\t\t\t\t\t// selecting a sorting option automatically deselects the\n\t\t\t\t\t\t\t\t\t\t// previously selected one, even if it is displayed in\n\t\t\t\t\t\t\t\t\t\t// another submenu. The field and direction are passed via\n\t\t\t\t\t\t\t\t\t\t// the `value` prop.\n\t\t\t\t\t\t\t\t\t\tname=\"view-table-sorting\"\n\t\t\t\t\t\t\t\t\t\tvalue={ value }\n\t\t\t\t\t\t\t\t\t\tchecked={ isChecked }\n\t\t\t\t\t\t\t\t\t\tonChange={ () => {\n\t\t\t\t\t\t\t\t\t\t\tonChangeView( {\n\t\t\t\t\t\t\t\t\t\t\t\t...view,\n\t\t\t\t\t\t\t\t\t\t\t\tsort: {\n\t\t\t\t\t\t\t\t\t\t\t\t\tfield: field.id,\n\t\t\t\t\t\t\t\t\t\t\t\t\tdirection,\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\t\t<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t{ info.label }\n\t\t\t\t\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t</DropdownMenuRadioItem>\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t) }\n\t\t\t\t\t</DropdownMenuGroup>\n\t\t\t\t) }\n\t\t\t\t{ isHidable && (\n\t\t\t\t\t<DropdownMenuItem\n\t\t\t\t\t\tprefix={ <Icon icon={ unseen } /> }\n\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\tonHide( field );\n\t\t\t\t\t\t\tonChangeView( {\n\t\t\t\t\t\t\t\t...view,\n\t\t\t\t\t\t\t\thiddenFields: view.hiddenFields.concat(\n\t\t\t\t\t\t\t\t\tfield.id\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t} }\n\t\t\t\t\t>\n\t\t\t\t\t\t<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t{ __( 'Hide' ) }\n\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t</DropdownMenuItem>\n\t\t\t\t) }\n\t\t\t\t{ isFilterable && (\n\t\t\t\t\t<DropdownMenuGroup>\n\t\t\t\t\t\t<DropdownMenu\n\t\t\t\t\t\t\tkey={ filter.field }\n\t\t\t\t\t\t\ttrigger={\n\t\t\t\t\t\t\t\t<DropdownMenuItem\n\t\t\t\t\t\t\t\t\tprefix={ <Icon icon={ funnel } /> }\n\t\t\t\t\t\t\t\t\tsuffix={\n\t\t\t\t\t\t\t\t\t\tactiveElement && (\n\t\t\t\t\t\t\t\t\t\t\t<span aria-hidden=\"true\">\n\t\t\t\t\t\t\t\t\t\t\t\t{ activeOperator in OPERATORS &&\n\t\t\t\t\t\t\t\t\t\t\t\t\t`${ OPERATORS[ activeOperator ].label } ` }\n\t\t\t\t\t\t\t\t\t\t\t\t{ activeElement?.label }\n\t\t\t\t\t\t\t\t\t\t\t</span>\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<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t{ __( 'Filter by' ) }\n\t\t\t\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t</DropdownMenuItem>\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<WithSeparators>\n\t\t\t\t\t\t\t\t<DropdownMenuGroup>\n\t\t\t\t\t\t\t\t\t{ filter.elements.map( ( element ) => {\n\t\t\t\t\t\t\t\t\t\tconst isActive =\n\t\t\t\t\t\t\t\t\t\t\tactiveElement?.value ===\n\t\t\t\t\t\t\t\t\t\t\telement.value;\n\t\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t\t<DropdownMenuRadioItemCustom\n\t\t\t\t\t\t\t\t\t\t\t\tkey={ element.value }\n\t\t\t\t\t\t\t\t\t\t\t\tname={ `view-table-${ filter.field }` }\n\t\t\t\t\t\t\t\t\t\t\t\tvalue={ element.value }\n\t\t\t\t\t\t\t\t\t\t\t\tchecked={ isActive }\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\tonChangeView( {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t...view,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tpage: 1,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilters: [\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t...otherFilters,\n\t\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\t\t\tfield: filter.field,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\toperator:\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tactiveOperator,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tvalue: isActive\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? undefined\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: element.value,\n\t\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\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\t\t<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t\t\t{ element.label }\n\t\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t\t{ !! element.description && (\n\t\t\t\t\t\t\t\t\t\t\t\t\t<DropdownMenuItemHelpText>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{ element.description }\n\t\t\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuItemHelpText>\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</DropdownMenuRadioItemCustom>\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</DropdownMenuGroup>\n\t\t\t\t\t\t\t\t{ filter.operators.length > 1 && (\n\t\t\t\t\t\t\t\t\t<DropdownMenu\n\t\t\t\t\t\t\t\t\t\ttrigger={\n\t\t\t\t\t\t\t\t\t\t\t<DropdownMenuItem\n\t\t\t\t\t\t\t\t\t\t\t\tsuffix={\n\t\t\t\t\t\t\t\t\t\t\t\t\t<span aria-hidden=\"true\">\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\t\tOPERATORS[\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tactiveOperator\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t]?.label\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</span>\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\t\t<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t\t\t{ __( 'Conditions' ) }\n\t\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuItem>\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\t\t{ Object.entries( OPERATORS ).map(\n\t\t\t\t\t\t\t\t\t\t\t( [\n\t\t\t\t\t\t\t\t\t\t\t\toperator,\n\t\t\t\t\t\t\t\t\t\t\t\t{ label, key },\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<DropdownMenuRadioItem\n\t\t\t\t\t\t\t\t\t\t\t\t\tkey={ key }\n\t\t\t\t\t\t\t\t\t\t\t\t\tname={ `view-table-${ filter.field }-conditions` }\n\t\t\t\t\t\t\t\t\t\t\t\t\tvalue={ operator }\n\t\t\t\t\t\t\t\t\t\t\t\t\tchecked={\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tactiveOperator ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\toperator\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\tonChange={ ( e ) =>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tonChangeView( {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t...view,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tpage: 1,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilters: [\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t...otherFilters,\n\t\t\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\t\t\t\tfield: filter.field,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\toperator:\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\te.target\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t.value,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tvalue: filterInView?.value,\n\t\t\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\t\t],\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\t\t<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{ label }\n\t\t\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuRadioItem>\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</DropdownMenu>\n\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t</WithSeparators>\n\t\t\t\t\t\t</DropdownMenu>\n\t\t\t\t\t</DropdownMenuGroup>\n\t\t\t\t) }\n\t\t\t</WithSeparators>\n\t\t</DropdownMenu>\n\t);\n} );\n\nfunction WithSeparators( { children } ) {\n\treturn Children.toArray( children )\n\t\t.filter( Boolean )\n\t\t.map( ( child, i ) => (\n\t\t\t<Fragment key={ i }>\n\t\t\t\t{ i > 0 && <DropdownMenuSeparator /> }\n\t\t\t\t{ child }\n\t\t\t</Fragment>\n\t\t) );\n}\n\nfunction ViewTable( {\n\tview,\n\tonChangeView,\n\tfields,\n\tactions,\n\tdata,\n\tgetItemId,\n\tisLoading = false,\n\tdeferredRendering,\n} ) {\n\tconst headerMenuRefs = useRef( new Map() );\n\tconst headerMenuToFocusRef = useRef();\n\tconst [ nextHeaderMenuToFocus, setNextHeaderMenuToFocus ] = useState();\n\n\tuseEffect( () => {\n\t\tif ( headerMenuToFocusRef.current ) {\n\t\t\theaderMenuToFocusRef.current.focus();\n\t\t\theaderMenuToFocusRef.current = undefined;\n\t\t}\n\t} );\n\n\tconst asyncData = useAsyncList( data );\n\tconst tableNoticeId = useId();\n\n\tif ( nextHeaderMenuToFocus ) {\n\t\t// If we need to force focus, we short-circuit rendering here\n\t\t// to prevent any additional work while we handle that.\n\t\t// Clearing out the focus directive is necessary to make sure\n\t\t// future renders don't cause unexpected focus jumps.\n\t\theaderMenuToFocusRef.current = nextHeaderMenuToFocus;\n\t\tsetNextHeaderMenuToFocus();\n\t\treturn;\n\t}\n\n\tconst onHide = ( field ) => {\n\t\tconst hidden = headerMenuRefs.current.get( field.id );\n\t\tconst fallback = headerMenuRefs.current.get( hidden.fallback );\n\t\tsetNextHeaderMenuToFocus( fallback?.node );\n\t};\n\tconst visibleFields = fields.filter(\n\t\t( field ) =>\n\t\t\t! view.hiddenFields.includes( field.id ) &&\n\t\t\t! [ view.layout.mediaField, view.layout.primaryField ].includes(\n\t\t\t\tfield.id\n\t\t\t)\n\t);\n\tconst usedData = deferredRendering ? asyncData : data;\n\tconst hasData = !! usedData?.length;\n\tconst sortValues = { asc: 'ascending', desc: 'descending' };\n\n\treturn (\n\t\t<div>\n\t\t\t<table\n\t\t\t\tclassName=\"dataviews-view-table\"\n\t\t\t\taria-busy={ isLoading }\n\t\t\t\taria-describedby={ tableNoticeId }\n\t\t\t>\n\t\t\t\t<thead>\n\t\t\t\t\t<tr>\n\t\t\t\t\t\t{ visibleFields.map( ( field, index ) => (\n\t\t\t\t\t\t\t<th\n\t\t\t\t\t\t\t\tkey={ field.id }\n\t\t\t\t\t\t\t\tstyle={ {\n\t\t\t\t\t\t\t\t\twidth: field.width || undefined,\n\t\t\t\t\t\t\t\t\tminWidth: field.minWidth || undefined,\n\t\t\t\t\t\t\t\t\tmaxWidth: field.maxWidth || undefined,\n\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\tdata-field-id={ field.id }\n\t\t\t\t\t\t\t\taria-sort={\n\t\t\t\t\t\t\t\t\tview.sort?.field === field.id &&\n\t\t\t\t\t\t\t\t\tsortValues[ view.sort.direction ]\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tscope=\"col\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<HeaderMenu\n\t\t\t\t\t\t\t\t\tref={ ( node ) => {\n\t\t\t\t\t\t\t\t\t\tif ( node ) {\n\t\t\t\t\t\t\t\t\t\t\theaderMenuRefs.current.set(\n\t\t\t\t\t\t\t\t\t\t\t\tfield.id,\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\tnode,\n\t\t\t\t\t\t\t\t\t\t\t\t\tfallback:\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tvisibleFields[\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tindex > 0\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? index - 1\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: 1\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t]?.id,\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} else {\n\t\t\t\t\t\t\t\t\t\t\theaderMenuRefs.current.delete(\n\t\t\t\t\t\t\t\t\t\t\t\tfield.id\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\tfield={ field }\n\t\t\t\t\t\t\t\t\tview={ view }\n\t\t\t\t\t\t\t\t\tonChangeView={ onChangeView }\n\t\t\t\t\t\t\t\t\tonHide={ onHide }\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</th>\n\t\t\t\t\t\t) ) }\n\t\t\t\t\t\t{ !! actions?.length && (\n\t\t\t\t\t\t\t<th data-field-id=\"actions\">\n\t\t\t\t\t\t\t\t<span className=\"dataviews-view-table-header\">\n\t\t\t\t\t\t\t\t\t{ __( 'Actions' ) }\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t</th>\n\t\t\t\t\t\t) }\n\t\t\t\t\t</tr>\n\t\t\t\t</thead>\n\t\t\t\t<tbody>\n\t\t\t\t\t{ hasData &&\n\t\t\t\t\t\tusedData.map( ( item ) => (\n\t\t\t\t\t\t\t<tr key={ getItemId( item ) }>\n\t\t\t\t\t\t\t\t{ visibleFields.map( ( field ) => (\n\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\tkey={ field.id }\n\t\t\t\t\t\t\t\t\t\tstyle={ {\n\t\t\t\t\t\t\t\t\t\t\twidth: field.width || undefined,\n\t\t\t\t\t\t\t\t\t\t\tminWidth:\n\t\t\t\t\t\t\t\t\t\t\t\tfield.minWidth || undefined,\n\t\t\t\t\t\t\t\t\t\t\tmaxWidth:\n\t\t\t\t\t\t\t\t\t\t\t\tfield.maxWidth || undefined,\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\t\t{ field.render( {\n\t\t\t\t\t\t\t\t\t\t\titem,\n\t\t\t\t\t\t\t\t\t\t} ) }\n\t\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t\t) ) }\n\t\t\t\t\t\t\t\t{ !! actions?.length && (\n\t\t\t\t\t\t\t\t\t<td>\n\t\t\t\t\t\t\t\t\t\t<ItemActions\n\t\t\t\t\t\t\t\t\t\t\titem={ item }\n\t\t\t\t\t\t\t\t\t\t\tactions={ actions }\n\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t) ) }\n\t\t\t\t</tbody>\n\t\t\t</table>\n\t\t\t<div\n\t\t\t\tclassName={ classNames( {\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\tid={ tableNoticeId }\n\t\t\t>\n\t\t\t\t{ ! hasData && (\n\t\t\t\t\t<p>{ isLoading ? __( 'Loading…' ) : __( 'No results' ) }</p>\n\t\t\t\t) }\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n\nexport default ViewTable;\n"],"mappings":"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"}
1
+ {"version":3,"names":["classnames","__","sprintf","useAsyncList","unseen","funnel","Button","Icon","privateApis","componentsPrivateApis","CheckboxControl","Children","Fragment","forwardRef","useEffect","useId","useRef","useState","unlock","ItemActions","ENUMERATION_TYPE","OPERATORS","SORTING_DIRECTIONS","DropdownMenuRadioItemCustom","DropdownMenuV2","DropdownMenu","DropdownMenuGroupV2","DropdownMenuGroup","DropdownMenuItemV2","DropdownMenuItem","DropdownMenuRadioItemV2","DropdownMenuRadioItem","DropdownMenuSeparatorV2","DropdownMenuSeparator","DropdownMenuItemLabelV2","DropdownMenuItemLabel","DropdownMenuItemHelpTextV2","DropdownMenuItemHelpText","sortArrows","asc","desc","sanitizeOperators","field","operators","filterBy","Array","isArray","Object","keys","filter","operator","includes","HeaderMenu","view","onChangeView","onHide","ref","isHidable","enableHiding","isSortable","enableSorting","isSorted","sort","id","filterInView","activeElement","activeOperator","otherFilters","type","length","elements","filters","find","f","element","value","isFilterable","header","createElement","align","trigger","size","className","variant","direction","style","minWidth","WithSeparators","entries","map","info","isChecked","key","name","checked","onChange","label","prefix","icon","onClick","hiddenFields","concat","suffix","isActive","page","undefined","description","e","target","children","toArray","Boolean","child","i","BulkSelectionCheckbox","selection","onSelectionChange","data","areAllSelected","__nextHasNoMarginBottom","indeterminate","SingleSelectionCheckbox","item","getItemId","primaryField","isSelected","selectionLabel","getValue","_item","itemId","ViewTable","fields","actions","isLoading","deferredRendering","hasBulkActions","some","action","supportsBulk","headerMenuRefs","Map","headerMenuToFocusRef","nextHeaderMenuToFocus","setNextHeaderMenuToFocus","current","focus","asyncData","tableNoticeId","hidden","get","fallback","node","visibleFields","layout","mediaField","usedData","hasData","sortValues","width","scope","index","maxWidth","set","delete","render"],"sources":["@wordpress/dataviews/src/view-table.js"],"sourcesContent":["/**\n * External dependencies\n */\nimport classnames from 'classnames';\n\n/**\n * WordPress dependencies\n */\nimport { __, sprintf } from '@wordpress/i18n';\nimport { useAsyncList } from '@wordpress/compose';\nimport { unseen, funnel } from '@wordpress/icons';\nimport {\n\tButton,\n\tIcon,\n\tprivateApis as componentsPrivateApis,\n\tCheckboxControl,\n} from '@wordpress/components';\nimport {\n\tChildren,\n\tFragment,\n\tforwardRef,\n\tuseEffect,\n\tuseId,\n\tuseRef,\n\tuseState,\n} from '@wordpress/element';\n\n/**\n * Internal dependencies\n */\nimport { unlock } from './lock-unlock';\nimport ItemActions from './item-actions';\nimport { ENUMERATION_TYPE, OPERATORS, SORTING_DIRECTIONS } from './constants';\nimport { DropdownMenuRadioItemCustom } from './dropdown-menu-helper';\n\nconst {\n\tDropdownMenuV2: DropdownMenu,\n\tDropdownMenuGroupV2: DropdownMenuGroup,\n\tDropdownMenuItemV2: DropdownMenuItem,\n\tDropdownMenuRadioItemV2: DropdownMenuRadioItem,\n\tDropdownMenuSeparatorV2: DropdownMenuSeparator,\n\tDropdownMenuItemLabelV2: DropdownMenuItemLabel,\n\tDropdownMenuItemHelpTextV2: DropdownMenuItemHelpText,\n} = unlock( componentsPrivateApis );\n\nconst sortArrows = { asc: '↑', desc: '↓' };\n\nconst sanitizeOperators = ( field ) => {\n\tlet operators = field.filterBy?.operators;\n\tif ( ! operators || ! Array.isArray( operators ) ) {\n\t\toperators = Object.keys( OPERATORS );\n\t}\n\treturn operators.filter( ( operator ) =>\n\t\tObject.keys( OPERATORS ).includes( operator )\n\t);\n};\n\nconst HeaderMenu = forwardRef( function HeaderMenu(\n\t{ field, view, onChangeView, onHide },\n\tref\n) {\n\tconst isHidable = field.enableHiding !== false;\n\n\tconst isSortable = field.enableSorting !== false;\n\tconst isSorted = view.sort?.field === field.id;\n\n\tlet filter, filterInView, activeElement, activeOperator, otherFilters;\n\tconst operators = sanitizeOperators( field );\n\tif ( field.type === ENUMERATION_TYPE && operators.length > 0 ) {\n\t\tfilter = {\n\t\t\tfield: field.id,\n\t\t\toperators,\n\t\t\telements: field.elements || [],\n\t\t};\n\t\tfilterInView = view.filters.find( ( f ) => f.field === filter.field );\n\t\totherFilters = view.filters.filter( ( f ) => f.field !== filter.field );\n\t\tactiveElement = filter.elements.find(\n\t\t\t( element ) => element.value === filterInView?.value\n\t\t);\n\t\tactiveOperator = filterInView?.operator || filter.operators[ 0 ];\n\t}\n\tconst isFilterable = !! filter;\n\n\tif ( ! isSortable && ! isHidable && ! isFilterable ) {\n\t\treturn field.header;\n\t}\n\n\treturn (\n\t\t<DropdownMenu\n\t\t\talign=\"start\"\n\t\t\ttrigger={\n\t\t\t\t<Button\n\t\t\t\t\tsize=\"compact\"\n\t\t\t\t\tclassName=\"dataviews-view-table-header-button\"\n\t\t\t\t\tref={ ref }\n\t\t\t\t\tvariant=\"tertiary\"\n\t\t\t\t>\n\t\t\t\t\t{ field.header }\n\t\t\t\t\t{ isSorted && (\n\t\t\t\t\t\t<span aria-hidden=\"true\">\n\t\t\t\t\t\t\t{ isSorted && sortArrows[ view.sort.direction ] }\n\t\t\t\t\t\t</span>\n\t\t\t\t\t) }\n\t\t\t\t</Button>\n\t\t\t}\n\t\t\tstyle={ { minWidth: '240px' } }\n\t\t>\n\t\t\t<WithSeparators>\n\t\t\t\t{ isSortable && (\n\t\t\t\t\t<DropdownMenuGroup>\n\t\t\t\t\t\t{ Object.entries( SORTING_DIRECTIONS ).map(\n\t\t\t\t\t\t\t( [ direction, info ] ) => {\n\t\t\t\t\t\t\t\tconst isChecked =\n\t\t\t\t\t\t\t\t\tisSorted &&\n\t\t\t\t\t\t\t\t\tview.sort.direction === direction;\n\n\t\t\t\t\t\t\t\tconst value = `${ field.id }-${ direction }`;\n\n\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t<DropdownMenuRadioItem\n\t\t\t\t\t\t\t\t\t\tkey={ value }\n\t\t\t\t\t\t\t\t\t\t// All sorting radio items share the same name, so that\n\t\t\t\t\t\t\t\t\t\t// selecting a sorting option automatically deselects the\n\t\t\t\t\t\t\t\t\t\t// previously selected one, even if it is displayed in\n\t\t\t\t\t\t\t\t\t\t// another submenu. The field and direction are passed via\n\t\t\t\t\t\t\t\t\t\t// the `value` prop.\n\t\t\t\t\t\t\t\t\t\tname=\"view-table-sorting\"\n\t\t\t\t\t\t\t\t\t\tvalue={ value }\n\t\t\t\t\t\t\t\t\t\tchecked={ isChecked }\n\t\t\t\t\t\t\t\t\t\tonChange={ () => {\n\t\t\t\t\t\t\t\t\t\t\tonChangeView( {\n\t\t\t\t\t\t\t\t\t\t\t\t...view,\n\t\t\t\t\t\t\t\t\t\t\t\tsort: {\n\t\t\t\t\t\t\t\t\t\t\t\t\tfield: field.id,\n\t\t\t\t\t\t\t\t\t\t\t\t\tdirection,\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\t\t<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t{ info.label }\n\t\t\t\t\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t</DropdownMenuRadioItem>\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t) }\n\t\t\t\t\t</DropdownMenuGroup>\n\t\t\t\t) }\n\t\t\t\t{ isHidable && (\n\t\t\t\t\t<DropdownMenuItem\n\t\t\t\t\t\tprefix={ <Icon icon={ unseen } /> }\n\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\tonHide( field );\n\t\t\t\t\t\t\tonChangeView( {\n\t\t\t\t\t\t\t\t...view,\n\t\t\t\t\t\t\t\thiddenFields: view.hiddenFields.concat(\n\t\t\t\t\t\t\t\t\tfield.id\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t} }\n\t\t\t\t\t>\n\t\t\t\t\t\t<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t{ __( 'Hide' ) }\n\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t</DropdownMenuItem>\n\t\t\t\t) }\n\t\t\t\t{ isFilterable && (\n\t\t\t\t\t<DropdownMenuGroup>\n\t\t\t\t\t\t<DropdownMenu\n\t\t\t\t\t\t\tkey={ filter.field }\n\t\t\t\t\t\t\ttrigger={\n\t\t\t\t\t\t\t\t<DropdownMenuItem\n\t\t\t\t\t\t\t\t\tprefix={ <Icon icon={ funnel } /> }\n\t\t\t\t\t\t\t\t\tsuffix={\n\t\t\t\t\t\t\t\t\t\tactiveElement && (\n\t\t\t\t\t\t\t\t\t\t\t<span aria-hidden=\"true\">\n\t\t\t\t\t\t\t\t\t\t\t\t{ activeOperator in OPERATORS &&\n\t\t\t\t\t\t\t\t\t\t\t\t\t`${ OPERATORS[ activeOperator ].label } ` }\n\t\t\t\t\t\t\t\t\t\t\t\t{ activeElement?.label }\n\t\t\t\t\t\t\t\t\t\t\t</span>\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<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t{ __( 'Filter by' ) }\n\t\t\t\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t</DropdownMenuItem>\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<WithSeparators>\n\t\t\t\t\t\t\t\t<DropdownMenuGroup>\n\t\t\t\t\t\t\t\t\t{ filter.elements.map( ( element ) => {\n\t\t\t\t\t\t\t\t\t\tconst isActive =\n\t\t\t\t\t\t\t\t\t\t\tactiveElement?.value ===\n\t\t\t\t\t\t\t\t\t\t\telement.value;\n\t\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t\t<DropdownMenuRadioItemCustom\n\t\t\t\t\t\t\t\t\t\t\t\tkey={ element.value }\n\t\t\t\t\t\t\t\t\t\t\t\tname={ `view-table-${ filter.field }` }\n\t\t\t\t\t\t\t\t\t\t\t\tvalue={ element.value }\n\t\t\t\t\t\t\t\t\t\t\t\tchecked={ isActive }\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\tonChangeView( {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t...view,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tpage: 1,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilters: [\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t...otherFilters,\n\t\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\t\t\tfield: filter.field,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\toperator:\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tactiveOperator,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tvalue: isActive\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? undefined\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: element.value,\n\t\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\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\t\t<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t\t\t{ element.label }\n\t\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t\t{ !! element.description && (\n\t\t\t\t\t\t\t\t\t\t\t\t\t<DropdownMenuItemHelpText>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{ element.description }\n\t\t\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuItemHelpText>\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</DropdownMenuRadioItemCustom>\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</DropdownMenuGroup>\n\t\t\t\t\t\t\t\t{ filter.operators.length > 1 && (\n\t\t\t\t\t\t\t\t\t<DropdownMenu\n\t\t\t\t\t\t\t\t\t\ttrigger={\n\t\t\t\t\t\t\t\t\t\t\t<DropdownMenuItem\n\t\t\t\t\t\t\t\t\t\t\t\tsuffix={\n\t\t\t\t\t\t\t\t\t\t\t\t\t<span aria-hidden=\"true\">\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\t\tOPERATORS[\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tactiveOperator\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t]?.label\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</span>\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\t\t<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t\t\t{ __( 'Conditions' ) }\n\t\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuItem>\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\t\t{ Object.entries( OPERATORS ).map(\n\t\t\t\t\t\t\t\t\t\t\t( [\n\t\t\t\t\t\t\t\t\t\t\t\toperator,\n\t\t\t\t\t\t\t\t\t\t\t\t{ label, key },\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<DropdownMenuRadioItem\n\t\t\t\t\t\t\t\t\t\t\t\t\tkey={ key }\n\t\t\t\t\t\t\t\t\t\t\t\t\tname={ `view-table-${ filter.field }-conditions` }\n\t\t\t\t\t\t\t\t\t\t\t\t\tvalue={ operator }\n\t\t\t\t\t\t\t\t\t\t\t\t\tchecked={\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tactiveOperator ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\toperator\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\tonChange={ ( e ) =>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tonChangeView( {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t...view,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tpage: 1,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilters: [\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t...otherFilters,\n\t\t\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\t\t\t\tfield: filter.field,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\toperator:\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\te.target\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t.value,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tvalue: filterInView?.value,\n\t\t\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\t\t],\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\t\t<DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{ label }\n\t\t\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuItemLabel>\n\t\t\t\t\t\t\t\t\t\t\t\t</DropdownMenuRadioItem>\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</DropdownMenu>\n\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t</WithSeparators>\n\t\t\t\t\t\t</DropdownMenu>\n\t\t\t\t\t</DropdownMenuGroup>\n\t\t\t\t) }\n\t\t\t</WithSeparators>\n\t\t</DropdownMenu>\n\t);\n} );\n\nfunction WithSeparators( { children } ) {\n\treturn Children.toArray( children )\n\t\t.filter( Boolean )\n\t\t.map( ( child, i ) => (\n\t\t\t<Fragment key={ i }>\n\t\t\t\t{ i > 0 && <DropdownMenuSeparator /> }\n\t\t\t\t{ child }\n\t\t\t</Fragment>\n\t\t) );\n}\n\nfunction BulkSelectionCheckbox( { selection, onSelectionChange, data } ) {\n\tconst areAllSelected = selection.length === data.length;\n\treturn (\n\t\t<CheckboxControl\n\t\t\tclassName=\"dataviews-view-table-selection-checkbox\"\n\t\t\t__nextHasNoMarginBottom\n\t\t\tchecked={ areAllSelected }\n\t\t\tindeterminate={ ! areAllSelected && selection.length }\n\t\t\tonChange={ () => {\n\t\t\t\tif ( areAllSelected ) {\n\t\t\t\t\tonSelectionChange( [] );\n\t\t\t\t} else {\n\t\t\t\t\tonSelectionChange( data );\n\t\t\t\t}\n\t\t\t} }\n\t\t\tlabel={ areAllSelected ? __( 'Deselect all' ) : __( 'Select all' ) }\n\t\t/>\n\t);\n}\n\nfunction SingleSelectionCheckbox( {\n\tselection,\n\tonSelectionChange,\n\titem,\n\tdata,\n\tgetItemId,\n\tprimaryField,\n} ) {\n\tconst id = getItemId( item );\n\tconst isSelected = selection.includes( id );\n\tlet selectionLabel;\n\tif ( primaryField?.getValue && item ) {\n\t\t// eslint-disable-next-line @wordpress/valid-sprintf\n\t\tselectionLabel = sprintf(\n\t\t\t/* translators: %s: item title. */\n\t\t\tisSelected ? __( 'Deselect item: %s' ) : __( 'Select item: %s' ),\n\t\t\tprimaryField.getValue( { item } )\n\t\t);\n\t} else {\n\t\tselectionLabel = isSelected\n\t\t\t? __( 'Select a new item' )\n\t\t\t: __( 'Deselect item' );\n\t}\n\treturn (\n\t\t<CheckboxControl\n\t\t\tclassName=\"dataviews-view-table-selection-checkbox\"\n\t\t\t__nextHasNoMarginBottom\n\t\t\tchecked={ isSelected }\n\t\t\tlabel={ selectionLabel }\n\t\t\tonChange={ () => {\n\t\t\t\tif ( ! isSelected ) {\n\t\t\t\t\tonSelectionChange(\n\t\t\t\t\t\tdata.filter( ( _item ) => {\n\t\t\t\t\t\t\tconst itemId = getItemId?.( _item );\n\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\titemId === id || selection.includes( itemId )\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t} )\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tonSelectionChange(\n\t\t\t\t\t\tdata.filter( ( _item ) => {\n\t\t\t\t\t\t\tconst itemId = getItemId?.( _item );\n\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\titemId !== id && selection.includes( itemId )\n\t\t\t\t\t\t\t);\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/>\n\t);\n}\n\nfunction ViewTable( {\n\tview,\n\tonChangeView,\n\tfields,\n\tactions,\n\tdata,\n\tgetItemId,\n\tisLoading = false,\n\tdeferredRendering,\n\tselection,\n\tonSelectionChange,\n} ) {\n\tconst hasBulkActions = actions?.some( ( action ) => action.supportsBulk );\n\tconst headerMenuRefs = useRef( new Map() );\n\tconst headerMenuToFocusRef = useRef();\n\tconst [ nextHeaderMenuToFocus, setNextHeaderMenuToFocus ] = useState();\n\n\tuseEffect( () => {\n\t\tif ( headerMenuToFocusRef.current ) {\n\t\t\theaderMenuToFocusRef.current.focus();\n\t\t\theaderMenuToFocusRef.current = undefined;\n\t\t}\n\t} );\n\n\tconst asyncData = useAsyncList( data );\n\tconst tableNoticeId = useId();\n\n\tif ( nextHeaderMenuToFocus ) {\n\t\t// If we need to force focus, we short-circuit rendering here\n\t\t// to prevent any additional work while we handle that.\n\t\t// Clearing out the focus directive is necessary to make sure\n\t\t// future renders don't cause unexpected focus jumps.\n\t\theaderMenuToFocusRef.current = nextHeaderMenuToFocus;\n\t\tsetNextHeaderMenuToFocus();\n\t\treturn;\n\t}\n\n\tconst onHide = ( field ) => {\n\t\tconst hidden = headerMenuRefs.current.get( field.id );\n\t\tconst fallback = headerMenuRefs.current.get( hidden.fallback );\n\t\tsetNextHeaderMenuToFocus( fallback?.node );\n\t};\n\tconst visibleFields = fields.filter(\n\t\t( field ) =>\n\t\t\t! view.hiddenFields.includes( field.id ) &&\n\t\t\t! [ view.layout.mediaField ].includes( field.id )\n\t);\n\tconst usedData = deferredRendering ? asyncData : data;\n\tconst hasData = !! usedData?.length;\n\tconst sortValues = { asc: 'ascending', desc: 'descending' };\n\n\tconst primaryField = fields.find(\n\t\t( field ) => field.id === view.layout.primaryField\n\t);\n\n\treturn (\n\t\t<div className=\"dataviews-view-table-wrapper\">\n\t\t\t<table\n\t\t\t\tclassName=\"dataviews-view-table\"\n\t\t\t\taria-busy={ isLoading }\n\t\t\t\taria-describedby={ tableNoticeId }\n\t\t\t>\n\t\t\t\t<thead>\n\t\t\t\t\t<tr className=\"dataviews-view-table__row\">\n\t\t\t\t\t\t{ hasBulkActions && (\n\t\t\t\t\t\t\t<th\n\t\t\t\t\t\t\t\tclassName=\"dataviews-view-table__checkbox-column\"\n\t\t\t\t\t\t\t\tstyle={ {\n\t\t\t\t\t\t\t\t\twidth: 20,\n\t\t\t\t\t\t\t\t\tminWidth: 20,\n\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\tdata-field-id=\"selection\"\n\t\t\t\t\t\t\t\tscope=\"col\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<BulkSelectionCheckbox\n\t\t\t\t\t\t\t\t\tselection={ selection }\n\t\t\t\t\t\t\t\t\tonSelectionChange={ onSelectionChange }\n\t\t\t\t\t\t\t\t\tdata={ data }\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</th>\n\t\t\t\t\t\t) }\n\t\t\t\t\t\t{ visibleFields.map( ( field, index ) => (\n\t\t\t\t\t\t\t<th\n\t\t\t\t\t\t\t\tkey={ field.id }\n\t\t\t\t\t\t\t\tstyle={ {\n\t\t\t\t\t\t\t\t\twidth: field.width || undefined,\n\t\t\t\t\t\t\t\t\tminWidth: field.minWidth || undefined,\n\t\t\t\t\t\t\t\t\tmaxWidth: field.maxWidth || undefined,\n\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\tdata-field-id={ field.id }\n\t\t\t\t\t\t\t\taria-sort={\n\t\t\t\t\t\t\t\t\tview.sort?.field === field.id &&\n\t\t\t\t\t\t\t\t\tsortValues[ view.sort.direction ]\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tscope=\"col\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<HeaderMenu\n\t\t\t\t\t\t\t\t\tref={ ( node ) => {\n\t\t\t\t\t\t\t\t\t\tif ( node ) {\n\t\t\t\t\t\t\t\t\t\t\theaderMenuRefs.current.set(\n\t\t\t\t\t\t\t\t\t\t\t\tfield.id,\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\tnode,\n\t\t\t\t\t\t\t\t\t\t\t\t\tfallback:\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tvisibleFields[\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tindex > 0\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? index - 1\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: 1\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t]?.id,\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} else {\n\t\t\t\t\t\t\t\t\t\t\theaderMenuRefs.current.delete(\n\t\t\t\t\t\t\t\t\t\t\t\tfield.id\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\tfield={ field }\n\t\t\t\t\t\t\t\t\tview={ view }\n\t\t\t\t\t\t\t\t\tonChangeView={ onChangeView }\n\t\t\t\t\t\t\t\t\tonHide={ onHide }\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</th>\n\t\t\t\t\t\t) ) }\n\t\t\t\t\t\t{ !! actions?.length && (\n\t\t\t\t\t\t\t<th\n\t\t\t\t\t\t\t\tdata-field-id=\"actions\"\n\t\t\t\t\t\t\t\tclassName=\"dataviews-view-table__actions-column\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<span className=\"dataviews-view-table-header\">\n\t\t\t\t\t\t\t\t\t{ __( 'Actions' ) }\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t</th>\n\t\t\t\t\t\t) }\n\t\t\t\t\t</tr>\n\t\t\t\t</thead>\n\t\t\t\t<tbody>\n\t\t\t\t\t{ hasData &&\n\t\t\t\t\t\tusedData.map( ( item, index ) => (\n\t\t\t\t\t\t\t<tr\n\t\t\t\t\t\t\t\tkey={ getItemId( item ) }\n\t\t\t\t\t\t\t\tclassName={ classnames(\n\t\t\t\t\t\t\t\t\t'dataviews-view-table__row',\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t'is-selected': selection.includes(\n\t\t\t\t\t\t\t\t\t\t\tgetItemId( item ) || index\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>\n\t\t\t\t\t\t\t\t{ hasBulkActions && (\n\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\tclassName=\"dataviews-view-table__checkbox-column\"\n\t\t\t\t\t\t\t\t\t\tstyle={ {\n\t\t\t\t\t\t\t\t\t\t\twidth: 20,\n\t\t\t\t\t\t\t\t\t\t\tminWidth: 20,\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\t\t<span className=\"dataviews-view-table__cell-content-wrapper\">\n\t\t\t\t\t\t\t\t\t\t\t<SingleSelectionCheckbox\n\t\t\t\t\t\t\t\t\t\t\t\tid={\n\t\t\t\t\t\t\t\t\t\t\t\t\tgetItemId( item ) || index\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\titem={ item }\n\t\t\t\t\t\t\t\t\t\t\t\tselection={ selection }\n\t\t\t\t\t\t\t\t\t\t\t\tonSelectionChange={\n\t\t\t\t\t\t\t\t\t\t\t\t\tonSelectionChange\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\tgetItemId={ getItemId }\n\t\t\t\t\t\t\t\t\t\t\t\tdata={ data }\n\t\t\t\t\t\t\t\t\t\t\t\tprimaryField={ primaryField }\n\t\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t\t{ visibleFields.map( ( field ) => (\n\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\tkey={ field.id }\n\t\t\t\t\t\t\t\t\t\tstyle={ {\n\t\t\t\t\t\t\t\t\t\t\twidth: field.width || undefined,\n\t\t\t\t\t\t\t\t\t\t\tminWidth:\n\t\t\t\t\t\t\t\t\t\t\t\tfield.minWidth || undefined,\n\t\t\t\t\t\t\t\t\t\t\tmaxWidth:\n\t\t\t\t\t\t\t\t\t\t\t\tfield.maxWidth || undefined,\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\t\t<span\n\t\t\t\t\t\t\t\t\t\t\tclassName={ classnames(\n\t\t\t\t\t\t\t\t\t\t\t\t'dataviews-view-table__cell-content-wrapper',\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\t'dataviews-view-table__primary-field':\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tprimaryField?.id ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tfield.id,\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\t\t{ field.render( {\n\t\t\t\t\t\t\t\t\t\t\t\titem,\n\t\t\t\t\t\t\t\t\t\t\t} ) }\n\t\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t\t) ) }\n\t\t\t\t\t\t\t\t{ !! actions?.length && (\n\t\t\t\t\t\t\t\t\t<td className=\"dataviews-view-table__actions-column\">\n\t\t\t\t\t\t\t\t\t\t<ItemActions\n\t\t\t\t\t\t\t\t\t\t\titem={ item }\n\t\t\t\t\t\t\t\t\t\t\tactions={ actions }\n\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t) ) }\n\t\t\t\t</tbody>\n\t\t\t</table>\n\t\t\t<div\n\t\t\t\tclassName={ classnames( {\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\tid={ tableNoticeId }\n\t\t\t>\n\t\t\t\t{ ! hasData && (\n\t\t\t\t\t<p>{ isLoading ? __( 'Loading…' ) : __( 'No results' ) }</p>\n\t\t\t\t) }\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n\nexport default ViewTable;\n"],"mappings":"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"}
@@ -97,7 +97,7 @@
97
97
  --wp-block-synced-color: #7a00df;
98
98
  --wp-block-synced-color--rgb: 122, 0, 223;
99
99
  }
100
- @media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
100
+ @media (min-resolution: 192dpi) {
101
101
  :root {
102
102
  --wp-admin-border-width-focus: 1.5px;
103
103
  }
@@ -122,6 +122,10 @@
122
122
  max-width: 240px;
123
123
  }
124
124
 
125
+ .dataviews-filters__view-actions.components-h-stack {
126
+ align-items: center;
127
+ }
128
+
125
129
  .dataviews-filters-button {
126
130
  position: relative;
127
131
  }
@@ -160,6 +164,10 @@
160
164
  margin: 32px 0 16px;
161
165
  }
162
166
 
167
+ .dataviews-view-table-wrapper {
168
+ overflow-x: auto;
169
+ }
170
+
163
171
  .dataviews-view-table {
164
172
  width: 100%;
165
173
  text-indent: 0;
@@ -182,12 +190,26 @@
182
190
  .dataviews-view-table td,
183
191
  .dataviews-view-table th {
184
192
  padding: 12px;
185
- min-width: 160px;
193
+ white-space: nowrap;
194
+ }
195
+ @media (min-width: 1440px) {
196
+ .dataviews-view-table td,
197
+ .dataviews-view-table th {
198
+ min-width: 200px;
199
+ }
186
200
  }
187
201
  .dataviews-view-table td[data-field-id=actions],
188
202
  .dataviews-view-table th[data-field-id=actions] {
189
203
  text-align: left;
190
204
  }
205
+ .dataviews-view-table td.dataviews-view-table__checkbox-column,
206
+ .dataviews-view-table th.dataviews-view-table__checkbox-column {
207
+ padding-left: 0;
208
+ }
209
+ .dataviews-view-table td .components-checkbox-control__input-container,
210
+ .dataviews-view-table th .components-checkbox-control__input-container {
211
+ margin: 4px;
212
+ }
191
213
  .dataviews-view-table tr {
192
214
  border-bottom: 1px solid #f0f0f0;
193
215
  }
@@ -211,9 +233,25 @@
211
233
  .dataviews-view-table tr:last-child {
212
234
  border-bottom: 0;
213
235
  }
214
- .dataviews-view-table tr:hover td {
236
+ .dataviews-view-table tr:hover {
215
237
  background-color: #f8f8f8;
216
238
  }
239
+ .dataviews-view-table tr .components-checkbox-control__input {
240
+ opacity: 0;
241
+ }
242
+ .dataviews-view-table tr .components-checkbox-control__input:checked, .dataviews-view-table tr .components-checkbox-control__input:indeterminate, .dataviews-view-table tr .components-checkbox-control__input:focus {
243
+ opacity: 1;
244
+ }
245
+ .dataviews-view-table tr:focus-within .components-checkbox-control__input, .dataviews-view-table tr:hover .components-checkbox-control__input {
246
+ opacity: 1;
247
+ }
248
+ .dataviews-view-table tr.is-selected {
249
+ background-color: rgba(var(--wp-admin-theme-color--rgb), 0.04);
250
+ color: #757575;
251
+ }
252
+ .dataviews-view-table tr.is-selected:hover {
253
+ background-color: rgba(var(--wp-admin-theme-color--rgb), 0.08);
254
+ }
217
255
  .dataviews-view-table thead tr {
218
256
  border: 0;
219
257
  }
@@ -230,6 +268,14 @@
230
268
  font-weight: 500;
231
269
  padding-right: 4px;
232
270
  }
271
+ .dataviews-view-table tbody td {
272
+ vertical-align: top;
273
+ }
274
+ .dataviews-view-table tbody .dataviews-view-table__cell-content-wrapper {
275
+ min-height: 32px;
276
+ display: flex;
277
+ align-items: center;
278
+ }
233
279
  .dataviews-view-table .dataviews-view-table-header-button {
234
280
  padding: 4px 8px;
235
281
  font-size: 11px;
@@ -248,6 +294,50 @@
248
294
  .dataviews-view-table .dataviews-view-table-header {
249
295
  padding-right: 4px;
250
296
  }
297
+ .dataviews-view-table .dataviews-view-table__actions-column {
298
+ width: 1%;
299
+ }
300
+
301
+ .dataviews-view-list__primary-field,
302
+ .dataviews-view-grid__primary-field,
303
+ .dataviews-view-table__primary-field {
304
+ font-size: 13px;
305
+ font-weight: 500;
306
+ color: #1e1e1e;
307
+ text-overflow: ellipsis;
308
+ white-space: nowrap;
309
+ overflow: hidden;
310
+ display: block;
311
+ width: 100%;
312
+ }
313
+ .dataviews-view-list__primary-field a,
314
+ .dataviews-view-grid__primary-field a,
315
+ .dataviews-view-table__primary-field a {
316
+ text-decoration: none;
317
+ color: inherit;
318
+ text-overflow: ellipsis;
319
+ white-space: nowrap;
320
+ overflow: hidden;
321
+ display: block;
322
+ width: 100%;
323
+ }
324
+ .dataviews-view-list__primary-field a:hover,
325
+ .dataviews-view-grid__primary-field a:hover,
326
+ .dataviews-view-table__primary-field a:hover {
327
+ color: #1e1e1e;
328
+ }
329
+ .dataviews-view-list__primary-field button.components-button.is-link,
330
+ .dataviews-view-grid__primary-field button.components-button.is-link,
331
+ .dataviews-view-table__primary-field button.components-button.is-link {
332
+ text-decoration: none;
333
+ color: inherit;
334
+ font-weight: inherit;
335
+ text-overflow: ellipsis;
336
+ white-space: nowrap;
337
+ overflow: hidden;
338
+ display: block;
339
+ width: 100%;
340
+ }
251
341
 
252
342
  .dataviews-view-grid {
253
343
  margin-bottom: 24px;
@@ -264,47 +354,45 @@
264
354
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
265
355
  }
266
356
  }
267
- .dataviews-view-grid .dataviews-view-grid__card .dataviews-view-grid__primary-field .dataviews-view-grid__title-field {
268
- white-space: nowrap;
269
- overflow: hidden;
270
- text-overflow: ellipsis;
271
- display: block;
272
- font-size: 13px;
273
- width: 100%;
357
+ .dataviews-view-grid .dataviews-view-grid__card {
358
+ border-radius: 4px;
359
+ border: 1px solid #e0e0e0;
360
+ height: 100%;
361
+ justify-content: flex-start;
274
362
  }
275
- .dataviews-view-grid .dataviews-view-grid__card .dataviews-view-grid__primary-field .dataviews-view-grid__title-field a,
276
- .dataviews-view-grid .dataviews-view-grid__card .dataviews-view-grid__primary-field button.dataviews-view-grid__title-field {
277
- font-weight: 500;
278
- color: #1e1e1e;
279
- text-decoration: none;
363
+ .dataviews-view-grid .dataviews-view-grid__card .dataviews-view-grid__title-actions {
364
+ padding: 0 4px;
365
+ }
366
+ .dataviews-view-grid .dataviews-view-grid__card .dataviews-view-grid__primary-field {
367
+ min-height: 40px;
280
368
  }
281
369
  .dataviews-view-grid .dataviews-view-grid__media {
282
370
  width: 100%;
283
371
  min-height: 200px;
284
372
  aspect-ratio: 1/1;
285
- box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.1);
286
- border-radius: 4px;
287
- overflow: hidden;
373
+ border-bottom: 1px solid #e0e0e0;
374
+ background-color: #f0f0f0;
375
+ border-radius: 3px 3px 0 0;
288
376
  }
289
- .dataviews-view-grid .dataviews-view-grid__media > * {
290
- -o-object-fit: cover;
291
- object-fit: cover;
377
+ .dataviews-view-grid .dataviews-view-grid__media img {
378
+ object-fit: cover;
292
379
  width: 100%;
293
380
  height: 100%;
294
381
  }
295
382
  .dataviews-view-grid .dataviews-view-grid__primary-field {
296
- min-height: 24px;
383
+ padding: 8px;
297
384
  }
298
385
  .dataviews-view-grid .dataviews-view-grid__fields {
299
386
  position: relative;
300
387
  font-size: 12px;
301
388
  line-height: 16px;
302
389
  }
303
- .dataviews-view-grid .dataviews-view-grid__fields .dataviews-view-grid__field .dataviews-view-grid__field-header {
304
- color: #757575;
390
+ .dataviews-view-grid .dataviews-view-grid__fields:not(:empty) {
391
+ padding: 12px;
392
+ padding-top: 0;
305
393
  }
306
394
  .dataviews-view-grid .dataviews-view-grid__fields .dataviews-view-grid__field .dataviews-view-grid__field-value {
307
- color: #1e1e1e;
395
+ color: #757575;
308
396
  }
309
397
 
310
398
  .dataviews-view-list {
@@ -331,6 +419,7 @@
331
419
  .dataviews-view-list li:not(.is-selected):hover {
332
420
  color: var(--wp-admin-theme-color);
333
421
  }
422
+ .dataviews-view-list li:not(.is-selected):hover .dataviews-view-list__primary-field,
334
423
  .dataviews-view-list li:not(.is-selected):hover .dataviews-view-list__fields {
335
424
  color: var(--wp-admin-theme-color);
336
425
  }
@@ -339,8 +428,10 @@
339
428
  background-color: var(--wp-admin-theme-color);
340
429
  color: #fff;
341
430
  }
431
+ .dataviews-view-list li.is-selected .dataviews-view-list__item-wrapper .dataviews-view-list__primary-field,
342
432
  .dataviews-view-list li.is-selected .dataviews-view-list__item-wrapper .dataviews-view-list__fields,
343
433
  .dataviews-view-list li.is-selected .dataviews-view-list__item-wrapper .components-button,
434
+ .dataviews-view-list li.is-selected:focus-within .dataviews-view-list__item-wrapper .dataviews-view-list__primary-field,
344
435
  .dataviews-view-list li.is-selected:focus-within .dataviews-view-list__item-wrapper .dataviews-view-list__fields,
345
436
  .dataviews-view-list li.is-selected:focus-within .dataviews-view-list__item-wrapper .components-button {
346
437
  color: #fff;
@@ -371,11 +462,18 @@
371
462
  white-space: nowrap;
372
463
  }
373
464
  .dataviews-view-list .dataviews-view-list__media-wrapper {
374
- min-width: 32px;
465
+ width: 32px;
375
466
  height: 32px;
376
467
  border-radius: 4px;
377
468
  overflow: hidden;
378
469
  position: relative;
470
+ flex-shrink: 0;
471
+ background-color: #f0f0f0;
472
+ }
473
+ .dataviews-view-list .dataviews-view-list__media-wrapper img {
474
+ width: 100%;
475
+ height: 100%;
476
+ object-fit: cover;
379
477
  }
380
478
  .dataviews-view-list .dataviews-view-list__media-wrapper::after {
381
479
  content: "";
@@ -404,6 +502,9 @@
404
502
  .dataviews-view-list .dataviews-view-list__fields .dataviews-view-list__field:last-child {
405
503
  margin-left: 0;
406
504
  }
505
+ .dataviews-view-list .dataviews-view-list__fields .dataviews-view-list__field:empty {
506
+ display: none;
507
+ }
407
508
  .dataviews-view-list + .dataviews-pagination {
408
509
  justify-content: space-between;
409
510
  }
@@ -429,7 +530,23 @@
429
530
  padding: 0 32px;
430
531
  }
431
532
 
533
+ .dataviews-view-table-selection-checkbox label {
534
+ position: absolute;
535
+ width: 1px;
536
+ height: 1px;
537
+ padding: 0;
538
+ margin: -1px;
539
+ overflow: hidden;
540
+ clip: rect(0, 0, 0, 0);
541
+ white-space: nowrap;
542
+ border: 0;
543
+ }
544
+
432
545
  .dataviews-filters__custom-menu-radio-item-prefix {
433
546
  display: block;
434
547
  width: 24px;
548
+ }
549
+
550
+ .dataviews-bulk-edit-button.components-button {
551
+ flex-shrink: 0;
435
552
  }