@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.
- package/CHANGELOG.md +2 -0
- package/build/bulk-actions.js +143 -0
- package/build/bulk-actions.js.map +1 -0
- package/build/dataviews.js +15 -1
- package/build/dataviews.js.map +1 -1
- package/build/item-actions.js +4 -4
- package/build/item-actions.js.map +1 -1
- package/build/pagination.js +2 -2
- package/build/pagination.js.map +1 -1
- package/build/view-actions.js +3 -2
- package/build/view-actions.js.map +1 -1
- package/build/view-grid.js +11 -8
- package/build/view-grid.js.map +1 -1
- package/build/view-list.js +13 -1
- package/build/view-list.js.map +1 -1
- package/build/view-table.js +116 -9
- package/build/view-table.js.map +1 -1
- package/build-module/bulk-actions.js +136 -0
- package/build-module/bulk-actions.js.map +1 -0
- package/build-module/dataviews.js +17 -3
- package/build-module/dataviews.js.map +1 -1
- package/build-module/item-actions.js +4 -4
- package/build-module/item-actions.js.map +1 -1
- package/build-module/pagination.js +2 -2
- package/build-module/pagination.js.map +1 -1
- package/build-module/view-actions.js +4 -3
- package/build-module/view-actions.js.map +1 -1
- package/build-module/view-grid.js +12 -9
- package/build-module/view-grid.js.map +1 -1
- package/build-module/view-list.js +13 -1
- package/build-module/view-list.js.map +1 -1
- package/build-module/view-table.js +120 -13
- package/build-module/view-table.js.map +1 -1
- package/build-style/style-rtl.css +143 -26
- package/build-style/style.css +143 -26
- package/package.json +11 -11
- package/src/bulk-actions.js +187 -0
- package/src/dataviews.js +29 -2
- package/src/item-actions.js +4 -7
- package/src/pagination.js +2 -6
- package/src/style.scss +152 -29
- package/src/view-actions.js +8 -14
- package/src/view-grid.js +14 -12
- package/src/view-list.js +20 -1
- 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
|
|
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
|
|
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
|
-
|
|
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",
|
|
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
|
-
|
|
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",
|
|
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:
|
|
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 (
|
|
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
|
-
|
|
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
|
|
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
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
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-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
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
|
-
|
|
286
|
-
|
|
287
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
304
|
-
|
|
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: #
|
|
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
|
-
|
|
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
|
}
|