@veeqo/transfigure 0.0.1

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 (357) hide show
  1. package/README.md +54 -0
  2. package/dist/BusinessLogic/BusinessLogicManager.d.ts +6 -0
  3. package/dist/BusinessLogic/index.d.ts +4 -0
  4. package/dist/BusinessLogic/mocks.d.ts +10 -0
  5. package/dist/BusinessLogic/types.d.ts +18 -0
  6. package/dist/BusinessLogic/useBusinessLogic.d.ts +1 -0
  7. package/dist/api/createCustomView/createCustomView.d.ts +6 -0
  8. package/dist/api/createCustomView/index.d.ts +1 -0
  9. package/dist/api/deleteCustomView/deleteCustomView.d.ts +1 -0
  10. package/dist/api/deleteCustomView/index.d.ts +1 -0
  11. package/dist/api/index.d.ts +5 -0
  12. package/dist/api/patchCurrentUser/index.d.ts +1 -0
  13. package/dist/api/patchCurrentUser/patchCurrentUser.d.ts +1 -0
  14. package/dist/api/patchCustomView/index.d.ts +1 -0
  15. package/dist/api/patchCustomView/patchCustomView.d.ts +6 -0
  16. package/dist/api/types.d.ts +16 -0
  17. package/dist/axiosWrappers/axiosWrappers.d.ts +15 -0
  18. package/dist/axiosWrappers/axiosWrappers.test.d.ts +1 -0
  19. package/dist/axiosWrappers/constants.d.ts +10 -0
  20. package/dist/axiosWrappers/index.d.ts +1 -0
  21. package/dist/axiosWrappers/types.d.ts +6 -0
  22. package/dist/axiosWrappers/utils/filterErrorStack/filterErrorStack.d.ts +14 -0
  23. package/dist/axiosWrappers/utils/filterErrorStack/filterErrorStack.test.d.ts +1 -0
  24. package/dist/axiosWrappers/utils/filterErrorStack/index.d.ts +1 -0
  25. package/dist/axiosWrappers/utils/filteringUtils/filteringUtils.d.ts +3 -0
  26. package/dist/axiosWrappers/utils/filteringUtils/filteringUtils.test.d.ts +1 -0
  27. package/dist/axiosWrappers/utils/filteringUtils/index.d.ts +1 -0
  28. package/dist/axiosWrappers/utils/injectIntoError/index.d.ts +1 -0
  29. package/dist/axiosWrappers/utils/injectIntoError/injectIntoError.d.ts +18 -0
  30. package/dist/axiosWrappers/utils/injectIntoError/injectIntoError.test.d.ts +1 -0
  31. package/dist/axiosWrappers/utils/isError/index.d.ts +1 -0
  32. package/dist/axiosWrappers/utils/isError/isError.d.ts +4 -0
  33. package/dist/components/ErrorBoundary/ErrorBoundary.d.ts +17 -0
  34. package/dist/components/ErrorBoundary/index.d.ts +1 -0
  35. package/dist/components/Filters/ActiveFilters/ActiveFilterArrayTag/ActiveFilterArrayTag.d.ts +6 -0
  36. package/dist/components/Filters/ActiveFilters/ActiveFilterArrayTag/index.d.ts +1 -0
  37. package/dist/components/Filters/ActiveFilters/ActiveFilterDateRangeTag/ActiveFilterDateRangeTag.d.ts +6 -0
  38. package/dist/components/Filters/ActiveFilters/ActiveFilterDateRangeTag/index.d.ts +1 -0
  39. package/dist/components/Filters/ActiveFilters/ActiveFilterNumberRangeTag/ActiveFilterNumberRangeTag.d.ts +6 -0
  40. package/dist/components/Filters/ActiveFilters/ActiveFilterNumberRangeTag/index.d.ts +1 -0
  41. package/dist/components/Filters/ActiveFilters/ActiveFilterTag/ActiveFilterTag.d.ts +6 -0
  42. package/dist/components/Filters/ActiveFilters/ActiveFilterTag/index.d.ts +1 -0
  43. package/dist/components/Filters/ActiveFilters/ActiveFilters.d.ts +1 -0
  44. package/dist/components/Filters/ActiveFilters/index.d.ts +5 -0
  45. package/dist/components/Filters/AdaptiveHeightContainer/AdaptiveHeightContainer.d.ts +8 -0
  46. package/dist/components/Filters/AdaptiveHeightContainer/index.d.ts +1 -0
  47. package/dist/components/Filters/AdaptiveHeightContainer/styled.d.ts +3 -0
  48. package/dist/components/Filters/Fields/AsyncCheckboxFilter/AsyncCheckboxFilter.d.ts +6 -0
  49. package/dist/components/Filters/Fields/AsyncCheckboxFilter/index.d.ts +1 -0
  50. package/dist/components/Filters/Fields/AsyncInlineCheckboxFilter/AsyncInlineCheckboxFilter.d.ts +8 -0
  51. package/dist/components/Filters/Fields/AsyncInlineCheckboxFilter/index.d.ts +1 -0
  52. package/dist/components/Filters/Fields/AsyncInlineRadioFilter/AsyncInlineRadioFilter.d.ts +8 -0
  53. package/dist/components/Filters/Fields/AsyncInlineRadioFilter/index.d.ts +1 -0
  54. package/dist/components/Filters/Fields/AsyncRadioFilter/AsyncRadioFilter.d.ts +6 -0
  55. package/dist/components/Filters/Fields/AsyncRadioFilter/index.d.ts +1 -0
  56. package/dist/components/Filters/Fields/CheckboxFilter/CheckboxFilter.d.ts +6 -0
  57. package/dist/components/Filters/Fields/CheckboxFilter/index.d.ts +1 -0
  58. package/dist/components/Filters/Fields/DateRangeFilter/DateRangeFilter.d.ts +6 -0
  59. package/dist/components/Filters/Fields/DateRangeFilter/index.d.ts +1 -0
  60. package/dist/components/Filters/Fields/FilterArrayField/FilterArrayField.d.ts +8 -0
  61. package/dist/components/Filters/Fields/FilterArrayField/index.d.ts +1 -0
  62. package/dist/components/Filters/Fields/FilterField/FilterField.d.ts +8 -0
  63. package/dist/components/Filters/Fields/FilterField/index.d.ts +1 -0
  64. package/dist/components/Filters/Fields/FilterGroup/FilterGroup.d.ts +6 -0
  65. package/dist/components/Filters/Fields/FilterGroup/index.d.ts +1 -0
  66. package/dist/components/Filters/Fields/FilterNumberRangeFilter/FilterNumberRangeFilter.d.ts +9 -0
  67. package/dist/components/Filters/Fields/FilterNumberRangeFilter/index.d.ts +1 -0
  68. package/dist/components/Filters/Fields/MultipleFieldFilter/MultipleFieldFilter.d.ts +7 -0
  69. package/dist/components/Filters/Fields/MultipleFieldFilter/index.d.ts +1 -0
  70. package/dist/components/Filters/Fields/NumberRangeFilter/MuiSlider.d.ts +27 -0
  71. package/dist/components/Filters/Fields/NumberRangeFilter/NumberRangeFilter.d.ts +6 -0
  72. package/dist/components/Filters/Fields/NumberRangeFilter/index.d.ts +1 -0
  73. package/dist/components/Filters/Fields/RadioFilter/RadioFilter.d.ts +6 -0
  74. package/dist/components/Filters/Fields/RadioFilter/index.d.ts +1 -0
  75. package/dist/components/Filters/Fields/index.d.ts +13 -0
  76. package/dist/components/Filters/FiltersDropdown/FiltersDropdown.d.ts +2 -0
  77. package/dist/components/Filters/FiltersDropdown/index.d.ts +1 -0
  78. package/dist/components/Filters/FiltersList/FiltersList.d.ts +2 -0
  79. package/dist/components/Filters/FiltersList/index.d.ts +1 -0
  80. package/dist/components/Filters/index.d.ts +4 -0
  81. package/dist/components/SearchBar/SearchBar.d.ts +1 -0
  82. package/dist/components/SearchBar/index.d.ts +1 -0
  83. package/dist/components/Table/Table.d.ts +1 -0
  84. package/dist/components/ToastsManager/ToastsManager.d.ts +1 -0
  85. package/dist/components/ToastsManager/index.d.ts +1 -0
  86. package/dist/components/Views/CreateView/CreateView.d.ts +5 -0
  87. package/dist/components/Views/CreateView/index.d.ts +1 -0
  88. package/dist/components/Views/EditDropdown/EditDropdown.d.ts +7 -0
  89. package/dist/components/Views/EditDropdown/index.d.ts +1 -0
  90. package/dist/components/Views/OptionsDropdown/OptionsDropdown.d.ts +10 -0
  91. package/dist/components/Views/OptionsDropdown/index.d.ts +1 -0
  92. package/dist/components/Views/OptionsDropdown/styled.d.ts +17 -0
  93. package/dist/components/Views/PillNotifications/InfoPill.d.ts +1 -0
  94. package/dist/components/Views/PillNotifications/PillNotifications.d.ts +9 -0
  95. package/dist/components/Views/PillNotifications/index.d.ts +1 -0
  96. package/dist/components/Views/PillNotifications/styled.d.ts +33 -0
  97. package/dist/components/Views/SortableViews/LegacySortableViews.d.ts +3 -0
  98. package/dist/components/Views/SortableViews/SortableViews.d.ts +1 -0
  99. package/dist/components/Views/SortableViews/index.d.ts +1 -0
  100. package/dist/components/Views/SortableViews/styled.d.ts +8 -0
  101. package/dist/components/Views/UnsavedChanges/UnsavedChanges.d.ts +5 -0
  102. package/dist/components/Views/UnsavedChanges/index.d.ts +1 -0
  103. package/dist/components/Views/UnsavedChanges/styled.d.ts +33 -0
  104. package/dist/components/Views/ViewDropdowns/ViewDropdowns.d.ts +1 -0
  105. package/dist/components/Views/ViewDropdowns/index.d.ts +1 -0
  106. package/dist/components/Views/ViewList/ViewsList.d.ts +1 -0
  107. package/dist/components/Views/ViewList/index.d.ts +1 -0
  108. package/dist/components/Views/ViewList/styled.d.ts +2 -0
  109. package/dist/components/Views/ViewTab/Confirmation/Confirmation.d.ts +8 -0
  110. package/dist/components/Views/ViewTab/Confirmation/index.d.ts +1 -0
  111. package/dist/components/Views/ViewTab/ViewTab.d.ts +6 -0
  112. package/dist/components/Views/ViewTab/index.d.ts +1 -0
  113. package/dist/components/Views/constants.d.ts +10 -0
  114. package/dist/components/Views/index.d.ts +10 -0
  115. package/dist/constants/constants.d.ts +8 -0
  116. package/dist/constants/dateConstants.d.ts +17 -0
  117. package/dist/constants/index.d.ts +2 -0
  118. package/dist/context/ModalContext/ModalContext.d.ts +6 -0
  119. package/dist/context/ModalContext/hooks.d.ts +1 -0
  120. package/dist/context/ModalContext/index.d.ts +3 -0
  121. package/dist/context/ModalContext/mocks/mockUseModal.d.ts +6 -0
  122. package/dist/context/ModalContext/modalId.d.ts +3 -0
  123. package/dist/context/ModalContext/types.d.ts +7 -0
  124. package/dist/context/index.d.ts +1 -0
  125. package/dist/fetchers/constants.d.ts +12 -0
  126. package/dist/fetchers/fetchers.d.ts +12 -0
  127. package/dist/fetchers/index.d.ts +3 -0
  128. package/dist/fetchers/withCSRF.d.ts +2 -0
  129. package/dist/hooks/index.d.ts +9 -0
  130. package/dist/hooks/useCustomViews/index.d.ts +1 -0
  131. package/dist/hooks/useCustomViews/useCustomViews.d.ts +16 -0
  132. package/dist/hooks/useDropdownManager/index.d.ts +1 -0
  133. package/dist/hooks/useDropdownManager/useDropdownManager.d.ts +35 -0
  134. package/dist/hooks/useDuplicateActiveView/index.d.ts +1 -0
  135. package/dist/hooks/useDuplicateActiveView/useDuplicateActiveView.d.ts +3 -0
  136. package/dist/hooks/useFilterArrayLabel/index.d.ts +1 -0
  137. package/dist/hooks/useFilterArrayLabel/useFilterArrayLabel.d.ts +8 -0
  138. package/dist/hooks/useFilterLabel/index.d.ts +1 -0
  139. package/dist/hooks/useFilterLabel/useFilterLabel.d.ts +8 -0
  140. package/dist/hooks/usePersistUnsavedChanges/index.d.ts +1 -0
  141. package/dist/hooks/usePersistUnsavedChanges/usePersistUnsavedChanges.d.ts +18 -0
  142. package/dist/hooks/useStores/index.d.ts +1 -0
  143. package/dist/hooks/useStores/types.d.ts +8 -0
  144. package/dist/hooks/useStores/useStores.d.ts +2 -0
  145. package/dist/hooks/useViewUrlChange/index.d.ts +1 -0
  146. package/dist/hooks/useViewUrlChange/useViewUrlChange.d.ts +1 -0
  147. package/dist/hooks/useViews/index.d.ts +1 -0
  148. package/dist/hooks/useViews/useViews.d.ts +15 -0
  149. package/dist/index.cjs +1 -0
  150. package/dist/index.d.ts +15 -0
  151. package/dist/index.js +143 -0
  152. package/dist/index10.cjs +1 -0
  153. package/dist/index10.js +29 -0
  154. package/dist/index11.cjs +1 -0
  155. package/dist/index11.js +23 -0
  156. package/dist/index12.cjs +1 -0
  157. package/dist/index12.js +24 -0
  158. package/dist/index13.cjs +1 -0
  159. package/dist/index13.js +42 -0
  160. package/dist/index14.cjs +1 -0
  161. package/dist/index14.js +42 -0
  162. package/dist/index15.cjs +1 -0
  163. package/dist/index15.js +57 -0
  164. package/dist/index16.cjs +1 -0
  165. package/dist/index16.js +49 -0
  166. package/dist/index17.cjs +1 -0
  167. package/dist/index17.js +45 -0
  168. package/dist/index18.cjs +1 -0
  169. package/dist/index18.js +55 -0
  170. package/dist/index19.cjs +1 -0
  171. package/dist/index19.js +39 -0
  172. package/dist/index2.cjs +1 -0
  173. package/dist/index2.js +7 -0
  174. package/dist/index20.cjs +1 -0
  175. package/dist/index20.js +39 -0
  176. package/dist/index21.cjs +1 -0
  177. package/dist/index21.js +55 -0
  178. package/dist/index22.cjs +1 -0
  179. package/dist/index22.js +36 -0
  180. package/dist/index23.cjs +1 -0
  181. package/dist/index23.js +62 -0
  182. package/dist/index24.cjs +1 -0
  183. package/dist/index24.js +21 -0
  184. package/dist/index25.cjs +1 -0
  185. package/dist/index25.js +34 -0
  186. package/dist/index26.cjs +1 -0
  187. package/dist/index26.js +43 -0
  188. package/dist/index27.cjs +1 -0
  189. package/dist/index27.js +38 -0
  190. package/dist/index28.cjs +1 -0
  191. package/dist/index28.js +53 -0
  192. package/dist/index29.cjs +1 -0
  193. package/dist/index29.js +111 -0
  194. package/dist/index3.cjs +1 -0
  195. package/dist/index3.js +9 -0
  196. package/dist/index30.cjs +1 -0
  197. package/dist/index30.js +36 -0
  198. package/dist/index31.cjs +1 -0
  199. package/dist/index31.js +33 -0
  200. package/dist/index32.cjs +1 -0
  201. package/dist/index32.js +17 -0
  202. package/dist/index33.cjs +1 -0
  203. package/dist/index33.js +96 -0
  204. package/dist/index34.cjs +1 -0
  205. package/dist/index34.js +21 -0
  206. package/dist/index35.cjs +1 -0
  207. package/dist/index35.js +75 -0
  208. package/dist/index36.cjs +1 -0
  209. package/dist/index36.js +30 -0
  210. package/dist/index37.cjs +1 -0
  211. package/dist/index37.js +31 -0
  212. package/dist/index38.cjs +1 -0
  213. package/dist/index38.js +57 -0
  214. package/dist/index39.cjs +1 -0
  215. package/dist/index39.js +34 -0
  216. package/dist/index4.cjs +1 -0
  217. package/dist/index4.js +14 -0
  218. package/dist/index40.cjs +1 -0
  219. package/dist/index40.js +40 -0
  220. package/dist/index41.cjs +1 -0
  221. package/dist/index41.js +37 -0
  222. package/dist/index42.cjs +1 -0
  223. package/dist/index42.js +13 -0
  224. package/dist/index43.cjs +1 -0
  225. package/dist/index43.js +9 -0
  226. package/dist/index44.cjs +1 -0
  227. package/dist/index44.js +4 -0
  228. package/dist/index45.cjs +1 -0
  229. package/dist/index45.js +23 -0
  230. package/dist/index46.cjs +1 -0
  231. package/dist/index46.js +4 -0
  232. package/dist/index47.cjs +1 -0
  233. package/dist/index47.js +6 -0
  234. package/dist/index48.cjs +1 -0
  235. package/dist/index48.js +15 -0
  236. package/dist/index49.cjs +1 -0
  237. package/dist/index49.js +15 -0
  238. package/dist/index5.cjs +1 -0
  239. package/dist/index5.js +18 -0
  240. package/dist/index50.cjs +1 -0
  241. package/dist/index50.js +23 -0
  242. package/dist/index51.cjs +1 -0
  243. package/dist/index51.js +221 -0
  244. package/dist/index52.cjs +1 -0
  245. package/dist/index52.js +44 -0
  246. package/dist/index53.cjs +1 -0
  247. package/dist/index53.js +36 -0
  248. package/dist/index54.cjs +1 -0
  249. package/dist/index54.js +39 -0
  250. package/dist/index55.cjs +1 -0
  251. package/dist/index55.js +100 -0
  252. package/dist/index56.cjs +1 -0
  253. package/dist/index56.js +11 -0
  254. package/dist/index57.cjs +1 -0
  255. package/dist/index57.js +63 -0
  256. package/dist/index58.cjs +1 -0
  257. package/dist/index58.js +65 -0
  258. package/dist/index59.cjs +1 -0
  259. package/dist/index59.js +28 -0
  260. package/dist/index6.cjs +1 -0
  261. package/dist/index6.js +110 -0
  262. package/dist/index60.cjs +1 -0
  263. package/dist/index60.js +301 -0
  264. package/dist/index61.cjs +1 -0
  265. package/dist/index61.js +66 -0
  266. package/dist/index62.cjs +1 -0
  267. package/dist/index62.js +65 -0
  268. package/dist/index63.cjs +1 -0
  269. package/dist/index63.js +39 -0
  270. package/dist/index64.cjs +1 -0
  271. package/dist/index64.js +34 -0
  272. package/dist/index65.cjs +1 -0
  273. package/dist/index65.js +11 -0
  274. package/dist/index66.cjs +1 -0
  275. package/dist/index66.js +14 -0
  276. package/dist/index67.cjs +1 -0
  277. package/dist/index67.js +21 -0
  278. package/dist/index68.cjs +1 -0
  279. package/dist/index68.js +21 -0
  280. package/dist/index69.cjs +1 -0
  281. package/dist/index69.js +44 -0
  282. package/dist/index7.cjs +1 -0
  283. package/dist/index7.js +6 -0
  284. package/dist/index70.cjs +1 -0
  285. package/dist/index70.js +19 -0
  286. package/dist/index71.cjs +1 -0
  287. package/dist/index71.js +4 -0
  288. package/dist/index72.cjs +1 -0
  289. package/dist/index72.js +11 -0
  290. package/dist/index73.cjs +3 -0
  291. package/dist/index73.js +16 -0
  292. package/dist/index74.cjs +1 -0
  293. package/dist/index74.js +11 -0
  294. package/dist/index75.cjs +1 -0
  295. package/dist/index75.js +28 -0
  296. package/dist/index76.cjs +1 -0
  297. package/dist/index76.js +21 -0
  298. package/dist/index77.cjs +19 -0
  299. package/dist/index77.js +32 -0
  300. package/dist/index78.cjs +1 -0
  301. package/dist/index78.js +18 -0
  302. package/dist/index79.cjs +1 -0
  303. package/dist/index79.js +11 -0
  304. package/dist/index8.cjs +1 -0
  305. package/dist/index8.js +16 -0
  306. package/dist/index80.cjs +12 -0
  307. package/dist/index80.js +18 -0
  308. package/dist/index81.cjs +80 -0
  309. package/dist/index81.js +99 -0
  310. package/dist/index82.cjs +1 -0
  311. package/dist/index82.js +4 -0
  312. package/dist/index83.cjs +80 -0
  313. package/dist/index83.js +99 -0
  314. package/dist/index84.cjs +1 -0
  315. package/dist/index84.js +38 -0
  316. package/dist/index85.cjs +13 -0
  317. package/dist/index85.js +21 -0
  318. package/dist/index86.cjs +7 -0
  319. package/dist/index86.js +14 -0
  320. package/dist/index9.cjs +1 -0
  321. package/dist/index9.js +149 -0
  322. package/dist/mobx/Filters/Filters.d.ts +51 -0
  323. package/dist/mobx/Filters/index.d.ts +1 -0
  324. package/dist/mobx/MobXProvider/MobXProvider.d.ts +12 -0
  325. package/dist/mobx/MobXProvider/index.d.ts +1 -0
  326. package/dist/mobx/Notifications/Notifications.d.ts +13 -0
  327. package/dist/mobx/Notifications/index.d.ts +1 -0
  328. package/dist/mobx/NumberRangeFilter/NumberRangeFilter.d.ts +20 -0
  329. package/dist/mobx/NumberRangeFilter/index.d.ts +1 -0
  330. package/dist/mobx/RangeFilter/RangeFilter.d.ts +18 -0
  331. package/dist/mobx/RangeFilter/index.d.ts +1 -0
  332. package/dist/mobx/Views/Views.d.ts +10 -0
  333. package/dist/mobx/Views/index.d.ts +1 -0
  334. package/dist/mobx/index.d.ts +6 -0
  335. package/dist/setupTests.d.ts +0 -0
  336. package/dist/storybookHelpers/StoryWrapper.d.ts +13 -0
  337. package/dist/storybookHelpers/apiMocks/current_user.d.ts +272 -0
  338. package/dist/storybookHelpers/apiMocks/custom_views.d.ts +53 -0
  339. package/dist/storybookHelpers/constants.d.ts +5 -0
  340. package/dist/types.d.ts +93 -0
  341. package/dist/utils/createAllView/createAllView.d.ts +3 -0
  342. package/dist/utils/createAllView/createAllView.test.d.ts +1 -0
  343. package/dist/utils/createAllView/index.d.ts +1 -0
  344. package/dist/utils/getAsyncOptions/getAsyncOptions.d.ts +10 -0
  345. package/dist/utils/getAsyncOptions/getAsyncOptions.test.d.ts +1 -0
  346. package/dist/utils/getAsyncOptions/index.d.ts +1 -0
  347. package/dist/utils/getFetcherFunction/getFetcherFunction.d.ts +5 -0
  348. package/dist/utils/getFetcherFunction/getFetcherFunction.test.d.ts +1 -0
  349. package/dist/utils/getFetcherFunction/index.d.ts +1 -0
  350. package/dist/utils/index.d.ts +5 -0
  351. package/dist/utils/isValidDateRange/index.d.ts +1 -0
  352. package/dist/utils/isValidDateRange/isValidDateRange.d.ts +2 -0
  353. package/dist/utils/isValidDateRange/isValidDateRange.test.d.ts +1 -0
  354. package/dist/utils/viewsAdapter/index.d.ts +1 -0
  355. package/dist/utils/viewsAdapter/viewsAdapter.d.ts +7 -0
  356. package/dist/utils/viewsAdapter/viewsAdapter.test.d.ts +1 -0
  357. package/package.json +126 -0
@@ -0,0 +1,39 @@
1
+ import { jsxs as n, jsx as s } from "react/jsx-runtime";
2
+ import { useMemo as u } from "react";
3
+ import { observer as F } from "mobx-react";
4
+ import { Stack as b, ChoiceList as y, Skeleton as d, theme as x, Text as A } from "@veeqo/ui";
5
+ import L from "swr/immutable";
6
+ import { getAsyncOptions as O } from "./index66.js";
7
+ import { getFetcherFunction as S } from "./index67.js";
8
+ const w = F(({
9
+ field: t,
10
+ editedValue: c,
11
+ setEditedValue: a
12
+ }) => {
13
+ var o, i;
14
+ const l = u(() => {
15
+ var e;
16
+ return S({
17
+ fetcherName: (e = t.fetchAsyncFilterOptions) == null ? void 0 : e.fetcher
18
+ });
19
+ }, [(o = t.fetchAsyncFilterOptions) == null ? void 0 : o.fetcher]), {
20
+ isLoading: m,
21
+ isValidating: h,
22
+ data: p,
23
+ error: f
24
+ } = L((i = t.fetchAsyncFilterOptions) == null ? void 0 : i.URL, l), r = m || h, g = O({
25
+ data: p,
26
+ config: t.fetchAsyncFilterOptions
27
+ });
28
+ return /* @__PURE__ */ n(b, { spacing: "xs", alignX: "stretch", children: [
29
+ /* @__PURE__ */ s(y, { title: t.label, options: g, selected: [c], onChange: (e) => a(`${e[0]}`) }),
30
+ r && /* @__PURE__ */ s(d, { width: "200px", height: x.sizes[5], "aria-busy": !0, "aria-label": `Loading ${t.label} filters` }),
31
+ !r && f && /* @__PURE__ */ n(A, { variant: "errorSmall", children: [
32
+ "Error: failed to load filter for ",
33
+ t.label
34
+ ] })
35
+ ] });
36
+ });
37
+ export {
38
+ w as AsyncInlineRadioFilter
39
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("react/jsx-runtime"),o=require("react"),L=require("mobx-react"),O=require("lodash/debounce"),s=require("@veeqo/ui"),R=require("swr/immutable"),j=require("./index66.cjs"),C=require("./index67.cjs"),V=require("./index7.cjs"),k=require("./index56.cjs"),d=e=>e&&e.__esModule?e:{default:e},E=d(O),v=d(R),B=L.observer(({field:e})=>{var l,u;const{FILTERS_DEBOUCE_INTERVAL_MS:h}=V.useBusinessLogic(),g=o.useMemo(()=>{var t;return C.getFetcherFunction({fetcherName:(t=e.fetchAsyncFilterOptions)==null?void 0:t.fetcher})},[(l=e.fetchAsyncFilterOptions)==null?void 0:l.fetcher]),{isLoading:F,isValidating:b,data:S,error:f}=v.default((u=e.fetchAsyncFilterOptions)==null?void 0:u.URL,g),i=F||b,{Filters:{setFilter:c,filters:m}}=k.useStores(),p=m.get(e.id),[y,a]=o.useState(p),q=o.useCallback(E.default((t,r)=>{c(t,r)},h),[c]),x=t=>{const r=`${t[0]}`;a(r),q(e.id,r)},_=()=>{a(""),c(e.id,"")},A=j.getAsyncOptions({data:S,config:e.fetchAsyncFilterOptions});return n.jsxs(s.Stack,{spacing:"xs",alignX:"stretch",children:[n.jsx(s.Button,{variant:"link",onClick:_,children:"Clear"}),n.jsx(s.ChoiceList,{title:e.label,options:A,selected:[y],onChange:t=>x(t)}),i&&n.jsx(s.Skeleton,{width:"200px",height:s.theme.sizes[5],"aria-busy":!0,"aria-label":`Loading ${e.label} filters`}),!i&&f&&n.jsxs(s.Text,{variant:"errorSmall",children:["Error: failed to load filter for ",e.label]})]})});exports.AsyncRadioFilter=B;
@@ -0,0 +1,55 @@
1
+ import { jsxs as l, jsx as s } from "react/jsx-runtime";
2
+ import { useMemo as C, useState as O, useCallback as x } from "react";
3
+ import { observer as V } from "mobx-react";
4
+ import k from "lodash/debounce";
5
+ import { Stack as E, Button as R, ChoiceList as v, Skeleton as B, theme as I, Text as T } from "@veeqo/ui";
6
+ import _ from "swr/immutable";
7
+ import { getAsyncOptions as j } from "./index66.js";
8
+ import { getFetcherFunction as w } from "./index67.js";
9
+ import { useBusinessLogic as M } from "./index7.js";
10
+ import { useStores as N } from "./index56.js";
11
+ const K = V(({
12
+ field: t
13
+ }) => {
14
+ var c, a;
15
+ const {
16
+ FILTERS_DEBOUCE_INTERVAL_MS: m
17
+ } = M(), h = C(() => {
18
+ var e;
19
+ return w({
20
+ fetcherName: (e = t.fetchAsyncFilterOptions) == null ? void 0 : e.fetcher
21
+ });
22
+ }, [(c = t.fetchAsyncFilterOptions) == null ? void 0 : c.fetcher]), {
23
+ isLoading: u,
24
+ isValidating: p,
25
+ data: f,
26
+ error: g
27
+ } = _((a = t.fetchAsyncFilterOptions) == null ? void 0 : a.URL, h), n = u || p, {
28
+ Filters: {
29
+ setFilter: o,
30
+ filters: d
31
+ }
32
+ } = N(), F = d.get(t.id), [b, i] = O(F), S = x(k((e, r) => {
33
+ o(e, r);
34
+ }, m), [o]), L = (e) => {
35
+ const r = `${e[0]}`;
36
+ i(r), S(t.id, r);
37
+ }, y = () => {
38
+ i(""), o(t.id, "");
39
+ }, A = j({
40
+ data: f,
41
+ config: t.fetchAsyncFilterOptions
42
+ });
43
+ return /* @__PURE__ */ l(E, { spacing: "xs", alignX: "stretch", children: [
44
+ /* @__PURE__ */ s(R, { variant: "link", onClick: y, children: "Clear" }),
45
+ /* @__PURE__ */ s(v, { title: t.label, options: A, selected: [b], onChange: (e) => L(e) }),
46
+ n && /* @__PURE__ */ s(B, { width: "200px", height: I.sizes[5], "aria-busy": !0, "aria-label": `Loading ${t.label} filters` }),
47
+ !n && g && /* @__PURE__ */ l(T, { variant: "errorSmall", children: [
48
+ "Error: failed to load filter for ",
49
+ t.label
50
+ ] })
51
+ ] });
52
+ });
53
+ export {
54
+ K as AsyncRadioFilter
55
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("react/jsx-runtime"),p=require("mobx-react"),i=require("react"),x=require("lodash/debounce"),o=require("@veeqo/ui"),F=require("./index7.cjs"),_=require("./index56.cjs"),q=e=>e&&e.__esModule?e:{default:e},k=q(x),j=p.observer(({field:e})=>{var u;const{FILTERS_DEBOUCE_INTERVAL_MS:l}=F.useBusinessLogic(),{Filters:{setArrayFilter:r,arrayFilters:a}}=_.useStores();if(!((u=e.options)!=null&&u.length))return null;const d=a.get(e.id)||[],[b,c]=i.useState(d),S=i.useCallback(k.default((t,s)=>{r(t,s)},l),[r]),g=t=>{const s=t.map(C=>`${C}`);c(s),S(e.id,s)},h=()=>{c([]),r(e.id,[])};return n.jsxs(o.Stack,{spacing:"xs",children:[n.jsx(o.Button,{variant:"link",onClick:h,children:"Clear"}),n.jsx(o.ChoiceList,{allowMultiple:!0,title:e.label,options:e.options,selected:b,onChange:t=>g(t)})]})});exports.CheckboxFilter=j;
@@ -0,0 +1,36 @@
1
+ import { jsxs as C, jsx as l } from "react/jsx-runtime";
2
+ import { observer as F } from "mobx-react";
3
+ import { useState as d, useCallback as S } from "react";
4
+ import b from "lodash/debounce";
5
+ import { Stack as g, Button as k, ChoiceList as x } from "@veeqo/ui";
6
+ import { useBusinessLogic as V } from "./index7.js";
7
+ import { useStores as E } from "./index56.js";
8
+ const w = F(({
9
+ field: e
10
+ }) => {
11
+ var n;
12
+ const {
13
+ FILTERS_DEBOUCE_INTERVAL_MS: i
14
+ } = V(), {
15
+ Filters: {
16
+ setArrayFilter: o,
17
+ arrayFilters: c
18
+ }
19
+ } = E();
20
+ if (!((n = e.options) != null && n.length)) return null;
21
+ const a = c.get(e.id) || [], [u, s] = d(a), m = S(b((t, r) => {
22
+ o(t, r);
23
+ }, i), [o]), p = (t) => {
24
+ const r = t.map((h) => `${h}`);
25
+ s(r), m(e.id, r);
26
+ };
27
+ return /* @__PURE__ */ C(g, { spacing: "xs", children: [
28
+ /* @__PURE__ */ l(k, { variant: "link", onClick: () => {
29
+ s([]), o(e.id, []);
30
+ }, children: "Clear" }),
31
+ /* @__PURE__ */ l(x, { allowMultiple: !0, title: e.label, options: e.options, selected: u, onChange: (t) => p(t) })
32
+ ] });
33
+ });
34
+ export {
35
+ w as CheckboxFilter
36
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("react/jsx-runtime"),P=require("react"),q=require("mobx-react"),n=require("@veeqo/ui"),E=require("./index62.cjs"),b=require("./index7.cjs"),k=require("./index56.cjs"),v=q.observer(({field:s})=>{const{DEFAULT_DATE_PRESET:c,DEFAULT_DATE_RANGE:l}=b.useBusinessLogic(),{Filters:{dateRangeFilters:i,setRangeFilter:o,clearRangeFilter:g}}=k.useStores(),e=i.get(s.id),[u,R]=P.useState(!1),d=(e==null?void 0:e.filterSelection)||c,a=()=>{const t=new E.RangeFilter;i.set(s.id,t)},F=t=>{const T=t.value===n.DateRanges.TODAY&&e&&(e==null?void 0:e.filterType)===void 0;if(!t||T)return;if(!u){R(!0);return}if(!e){a();return}if(!e)return;const f=t.value;o({dates:{start:e.gte,end:e.lte},key:f,range:e})},S=t=>{if(t){if(!e){a();return}e.setDates(t.start,t.end)}},D=()=>{g(s.id)},h=e?e.selectedRange:l;return r.jsxs(n.Stack,{spacing:"xs",children:[r.jsx(n.Button,{variant:"link",onClick:D,children:"Clear"}),r.jsx(n.DateRangePicker,{"aria-label":`date range for ${s.label}`,selectedPreset:d,setSelectedPreset:F,selectedRange:h,setSelectedRange:S})]})});exports.DateRangeFilter=v;
@@ -0,0 +1,62 @@
1
+ import { jsxs as D, jsx as i } from "react/jsx-runtime";
2
+ import { useState as S } from "react";
3
+ import { observer as T } from "mobx-react";
4
+ import { Stack as E, Button as P, DateRangePicker as k, DateRanges as A } from "@veeqo/ui";
5
+ import { RangeFilter as v } from "./index62.js";
6
+ import { useBusinessLogic as C } from "./index7.js";
7
+ import { useStores as x } from "./index56.js";
8
+ const U = T(({
9
+ field: r
10
+ }) => {
11
+ const {
12
+ DEFAULT_DATE_PRESET: a,
13
+ DEFAULT_DATE_RANGE: o
14
+ } = C(), {
15
+ Filters: {
16
+ dateRangeFilters: n,
17
+ setRangeFilter: l,
18
+ clearRangeFilter: c
19
+ }
20
+ } = x(), e = n.get(r.id), [g, d] = S(!1), R = (e == null ? void 0 : e.filterSelection) || a, s = () => {
21
+ const t = new v();
22
+ n.set(r.id, t);
23
+ }, f = (t) => {
24
+ const u = t.value === A.TODAY && e && (e == null ? void 0 : e.filterType) === void 0;
25
+ if (!t || u) return;
26
+ if (!g) {
27
+ d(!0);
28
+ return;
29
+ }
30
+ if (!e) {
31
+ s();
32
+ return;
33
+ }
34
+ if (!e) return;
35
+ const h = t.value;
36
+ l({
37
+ dates: {
38
+ start: e.gte,
39
+ end: e.lte
40
+ },
41
+ key: h,
42
+ range: e
43
+ });
44
+ }, m = (t) => {
45
+ if (t) {
46
+ if (!e) {
47
+ s();
48
+ return;
49
+ }
50
+ e.setDates(t.start, t.end);
51
+ }
52
+ }, p = () => {
53
+ c(r.id);
54
+ }, F = e ? e.selectedRange : o;
55
+ return /* @__PURE__ */ D(E, { spacing: "xs", children: [
56
+ /* @__PURE__ */ i(P, { variant: "link", onClick: p, children: "Clear" }),
57
+ /* @__PURE__ */ i(k, { "aria-label": `date range for ${r.label}`, selectedPreset: R, setSelectedPreset: f, selectedRange: F, setSelectedRange: m })
58
+ ] });
59
+ });
60
+ export {
61
+ U as DateRangeFilter
62
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("react/jsx-runtime"),o=require("mobx-react"),s=require("@veeqo/ui"),c=require("./index44.cjs"),u=require("./index19.cjs"),h=o.observer(({data:e,editedValue:r,setEditedValue:t})=>{var i;switch(e.filterType){case c.FilterChoiceValue.CHECKBOX:return e.fetchAsyncFilterOptions?n.jsx(u.AsyncInlineCheckboxFilter,{field:e,setEditedValue:t,editedValue:r}):n.jsx(s.ChoiceList,{allowMultiple:!0,title:e.label,options:(i=e.options)!=null&&i.length?e.options:[],selected:r,onChange:l=>t(l)});default:return null}});exports.FilterArrayField=h;
@@ -0,0 +1,21 @@
1
+ import { jsx as t } from "react/jsx-runtime";
2
+ import { observer as n } from "mobx-react";
3
+ import { ChoiceList as p } from "@veeqo/ui";
4
+ import { FilterChoiceValue as s } from "./index44.js";
5
+ import { AsyncInlineCheckboxFilter as c } from "./index19.js";
6
+ const F = n(({
7
+ data: r,
8
+ editedValue: e,
9
+ setEditedValue: o
10
+ }) => {
11
+ var i;
12
+ switch (r.filterType) {
13
+ case s.CHECKBOX:
14
+ return r.fetchAsyncFilterOptions ? /* @__PURE__ */ t(c, { field: r, setEditedValue: o, editedValue: e }) : /* @__PURE__ */ t(p, { allowMultiple: !0, title: r.label, options: (i = r.options) != null && i.length ? r.options : [], selected: e, onChange: (l) => o(l) });
15
+ default:
16
+ return null;
17
+ }
18
+ });
19
+ export {
20
+ F as FilterArrayField
21
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("react/jsx-runtime"),u=require("mobx-react"),s=require("@veeqo/ui"),i=require("./index44.cjs"),F=require("./index20.cjs"),h=u.observer(({data:e,editedValue:r,setEditedValue:l})=>{var c;let t;switch(e.filterType){case i.FilterChoiceValue.NUMBER:t="number";break;case i.FilterChoiceValue.TEXT:t="text";break}switch(e.filterType){case i.FilterChoiceValue.TEXT:case i.FilterChoiceValue.NUMBER:return o.jsx(s.TextField,{label:e.label,type:t,value:r,onChange:n=>l(n)});case i.FilterChoiceValue.RADIO:case i.FilterChoiceValue.DATE_RANGE:return e.fetchAsyncFilterOptions?o.jsx(F.AsyncInlineRadioFilter,{field:e,setEditedValue:l,editedValue:r}):o.jsx(s.ChoiceList,{title:e.label,options:(c=e.options)!=null&&c.length?e.options:[],selected:[r],onChange:n=>l(`${n[0]}`)});default:return null}});exports.FilterField=h;
@@ -0,0 +1,34 @@
1
+ import { jsx as n } from "react/jsx-runtime";
2
+ import { observer as c } from "mobx-react";
3
+ import { ChoiceList as p, TextField as f } from "@veeqo/ui";
4
+ import { FilterChoiceValue as r } from "./index44.js";
5
+ import { AsyncInlineRadioFilter as m } from "./index20.js";
6
+ const y = c(({
7
+ data: e,
8
+ editedValue: o,
9
+ setEditedValue: i
10
+ }) => {
11
+ var s;
12
+ let t;
13
+ switch (e.filterType) {
14
+ case r.NUMBER:
15
+ t = "number";
16
+ break;
17
+ case r.TEXT:
18
+ t = "text";
19
+ break;
20
+ }
21
+ switch (e.filterType) {
22
+ case r.TEXT:
23
+ case r.NUMBER:
24
+ return /* @__PURE__ */ n(f, { label: e.label, type: t, value: o, onChange: (l) => i(l) });
25
+ case r.RADIO:
26
+ case r.DATE_RANGE:
27
+ return e.fetchAsyncFilterOptions ? /* @__PURE__ */ n(m, { field: e, setEditedValue: i, editedValue: o }) : /* @__PURE__ */ n(p, { title: e.label, options: (s = e.options) != null && s.length ? e.options : [], selected: [o], onChange: (l) => i(`${l[0]}`) });
28
+ default:
29
+ return null;
30
+ }
31
+ });
32
+ export {
33
+ y as FilterField
34
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("react/jsx-runtime"),s=require("mobx-react"),n=require("@veeqo/ui"),c=require("@veeqo/components"),u=require("./index28.cjs"),t=require("./index44.cjs"),F=require("./index22.cjs"),a=require("./index30.cjs"),h=require("./index29.cjs"),p=require("./index23.cjs"),x=require("./index21.cjs"),y=require("./index18.cjs"),{Glyph:R}=c.VeeqoCommon,C=s.observer(({data:i})=>{const l=i.fields.filter(e=>e.filterType===t.FilterChoiceValue.TEXT||e.filterType===t.FilterChoiceValue.NUMBER),o=i.fields.filter(e=>e.filterType!==t.FilterChoiceValue.TEXT&&e.filterType!==t.FilterChoiceValue.NUMBER);return r.jsx(n.Accordion,{iconSlot:r.jsx(R,{name:"product-menu"}),label:i.label,children:r.jsxs(n.Stack,{children:[l.length>0?r.jsx(u.MultipleFieldFilter,{fields:l,groupId:i.id}):null,o.map(e=>{switch(e.filterType){case t.FilterChoiceValue.CHECKBOX:return e.fetchAsyncFilterOptions?r.jsx(y.AsyncCheckboxFilter,{field:e}):r.jsx(F.CheckboxFilter,{field:e});case t.FilterChoiceValue.RADIO:return e.fetchAsyncFilterOptions?r.jsx(x.AsyncRadioFilter,{field:e}):r.jsx(a.RadioFilter,{field:e});case t.FilterChoiceValue.DATE_RANGE:return r.jsx(p.DateRangeFilter,{field:e});case t.FilterChoiceValue.NUMBER_RANGE:return r.jsx(h.NumberRangeFilter,{field:e});default:return r.jsxs("div",{children:[e.id,": Unknown filter type: ",e.filterType]},e.id)}})]})})});exports.FilterGroup=C;
@@ -0,0 +1,43 @@
1
+ import { jsx as e, jsxs as n } from "react/jsx-runtime";
2
+ import { observer as m } from "mobx-react";
3
+ import { Accordion as p, Stack as c } from "@veeqo/ui";
4
+ import { VeeqoCommon as s } from "@veeqo/components";
5
+ import { MultipleFieldFilter as f } from "./index28.js";
6
+ import { FilterChoiceValue as t } from "./index44.js";
7
+ import { CheckboxFilter as u } from "./index22.js";
8
+ import { RadioFilter as F } from "./index30.js";
9
+ import { NumberRangeFilter as a } from "./index29.js";
10
+ import { DateRangeFilter as y } from "./index23.js";
11
+ import { AsyncRadioFilter as T } from "./index21.js";
12
+ import { AsyncCheckboxFilter as h } from "./index18.js";
13
+ const {
14
+ Glyph: R
15
+ } = s, O = m(({
16
+ data: o
17
+ }) => {
18
+ const i = o.fields.filter((r) => r.filterType === t.TEXT || r.filterType === t.NUMBER), l = o.fields.filter((r) => r.filterType !== t.TEXT && r.filterType !== t.NUMBER);
19
+ return /* @__PURE__ */ e(p, { iconSlot: /* @__PURE__ */ e(R, { name: "product-menu" }), label: o.label, children: /* @__PURE__ */ n(c, { children: [
20
+ i.length > 0 ? /* @__PURE__ */ e(f, { fields: i, groupId: o.id }) : null,
21
+ l.map((r) => {
22
+ switch (r.filterType) {
23
+ case t.CHECKBOX:
24
+ return r.fetchAsyncFilterOptions ? /* @__PURE__ */ e(h, { field: r }) : /* @__PURE__ */ e(u, { field: r });
25
+ case t.RADIO:
26
+ return r.fetchAsyncFilterOptions ? /* @__PURE__ */ e(T, { field: r }) : /* @__PURE__ */ e(F, { field: r });
27
+ case t.DATE_RANGE:
28
+ return /* @__PURE__ */ e(y, { field: r });
29
+ case t.NUMBER_RANGE:
30
+ return /* @__PURE__ */ e(a, { field: r });
31
+ default:
32
+ return /* @__PURE__ */ n("div", { children: [
33
+ r.id,
34
+ ": Unknown filter type: ",
35
+ r.filterType
36
+ ] }, r.id);
37
+ }
38
+ })
39
+ ] }) });
40
+ });
41
+ export {
42
+ O as FilterGroup
43
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("react/jsx-runtime"),p=require("mobx-react"),l=require("@veeqo/ui"),v=require("./index84.cjs"),y=p.observer(({data:m,editedValue:t,setEditedValue:c})=>{var b;if(!((b=m.options)!=null&&b.length))return null;const[u,x]=m.options,i=Number(u.value),a=Number(x.value),h=(s,n)=>{if(!Array.isArray(n)||n.length!==2||!t)return;const[e,j]=n,g=t==null?void 0:t.clone();g.setGte(e),g.setLte(j),c(g)},o={gte:(t==null?void 0:t.gte)||0,lte:(t==null?void 0:t.lte)||100},M=s=>{if(!t)return;const n=t.clone(),e=Number(s);e>n.lteMax||(e>=n.gteMin&&e<=n.lteMax&&n.setGte(e),(!n.lte||e>=n.lte)&&n.setLte(n.lteMax),c(n))},f=s=>{if(!t)return;const n=t.clone(),e=Number(s);e<n.gteMin||(e>=n.gteMin&&e<=n.lteMax&&n.setLte(e),(!n.gte||e<=n.gte)&&n.setGte(n.gteMin),c(n))},S=[o.gte,o.lte];return r.jsxs(l.Stack,{spacing:"xs",alignX:"stretch",children:[r.jsxs(l.Stack,{direction:"horizontal",children:[r.jsx(l.TextField,{label:u.label,type:"number",min:i,max:a,value:o.gte.toString(),onChange:M}),r.jsx(l.TextField,{label:x.label,type:"number",min:i,max:a,value:o.lte.toString(),onChange:f})]}),r.jsx(v.MUISlider,{value:S,onChange:h,min:i,max:a,valueLabelDisplay:"auto"})]})});exports.FilterNumberRangeFilter=y;
@@ -0,0 +1,38 @@
1
+ import { jsxs as b, jsx as a } from "react/jsx-runtime";
2
+ import { observer as N } from "mobx-react";
3
+ import { Stack as h, TextField as u } from "@veeqo/ui";
4
+ import { MUISlider as L } from "./index84.js";
5
+ const j = N(({
6
+ data: g,
7
+ editedValue: t,
8
+ setEditedValue: l
9
+ }) => {
10
+ var f;
11
+ if (!((f = g.options) != null && f.length)) return null;
12
+ const [i, x] = g.options, s = Number(i.value), c = Number(x.value), p = (e, n) => {
13
+ if (!Array.isArray(n) || n.length !== 2 || !t) return;
14
+ const [r, y] = n, m = t == null ? void 0 : t.clone();
15
+ m.setGte(r), m.setLte(y), l(m);
16
+ }, o = {
17
+ gte: (t == null ? void 0 : t.gte) || 0,
18
+ lte: (t == null ? void 0 : t.lte) || 100
19
+ }, M = (e) => {
20
+ if (!t) return;
21
+ const n = t.clone(), r = Number(e);
22
+ r > n.lteMax || (r >= n.gteMin && r <= n.lteMax && n.setGte(r), (!n.lte || r >= n.lte) && n.setLte(n.lteMax), l(n));
23
+ }, v = (e) => {
24
+ if (!t) return;
25
+ const n = t.clone(), r = Number(e);
26
+ r < n.gteMin || (r >= n.gteMin && r <= n.lteMax && n.setLte(r), (!n.gte || r <= n.gte) && n.setGte(n.gteMin), l(n));
27
+ }, C = [o.gte, o.lte];
28
+ return /* @__PURE__ */ b(h, { spacing: "xs", alignX: "stretch", children: [
29
+ /* @__PURE__ */ b(h, { direction: "horizontal", children: [
30
+ /* @__PURE__ */ a(u, { label: i.label, type: "number", min: s, max: c, value: o.gte.toString(), onChange: M }),
31
+ /* @__PURE__ */ a(u, { label: x.label, type: "number", min: s, max: c, value: o.lte.toString(), onChange: v })
32
+ ] }),
33
+ /* @__PURE__ */ a(L, { value: C, onChange: p, min: s, max: c, valueLabelDisplay: "auto" })
34
+ ] });
35
+ });
36
+ export {
37
+ j as FilterNumberRangeFilter
38
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("react/jsx-runtime"),c=require("react"),h=require("mobx-react"),o=require("@veeqo/ui"),x=require("lodash/debounce"),a=require("./index44.cjs"),E=require("./index7.cjs"),T=require("./index56.cjs"),g=r=>r&&r.__esModule?r:{default:r},k=g(x),m=h.observer(({fields:r,groupId:u})=>{const{FILTERS_DEBOUCE_INTERVAL_MS:d}=E.useBusinessLogic(),{Filters:{getFiltersForGroup:F,setFilter:l,clearFiltersForGroup:b}}=T.useStores(),p=F(u),[S,n]=c.useState(p),q=c.useCallback(k.default((e,t)=>{l(e,t)},d),[l]),C=(e,t)=>{n(s=>({...s,[e]:t})),q(e,t)},_=()=>{const e=r.reduce((t,s)=>({...t,[s.id]:""}),{});n(e),b(u)};return i.jsxs(o.Stack,{children:[i.jsx(o.Button,{variant:"link",onClick:_,children:"Clear"}),r.map(e=>{let t;switch(e.filterType){case a.FilterChoiceValue.NUMBER:t="number";break;case a.FilterChoiceValue.TEXT:t="text";break}return i.jsx(o.TextField,{type:t,value:S[e.id],label:e.label,onChange:s=>C(e.id,s)},e.id)})]})});exports.MultipleFieldFilter=m;
@@ -0,0 +1,53 @@
1
+ import { jsxs as C, jsx as c } from "react/jsx-runtime";
2
+ import { useState as E, useCallback as h } from "react";
3
+ import { observer as k } from "mobx-react";
4
+ import { Stack as S, Button as T, TextField as x } from "@veeqo/ui";
5
+ import V from "lodash/debounce";
6
+ import { FilterChoiceValue as n } from "./index44.js";
7
+ import { useBusinessLogic as f } from "./index7.js";
8
+ import { useStores as B } from "./index56.js";
9
+ const N = k(({
10
+ fields: o,
11
+ groupId: s
12
+ }) => {
13
+ const {
14
+ FILTERS_DEBOUCE_INTERVAL_MS: a
15
+ } = f(), {
16
+ Filters: {
17
+ getFiltersForGroup: u,
18
+ setFilter: i,
19
+ clearFiltersForGroup: m
20
+ }
21
+ } = B(), F = u(s), [p, l] = E(F), d = h(V((e, t) => {
22
+ i(e, t);
23
+ }, a), [i]), b = (e, t) => {
24
+ l((r) => ({
25
+ ...r,
26
+ [e]: t
27
+ })), d(e, t);
28
+ };
29
+ return /* @__PURE__ */ C(S, { children: [
30
+ /* @__PURE__ */ c(T, { variant: "link", onClick: () => {
31
+ const e = o.reduce((t, r) => ({
32
+ ...t,
33
+ [r.id]: ""
34
+ }), {});
35
+ l(e), m(s);
36
+ }, children: "Clear" }),
37
+ o.map((e) => {
38
+ let t;
39
+ switch (e.filterType) {
40
+ case n.NUMBER:
41
+ t = "number";
42
+ break;
43
+ case n.TEXT:
44
+ t = "text";
45
+ break;
46
+ }
47
+ return /* @__PURE__ */ c(x, { type: t, value: p[e.id], label: e.label, onChange: (r) => b(e.id, r) }, e.id);
48
+ })
49
+ ] });
50
+ });
51
+ export {
52
+ N as MultipleFieldFilter
53
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("react/jsx-runtime"),d=require("react"),_=require("mobx-react"),j=require("lodash/debounce"),r=require("@veeqo/ui"),L=require("./index84.cjs"),R=require("./index61.cjs"),p=require("./index7.cjs"),y=require("./index56.cjs"),v=i=>i&&i.__esModule?i:{default:i},k=v(j),I=_.observer(({field:i})=>{var M;const{FILTERS_DEBOUCE_INTERVAL_MS:f}=p.useBusinessLogic(),{Filters:{numberRangeFilters:u,setNumberRangeFilter:x,clearNumberRangeFilter:F}}=y.useStores(),e=u.get(i.id),[o,g]=d.useState({gte:(e==null?void 0:e.gte)??0,lte:(e==null?void 0:e.lte)??100});if(!((M=i.options)!=null&&M.length))return null;const b=()=>{const l=new R.NumberRangeFilter({filterId:i.id});return u.set(i.id,l),l},c=d.useCallback(k.default(({numberRange:l,lte:t,gte:n})=>{x({numberRange:l,lte:t,gte:n})},f),[x]),h=()=>{g({gte:0,lte:100}),F(i.id)},S=(l,t)=>{let n=new R.NumberRangeFilter({filterId:i.id});if(e||(n=b()),!Array.isArray(t)||t.length!==2)return;const[s,m]=t;g({gte:s,lte:m}),c(e?{numberRange:e,lte:m,gte:s}:{numberRange:n,lte:m,gte:s})},N=l=>{if(e||b(),!e)return;const t=Number(l);if(t>e.lteMax)return;let{lte:n}=e,{gte:s}=e;t>=e.gteMin&&t<=e.lteMax&&(s=t),(!e.lte||t>=e.lte)&&(n=e.lteMax),g({gte:s,lte:n}),c({numberRange:e,lte:n,gte:s})},C=l=>{if(e||b(),!e)return;const t=Number(l);if(t<e.gteMin)return;let{lte:n}=e,{gte:s}=e;t>=e.gteMin&&t<=e.lteMax&&(n=t),(!e.gte||t<=e.gte)&&(s=e.gteMin),g({gte:s,lte:n}),c({numberRange:e,lte:n,gte:s})},q=[o.gte,o.lte];return a.jsxs(r.Stack,{spacing:"xs",alignX:"stretch",children:[a.jsx(r.Button,{variant:"link",onClick:h,children:"Clear"}),a.jsxs(r.Stack,{direction:"horizontal",children:[a.jsx(r.TextField,{label:e==null?void 0:e.gteMinLabel,type:"number",min:e==null?void 0:e.gteMin,max:e==null?void 0:e.lteMax,value:o.gte.toString(),onChange:N}),a.jsx(r.TextField,{label:e==null?void 0:e.lteMaxLabel,type:"number",min:e==null?void 0:e.gteMin,max:e==null?void 0:e.lteMax,value:o.lte.toString(),onChange:C})]}),a.jsx(L.MUISlider,{value:q,onChange:S,min:e==null?void 0:e.gteMin,max:e==null?void 0:e.lteMax,valueLabelDisplay:"auto"})]})});exports.NumberRangeFilter=I;
@@ -0,0 +1,111 @@
1
+ import { jsxs as R, jsx as s } from "react/jsx-runtime";
2
+ import { useState as y, useCallback as I } from "react";
3
+ import { observer as k } from "mobx-react";
4
+ import E from "lodash/debounce";
5
+ import { Stack as c, Button as _, TextField as p } from "@veeqo/ui";
6
+ import { MUISlider as A } from "./index84.js";
7
+ import { NumberRangeFilter as h } from "./index61.js";
8
+ import { useBusinessLogic as B } from "./index7.js";
9
+ import { useStores as T } from "./index56.js";
10
+ const q = k(({
11
+ field: l
12
+ }) => {
13
+ var x;
14
+ const {
15
+ FILTERS_DEBOUCE_INTERVAL_MS: F
16
+ } = B(), {
17
+ Filters: {
18
+ numberRangeFilters: f,
19
+ setNumberRangeFilter: M,
20
+ clearNumberRangeFilter: d
21
+ }
22
+ } = T(), e = f.get(l.id), [a, r] = y({
23
+ gte: (e == null ? void 0 : e.gte) ?? 0,
24
+ lte: (e == null ? void 0 : e.lte) ?? 100
25
+ });
26
+ if (!((x = l.options) != null && x.length)) return null;
27
+ const m = () => {
28
+ const o = new h({
29
+ filterId: l.id
30
+ });
31
+ return f.set(l.id, o), o;
32
+ }, g = I(E(({
33
+ numberRange: o,
34
+ lte: t,
35
+ gte: i
36
+ }) => {
37
+ M({
38
+ numberRange: o,
39
+ lte: t,
40
+ gte: i
41
+ });
42
+ }, F), [M]), C = () => {
43
+ r({
44
+ gte: 0,
45
+ lte: 100
46
+ }), d(l.id);
47
+ }, N = (o, t) => {
48
+ let i = new h({
49
+ filterId: l.id
50
+ });
51
+ if (e || (i = m()), !Array.isArray(t) || t.length !== 2) return;
52
+ const [n, b] = t;
53
+ r({
54
+ gte: n,
55
+ lte: b
56
+ }), g(e ? {
57
+ numberRange: e,
58
+ lte: b,
59
+ gte: n
60
+ } : {
61
+ numberRange: i,
62
+ lte: b,
63
+ gte: n
64
+ });
65
+ }, S = (o) => {
66
+ if (e || m(), !e) return;
67
+ const t = Number(o);
68
+ if (t > e.lteMax) return;
69
+ let {
70
+ lte: i
71
+ } = e, {
72
+ gte: n
73
+ } = e;
74
+ t >= e.gteMin && t <= e.lteMax && (n = t), (!e.lte || t >= e.lte) && (i = e.lteMax), r({
75
+ gte: n,
76
+ lte: i
77
+ }), g({
78
+ numberRange: e,
79
+ lte: i,
80
+ gte: n
81
+ });
82
+ }, L = (o) => {
83
+ if (e || m(), !e) return;
84
+ const t = Number(o);
85
+ if (t < e.gteMin) return;
86
+ let {
87
+ lte: i
88
+ } = e, {
89
+ gte: n
90
+ } = e;
91
+ t >= e.gteMin && t <= e.lteMax && (i = t), (!e.gte || t <= e.gte) && (n = e.gteMin), r({
92
+ gte: n,
93
+ lte: i
94
+ }), g({
95
+ numberRange: e,
96
+ lte: i,
97
+ gte: n
98
+ });
99
+ }, v = [a.gte, a.lte];
100
+ return /* @__PURE__ */ R(c, { spacing: "xs", alignX: "stretch", children: [
101
+ /* @__PURE__ */ s(_, { variant: "link", onClick: C, children: "Clear" }),
102
+ /* @__PURE__ */ R(c, { direction: "horizontal", children: [
103
+ /* @__PURE__ */ s(p, { label: e == null ? void 0 : e.gteMinLabel, type: "number", min: e == null ? void 0 : e.gteMin, max: e == null ? void 0 : e.lteMax, value: a.gte.toString(), onChange: S }),
104
+ /* @__PURE__ */ s(p, { label: e == null ? void 0 : e.lteMaxLabel, type: "number", min: e == null ? void 0 : e.gteMin, max: e == null ? void 0 : e.lteMax, value: a.lte.toString(), onChange: L })
105
+ ] }),
106
+ /* @__PURE__ */ s(A, { value: v, onChange: N, min: e == null ? void 0 : e.gteMin, max: e == null ? void 0 : e.lteMax, valueLabelDisplay: "auto" })
107
+ ] });
108
+ });
109
+ export {
110
+ q as NumberRangeFilter
111
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./index6.cjs"),t=require("./index48.cjs"),s=require("./index49.cjs"),n=(r={})=>e.axios.patch("/current_user",{user:r},t.withCSRF(s.vndAPI));exports.patchCurrentUser=n;
package/dist/index3.js ADDED
@@ -0,0 +1,9 @@
1
+ import { axios as t } from "./index6.js";
2
+ import { withCSRF as o } from "./index48.js";
3
+ import { vndAPI as e } from "./index49.js";
4
+ const s = (r = {}) => t.patch("/current_user", {
5
+ user: r
6
+ }, o(e));
7
+ export {
8
+ s as patchCurrentUser
9
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("react/jsx-runtime"),h=require("mobx-react"),u=require("react"),q=require("lodash/debounce"),r=require("@veeqo/ui"),C=require("./index7.cjs"),F=require("./index56.cjs"),p=e=>e&&e.__esModule?e:{default:e},x=p(q),R=h.observer(({field:e})=>{var i;const{FILTERS_DEBOUCE_INTERVAL_MS:l}=C.useBusinessLogic(),{Filters:{setFilter:n,filters:a}}=F.useStores();if(!((i=e.options)!=null&&i.length))return null;const d=a.get(e.id),[S,c]=u.useState(d),b=u.useCallback(x.default((t,s)=>{n(t,s)},l),[n]),g=t=>{const s=`${t[0]}`;c(s),b(e.id,s)},_=()=>{c(""),n(e.id,"")};return o.jsxs(r.Stack,{spacing:"xs",children:[o.jsx(r.Button,{variant:"link",onClick:_,children:"Clear"}),o.jsx(r.ChoiceList,{title:e.label,options:e.options,selected:[S],onChange:t=>g(t)})]})});exports.RadioFilter=R;
@@ -0,0 +1,36 @@
1
+ import { jsxs as d, jsx as i } from "react/jsx-runtime";
2
+ import { observer as h } from "mobx-react";
3
+ import { useState as C, useCallback as F } from "react";
4
+ import S from "lodash/debounce";
5
+ import { Stack as g, Button as b, ChoiceList as V } from "@veeqo/ui";
6
+ import { useBusinessLogic as f } from "./index7.js";
7
+ import { useStores as k } from "./index56.js";
8
+ const I = h(({
9
+ field: e
10
+ }) => {
11
+ var n;
12
+ const {
13
+ FILTERS_DEBOUCE_INTERVAL_MS: c
14
+ } = f(), {
15
+ Filters: {
16
+ setFilter: r,
17
+ filters: l
18
+ }
19
+ } = k();
20
+ if (!((n = e.options) != null && n.length)) return null;
21
+ const a = l.get(e.id), [u, s] = C(a), m = F(S((t, o) => {
22
+ r(t, o);
23
+ }, c), [r]), p = (t) => {
24
+ const o = `${t[0]}`;
25
+ s(o), m(e.id, o);
26
+ };
27
+ return /* @__PURE__ */ d(g, { spacing: "xs", children: [
28
+ /* @__PURE__ */ i(b, { variant: "link", onClick: () => {
29
+ s(""), r(e.id, "");
30
+ }, children: "Clear" }),
31
+ /* @__PURE__ */ i(V, { title: e.label, options: e.options, selected: [u], onChange: (t) => p(t) })
32
+ ] });
33
+ });
34
+ export {
35
+ I as RadioFilter
36
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),t=require("mobx-react"),s=require("@veeqo/ui"),i=require("@veeqo/components"),l=require("./index32.cjs"),n=require("./index56.cjs"),{Glyph:d}=i.VeeqoCommon,c=t.observer(()=>{const{Filters:{isFiltersDropdownVisible:o,toggleFiltersDropdownVisible:r}}=n.useStores();return e.jsx(s.Dropdown,{id:"filters-dropdown",ctaProps:{iconSlot:e.jsx(d,{name:"filter"}),children:"Filters",loading:!1,disabled:!1,className:"act-toggle-filter",style:{borderRadius:s.theme.radius.base}},style:{padding:0},shouldShow:o,setShouldShow:r,children:e.jsx(l.FiltersList,{})})});exports.FiltersDropdown=c;
@@ -0,0 +1,33 @@
1
+ import { jsx as o } from "react/jsx-runtime";
2
+ import { observer as s } from "mobx-react";
3
+ import { Dropdown as t, theme as i } from "@veeqo/ui";
4
+ import { VeeqoCommon as l } from "@veeqo/components";
5
+ import { FiltersList as d } from "./index32.js";
6
+ import { useStores as m } from "./index56.js";
7
+ const {
8
+ Glyph: n
9
+ } = l, b = s(() => {
10
+ const {
11
+ Filters: {
12
+ isFiltersDropdownVisible: r,
13
+ toggleFiltersDropdownVisible: e
14
+ }
15
+ } = m();
16
+ return /* @__PURE__ */ o(t, { id: "filters-dropdown", ctaProps: {
17
+ iconSlot: /* @__PURE__ */ o(n, { name: "filter" }),
18
+ children: "Filters",
19
+ loading: !1,
20
+ // TODO needs implementing?
21
+ disabled: !1,
22
+ // TODO needs implementing?
23
+ className: "act-toggle-filter",
24
+ style: {
25
+ borderRadius: i.radius.base
26
+ }
27
+ }, style: {
28
+ padding: 0
29
+ }, shouldShow: r, setShouldShow: e, children: /* @__PURE__ */ o(d, {}) });
30
+ });
31
+ export {
32
+ b as FiltersDropdown
33
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),s=require("mobx-react"),n=require("@veeqo/ui"),o=require("./index26.cjs"),u=require("./index7.cjs"),c=require("./index75.cjs"),a=s.observer(()=>{const{GROUP_MAP:t}=u.useBusinessLogic();return e.jsx(c.AdaptiveHeightContainer,{style:{minWidth:"360px"},children:e.jsx(n.Stack,{alignX:"stretch",children:Array.from(t).map(([r,i])=>e.jsx(o.FilterGroup,{data:i},r))})})});exports.FiltersList=a;