@wordpress/dataviews 4.22.0 → 5.0.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 (343) hide show
  1. package/CHANGELOG.md +39 -0
  2. package/README.md +147 -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 +89 -27
  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/date.js +57 -0
  71. package/build/field-types/date.js.map +1 -0
  72. package/build/field-types/datetime.js +19 -1
  73. package/build/field-types/datetime.js.map +1 -1
  74. package/build/field-types/email.js +60 -0
  75. package/build/field-types/email.js.map +1 -0
  76. package/build/field-types/index.js +42 -1
  77. package/build/field-types/index.js.map +1 -1
  78. package/build/field-types/integer.js +23 -1
  79. package/build/field-types/integer.js.map +1 -1
  80. package/build/field-types/media.js +31 -0
  81. package/build/field-types/media.js.map +1 -0
  82. package/build/field-types/text.js +23 -1
  83. package/build/field-types/text.js.map +1 -1
  84. package/build/filter-and-sort-data-view.js +174 -11
  85. package/build/filter-and-sort-data-view.js.map +1 -1
  86. package/build/normalize-fields.js +72 -11
  87. package/build/normalize-fields.js.map +1 -1
  88. package/build/types.js.map +1 -1
  89. package/build/utils.js +11 -19
  90. package/build/utils.js.map +1 -1
  91. package/build-module/components/dataviews/index.js +74 -40
  92. package/build-module/components/dataviews/index.js.map +1 -1
  93. package/build-module/components/dataviews-context/index.js +16 -2
  94. package/build-module/components/dataviews-context/index.js.map +1 -1
  95. package/build-module/components/dataviews-filters/filter.js +309 -0
  96. package/build-module/components/dataviews-filters/filter.js.map +1 -0
  97. package/build-module/components/dataviews-filters/index.js +22 -21
  98. package/build-module/components/dataviews-filters/index.js.map +1 -1
  99. package/build-module/components/dataviews-filters/input-widget.js +69 -0
  100. package/build-module/components/dataviews-filters/input-widget.js.map +1 -0
  101. package/build-module/components/dataviews-filters/search-widget.js +31 -37
  102. package/build-module/components/dataviews-filters/search-widget.js.map +1 -1
  103. package/build-module/components/dataviews-filters/utils.js +18 -0
  104. package/build-module/components/dataviews-filters/utils.js.map +1 -0
  105. package/build-module/components/dataviews-item-actions/index.js +1 -1
  106. package/build-module/components/dataviews-item-actions/index.js.map +1 -1
  107. package/build-module/components/dataviews-layout/index.js +7 -2
  108. package/build-module/components/dataviews-layout/index.js.map +1 -1
  109. package/build-module/components/dataviews-pagination/index.js +4 -4
  110. package/build-module/components/dataviews-pagination/index.js.map +1 -1
  111. package/build-module/components/dataviews-selection-checkbox/index.js.map +1 -1
  112. package/build-module/components/dataviews-view-config/index.js +9 -20
  113. package/build-module/components/dataviews-view-config/index.js.map +1 -1
  114. package/build-module/constants.js +82 -1
  115. package/build-module/constants.js.map +1 -1
  116. package/build-module/dataform-controls/boolean.js +35 -0
  117. package/build-module/dataform-controls/boolean.js.map +1 -0
  118. package/build-module/dataform-controls/checkbox.js +37 -0
  119. package/build-module/dataform-controls/checkbox.js.map +1 -0
  120. package/build-module/dataform-controls/datetime.js +98 -3
  121. package/build-module/dataform-controls/datetime.js.map +1 -1
  122. package/build-module/dataform-controls/email.js +41 -0
  123. package/build-module/dataform-controls/email.js.map +1 -0
  124. package/build-module/dataform-controls/index.js +9 -1
  125. package/build-module/dataform-controls/index.js.map +1 -1
  126. package/build-module/dataform-controls/integer.js +51 -3
  127. package/build-module/dataform-controls/integer.js.map +1 -1
  128. package/build-module/dataform-controls/select.js +1 -0
  129. package/build-module/dataform-controls/select.js.map +1 -1
  130. package/build-module/dataform-controls/text.js +3 -1
  131. package/build-module/dataform-controls/text.js.map +1 -1
  132. package/build-module/dataform-controls/toggle-group.js +45 -0
  133. package/build-module/dataform-controls/toggle-group.js.map +1 -0
  134. package/build-module/dataforms-layouts/data-form-layout.js +1 -1
  135. package/build-module/dataforms-layouts/data-form-layout.js.map +1 -1
  136. package/build-module/dataforms-layouts/panel/index.js +14 -5
  137. package/build-module/dataforms-layouts/panel/index.js.map +1 -1
  138. package/build-module/dataforms-layouts/regular/index.js +23 -4
  139. package/build-module/dataforms-layouts/regular/index.js.map +1 -1
  140. package/build-module/dataviews-layouts/grid/index.js +90 -29
  141. package/build-module/dataviews-layouts/grid/index.js.map +1 -1
  142. package/build-module/dataviews-layouts/list/index.js +11 -6
  143. package/build-module/dataviews-layouts/list/index.js.map +1 -1
  144. package/build-module/dataviews-layouts/table/column-header-menu.js +9 -7
  145. package/build-module/dataviews-layouts/table/column-header-menu.js.map +1 -1
  146. package/build-module/dataviews-layouts/table/column-primary.js +18 -12
  147. package/build-module/dataviews-layouts/table/column-primary.js.map +1 -1
  148. package/build-module/dataviews-layouts/table/index.js +47 -16
  149. package/build-module/dataviews-layouts/table/index.js.map +1 -1
  150. package/build-module/dataviews-layouts/table/use-is-horizontal-scroll-end.js +58 -0
  151. package/build-module/dataviews-layouts/table/use-is-horizontal-scroll-end.js.map +1 -0
  152. package/build-module/dataviews-layouts/utils/item-click-wrapper.js +71 -0
  153. package/build-module/dataviews-layouts/utils/item-click-wrapper.js.map +1 -0
  154. package/build-module/field-types/array.js +57 -0
  155. package/build-module/field-types/array.js.map +1 -0
  156. package/build-module/field-types/boolean.js +65 -0
  157. package/build-module/field-types/boolean.js.map +1 -0
  158. package/build-module/field-types/date.js +51 -0
  159. package/build-module/field-types/date.js.map +1 -0
  160. package/build-module/field-types/datetime.js +19 -1
  161. package/build-module/field-types/datetime.js.map +1 -1
  162. package/build-module/field-types/email.js +54 -0
  163. package/build-module/field-types/email.js.map +1 -0
  164. package/build-module/field-types/index.js +42 -1
  165. package/build-module/field-types/index.js.map +1 -1
  166. package/build-module/field-types/integer.js +23 -1
  167. package/build-module/field-types/integer.js.map +1 -1
  168. package/build-module/field-types/media.js +25 -0
  169. package/build-module/field-types/media.js.map +1 -0
  170. package/build-module/field-types/text.js +23 -1
  171. package/build-module/field-types/text.js.map +1 -1
  172. package/build-module/filter-and-sort-data-view.js +175 -12
  173. package/build-module/filter-and-sort-data-view.js.map +1 -1
  174. package/build-module/normalize-fields.js +72 -11
  175. package/build-module/normalize-fields.js.map +1 -1
  176. package/build-module/types.js.map +1 -1
  177. package/build-module/utils.js +10 -17
  178. package/build-module/utils.js.map +1 -1
  179. package/build-style/style-rtl.css +315 -13
  180. package/build-style/style.css +315 -13
  181. package/build-types/components/dataform/stories/index.story.d.ts.map +1 -1
  182. package/build-types/components/dataviews/index.d.ts +24 -3
  183. package/build-types/components/dataviews/index.d.ts.map +1 -1
  184. package/build-types/components/dataviews/stories/fixtures.d.ts +10 -1
  185. package/build-types/components/dataviews/stories/fixtures.d.ts.map +1 -1
  186. package/build-types/components/dataviews/stories/index.story.d.ts +23 -4
  187. package/build-types/components/dataviews/stories/index.story.d.ts.map +1 -1
  188. package/build-types/components/dataviews-context/index.d.ts +14 -1
  189. package/build-types/components/dataviews-context/index.d.ts.map +1 -1
  190. package/build-types/components/dataviews-filters/filter.d.ts +15 -0
  191. package/build-types/components/dataviews-filters/filter.d.ts.map +1 -0
  192. package/build-types/components/dataviews-filters/index.d.ts +3 -8
  193. package/build-types/components/dataviews-filters/index.d.ts.map +1 -1
  194. package/build-types/components/dataviews-filters/input-widget.d.ts +13 -0
  195. package/build-types/components/dataviews-filters/input-widget.d.ts.map +1 -0
  196. package/build-types/components/dataviews-filters/search-widget.d.ts +4 -5
  197. package/build-types/components/dataviews-filters/search-widget.d.ts.map +1 -1
  198. package/build-types/components/dataviews-filters/utils.d.ts +6 -0
  199. package/build-types/components/dataviews-filters/utils.d.ts.map +1 -0
  200. package/build-types/components/dataviews-layout/index.d.ts +5 -1
  201. package/build-types/components/dataviews-layout/index.d.ts.map +1 -1
  202. package/build-types/components/dataviews-pagination/index.d.ts +1 -1
  203. package/build-types/components/dataviews-pagination/index.d.ts.map +1 -1
  204. package/build-types/components/dataviews-selection-checkbox/index.d.ts +2 -2
  205. package/build-types/components/dataviews-selection-checkbox/index.d.ts.map +1 -1
  206. package/build-types/components/dataviews-view-config/index.d.ts +3 -4
  207. package/build-types/components/dataviews-view-config/index.d.ts.map +1 -1
  208. package/build-types/components/stories/index.story.d.ts +63 -0
  209. package/build-types/components/stories/index.story.d.ts.map +1 -0
  210. package/build-types/constants.d.ts +20 -3
  211. package/build-types/constants.d.ts.map +1 -1
  212. package/build-types/dataform-controls/boolean.d.ts +6 -0
  213. package/build-types/dataform-controls/boolean.d.ts.map +1 -0
  214. package/build-types/dataform-controls/checkbox.d.ts +6 -0
  215. package/build-types/dataform-controls/checkbox.d.ts.map +1 -0
  216. package/build-types/dataform-controls/datetime.d.ts +1 -1
  217. package/build-types/dataform-controls/datetime.d.ts.map +1 -1
  218. package/build-types/dataform-controls/email.d.ts +6 -0
  219. package/build-types/dataform-controls/email.d.ts.map +1 -0
  220. package/build-types/dataform-controls/index.d.ts +1 -1
  221. package/build-types/dataform-controls/index.d.ts.map +1 -1
  222. package/build-types/dataform-controls/integer.d.ts +1 -4
  223. package/build-types/dataform-controls/integer.d.ts.map +1 -1
  224. package/build-types/dataform-controls/select.d.ts.map +1 -1
  225. package/build-types/dataform-controls/text.d.ts.map +1 -1
  226. package/build-types/dataform-controls/toggle-group.d.ts +6 -0
  227. package/build-types/dataform-controls/toggle-group.d.ts.map +1 -0
  228. package/build-types/dataforms-layouts/panel/index.d.ts.map +1 -1
  229. package/build-types/dataforms-layouts/regular/index.d.ts.map +1 -1
  230. package/build-types/dataviews-layouts/grid/index.d.ts +2 -1
  231. package/build-types/dataviews-layouts/grid/index.d.ts.map +1 -1
  232. package/build-types/dataviews-layouts/index.d.ts +3 -3
  233. package/build-types/dataviews-layouts/list/index.d.ts.map +1 -1
  234. package/build-types/dataviews-layouts/table/column-header-menu.d.ts.map +1 -1
  235. package/build-types/dataviews-layouts/table/column-primary.d.ts +8 -1
  236. package/build-types/dataviews-layouts/table/column-primary.d.ts.map +1 -1
  237. package/build-types/dataviews-layouts/table/index.d.ts +1 -1
  238. package/build-types/dataviews-layouts/table/index.d.ts.map +1 -1
  239. package/build-types/dataviews-layouts/table/use-is-horizontal-scroll-end.d.ts +19 -0
  240. package/build-types/dataviews-layouts/table/use-is-horizontal-scroll-end.d.ts.map +1 -0
  241. package/build-types/dataviews-layouts/utils/item-click-wrapper.d.ts +15 -0
  242. package/build-types/dataviews-layouts/utils/item-click-wrapper.d.ts.map +1 -0
  243. package/build-types/field-types/array.d.ts +7 -0
  244. package/build-types/field-types/array.d.ts.map +1 -0
  245. package/build-types/field-types/boolean.d.ts +19 -0
  246. package/build-types/field-types/boolean.d.ts.map +1 -0
  247. package/build-types/field-types/date.d.ts +16 -0
  248. package/build-types/field-types/date.d.ts.map +1 -0
  249. package/build-types/field-types/datetime.d.ts +7 -1
  250. package/build-types/field-types/datetime.d.ts.map +1 -1
  251. package/build-types/field-types/email.d.ts +19 -0
  252. package/build-types/field-types/email.d.ts.map +1 -0
  253. package/build-types/field-types/index.d.ts +2 -10
  254. package/build-types/field-types/index.d.ts.map +1 -1
  255. package/build-types/field-types/integer.d.ts +7 -1
  256. package/build-types/field-types/integer.d.ts.map +1 -1
  257. package/build-types/field-types/media.d.ts +16 -0
  258. package/build-types/field-types/media.d.ts.map +1 -0
  259. package/build-types/field-types/text.d.ts +7 -1
  260. package/build-types/field-types/text.d.ts.map +1 -1
  261. package/build-types/filter-and-sort-data-view.d.ts.map +1 -1
  262. package/build-types/normalize-fields.d.ts.map +1 -1
  263. package/build-types/types.d.ts +74 -8
  264. package/build-types/types.d.ts.map +1 -1
  265. package/build-types/utils.d.ts +5 -2
  266. package/build-types/utils.d.ts.map +1 -1
  267. package/build-wp/index.js +3299 -1182
  268. package/package.json +18 -12
  269. package/src/components/dataform/stories/index.story.tsx +41 -20
  270. package/src/components/dataviews/index.tsx +108 -43
  271. package/src/components/dataviews/stories/fixtures.tsx +135 -69
  272. package/src/components/dataviews/stories/index.story.tsx +265 -7
  273. package/src/components/dataviews/stories/style.css +24 -3
  274. package/src/components/dataviews/style.scss +27 -0
  275. package/src/components/dataviews-context/index.ts +30 -2
  276. package/src/components/dataviews-filters/filter.tsx +603 -0
  277. package/src/components/dataviews-filters/index.tsx +23 -29
  278. package/src/components/dataviews-filters/input-widget.tsx +91 -0
  279. package/src/components/dataviews-filters/search-widget.tsx +51 -48
  280. package/src/components/dataviews-filters/style.scss +117 -14
  281. package/src/components/dataviews-filters/utils.ts +25 -0
  282. package/src/components/dataviews-item-actions/index.tsx +1 -1
  283. package/src/components/dataviews-layout/index.tsx +8 -1
  284. package/src/components/dataviews-pagination/index.tsx +4 -4
  285. package/src/components/dataviews-selection-checkbox/index.tsx +2 -2
  286. package/src/components/dataviews-view-config/index.tsx +10 -18
  287. package/src/components/stories/index.story.tsx +372 -0
  288. package/src/constants.ts +116 -1
  289. package/src/dataform-controls/boolean.tsx +30 -0
  290. package/src/dataform-controls/checkbox.tsx +31 -0
  291. package/src/dataform-controls/datetime.tsx +106 -2
  292. package/src/dataform-controls/email.tsx +42 -0
  293. package/src/dataform-controls/index.tsx +8 -0
  294. package/src/dataform-controls/integer.tsx +75 -1
  295. package/src/dataform-controls/select.tsx +1 -0
  296. package/src/dataform-controls/style.scss +5 -0
  297. package/src/dataform-controls/text.tsx +2 -1
  298. package/src/dataform-controls/toggle-group.tsx +59 -0
  299. package/src/dataforms-layouts/data-form-layout.tsx +1 -1
  300. package/src/dataforms-layouts/panel/index.tsx +19 -7
  301. package/src/dataforms-layouts/panel/style.scss +8 -1
  302. package/src/dataforms-layouts/regular/index.tsx +50 -17
  303. package/src/dataforms-layouts/regular/style.scss +4 -1
  304. package/src/dataviews-layouts/grid/index.tsx +180 -68
  305. package/src/dataviews-layouts/grid/style.scss +8 -0
  306. package/src/dataviews-layouts/list/index.tsx +12 -5
  307. package/src/dataviews-layouts/table/column-header-menu.tsx +10 -8
  308. package/src/dataviews-layouts/table/column-primary.tsx +26 -13
  309. package/src/dataviews-layouts/table/index.tsx +74 -10
  310. package/src/dataviews-layouts/table/style.scss +37 -1
  311. package/src/dataviews-layouts/table/use-is-horizontal-scroll-end.ts +82 -0
  312. package/src/dataviews-layouts/utils/item-click-wrapper.tsx +93 -0
  313. package/src/field-types/array.tsx +75 -0
  314. package/src/field-types/boolean.tsx +66 -0
  315. package/src/field-types/date.ts +56 -0
  316. package/src/field-types/datetime.tsx +46 -2
  317. package/src/field-types/email.tsx +79 -0
  318. package/src/field-types/index.tsx +50 -3
  319. package/src/field-types/integer.tsx +53 -2
  320. package/src/field-types/media.tsx +28 -0
  321. package/src/field-types/text.tsx +41 -2
  322. package/src/filter-and-sort-data-view.ts +270 -10
  323. package/src/normalize-fields.ts +116 -13
  324. package/src/test/dataviews.tsx +20 -2
  325. package/src/test/filter-and-sort-data-view.js +601 -25
  326. package/src/test/normalize-fields.ts +155 -0
  327. package/src/types.ts +112 -9
  328. package/src/utils.ts +10 -33
  329. package/tsconfig.json +2 -0
  330. package/tsconfig.tsbuildinfo +1 -1
  331. package/build/components/dataviews-filters/filter-summary.js.map +0 -1
  332. package/build/dataviews-layouts/utils/get-clickable-item-props.js +0 -36
  333. package/build/dataviews-layouts/utils/get-clickable-item-props.js.map +0 -1
  334. package/build-module/components/dataviews-filters/filter-summary.js +0 -218
  335. package/build-module/components/dataviews-filters/filter-summary.js.map +0 -1
  336. package/build-module/dataviews-layouts/utils/get-clickable-item-props.js +0 -30
  337. package/build-module/dataviews-layouts/utils/get-clickable-item-props.js.map +0 -1
  338. package/build-types/components/dataviews-filters/filter-summary.d.ts +0 -14
  339. package/build-types/components/dataviews-filters/filter-summary.d.ts.map +0 -1
  340. package/build-types/dataviews-layouts/utils/get-clickable-item-props.d.ts +0 -19
  341. package/build-types/dataviews-layouts/utils/get-clickable-item-props.d.ts.map +0 -1
  342. package/src/components/dataviews-filters/filter-summary.tsx +0 -338
  343. package/src/dataviews-layouts/utils/get-clickable-item-props.ts +0 -39
@@ -1,338 +0,0 @@
1
- /**
2
- * External dependencies
3
- */
4
- import clsx from 'clsx';
5
- import type { RefObject } from 'react';
6
-
7
- /**
8
- * WordPress dependencies
9
- */
10
- import {
11
- Dropdown,
12
- __experimentalVStack as VStack,
13
- __experimentalHStack as HStack,
14
- FlexItem,
15
- SelectControl,
16
- Tooltip,
17
- Icon,
18
- } from '@wordpress/components';
19
- import { __, sprintf } from '@wordpress/i18n';
20
- import { useRef, createInterpolateElement } from '@wordpress/element';
21
- import { closeSmall } from '@wordpress/icons';
22
-
23
- const ENTER = 'Enter';
24
- const SPACE = ' ';
25
-
26
- /**
27
- * Internal dependencies
28
- */
29
- import SearchWidget from './search-widget';
30
- import {
31
- OPERATORS,
32
- OPERATOR_IS,
33
- OPERATOR_IS_NOT,
34
- OPERATOR_IS_ANY,
35
- OPERATOR_IS_NONE,
36
- OPERATOR_IS_ALL,
37
- OPERATOR_IS_NOT_ALL,
38
- } from '../../constants';
39
- import type {
40
- Filter,
41
- NormalizedFilter,
42
- Operator,
43
- Option,
44
- View,
45
- } from '../../types';
46
-
47
- interface FilterTextProps {
48
- activeElements: Option[];
49
- filterInView?: Filter;
50
- filter: NormalizedFilter;
51
- }
52
-
53
- interface OperatorSelectorProps {
54
- filter: NormalizedFilter;
55
- view: View;
56
- onChangeView: ( view: View ) => void;
57
- }
58
-
59
- interface FilterSummaryProps extends OperatorSelectorProps {
60
- addFilterRef: RefObject< HTMLButtonElement >;
61
- openedFilter: string | null;
62
- }
63
-
64
- const FilterText = ( {
65
- activeElements,
66
- filterInView,
67
- filter,
68
- }: FilterTextProps ) => {
69
- if ( activeElements === undefined || activeElements.length === 0 ) {
70
- return filter.name;
71
- }
72
-
73
- const filterTextWrappers = {
74
- Name: <span className="dataviews-filters__summary-filter-text-name" />,
75
- Value: (
76
- <span className="dataviews-filters__summary-filter-text-value" />
77
- ),
78
- };
79
-
80
- if ( filterInView?.operator === OPERATOR_IS_ANY ) {
81
- return createInterpolateElement(
82
- sprintf(
83
- /* translators: 1: Filter name. 3: Filter value. e.g.: "Author is any: Admin, Editor". */
84
- __( '<Name>%1$s is any: </Name><Value>%2$s</Value>' ),
85
- filter.name,
86
- activeElements.map( ( element ) => element.label ).join( ', ' )
87
- ),
88
- filterTextWrappers
89
- );
90
- }
91
-
92
- if ( filterInView?.operator === OPERATOR_IS_NONE ) {
93
- return createInterpolateElement(
94
- sprintf(
95
- /* translators: 1: Filter name. 3: Filter value. e.g.: "Author is none: Admin, Editor". */
96
- __( '<Name>%1$s is none: </Name><Value>%2$s</Value>' ),
97
- filter.name,
98
- activeElements.map( ( element ) => element.label ).join( ', ' )
99
- ),
100
- filterTextWrappers
101
- );
102
- }
103
-
104
- if ( filterInView?.operator === OPERATOR_IS_ALL ) {
105
- return createInterpolateElement(
106
- sprintf(
107
- /* translators: 1: Filter name. 3: Filter value. e.g.: "Author is all: Admin, Editor". */
108
- __( '<Name>%1$s is all: </Name><Value>%2$s</Value>' ),
109
- filter.name,
110
- activeElements.map( ( element ) => element.label ).join( ', ' )
111
- ),
112
- filterTextWrappers
113
- );
114
- }
115
-
116
- if ( filterInView?.operator === OPERATOR_IS_NOT_ALL ) {
117
- return createInterpolateElement(
118
- sprintf(
119
- /* translators: 1: Filter name. 3: Filter value. e.g.: "Author is not all: Admin, Editor". */
120
- __( '<Name>%1$s is not all: </Name><Value>%2$s</Value>' ),
121
- filter.name,
122
- activeElements.map( ( element ) => element.label ).join( ', ' )
123
- ),
124
- filterTextWrappers
125
- );
126
- }
127
-
128
- if ( filterInView?.operator === OPERATOR_IS ) {
129
- return createInterpolateElement(
130
- sprintf(
131
- /* translators: 1: Filter name. 3: Filter value. e.g.: "Author is: Admin". */
132
- __( '<Name>%1$s is: </Name><Value>%2$s</Value>' ),
133
- filter.name,
134
- activeElements[ 0 ].label
135
- ),
136
- filterTextWrappers
137
- );
138
- }
139
-
140
- if ( filterInView?.operator === OPERATOR_IS_NOT ) {
141
- return createInterpolateElement(
142
- sprintf(
143
- /* translators: 1: Filter name. 3: Filter value. e.g.: "Author is not: Admin". */
144
- __( '<Name>%1$s is not: </Name><Value>%2$s</Value>' ),
145
- filter.name,
146
- activeElements[ 0 ].label
147
- ),
148
- filterTextWrappers
149
- );
150
- }
151
-
152
- return sprintf(
153
- /* translators: 1: Filter name e.g.: "Unknown status for Author". */
154
- __( 'Unknown status for %1$s' ),
155
- filter.name
156
- );
157
- };
158
-
159
- function OperatorSelector( {
160
- filter,
161
- view,
162
- onChangeView,
163
- }: OperatorSelectorProps ) {
164
- const operatorOptions = filter.operators?.map( ( operator ) => ( {
165
- value: operator,
166
- label: OPERATORS[ operator ]?.label,
167
- } ) );
168
- const currentFilter = view.filters?.find(
169
- ( _filter ) => _filter.field === filter.field
170
- );
171
- const value = currentFilter?.operator || filter.operators[ 0 ];
172
- return (
173
- operatorOptions.length > 1 && (
174
- <HStack
175
- spacing={ 2 }
176
- justify="flex-start"
177
- className="dataviews-filters__summary-operators-container"
178
- >
179
- <FlexItem className="dataviews-filters__summary-operators-filter-name">
180
- { filter.name }
181
- </FlexItem>
182
-
183
- <SelectControl
184
- label={ __( 'Conditions' ) }
185
- value={ value }
186
- options={ operatorOptions }
187
- onChange={ ( newValue ) => {
188
- const operator = newValue as Operator;
189
- const newFilters = currentFilter
190
- ? [
191
- ...( view.filters ?? [] ).map(
192
- ( _filter ) => {
193
- if (
194
- _filter.field === filter.field
195
- ) {
196
- return {
197
- ..._filter,
198
- operator,
199
- };
200
- }
201
- return _filter;
202
- }
203
- ),
204
- ]
205
- : [
206
- ...( view.filters ?? [] ),
207
- {
208
- field: filter.field,
209
- operator,
210
- value: undefined,
211
- },
212
- ];
213
- onChangeView( {
214
- ...view,
215
- page: 1,
216
- filters: newFilters,
217
- } );
218
- } }
219
- size="small"
220
- __nextHasNoMarginBottom
221
- hideLabelFromVision
222
- />
223
- </HStack>
224
- )
225
- );
226
- }
227
-
228
- export default function FilterSummary( {
229
- addFilterRef,
230
- openedFilter,
231
- ...commonProps
232
- }: FilterSummaryProps ) {
233
- const toggleRef = useRef< HTMLDivElement >( null );
234
- const { filter, view, onChangeView } = commonProps;
235
- const filterInView = view.filters?.find(
236
- ( f ) => f.field === filter.field
237
- );
238
- const activeElements = filter.elements.filter( ( element ) => {
239
- if ( filter.singleSelection ) {
240
- return element.value === filterInView?.value;
241
- }
242
- return filterInView?.value?.includes( element.value );
243
- } );
244
- const isPrimary = filter.isPrimary;
245
- const hasValues = filterInView?.value !== undefined;
246
- const canResetOrRemove = ! isPrimary || hasValues;
247
- return (
248
- <Dropdown
249
- defaultOpen={ openedFilter === filter.field }
250
- contentClassName="dataviews-filters__summary-popover"
251
- popoverProps={ { placement: 'bottom-start', role: 'dialog' } }
252
- onClose={ () => {
253
- toggleRef.current?.focus();
254
- } }
255
- renderToggle={ ( { isOpen, onToggle } ) => (
256
- <div className="dataviews-filters__summary-chip-container">
257
- <Tooltip
258
- text={ sprintf(
259
- /* translators: 1: Filter name. */
260
- __( 'Filter by: %1$s' ),
261
- filter.name.toLowerCase()
262
- ) }
263
- placement="top"
264
- >
265
- <div
266
- className={ clsx(
267
- 'dataviews-filters__summary-chip',
268
- {
269
- 'has-reset': canResetOrRemove,
270
- 'has-values': hasValues,
271
- }
272
- ) }
273
- role="button"
274
- tabIndex={ 0 }
275
- onClick={ onToggle }
276
- onKeyDown={ ( event ) => {
277
- if ( [ ENTER, SPACE ].includes( event.key ) ) {
278
- onToggle();
279
- event.preventDefault();
280
- }
281
- } }
282
- aria-pressed={ isOpen }
283
- aria-expanded={ isOpen }
284
- ref={ toggleRef }
285
- >
286
- <FilterText
287
- activeElements={ activeElements }
288
- filterInView={ filterInView }
289
- filter={ filter }
290
- />
291
- </div>
292
- </Tooltip>
293
- { canResetOrRemove && (
294
- <Tooltip
295
- text={ isPrimary ? __( 'Reset' ) : __( 'Remove' ) }
296
- placement="top"
297
- >
298
- <button
299
- className={ clsx(
300
- 'dataviews-filters__summary-chip-remove',
301
- { 'has-values': hasValues }
302
- ) }
303
- onClick={ () => {
304
- onChangeView( {
305
- ...view,
306
- page: 1,
307
- filters: view.filters?.filter(
308
- ( _filter ) =>
309
- _filter.field !== filter.field
310
- ),
311
- } );
312
- // If the filter is not primary and can be removed, it will be added
313
- // back to the available filters from `Add filter` component.
314
- if ( ! isPrimary ) {
315
- addFilterRef.current?.focus();
316
- } else {
317
- // If is primary, focus the toggle button.
318
- toggleRef.current?.focus();
319
- }
320
- } }
321
- >
322
- <Icon icon={ closeSmall } />
323
- </button>
324
- </Tooltip>
325
- ) }
326
- </div>
327
- ) }
328
- renderContent={ () => {
329
- return (
330
- <VStack spacing={ 0 } justify="flex-start">
331
- <OperatorSelector { ...commonProps } />
332
- <SearchWidget { ...commonProps } />
333
- </VStack>
334
- );
335
- } }
336
- />
337
- );
338
- }
@@ -1,39 +0,0 @@
1
- export default function getClickableItemProps< Item >( {
2
- item,
3
- isItemClickable,
4
- onClickItem,
5
- className,
6
- }: {
7
- item: Item;
8
- isItemClickable: ( item: Item ) => boolean;
9
- onClickItem?: ( item: Item ) => void;
10
- className?: string;
11
- } ) {
12
- if ( ! isItemClickable( item ) || ! onClickItem ) {
13
- return { className };
14
- }
15
-
16
- return {
17
- className: className
18
- ? `${ className } ${ className }--clickable`
19
- : undefined,
20
- role: 'button',
21
- tabIndex: 0,
22
- onClick: ( event: React.MouseEvent ) => {
23
- // Prevents onChangeSelection from triggering.
24
- event.stopPropagation();
25
- onClickItem( item );
26
- },
27
- onKeyDown: ( event: React.KeyboardEvent ) => {
28
- if (
29
- event.key === 'Enter' ||
30
- event.key === '' ||
31
- event.key === ' '
32
- ) {
33
- // Prevents onChangeSelection from triggering.
34
- event.stopPropagation();
35
- onClickItem( item );
36
- }
37
- },
38
- };
39
- }