@bynder/compact-view 5.1.2 → 5.1.4

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 (377) hide show
  1. package/ActiveFilter.js +33 -0
  2. package/ActiveFilter.js.map +1 -0
  3. package/ActiveFilters.js +81 -0
  4. package/ActiveFilters.js.map +1 -0
  5. package/AddMedia.js +90 -0
  6. package/AddMedia.js.map +1 -0
  7. package/Advanced.js +66 -0
  8. package/Advanced.js.map +1 -0
  9. package/App.d.ts +1 -1
  10. package/App.js +89 -0
  11. package/App.js.map +1 -0
  12. package/AssetCard.js +172 -0
  13. package/AssetCard.js.map +1 -0
  14. package/AssetCardMetaproperties.js +47 -0
  15. package/AssetCardMetaproperties.js.map +1 -0
  16. package/AssetFilter.js +158 -0
  17. package/AssetFilter.js.map +1 -0
  18. package/AssetFilterContext.js +162 -0
  19. package/AssetFilterContext.js.map +1 -0
  20. package/AssetItem.js +40 -0
  21. package/AssetItem.js.map +1 -0
  22. package/AssetList.js +158 -0
  23. package/AssetList.js.map +1 -0
  24. package/AssetTypeItem.js +34 -0
  25. package/AssetTypeItem.js.map +1 -0
  26. package/AssetsView.js +61 -0
  27. package/AssetsView.js.map +1 -0
  28. package/Autocomplete.js +148 -0
  29. package/Autocomplete.js.map +1 -0
  30. package/ButtonAction.js +14 -0
  31. package/ButtonAction.js.map +1 -0
  32. package/CardSkeleton.js +31 -0
  33. package/CardSkeleton.js.map +1 -0
  34. package/Checkbox.styles.js +38 -0
  35. package/Checkbox.styles.js.map +1 -0
  36. package/Chip.js +43 -0
  37. package/Chip.js.map +1 -0
  38. package/CollectionCard.js +56 -0
  39. package/CollectionCard.js.map +1 -0
  40. package/CollectionItem.js +41 -0
  41. package/CollectionItem.js.map +1 -0
  42. package/CollectionList.js +53 -0
  43. package/CollectionList.js.map +1 -0
  44. package/CollectionView.js +73 -0
  45. package/CollectionView.js.map +1 -0
  46. package/CollectionsView.js +58 -0
  47. package/CollectionsView.js.map +1 -0
  48. package/ConfigContext.js +18 -0
  49. package/ConfigContext.js.map +1 -0
  50. package/ConnectButton.js +20 -0
  51. package/ConnectButton.js.map +1 -0
  52. package/Container.js +52 -0
  53. package/Container.js.map +1 -0
  54. package/ContextAction.js +42 -0
  55. package/ContextAction.js.map +1 -0
  56. package/Dat/Dat.d.ts +2 -12
  57. package/Dat/DatDropdownItem.d.ts +1 -1
  58. package/Dat/index.d.ts +0 -1
  59. package/Dat/types.d.ts +1 -1
  60. package/Dat.js +90 -0
  61. package/Dat.js.map +1 -0
  62. package/DatDropdownItem.js +47 -0
  63. package/DatDropdownItem.js.map +1 -0
  64. package/DesignSystemContext.js +12 -0
  65. package/DesignSystemContext.js.map +1 -0
  66. package/DirectionSelect.js +43 -0
  67. package/DirectionSelect.js.map +1 -0
  68. package/DocumentIcon.js +69 -0
  69. package/DocumentIcon.js.map +1 -0
  70. package/DomainInput.js +39 -0
  71. package/DomainInput.js.map +1 -0
  72. package/DragSelect.js +144 -0
  73. package/DragSelect.js.map +1 -0
  74. package/Dropdown.js +72 -0
  75. package/Dropdown.js.map +1 -0
  76. package/DropdownContent.js +59 -0
  77. package/DropdownContent.js.map +1 -0
  78. package/DropdownListItem.js +52 -0
  79. package/DropdownListItem.js.map +1 -0
  80. package/ErrorIcon.js +48 -0
  81. package/ErrorIcon.js.map +1 -0
  82. package/ErrorMessage.js +40 -0
  83. package/ErrorMessage.js.map +1 -0
  84. package/FieldSelect.js +74 -0
  85. package/FieldSelect.js.map +1 -0
  86. package/FileSelector.js +239 -0
  87. package/FileSelector.js.map +1 -0
  88. package/Header.js +42 -0
  89. package/Header.js.map +1 -0
  90. package/HorizontalScroll.js +51 -0
  91. package/HorizontalScroll.js.map +1 -0
  92. package/InfiniteScroll.js +26 -0
  93. package/InfiniteScroll.js.map +1 -0
  94. package/LeftArrow.js +31 -0
  95. package/LeftArrow.js.map +1 -0
  96. package/LoginComponent.js +32 -0
  97. package/LoginComponent.js.map +1 -0
  98. package/LoginContext.js +85 -0
  99. package/LoginContext.js.map +1 -0
  100. package/MetapropertyFilterContent.js +25 -0
  101. package/MetapropertyFilterContent.js.map +1 -0
  102. package/MetapropertyOption.js +24 -0
  103. package/MetapropertyOption.js.map +1 -0
  104. package/Modal.js +48 -0
  105. package/Modal.js.map +1 -0
  106. package/NoResults.js +51 -0
  107. package/NoResults.js.map +1 -0
  108. package/Oops.js +54 -0
  109. package/Oops.js.map +1 -0
  110. package/Option.js +50 -0
  111. package/Option.js.map +1 -0
  112. package/RefreshingSpinner.js +22 -0
  113. package/RefreshingSpinner.js.map +1 -0
  114. package/ReportModal.js +51 -0
  115. package/ReportModal.js.map +1 -0
  116. package/RightArrow.js +31 -0
  117. package/RightArrow.js.map +1 -0
  118. package/RootElementContext.js +12 -0
  119. package/RootElementContext.js.map +1 -0
  120. package/SearchInput.js +76 -0
  121. package/SearchInput.js.map +1 -0
  122. package/SelectedItemContainer.js +44 -0
  123. package/SelectedItemContainer.js.map +1 -0
  124. package/SelectedItems.js +27 -0
  125. package/SelectedItems.js.map +1 -0
  126. package/SelectionContext.js +144 -0
  127. package/SelectionContext.js.map +1 -0
  128. package/SelectionFooter.js +65 -0
  129. package/SelectionFooter.js.map +1 -0
  130. package/ShadowRoot.js +11 -0
  131. package/ShadowRoot.js.map +1 -0
  132. package/ShadowRootInternal.js +78 -0
  133. package/ShadowRootInternal.js.map +1 -0
  134. package/Shield.js +25 -0
  135. package/Shield.js.map +1 -0
  136. package/Skeleton.js +43 -0
  137. package/Skeleton.js.map +1 -0
  138. package/SmartFilterContent.js +11 -0
  139. package/SmartFilterContent.js.map +1 -0
  140. package/SmartFilterSelect.js +91 -0
  141. package/SmartFilterSelect.js.map +1 -0
  142. package/Smartfilters.js +186 -0
  143. package/Smartfilters.js.map +1 -0
  144. package/Spinner.js +32 -0
  145. package/Spinner.js.map +1 -0
  146. package/StatefulAssetList.js +100 -0
  147. package/StatefulAssetList.js.map +1 -0
  148. package/Styles.css.js +5 -0
  149. package/Styles.css.js.map +1 -0
  150. package/SwitchNLS.js +80 -0
  151. package/SwitchNLS.js.map +1 -0
  152. package/TagItem.js +38 -0
  153. package/TagItem.js.map +1 -0
  154. package/Tags.js +48 -0
  155. package/Tags.js.map +1 -0
  156. package/Theming.js +30 -0
  157. package/Theming.js.map +1 -0
  158. package/Toolbar.js +53 -0
  159. package/Toolbar.js.map +1 -0
  160. package/Tooltip.js +81 -0
  161. package/Tooltip.js.map +1 -0
  162. package/ViewSwitch.js +45 -0
  163. package/ViewSwitch.js.map +1 -0
  164. package/api/filterAssets.d.ts +1 -1
  165. package/api/getCollections.d.ts +1 -1
  166. package/api/getFilters.d.ts +1 -1
  167. package/api/getSimilarityAssets.d.ts +1 -1
  168. package/api/index.d.ts +2 -2
  169. package/api/rest/autocomplete.d.ts +1 -1
  170. package/api/rest/getAssetCounts.d.ts +2 -2
  171. package/api/rest/getInitialFilters.d.ts +2 -2
  172. package/api/rest/getMetapropertiesOptions.d.ts +1 -1
  173. package/app-config/ConfigContext.d.ts +3 -4
  174. package/app-config/appConfig.type.guard.d.ts +1 -1
  175. package/asset.type.js +31 -0
  176. package/asset.type.js.map +1 -0
  177. package/asyncDebounce.js +14 -0
  178. package/asyncDebounce.js.map +1 -0
  179. package/auth.js +35 -0
  180. package/auth.js.map +1 -0
  181. package/autocomplete2.js +25 -0
  182. package/autocomplete2.js.map +1 -0
  183. package/base64Converter.js +15 -0
  184. package/base64Converter.js.map +1 -0
  185. package/chunk.js +10 -0
  186. package/chunk.js.map +1 -0
  187. package/class.js +7 -0
  188. package/class.js.map +1 -0
  189. package/combineFilters.js +9 -0
  190. package/combineFilters.js.map +1 -0
  191. package/combineMetaproperties.js +25 -0
  192. package/combineMetaproperties.js.map +1 -0
  193. package/common/components/CardSkeleton.d.ts +1 -1
  194. package/common/components/Checkbox.styles.d.ts +4 -4
  195. package/common/components/Chip.d.ts +1 -1
  196. package/common/components/DocumentIcon.d.ts +1 -1
  197. package/common/components/DragSelect.d.ts +1 -1
  198. package/common/components/HorizontalScroll.d.ts +1 -1
  199. package/common/components/InfiniteScroll.d.ts +1 -1
  200. package/common/components/LeftArrow.d.ts +1 -1
  201. package/common/components/Modal.d.ts +1 -1
  202. package/common/components/NoResults.d.ts +1 -1
  203. package/common/components/RightArrow.d.ts +1 -1
  204. package/common/components/Skeleton.d.ts +1 -1
  205. package/common/components/Spinner.d.ts +1 -1
  206. package/common/components/Tooltip.d.ts +1 -1
  207. package/common/components/dropdown/Dropdown.d.ts +1 -1
  208. package/common/components/dropdown/DropdownContent.d.ts +1 -1
  209. package/common/components/dropdown/DropdownListItem.d.ts +1 -1
  210. package/common/hooks/useClickOutside.d.ts +1 -1
  211. package/constants.js +15 -0
  212. package/constants.js.map +1 -0
  213. package/createSelectors.js +11 -0
  214. package/createSelectors.js.map +1 -0
  215. package/crypto.js +21 -0
  216. package/crypto.js.map +1 -0
  217. package/error-handling/ErrorIcon.d.ts +1 -1
  218. package/error-handling/ErrorMessage.d.ts +1 -1
  219. package/error-handling/Oops.d.ts +1 -1
  220. package/error-handling/ReportModal.d.ts +1 -1
  221. package/error-handling/Shield.d.ts +1 -1
  222. package/filter/AssetFilter.d.ts +1 -1
  223. package/filter/AssetFilterContext.d.ts +3 -3
  224. package/filter/active-filters/ActiveFilter.d.ts +1 -1
  225. package/filter/active-filters/ActiveFilters.d.ts +1 -1
  226. package/filter/filters/advanced/Advanced.d.ts +1 -1
  227. package/filter/filters/advanced/AssetTypeItem.d.ts +1 -1
  228. package/filter/filters/metaproperty/Metaproperty.d.ts +1 -1
  229. package/filter/filters/metaproperty/MetapropertyFilterContent.d.ts +1 -1
  230. package/filter/filters/metaproperty/MetapropertyOption.d.ts +1 -1
  231. package/filter/filters/metaproperty/SmartFilterContent.d.ts +1 -1
  232. package/filter/filters/smartfilters/Metaproperties/Autocomplete.d.ts +3 -3
  233. package/filter/filters/smartfilters/Metaproperties/Option.d.ts +2 -2
  234. package/filter/filters/smartfilters/Metaproperties/SmartFilterSelect.d.ts +2 -2
  235. package/filter/filters/smartfilters/Smartfilters.d.ts +2 -2
  236. package/filter/filters/tags/TagItem.d.ts +1 -1
  237. package/filter/filters/tags/Tags.d.ts +1 -1
  238. package/filterAssets.js +175 -0
  239. package/filterAssets.js.map +1 -0
  240. package/filterEmptyMetaproperties.js +11 -0
  241. package/filterEmptyMetaproperties.js.map +1 -0
  242. package/getAsset.js +70 -0
  243. package/getAsset.js.map +1 -0
  244. package/getAssetCounts.js +27 -0
  245. package/getAssetCounts.js.map +1 -0
  246. package/getAssets.js +137 -0
  247. package/getAssets.js.map +1 -0
  248. package/getCollections.js +78 -0
  249. package/getCollections.js.map +1 -0
  250. package/getFilters.js +84 -0
  251. package/getFilters.js.map +1 -0
  252. package/getInitialFilters.js +51 -0
  253. package/getInitialFilters.js.map +1 -0
  254. package/getMetapropertiesOptions.js +31 -0
  255. package/getMetapropertiesOptions.js.map +1 -0
  256. package/getSimilarityAssets.js +141 -0
  257. package/getSimilarityAssets.js.map +1 -0
  258. package/handlers.js +11 -0
  259. package/handlers.js.map +1 -0
  260. package/helpers.js +7 -0
  261. package/helpers.js.map +1 -0
  262. package/index.js +9 -1162
  263. package/index.js.map +1 -0
  264. package/index2.js +18 -0
  265. package/index2.js.map +1 -0
  266. package/index3.js +36 -0
  267. package/index3.js.map +1 -0
  268. package/index4.js +20 -0
  269. package/index4.js.map +1 -0
  270. package/logger.js +7 -0
  271. package/logger.js.map +1 -0
  272. package/login/LoginComponent.d.ts +1 -1
  273. package/login/LoginContext.d.ts +1 -1
  274. package/login/components/ConnectButton.d.ts +1 -1
  275. package/login/components/Container.d.ts +1 -1
  276. package/login/components/DomainInput.d.ts +1 -1
  277. package/login/components/Header.d.ts +1 -1
  278. package/login/components/RefreshingSpinner.d.ts +1 -1
  279. package/loginwindow.js +84 -0
  280. package/loginwindow.js.map +1 -0
  281. package/normalizeResponse.js +31 -0
  282. package/normalizeResponse.js.map +1 -0
  283. package/oauth2.js +87 -0
  284. package/oauth2.js.map +1 -0
  285. package/order/DirectionSelect.d.ts +1 -1
  286. package/order/FieldSelect.d.ts +2 -2
  287. package/package.json +2 -9
  288. package/result.type.js +25 -0
  289. package/result.type.js.map +1 -0
  290. package/router/RouterContext.d.ts +1 -1
  291. package/search/SearchInput.d.ts +1 -1
  292. package/search/SwitchNLS.d.ts +1 -1
  293. package/search/index.d.ts +0 -2
  294. package/select/FileSelector.d.ts +1 -1
  295. package/select/SelectionContext.d.ts +1 -1
  296. package/select/SelectionFooter.d.ts +1 -1
  297. package/select/add-media/AddMedia.d.ts +1 -1
  298. package/select/add-media/ButtonAction.d.ts +1 -1
  299. package/select/current-selection/AssetItem.d.ts +1 -1
  300. package/select/current-selection/CollectionItem.d.ts +1 -1
  301. package/select/current-selection/SelectedItemContainer.d.ts +1 -1
  302. package/select/current-selection/SelectedItems.d.ts +1 -1
  303. package/store/useDatStore.d.ts +73 -0
  304. package/store/useOrderingStore.d.ts +2 -2
  305. package/store/useRouterStore.d.ts +4 -4
  306. package/store/useSearchStore.d.ts +69 -0
  307. package/store/useSimilaritySearchStore.d.ts +67 -0
  308. package/style/DesignSystemContext.d.ts +1 -1
  309. package/style/RootElementContext.d.ts +1 -1
  310. package/style/Theming.d.ts +1 -1
  311. package/style/shadowroot/ShadowRoot.d.ts +1 -1
  312. package/style/shadowroot/ShadowRootInternal.d.ts +1 -1
  313. package/text.js +9 -0
  314. package/text.js.map +1 -0
  315. package/toolbar/Toolbar.d.ts +1 -1
  316. package/toolbar/ViewSwitch.d.ts +1 -1
  317. package/trimMetapropertyValue.js +6 -0
  318. package/trimMetapropertyValue.js.map +1 -0
  319. package/url.js +7 -0
  320. package/url.js.map +1 -0
  321. package/useAccountDomain.js +33 -0
  322. package/useAccountDomain.js.map +1 -0
  323. package/useAuthInformation.js +42 -0
  324. package/useAuthInformation.js.map +1 -0
  325. package/useClickOutside.js +16 -0
  326. package/useClickOutside.js.map +1 -0
  327. package/useDatStore.js +62 -0
  328. package/useDatStore.js.map +1 -0
  329. package/useDimensions.js +31 -0
  330. package/useDimensions.js.map +1 -0
  331. package/useOrderingStore.js +27 -0
  332. package/useOrderingStore.js.map +1 -0
  333. package/useRouterStore.js +21 -0
  334. package/useRouterStore.js.map +1 -0
  335. package/useSearchStore.js +49 -0
  336. package/useSearchStore.js.map +1 -0
  337. package/useSimilaritySearchStore.js +28 -0
  338. package/useSimilaritySearchStore.js.map +1 -0
  339. package/utils/base64Converter.d.ts +1 -1
  340. package/utils/combineFilters.d.ts +1 -1
  341. package/utils/combineMetaproperties.d.ts +2 -2
  342. package/utils/filterEmptyMetaproperties.d.ts +1 -1
  343. package/utils/getMetaPropertiesForFilter.d.ts +1 -1
  344. package/utils/normalizeResponse.d.ts +1 -1
  345. package/utils.js +49 -0
  346. package/utils.js.map +1 -0
  347. package/utils2.js +51 -0
  348. package/utils2.js.map +1 -0
  349. package/views/asset/AssetList.d.ts +5 -3
  350. package/views/asset/AssetsView.d.ts +1 -1
  351. package/views/asset/StatefulAssetList.d.ts +2 -2
  352. package/views/asset/asset-card/AssetCard.d.ts +1 -1
  353. package/views/asset/asset-card/AssetCardMetaproperties.d.ts +3 -3
  354. package/views/asset/asset-card/ContextAction.d.ts +1 -1
  355. package/views/collection/CollectionView.d.ts +1 -1
  356. package/views/collections/CollectionCard.d.ts +1 -1
  357. package/views/collections/CollectionList.d.ts +1 -1
  358. package/views/collections/CollectionsView.d.ts +1 -1
  359. package/Dat/DatContext.d.ts +0 -12
  360. package/__tests__/utils/index.d.ts +0 -116
  361. package/api/__tests__/testMocks/mocks.d.ts +0 -14
  362. package/api/__tests__/utils.d.ts +0 -10
  363. package/common/components/__mocks__/Tooltip.d.ts +0 -6
  364. package/common/components/__tests__/utils.d.ts +0 -34
  365. package/error-handling/__tests__/utils.d.ts +0 -56
  366. package/filter/__tests__/utils.d.ts +0 -13
  367. package/index.mjs +0 -1163
  368. package/login/__tests__/mocks.d.ts +0 -1
  369. package/login/__tests__/utils.d.ts +0 -41
  370. package/search/SearchContext.d.ts +0 -25
  371. package/search/SimilaritySearchContext.d.ts +0 -21
  372. package/search/__mocks__/SimilaritySearchContext.d.ts +0 -5
  373. package/select/__tests__/utils.d.ts +0 -11
  374. package/style/shadowroot/__mocks__/ShadowRoot.d.ts +0 -4
  375. package/utils/__mocks__/logger.d.ts +0 -4
  376. package/views/asset/__tests__/utils.d.ts +0 -7
  377. package/views/collections/__tests__/utils.d.ts +0 -5
package/getAsset.js ADDED
@@ -0,0 +1,70 @@
1
+ import { isErr as d, ok as o } from "./result.type.js";
2
+ import { fetchWithGraphql as l } from "./index3.js";
3
+ const p = `
4
+ id
5
+ name
6
+ description
7
+ databaseId
8
+ createdAt
9
+ originalUrl
10
+ publishedAt
11
+ tags
12
+ type
13
+ updatedAt
14
+ url
15
+ extensions
16
+ metaproperties {
17
+ nodes {
18
+ name
19
+ type
20
+ options {
21
+ name
22
+ displayLabel
23
+ }
24
+ }
25
+ }
26
+ textMetaproperties {
27
+ name
28
+ value
29
+ }
30
+ derivatives {
31
+ thumbnail
32
+ webImage
33
+ }
34
+ ... on Video {
35
+ previewUrls
36
+ streamingLinks {
37
+ dash,
38
+ hls
39
+ }
40
+ }
41
+ `;
42
+ async function A(t) {
43
+ const { assetId: s, auth: i, assetFieldSelection: a = p, noCache: n } = t, r = `
44
+ fragment AddMediaAsset on Asset {
45
+ ${a}
46
+ }
47
+
48
+ query getAssetById($id: ID!) {
49
+ node(id: $id) {
50
+ __typename
51
+ id
52
+ ...on Asset {
53
+ ...AddMediaAsset
54
+ files
55
+ }
56
+ }
57
+ }`, e = await l({
58
+ query: r,
59
+ variables: { id: s },
60
+ auth: i,
61
+ noCache: n,
62
+ isNewGQL: !0
63
+ });
64
+ return d(e) ? e : o(e.value.node);
65
+ }
66
+ export {
67
+ p as defaultAssetFieldSelection,
68
+ A as getAsset
69
+ };
70
+ //# sourceMappingURL=getAsset.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getAsset.js","sources":["../../src/api/getAsset.ts"],"sourcesContent":["import { isErr, ok, Result } from '../auth/result.type';\nimport { fetchWithGraphql } from '.';\nimport { File } from '../select/file.type';\nimport { AuthInformationState } from '../auth/useAuthInformation';\n\nexport const defaultAssetFieldSelection = `\n id\n name\n description\n databaseId\n createdAt\n originalUrl\n publishedAt\n tags\n type\n updatedAt\n url\n extensions\n metaproperties {\n nodes {\n name\n type\n options {\n name\n displayLabel\n }\n }\n }\n textMetaproperties {\n name\n value\n }\n derivatives {\n thumbnail\n webImage\n }\n ... on Video {\n previewUrls\n streamingLinks {\n dash,\n hls\n }\n }\n`;\n\ninterface Data {\n\tnode: Asset;\n}\n\n// TODO: see if we can get type automatically from GraphQL schema\nexport interface StreamingLinks {\n\thls: string;\n\tdash: string;\n}\nexport interface Asset {\n\tid: string;\n\tfiles: Record<string, File>;\n\tdatabaseId?: string;\n\tstreamingLinks?: StreamingLinks;\n}\n\nexport async function getAsset(options: {\n\tassetId: string;\n\tauth: AuthInformationState | null;\n\tassetFieldSelection?: string;\n\tnoCache?: boolean;\n}): Promise<Result<Asset, string>> {\n\tconst { assetId, auth, assetFieldSelection = defaultAssetFieldSelection, noCache } = options;\n\tconst query = `\n fragment AddMediaAsset on Asset {\n ${assetFieldSelection}\n }\n\n query getAssetById($id: ID!) {\n node(id: $id) {\n __typename\n id\n ...on Asset {\n ...AddMediaAsset\n files\n }\n }\n }`;\n\n\tconst variables = { id: assetId };\n\n\tconst queryResponse = (await fetchWithGraphql({\n\t\tquery,\n\t\tvariables,\n\t\tauth,\n\t\tnoCache,\n\t\tisNewGQL: true,\n\t})) as Result<Data, string>;\n\n\tif (isErr(queryResponse)) {\n\t\treturn queryResponse;\n\t}\n\n\treturn ok(queryResponse.value.node);\n}\n"],"names":["defaultAssetFieldSelection","getAsset","options","assetId","auth","assetFieldSelection","noCache","query","queryResponse","fetchWithGraphql","isErr","ok"],"mappings":";;AAKO,MAAMA,IAA6B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAwD1C,eAAsBC,EAASC,GAKI;AAClC,QAAM,EAAE,SAAAC,GAAS,MAAAC,GAAM,qBAAAC,IAAsBL,GAA4B,SAAAM,MAAYJ,GAC/EK,IAAQ;AAAA;AAAA,cAEDF,CAAmB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,YAgB1BG,IAAiB,MAAMC,EAAiB;AAAA,IAC7C,OAAAF;AAAA,IACA,WAJiB,EAAE,IAAIJ,EAAA;AAAA,IAKvB,MAAAC;AAAA,IACA,SAAAE;AAAA,IACA,UAAU;AAAA,EAAA,CACV;AAED,SAAII,EAAMF,CAAa,IACfA,IAGDG,EAAGH,EAAc,MAAM,IAAI;AACnC;"}
@@ -0,0 +1,27 @@
1
+ import { ensureValidUrl as c } from "./url.js";
2
+ import { getRequest as d } from "./index4.js";
3
+ const g = async ({
4
+ auth: t,
5
+ filter: e
6
+ }) => {
7
+ if (!t) throw new Error("No authentication provided");
8
+ let s = t.accountDomain !== void 0 ? c(t.accountDomain.trim()) : `https://${window.location.host}`;
9
+ s.charAt(s.length - 1) === "/" && (s = s.slice(0, -1));
10
+ const a = t.getAccessToken && t.getAccessToken(), r = a === void 0 ? {} : { Authorization: `Bearer ${a}` }, o = new URLSearchParams();
11
+ o.append("total", "false"), o.append("count", "true"), o.append("limit", "0"), e.searchTerm && o.append("keyword", e.searchTerm), e.assetTypes?.length ? o.append("type", e.assetTypes.join(",").toLowerCase()) : o.append("type", "audio,document,image,video"), e.collectionId && o.append("collectionId", e.collectionId), e.tagNames?.length && o.append("tags", e.tagNames.join(",")), e.isLimitedUse !== void 0 && o.append("keyVisual", e.isLimitedUse ? "1" : "0"), e.metaproperties && Object.entries(e.metaproperties).forEach(([n, p]) => {
12
+ const i = Object.keys(p);
13
+ i.length > 0 && o.append(`property_${n}`, i.join(","));
14
+ });
15
+ try {
16
+ return await d(
17
+ `${s}/api/v4/media?${o.toString()}`,
18
+ { headers: r }
19
+ );
20
+ } catch (n) {
21
+ throw new Error(`Error fetching initial filters: ${n}`);
22
+ }
23
+ };
24
+ export {
25
+ g as getAssetCounts
26
+ };
27
+ //# sourceMappingURL=getAssetCounts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getAssetCounts.js","sources":["../../src/api/rest/getAssetCounts.ts"],"sourcesContent":["import { AssetType } from '@src/views/asset/asset.type';\nimport { AuthInformationState } from '@src/auth/useAuthInformation';\nimport { ensureValidUrl } from '@src/utils/url';\nimport { getRequest } from '.';\nimport { selectedSmartfilterOptionsType, AssetCountType } from './types';\n\nexport interface AssetFilter {\n\tsearchTerm?: string;\n\ttagNames?: string[];\n\tassetTypes?: AssetType[];\n\tcollectionId?: string;\n\tmetaproperties?: selectedSmartfilterOptionsType;\n\tisLimitedUse?: boolean;\n}\n\nexport const getAssetCounts = async ({\n\tauth,\n\tfilter,\n}: {\n\tauth: AuthInformationState | null;\n\tfilter: AssetFilter;\n}): Promise<AssetCountType> => {\n\tif (!auth) throw new Error('No authentication provided');\n\n\tlet host =\n\t\tauth.accountDomain !== undefined\n\t\t\t? ensureValidUrl(auth.accountDomain.trim())\n\t\t\t: `https://${window.location.host}`;\n\n\t// For the sake of consistency, check if last char is a slash\n\t// and remove it\n\tif (host.charAt(host.length - 1) === '/') {\n\t\thost = host.slice(0, -1);\n\t}\n\n\tconst accessToken = auth.getAccessToken && auth.getAccessToken();\n\n\tconst headers = accessToken === undefined ? {} : { Authorization: `Bearer ${accessToken}` };\n\n\t// Build query parameters\n\tconst params = new URLSearchParams();\n\n\t// Add fixed parameters\n\tparams.append('total', 'false');\n\tparams.append('count', 'true');\n\tparams.append('limit', '0');\n\n\t// Add filter parameters\n\tif (filter.searchTerm) {\n\t\tparams.append('keyword', filter.searchTerm);\n\t}\n\n\tif (filter.assetTypes?.length) {\n\t\tparams.append('type', filter.assetTypes.join(',').toLowerCase());\n\t} else {\n\t\tparams.append('type', 'audio,document,image,video');\n\t}\n\n\tif (filter.collectionId) {\n\t\tparams.append('collectionId', filter.collectionId);\n\t}\n\n\tif (filter.tagNames?.length) {\n\t\tparams.append('tags', filter.tagNames.join(','));\n\t}\n\n\tif (filter.isLimitedUse !== undefined) {\n\t\tparams.append('keyVisual', filter.isLimitedUse ? '1' : '0');\n\t}\n\n\t// Add metaproperty filters\n\tif (filter.metaproperties) {\n\t\tObject.entries(filter.metaproperties).forEach(([name, values]) => {\n\t\t\tconst optionsIds = Object.keys(values);\n\n\t\t\tif (optionsIds.length > 0) {\n\t\t\t\tparams.append(`property_${name}`, optionsIds.join(','));\n\t\t\t}\n\t\t});\n\t}\n\n\ttry {\n\t\tconst response = await getRequest<AssetCountType>(\n\t\t\t`${host}/api/v4/media?${params.toString()}`,\n\t\t\t{ headers },\n\t\t);\n\n\t\treturn response;\n\t} catch (error) {\n\t\tthrow new Error(`Error fetching initial filters: ${error}`);\n\t}\n};\n"],"names":["getAssetCounts","auth","filter","host","ensureValidUrl","accessToken","headers","params","name","values","optionsIds","getRequest","error"],"mappings":";;AAeO,MAAMA,IAAiB,OAAO;AAAA,EACpC,MAAAC;AAAA,EACA,QAAAC;AACD,MAG+B;AAC9B,MAAI,CAACD,EAAM,OAAM,IAAI,MAAM,4BAA4B;AAEvD,MAAIE,IACHF,EAAK,kBAAkB,SACpBG,EAAeH,EAAK,cAAc,KAAA,CAAM,IACxC,WAAW,OAAO,SAAS,IAAI;AAInC,EAAIE,EAAK,OAAOA,EAAK,SAAS,CAAC,MAAM,QACpCA,IAAOA,EAAK,MAAM,GAAG,EAAE;AAGxB,QAAME,IAAcJ,EAAK,kBAAkBA,EAAK,eAAA,GAE1CK,IAAUD,MAAgB,SAAY,CAAA,IAAK,EAAE,eAAe,UAAUA,CAAW,GAAA,GAGjFE,IAAS,IAAI,gBAAA;AAGnB,EAAAA,EAAO,OAAO,SAAS,OAAO,GAC9BA,EAAO,OAAO,SAAS,MAAM,GAC7BA,EAAO,OAAO,SAAS,GAAG,GAGtBL,EAAO,cACVK,EAAO,OAAO,WAAWL,EAAO,UAAU,GAGvCA,EAAO,YAAY,SACtBK,EAAO,OAAO,QAAQL,EAAO,WAAW,KAAK,GAAG,EAAE,aAAa,IAE/DK,EAAO,OAAO,QAAQ,4BAA4B,GAG/CL,EAAO,gBACVK,EAAO,OAAO,gBAAgBL,EAAO,YAAY,GAG9CA,EAAO,UAAU,UACpBK,EAAO,OAAO,QAAQL,EAAO,SAAS,KAAK,GAAG,CAAC,GAG5CA,EAAO,iBAAiB,UAC3BK,EAAO,OAAO,aAAaL,EAAO,eAAe,MAAM,GAAG,GAIvDA,EAAO,kBACV,OAAO,QAAQA,EAAO,cAAc,EAAE,QAAQ,CAAC,CAACM,GAAMC,CAAM,MAAM;AACjE,UAAMC,IAAa,OAAO,KAAKD,CAAM;AAErC,IAAIC,EAAW,SAAS,KACvBH,EAAO,OAAO,YAAYC,CAAI,IAAIE,EAAW,KAAK,GAAG,CAAC;AAAA,EAExD,CAAC;AAGF,MAAI;AAMH,WALiB,MAAMC;AAAA,MACtB,GAAGR,CAAI,iBAAiBI,EAAO,UAAU;AAAA,MACzC,EAAE,SAAAD,EAAA;AAAA,IAAQ;AAAA,EAIZ,SAASM,GAAO;AACf,UAAM,IAAI,MAAM,mCAAmCA,CAAK,EAAE;AAAA,EAC3D;AACD;"}
package/getAssets.js ADDED
@@ -0,0 +1,137 @@
1
+ import { isErr as A, ok as h } from "./result.type.js";
2
+ import { fetchWithGraphql as v } from "./index3.js";
3
+ import { MAX_GET_ASSETS_LIMIT as I } from "./constants.js";
4
+ import { chunk as S } from "./chunk.js";
5
+ import { convertAssetIdToBase64 as _ } from "./base64Converter.js";
6
+ const b = `
7
+ id
8
+ name
9
+ description
10
+ databaseId
11
+ createdAt
12
+ originalUrl
13
+ publishedAt
14
+ tags
15
+ type
16
+ updatedAt
17
+ url
18
+ extensions
19
+ metaproperties {
20
+ nodes {
21
+ name
22
+ type
23
+ options {
24
+ name
25
+ displayLabel
26
+ }
27
+ }
28
+ }
29
+ textMetaproperties {
30
+ name
31
+ value
32
+ label
33
+ }
34
+ derivatives {
35
+ thumbnail
36
+ webImage
37
+ }
38
+ ... on Video {
39
+ previewUrls
40
+ streamingLinks {
41
+ dash,
42
+ hls
43
+ }
44
+ }
45
+ `;
46
+ async function $(o) {
47
+ const {
48
+ selectedItems: t,
49
+ auth: n,
50
+ assetFieldSelection: i = b,
51
+ noCache: a,
52
+ isSimilaritySearchEnabled: l = !1
53
+ } = o;
54
+ if (t.length <= I)
55
+ return f({
56
+ selectedItems: t,
57
+ auth: n,
58
+ assetFieldSelection: i,
59
+ noCache: a,
60
+ isSimilaritySearchEnabled: l
61
+ });
62
+ const u = S(t, 280).map(
63
+ (s) => f({
64
+ selectedItems: s,
65
+ auth: n,
66
+ assetFieldSelection: i,
67
+ noCache: a,
68
+ isSimilaritySearchEnabled: l
69
+ })
70
+ ), c = await Promise.all(u), r = [];
71
+ for (const s of c) {
72
+ if (A(s))
73
+ return s;
74
+ r.push(...s.value);
75
+ }
76
+ return h(r);
77
+ }
78
+ const f = async ({
79
+ selectedItems: o,
80
+ auth: t,
81
+ assetFieldSelection: n,
82
+ noCache: i,
83
+ isSimilaritySearchEnabled: a
84
+ }) => {
85
+ const l = `
86
+ fragment AddMediaAsset on Asset {
87
+ ${n}
88
+ }
89
+
90
+ query getAssetsById($ids: [ID!]!, $collectionCount: Int) {
91
+ nodes(ids: $ids) {
92
+ __typename
93
+ id
94
+ ...on Asset {
95
+ ...AddMediaAsset
96
+ files
97
+ }
98
+ ...on Collection {
99
+ assets(first: $collectionCount) {
100
+ nodes {
101
+ __typename
102
+ id
103
+ ...AddMediaAsset
104
+ files
105
+ }
106
+ }
107
+ }
108
+ }
109
+ }`, c = o.filter((e) => e.type === "collection").map((e) => e.value.assetCount).reduce(
110
+ (e, y) => e + y,
111
+ 0
112
+ ), r = {
113
+ ids: o.map(
114
+ (e) => a ? _(e.value.id) : e.value.id
115
+ ),
116
+ collectionCount: c
117
+ }, s = await v({
118
+ query: l,
119
+ variables: r,
120
+ auth: t,
121
+ noCache: i,
122
+ isNewGQL: !0
123
+ });
124
+ if (A(s))
125
+ return s;
126
+ const d = [];
127
+ for (const e of s.value.nodes)
128
+ e.__typename === "Collection" ? d.push(...e.assets.nodes) : d.push(e);
129
+ const p = /* @__PURE__ */ new Set(), m = [];
130
+ for (const e of d)
131
+ p.has(e.id) || (m.push(e), p.add(e.id));
132
+ return h(m);
133
+ };
134
+ export {
135
+ $ as getAssets
136
+ };
137
+ //# sourceMappingURL=getAssets.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getAssets.js","sources":["../../src/api/getAssets.ts"],"sourcesContent":["import { isErr, ok, Result } from '../auth/result.type';\nimport { SelectedCollection, SelectedItem } from '../select/SelectionContext';\nimport { fetchWithGraphql } from '.';\nimport { Asset } from './getAsset';\nimport { AuthInformationState } from '../auth/useAuthInformation';\nimport { MAX_GET_ASSETS_LIMIT } from '@src/constants';\nimport { chunk } from '@src/utils/chunk';\nimport { convertAssetIdToBase64 } from '@src/utils/base64Converter';\n\nconst defaultAssetFieldSelection = `\n id\n name\n description\n databaseId\n createdAt\n originalUrl\n publishedAt\n tags\n type\n updatedAt\n url\n extensions\n metaproperties {\n nodes {\n name\n type\n options {\n name\n displayLabel\n }\n }\n }\n textMetaproperties {\n name\n value\n label\n }\n derivatives {\n thumbnail\n webImage\n }\n ... on Video {\n previewUrls\n\t streamingLinks {\n dash,\n hls\n }\n }\n`;\n\ntype CollectionNode = {\n\t__typename: 'Collection';\n\tassets: {\n\t\tnodes: Asset[];\n\t};\n};\n\n// There are more alternative types than 'Image', but here I only care that it's _not_ 'Collection'\ntype NonCollectionNode = { __typename: 'Image' } & Asset;\n\ninterface Data {\n\tnodes: (CollectionNode | NonCollectionNode)[];\n}\n\nexport async function getAssets(options: {\n\tselectedItems: SelectedItem[];\n\tauth: AuthInformationState | null;\n\tassetFieldSelection?: string;\n\tnoCache?: boolean;\n\tisSimilaritySearchEnabled?: boolean;\n}): Promise<Result<Asset[], string>> {\n\tconst {\n\t\tselectedItems,\n\t\tauth,\n\t\tassetFieldSelection = defaultAssetFieldSelection,\n\t\tnoCache,\n\t\tisSimilaritySearchEnabled = false,\n\t} = options;\n\n\tif (selectedItems.length <= MAX_GET_ASSETS_LIMIT) {\n\t\treturn fetchAssetsChunk({\n\t\t\tselectedItems,\n\t\t\tauth,\n\t\t\tassetFieldSelection,\n\t\t\tnoCache,\n\t\t\tisSimilaritySearchEnabled,\n\t\t});\n\t}\n\n\tconst chunks: SelectedItem[][] = chunk(selectedItems, 280);\n\tconst promises = chunks.map((chunkItem) =>\n\t\tfetchAssetsChunk({\n\t\t\tselectedItems: chunkItem,\n\t\t\tauth,\n\t\t\tassetFieldSelection,\n\t\t\tnoCache,\n\t\t\tisSimilaritySearchEnabled,\n\t\t}),\n\t);\n\n\tconst results = await Promise.all(promises);\n\n\tconst allAssets: Asset[] = [];\n\n\tfor (const result of results) {\n\t\tif (isErr(result)) {\n\t\t\treturn result;\n\t\t}\n\n\t\tallAssets.push(...result.value);\n\t}\n\n\treturn ok(allAssets);\n}\n\nconst fetchAssetsChunk = async ({\n\tselectedItems,\n\tauth,\n\tassetFieldSelection,\n\tnoCache,\n\tisSimilaritySearchEnabled,\n}: {\n\tselectedItems: SelectedItem[];\n\tauth: AuthInformationState | null;\n\tassetFieldSelection: string;\n\tnoCache?: boolean;\n\tisSimilaritySearchEnabled?: boolean;\n}): Promise<Result<Asset[], string>> => {\n\tconst query = `\n fragment AddMediaAsset on Asset {\n ${assetFieldSelection}\n }\n\n query getAssetsById($ids: [ID!]!, $collectionCount: Int) {\n nodes(ids: $ids) {\n __typename\n id\n ...on Asset {\n ...AddMediaAsset\n files\n }\n ...on Collection {\n assets(first: $collectionCount) {\n nodes {\n __typename\n id\n ...AddMediaAsset\n files\n }\n }\n }\n }\n }`;\n\n\tconst allCollectionCounts: number[] = selectedItems\n\t\t.filter((item): item is SelectedCollection => item.type === 'collection')\n\t\t.map((collection) => collection.value.assetCount);\n\tconst collectionAssetCounter = 0;\n\tconst collectionCountSum = allCollectionCounts.reduce(\n\t\t(previousValue, currentValue) => previousValue + currentValue,\n\t\tcollectionAssetCounter,\n\t);\n\n\tconst variables = {\n\t\tids: selectedItems.map((item) =>\n\t\t\tisSimilaritySearchEnabled ? convertAssetIdToBase64(item.value.id) : item.value.id,\n\t\t),\n\t\tcollectionCount: collectionCountSum,\n\t};\n\n\tconst queryResponse = (await fetchWithGraphql({\n\t\tquery,\n\t\tvariables,\n\t\tauth,\n\t\tnoCache,\n\t\tisNewGQL: true,\n\t})) as Result<Data, string>;\n\n\tif (isErr(queryResponse)) {\n\t\treturn queryResponse;\n\t}\n\n\tconst allAssets: Asset[] = [];\n\n\tfor (const node of queryResponse.value.nodes) {\n\t\tif (node.__typename === 'Collection') {\n\t\t\tallAssets.push(...node.assets.nodes);\n\t\t} else {\n\t\t\tallAssets.push(node);\n\t\t}\n\t}\n\n\tconst assetIdAccumulator = new Set<string>();\n\tconst uniqueAssets: Asset[] = [];\n\n\tfor (const asset of allAssets) {\n\t\tif (!assetIdAccumulator.has(asset.id)) {\n\t\t\tuniqueAssets.push(asset);\n\t\t\tassetIdAccumulator.add(asset.id);\n\t\t}\n\t}\n\n\treturn ok(uniqueAssets);\n};\n"],"names":["defaultAssetFieldSelection","getAssets","options","selectedItems","auth","assetFieldSelection","noCache","isSimilaritySearchEnabled","MAX_GET_ASSETS_LIMIT","fetchAssetsChunk","promises","chunk","chunkItem","results","allAssets","result","isErr","ok","query","collectionCountSum","item","collection","previousValue","currentValue","variables","convertAssetIdToBase64","queryResponse","fetchWithGraphql","node","assetIdAccumulator","uniqueAssets","asset"],"mappings":";;;;;AASA,MAAMA,IAA6B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAuDnC,eAAsBC,EAAUC,GAMK;AACpC,QAAM;AAAA,IACL,eAAAC;AAAA,IACA,MAAAC;AAAA,IACA,qBAAAC,IAAsBL;AAAA,IACtB,SAAAM;AAAA,IACA,2BAAAC,IAA4B;AAAA,EAAA,IACzBL;AAEJ,MAAIC,EAAc,UAAUK;AAC3B,WAAOC,EAAiB;AAAA,MACvB,eAAAN;AAAA,MACA,MAAAC;AAAA,MACA,qBAAAC;AAAA,MACA,SAAAC;AAAA,MACA,2BAAAC;AAAA,IAAA,CACA;AAIF,QAAMG,IAD2BC,EAAMR,GAAe,GAAG,EACjC;AAAA,IAAI,CAACS,MAC5BH,EAAiB;AAAA,MAChB,eAAeG;AAAA,MACf,MAAAR;AAAA,MACA,qBAAAC;AAAA,MACA,SAAAC;AAAA,MACA,2BAAAC;AAAA,IAAA,CACA;AAAA,EAAA,GAGIM,IAAU,MAAM,QAAQ,IAAIH,CAAQ,GAEpCI,IAAqB,CAAA;AAE3B,aAAWC,KAAUF,GAAS;AAC7B,QAAIG,EAAMD,CAAM;AACf,aAAOA;AAGR,IAAAD,EAAU,KAAK,GAAGC,EAAO,KAAK;AAAA,EAC/B;AAEA,SAAOE,EAAGH,CAAS;AACpB;AAEA,MAAML,IAAmB,OAAO;AAAA,EAC/B,eAAAN;AAAA,EACA,MAAAC;AAAA,EACA,qBAAAC;AAAA,EACA,SAAAC;AAAA,EACA,2BAAAC;AACD,MAMwC;AACvC,QAAMW,IAAQ;AAAA;AAAA,cAEDb,CAAmB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,YA4B1Bc,IAJgChB,EACpC,OAAO,CAACiB,MAAqCA,EAAK,SAAS,YAAY,EACvE,IAAI,CAACC,MAAeA,EAAW,MAAM,UAAU,EAEF;AAAA,IAC9C,CAACC,GAAeC,MAAiBD,IAAgBC;AAAA,IAFnB;AAAA,EAG9B,GAGKC,IAAY;AAAA,IACjB,KAAKrB,EAAc;AAAA,MAAI,CAACiB,MACvBb,IAA4BkB,EAAuBL,EAAK,MAAM,EAAE,IAAIA,EAAK,MAAM;AAAA,IAAA;AAAA,IAEhF,iBAAiBD;AAAA,EAAA,GAGZO,IAAiB,MAAMC,EAAiB;AAAA,IAC7C,OAAAT;AAAA,IACA,WAAAM;AAAA,IACA,MAAApB;AAAA,IACA,SAAAE;AAAA,IACA,UAAU;AAAA,EAAA,CACV;AAED,MAAIU,EAAMU,CAAa;AACtB,WAAOA;AAGR,QAAMZ,IAAqB,CAAA;AAE3B,aAAWc,KAAQF,EAAc,MAAM;AACtC,IAAIE,EAAK,eAAe,eACvBd,EAAU,KAAK,GAAGc,EAAK,OAAO,KAAK,IAEnCd,EAAU,KAAKc,CAAI;AAIrB,QAAMC,wBAAyB,IAAA,GACzBC,IAAwB,CAAA;AAE9B,aAAWC,KAASjB;AACnB,IAAKe,EAAmB,IAAIE,EAAM,EAAE,MACnCD,EAAa,KAAKC,CAAK,GACvBF,EAAmB,IAAIE,EAAM,EAAE;AAIjC,SAAOd,EAAGa,CAAY;AACvB;"}
@@ -0,0 +1,78 @@
1
+ import { useState as g, useEffect as m } from "react";
2
+ import { isErr as h } from "./result.type.js";
3
+ import { fetchWithGraphql as v } from "./index3.js";
4
+ import { useAuth as C } from "./LoginContext.js";
5
+ const y = `
6
+ query getCollections($searchTerm: String, $orderBy: CollectionOrder!, $after: Cursor) {
7
+ collections(after: $after, first: 50, filter: {name_contains: $searchTerm, assetCount_gte: 1}, orderBy: $orderBy) {
8
+ nodes {
9
+ id
10
+ name
11
+ assetCount
12
+ thumbnailUrls
13
+ url
14
+ }
15
+ totalCount
16
+ pageInfo {
17
+ endCursor
18
+ hasNextPage
19
+ }
20
+ }
21
+ }`;
22
+ function T(r, i = !1) {
23
+ const d = C(), [o, l] = g({ tag: "Loading", value: null });
24
+ let c = !1;
25
+ const u = async (e) => {
26
+ l((n) => ({
27
+ tag: "Loading",
28
+ value: n.tag === "Failure" ? null : n.value
29
+ }));
30
+ const t = {
31
+ ...r,
32
+ searchTerm: r.searchTerm ?? null,
33
+ after: e ?? null
34
+ }, a = await v({
35
+ query: y,
36
+ variables: t,
37
+ auth: d,
38
+ noCache: i
39
+ });
40
+ c || (h(a) ? l({
41
+ tag: "Failure",
42
+ value: a.error
43
+ }) : f(a, e));
44
+ }, f = (e, t) => {
45
+ !s() || !t ? l({
46
+ tag: "Loaded",
47
+ value: e.value
48
+ }) : l((a) => {
49
+ const n = s(a)?.nodes ?? [];
50
+ return {
51
+ tag: "Loaded",
52
+ value: {
53
+ collections: {
54
+ ...e.value.collections,
55
+ nodes: [...n, ...e.value.collections.nodes]
56
+ }
57
+ }
58
+ };
59
+ });
60
+ }, s = (e) => {
61
+ const t = e ?? o;
62
+ if (t.tag !== "Failure")
63
+ return t.value?.collections;
64
+ };
65
+ return m(() => (u(), () => {
66
+ c = !0;
67
+ }), [r.searchTerm, r.orderBy]), {
68
+ data: o,
69
+ executeQuery: () => u(),
70
+ isLoading: !o || o.tag === "Loading",
71
+ loadMore: () => u(s()?.pageInfo.endCursor),
72
+ hasNextPage: !!s()?.pageInfo.hasNextPage
73
+ };
74
+ }
75
+ export {
76
+ T as useGetCollections
77
+ };
78
+ //# sourceMappingURL=getCollections.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getCollections.js","sources":["../../src/api/getCollections.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport { isErr, Ok, Result } from '../auth/result.type';\nimport { fetchWithGraphql } from '.';\nimport { Ordering } from '@src/store/useOrderingStore';\nimport { Collection } from '../views/collection/collection.types';\nimport { Connection, Data } from './graphql.types';\nimport { useAuth } from '../login/LoginContext';\n\nexport interface GraphqlResponse {\n\tcollections: Collections;\n}\n\nexport interface Collections {\n\tnodes: Collection[];\n\ttotalCount: number;\n\tpageInfo: {\n\t\tendCursor: string;\n\t\thasNextPage: boolean;\n\t};\n}\n\nconst query = `\nquery getCollections($searchTerm: String, $orderBy: CollectionOrder!, $after: Cursor) {\n collections(after: $after, first: 50, filter: {name_contains: $searchTerm, assetCount_gte: 1}, orderBy: $orderBy) {\n nodes {\n id\n name\n assetCount\n thumbnailUrls\n url\n }\n totalCount\n pageInfo {\n endCursor\n hasNextPage\n }\n }\n}`;\n\nexport function useGetCollections(\n\toptions: {\n\t\tsearchTerm?: string;\n\t\torderBy: Ordering;\n\t},\n\tnoCache = false,\n): Connection<GraphqlResponse> {\n\tconst auth = useAuth();\n\tconst [data, setData] = useState<Data<GraphqlResponse>>({ tag: 'Loading', value: null });\n\tlet cancelRequestActions = false;\n\n\tconst fetchCollections = async (after?: string) => {\n\t\tsetData((previousData) => ({\n\t\t\ttag: 'Loading',\n\t\t\tvalue: previousData.tag === 'Failure' ? null : previousData.value,\n\t\t}));\n\n\t\tconst variables = {\n\t\t\t...options,\n\t\t\tsearchTerm: options.searchTerm ?? null,\n\t\t\tafter: after ?? null,\n\t\t};\n\n\t\tconst queryResponse = (await fetchWithGraphql({\n\t\t\tquery,\n\t\t\tvariables,\n\t\t\tauth,\n\t\t\tnoCache,\n\t\t})) as Result<GraphqlResponse, string>;\n\n\t\tif (!cancelRequestActions) {\n\t\t\tif (isErr(queryResponse)) {\n\t\t\t\tsetData({\n\t\t\t\t\ttag: 'Failure',\n\t\t\t\t\tvalue: queryResponse.error,\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tsetOkStatus(queryResponse, after);\n\t\t\t}\n\t\t}\n\t};\n\n\tconst setOkStatus = (queryResponse: Ok<GraphqlResponse>, after?: string) => {\n\t\tif (!getCollectionsData() || !after) {\n\t\t\tsetData({\n\t\t\t\ttag: 'Loaded',\n\t\t\t\tvalue: queryResponse.value,\n\t\t\t});\n\t\t} else {\n\t\t\tsetData((prev) => {\n\t\t\t\tconst previousNodes = getCollectionsData(prev)?.nodes ?? [];\n\n\t\t\t\treturn {\n\t\t\t\t\ttag: 'Loaded',\n\t\t\t\t\tvalue: {\n\t\t\t\t\t\tcollections: {\n\t\t\t\t\t\t\t...queryResponse.value.collections,\n\t\t\t\t\t\t\tnodes: [...previousNodes, ...queryResponse.value.collections.nodes],\n\t\t\t\t\t\t},\n\t\t\t\t\t},\n\t\t\t\t};\n\t\t\t});\n\t\t}\n\t};\n\n\tconst getCollectionsData = (previousData?: Data<GraphqlResponse>): Collections | undefined => {\n\t\tconst collectionData = previousData ?? data;\n\n\t\tif (collectionData.tag === 'Failure') {\n\t\t\treturn undefined;\n\t\t}\n\n\t\treturn collectionData.value?.collections;\n\t};\n\n\tuseEffect(() => {\n\t\tfetchCollections();\n\n\t\treturn () => {\n\t\t\t// eslint-disable-next-line\n\t\t\tcancelRequestActions = true;\n\t\t};\n\t}, [options.searchTerm, options.orderBy]);\n\n\treturn {\n\t\tdata,\n\t\texecuteQuery: () => fetchCollections(),\n\t\tisLoading: !data || data.tag === 'Loading',\n\t\tloadMore: () => fetchCollections(getCollectionsData()?.pageInfo.endCursor),\n\t\thasNextPage: !!getCollectionsData()?.pageInfo.hasNextPage,\n\t};\n}\n"],"names":["query","useGetCollections","options","noCache","auth","useAuth","data","setData","useState","cancelRequestActions","fetchCollections","after","previousData","variables","queryResponse","fetchWithGraphql","isErr","setOkStatus","getCollectionsData","prev","previousNodes","collectionData","useEffect"],"mappings":";;;;AAsBA,MAAMA,IAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAkBP,SAASC,EACfC,GAIAC,IAAU,IACoB;AAC9B,QAAMC,IAAOC,EAAA,GACP,CAACC,GAAMC,CAAO,IAAIC,EAAgC,EAAE,KAAK,WAAW,OAAO,MAAM;AACvF,MAAIC,IAAuB;AAE3B,QAAMC,IAAmB,OAAOC,MAAmB;AAClD,IAAAJ,EAAQ,CAACK,OAAkB;AAAA,MAC1B,KAAK;AAAA,MACL,OAAOA,EAAa,QAAQ,YAAY,OAAOA,EAAa;AAAA,IAAA,EAC3D;AAEF,UAAMC,IAAY;AAAA,MACjB,GAAGX;AAAA,MACH,YAAYA,EAAQ,cAAc;AAAA,MAClC,OAAOS,KAAS;AAAA,IAAA,GAGXG,IAAiB,MAAMC,EAAiB;AAAA,MAC7C,OAAAf;AAAA,MACA,WAAAa;AAAA,MACA,MAAAT;AAAA,MACA,SAAAD;AAAA,IAAA,CACA;AAED,IAAKM,MACAO,EAAMF,CAAa,IACtBP,EAAQ;AAAA,MACP,KAAK;AAAA,MACL,OAAOO,EAAc;AAAA,IAAA,CACrB,IAEDG,EAAYH,GAAeH,CAAK;AAAA,EAGnC,GAEMM,IAAc,CAACH,GAAoCH,MAAmB;AAC3E,IAAI,CAACO,OAAwB,CAACP,IAC7BJ,EAAQ;AAAA,MACP,KAAK;AAAA,MACL,OAAOO,EAAc;AAAA,IAAA,CACrB,IAEDP,EAAQ,CAACY,MAAS;AACjB,YAAMC,IAAgBF,EAAmBC,CAAI,GAAG,SAAS,CAAA;AAEzD,aAAO;AAAA,QACN,KAAK;AAAA,QACL,OAAO;AAAA,UACN,aAAa;AAAA,YACZ,GAAGL,EAAc,MAAM;AAAA,YACvB,OAAO,CAAC,GAAGM,GAAe,GAAGN,EAAc,MAAM,YAAY,KAAK;AAAA,UAAA;AAAA,QACnE;AAAA,MACD;AAAA,IAEF,CAAC;AAAA,EAEH,GAEMI,IAAqB,CAACN,MAAkE;AAC7F,UAAMS,IAAiBT,KAAgBN;AAEvC,QAAIe,EAAe,QAAQ;AAI3B,aAAOA,EAAe,OAAO;AAAA,EAC9B;AAEA,SAAAC,EAAU,OACTZ,EAAA,GAEO,MAAM;AAEZ,IAAAD,IAAuB;AAAA,EACxB,IACE,CAACP,EAAQ,YAAYA,EAAQ,OAAO,CAAC,GAEjC;AAAA,IACN,MAAAI;AAAA,IACA,cAAc,MAAMI,EAAA;AAAA,IACpB,WAAW,CAACJ,KAAQA,EAAK,QAAQ;AAAA,IACjC,UAAU,MAAMI,EAAiBQ,EAAA,GAAsB,SAAS,SAAS;AAAA,IACzE,aAAa,CAAC,CAACA,EAAA,GAAsB,SAAS;AAAA,EAAA;AAEhD;"}
package/getFilters.js ADDED
@@ -0,0 +1,84 @@
1
+ import { useState as F, useEffect as v } from "react";
2
+ import { isErr as A } from "./result.type.js";
3
+ import { fetchWithGraphql as L } from "./index3.js";
4
+ import { useAuth as b } from "./LoginContext.js";
5
+ import { combineFilters as n } from "./combineFilters.js";
6
+ import { convertOptionsToBase64 as q } from "./base64Converter.js";
7
+ const w = `
8
+ query searchAssets($filter: AssetFilter!, $language: String!) {
9
+ searchAssets(filter: $filter) {
10
+ tags {
11
+ nodes {
12
+ id
13
+ name
14
+ assetCount
15
+ }
16
+ }
17
+ count {
18
+ assetType {
19
+ image
20
+ video
21
+ audio
22
+ document
23
+ archive
24
+ }
25
+ }
26
+ }
27
+ }`;
28
+ function E(e, c = !1) {
29
+ const f = b(), [i, r] = F({ tag: "Loading", value: null });
30
+ let l = !1;
31
+ const d = async () => {
32
+ r((o) => ({
33
+ tag: "Loading",
34
+ value: o.tag === "Failure" ? null : o.value
35
+ }));
36
+ const { filter: s, searchTerm: u, allAssetTypes: m, language: p, predefinedFilter: t } = e, g = n({
37
+ filters: s?.assetTypes,
38
+ predefinedFilters: t?.predefinedAssetType,
39
+ showToolbar: t?.showToolbar
40
+ }), h = n({
41
+ filters: s?.tags,
42
+ predefinedFilters: t?.predefinedTagNames,
43
+ showToolbar: t?.showToolbar
44
+ }), T = q(s.selectedSmartfilterOptions), y = {
45
+ filter: {
46
+ assetType_in: g ?? m,
47
+ collectionId: e.collectionId || t?.collectionId,
48
+ metapropertyOptionId_in: T,
49
+ searchTerm: u,
50
+ tagNames_in: h,
51
+ isLimitedUse: s.isLimited
52
+ },
53
+ language: p
54
+ }, a = await L({
55
+ query: w,
56
+ variables: y,
57
+ auth: f,
58
+ noCache: c
59
+ });
60
+ l || (A(a) ? r({
61
+ tag: "Failure",
62
+ value: a.error
63
+ }) : r({
64
+ tag: "Loaded",
65
+ value: a.value
66
+ }));
67
+ };
68
+ return v(() => (d(), () => {
69
+ l = !0;
70
+ }), [
71
+ e.filter.assetTypes,
72
+ e.filter.selectedSmartfilterOptions,
73
+ e.filter.tags,
74
+ e.searchTerm
75
+ ]), {
76
+ data: i,
77
+ isLoading: i.tag === "Loading"
78
+ };
79
+ }
80
+ export {
81
+ w as query,
82
+ E as useGetFilters
83
+ };
84
+ //# sourceMappingURL=getFilters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getFilters.js","sources":["../../src/api/getFilters.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport { isErr, Result } from '../auth/result.type';\nimport { fetchWithGraphql } from '.';\nimport { Data } from './graphql.types';\nimport { useAuth } from '../login/LoginContext';\nimport { Tag } from '../filter/filters/metaproperty/MetapropertyFilterContent';\n\nimport { Filter } from '../filter/AssetFilterContext';\nimport { AssetType } from '../views/asset/asset.type';\nimport { AssetFilterJson } from '@src/filter/assetFilter.type';\nimport { combineFilters } from '@src/utils/combineFilters';\nimport { convertOptionsToBase64 } from '@src/utils/base64Converter';\n\nexport interface GraphqlFiltersResponse {\n\tsearchAssets: {\n\t\tcount: {\n\t\t\tassetType: {\n\t\t\t\taudio: number;\n\t\t\t\tdocument: number;\n\t\t\t\timage: number;\n\t\t\t\tvideo: number;\n\t\t\t\tarchive: number;\n\t\t\t};\n\t\t};\n\t\ttags?: {\n\t\t\tnodes: Tag[];\n\t\t};\n\t};\n}\n\nexport const query = `\nquery searchAssets($filter: AssetFilter!, $language: String!) {\n searchAssets(filter: $filter) {\n tags {\n nodes {\n id\n name\n assetCount\n }\n }\n count {\n assetType {\n image\n video\n audio\n document\n archive\n }\n }\n }\n }`;\n\nexport function useGetFilters(\n\toptions: {\n\t\tfilter: Filter;\n\t\tsearchTerm: null | undefined | string;\n\t\tallAssetTypes: AssetType[];\n\t\tlanguage: string;\n\t\tpredefinedFilter?: AssetFilterJson;\n\t\tcollectionId: string | null;\n\t},\n\tnoCache = false,\n): { data: Data<GraphqlFiltersResponse>; isLoading: boolean } {\n\tconst auth = useAuth();\n\tconst [data, setData] = useState<Data<GraphqlFiltersResponse>>({ tag: 'Loading', value: null });\n\tlet cancelRequestActions = false;\n\n\tconst fetchFilters = async () => {\n\t\tsetData((previousData) => ({\n\t\t\ttag: 'Loading',\n\t\t\tvalue: previousData.tag === 'Failure' ? null : previousData.value,\n\t\t}));\n\t\tconst { filter, searchTerm, allAssetTypes, language, predefinedFilter } = options;\n\n\t\tconst assetTypeFilter = combineFilters({\n\t\t\tfilters: filter?.assetTypes,\n\t\t\tpredefinedFilters: predefinedFilter?.predefinedAssetType,\n\t\t\tshowToolbar: predefinedFilter?.showToolbar,\n\t\t});\n\n\t\tconst tagNamesFilter = combineFilters({\n\t\t\tfilters: filter?.tags,\n\t\t\tpredefinedFilters: predefinedFilter?.predefinedTagNames,\n\t\t\tshowToolbar: predefinedFilter?.showToolbar,\n\t\t});\n\n\t\tconst metapropertyOptions = convertOptionsToBase64(filter.selectedSmartfilterOptions);\n\n\t\tconst variables = {\n\t\t\tfilter: {\n\t\t\t\tassetType_in: assetTypeFilter ?? allAssetTypes,\n\t\t\t\tcollectionId: options.collectionId || predefinedFilter?.collectionId,\n\t\t\t\tmetapropertyOptionId_in: metapropertyOptions,\n\t\t\t\tsearchTerm,\n\t\t\t\ttagNames_in: tagNamesFilter,\n\t\t\t\tisLimitedUse: filter.isLimited,\n\t\t\t},\n\t\t\tlanguage,\n\t\t};\n\n\t\tconst queryResponse = (await fetchWithGraphql({\n\t\t\tquery,\n\t\t\tvariables,\n\t\t\tauth,\n\t\t\tnoCache,\n\t\t})) as Result<GraphqlFiltersResponse, string>;\n\n\t\tif (!cancelRequestActions) {\n\t\t\tif (isErr(queryResponse)) {\n\t\t\t\tsetData({\n\t\t\t\t\ttag: 'Failure',\n\t\t\t\t\tvalue: queryResponse.error,\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tsetData({\n\t\t\t\t\ttag: 'Loaded',\n\t\t\t\t\tvalue: queryResponse.value,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t};\n\n\tuseEffect(() => {\n\t\tfetchFilters();\n\n\t\treturn () => {\n\t\t\t// eslint-disable-next-line\n\t\t\tcancelRequestActions = true;\n\t\t};\n\t}, [\n\t\toptions.filter.assetTypes,\n\t\toptions.filter.selectedSmartfilterOptions,\n\t\toptions.filter.tags,\n\t\toptions.searchTerm,\n\t]);\n\n\treturn {\n\t\tdata,\n\t\tisLoading: data.tag === 'Loading',\n\t};\n}\n"],"names":["query","useGetFilters","options","noCache","auth","useAuth","data","setData","useState","cancelRequestActions","fetchFilters","previousData","filter","searchTerm","allAssetTypes","language","predefinedFilter","assetTypeFilter","combineFilters","tagNamesFilter","metapropertyOptions","convertOptionsToBase64","variables","queryResponse","fetchWithGraphql","isErr","useEffect"],"mappings":";;;;;;AA+BO,MAAMA,IAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAsBd,SAASC,EACfC,GAQAC,IAAU,IACmD;AAC7D,QAAMC,IAAOC,EAAA,GACP,CAACC,GAAMC,CAAO,IAAIC,EAAuC,EAAE,KAAK,WAAW,OAAO,MAAM;AAC9F,MAAIC,IAAuB;AAE3B,QAAMC,IAAe,YAAY;AAChC,IAAAH,EAAQ,CAACI,OAAkB;AAAA,MAC1B,KAAK;AAAA,MACL,OAAOA,EAAa,QAAQ,YAAY,OAAOA,EAAa;AAAA,IAAA,EAC3D;AACF,UAAM,EAAE,QAAAC,GAAQ,YAAAC,GAAY,eAAAC,GAAe,UAAAC,GAAU,kBAAAC,MAAqBd,GAEpEe,IAAkBC,EAAe;AAAA,MACtC,SAASN,GAAQ;AAAA,MACjB,mBAAmBI,GAAkB;AAAA,MACrC,aAAaA,GAAkB;AAAA,IAAA,CAC/B,GAEKG,IAAiBD,EAAe;AAAA,MACrC,SAASN,GAAQ;AAAA,MACjB,mBAAmBI,GAAkB;AAAA,MACrC,aAAaA,GAAkB;AAAA,IAAA,CAC/B,GAEKI,IAAsBC,EAAuBT,EAAO,0BAA0B,GAE9EU,IAAY;AAAA,MACjB,QAAQ;AAAA,QACP,cAAcL,KAAmBH;AAAA,QACjC,cAAcZ,EAAQ,gBAAgBc,GAAkB;AAAA,QACxD,yBAAyBI;AAAA,QACzB,YAAAP;AAAA,QACA,aAAaM;AAAA,QACb,cAAcP,EAAO;AAAA,MAAA;AAAA,MAEtB,UAAAG;AAAA,IAAA,GAGKQ,IAAiB,MAAMC,EAAiB;AAAA,MAC7C,OAAAxB;AAAA,MACA,WAAAsB;AAAA,MACA,MAAAlB;AAAA,MACA,SAAAD;AAAA,IAAA,CACA;AAED,IAAKM,MACAgB,EAAMF,CAAa,IACtBhB,EAAQ;AAAA,MACP,KAAK;AAAA,MACL,OAAOgB,EAAc;AAAA,IAAA,CACrB,IAEDhB,EAAQ;AAAA,MACP,KAAK;AAAA,MACL,OAAOgB,EAAc;AAAA,IAAA,CACrB;AAAA,EAGJ;AAEA,SAAAG,EAAU,OACThB,EAAA,GAEO,MAAM;AAEZ,IAAAD,IAAuB;AAAA,EACxB,IACE;AAAA,IACFP,EAAQ,OAAO;AAAA,IACfA,EAAQ,OAAO;AAAA,IACfA,EAAQ,OAAO;AAAA,IACfA,EAAQ;AAAA,EAAA,CACR,GAEM;AAAA,IACN,MAAAI;AAAA,IACA,WAAWA,EAAK,QAAQ;AAAA,EAAA;AAE1B;"}
@@ -0,0 +1,51 @@
1
+ import { getRequest as p } from "./index4.js";
2
+ import { handlers as f } from "./handlers.js";
3
+ import { ensureValidUrl as m } from "./url.js";
4
+ import { filterEmptyMetaproperties as d } from "./filterEmptyMetaproperties.js";
5
+ const y = async ({ auth: r }) => {
6
+ if (!r) throw new Error("No authentication provided");
7
+ let e = r.accountDomain !== void 0 ? m(r.accountDomain.trim()) : `https://${window.location.host}`;
8
+ e.charAt(e.length - 1) === "/" && (e = e.slice(0, -1));
9
+ const l = r.getAccessToken && r.getAccessToken(), i = l === void 0 ? {} : { Authorization: `Bearer ${l}` };
10
+ try {
11
+ const o = (await p(
12
+ `${e}${f.smartfilters}`,
13
+ { headers: i }
14
+ )).filter((a) => a.metaproperties.length > 0), t = await h(o, e, i), s = d(t);
15
+ return {
16
+ filters: o,
17
+ metaproperties: s
18
+ };
19
+ } catch (c) {
20
+ throw new Error(`Error fetching initial filters: ${c}`);
21
+ }
22
+ }, h = async (r, e, l) => {
23
+ const i = [];
24
+ for (const t of r)
25
+ for (const s of t.metaproperties) {
26
+ const a = `${e}${f.metapropertiesWithOptions(
27
+ t.id,
28
+ s
29
+ )}?filterKey=savedFilters&limit=30`;
30
+ i.push(
31
+ p(a, {
32
+ headers: l
33
+ }).then((n) => ({
34
+ id: s,
35
+ smartfilterID: t.id,
36
+ response: n
37
+ })).catch(() => null)
38
+ );
39
+ }
40
+ const c = await Promise.allSettled(i), o = {};
41
+ for (const t of c)
42
+ if (t.status === "fulfilled" && t.value !== null) {
43
+ const { id: s, response: a, smartfilterID: n } = t.value;
44
+ o[n] = o[n] || {}, o[n][s] = a;
45
+ }
46
+ return o;
47
+ };
48
+ export {
49
+ y as getInitialFilters
50
+ };
51
+ //# sourceMappingURL=getInitialFilters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getInitialFilters.js","sources":["../../src/api/rest/getInitialFilters.ts"],"sourcesContent":["import { RawAxiosResponseHeaders } from 'axios';\nimport { getRequest } from '.';\nimport { handlers } from './handlers';\nimport { AuthInformationState } from '@src/auth/useAuthInformation';\nimport { ensureValidUrl } from '@src/utils/url';\nimport { filterEmptyMetaproperties } from '@src/utils/filterEmptyMetaproperties';\nimport { SmartfilterResponse, SmartfilterMetaproperty } from './types';\n\nexport const getInitialFilters = async ({ auth }: { auth: AuthInformationState | null }) => {\n\tif (!auth) throw new Error('No authentication provided');\n\n\tlet host =\n\t\tauth.accountDomain !== undefined\n\t\t\t? ensureValidUrl(auth.accountDomain.trim())\n\t\t\t: `https://${window.location.host}`;\n\n\t// For the sake of consistency, check if last char is a slash\n\t// and remove it\n\tif (host.charAt(host.length - 1) === '/') {\n\t\thost = host.slice(0, -1);\n\t}\n\n\tconst accessToken = auth.getAccessToken && auth.getAccessToken();\n\n\tconst headers = accessToken === undefined ? {} : { Authorization: `Bearer ${accessToken}` };\n\n\ttry {\n\t\tconst smartfilters: SmartfilterResponse = await getRequest<SmartfilterResponse>(\n\t\t\t`${host}${handlers.smartfilters}`,\n\t\t\t{ headers },\n\t\t);\n\t\tconst validSmartfilters = smartfilters.filter((filter) => filter.metaproperties.length > 0);\n\t\tconst metaproperties = await getMetapropertiesWithOptions(validSmartfilters, host, headers);\n\t\tconst validMetaproperties = filterEmptyMetaproperties(metaproperties);\n\n\t\treturn {\n\t\t\tfilters: validSmartfilters,\n\t\t\tmetaproperties: validMetaproperties,\n\t\t};\n\t} catch (error) {\n\t\tthrow new Error(`Error fetching initial filters: ${error}`);\n\t}\n};\n\nconst getMetapropertiesWithOptions = async (\n\tsmartfilters: SmartfilterResponse,\n\thost: string,\n\theaders: RawAxiosResponseHeaders,\n): Promise<Record<string, Record<string, SmartfilterMetaproperty>>> => {\n\tconst metapropertyPromises: Array<\n\t\tPromise<{ id: string; smartfilterID: string; response: SmartfilterMetaproperty } | null>\n\t> = [];\n\n\tfor (const smartfilter of smartfilters) {\n\t\tfor (const metapropertyId of smartfilter.metaproperties) {\n\t\t\tconst url = `${host}${handlers.metapropertiesWithOptions(\n\t\t\t\tsmartfilter.id,\n\t\t\t\tmetapropertyId,\n\t\t\t)}?filterKey=savedFilters&limit=30`;\n\n\t\t\tmetapropertyPromises.push(\n\t\t\t\tgetRequest<SmartfilterMetaproperty>(url, {\n\t\t\t\t\theaders,\n\t\t\t\t})\n\t\t\t\t\t.then((response) => ({\n\t\t\t\t\t\tid: metapropertyId,\n\t\t\t\t\t\tsmartfilterID: smartfilter.id,\n\t\t\t\t\t\tresponse,\n\t\t\t\t\t}))\n\t\t\t\t\t.catch(() => null),\n\t\t\t);\n\t\t}\n\t}\n\n\tconst settledResults = await Promise.allSettled(metapropertyPromises);\n\n\tconst fetchedMetaproperties: Record<string, Record<string, SmartfilterMetaproperty>> = {};\n\n\tfor (const result of settledResults) {\n\t\tif (result.status === 'fulfilled' && result.value !== null) {\n\t\t\tconst { id, response, smartfilterID } = result.value;\n\t\t\tfetchedMetaproperties[smartfilterID] = fetchedMetaproperties[smartfilterID] || {};\n\t\t\tfetchedMetaproperties[smartfilterID][id] = response;\n\t\t}\n\t}\n\n\treturn fetchedMetaproperties;\n};\n"],"names":["getInitialFilters","auth","host","ensureValidUrl","accessToken","headers","validSmartfilters","getRequest","handlers","filter","metaproperties","getMetapropertiesWithOptions","validMetaproperties","filterEmptyMetaproperties","error","smartfilters","metapropertyPromises","smartfilter","metapropertyId","url","response","settledResults","fetchedMetaproperties","result","id","smartfilterID"],"mappings":";;;;AAQO,MAAMA,IAAoB,OAAO,EAAE,MAAAC,QAAkD;AAC3F,MAAI,CAACA,EAAM,OAAM,IAAI,MAAM,4BAA4B;AAEvD,MAAIC,IACHD,EAAK,kBAAkB,SACpBE,EAAeF,EAAK,cAAc,KAAA,CAAM,IACxC,WAAW,OAAO,SAAS,IAAI;AAInC,EAAIC,EAAK,OAAOA,EAAK,SAAS,CAAC,MAAM,QACpCA,IAAOA,EAAK,MAAM,GAAG,EAAE;AAGxB,QAAME,IAAcH,EAAK,kBAAkBA,EAAK,eAAA,GAE1CI,IAAUD,MAAgB,SAAY,CAAA,IAAK,EAAE,eAAe,UAAUA,CAAW,GAAA;AAEvF,MAAI;AAKH,UAAME,KAJoC,MAAMC;AAAA,MAC/C,GAAGL,CAAI,GAAGM,EAAS,YAAY;AAAA,MAC/B,EAAE,SAAAH,EAAA;AAAA,IAAQ,GAE4B,OAAO,CAACI,MAAWA,EAAO,eAAe,SAAS,CAAC,GACpFC,IAAiB,MAAMC,EAA6BL,GAAmBJ,GAAMG,CAAO,GACpFO,IAAsBC,EAA0BH,CAAc;AAEpE,WAAO;AAAA,MACN,SAASJ;AAAA,MACT,gBAAgBM;AAAA,IAAA;AAAA,EAElB,SAASE,GAAO;AACf,UAAM,IAAI,MAAM,mCAAmCA,CAAK,EAAE;AAAA,EAC3D;AACD,GAEMH,IAA+B,OACpCI,GACAb,GACAG,MACsE;AACtE,QAAMW,IAEF,CAAA;AAEJ,aAAWC,KAAeF;AACzB,eAAWG,KAAkBD,EAAY,gBAAgB;AACxD,YAAME,IAAM,GAAGjB,CAAI,GAAGM,EAAS;AAAA,QAC9BS,EAAY;AAAA,QACZC;AAAA,MAAA,CACA;AAED,MAAAF,EAAqB;AAAA,QACpBT,EAAoCY,GAAK;AAAA,UACxC,SAAAd;AAAA,QAAA,CACA,EACC,KAAK,CAACe,OAAc;AAAA,UACpB,IAAIF;AAAA,UACJ,eAAeD,EAAY;AAAA,UAC3B,UAAAG;AAAA,QAAA,EACC,EACD,MAAM,MAAM,IAAI;AAAA,MAAA;AAAA,IAEpB;AAGD,QAAMC,IAAiB,MAAM,QAAQ,WAAWL,CAAoB,GAE9DM,IAAiF,CAAA;AAEvF,aAAWC,KAAUF;AACpB,QAAIE,EAAO,WAAW,eAAeA,EAAO,UAAU,MAAM;AAC3D,YAAM,EAAE,IAAAC,GAAI,UAAAJ,GAAU,eAAAK,EAAA,IAAkBF,EAAO;AAC/C,MAAAD,EAAsBG,CAAa,IAAIH,EAAsBG,CAAa,KAAK,CAAA,GAC/EH,EAAsBG,CAAa,EAAED,CAAE,IAAIJ;AAAA,IAC5C;AAGD,SAAOE;AACR;"}
@@ -0,0 +1,31 @@
1
+ import { getRequest as l } from "./index4.js";
2
+ import { handlers as m } from "./handlers.js";
3
+ import { ensureValidUrl as d } from "./url.js";
4
+ const w = async ({
5
+ auth: e,
6
+ smartfilterId: i,
7
+ metapropertyId: s,
8
+ labelKeyset: n,
9
+ zindexKeyset: c,
10
+ mpoKeyset: a
11
+ }) => {
12
+ if (!e) throw new Error("No authentication provided");
13
+ let t = e.accountDomain !== void 0 ? d(e.accountDomain.trim()) : `https://${window.location.host}`;
14
+ t.charAt(t.length - 1) === "/" && (t = t.slice(0, -1));
15
+ const o = e.getAccessToken && e.getAccessToken(), p = o === void 0 ? {} : { Authorization: `Bearer ${o}` };
16
+ try {
17
+ return await l(
18
+ `${t}${m.metapropertiesWithOptions(
19
+ i,
20
+ s
21
+ )}?filterKey=savedFilters&limit=30&labelKeyset=${n}&zindexKeyset=${c}&mpoKeyset=${a}`,
22
+ { headers: p }
23
+ );
24
+ } catch (r) {
25
+ throw new Error(`Error fetching initial filters: ${r}`);
26
+ }
27
+ };
28
+ export {
29
+ w as getMetapropertiesOptions
30
+ };
31
+ //# sourceMappingURL=getMetapropertiesOptions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getMetapropertiesOptions.js","sources":["../../src/api/rest/getMetapropertiesOptions.ts"],"sourcesContent":["import { getRequest } from '.';\nimport { handlers } from './handlers';\nimport { AuthInformationState } from '@src/auth/useAuthInformation';\nimport { ensureValidUrl } from '@src/utils/url';\nimport { SmartfilterMetaproperty } from './types';\n\ntype OptionsRequestType = {\n\tauth: AuthInformationState | null;\n\tmetapropertyId: string;\n\tsmartfilterId: string;\n\tlabelKeyset: string;\n\tzindexKeyset: number;\n\tmpoKeyset: string;\n};\n\nexport const getMetapropertiesOptions = async ({\n\tauth,\n\tsmartfilterId,\n\tmetapropertyId,\n\tlabelKeyset,\n\tzindexKeyset,\n\tmpoKeyset,\n}: OptionsRequestType) => {\n\tif (!auth) throw new Error('No authentication provided');\n\n\tlet host =\n\t\tauth.accountDomain !== undefined\n\t\t\t? ensureValidUrl(auth.accountDomain.trim())\n\t\t\t: `https://${window.location.host}`;\n\n\t// For the sake of consistency, check if last char is a slash\n\t// and remove it\n\tif (host.charAt(host.length - 1) === '/') {\n\t\thost = host.slice(0, -1);\n\t}\n\n\tconst accessToken = auth.getAccessToken && auth.getAccessToken();\n\n\tconst headers = accessToken === undefined ? {} : { Authorization: `Bearer ${accessToken}` };\n\n\ttry {\n\t\tconst options = await getRequest<SmartfilterMetaproperty>(\n\t\t\t`${host}${handlers.metapropertiesWithOptions(\n\t\t\t\tsmartfilterId,\n\t\t\t\tmetapropertyId,\n\t\t\t)}?filterKey=savedFilters&limit=30&labelKeyset=${labelKeyset}&zindexKeyset=${zindexKeyset}&mpoKeyset=${mpoKeyset}`,\n\t\t\t{ headers },\n\t\t);\n\n\t\treturn options;\n\t} catch (error) {\n\t\tthrow new Error(`Error fetching initial filters: ${error}`);\n\t}\n};\n"],"names":["getMetapropertiesOptions","auth","smartfilterId","metapropertyId","labelKeyset","zindexKeyset","mpoKeyset","host","ensureValidUrl","accessToken","headers","getRequest","handlers","error"],"mappings":";;;AAeO,MAAMA,IAA2B,OAAO;AAAA,EAC9C,MAAAC;AAAA,EACA,eAAAC;AAAA,EACA,gBAAAC;AAAA,EACA,aAAAC;AAAA,EACA,cAAAC;AAAA,EACA,WAAAC;AACD,MAA0B;AACzB,MAAI,CAACL,EAAM,OAAM,IAAI,MAAM,4BAA4B;AAEvD,MAAIM,IACHN,EAAK,kBAAkB,SACpBO,EAAeP,EAAK,cAAc,KAAA,CAAM,IACxC,WAAW,OAAO,SAAS,IAAI;AAInC,EAAIM,EAAK,OAAOA,EAAK,SAAS,CAAC,MAAM,QACpCA,IAAOA,EAAK,MAAM,GAAG,EAAE;AAGxB,QAAME,IAAcR,EAAK,kBAAkBA,EAAK,eAAA,GAE1CS,IAAUD,MAAgB,SAAY,CAAA,IAAK,EAAE,eAAe,UAAUA,CAAW,GAAA;AAEvF,MAAI;AASH,WARgB,MAAME;AAAA,MACrB,GAAGJ,CAAI,GAAGK,EAAS;AAAA,QAClBV;AAAA,QACAC;AAAA,MAAA,CACA,gDAAgDC,CAAW,iBAAiBC,CAAY,cAAcC,CAAS;AAAA,MAChH,EAAE,SAAAI,EAAA;AAAA,IAAQ;AAAA,EAIZ,SAASG,GAAO;AACf,UAAM,IAAI,MAAM,mCAAmCA,CAAK,EAAE;AAAA,EAC3D;AACD;"}