@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.
- package/ActiveFilter.js +33 -0
- package/ActiveFilter.js.map +1 -0
- package/ActiveFilters.js +81 -0
- package/ActiveFilters.js.map +1 -0
- package/AddMedia.js +90 -0
- package/AddMedia.js.map +1 -0
- package/Advanced.js +66 -0
- package/Advanced.js.map +1 -0
- package/App.d.ts +1 -1
- package/App.js +89 -0
- package/App.js.map +1 -0
- package/AssetCard.js +172 -0
- package/AssetCard.js.map +1 -0
- package/AssetCardMetaproperties.js +47 -0
- package/AssetCardMetaproperties.js.map +1 -0
- package/AssetFilter.js +158 -0
- package/AssetFilter.js.map +1 -0
- package/AssetFilterContext.js +162 -0
- package/AssetFilterContext.js.map +1 -0
- package/AssetItem.js +40 -0
- package/AssetItem.js.map +1 -0
- package/AssetList.js +158 -0
- package/AssetList.js.map +1 -0
- package/AssetTypeItem.js +34 -0
- package/AssetTypeItem.js.map +1 -0
- package/AssetsView.js +61 -0
- package/AssetsView.js.map +1 -0
- package/Autocomplete.js +148 -0
- package/Autocomplete.js.map +1 -0
- package/ButtonAction.js +14 -0
- package/ButtonAction.js.map +1 -0
- package/CardSkeleton.js +31 -0
- package/CardSkeleton.js.map +1 -0
- package/Checkbox.styles.js +38 -0
- package/Checkbox.styles.js.map +1 -0
- package/Chip.js +43 -0
- package/Chip.js.map +1 -0
- package/CollectionCard.js +56 -0
- package/CollectionCard.js.map +1 -0
- package/CollectionItem.js +41 -0
- package/CollectionItem.js.map +1 -0
- package/CollectionList.js +53 -0
- package/CollectionList.js.map +1 -0
- package/CollectionView.js +73 -0
- package/CollectionView.js.map +1 -0
- package/CollectionsView.js +58 -0
- package/CollectionsView.js.map +1 -0
- package/ConfigContext.js +18 -0
- package/ConfigContext.js.map +1 -0
- package/ConnectButton.js +20 -0
- package/ConnectButton.js.map +1 -0
- package/Container.js +52 -0
- package/Container.js.map +1 -0
- package/ContextAction.js +42 -0
- package/ContextAction.js.map +1 -0
- package/Dat/Dat.d.ts +2 -12
- package/Dat/DatDropdownItem.d.ts +1 -1
- package/Dat/index.d.ts +0 -1
- package/Dat/types.d.ts +1 -1
- package/Dat.js +90 -0
- package/Dat.js.map +1 -0
- package/DatDropdownItem.js +47 -0
- package/DatDropdownItem.js.map +1 -0
- package/DesignSystemContext.js +12 -0
- package/DesignSystemContext.js.map +1 -0
- package/DirectionSelect.js +43 -0
- package/DirectionSelect.js.map +1 -0
- package/DocumentIcon.js +69 -0
- package/DocumentIcon.js.map +1 -0
- package/DomainInput.js +39 -0
- package/DomainInput.js.map +1 -0
- package/DragSelect.js +144 -0
- package/DragSelect.js.map +1 -0
- package/Dropdown.js +72 -0
- package/Dropdown.js.map +1 -0
- package/DropdownContent.js +59 -0
- package/DropdownContent.js.map +1 -0
- package/DropdownListItem.js +52 -0
- package/DropdownListItem.js.map +1 -0
- package/ErrorIcon.js +48 -0
- package/ErrorIcon.js.map +1 -0
- package/ErrorMessage.js +40 -0
- package/ErrorMessage.js.map +1 -0
- package/FieldSelect.js +74 -0
- package/FieldSelect.js.map +1 -0
- package/FileSelector.js +239 -0
- package/FileSelector.js.map +1 -0
- package/Header.js +42 -0
- package/Header.js.map +1 -0
- package/HorizontalScroll.js +51 -0
- package/HorizontalScroll.js.map +1 -0
- package/InfiniteScroll.js +26 -0
- package/InfiniteScroll.js.map +1 -0
- package/LeftArrow.js +31 -0
- package/LeftArrow.js.map +1 -0
- package/LoginComponent.js +32 -0
- package/LoginComponent.js.map +1 -0
- package/LoginContext.js +85 -0
- package/LoginContext.js.map +1 -0
- package/MetapropertyFilterContent.js +25 -0
- package/MetapropertyFilterContent.js.map +1 -0
- package/MetapropertyOption.js +24 -0
- package/MetapropertyOption.js.map +1 -0
- package/Modal.js +48 -0
- package/Modal.js.map +1 -0
- package/NoResults.js +51 -0
- package/NoResults.js.map +1 -0
- package/Oops.js +54 -0
- package/Oops.js.map +1 -0
- package/Option.js +50 -0
- package/Option.js.map +1 -0
- package/RefreshingSpinner.js +22 -0
- package/RefreshingSpinner.js.map +1 -0
- package/ReportModal.js +51 -0
- package/ReportModal.js.map +1 -0
- package/RightArrow.js +31 -0
- package/RightArrow.js.map +1 -0
- package/RootElementContext.js +12 -0
- package/RootElementContext.js.map +1 -0
- package/SearchInput.js +76 -0
- package/SearchInput.js.map +1 -0
- package/SelectedItemContainer.js +44 -0
- package/SelectedItemContainer.js.map +1 -0
- package/SelectedItems.js +27 -0
- package/SelectedItems.js.map +1 -0
- package/SelectionContext.js +144 -0
- package/SelectionContext.js.map +1 -0
- package/SelectionFooter.js +65 -0
- package/SelectionFooter.js.map +1 -0
- package/ShadowRoot.js +11 -0
- package/ShadowRoot.js.map +1 -0
- package/ShadowRootInternal.js +78 -0
- package/ShadowRootInternal.js.map +1 -0
- package/Shield.js +25 -0
- package/Shield.js.map +1 -0
- package/Skeleton.js +43 -0
- package/Skeleton.js.map +1 -0
- package/SmartFilterContent.js +11 -0
- package/SmartFilterContent.js.map +1 -0
- package/SmartFilterSelect.js +91 -0
- package/SmartFilterSelect.js.map +1 -0
- package/Smartfilters.js +186 -0
- package/Smartfilters.js.map +1 -0
- package/Spinner.js +32 -0
- package/Spinner.js.map +1 -0
- package/StatefulAssetList.js +100 -0
- package/StatefulAssetList.js.map +1 -0
- package/Styles.css.js +5 -0
- package/Styles.css.js.map +1 -0
- package/SwitchNLS.js +80 -0
- package/SwitchNLS.js.map +1 -0
- package/TagItem.js +38 -0
- package/TagItem.js.map +1 -0
- package/Tags.js +48 -0
- package/Tags.js.map +1 -0
- package/Theming.js +30 -0
- package/Theming.js.map +1 -0
- package/Toolbar.js +53 -0
- package/Toolbar.js.map +1 -0
- package/Tooltip.js +81 -0
- package/Tooltip.js.map +1 -0
- package/ViewSwitch.js +45 -0
- package/ViewSwitch.js.map +1 -0
- package/api/filterAssets.d.ts +1 -1
- package/api/getCollections.d.ts +1 -1
- package/api/getFilters.d.ts +1 -1
- package/api/getSimilarityAssets.d.ts +1 -1
- package/api/index.d.ts +2 -2
- package/api/rest/autocomplete.d.ts +1 -1
- package/api/rest/getAssetCounts.d.ts +2 -2
- package/api/rest/getInitialFilters.d.ts +2 -2
- package/api/rest/getMetapropertiesOptions.d.ts +1 -1
- package/app-config/ConfigContext.d.ts +3 -4
- package/app-config/appConfig.type.guard.d.ts +1 -1
- package/asset.type.js +31 -0
- package/asset.type.js.map +1 -0
- package/asyncDebounce.js +14 -0
- package/asyncDebounce.js.map +1 -0
- package/auth.js +35 -0
- package/auth.js.map +1 -0
- package/autocomplete2.js +25 -0
- package/autocomplete2.js.map +1 -0
- package/base64Converter.js +15 -0
- package/base64Converter.js.map +1 -0
- package/chunk.js +10 -0
- package/chunk.js.map +1 -0
- package/class.js +7 -0
- package/class.js.map +1 -0
- package/combineFilters.js +9 -0
- package/combineFilters.js.map +1 -0
- package/combineMetaproperties.js +25 -0
- package/combineMetaproperties.js.map +1 -0
- package/common/components/CardSkeleton.d.ts +1 -1
- package/common/components/Checkbox.styles.d.ts +4 -4
- package/common/components/Chip.d.ts +1 -1
- package/common/components/DocumentIcon.d.ts +1 -1
- package/common/components/DragSelect.d.ts +1 -1
- package/common/components/HorizontalScroll.d.ts +1 -1
- package/common/components/InfiniteScroll.d.ts +1 -1
- package/common/components/LeftArrow.d.ts +1 -1
- package/common/components/Modal.d.ts +1 -1
- package/common/components/NoResults.d.ts +1 -1
- package/common/components/RightArrow.d.ts +1 -1
- package/common/components/Skeleton.d.ts +1 -1
- package/common/components/Spinner.d.ts +1 -1
- package/common/components/Tooltip.d.ts +1 -1
- package/common/components/dropdown/Dropdown.d.ts +1 -1
- package/common/components/dropdown/DropdownContent.d.ts +1 -1
- package/common/components/dropdown/DropdownListItem.d.ts +1 -1
- package/common/hooks/useClickOutside.d.ts +1 -1
- package/constants.js +15 -0
- package/constants.js.map +1 -0
- package/createSelectors.js +11 -0
- package/createSelectors.js.map +1 -0
- package/crypto.js +21 -0
- package/crypto.js.map +1 -0
- package/error-handling/ErrorIcon.d.ts +1 -1
- package/error-handling/ErrorMessage.d.ts +1 -1
- package/error-handling/Oops.d.ts +1 -1
- package/error-handling/ReportModal.d.ts +1 -1
- package/error-handling/Shield.d.ts +1 -1
- package/filter/AssetFilter.d.ts +1 -1
- package/filter/AssetFilterContext.d.ts +3 -3
- package/filter/active-filters/ActiveFilter.d.ts +1 -1
- package/filter/active-filters/ActiveFilters.d.ts +1 -1
- package/filter/filters/advanced/Advanced.d.ts +1 -1
- package/filter/filters/advanced/AssetTypeItem.d.ts +1 -1
- package/filter/filters/metaproperty/Metaproperty.d.ts +1 -1
- package/filter/filters/metaproperty/MetapropertyFilterContent.d.ts +1 -1
- package/filter/filters/metaproperty/MetapropertyOption.d.ts +1 -1
- package/filter/filters/metaproperty/SmartFilterContent.d.ts +1 -1
- package/filter/filters/smartfilters/Metaproperties/Autocomplete.d.ts +3 -3
- package/filter/filters/smartfilters/Metaproperties/Option.d.ts +2 -2
- package/filter/filters/smartfilters/Metaproperties/SmartFilterSelect.d.ts +2 -2
- package/filter/filters/smartfilters/Smartfilters.d.ts +2 -2
- package/filter/filters/tags/TagItem.d.ts +1 -1
- package/filter/filters/tags/Tags.d.ts +1 -1
- package/filterAssets.js +175 -0
- package/filterAssets.js.map +1 -0
- package/filterEmptyMetaproperties.js +11 -0
- package/filterEmptyMetaproperties.js.map +1 -0
- package/getAsset.js +70 -0
- package/getAsset.js.map +1 -0
- package/getAssetCounts.js +27 -0
- package/getAssetCounts.js.map +1 -0
- package/getAssets.js +137 -0
- package/getAssets.js.map +1 -0
- package/getCollections.js +78 -0
- package/getCollections.js.map +1 -0
- package/getFilters.js +84 -0
- package/getFilters.js.map +1 -0
- package/getInitialFilters.js +51 -0
- package/getInitialFilters.js.map +1 -0
- package/getMetapropertiesOptions.js +31 -0
- package/getMetapropertiesOptions.js.map +1 -0
- package/getSimilarityAssets.js +141 -0
- package/getSimilarityAssets.js.map +1 -0
- package/handlers.js +11 -0
- package/handlers.js.map +1 -0
- package/helpers.js +7 -0
- package/helpers.js.map +1 -0
- package/index.js +9 -1162
- package/index.js.map +1 -0
- package/index2.js +18 -0
- package/index2.js.map +1 -0
- package/index3.js +36 -0
- package/index3.js.map +1 -0
- package/index4.js +20 -0
- package/index4.js.map +1 -0
- package/logger.js +7 -0
- package/logger.js.map +1 -0
- package/login/LoginComponent.d.ts +1 -1
- package/login/LoginContext.d.ts +1 -1
- package/login/components/ConnectButton.d.ts +1 -1
- package/login/components/Container.d.ts +1 -1
- package/login/components/DomainInput.d.ts +1 -1
- package/login/components/Header.d.ts +1 -1
- package/login/components/RefreshingSpinner.d.ts +1 -1
- package/loginwindow.js +84 -0
- package/loginwindow.js.map +1 -0
- package/normalizeResponse.js +31 -0
- package/normalizeResponse.js.map +1 -0
- package/oauth2.js +87 -0
- package/oauth2.js.map +1 -0
- package/order/DirectionSelect.d.ts +1 -1
- package/order/FieldSelect.d.ts +2 -2
- package/package.json +2 -9
- package/result.type.js +25 -0
- package/result.type.js.map +1 -0
- package/router/RouterContext.d.ts +1 -1
- package/search/SearchInput.d.ts +1 -1
- package/search/SwitchNLS.d.ts +1 -1
- package/search/index.d.ts +0 -2
- package/select/FileSelector.d.ts +1 -1
- package/select/SelectionContext.d.ts +1 -1
- package/select/SelectionFooter.d.ts +1 -1
- package/select/add-media/AddMedia.d.ts +1 -1
- package/select/add-media/ButtonAction.d.ts +1 -1
- package/select/current-selection/AssetItem.d.ts +1 -1
- package/select/current-selection/CollectionItem.d.ts +1 -1
- package/select/current-selection/SelectedItemContainer.d.ts +1 -1
- package/select/current-selection/SelectedItems.d.ts +1 -1
- package/store/useDatStore.d.ts +73 -0
- package/store/useOrderingStore.d.ts +2 -2
- package/store/useRouterStore.d.ts +4 -4
- package/store/useSearchStore.d.ts +69 -0
- package/store/useSimilaritySearchStore.d.ts +67 -0
- package/style/DesignSystemContext.d.ts +1 -1
- package/style/RootElementContext.d.ts +1 -1
- package/style/Theming.d.ts +1 -1
- package/style/shadowroot/ShadowRoot.d.ts +1 -1
- package/style/shadowroot/ShadowRootInternal.d.ts +1 -1
- package/text.js +9 -0
- package/text.js.map +1 -0
- package/toolbar/Toolbar.d.ts +1 -1
- package/toolbar/ViewSwitch.d.ts +1 -1
- package/trimMetapropertyValue.js +6 -0
- package/trimMetapropertyValue.js.map +1 -0
- package/url.js +7 -0
- package/url.js.map +1 -0
- package/useAccountDomain.js +33 -0
- package/useAccountDomain.js.map +1 -0
- package/useAuthInformation.js +42 -0
- package/useAuthInformation.js.map +1 -0
- package/useClickOutside.js +16 -0
- package/useClickOutside.js.map +1 -0
- package/useDatStore.js +62 -0
- package/useDatStore.js.map +1 -0
- package/useDimensions.js +31 -0
- package/useDimensions.js.map +1 -0
- package/useOrderingStore.js +27 -0
- package/useOrderingStore.js.map +1 -0
- package/useRouterStore.js +21 -0
- package/useRouterStore.js.map +1 -0
- package/useSearchStore.js +49 -0
- package/useSearchStore.js.map +1 -0
- package/useSimilaritySearchStore.js +28 -0
- package/useSimilaritySearchStore.js.map +1 -0
- package/utils/base64Converter.d.ts +1 -1
- package/utils/combineFilters.d.ts +1 -1
- package/utils/combineMetaproperties.d.ts +2 -2
- package/utils/filterEmptyMetaproperties.d.ts +1 -1
- package/utils/getMetaPropertiesForFilter.d.ts +1 -1
- package/utils/normalizeResponse.d.ts +1 -1
- package/utils.js +49 -0
- package/utils.js.map +1 -0
- package/utils2.js +51 -0
- package/utils2.js.map +1 -0
- package/views/asset/AssetList.d.ts +5 -3
- package/views/asset/AssetsView.d.ts +1 -1
- package/views/asset/StatefulAssetList.d.ts +2 -2
- package/views/asset/asset-card/AssetCard.d.ts +1 -1
- package/views/asset/asset-card/AssetCardMetaproperties.d.ts +3 -3
- package/views/asset/asset-card/ContextAction.d.ts +1 -1
- package/views/collection/CollectionView.d.ts +1 -1
- package/views/collections/CollectionCard.d.ts +1 -1
- package/views/collections/CollectionList.d.ts +1 -1
- package/views/collections/CollectionsView.d.ts +1 -1
- package/Dat/DatContext.d.ts +0 -12
- package/__tests__/utils/index.d.ts +0 -116
- package/api/__tests__/testMocks/mocks.d.ts +0 -14
- package/api/__tests__/utils.d.ts +0 -10
- package/common/components/__mocks__/Tooltip.d.ts +0 -6
- package/common/components/__tests__/utils.d.ts +0 -34
- package/error-handling/__tests__/utils.d.ts +0 -56
- package/filter/__tests__/utils.d.ts +0 -13
- package/index.mjs +0 -1163
- package/login/__tests__/mocks.d.ts +0 -1
- package/login/__tests__/utils.d.ts +0 -41
- package/search/SearchContext.d.ts +0 -25
- package/search/SimilaritySearchContext.d.ts +0 -21
- package/search/__mocks__/SimilaritySearchContext.d.ts +0 -5
- package/select/__tests__/utils.d.ts +0 -11
- package/style/shadowroot/__mocks__/ShadowRoot.d.ts +0 -4
- package/utils/__mocks__/logger.d.ts +0 -4
- package/views/asset/__tests__/utils.d.ts +0 -7
- 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
|
package/getAsset.js.map
ADDED
|
@@ -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
|
package/getAssets.js.map
ADDED
|
@@ -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;"}
|