@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,3 +1,8 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import { subDays, subYears } from 'date-fns';
5
+
1
6
  /**
2
7
  * Internal dependencies
3
8
  */
@@ -44,13 +49,13 @@ describe( 'filters', () => {
44
49
  const { data: result } = filterSortAndPaginate(
45
50
  data,
46
51
  {
47
- search: 'photo',
52
+ search: 'earth',
48
53
  filters: [],
49
54
  },
50
55
  fields
51
56
  );
52
- expect( result ).toHaveLength( 1 );
53
- expect( result[ 0 ].description ).toBe( 'NASA photo' );
57
+ expect( result ).toHaveLength( 2 );
58
+ expect( result[ 0 ].description ).toBe( "Earth's satellite" );
54
59
  } );
55
60
 
56
61
  it( 'should perform case-insensitive and accent-insensitive search', () => {
@@ -100,9 +105,9 @@ describe( 'filters', () => {
100
105
  fields
101
106
  );
102
107
  expect( result ).toHaveLength( 9 );
103
- expect( result[ 0 ].title ).toBe( 'Apollo' );
104
- expect( result[ 1 ].title ).toBe( 'Space' );
105
- expect( result[ 2 ].title ).toBe( 'NASA' );
108
+ expect( result[ 0 ].title ).toBe( 'Moon' );
109
+ expect( result[ 1 ].title ).toBe( 'Io' );
110
+ expect( result[ 2 ].title ).toBe( 'Europa' );
106
111
  expect( result[ 3 ].title ).toBe( 'Mercury' );
107
112
  expect( result[ 4 ].title ).toBe( 'Venus' );
108
113
  expect( result[ 5 ].title ).toBe( 'Earth' );
@@ -145,9 +150,9 @@ describe( 'filters', () => {
145
150
  fields
146
151
  );
147
152
  expect( result ).toHaveLength( 3 );
148
- expect( result[ 0 ].title ).toBe( 'Apollo' );
149
- expect( result[ 1 ].title ).toBe( 'Space' );
150
- expect( result[ 2 ].title ).toBe( 'NASA' );
153
+ expect( result[ 0 ].title ).toBe( 'Moon' );
154
+ expect( result[ 1 ].title ).toBe( 'Io' );
155
+ expect( result[ 2 ].title ).toBe( 'Europa' );
151
156
  } );
152
157
 
153
158
  it( 'should search using IS ANY filter for ARRAY values', () => {
@@ -158,15 +163,15 @@ describe( 'filters', () => {
158
163
  {
159
164
  field: 'categories',
160
165
  operator: 'isAny',
161
- value: [ 'NASA' ],
166
+ value: [ 'Earth' ],
162
167
  },
163
168
  ],
164
169
  },
165
170
  fields
166
171
  );
167
172
  expect( result ).toHaveLength( 2 );
168
- expect( result[ 0 ].title ).toBe( 'Apollo' );
169
- expect( result[ 1 ].title ).toBe( 'NASA' );
173
+ expect( result[ 0 ].title ).toBe( 'Moon' );
174
+ expect( result[ 1 ].title ).toBe( 'Earth' );
170
175
  } );
171
176
 
172
177
  it( 'should search using IS NONE filter for ARRAY values', () => {
@@ -177,14 +182,20 @@ describe( 'filters', () => {
177
182
  {
178
183
  field: 'categories',
179
184
  operator: 'isNone',
180
- value: [ 'Space' ],
185
+ value: [ 'Terrestrial' ],
181
186
  },
182
187
  ],
183
188
  },
184
189
  fields
185
190
  );
186
- expect( result ).toHaveLength( 1 );
187
- expect( result[ 0 ].title ).toBe( 'NASA' );
191
+ expect( result ).toHaveLength( 7 );
192
+ expect( result[ 0 ].title ).toBe( 'Moon' );
193
+ expect( result[ 1 ].title ).toBe( 'Io' );
194
+ expect( result[ 2 ].title ).toBe( 'Europa' );
195
+ expect( result[ 3 ].title ).toBe( 'Neptune' );
196
+ expect( result[ 4 ].title ).toBe( 'Jupiter' );
197
+ expect( result[ 5 ].title ).toBe( 'Saturn' );
198
+ expect( result[ 6 ].title ).toBe( 'Uranus' );
188
199
  } );
189
200
 
190
201
  it( 'should search using IS ALL filter', () => {
@@ -201,7 +212,7 @@ describe( 'filters', () => {
201
212
  },
202
213
  fields
203
214
  );
204
- expect( result ).toHaveLength( 7 );
215
+ expect( result ).toHaveLength( 8 );
205
216
  expect( result[ 0 ].title ).toBe( 'Neptune' );
206
217
  expect( result[ 1 ].title ).toBe( 'Mercury' );
207
218
  expect( result[ 2 ].title ).toBe( 'Venus' );
@@ -209,6 +220,7 @@ describe( 'filters', () => {
209
220
  expect( result[ 4 ].title ).toBe( 'Mars' );
210
221
  expect( result[ 5 ].title ).toBe( 'Jupiter' );
211
222
  expect( result[ 6 ].title ).toBe( 'Saturn' );
223
+ expect( result[ 7 ].title ).toBe( 'Uranus' );
212
224
  } );
213
225
 
214
226
  it( 'should search using IS NOT ALL filter', () => {
@@ -219,20 +231,562 @@ describe( 'filters', () => {
219
231
  {
220
232
  field: 'categories',
221
233
  operator: 'isNotAll',
222
- value: [ 'Planet', 'Solar system' ],
234
+ value: [ 'Planet' ],
223
235
  },
224
236
  ],
225
237
  },
226
238
  fields
227
239
  );
228
240
  expect( result ).toHaveLength( 3 );
229
- expect( result[ 0 ].title ).toBe( 'Apollo' );
230
- expect( result[ 1 ].title ).toBe( 'Space' );
231
- expect( result[ 2 ].title ).toBe( 'NASA' );
241
+ expect( result[ 0 ].title ).toBe( 'Moon' );
242
+ expect( result[ 1 ].title ).toBe( 'Io' );
243
+ expect( result[ 2 ].title ).toBe( 'Europa' );
244
+ } );
245
+
246
+ it( 'should search using IS filter and return all values if filter.value is undefined', () => {
247
+ const { data: result } = filterSortAndPaginate(
248
+ data,
249
+ {
250
+ filters: [
251
+ {
252
+ field: 'type',
253
+ operator: 'is',
254
+ value: undefined,
255
+ },
256
+ ],
257
+ },
258
+ fields
259
+ );
260
+ expect( result ).toHaveLength( 11 );
261
+ expect( result[ 0 ].title ).toBe( 'Moon' );
262
+ expect( result[ 1 ].title ).toBe( 'Io' );
263
+ expect( result[ 2 ].title ).toBe( 'Europa' );
264
+ expect( result[ 3 ].title ).toBe( 'Neptune' );
265
+ expect( result[ 4 ].title ).toBe( 'Mercury' );
266
+ expect( result[ 5 ].title ).toBe( 'Venus' );
267
+ expect( result[ 6 ].title ).toBe( 'Earth' );
268
+ expect( result[ 7 ].title ).toBe( 'Mars' );
269
+ expect( result[ 8 ].title ).toBe( 'Jupiter' );
270
+ expect( result[ 9 ].title ).toBe( 'Saturn' );
271
+ expect( result[ 10 ].title ).toBe( 'Uranus' );
272
+ } );
273
+
274
+ it( 'should filter using LESS THAN operator for integer', () => {
275
+ const { data: result } = filterSortAndPaginate(
276
+ data,
277
+ {
278
+ filters: [
279
+ {
280
+ field: 'satellites',
281
+ operator: 'lessThan',
282
+ value: 2,
283
+ },
284
+ ],
285
+ },
286
+ fields
287
+ );
288
+ expect( result.every( ( item ) => item.satellites < 2 ) ).toBe( true );
289
+ } );
290
+
291
+ it( 'should filter using GREATER THAN operator for integer', () => {
292
+ const { data: result } = filterSortAndPaginate(
293
+ data,
294
+ {
295
+ filters: [
296
+ {
297
+ field: 'satellites',
298
+ operator: 'greaterThan',
299
+ value: 10,
300
+ },
301
+ ],
302
+ },
303
+ fields
304
+ );
305
+ expect( result.every( ( item ) => item.satellites > 10 ) ).toBe( true );
306
+ } );
307
+
308
+ it( 'should filter using LESS THAN OR EQUAL operator for integer', () => {
309
+ const { data: result } = filterSortAndPaginate(
310
+ data,
311
+ {
312
+ filters: [
313
+ {
314
+ field: 'satellites',
315
+ operator: 'lessThanOrEqual',
316
+ value: 1,
317
+ },
318
+ ],
319
+ },
320
+ fields
321
+ );
322
+ expect( result.every( ( item ) => item.satellites <= 1 ) ).toBe( true );
323
+ } );
324
+
325
+ it( 'should filter using GREATER THAN OR EQUAL operator for integer', () => {
326
+ const { data: result } = filterSortAndPaginate(
327
+ data,
328
+ {
329
+ filters: [
330
+ {
331
+ field: 'satellites',
332
+ operator: 'greaterThanOrEqual',
333
+ value: 27,
334
+ },
335
+ ],
336
+ },
337
+ fields
338
+ );
339
+ expect( result.every( ( item ) => item.satellites >= 27 ) ).toBe(
340
+ true
341
+ );
342
+ } );
343
+
344
+ it( 'should filter using CONTAINS operator for text fields', () => {
345
+ const { data: result } = filterSortAndPaginate(
346
+ data,
347
+ {
348
+ filters: [
349
+ {
350
+ field: 'title',
351
+ operator: 'contains',
352
+ value: 'nep',
353
+ },
354
+ ],
355
+ },
356
+ fields
357
+ );
358
+ expect( result ).toHaveLength( 1 );
359
+ expect( result[ 0 ].title ).toBe( 'Neptune' );
360
+ } );
361
+
362
+ it( 'should filter using NOT_CONTAINS operator for text fields', () => {
363
+ const { data: result } = filterSortAndPaginate(
364
+ data,
365
+ {
366
+ filters: [
367
+ {
368
+ field: 'description',
369
+ operator: 'notContains',
370
+ value: 'Solar system',
371
+ },
372
+ ],
373
+ },
374
+ fields
375
+ );
376
+ expect( result.map( ( r ) => r.description ) ).toEqual( [
377
+ "Earth's satellite",
378
+ 'Moon of Jupiter',
379
+ 'Moon of Jupiter',
380
+ 'La planète Vénus',
381
+ ] );
382
+ } );
383
+
384
+ it( 'should filter using STARTS_WITH operator for text fields', () => {
385
+ const { data: result } = filterSortAndPaginate(
386
+ data,
387
+ {
388
+ filters: [
389
+ {
390
+ field: 'title',
391
+ operator: 'startsWith',
392
+ value: 'Mar',
393
+ },
394
+ ],
395
+ },
396
+ fields
397
+ );
398
+ expect( result.map( ( r ) => r.title ) ).toContain( 'Mars' );
399
+ } );
400
+
401
+ it( 'should filter using BEFORE operator for datetime', () => {
402
+ const { data: result } = filterSortAndPaginate(
403
+ data,
404
+ {
405
+ filters: [
406
+ {
407
+ field: 'date',
408
+ operator: 'before',
409
+ value: '2020-01-01',
410
+ },
411
+ ],
412
+ },
413
+ fields
414
+ );
415
+ expect(
416
+ result.every(
417
+ ( item ) => new Date( item.date ) < new Date( '2020-01-01' )
418
+ )
419
+ ).toBe( true );
420
+ } );
421
+
422
+ it( 'should filter using AFTER operator for datetime', () => {
423
+ const { data: result } = filterSortAndPaginate(
424
+ data,
425
+ {
426
+ filters: [
427
+ {
428
+ field: 'date',
429
+ operator: 'after',
430
+ value: '2020-01-01',
431
+ },
432
+ ],
433
+ },
434
+ fields
435
+ );
436
+ expect(
437
+ result.every(
438
+ ( item ) => new Date( item.date ) > new Date( '2020-01-01' )
439
+ )
440
+ ).toBe( true );
441
+ } );
442
+
443
+ it( 'should filter using BEFORE (inc) operator for datetime', () => {
444
+ const { data: result } = filterSortAndPaginate(
445
+ data,
446
+ {
447
+ filters: [
448
+ {
449
+ field: 'date',
450
+ operator: 'beforeInc',
451
+ value: '2020-01-01',
452
+ },
453
+ ],
454
+ },
455
+ fields
456
+ );
457
+ expect(
458
+ result.every(
459
+ ( item ) => new Date( item.date ) <= new Date( '2020-01-01' )
460
+ )
461
+ ).toBe( true );
462
+ } );
463
+
464
+ it( 'should filter using AFTER (inc) operator for datetime', () => {
465
+ const { data: result } = filterSortAndPaginate(
466
+ data,
467
+ {
468
+ filters: [
469
+ {
470
+ field: 'date',
471
+ operator: 'afterInc',
472
+ value: '2020-01-01',
473
+ },
474
+ ],
475
+ },
476
+ fields
477
+ );
478
+ expect(
479
+ result.every(
480
+ ( item ) => new Date( item.date ) >= new Date( '2020-01-01' )
481
+ )
482
+ ).toBe( true );
483
+ } );
484
+
485
+ it( 'should filter using ON operator for datetime with exact date match', () => {
486
+ const { data: result } = filterSortAndPaginate(
487
+ data,
488
+ {
489
+ filters: [
490
+ {
491
+ field: 'date',
492
+ operator: 'on',
493
+ value: '2020-01-01',
494
+ },
495
+ ],
496
+ },
497
+ fields
498
+ );
499
+ expect( result.length ).toBe( 2 );
500
+ expect( result[ 0 ].title ).toBe( 'Neptune' );
501
+ } );
502
+
503
+ it( 'should filter using ON operator for datetime with different date formats', () => {
504
+ // Test that '2019-03-01T00:00:00Z' matches '2019-03-01'
505
+ const testData = [
506
+ { title: 'Test Item 1', date: '2019-03-01T00:00:00Z' },
507
+ { title: 'Test Item 2', date: '2019-03-02' },
508
+ ];
509
+ const testFields = [
510
+ {
511
+ id: 'date',
512
+ type: 'datetime',
513
+ getValue: ( { item } ) => item.date,
514
+ },
515
+ ];
516
+
517
+ const { data: result } = filterSortAndPaginate(
518
+ testData,
519
+ {
520
+ filters: [
521
+ {
522
+ field: 'date',
523
+ operator: 'on',
524
+ value: '2019-03-01',
525
+ },
526
+ ],
527
+ },
528
+ testFields
529
+ );
530
+ expect( result.length ).toBe( 1 );
531
+ expect( result[ 0 ].title ).toBe( 'Test Item 1' );
532
+ } );
533
+
534
+ it( 'should filter using NOT_ON operator for datetime', () => {
535
+ const { data: result } = filterSortAndPaginate(
536
+ data,
537
+ {
538
+ filters: [
539
+ {
540
+ field: 'date',
541
+ operator: 'notOn',
542
+ value: '2020-01-01',
543
+ },
544
+ ],
545
+ },
546
+ fields
547
+ );
548
+ expect( result.length ).toBe( 9 );
549
+ expect( result.map( ( r ) => r.title ) ).not.toContain( 'Neptune' );
550
+ } );
551
+
552
+ it( 'should filter using NOT_ON operator for datetime with different date formats', () => {
553
+ // Test that '2019-03-01T00:00:00Z' does not match '2019-03-02'
554
+ const testData = [
555
+ { title: 'Test Item 1', date: '2019-03-01T00:00:00Z' },
556
+ { title: 'Test Item 2', date: '2019-03-02T00:00:00Z' },
557
+ ];
558
+ const testFields = [
559
+ {
560
+ id: 'date',
561
+ type: 'datetime',
562
+ getValue: ( { item } ) => item.date,
563
+ },
564
+ ];
565
+
566
+ const { data: result } = filterSortAndPaginate(
567
+ testData,
568
+ {
569
+ filters: [
570
+ {
571
+ field: 'date',
572
+ operator: 'notOn',
573
+ value: '2019-03-01',
574
+ },
575
+ ],
576
+ },
577
+ testFields
578
+ );
579
+ expect( result.length ).toBe( 1 );
580
+ expect( result[ 0 ].title ).toBe( 'Test Item 2' );
581
+ } );
582
+
583
+ it( 'should filter numbers inclusively between min and max using BETWEEN operator', () => {
584
+ const { data: result } = filterSortAndPaginate(
585
+ data,
586
+ {
587
+ filters: [
588
+ {
589
+ field: 'satellites',
590
+ operator: 'between',
591
+ value: [ 10, 30 ],
592
+ },
593
+ ],
594
+ },
595
+ fields
596
+ );
597
+ expect( result.map( ( r ) => r.title ).sort() ).toEqual( [
598
+ 'Neptune',
599
+ 'Uranus',
600
+ ] );
601
+ } );
602
+
603
+ it( 'should filter numbers inclusively at the edges using BETWEEN operator', () => {
604
+ const { data: result } = filterSortAndPaginate(
605
+ data,
606
+ {
607
+ filters: [
608
+ {
609
+ field: 'satellites',
610
+ operator: 'between',
611
+ value: [ 28, 28 ],
612
+ },
613
+ ],
614
+ },
615
+ fields
616
+ );
617
+ expect( result.map( ( r ) => r.title ) ).toEqual( [ 'Uranus' ] );
618
+ } );
619
+
620
+ it( 'should filter dates inclusively between min and max using BETWEEN operator', () => {
621
+ const { data: result } = filterSortAndPaginate(
622
+ data,
623
+ {
624
+ filters: [
625
+ {
626
+ field: 'date',
627
+ operator: 'between',
628
+ value: [ '1977-08-20', '1989-08-25' ],
629
+ },
630
+ ],
631
+ },
632
+ fields
633
+ );
634
+ const allInRange = result.every(
635
+ ( r ) => r.date >= '1977-08-20' && r.date <= '1989-08-25'
636
+ );
637
+ expect( allInRange ).toBe( true );
638
+ } );
639
+
640
+ it( 'should return no results if min > max using BETWEEN operator', () => {
641
+ const { data: result } = filterSortAndPaginate(
642
+ data,
643
+ {
644
+ filters: [
645
+ {
646
+ field: 'satellites',
647
+ operator: 'between',
648
+ value: [ 30, 10 ],
649
+ },
650
+ ],
651
+ },
652
+ fields
653
+ );
654
+ expect( result ).toHaveLength( 0 );
655
+ } );
656
+
657
+ it( 'should filter using IN_THE_PAST operator for datetime (days)', () => {
658
+ const testData = [
659
+ { title: 'Recent', date: subDays( new Date(), 5 ) },
660
+ { title: 'Old', date: subDays( new Date(), 14 ) },
661
+ ];
662
+ const testFields = [ { id: 'date', type: 'datetime', label: 'Date' } ];
663
+ const { data: result } = filterSortAndPaginate(
664
+ testData,
665
+ {
666
+ filters: [
667
+ {
668
+ field: 'date',
669
+ operator: 'inThePast',
670
+ value: { value: 7, unit: 'days' },
671
+ },
672
+ ],
673
+ },
674
+ testFields
675
+ );
676
+ expect( result ).toHaveLength( 1 );
677
+ expect( result ).toStrictEqual( [ testData[ 0 ] ] );
678
+ } );
679
+
680
+ it( 'should filter using OVER operator for datetime (days)', () => {
681
+ const testData = [
682
+ { title: 'Recent', date: subDays( new Date(), 5 ) },
683
+ { title: 'Old', date: subDays( new Date(), 14 ) },
684
+ ];
685
+ const testFields = [ { id: 'date', type: 'datetime', label: 'Date' } ];
686
+ const { data: result } = filterSortAndPaginate(
687
+ testData,
688
+ {
689
+ filters: [
690
+ {
691
+ field: 'date',
692
+ operator: 'over',
693
+ value: { value: 10, unit: 'days' },
694
+ },
695
+ ],
696
+ },
697
+ testFields
698
+ );
699
+ expect( result ).toHaveLength( 1 );
700
+ expect( result ).toStrictEqual( [ testData[ 1 ] ] );
701
+ } );
702
+
703
+ it( 'should filter using IN_THE_PAST operator for datetime (years)', () => {
704
+ const testData = [
705
+ { title: 'Recent', date: subYears( new Date(), 1 ) },
706
+ { title: 'Old', date: subYears( new Date(), 5 ) },
707
+ ];
708
+ const testFields = [ { id: 'date', type: 'datetime', label: 'Date' } ];
709
+ const { data: result } = filterSortAndPaginate(
710
+ testData,
711
+ {
712
+ filters: [
713
+ {
714
+ field: 'date',
715
+ operator: 'inThePast',
716
+ value: { value: 3, unit: 'years' },
717
+ },
718
+ ],
719
+ },
720
+ testFields
721
+ );
722
+ expect( result ).toHaveLength( 1 );
723
+ expect( result ).toStrictEqual( [ testData[ 0 ] ] );
724
+ } );
725
+
726
+ it( 'should filter using OVER operator for datetime (years)', () => {
727
+ const testData = [
728
+ { title: 'Recent', date: subYears( new Date(), 1 ) },
729
+ { title: 'Old', date: subYears( new Date(), 5 ) },
730
+ ];
731
+ const testFields = [ { id: 'date', type: 'datetime', label: 'Date' } ];
732
+ const { data: result } = filterSortAndPaginate(
733
+ testData,
734
+ {
735
+ filters: [
736
+ {
737
+ field: 'date',
738
+ operator: 'over',
739
+ value: { value: 3, unit: 'years' },
740
+ },
741
+ ],
742
+ },
743
+ testFields
744
+ );
745
+ expect( result ).toHaveLength( 1 );
746
+ expect( result ).toStrictEqual( [ testData[ 1 ] ] );
232
747
  } );
233
748
  } );
234
749
 
235
750
  describe( 'sorting', () => {
751
+ it( 'should sort by groupByField first, then by sort.field', () => {
752
+ const { data: result } = filterSortAndPaginate(
753
+ data,
754
+ {
755
+ sort: { field: 'title', direction: 'desc' },
756
+ groupByField: 'type',
757
+ },
758
+ fields
759
+ );
760
+
761
+ expect( result ).toHaveLength( 11 );
762
+
763
+ expect( result[ 0 ].type ).toBe( 'Gas giant' );
764
+ expect( result[ 0 ].title ).toBe( 'Saturn' );
765
+ expect( result[ 1 ].type ).toBe( 'Gas giant' );
766
+ expect( result[ 1 ].title ).toBe( 'Jupiter' );
767
+
768
+ expect( result[ 2 ].type ).toBe( 'Ice giant' );
769
+ expect( result[ 2 ].title ).toBe( 'Uranus' );
770
+ expect( result[ 3 ].type ).toBe( 'Ice giant' );
771
+ expect( result[ 3 ].title ).toBe( 'Neptune' );
772
+
773
+ expect( result[ 4 ].type ).toBe( 'Satellite' );
774
+ expect( result[ 4 ].title ).toBe( 'Moon' );
775
+ expect( result[ 5 ].type ).toBe( 'Satellite' );
776
+ expect( result[ 5 ].title ).toBe( 'Io' );
777
+ expect( result[ 6 ].type ).toBe( 'Satellite' );
778
+ expect( result[ 6 ].title ).toBe( 'Europa' );
779
+
780
+ expect( result[ 7 ].type ).toBe( 'Terrestrial' );
781
+ expect( result[ 7 ].title ).toBe( 'Venus' );
782
+ expect( result[ 8 ].type ).toBe( 'Terrestrial' );
783
+ expect( result[ 8 ].title ).toBe( 'Mercury' );
784
+ expect( result[ 9 ].type ).toBe( 'Terrestrial' );
785
+ expect( result[ 9 ].title ).toBe( 'Mars' );
786
+ expect( result[ 10 ].type ).toBe( 'Terrestrial' );
787
+ expect( result[ 10 ].title ).toBe( 'Earth' );
788
+ } );
789
+
236
790
  it( 'should sort integer field types', () => {
237
791
  const { data: result } = filterSortAndPaginate(
238
792
  data,
@@ -277,9 +831,9 @@ describe( 'sorting', () => {
277
831
  fields
278
832
  );
279
833
  expect( resultDesc ).toHaveLength( 11 );
280
- expect( resultDesc[ 0 ].title ).toBe( 'NASA' );
834
+ expect( resultDesc[ 0 ].title ).toBe( 'Europa' );
281
835
  expect( resultDesc[ 1 ].title ).toBe( 'Earth' );
282
- expect( resultDesc[ 9 ].title ).toBe( 'Space' );
836
+ expect( resultDesc[ 9 ].title ).toBe( 'Io' );
283
837
  expect( resultDesc[ 10 ].title ).toBe( 'Jupiter' );
284
838
 
285
839
  const { data: resultAsc } = filterSortAndPaginate(
@@ -291,9 +845,9 @@ describe( 'sorting', () => {
291
845
  );
292
846
  expect( resultAsc ).toHaveLength( 11 );
293
847
  expect( resultAsc[ 0 ].title ).toBe( 'Jupiter' );
294
- expect( resultAsc[ 1 ].title ).toBe( 'Space' );
848
+ expect( resultAsc[ 1 ].title ).toBe( 'Io' );
295
849
  expect( resultAsc[ 9 ].title ).toBe( 'Earth' );
296
- expect( resultAsc[ 10 ].title ).toBe( 'NASA' );
850
+ expect( resultAsc[ 10 ].title ).toBe( 'Europa' );
297
851
  } );
298
852
 
299
853
  it( 'should sort untyped fields if the value is a number', () => {
@@ -338,6 +892,28 @@ describe( 'sorting', () => {
338
892
  expect( result[ 0 ].title ).toBe( 'Uranus' );
339
893
  expect( result[ 1 ].title ).toBe( 'Neptune' );
340
894
  } );
895
+
896
+ it( 'should sort only by groupByField when sort is not specified', () => {
897
+ const { data: result } = filterSortAndPaginate(
898
+ data,
899
+ {
900
+ groupByField: 'type',
901
+ },
902
+ fields
903
+ );
904
+
905
+ let currentType = result[ 0 ].type;
906
+ let groupCount = 1;
907
+
908
+ for ( let i = 1; i < result.length; i++ ) {
909
+ if ( result[ i ].type !== currentType ) {
910
+ currentType = result[ i ].type;
911
+ groupCount++;
912
+ }
913
+ }
914
+
915
+ expect( groupCount ).toBe( 4 );
916
+ } );
341
917
  } );
342
918
 
343
919
  describe( 'pagination', () => {
@@ -352,7 +928,7 @@ describe( 'pagination', () => {
352
928
  fields
353
929
  );
354
930
  expect( result ).toHaveLength( 2 );
355
- expect( result[ 0 ].title ).toBe( 'NASA' );
931
+ expect( result[ 0 ].title ).toBe( 'Europa' );
356
932
  expect( result[ 1 ].title ).toBe( 'Neptune' );
357
933
  expect( paginationInfo ).toStrictEqual( {
358
934
  totalItems: data.length,