@wordpress/dataviews 4.22.0 → 5.0.1-next.719a03cbe.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 (335) hide show
  1. package/CHANGELOG.md +39 -0
  2. package/README.md +146 -32
  3. package/build/components/dataviews/index.js +71 -37
  4. package/build/components/dataviews/index.js.map +1 -1
  5. package/build/components/dataviews-context/index.js +15 -1
  6. package/build/components/dataviews-context/index.js.map +1 -1
  7. package/build/components/dataviews-filters/{filter-summary.js → filter.js} +108 -17
  8. package/build/components/dataviews-filters/filter.js.map +1 -0
  9. package/build/components/dataviews-filters/index.js +21 -20
  10. package/build/components/dataviews-filters/index.js.map +1 -1
  11. package/build/components/dataviews-filters/input-widget.js +76 -0
  12. package/build/components/dataviews-filters/input-widget.js.map +1 -0
  13. package/build/components/dataviews-filters/search-widget.js +33 -39
  14. package/build/components/dataviews-filters/search-widget.js.map +1 -1
  15. package/build/components/dataviews-filters/utils.js +25 -0
  16. package/build/components/dataviews-filters/utils.js.map +1 -0
  17. package/build/components/dataviews-item-actions/index.js +1 -1
  18. package/build/components/dataviews-item-actions/index.js.map +1 -1
  19. package/build/components/dataviews-layout/index.js +7 -2
  20. package/build/components/dataviews-layout/index.js.map +1 -1
  21. package/build/components/dataviews-pagination/index.js +4 -3
  22. package/build/components/dataviews-pagination/index.js.map +1 -1
  23. package/build/components/dataviews-selection-checkbox/index.js.map +1 -1
  24. package/build/components/dataviews-view-config/index.js +10 -19
  25. package/build/components/dataviews-view-config/index.js.map +1 -1
  26. package/build/constants.js +83 -2
  27. package/build/constants.js.map +1 -1
  28. package/build/dataform-controls/boolean.js +42 -0
  29. package/build/dataform-controls/boolean.js.map +1 -0
  30. package/build/dataform-controls/checkbox.js +44 -0
  31. package/build/dataform-controls/checkbox.js.map +1 -0
  32. package/build/dataform-controls/datetime.js +96 -2
  33. package/build/dataform-controls/datetime.js.map +1 -1
  34. package/build/dataform-controls/email.js +48 -0
  35. package/build/dataform-controls/email.js.map +1 -0
  36. package/build/dataform-controls/index.js +9 -1
  37. package/build/dataform-controls/index.js.map +1 -1
  38. package/build/dataform-controls/integer.js +49 -1
  39. package/build/dataform-controls/integer.js.map +1 -1
  40. package/build/dataform-controls/select.js +1 -0
  41. package/build/dataform-controls/select.js.map +1 -1
  42. package/build/dataform-controls/text.js +3 -1
  43. package/build/dataform-controls/text.js.map +1 -1
  44. package/build/dataform-controls/toggle-group.js +52 -0
  45. package/build/dataform-controls/toggle-group.js.map +1 -0
  46. package/build/dataforms-layouts/data-form-layout.js +1 -1
  47. package/build/dataforms-layouts/data-form-layout.js.map +1 -1
  48. package/build/dataforms-layouts/panel/index.js +14 -5
  49. package/build/dataforms-layouts/panel/index.js.map +1 -1
  50. package/build/dataforms-layouts/regular/index.js +23 -4
  51. package/build/dataforms-layouts/regular/index.js.map +1 -1
  52. package/build/dataviews-layouts/grid/index.js +31 -25
  53. package/build/dataviews-layouts/grid/index.js.map +1 -1
  54. package/build/dataviews-layouts/list/index.js +11 -6
  55. package/build/dataviews-layouts/list/index.js.map +1 -1
  56. package/build/dataviews-layouts/table/column-header-menu.js +9 -7
  57. package/build/dataviews-layouts/table/column-header-menu.js.map +1 -1
  58. package/build/dataviews-layouts/table/column-primary.js +18 -13
  59. package/build/dataviews-layouts/table/column-primary.js.map +1 -1
  60. package/build/dataviews-layouts/table/index.js +46 -14
  61. package/build/dataviews-layouts/table/index.js.map +1 -1
  62. package/build/dataviews-layouts/table/use-is-horizontal-scroll-end.js +65 -0
  63. package/build/dataviews-layouts/table/use-is-horizontal-scroll-end.js.map +1 -0
  64. package/build/dataviews-layouts/utils/item-click-wrapper.js +77 -0
  65. package/build/dataviews-layouts/utils/item-click-wrapper.js.map +1 -0
  66. package/build/field-types/array.js +62 -0
  67. package/build/field-types/array.js.map +1 -0
  68. package/build/field-types/boolean.js +71 -0
  69. package/build/field-types/boolean.js.map +1 -0
  70. package/build/field-types/datetime.js +19 -1
  71. package/build/field-types/datetime.js.map +1 -1
  72. package/build/field-types/email.js +60 -0
  73. package/build/field-types/email.js.map +1 -0
  74. package/build/field-types/index.js +38 -1
  75. package/build/field-types/index.js.map +1 -1
  76. package/build/field-types/integer.js +23 -1
  77. package/build/field-types/integer.js.map +1 -1
  78. package/build/field-types/media.js +31 -0
  79. package/build/field-types/media.js.map +1 -0
  80. package/build/field-types/text.js +23 -1
  81. package/build/field-types/text.js.map +1 -1
  82. package/build/filter-and-sort-data-view.js +152 -1
  83. package/build/filter-and-sort-data-view.js.map +1 -1
  84. package/build/normalize-fields.js +72 -11
  85. package/build/normalize-fields.js.map +1 -1
  86. package/build/types.js.map +1 -1
  87. package/build/utils.js +11 -19
  88. package/build/utils.js.map +1 -1
  89. package/build-module/components/dataviews/index.js +74 -40
  90. package/build-module/components/dataviews/index.js.map +1 -1
  91. package/build-module/components/dataviews-context/index.js +16 -2
  92. package/build-module/components/dataviews-context/index.js.map +1 -1
  93. package/build-module/components/dataviews-filters/filter.js +309 -0
  94. package/build-module/components/dataviews-filters/filter.js.map +1 -0
  95. package/build-module/components/dataviews-filters/index.js +22 -21
  96. package/build-module/components/dataviews-filters/index.js.map +1 -1
  97. package/build-module/components/dataviews-filters/input-widget.js +69 -0
  98. package/build-module/components/dataviews-filters/input-widget.js.map +1 -0
  99. package/build-module/components/dataviews-filters/search-widget.js +31 -37
  100. package/build-module/components/dataviews-filters/search-widget.js.map +1 -1
  101. package/build-module/components/dataviews-filters/utils.js +18 -0
  102. package/build-module/components/dataviews-filters/utils.js.map +1 -0
  103. package/build-module/components/dataviews-item-actions/index.js +1 -1
  104. package/build-module/components/dataviews-item-actions/index.js.map +1 -1
  105. package/build-module/components/dataviews-layout/index.js +7 -2
  106. package/build-module/components/dataviews-layout/index.js.map +1 -1
  107. package/build-module/components/dataviews-pagination/index.js +4 -4
  108. package/build-module/components/dataviews-pagination/index.js.map +1 -1
  109. package/build-module/components/dataviews-selection-checkbox/index.js.map +1 -1
  110. package/build-module/components/dataviews-view-config/index.js +9 -20
  111. package/build-module/components/dataviews-view-config/index.js.map +1 -1
  112. package/build-module/constants.js +82 -1
  113. package/build-module/constants.js.map +1 -1
  114. package/build-module/dataform-controls/boolean.js +35 -0
  115. package/build-module/dataform-controls/boolean.js.map +1 -0
  116. package/build-module/dataform-controls/checkbox.js +37 -0
  117. package/build-module/dataform-controls/checkbox.js.map +1 -0
  118. package/build-module/dataform-controls/datetime.js +98 -3
  119. package/build-module/dataform-controls/datetime.js.map +1 -1
  120. package/build-module/dataform-controls/email.js +41 -0
  121. package/build-module/dataform-controls/email.js.map +1 -0
  122. package/build-module/dataform-controls/index.js +9 -1
  123. package/build-module/dataform-controls/index.js.map +1 -1
  124. package/build-module/dataform-controls/integer.js +51 -3
  125. package/build-module/dataform-controls/integer.js.map +1 -1
  126. package/build-module/dataform-controls/select.js +1 -0
  127. package/build-module/dataform-controls/select.js.map +1 -1
  128. package/build-module/dataform-controls/text.js +3 -1
  129. package/build-module/dataform-controls/text.js.map +1 -1
  130. package/build-module/dataform-controls/toggle-group.js +45 -0
  131. package/build-module/dataform-controls/toggle-group.js.map +1 -0
  132. package/build-module/dataforms-layouts/data-form-layout.js +1 -1
  133. package/build-module/dataforms-layouts/data-form-layout.js.map +1 -1
  134. package/build-module/dataforms-layouts/panel/index.js +14 -5
  135. package/build-module/dataforms-layouts/panel/index.js.map +1 -1
  136. package/build-module/dataforms-layouts/regular/index.js +23 -4
  137. package/build-module/dataforms-layouts/regular/index.js.map +1 -1
  138. package/build-module/dataviews-layouts/grid/index.js +31 -26
  139. package/build-module/dataviews-layouts/grid/index.js.map +1 -1
  140. package/build-module/dataviews-layouts/list/index.js +11 -6
  141. package/build-module/dataviews-layouts/list/index.js.map +1 -1
  142. package/build-module/dataviews-layouts/table/column-header-menu.js +9 -7
  143. package/build-module/dataviews-layouts/table/column-header-menu.js.map +1 -1
  144. package/build-module/dataviews-layouts/table/column-primary.js +18 -12
  145. package/build-module/dataviews-layouts/table/column-primary.js.map +1 -1
  146. package/build-module/dataviews-layouts/table/index.js +47 -16
  147. package/build-module/dataviews-layouts/table/index.js.map +1 -1
  148. package/build-module/dataviews-layouts/table/use-is-horizontal-scroll-end.js +58 -0
  149. package/build-module/dataviews-layouts/table/use-is-horizontal-scroll-end.js.map +1 -0
  150. package/build-module/dataviews-layouts/utils/item-click-wrapper.js +71 -0
  151. package/build-module/dataviews-layouts/utils/item-click-wrapper.js.map +1 -0
  152. package/build-module/field-types/array.js +57 -0
  153. package/build-module/field-types/array.js.map +1 -0
  154. package/build-module/field-types/boolean.js +65 -0
  155. package/build-module/field-types/boolean.js.map +1 -0
  156. package/build-module/field-types/datetime.js +19 -1
  157. package/build-module/field-types/datetime.js.map +1 -1
  158. package/build-module/field-types/email.js +54 -0
  159. package/build-module/field-types/email.js.map +1 -0
  160. package/build-module/field-types/index.js +38 -1
  161. package/build-module/field-types/index.js.map +1 -1
  162. package/build-module/field-types/integer.js +23 -1
  163. package/build-module/field-types/integer.js.map +1 -1
  164. package/build-module/field-types/media.js +25 -0
  165. package/build-module/field-types/media.js.map +1 -0
  166. package/build-module/field-types/text.js +23 -1
  167. package/build-module/field-types/text.js.map +1 -1
  168. package/build-module/filter-and-sort-data-view.js +153 -2
  169. package/build-module/filter-and-sort-data-view.js.map +1 -1
  170. package/build-module/normalize-fields.js +72 -11
  171. package/build-module/normalize-fields.js.map +1 -1
  172. package/build-module/types.js.map +1 -1
  173. package/build-module/utils.js +10 -17
  174. package/build-module/utils.js.map +1 -1
  175. package/build-style/style-rtl.css +307 -13
  176. package/build-style/style.css +307 -13
  177. package/build-types/components/dataform/stories/index.story.d.ts.map +1 -1
  178. package/build-types/components/dataviews/index.d.ts +24 -3
  179. package/build-types/components/dataviews/index.d.ts.map +1 -1
  180. package/build-types/components/dataviews/stories/fixtures.d.ts +9 -1
  181. package/build-types/components/dataviews/stories/fixtures.d.ts.map +1 -1
  182. package/build-types/components/dataviews/stories/index.story.d.ts +22 -4
  183. package/build-types/components/dataviews/stories/index.story.d.ts.map +1 -1
  184. package/build-types/components/dataviews-context/index.d.ts +14 -1
  185. package/build-types/components/dataviews-context/index.d.ts.map +1 -1
  186. package/build-types/components/dataviews-filters/filter.d.ts +15 -0
  187. package/build-types/components/dataviews-filters/filter.d.ts.map +1 -0
  188. package/build-types/components/dataviews-filters/index.d.ts +3 -8
  189. package/build-types/components/dataviews-filters/index.d.ts.map +1 -1
  190. package/build-types/components/dataviews-filters/input-widget.d.ts +13 -0
  191. package/build-types/components/dataviews-filters/input-widget.d.ts.map +1 -0
  192. package/build-types/components/dataviews-filters/search-widget.d.ts +4 -5
  193. package/build-types/components/dataviews-filters/search-widget.d.ts.map +1 -1
  194. package/build-types/components/dataviews-filters/utils.d.ts +6 -0
  195. package/build-types/components/dataviews-filters/utils.d.ts.map +1 -0
  196. package/build-types/components/dataviews-layout/index.d.ts +5 -1
  197. package/build-types/components/dataviews-layout/index.d.ts.map +1 -1
  198. package/build-types/components/dataviews-pagination/index.d.ts +1 -1
  199. package/build-types/components/dataviews-pagination/index.d.ts.map +1 -1
  200. package/build-types/components/dataviews-selection-checkbox/index.d.ts +2 -2
  201. package/build-types/components/dataviews-selection-checkbox/index.d.ts.map +1 -1
  202. package/build-types/components/dataviews-view-config/index.d.ts +3 -4
  203. package/build-types/components/dataviews-view-config/index.d.ts.map +1 -1
  204. package/build-types/components/stories/index.story.d.ts +59 -0
  205. package/build-types/components/stories/index.story.d.ts.map +1 -0
  206. package/build-types/constants.d.ts +20 -3
  207. package/build-types/constants.d.ts.map +1 -1
  208. package/build-types/dataform-controls/boolean.d.ts +6 -0
  209. package/build-types/dataform-controls/boolean.d.ts.map +1 -0
  210. package/build-types/dataform-controls/checkbox.d.ts +6 -0
  211. package/build-types/dataform-controls/checkbox.d.ts.map +1 -0
  212. package/build-types/dataform-controls/datetime.d.ts +1 -1
  213. package/build-types/dataform-controls/datetime.d.ts.map +1 -1
  214. package/build-types/dataform-controls/email.d.ts +6 -0
  215. package/build-types/dataform-controls/email.d.ts.map +1 -0
  216. package/build-types/dataform-controls/index.d.ts +1 -1
  217. package/build-types/dataform-controls/index.d.ts.map +1 -1
  218. package/build-types/dataform-controls/integer.d.ts +1 -4
  219. package/build-types/dataform-controls/integer.d.ts.map +1 -1
  220. package/build-types/dataform-controls/select.d.ts.map +1 -1
  221. package/build-types/dataform-controls/text.d.ts.map +1 -1
  222. package/build-types/dataform-controls/toggle-group.d.ts +6 -0
  223. package/build-types/dataform-controls/toggle-group.d.ts.map +1 -0
  224. package/build-types/dataforms-layouts/panel/index.d.ts.map +1 -1
  225. package/build-types/dataforms-layouts/regular/index.d.ts.map +1 -1
  226. package/build-types/dataviews-layouts/grid/index.d.ts +2 -1
  227. package/build-types/dataviews-layouts/grid/index.d.ts.map +1 -1
  228. package/build-types/dataviews-layouts/index.d.ts +3 -3
  229. package/build-types/dataviews-layouts/list/index.d.ts.map +1 -1
  230. package/build-types/dataviews-layouts/table/column-header-menu.d.ts.map +1 -1
  231. package/build-types/dataviews-layouts/table/column-primary.d.ts +8 -1
  232. package/build-types/dataviews-layouts/table/column-primary.d.ts.map +1 -1
  233. package/build-types/dataviews-layouts/table/index.d.ts +1 -1
  234. package/build-types/dataviews-layouts/table/index.d.ts.map +1 -1
  235. package/build-types/dataviews-layouts/table/use-is-horizontal-scroll-end.d.ts +19 -0
  236. package/build-types/dataviews-layouts/table/use-is-horizontal-scroll-end.d.ts.map +1 -0
  237. package/build-types/dataviews-layouts/utils/item-click-wrapper.d.ts +15 -0
  238. package/build-types/dataviews-layouts/utils/item-click-wrapper.d.ts.map +1 -0
  239. package/build-types/field-types/array.d.ts +7 -0
  240. package/build-types/field-types/array.d.ts.map +1 -0
  241. package/build-types/field-types/boolean.d.ts +19 -0
  242. package/build-types/field-types/boolean.d.ts.map +1 -0
  243. package/build-types/field-types/datetime.d.ts +7 -1
  244. package/build-types/field-types/datetime.d.ts.map +1 -1
  245. package/build-types/field-types/email.d.ts +19 -0
  246. package/build-types/field-types/email.d.ts.map +1 -0
  247. package/build-types/field-types/index.d.ts +2 -10
  248. package/build-types/field-types/index.d.ts.map +1 -1
  249. package/build-types/field-types/integer.d.ts +7 -1
  250. package/build-types/field-types/integer.d.ts.map +1 -1
  251. package/build-types/field-types/media.d.ts +16 -0
  252. package/build-types/field-types/media.d.ts.map +1 -0
  253. package/build-types/field-types/text.d.ts +7 -1
  254. package/build-types/field-types/text.d.ts.map +1 -1
  255. package/build-types/filter-and-sort-data-view.d.ts.map +1 -1
  256. package/build-types/normalize-fields.d.ts.map +1 -1
  257. package/build-types/types.d.ts +70 -8
  258. package/build-types/types.d.ts.map +1 -1
  259. package/build-types/utils.d.ts +5 -2
  260. package/build-types/utils.d.ts.map +1 -1
  261. package/build-wp/index.js +2545 -994
  262. package/package.json +18 -12
  263. package/src/components/dataform/stories/index.story.tsx +41 -20
  264. package/src/components/dataviews/index.tsx +108 -43
  265. package/src/components/dataviews/stories/fixtures.tsx +58 -13
  266. package/src/components/dataviews/stories/index.story.tsx +228 -7
  267. package/src/components/dataviews/stories/style.css +24 -3
  268. package/src/components/dataviews/style.scss +27 -0
  269. package/src/components/dataviews-context/index.ts +30 -2
  270. package/src/components/dataviews-filters/filter.tsx +603 -0
  271. package/src/components/dataviews-filters/index.tsx +23 -29
  272. package/src/components/dataviews-filters/input-widget.tsx +91 -0
  273. package/src/components/dataviews-filters/search-widget.tsx +51 -48
  274. package/src/components/dataviews-filters/style.scss +117 -14
  275. package/src/components/dataviews-filters/utils.ts +25 -0
  276. package/src/components/dataviews-item-actions/index.tsx +1 -1
  277. package/src/components/dataviews-layout/index.tsx +8 -1
  278. package/src/components/dataviews-pagination/index.tsx +4 -4
  279. package/src/components/dataviews-selection-checkbox/index.tsx +2 -2
  280. package/src/components/dataviews-view-config/index.tsx +10 -18
  281. package/src/components/stories/index.story.tsx +351 -0
  282. package/src/constants.ts +116 -1
  283. package/src/dataform-controls/boolean.tsx +30 -0
  284. package/src/dataform-controls/checkbox.tsx +31 -0
  285. package/src/dataform-controls/datetime.tsx +106 -2
  286. package/src/dataform-controls/email.tsx +42 -0
  287. package/src/dataform-controls/index.tsx +8 -0
  288. package/src/dataform-controls/integer.tsx +75 -1
  289. package/src/dataform-controls/select.tsx +1 -0
  290. package/src/dataform-controls/style.scss +5 -0
  291. package/src/dataform-controls/text.tsx +2 -1
  292. package/src/dataform-controls/toggle-group.tsx +59 -0
  293. package/src/dataforms-layouts/data-form-layout.tsx +1 -1
  294. package/src/dataforms-layouts/panel/index.tsx +19 -7
  295. package/src/dataforms-layouts/panel/style.scss +8 -1
  296. package/src/dataforms-layouts/regular/index.tsx +50 -17
  297. package/src/dataforms-layouts/regular/style.scss +4 -1
  298. package/src/dataviews-layouts/grid/index.tsx +47 -26
  299. package/src/dataviews-layouts/list/index.tsx +12 -5
  300. package/src/dataviews-layouts/table/column-header-menu.tsx +10 -8
  301. package/src/dataviews-layouts/table/column-primary.tsx +26 -13
  302. package/src/dataviews-layouts/table/index.tsx +74 -10
  303. package/src/dataviews-layouts/table/style.scss +37 -1
  304. package/src/dataviews-layouts/table/use-is-horizontal-scroll-end.ts +82 -0
  305. package/src/dataviews-layouts/utils/item-click-wrapper.tsx +93 -0
  306. package/src/field-types/array.tsx +75 -0
  307. package/src/field-types/boolean.tsx +66 -0
  308. package/src/field-types/datetime.tsx +46 -2
  309. package/src/field-types/email.tsx +79 -0
  310. package/src/field-types/index.tsx +45 -3
  311. package/src/field-types/integer.tsx +53 -2
  312. package/src/field-types/media.tsx +28 -0
  313. package/src/field-types/text.tsx +41 -2
  314. package/src/filter-and-sort-data-view.ts +243 -1
  315. package/src/normalize-fields.ts +116 -13
  316. package/src/test/dataviews.tsx +20 -2
  317. package/src/test/filter-and-sort-data-view.js +507 -0
  318. package/src/test/normalize-fields.ts +155 -0
  319. package/src/types.ts +106 -9
  320. package/src/utils.ts +10 -33
  321. package/tsconfig.json +2 -0
  322. package/tsconfig.tsbuildinfo +1 -1
  323. package/build/components/dataviews-filters/filter-summary.js.map +0 -1
  324. package/build/dataviews-layouts/utils/get-clickable-item-props.js +0 -36
  325. package/build/dataviews-layouts/utils/get-clickable-item-props.js.map +0 -1
  326. package/build-module/components/dataviews-filters/filter-summary.js +0 -218
  327. package/build-module/components/dataviews-filters/filter-summary.js.map +0 -1
  328. package/build-module/dataviews-layouts/utils/get-clickable-item-props.js +0 -30
  329. package/build-module/dataviews-layouts/utils/get-clickable-item-props.js.map +0 -1
  330. package/build-types/components/dataviews-filters/filter-summary.d.ts +0 -14
  331. package/build-types/components/dataviews-filters/filter-summary.d.ts.map +0 -1
  332. package/build-types/dataviews-layouts/utils/get-clickable-item-props.d.ts +0 -19
  333. package/build-types/dataviews-layouts/utils/get-clickable-item-props.d.ts.map +0 -1
  334. package/src/components/dataviews-filters/filter-summary.tsx +0 -338
  335. package/src/dataviews-layouts/utils/get-clickable-item-props.ts +0 -39
@@ -1,13 +1,39 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import type { Meta } from '@storybook/react';
5
+
1
6
  /**
2
7
  * WordPress dependencies
3
8
  */
4
- import { useState, useMemo } from '@wordpress/element';
9
+ import {
10
+ useState,
11
+ useMemo,
12
+ createInterpolateElement,
13
+ } from '@wordpress/element';
14
+ import {
15
+ Card,
16
+ CardHeader,
17
+ CardBody,
18
+ __experimentalGrid as Grid,
19
+ __experimentalHeading as Heading,
20
+ __experimentalText as Text,
21
+ __experimentalHStack as HStack,
22
+ __experimentalVStack as VStack,
23
+ } from '@wordpress/components';
24
+ import { __, _n } from '@wordpress/i18n';
5
25
 
6
26
  /**
7
27
  * Internal dependencies
8
28
  */
9
29
  import DataViews from '../index';
10
- import { DEFAULT_VIEW, actions, data, fields } from './fixtures';
30
+ import {
31
+ DEFAULT_VIEW,
32
+ actions,
33
+ data,
34
+ fields,
35
+ type SpaceObject,
36
+ } from './fixtures';
11
37
  import { LAYOUT_GRID, LAYOUT_LIST, LAYOUT_TABLE } from '../../../constants';
12
38
  import { filterSortAndPaginate } from '../../../filter-and-sort-data-view';
13
39
  import type { View } from '../../../types';
@@ -17,7 +43,8 @@ import './style.css';
17
43
  const meta = {
18
44
  title: 'DataViews/DataViews',
19
45
  component: DataViews,
20
- };
46
+ } as Meta< typeof DataViews >;
47
+
21
48
  export default meta;
22
49
 
23
50
  const defaultLayouts = {
@@ -46,10 +73,17 @@ export const Default = () => {
46
73
  fields={ fields }
47
74
  onChangeView={ setView }
48
75
  actions={ actions }
49
- onClickItem={ ( item ) => {
50
- // eslint-disable-next-line no-alert
51
- alert( 'Clicked: ' + item.title );
52
- } }
76
+ renderItemLink={ ( { item, ...props }: { item: SpaceObject } ) => (
77
+ <button
78
+ style={ { background: 'none', border: 'none', padding: 0 } }
79
+ onClick={ ( e ) => {
80
+ e.stopPropagation();
81
+ // eslint-disable-next-line no-alert
82
+ alert( 'Clicked: ' + item.title );
83
+ } }
84
+ { ...props }
85
+ />
86
+ ) }
53
87
  isItemClickable={ () => true }
54
88
  defaultLayouts={ defaultLayouts }
55
89
  />
@@ -105,3 +139,190 @@ export const FieldsNoSortableNoHidable = () => {
105
139
  />
106
140
  );
107
141
  };
142
+
143
+ /**
144
+ * Custom composition example
145
+ */
146
+ function PlanetOverview( { planets }: { planets: SpaceObject[] } ) {
147
+ const moons = planets.reduce( ( sum, item ) => sum + item.satellites, 0 );
148
+
149
+ return (
150
+ <>
151
+ <Heading className="free-composition-heading" level={ 2 }>
152
+ { __( 'Solar System numbers' ) }
153
+ </Heading>
154
+ <Grid
155
+ templateColumns="repeat(auto-fit, minmax(330px, 1fr))"
156
+ align="flex-start"
157
+ className="free-composition-header"
158
+ >
159
+ <Card variant="secondary">
160
+ <CardBody>
161
+ <VStack>
162
+ <Text size={ 18 } as="p">
163
+ { createInterpolateElement(
164
+ _n(
165
+ '<PlanetsNumber /> planet',
166
+ '<PlanetsNumber /> planets',
167
+ planets.length
168
+ ),
169
+ {
170
+ PlanetsNumber: (
171
+ <strong>{ planets.length } </strong>
172
+ ),
173
+ }
174
+ ) }
175
+ </Text>
176
+
177
+ <Text size={ 18 } as="p">
178
+ { createInterpolateElement(
179
+ _n(
180
+ '<SatellitesNumber /> moon',
181
+ '<SatellitesNumber /> moons',
182
+ moons
183
+ ),
184
+ {
185
+ SatellitesNumber: (
186
+ <strong>{ moons } </strong>
187
+ ),
188
+ }
189
+ ) }
190
+ </Text>
191
+ </VStack>
192
+ </CardBody>
193
+ </Card>
194
+
195
+ <VStack>
196
+ <HStack justify="start">
197
+ <DataViews.FiltersToggle />
198
+ <DataViews.Search label={ __( 'moons by planet' ) } />
199
+ </HStack>
200
+ <DataViews.Filters />
201
+ </VStack>
202
+
203
+ <VStack>
204
+ <HStack justify="end">
205
+ <DataViews.Pagination />
206
+ <DataViews.ViewConfig />
207
+ <DataViews.LayoutSwitcher />
208
+ </HStack>
209
+
210
+ <DataViews.BulkActionToolbar />
211
+ </VStack>
212
+ </Grid>
213
+
214
+ <DataViews.Layout className="free-composition-dataviews-layout" />
215
+ </>
216
+ );
217
+ }
218
+
219
+ /**
220
+ * This is a basic example of using the DataViews component in
221
+ * a free composition mode.
222
+ *
223
+ * Unlike the default usage where DataViews renders its own UI,
224
+ * here we use it purely to provide context and handle data-related logic.
225
+ *
226
+ * The UI is fully custom and composed externally via the
227
+ * `PlanetOverview` component.
228
+ *
229
+ * In future iterations, this story will showcase more advanced compositions
230
+ * using built-in subcomponents like <Search />, filters,
231
+ * or pagination controls.
232
+ */
233
+ export const FreeComposition = () => {
234
+ const [ view, setView ] = useState< View >( {
235
+ ...DEFAULT_VIEW,
236
+ fields: [ 'categories' ],
237
+ titleField: 'title',
238
+ descriptionField: 'description',
239
+ mediaField: 'image',
240
+ } );
241
+
242
+ const { data: processedData, paginationInfo } = useMemo( () => {
243
+ return filterSortAndPaginate( data, view, fields );
244
+ }, [ view ] );
245
+
246
+ const planets = processedData.filter( ( item ) =>
247
+ item.categories.includes( 'Planet' )
248
+ );
249
+
250
+ return (
251
+ <div className="free-composition">
252
+ <DataViews
253
+ getItemId={ ( item ) => item.id.toString() }
254
+ paginationInfo={ paginationInfo }
255
+ data={ processedData }
256
+ view={ view }
257
+ fields={ fields }
258
+ actions={ actions }
259
+ onChangeView={ setView }
260
+ defaultLayouts={ {
261
+ table: {},
262
+ grid: {},
263
+ } }
264
+ >
265
+ <PlanetOverview planets={ planets } />
266
+ </DataViews>
267
+ </div>
268
+ );
269
+ };
270
+
271
+ export const WithCard = () => {
272
+ const [ view, setView ] = useState< View >( {
273
+ ...DEFAULT_VIEW,
274
+ fields: [ 'categories' ],
275
+ titleField: 'title',
276
+ descriptionField: 'description',
277
+ mediaField: 'image',
278
+ } );
279
+ const { data: shownData, paginationInfo } = useMemo( () => {
280
+ return filterSortAndPaginate( data, view, fields );
281
+ }, [ view ] );
282
+ return (
283
+ <Card>
284
+ <CardHeader>Header</CardHeader>
285
+ <CardBody>
286
+ <DataViews
287
+ getItemId={ ( item ) => item.id.toString() }
288
+ paginationInfo={ paginationInfo }
289
+ data={ shownData }
290
+ view={ view }
291
+ fields={ fields }
292
+ onChangeView={ setView }
293
+ actions={ actions.filter(
294
+ ( action ) => ! action.supportsBulk
295
+ ) }
296
+ defaultLayouts={ defaultLayouts }
297
+ />
298
+ </CardBody>
299
+ </Card>
300
+ );
301
+ };
302
+
303
+ export const CustomPerPageSizes = () => {
304
+ const [ view, setView ] = useState< View >( {
305
+ ...DEFAULT_VIEW,
306
+ fields: [ 'categories' ],
307
+ titleField: 'title',
308
+ descriptionField: 'description',
309
+ mediaField: 'image',
310
+ perPage: 3,
311
+ } );
312
+ const { data: shownData, paginationInfo } = useMemo( () => {
313
+ return filterSortAndPaginate( data, view, fields );
314
+ }, [ view ] );
315
+ return (
316
+ <DataViews
317
+ getItemId={ ( item ) => item.id.toString() }
318
+ paginationInfo={ paginationInfo }
319
+ data={ shownData }
320
+ view={ view }
321
+ fields={ fields }
322
+ onChangeView={ setView }
323
+ actions={ actions.filter( ( action ) => ! action.supportsBulk ) }
324
+ defaultLayouts={ defaultLayouts }
325
+ perPageSizes={ [ 3, 6, 12, 24 ] }
326
+ />
327
+ );
328
+ };
@@ -1,4 +1,25 @@
1
1
  .theme-field-description {
2
- text-wrap: balance;
3
- text-wrap: pretty;
4
- }
2
+ text-wrap: balance;
3
+ text-wrap: pretty;
4
+ }
5
+
6
+ .free-composition {
7
+ height: 600px;
8
+ overflow: auto;
9
+ }
10
+
11
+ .free-composition-heading,
12
+ .free-composition-header {
13
+ padding: 16px 48px;
14
+ }
15
+
16
+ .free-composition-heading {
17
+ position: sticky;
18
+ top: 0;
19
+ z-index: 2;
20
+ background-color: #fff;
21
+ }
22
+
23
+ .free-composition-dataviews-layout thead {
24
+ inset-block-start: 67px;
25
+ }
@@ -96,3 +96,30 @@
96
96
  }
97
97
  @include link-reset();
98
98
  }
99
+
100
+ /**
101
+ * Applying a consistent 24px padding when DataViews are placed within cards.
102
+ */
103
+ .components-card__body:has(> .dataviews-wrapper) {
104
+ padding: $grid-unit-10 0 0;
105
+ overflow: hidden; // Prevent cells with white backgrounds overflowing the card
106
+
107
+ .dataviews__view-actions,
108
+ .dataviews-filters__container,
109
+ .dataviews-footer,
110
+ .dataviews-view-grid,
111
+ .dataviews-loading,
112
+ .dataviews-no-results {
113
+ padding-inline: $grid-unit-30;
114
+ }
115
+
116
+ .dataviews-view-table tr td:first-child,
117
+ .dataviews-view-table tr th:first-child {
118
+ padding-inline-start: $grid-unit-30;
119
+ }
120
+
121
+ .dataviews-view-table tr td:last-child,
122
+ .dataviews-view-table tr th:last-child {
123
+ padding-inline-end: $grid-unit-30;
124
+ }
125
+ }
@@ -1,12 +1,23 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import type { ComponentProps, ReactElement } from 'react';
5
+
1
6
  /**
2
7
  * WordPress dependencies
3
8
  */
4
- import { createContext } from '@wordpress/element';
9
+ import { createContext, createRef } from '@wordpress/element';
5
10
 
6
11
  /**
7
12
  * Internal dependencies
8
13
  */
9
- import type { View, Action, NormalizedField } from '../../types';
14
+ import type {
15
+ View,
16
+ Action,
17
+ NormalizedField,
18
+ SupportedLayouts,
19
+ NormalizedFilter,
20
+ } from '../../types';
10
21
  import type { SetSelection } from '../../private-types';
11
22
  import { LAYOUT_TABLE } from '../../constants';
12
23
 
@@ -28,8 +39,19 @@ type DataViewsContextType< Item > = {
28
39
  getItemId: ( item: Item ) => string;
29
40
  getItemLevel?: ( item: Item ) => number;
30
41
  onClickItem?: ( item: Item ) => void;
42
+ renderItemLink?: (
43
+ props: {
44
+ item: Item;
45
+ } & ComponentProps< 'a' >
46
+ ) => ReactElement;
31
47
  isItemClickable: ( item: Item ) => boolean;
32
48
  containerWidth: number;
49
+ containerRef: React.MutableRefObject< HTMLDivElement | null >;
50
+ defaultLayouts: SupportedLayouts;
51
+ filters: NormalizedFilter[];
52
+ isShowingFilter: boolean;
53
+ setIsShowingFilter: ( value: boolean ) => void;
54
+ perPageSizes?: [ number, number, number, number ];
33
55
  };
34
56
 
35
57
  const DataViewsContext = createContext< DataViewsContextType< any > >( {
@@ -47,7 +69,13 @@ const DataViewsContext = createContext< DataViewsContextType< any > >( {
47
69
  openedFilter: null,
48
70
  getItemId: ( item ) => item.id,
49
71
  isItemClickable: () => true,
72
+ renderItemLink: undefined,
50
73
  containerWidth: 0,
74
+ containerRef: createRef(),
75
+ defaultLayouts: { list: {}, grid: {}, table: {} },
76
+ filters: [],
77
+ isShowingFilter: false,
78
+ setIsShowingFilter: () => {},
51
79
  } );
52
80
 
53
81
  export default DataViewsContext;