@internetarchive/collection-browser 2.22.1-alpha-webdev7818.5 → 2.22.1-alpha2

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 (45) hide show
  1. package/.editorconfig +29 -29
  2. package/.github/workflows/ci.yml +27 -27
  3. package/.github/workflows/gh-pages-main.yml +39 -39
  4. package/.github/workflows/npm-publish.yml +39 -39
  5. package/.github/workflows/pr-preview.yml +38 -38
  6. package/.husky/pre-commit +4 -4
  7. package/.prettierignore +1 -1
  8. package/LICENSE +661 -661
  9. package/README.md +83 -83
  10. package/dist/src/collection-browser.d.ts +6 -3
  11. package/dist/src/collection-browser.js +691 -681
  12. package/dist/src/collection-browser.js.map +1 -1
  13. package/dist/src/data-source/collection-browser-data-source-interface.js.map +1 -1
  14. package/dist/src/data-source/collection-browser-data-source.js.map +1 -1
  15. package/dist/src/manage/manage-bar.d.ts +4 -0
  16. package/dist/src/manage/manage-bar.js +21 -0
  17. package/dist/src/manage/manage-bar.js.map +1 -1
  18. package/dist/src/manage/remove-items-modal-content.js +0 -1
  19. package/dist/src/manage/remove-items-modal-content.js.map +1 -1
  20. package/dist/src/tiles/list/tile-list-compact-header.js +45 -45
  21. package/dist/src/tiles/list/tile-list-compact-header.js.map +1 -1
  22. package/dist/src/tiles/list/tile-list-compact.js +97 -97
  23. package/dist/src/tiles/list/tile-list-compact.js.map +1 -1
  24. package/dist/src/tiles/list/tile-list.js +289 -289
  25. package/dist/src/tiles/list/tile-list.js.map +1 -1
  26. package/dist/test/collection-browser.test.js +187 -187
  27. package/dist/test/collection-browser.test.js.map +1 -1
  28. package/eslint.config.mjs +53 -53
  29. package/index.html +24 -24
  30. package/local.archive.org.cert +86 -86
  31. package/local.archive.org.key +27 -27
  32. package/package.json +117 -117
  33. package/renovate.json +6 -6
  34. package/src/collection-browser.ts +2763 -2755
  35. package/src/data-source/collection-browser-data-source-interface.ts +333 -333
  36. package/src/data-source/collection-browser-data-source.ts +1390 -1390
  37. package/src/manage/manage-bar.ts +23 -0
  38. package/src/manage/remove-items-modal-content.ts +0 -1
  39. package/src/tiles/list/tile-list-compact-header.ts +86 -86
  40. package/src/tiles/list/tile-list-compact.ts +236 -236
  41. package/src/tiles/list/tile-list.ts +688 -688
  42. package/test/collection-browser.test.ts +2359 -2359
  43. package/tsconfig.json +20 -20
  44. package/web-dev-server.config.mjs +30 -30
  45. package/web-test-runner.config.mjs +41 -41
@@ -1 +1 @@
1
- {"version":3,"file":"collection-browser-data-source-interface.js","sourceRoot":"","sources":["../../../src/data-source/collection-browser-data-source-interface.ts"],"names":[],"mappings":"","sourcesContent":["import type {\r\n FilterMap,\r\n Aggregation,\r\n CollectionExtraInfo,\r\n AccountExtraInfo,\r\n PageElementMap,\r\n SearchResponseSessionContext,\r\n} from '@internetarchive/search-service';\r\nimport type { ReactiveController } from 'lit';\r\nimport type {\r\n PrefixFilterType,\r\n PrefixFilterCounts,\r\n TileModel,\r\n} from '../models';\r\nimport type {\r\n PageSpecifierParams,\r\n CollectionTitles,\r\n TVChannelAliases,\r\n} from './models';\r\n\r\nexport interface CollectionBrowserDataSourceInterface\r\n extends ReactiveController {\r\n /**\r\n * How many tile models are present in this data source\r\n */\r\n readonly size: number;\r\n\r\n /**\r\n * How many results there are in the full result set for the current query\r\n * (not necessarily all loaded yet).\r\n */\r\n readonly totalResults: number;\r\n\r\n /**\r\n * Whether the host has a valid set of properties for performing a search.\r\n * For instance, on the search page this requires a valid search service and a\r\n * non-empty query, while collection pages allow searching with an empty query\r\n * for MDS but not FTS.\r\n */\r\n readonly canPerformSearch: boolean;\r\n\r\n /**\r\n * Whether the end of the set of results for the current query state has been\r\n * encountered (i.e., the last page of results).\r\n */\r\n readonly endOfDataReached: boolean;\r\n\r\n /**\r\n * True if the initial work for a new query state has been completed (i.e., firing initial\r\n * page/facet requests). False otherwise.\r\n */\r\n readonly queryInitialized: boolean;\r\n\r\n /**\r\n * A string key compactly representing the current full search state, which can\r\n * be used to determine, e.g., when a new search is required or whether an arriving\r\n * response is outdated.\r\n */\r\n readonly pageFetchQueryKey: string;\r\n\r\n /**\r\n * Similar to `pageFetchQueryKey`, but excluding properties that do not affect\r\n * the validity of a set of facets (e.g., sort).\r\n */\r\n readonly facetFetchQueryKey: string;\r\n\r\n /**\r\n * An object representing any collection- or profile-specific properties to be passed along\r\n * to the search service, specifying the exact page/tab to fetch results for.\r\n */\r\n readonly pageSpecifierParams: PageSpecifierParams | null;\r\n\r\n /**\r\n * A FilterMap object representing all filters applied to the current search,\r\n * including any facets, letter filters, and date ranges.\r\n */\r\n readonly filterMap: FilterMap;\r\n\r\n /**\r\n * The full set of aggregations retrieved for the current search.\r\n */\r\n readonly aggregations?: Record<string, Aggregation>;\r\n\r\n /**\r\n * The `year_histogram` or `date_histogram` aggregation retrieved for the current search.\r\n */\r\n readonly histogramAggregation?: Aggregation;\r\n\r\n /**\r\n * A map from collection identifiers that appear on hits or aggregations for the\r\n * current search, to their human-readable collection titles.\r\n */\r\n readonly collectionTitles: CollectionTitles;\r\n\r\n /**\r\n * A map from TV channel names appearing in `creator` aggregations, to their\r\n * more human-readable network names.\r\n */\r\n readonly tvChannelAliases: TVChannelAliases;\r\n\r\n /**\r\n * The \"extra info\" package provided by the PPS for collection pages, including details\r\n * used to populate the target collection header & About tab content.\r\n */\r\n readonly collectionExtraInfo?: CollectionExtraInfo;\r\n\r\n /**\r\n * The \"extra info\" package provided by the PPS for profile pages, including details\r\n * used to populate the profile header.\r\n */\r\n readonly accountExtraInfo?: AccountExtraInfo;\r\n\r\n /**\r\n * Context about the user session that produced the search response, from the PPS.\r\n */\r\n readonly sessionContext?: SearchResponseSessionContext;\r\n\r\n /**\r\n * The set of requested page elements for profile pages, if applicable. These represent\r\n * any content specific to the current profile tab.\r\n */\r\n readonly pageElements?: PageElementMap;\r\n\r\n /**\r\n * An array of the current target collection's parent collections. Should include *all*\r\n * ancestors in the collection hierarchy, not just the immediate parent.\r\n */\r\n readonly parentCollections?: string[];\r\n\r\n /**\r\n * An object storing result counts for the current search bucketed by letter prefix.\r\n * Keys are the result field on which the prefixes are considered (e.g., title/creator)\r\n * and values are a Record mapping letters to their counts.\r\n */\r\n readonly prefixFilterCountMap: Partial<\r\n Record<PrefixFilterType, PrefixFilterCounts>\r\n >;\r\n\r\n /**\r\n * Any error message from the most recent search results response.\r\n */\r\n readonly queryErrorMessage?: string;\r\n\r\n /**\r\n * An array of all the tile models whose management checkboxes are checked\r\n */\r\n readonly checkedTileModels: TileModel[];\r\n\r\n /**\r\n * An array of all the tile models whose management checkboxes are unchecked\r\n */\r\n readonly uncheckedTileModels: TileModel[];\r\n\r\n /**\r\n * A Promise which, after each query change, resolves once the fetches for the initial\r\n * search have completed. Waits for *both* the hits and aggregations fetches to finish.\r\n *\r\n * Ensure you await this component's `updateComplete` promise before awaiting this\r\n * one, to ensure you do not await an obsolete promise from the previous update.\r\n */\r\n readonly initialSearchComplete: Promise<boolean>;\r\n\r\n /**\r\n * Resets the data source to its empty state, with no result pages, aggregations, etc.\r\n */\r\n reset(): void;\r\n\r\n /**\r\n * Resets the data source's result pages, keeping other state intact.\r\n */\r\n resetPages(): void;\r\n\r\n /**\r\n * Adds the given page of tile models to the data source.\r\n * If the given page number already exists, that page will be overwritten.\r\n * This method expects that the provided tiles already fit the configured page size; it\r\n * will not split them into multiple pages.\r\n * @param pageNum Which page number to add (indexed starting from 1)\r\n * @param pageTiles The array of tile models for the new page\r\n */\r\n addPage(pageNum: number, pageTiles: TileModel[]): void;\r\n\r\n /**\r\n * Adds all of the given pages of tile models to the data source, splitting them into\r\n * multiple pages according to the configured page size if necessary. Any pages that\r\n * have tiles added by this method will have any existing content overwritten.\r\n * @param firstPageNum Which page number to start adding pages from (pages are indexed starting from 1)\r\n * @param tiles The full array of tile models to add across one or more pages\r\n */\r\n addMultiplePages(firstPageNum: number, tiles: TileModel[]): void;\r\n\r\n /**\r\n * Returns the given page of tile models from the data source.\r\n * @param pageNum Which page number to get (indexed starting from 1)\r\n */\r\n getPage(pageNum: number): TileModel[];\r\n\r\n /**\r\n * Returns the full set of paged tile models stored in this data source.\r\n */\r\n getAllPages(): Record<string, TileModel[]>;\r\n\r\n /**\r\n * Whether the data source contains any tiles for the given page number.\r\n * @param pageNum Which page number to query (indexed starting from 1)\r\n */\r\n hasPage(pageNum: number): boolean;\r\n\r\n /**\r\n * Returns the single tile model appearing at the given index in the\r\n * data source, with respect to the current page size. Returns `undefined` if\r\n * the corresponding page is not present on the data source or if it does not\r\n * contain a tile model at the corresponding index.\r\n * @param index The 0-based index (within the full data source) of the tile to get\r\n */\r\n getTileModelAt(index: number): TileModel | undefined;\r\n\r\n /**\r\n * Returns the first numeric tile index corresponding to the given tile model object,\r\n * or -1 if the given tile model is not present.\r\n * @param tile The tile model to search for in the data source\r\n */\r\n indexOf(tile: TileModel): number;\r\n\r\n /**\r\n * Requests that the data source fire a backend request for the given page of results.\r\n * @param pageNum Which page number to fetch results for\r\n * @param numInitialPages How many pages should be batched together on an initial fetch\r\n */\r\n fetchPage(pageNum: number, numInitialPages?: number): Promise<void>;\r\n\r\n /**\r\n * Requests that the data source update its prefix bucket result counts for the given\r\n * type of prefix filter.\r\n * @param filterType Which prefixable field to update the buckets for (e.g., title/creator)\r\n */\r\n updatePrefixFilterCounts(filterType: PrefixFilterType): Promise<void>;\r\n\r\n /**\r\n * Fetches and caches the prefix filter counts for the current sort type,\r\n * provided it is one that permits prefix filtering. (If not, this does nothing).\r\n */\r\n updatePrefixFiltersForCurrentSort(): Promise<void>;\r\n\r\n /**\r\n * Clears the cached letter counts for both title and creator, and\r\n * fetches a new set of counts for whichever of them is the currently\r\n * selected sort option (which may be neither).\r\n *\r\n * Call this whenever the counts are invalidated (e.g., by a query change).\r\n */\r\n refreshLetterCounts(): void;\r\n\r\n /**\r\n * Returns the current page size of the data source.\r\n */\r\n getPageSize(): number;\r\n\r\n /**\r\n * Changes the page size used by the data source, discarding any previously-fetched pages.\r\n *\r\n * **Note: this operation will reset any data stored in the data source!**\r\n * @param pageSize\r\n */\r\n setPageSize(pageSize: number): void;\r\n\r\n /**\r\n * Sets the total number of pages that should be batched together on each initial fetch.\r\n * @param pages How many initial pages to batch\r\n */\r\n setNumInitialPages(numPages: number): void;\r\n\r\n /**\r\n * Sets the total result count for this data source to the given value.\r\n * @param count The number of total results to set\r\n */\r\n setTotalResultCount(count: number): void;\r\n\r\n /**\r\n * Sets whether this data source should suppress further data fetches, i.e. ignore any\r\n * future query changes on its host that would trigger a page/facet fetch.\r\n * @param suppressed Whether further fetches for this data source should be suppressed\r\n */\r\n setFetchesSuppressed(suppressed: boolean): void;\r\n\r\n /**\r\n * Sets whether the end of the current data has been reached, indicating whether further\r\n * pages should be looked up.\r\n * @param reached Whether we are at the end of the data for the current query state\r\n */\r\n setEndOfDataReached(reached: boolean): void;\r\n\r\n /**\r\n * Notifies the data source that a query change has occurred, which may trigger a data\r\n * reset & new fetches.\r\n */\r\n handleQueryChange(): Promise<void>;\r\n\r\n /**\r\n * Notifies the data source that the readiness state of the facets has been changed, which\r\n * may trigger facet fetches if they were previously delayed.\r\n */\r\n handleFacetReadinessChange(ready: boolean): Promise<void>;\r\n\r\n /**\r\n * Applies the given map function to all of the tile models in every page of the data\r\n * source.\r\n * @param callback A callback function to apply on each tile model, as with Array.map\r\n */\r\n map(\r\n callback: (\r\n model: TileModel,\r\n index: number,\r\n array: TileModel[],\r\n ) => TileModel,\r\n ): void;\r\n\r\n /**\r\n * Checks every tile's management checkbox\r\n */\r\n checkAllTiles(): void;\r\n\r\n /**\r\n * Unchecks every tile's management checkbox\r\n */\r\n uncheckAllTiles(): void;\r\n\r\n /**\r\n * Removes all tile models that are currently checked & adjusts the paging\r\n * of the data source to account for any new gaps in the data.\r\n */\r\n removeCheckedTiles(): void;\r\n}\r\n"]}
1
+ {"version":3,"file":"collection-browser-data-source-interface.js","sourceRoot":"","sources":["../../../src/data-source/collection-browser-data-source-interface.ts"],"names":[],"mappings":"","sourcesContent":["import type {\n FilterMap,\n Aggregation,\n CollectionExtraInfo,\n AccountExtraInfo,\n PageElementMap,\n SearchResponseSessionContext,\n} from '@internetarchive/search-service';\nimport type { ReactiveController } from 'lit';\nimport type {\n PrefixFilterType,\n PrefixFilterCounts,\n TileModel,\n} from '../models';\nimport type {\n PageSpecifierParams,\n CollectionTitles,\n TVChannelAliases,\n} from './models';\n\nexport interface CollectionBrowserDataSourceInterface\n extends ReactiveController {\n /**\n * How many tile models are present in this data source\n */\n readonly size: number;\n\n /**\n * How many results there are in the full result set for the current query\n * (not necessarily all loaded yet).\n */\n readonly totalResults: number;\n\n /**\n * Whether the host has a valid set of properties for performing a search.\n * For instance, on the search page this requires a valid search service and a\n * non-empty query, while collection pages allow searching with an empty query\n * for MDS but not FTS.\n */\n readonly canPerformSearch: boolean;\n\n /**\n * Whether the end of the set of results for the current query state has been\n * encountered (i.e., the last page of results).\n */\n readonly endOfDataReached: boolean;\n\n /**\n * True if the initial work for a new query state has been completed (i.e., firing initial\n * page/facet requests). False otherwise.\n */\n readonly queryInitialized: boolean;\n\n /**\n * A string key compactly representing the current full search state, which can\n * be used to determine, e.g., when a new search is required or whether an arriving\n * response is outdated.\n */\n readonly pageFetchQueryKey: string;\n\n /**\n * Similar to `pageFetchQueryKey`, but excluding properties that do not affect\n * the validity of a set of facets (e.g., sort).\n */\n readonly facetFetchQueryKey: string;\n\n /**\n * An object representing any collection- or profile-specific properties to be passed along\n * to the search service, specifying the exact page/tab to fetch results for.\n */\n readonly pageSpecifierParams: PageSpecifierParams | null;\n\n /**\n * A FilterMap object representing all filters applied to the current search,\n * including any facets, letter filters, and date ranges.\n */\n readonly filterMap: FilterMap;\n\n /**\n * The full set of aggregations retrieved for the current search.\n */\n readonly aggregations?: Record<string, Aggregation>;\n\n /**\n * The `year_histogram` or `date_histogram` aggregation retrieved for the current search.\n */\n readonly histogramAggregation?: Aggregation;\n\n /**\n * A map from collection identifiers that appear on hits or aggregations for the\n * current search, to their human-readable collection titles.\n */\n readonly collectionTitles: CollectionTitles;\n\n /**\n * A map from TV channel names appearing in `creator` aggregations, to their\n * more human-readable network names.\n */\n readonly tvChannelAliases: TVChannelAliases;\n\n /**\n * The \"extra info\" package provided by the PPS for collection pages, including details\n * used to populate the target collection header & About tab content.\n */\n readonly collectionExtraInfo?: CollectionExtraInfo;\n\n /**\n * The \"extra info\" package provided by the PPS for profile pages, including details\n * used to populate the profile header.\n */\n readonly accountExtraInfo?: AccountExtraInfo;\n\n /**\n * Context about the user session that produced the search response, from the PPS.\n */\n readonly sessionContext?: SearchResponseSessionContext;\n\n /**\n * The set of requested page elements for profile pages, if applicable. These represent\n * any content specific to the current profile tab.\n */\n readonly pageElements?: PageElementMap;\n\n /**\n * An array of the current target collection's parent collections. Should include *all*\n * ancestors in the collection hierarchy, not just the immediate parent.\n */\n readonly parentCollections?: string[];\n\n /**\n * An object storing result counts for the current search bucketed by letter prefix.\n * Keys are the result field on which the prefixes are considered (e.g., title/creator)\n * and values are a Record mapping letters to their counts.\n */\n readonly prefixFilterCountMap: Partial<\n Record<PrefixFilterType, PrefixFilterCounts>\n >;\n\n /**\n * Any error message from the most recent search results response.\n */\n readonly queryErrorMessage?: string;\n\n /**\n * An array of all the tile models whose management checkboxes are checked\n */\n readonly checkedTileModels: TileModel[];\n\n /**\n * An array of all the tile models whose management checkboxes are unchecked\n */\n readonly uncheckedTileModels: TileModel[];\n\n /**\n * A Promise which, after each query change, resolves once the fetches for the initial\n * search have completed. Waits for *both* the hits and aggregations fetches to finish.\n *\n * Ensure you await this component's `updateComplete` promise before awaiting this\n * one, to ensure you do not await an obsolete promise from the previous update.\n */\n readonly initialSearchComplete: Promise<boolean>;\n\n /**\n * Resets the data source to its empty state, with no result pages, aggregations, etc.\n */\n reset(): void;\n\n /**\n * Resets the data source's result pages, keeping other state intact.\n */\n resetPages(): void;\n\n /**\n * Adds the given page of tile models to the data source.\n * If the given page number already exists, that page will be overwritten.\n * This method expects that the provided tiles already fit the configured page size; it\n * will not split them into multiple pages.\n * @param pageNum Which page number to add (indexed starting from 1)\n * @param pageTiles The array of tile models for the new page\n */\n addPage(pageNum: number, pageTiles: TileModel[]): void;\n\n /**\n * Adds all of the given pages of tile models to the data source, splitting them into\n * multiple pages according to the configured page size if necessary. Any pages that\n * have tiles added by this method will have any existing content overwritten.\n * @param firstPageNum Which page number to start adding pages from (pages are indexed starting from 1)\n * @param tiles The full array of tile models to add across one or more pages\n */\n addMultiplePages(firstPageNum: number, tiles: TileModel[]): void;\n\n /**\n * Returns the given page of tile models from the data source.\n * @param pageNum Which page number to get (indexed starting from 1)\n */\n getPage(pageNum: number): TileModel[];\n\n /**\n * Returns the full set of paged tile models stored in this data source.\n */\n getAllPages(): Record<string, TileModel[]>;\n\n /**\n * Whether the data source contains any tiles for the given page number.\n * @param pageNum Which page number to query (indexed starting from 1)\n */\n hasPage(pageNum: number): boolean;\n\n /**\n * Returns the single tile model appearing at the given index in the\n * data source, with respect to the current page size. Returns `undefined` if\n * the corresponding page is not present on the data source or if it does not\n * contain a tile model at the corresponding index.\n * @param index The 0-based index (within the full data source) of the tile to get\n */\n getTileModelAt(index: number): TileModel | undefined;\n\n /**\n * Returns the first numeric tile index corresponding to the given tile model object,\n * or -1 if the given tile model is not present.\n * @param tile The tile model to search for in the data source\n */\n indexOf(tile: TileModel): number;\n\n /**\n * Requests that the data source fire a backend request for the given page of results.\n * @param pageNum Which page number to fetch results for\n * @param numInitialPages How many pages should be batched together on an initial fetch\n */\n fetchPage(pageNum: number, numInitialPages?: number): Promise<void>;\n\n /**\n * Requests that the data source update its prefix bucket result counts for the given\n * type of prefix filter.\n * @param filterType Which prefixable field to update the buckets for (e.g., title/creator)\n */\n updatePrefixFilterCounts(filterType: PrefixFilterType): Promise<void>;\n\n /**\n * Fetches and caches the prefix filter counts for the current sort type,\n * provided it is one that permits prefix filtering. (If not, this does nothing).\n */\n updatePrefixFiltersForCurrentSort(): Promise<void>;\n\n /**\n * Clears the cached letter counts for both title and creator, and\n * fetches a new set of counts for whichever of them is the currently\n * selected sort option (which may be neither).\n *\n * Call this whenever the counts are invalidated (e.g., by a query change).\n */\n refreshLetterCounts(): void;\n\n /**\n * Returns the current page size of the data source.\n */\n getPageSize(): number;\n\n /**\n * Changes the page size used by the data source, discarding any previously-fetched pages.\n *\n * **Note: this operation will reset any data stored in the data source!**\n * @param pageSize\n */\n setPageSize(pageSize: number): void;\n\n /**\n * Sets the total number of pages that should be batched together on each initial fetch.\n * @param pages How many initial pages to batch\n */\n setNumInitialPages(numPages: number): void;\n\n /**\n * Sets the total result count for this data source to the given value.\n * @param count The number of total results to set\n */\n setTotalResultCount(count: number): void;\n\n /**\n * Sets whether this data source should suppress further data fetches, i.e. ignore any\n * future query changes on its host that would trigger a page/facet fetch.\n * @param suppressed Whether further fetches for this data source should be suppressed\n */\n setFetchesSuppressed(suppressed: boolean): void;\n\n /**\n * Sets whether the end of the current data has been reached, indicating whether further\n * pages should be looked up.\n * @param reached Whether we are at the end of the data for the current query state\n */\n setEndOfDataReached(reached: boolean): void;\n\n /**\n * Notifies the data source that a query change has occurred, which may trigger a data\n * reset & new fetches.\n */\n handleQueryChange(): Promise<void>;\n\n /**\n * Notifies the data source that the readiness state of the facets has been changed, which\n * may trigger facet fetches if they were previously delayed.\n */\n handleFacetReadinessChange(ready: boolean): Promise<void>;\n\n /**\n * Applies the given map function to all of the tile models in every page of the data\n * source.\n * @param callback A callback function to apply on each tile model, as with Array.map\n */\n map(\n callback: (\n model: TileModel,\n index: number,\n array: TileModel[],\n ) => TileModel,\n ): void;\n\n /**\n * Checks every tile's management checkbox\n */\n checkAllTiles(): void;\n\n /**\n * Unchecks every tile's management checkbox\n */\n uncheckAllTiles(): void;\n\n /**\n * Removes all tile models that are currently checked & adjusts the paging\n * of the data source to account for any new gaps in the data.\n */\n removeCheckedTiles(): void;\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"collection-browser-data-source.js","sourceRoot":"","sources":["../../../src/data-source/collection-browser-data-source.ts"],"names":[],"mappings":"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","sourcesContent":["import type { ReactiveControllerHost } from 'lit';\r\nimport {\r\n AccountExtraInfo,\r\n Aggregation,\r\n Bucket,\r\n CollectionExtraInfo,\r\n FilterConstraint,\r\n FilterMap,\r\n FilterMapBuilder,\r\n PageElementMap,\r\n SearchParams,\r\n SearchResponseSessionContext,\r\n SearchResult,\r\n SearchType,\r\n} from '@internetarchive/search-service';\r\nimport {\r\n prefixFilterAggregationKeys,\r\n type FacetBucket,\r\n type PrefixFilterType,\r\n TileModel,\r\n PrefixFilterCounts,\r\n RequestKind,\r\n SortField,\r\n SORT_OPTIONS,\r\n HitRequestSource,\r\n} from '../models';\r\nimport { FACETLESS_PAGE_ELEMENTS, type PageSpecifierParams } from './models';\r\nimport type { CollectionBrowserDataSourceInterface } from './collection-browser-data-source-interface';\r\nimport type { CollectionBrowserSearchInterface } from './collection-browser-query-state';\r\nimport { sha1 } from '../utils/sha1';\r\nimport { log } from '../utils/log';\r\nimport { mergeSelectedFacets } from '../utils/facet-utils';\r\n\r\nexport class CollectionBrowserDataSource\r\n implements CollectionBrowserDataSourceInterface\r\n{\r\n /**\r\n * All pages of tile models that have been fetched so far, indexed by their page\r\n * number (with the first being page 1).\r\n */\r\n private pages: Record<string, TileModel[]> = {};\r\n\r\n /**\r\n * Tile offset to apply when looking up tiles in the pages, in order to maintain\r\n * page alignment after tiles are removed.\r\n */\r\n private offset = 0;\r\n\r\n /**\r\n * Total number of tile models stored in this data source's pages\r\n */\r\n private numTileModels = 0;\r\n\r\n /**\r\n * How many consecutive pages should be batched together on the initial page fetch.\r\n * Defaults to 2 pages.\r\n */\r\n private numInitialPages = 2;\r\n\r\n /**\r\n * A set of fetch IDs that are valid for the current query state\r\n */\r\n private fetchesInProgress = new Set<string>();\r\n\r\n /**\r\n * A record of the query key used for the last search.\r\n * If this changes, we need to load new results.\r\n */\r\n private previousQueryKey: string = '';\r\n\r\n /**\r\n * Whether the initial page of search results for the current query state\r\n * is presently being fetched.\r\n */\r\n private searchResultsLoading = false;\r\n\r\n /**\r\n * Whether the facets (aggregations) for the current query state are\r\n * presently being fetched.\r\n */\r\n private facetsLoading = false;\r\n\r\n /**\r\n * Whether the facets are actually visible -- if not, then we can delay any facet\r\n * fetches until they become visible.\r\n */\r\n private facetsReadyToLoad = false;\r\n\r\n /**\r\n * Whether further query changes should be ignored and not trigger fetches\r\n */\r\n private suppressFetches = false;\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n totalResults = 0;\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n endOfDataReached = false;\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n queryInitialized = false;\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n aggregations?: Record<string, Aggregation>;\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n histogramAggregation?: Aggregation;\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n collectionTitles = new Map<string, string>();\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n tvChannelAliases = new Map<string, string>();\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n collectionExtraInfo?: CollectionExtraInfo;\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n accountExtraInfo?: AccountExtraInfo;\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n sessionContext?: SearchResponseSessionContext;\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n pageElements?: PageElementMap;\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n parentCollections?: string[] = [];\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n prefixFilterCountMap: Partial<Record<PrefixFilterType, PrefixFilterCounts>> =\r\n {};\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n queryErrorMessage?: string;\r\n\r\n /**\r\n * Internal property to store the private value backing the `initialSearchComplete` getter.\r\n */\r\n private _initialSearchCompletePromise: Promise<boolean> =\r\n Promise.resolve(true);\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n get initialSearchComplete(): Promise<boolean> {\r\n return this._initialSearchCompletePromise;\r\n }\r\n\r\n constructor(\r\n /** The host element to which this controller should attach listeners */\r\n private readonly host: ReactiveControllerHost &\r\n CollectionBrowserSearchInterface,\r\n /** Default size of result pages */\r\n private pageSize: number = 50,\r\n ) {\r\n // Just setting some property values\r\n }\r\n\r\n hostConnected(): void {\r\n this.setSearchResultsLoading(this.searchResultsLoading);\r\n this.setFacetsLoading(this.facetsLoading);\r\n }\r\n\r\n hostUpdate(): void {\r\n // This reactive controller hook is run whenever the host component (collection-browser) performs an update.\r\n // We check whether the host's state has changed in a way which should trigger a reset & new results fetch.\r\n\r\n // Only the currently-installed data source should react to the update\r\n if (!this.activeOnHost) return;\r\n\r\n // Copy loading states onto the host\r\n this.setSearchResultsLoading(this.searchResultsLoading);\r\n this.setFacetsLoading(this.facetsLoading);\r\n\r\n // Can't perform searches without a search service\r\n if (!this.host.searchService) return;\r\n\r\n // We should only reset if part of the full query state has changed\r\n const queryKeyChanged = this.pageFetchQueryKey !== this.previousQueryKey;\r\n if (!queryKeyChanged) return;\r\n\r\n // We should only reset if either:\r\n // (a) our state permits a valid search, or\r\n // (b) we have a blank query that we're showing a placeholder/message for\r\n const queryIsEmpty = !this.host.baseQuery;\r\n if (!(this.canPerformSearch || queryIsEmpty)) return;\r\n\r\n if (this.activeOnHost) this.host.emitQueryStateChanged();\r\n this.handleQueryChange();\r\n }\r\n\r\n /**\r\n * Returns whether this data source is the one currently installed on the host component.\r\n */\r\n private get activeOnHost(): boolean {\r\n return this.host.dataSource === this;\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n get size(): number {\r\n return this.numTileModels;\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n reset(): void {\r\n log('Resetting CB data source');\r\n this.pages = {};\r\n this.aggregations = {};\r\n this.histogramAggregation = undefined;\r\n this.pageElements = undefined;\r\n this.parentCollections = [];\r\n this.previousQueryKey = '';\r\n this.queryErrorMessage = undefined;\r\n\r\n this.offset = 0;\r\n this.numTileModels = 0;\r\n this.endOfDataReached = false;\r\n this.queryInitialized = false;\r\n this.facetsLoading = false;\r\n\r\n // Invalidate any fetches in progress\r\n this.fetchesInProgress.clear();\r\n\r\n this.setTotalResultCount(0);\r\n this.requestHostUpdate();\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n resetPages(): void {\r\n if (Object.keys(this.pages).length < this.host.maxPagesToManage) {\r\n this.pages = {};\r\n\r\n // Invalidate any page fetches in progress (keep facet fetches)\r\n this.fetchesInProgress.forEach(key => {\r\n if (!key.startsWith('facets-')) this.fetchesInProgress.delete(key);\r\n });\r\n this.requestHostUpdate();\r\n }\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n addPage(pageNum: number, pageTiles: TileModel[]): void {\r\n this.pages[pageNum] = pageTiles;\r\n this.numTileModels += pageTiles.length;\r\n this.requestHostUpdate();\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n addMultiplePages(firstPageNum: number, tiles: TileModel[]): void {\r\n const numPages = Math.ceil(tiles.length / this.pageSize);\r\n for (let i = 0; i < numPages; i += 1) {\r\n const pageStartIndex = this.pageSize * i;\r\n this.addPage(\r\n firstPageNum + i,\r\n tiles.slice(pageStartIndex, pageStartIndex + this.pageSize),\r\n );\r\n }\r\n\r\n const visiblePages = this.host.currentVisiblePageNumbers;\r\n const needsReload = visiblePages.some(\r\n page => page >= firstPageNum && page <= firstPageNum + numPages,\r\n );\r\n if (needsReload) {\r\n this.refreshVisibleResults();\r\n }\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n getPage(pageNum: number): TileModel[] {\r\n return this.pages[pageNum];\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n getAllPages(): Record<string, TileModel[]> {\r\n return this.pages;\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n hasPage(pageNum: number): boolean {\r\n return !!this.pages[pageNum];\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n getTileModelAt(index: number): TileModel | undefined {\r\n const offsetIndex = index + this.offset;\r\n const expectedPageNum = Math.floor(offsetIndex / this.pageSize) + 1;\r\n const expectedIndexOnPage = offsetIndex % this.pageSize;\r\n\r\n let page = 1;\r\n let tilesSeen = 0;\r\n while (tilesSeen <= offsetIndex) {\r\n if (!this.pages[page]) {\r\n // If we encounter a missing page, either we're past all the results or the page data is sparse.\r\n // So just return the tile at the expected position if it exists.\r\n return this.pages[expectedPageNum]?.[expectedIndexOnPage];\r\n }\r\n\r\n if (tilesSeen + this.pages[page].length > offsetIndex) {\r\n return this.pages[page][offsetIndex - tilesSeen];\r\n }\r\n\r\n tilesSeen += this.pages[page].length;\r\n page += 1;\r\n }\r\n\r\n return this.pages[expectedPageNum]?.[expectedIndexOnPage];\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n indexOf(tile: TileModel): number {\r\n return Object.values(this.pages).flat().indexOf(tile) - this.offset;\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n getPageSize(): number {\r\n return this.pageSize;\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n setPageSize(pageSize: number): void {\r\n this.reset();\r\n this.pageSize = pageSize;\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n setNumInitialPages(numPages: number): void {\r\n this.numInitialPages = numPages;\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n setTotalResultCount(count: number): void {\r\n this.totalResults = count;\r\n if (this.activeOnHost) {\r\n this.host.setTotalResultCount(count);\r\n }\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n setFetchesSuppressed(suppressed: boolean): void {\r\n this.suppressFetches = suppressed;\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n setEndOfDataReached(reached: boolean): void {\r\n this.endOfDataReached = reached;\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n async handleQueryChange(): Promise<void> {\r\n // Don't react to the change if fetches are suppressed for this data source\r\n if (this.suppressFetches) return;\r\n\r\n this.reset();\r\n\r\n // Reset the `initialSearchComplete` promise with a new value for the imminent search\r\n let initialSearchCompleteResolver: (value: boolean) => void;\r\n this._initialSearchCompletePromise = new Promise(res => {\r\n initialSearchCompleteResolver = res;\r\n });\r\n\r\n // Fire the initial page & facet requests\r\n this.queryInitialized = true;\r\n await Promise.all([\r\n this.doInitialPageFetch(),\r\n this.canFetchFacets ? this.fetchFacets() : null,\r\n ]);\r\n\r\n // Resolve the `initialSearchComplete` promise for this search\r\n initialSearchCompleteResolver!(true);\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n async handleFacetReadinessChange(ready: boolean): Promise<void> {\r\n const facetsBecameReady = !this.facetsReadyToLoad && ready;\r\n this.facetsReadyToLoad = ready;\r\n\r\n const needsFetch = facetsBecameReady && this.canFetchFacets;\r\n if (needsFetch) {\r\n this.fetchFacets();\r\n }\r\n }\r\n\r\n /**\r\n * Whether the data source & its host are in a state where a facet request should be fired.\r\n * (i.e., they aren't suppressed or already loading, etc.)\r\n */\r\n private get canFetchFacets(): boolean {\r\n // Don't fetch facets if they are suppressed entirely or not required for the current profile page element\r\n if (this.host.facetLoadStrategy === 'off') return false;\r\n if (FACETLESS_PAGE_ELEMENTS.includes(this.host.profileElement!))\r\n return false;\r\n\r\n // If facets are to be lazy-loaded, don't fetch them if they are not going to be visible anyway\r\n // (wait until they become visible instead)\r\n if (this.host.facetLoadStrategy !== 'eager' && !this.facetsReadyToLoad)\r\n return false;\r\n\r\n // Don't fetch facets again if they are already fetched or pending\r\n const facetsAlreadyFetched =\r\n Object.keys(this.aggregations ?? {}).length > 0;\r\n if (this.facetsLoading || facetsAlreadyFetched) return false;\r\n\r\n return true;\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n map(\r\n callback: (\r\n model: TileModel,\r\n index: number,\r\n array: TileModel[],\r\n ) => TileModel,\r\n ): void {\r\n if (!Object.keys(this.pages).length) return;\r\n this.pages = Object.fromEntries(\r\n Object.entries(this.pages).map(([page, tileModels]) => [\r\n page,\r\n tileModels.map((model, index, array) =>\r\n model ? callback(model, index, array) : model,\r\n ),\r\n ]),\r\n );\r\n this.requestHostUpdate();\r\n this.refreshVisibleResults();\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n checkAllTiles = (): void => {\r\n this.map(model => {\r\n const cloned = model.clone();\r\n cloned.checked = true;\r\n return cloned;\r\n });\r\n };\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n uncheckAllTiles = (): void => {\r\n this.map(model => {\r\n const cloned = model.clone();\r\n cloned.checked = false;\r\n return cloned;\r\n });\r\n };\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n removeCheckedTiles = (): void => {\r\n // To make sure our data source remains page-aligned, we will offset our data source by\r\n // the number of removed tiles, so that we can just add the offset when the infinite\r\n // scroller queries for cell contents.\r\n // This only matters while we're still viewing the same set of results. If the user changes\r\n // their query/filters/sort, then the data source is overwritten and the offset cleared.\r\n const { checkedTileModels, uncheckedTileModels } = this;\r\n const numChecked = checkedTileModels.length;\r\n if (numChecked === 0) return;\r\n this.offset += numChecked;\r\n const newPages: typeof this.pages = {};\r\n\r\n // Which page the remaining tile models start on, post-offset\r\n let offsetPageNumber = Math.floor(this.offset / this.pageSize) + 1;\r\n let indexOnPage = this.offset % this.pageSize;\r\n\r\n // Fill the pages up to that point with empty models\r\n for (let page = 1; page <= offsetPageNumber; page += 1) {\r\n const remainingHidden = this.offset - this.pageSize * (page - 1);\r\n const offsetCellsOnPage = Math.min(this.pageSize, remainingHidden);\r\n newPages[page] = Array(offsetCellsOnPage).fill(undefined);\r\n }\r\n\r\n // Shift all the remaining tiles into their new positions in the data source\r\n for (const model of uncheckedTileModels) {\r\n if (!newPages[offsetPageNumber]) newPages[offsetPageNumber] = [];\r\n newPages[offsetPageNumber].push(model);\r\n indexOnPage += 1;\r\n if (indexOnPage >= this.pageSize) {\r\n offsetPageNumber += 1;\r\n indexOnPage = 0;\r\n }\r\n }\r\n\r\n // Swap in the new pages\r\n this.pages = newPages;\r\n this.numTileModels -= numChecked;\r\n this.totalResults -= numChecked;\r\n this.host.setTileCount(this.size);\r\n this.host.setTotalResultCount(this.totalResults);\r\n this.requestHostUpdate();\r\n this.refreshVisibleResults();\r\n };\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n get checkedTileModels(): TileModel[] {\r\n return this.getFilteredTileModels(model => model.checked);\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n get uncheckedTileModels(): TileModel[] {\r\n return this.getFilteredTileModels(model => !model.checked);\r\n }\r\n\r\n /**\r\n * Returns a flattened, filtered array of all the tile models in the data source\r\n * for which the given predicate returns a truthy value.\r\n *\r\n * @param predicate A callback function to apply on each tile model, as with Array.filter\r\n * @returns A filtered array of tile models satisfying the predicate\r\n */\r\n private getFilteredTileModels(\r\n predicate: (model: TileModel, index: number, array: TileModel[]) => unknown,\r\n ): TileModel[] {\r\n return Object.values(this.pages)\r\n .flat()\r\n .filter((model, index, array) =>\r\n model ? predicate(model, index, array) : false,\r\n );\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n get canPerformSearch(): boolean {\r\n if (!this.host.searchService) return false;\r\n\r\n const trimmedQuery = this.host.baseQuery?.trim();\r\n const hasNonEmptyQuery = !!trimmedQuery;\r\n const isCollectionSearch = !!this.host.withinCollection;\r\n const isProfileSearch = !!this.host.withinProfile;\r\n const hasProfileElement = !!this.host.profileElement;\r\n const isDefaultedSearch = this.host.searchType === SearchType.DEFAULT;\r\n const isMetadataSearch = this.host.searchType === SearchType.METADATA;\r\n const isTvSearch = this.host.searchType === SearchType.TV;\r\n\r\n // Metadata/tv searches within a collection are allowed to have no query.\r\n const isValidForCollectionSearch =\r\n isDefaultedSearch || isMetadataSearch || isTvSearch;\r\n\r\n // Searches within a profile page may also be performed without a query, provided the profile element is set.\r\n const isValidForProfileSearch =\r\n hasProfileElement && (isDefaultedSearch || isMetadataSearch);\r\n\r\n // Otherwise, a non-empty query must be set.\r\n return (\r\n hasNonEmptyQuery ||\r\n (isCollectionSearch && isValidForCollectionSearch) ||\r\n (isProfileSearch && isValidForProfileSearch)\r\n );\r\n }\r\n\r\n /**\r\n * Sets the state for whether the initial set of search results for the\r\n * current query is loading\r\n */\r\n private setSearchResultsLoading(loading: boolean): void {\r\n this.searchResultsLoading = loading;\r\n if (this.activeOnHost) {\r\n this.host.setSearchResultsLoading(loading);\r\n }\r\n }\r\n\r\n /**\r\n * Sets the state for whether the facets for a query is loading\r\n */\r\n private setFacetsLoading(loading: boolean): void {\r\n this.facetsLoading = loading;\r\n if (this.activeOnHost) {\r\n this.host.setFacetsLoading(loading);\r\n }\r\n }\r\n\r\n /**\r\n * Requests that the host perform an update, provided this data\r\n * source is actively installed on it.\r\n */\r\n private requestHostUpdate(): void {\r\n if (this.activeOnHost) {\r\n this.host.requestUpdate();\r\n }\r\n }\r\n\r\n /**\r\n * Requests that the host refresh its visible tiles, provided this\r\n * data source is actively installed on it.\r\n */\r\n private refreshVisibleResults(): void {\r\n if (this.activeOnHost) {\r\n this.host.refreshVisibleResults();\r\n }\r\n }\r\n\r\n /**\r\n * The query key is a string that uniquely identifies the current search.\r\n * It consists of:\r\n * - The current base query\r\n * - The current collection/profile target & page element\r\n * - The current search type\r\n * - Any currently-applied facets\r\n * - Any currently-applied date range\r\n * - Any currently-applied prefix filters\r\n * - The current sort options\r\n *\r\n * This lets us internally keep track of queries so we don't persist data that's\r\n * no longer relevant. Not meant to be human-readable.\r\n */\r\n get pageFetchQueryKey(): string {\r\n const profileKey = `pf;${this.host.withinProfile}--pe;${this.host.profileElement}`;\r\n const pageTarget = this.host.withinCollection ?? profileKey;\r\n const sortField = this.host.selectedSort ?? 'none';\r\n const sortDirection = this.host.sortDirection ?? 'none';\r\n return `fq:${this.fullQuery}-pt:${pageTarget}-st:${this.host.searchType}-sf:${sortField}-sd:${sortDirection}`;\r\n }\r\n\r\n /**\r\n * Similar to `pageFetchQueryKey` above, but excludes sort fields since they\r\n * are not relevant in determining aggregation queries.\r\n */\r\n get facetFetchQueryKey(): string {\r\n const profileKey = `pf;${this.host.withinProfile}--pe;${this.host.profileElement}`;\r\n const pageTarget = this.host.withinCollection ?? profileKey;\r\n return `facets-fq:${this.fullQuery}-pt:${pageTarget}-st:${this.host.searchType}`;\r\n }\r\n\r\n /**\r\n * Constructs a search service FilterMap object from the combination of\r\n * all the currently-applied filters. This includes any facets, letter\r\n * filters, and date range.\r\n */\r\n get filterMap(): FilterMap {\r\n const builder = new FilterMapBuilder();\r\n\r\n const {\r\n minSelectedDate,\r\n maxSelectedDate,\r\n selectedFacets,\r\n internalFilters,\r\n selectedTitleFilter,\r\n selectedCreatorFilter,\r\n } = this.host;\r\n\r\n const dateField = this.host.searchType === SearchType.TV ? 'date' : 'year';\r\n\r\n if (minSelectedDate) {\r\n builder.addFilter(\r\n dateField,\r\n minSelectedDate,\r\n FilterConstraint.GREATER_OR_EQUAL,\r\n );\r\n }\r\n if (maxSelectedDate) {\r\n builder.addFilter(\r\n dateField,\r\n maxSelectedDate,\r\n FilterConstraint.LESS_OR_EQUAL,\r\n );\r\n }\r\n\r\n // Add any selected facets and internal filters\r\n const combinedFilters = mergeSelectedFacets(\r\n internalFilters,\r\n selectedFacets,\r\n );\r\n if (combinedFilters) {\r\n for (const [facetName, facetValues] of Object.entries(combinedFilters)) {\r\n const { name, values } = this.prepareFacetForFetch(\r\n facetName,\r\n facetValues,\r\n );\r\n for (const [value, bucket] of Object.entries(values)) {\r\n let constraint;\r\n if (bucket.state === 'selected') {\r\n constraint = FilterConstraint.INCLUDE;\r\n } else if (bucket.state === 'hidden') {\r\n constraint = FilterConstraint.EXCLUDE;\r\n }\r\n\r\n if (constraint) {\r\n builder.addFilter(name, value, constraint);\r\n }\r\n }\r\n }\r\n }\r\n\r\n // Add any letter filters\r\n if (selectedTitleFilter) {\r\n builder.addFilter(\r\n 'firstTitle',\r\n selectedTitleFilter,\r\n FilterConstraint.INCLUDE,\r\n );\r\n }\r\n if (selectedCreatorFilter) {\r\n builder.addFilter(\r\n 'firstCreator',\r\n selectedCreatorFilter,\r\n FilterConstraint.INCLUDE,\r\n );\r\n }\r\n\r\n // Add any TV clip type filter, if applicable\r\n if (this.host.searchType === SearchType.TV) {\r\n switch (this.host.tvClipFilter) {\r\n case 'commercials':\r\n builder.addFilter('ad_id', '*', FilterConstraint.INCLUDE);\r\n break;\r\n case 'factchecks':\r\n builder.addFilter('factcheck', '*', FilterConstraint.INCLUDE);\r\n break;\r\n case 'quotes':\r\n builder.addFilter('clip', '1', FilterConstraint.INCLUDE);\r\n break;\r\n case 'all':\r\n default:\r\n break;\r\n }\r\n }\r\n\r\n const filterMap = builder.build();\r\n return filterMap;\r\n }\r\n\r\n /**\r\n * Produces a compact unique ID for a search request that can help with debugging\r\n * on the backend by making related requests easier to trace through different services.\r\n * (e.g., tying the hits/aggregations requests for the same page back to a single hash).\r\n *\r\n * @param params The search service parameters for the request\r\n * @param kind The kind of request (hits-only, aggregations-only, or both)\r\n * @returns A Promise resolving to the uid to apply to the request\r\n */\r\n async requestUID(params: SearchParams, kind: RequestKind): Promise<string> {\r\n const paramsToHash = JSON.stringify({\r\n pageType: params.pageType,\r\n pageTarget: params.pageTarget,\r\n query: params.query,\r\n fields: params.fields,\r\n filters: params.filters,\r\n sort: params.sort,\r\n searchType: this.host.searchType,\r\n });\r\n\r\n const fullQueryHash = (await sha1(paramsToHash)).slice(0, 20); // First 80 bits of SHA-1 are plenty for this\r\n const sessionId = (await this.host.getSessionId()).slice(0, 20); // Likewise\r\n const page = params.page ?? 0;\r\n const kindPrefix = kind.charAt(0); // f = full, h = hits, a = aggregations\r\n const currentTime = Date.now();\r\n\r\n return `R:${fullQueryHash}-S:${sessionId}-P:${page}-K:${kindPrefix}-T:${currentTime}`;\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n get pageSpecifierParams(): PageSpecifierParams | null {\r\n if (this.host.withinCollection) {\r\n return {\r\n pageType: 'collection_details',\r\n pageTarget: this.host.withinCollection,\r\n };\r\n }\r\n if (this.host.withinProfile) {\r\n return {\r\n pageType: 'account_details',\r\n pageTarget: this.host.withinProfile,\r\n pageElements: this.host.profileElement\r\n ? [this.host.profileElement]\r\n : [],\r\n };\r\n }\r\n return null;\r\n }\r\n\r\n /**\r\n * The full query, including year facets and date range clauses\r\n */\r\n private get fullQuery(): string | undefined {\r\n let fullQuery = this.host.baseQuery?.trim() ?? '';\r\n\r\n const { facetQuery, dateRangeQueryClause, sortFilterQueries } = this;\r\n\r\n if (facetQuery) {\r\n fullQuery += ` AND ${facetQuery}`;\r\n }\r\n if (dateRangeQueryClause) {\r\n fullQuery += ` AND ${dateRangeQueryClause}`;\r\n }\r\n if (sortFilterQueries) {\r\n fullQuery += ` AND ${sortFilterQueries}`;\r\n }\r\n return fullQuery.trim();\r\n }\r\n\r\n /**\r\n * Generates a query string representing the current set of applied facets\r\n *\r\n * Example: `mediatype:(\"collection\" OR \"audio\" OR -\"etree\") AND year:(\"2000\" OR \"2001\")`\r\n */\r\n private get facetQuery(): string | undefined {\r\n if (!this.host.selectedFacets) return undefined;\r\n const facetClauses = [];\r\n for (const [facetName, facetValues] of Object.entries(\r\n this.host.selectedFacets,\r\n )) {\r\n facetClauses.push(this.buildFacetClause(facetName, facetValues));\r\n }\r\n return this.joinFacetClauses(facetClauses)?.trim();\r\n }\r\n\r\n private get dateRangeQueryClause(): string | undefined {\r\n if (!this.host.minSelectedDate || !this.host.maxSelectedDate) {\r\n return undefined;\r\n }\r\n\r\n return `year:[${this.host.minSelectedDate} TO ${this.host.maxSelectedDate}]`;\r\n }\r\n\r\n private get sortFilterQueries(): string {\r\n const queries = [this.titleQuery, this.creatorQuery];\r\n return queries.filter(q => q).join(' AND ');\r\n }\r\n\r\n /**\r\n * Returns a query clause identifying the currently selected title filter,\r\n * e.g., `firstTitle:X`.\r\n */\r\n private get titleQuery(): string | undefined {\r\n return this.host.selectedTitleFilter\r\n ? `firstTitle:${this.host.selectedTitleFilter}`\r\n : undefined;\r\n }\r\n\r\n /**\r\n * Returns a query clause identifying the currently selected creator filter,\r\n * e.g., `firstCreator:X`.\r\n */\r\n private get creatorQuery(): string | undefined {\r\n return this.host.selectedCreatorFilter\r\n ? `firstCreator:${this.host.selectedCreatorFilter}`\r\n : undefined;\r\n }\r\n\r\n /**\r\n * Builds an OR-joined facet clause for the given facet name and values.\r\n *\r\n * E.g., for name `subject` and values\r\n * `{ foo: { state: 'selected' }, bar: { state: 'hidden' } }`\r\n * this will produce the clause\r\n * `subject:(\"foo\" OR -\"bar\")`.\r\n *\r\n * @param facetName The facet type (e.g., 'collection')\r\n * @param facetValues The facet buckets, mapped by their keys\r\n */\r\n private buildFacetClause(\r\n facetName: string,\r\n facetValues: Record<string, FacetBucket>,\r\n ): string {\r\n const { name: facetQueryName, values } = this.prepareFacetForFetch(\r\n facetName,\r\n facetValues,\r\n );\r\n const facetEntries = Object.entries(values);\r\n if (facetEntries.length === 0) return '';\r\n\r\n const facetValuesArray: string[] = [];\r\n for (const [key, facetData] of facetEntries) {\r\n const plusMinusPrefix = facetData.state === 'hidden' ? '-' : '';\r\n facetValuesArray.push(`${plusMinusPrefix}\"${key}\"`);\r\n }\r\n\r\n const valueQuery = facetValuesArray.join(` OR `);\r\n return `${facetQueryName}:(${valueQuery})`;\r\n }\r\n\r\n /**\r\n * Handles some special pre-request normalization steps for certain facet types\r\n * that require them.\r\n *\r\n * @param facetName The name of the facet type (e.g., 'language')\r\n * @param facetValues An array of values for that facet type\r\n */\r\n private prepareFacetForFetch(\r\n facetName: string,\r\n facetValues: Record<string, FacetBucket>,\r\n ): { name: string; values: Record<string, FacetBucket> } {\r\n // eslint-disable-next-line prefer-const\r\n let [normalizedName, normalizedValues] = [facetName, facetValues];\r\n\r\n // The full \"search engine\" name of the lending field is \"lending___status\"\r\n if (facetName === 'lending') {\r\n normalizedName = 'lending___status';\r\n }\r\n\r\n return {\r\n name: normalizedName,\r\n values: normalizedValues,\r\n };\r\n }\r\n\r\n /**\r\n * Takes an array of facet clauses, and combines them into a\r\n * full AND-joined facet query string. Empty clauses are ignored.\r\n */\r\n private joinFacetClauses(facetClauses: string[]): string | undefined {\r\n const nonEmptyFacetClauses = facetClauses.filter(\r\n clause => clause.length > 0,\r\n );\r\n return nonEmptyFacetClauses.length > 0\r\n ? `(${nonEmptyFacetClauses.join(' AND ')})`\r\n : undefined;\r\n }\r\n\r\n /**\r\n * Fires a backend request to fetch a set of aggregations (representing UI facets) for\r\n * the current search state.\r\n */\r\n private async fetchFacets(): Promise<void> {\r\n const trimmedQuery = this.host.baseQuery?.trim();\r\n if (!this.canPerformSearch) return;\r\n\r\n const { facetFetchQueryKey } = this;\r\n if (this.fetchesInProgress.has(facetFetchQueryKey)) return;\r\n this.fetchesInProgress.add(facetFetchQueryKey);\r\n\r\n this.setFacetsLoading(true);\r\n\r\n const sortParams = this.host.sortParam ? [this.host.sortParam] : [];\r\n const params: SearchParams = {\r\n ...this.pageSpecifierParams,\r\n query: trimmedQuery || '',\r\n rows: 0,\r\n filters: this.filterMap,\r\n // Fetch a few extra buckets beyond the 6 we show, in case some get suppressed\r\n aggregationsSize: 10,\r\n // Note: we don't need an aggregations param to fetch the default aggregations from the PPS.\r\n // The default aggregations for the search_results page type should be what we need here.\r\n };\r\n params.uid = await this.requestUID(\r\n { ...params, sort: sortParams },\r\n 'aggregations',\r\n );\r\n\r\n const searchResponse = await this.host.searchService?.search(\r\n params,\r\n this.host.searchType,\r\n );\r\n const success = searchResponse?.success;\r\n\r\n // This is checking to see if the query has changed since the data was fetched.\r\n // If so, we just want to discard this set of aggregations because they are\r\n // likely no longer valid for the newer query.\r\n const queryChangedSinceFetch =\r\n !this.fetchesInProgress.has(facetFetchQueryKey);\r\n this.fetchesInProgress.delete(facetFetchQueryKey);\r\n if (queryChangedSinceFetch) return;\r\n\r\n if (!success) {\r\n const errorMsg = searchResponse?.error?.message;\r\n const detailMsg = searchResponse?.error?.details?.message;\r\n\r\n if (!errorMsg && !detailMsg) {\r\n // @ts-expect-error: Property 'Sentry' does not exist on type 'Window & typeof globalThis'\r\n window?.Sentry?.captureMessage?.(\r\n 'Missing or malformed facet response from backend',\r\n 'error',\r\n );\r\n }\r\n\r\n this.setFacetsLoading(false);\r\n return;\r\n }\r\n\r\n const { aggregations, collectionTitles, tvChannelAliases } =\r\n success.response;\r\n this.aggregations = aggregations;\r\n\r\n this.histogramAggregation =\r\n this.host.searchType === SearchType.TV\r\n ? aggregations?.date_histogram\r\n : aggregations?.year_histogram;\r\n\r\n if (collectionTitles) {\r\n for (const [id, title] of Object.entries(collectionTitles)) {\r\n this.collectionTitles.set(id, title);\r\n }\r\n }\r\n if (tvChannelAliases) {\r\n for (const [channel, network] of Object.entries(tvChannelAliases)) {\r\n this.tvChannelAliases.set(channel, network);\r\n }\r\n }\r\n\r\n this.setFacetsLoading(false);\r\n this.requestHostUpdate();\r\n }\r\n\r\n /**\r\n * Performs the initial page fetch(es) for the current search state.\r\n */\r\n private async doInitialPageFetch(): Promise<void> {\r\n this.setSearchResultsLoading(true);\r\n // Try to batch 2 initial page requests when possible\r\n await this.fetchPage(this.host.initialPageNumber, this.numInitialPages);\r\n }\r\n\r\n /**\r\n * Fetches one or more pages of results and updates the data source.\r\n *\r\n * @param pageNumber The page number to fetch\r\n * @param numInitialPages If this is an initial page fetch (`pageNumber = 1`),\r\n * specifies how many pages to batch together in one request. Ignored\r\n * if `pageNumber != 1`, defaulting to a single page.\r\n */\r\n async fetchPage(pageNumber: number, numInitialPages = 1): Promise<void> {\r\n const trimmedQuery = this.host.baseQuery?.trim();\r\n // reset loading status\r\n if (!this.canPerformSearch) {\r\n this.setSearchResultsLoading(false);\r\n return;\r\n }\r\n\r\n // if we already have data, don't fetch again\r\n if (this.hasPage(pageNumber)) return;\r\n\r\n if (this.endOfDataReached) return;\r\n\r\n // Batch multiple initial page requests together if needed (e.g., can request\r\n // pages 1 and 2 together in a single request).\r\n let numPages = pageNumber === 1 ? numInitialPages : 1;\r\n const numRows = this.pageSize * numPages;\r\n\r\n // if a fetch is already in progress for this query and page, don't fetch again\r\n const { pageFetchQueryKey } = this;\r\n const currentPageKey = `${pageFetchQueryKey}-p:${pageNumber}`;\r\n if (this.fetchesInProgress.has(currentPageKey)) return;\r\n\r\n for (let i = 0; i < numPages; i += 1) {\r\n this.fetchesInProgress.add(`${pageFetchQueryKey}-p:${pageNumber + i}`);\r\n }\r\n this.previousQueryKey = pageFetchQueryKey;\r\n\r\n const { withinCollection, withinProfile } = this.host;\r\n\r\n let sortParams = this.host.sortParam ? [this.host.sortParam] : [];\r\n // TODO eventually the PPS should handle these defaults natively\r\n const isDefaultProfileSort =\r\n withinProfile && this.host.selectedSort === SortField.default;\r\n if (isDefaultProfileSort && this.host.defaultSortField) {\r\n const sortOption = SORT_OPTIONS[this.host.defaultSortField];\r\n if (sortOption.searchServiceKey) {\r\n sortParams = [\r\n {\r\n field: sortOption.searchServiceKey,\r\n direction: 'desc',\r\n },\r\n ];\r\n }\r\n }\r\n\r\n const params: SearchParams = {\r\n ...this.pageSpecifierParams,\r\n query: trimmedQuery || '',\r\n page: pageNumber,\r\n rows: numRows,\r\n sort: sortParams,\r\n filters: this.filterMap,\r\n aggregations: { omit: true },\r\n };\r\n params.uid = await this.requestUID(params, 'hits');\r\n\r\n // log('=== FIRING PAGE REQUEST ===', params);\r\n const searchResponse = await this.host.searchService?.search(\r\n params,\r\n this.host.searchType,\r\n );\r\n // log('=== RECEIVED PAGE RESPONSE IN CB ===', searchResponse);\r\n const success = searchResponse?.success;\r\n\r\n // This is checking to see if the fetch has been invalidated since it was fired off.\r\n // If so, we just want to discard the response since it is for an obsolete query state.\r\n if (!this.fetchesInProgress.has(currentPageKey)) return;\r\n for (let i = 0; i < numPages; i += 1) {\r\n this.fetchesInProgress.delete(`${pageFetchQueryKey}-p:${pageNumber + i}`);\r\n }\r\n\r\n if (!success) {\r\n const errorMsg = searchResponse?.error?.message;\r\n const detailMsg = searchResponse?.error?.details?.message;\r\n\r\n this.queryErrorMessage = `${errorMsg ?? ''}${\r\n detailMsg ? `; ${detailMsg}` : ''\r\n }`;\r\n\r\n if (!this.queryErrorMessage) {\r\n this.queryErrorMessage = 'Missing or malformed response from backend';\r\n // @ts-expect-error: Property 'Sentry' does not exist on type 'Window & typeof globalThis'\r\n window?.Sentry?.captureMessage?.(this.queryErrorMessage, 'error');\r\n }\r\n\r\n this.setSearchResultsLoading(false);\r\n this.requestHostUpdate();\r\n return;\r\n }\r\n\r\n this.setTotalResultCount(success.response.totalResults - this.offset);\r\n if (this.activeOnHost && this.totalResults === 0) {\r\n // display event to offshoot when result count is zero.\r\n this.host.emitEmptyResults();\r\n }\r\n\r\n this.sessionContext = success.sessionContext;\r\n if (withinCollection) {\r\n this.collectionExtraInfo = success.response.collectionExtraInfo;\r\n\r\n // For collections, we want the UI to respect the default sort option\r\n // which can be specified in metadata, or otherwise assumed to be week:desc\r\n if (this.activeOnHost) {\r\n this.host.applyDefaultCollectionSort(this.collectionExtraInfo);\r\n }\r\n\r\n if (this.collectionExtraInfo) {\r\n this.parentCollections = [].concat(\r\n this.collectionExtraInfo.public_metadata?.collection ?? [],\r\n );\r\n\r\n // Update the TV collection status now that we know the parent collections\r\n this.host.isTVCollection =\r\n this.host.withinCollection?.startsWith('TV-') ||\r\n this.host.withinCollection === 'tvnews' ||\r\n this.host.withinCollection === 'tvarchive' ||\r\n this.parentCollections.includes('tvnews') ||\r\n this.parentCollections.includes('tvarchive');\r\n }\r\n } else if (withinProfile) {\r\n this.accountExtraInfo = success.response.accountExtraInfo;\r\n this.pageElements = success.response.pageElements;\r\n }\r\n\r\n const { results, collectionTitles, tvChannelAliases } = success.response;\r\n if (results && results.length > 0) {\r\n // Load any collection titles present on the response into the cache,\r\n // or queue up preload fetches for them if none were present.\r\n if (collectionTitles) {\r\n for (const [id, title] of Object.entries(collectionTitles)) {\r\n this.collectionTitles.set(id, title);\r\n }\r\n\r\n // Also add the target collection's title if available\r\n const targetTitle = this.collectionExtraInfo?.public_metadata?.title;\r\n if (withinCollection && targetTitle) {\r\n this.collectionTitles.set(withinCollection, targetTitle);\r\n }\r\n }\r\n\r\n if (tvChannelAliases) {\r\n for (const [channel, network] of Object.entries(tvChannelAliases)) {\r\n this.tvChannelAliases.set(channel, network);\r\n }\r\n }\r\n\r\n // Update the data source for each returned page.\r\n // For loans and web archives, we must account for receiving more pages than we asked for.\r\n const isUnpagedElement = ['lending', 'web_archives'].includes(\r\n this.host.profileElement!,\r\n );\r\n if (isUnpagedElement) {\r\n numPages = Math.ceil(results.length / this.pageSize);\r\n this.endOfDataReached = true;\r\n if (this.activeOnHost) this.host.setTileCount(this.totalResults);\r\n }\r\n\r\n for (let i = 0; i < numPages; i += 1) {\r\n const pageStartIndex = this.pageSize * i;\r\n this.addFetchedResultsToDataSource(\r\n pageNumber + i,\r\n results.slice(pageStartIndex, pageStartIndex + this.pageSize),\r\n !isUnpagedElement || i === numPages - 1,\r\n );\r\n }\r\n }\r\n\r\n // When we reach the end of the data, we can set the infinite scroller's\r\n // item count to the real total number of results (rather than the\r\n // temporary estimates based on pages rendered so far).\r\n if (this.size >= this.totalResults || results.length === 0) {\r\n this.endOfDataReached = true;\r\n if (this.activeOnHost) this.host.setTileCount(this.size);\r\n }\r\n\r\n this.setSearchResultsLoading(false);\r\n this.requestHostUpdate();\r\n }\r\n\r\n /**\r\n * Returns the type of request that produced the current set of hits,\r\n * based on the presence of a search query or profile/collection target\r\n * on the host.\r\n */\r\n private get hitRequestSource(): HitRequestSource {\r\n const { host } = this;\r\n if (host.baseQuery) return 'search_query';\r\n if (host.withinProfile) return 'profile_tab';\r\n if (host.withinCollection) return 'collection_members';\r\n return 'unknown';\r\n }\r\n\r\n /**\r\n * Update the datasource from the fetch response\r\n *\r\n * @param pageNumber\r\n * @param results\r\n */\r\n private addFetchedResultsToDataSource(\r\n pageNumber: number,\r\n results: SearchResult[],\r\n needsReload = true,\r\n ): void {\r\n const tiles: TileModel[] = [];\r\n const requestSource = this.hitRequestSource;\r\n results?.forEach(result => {\r\n if (!result.identifier) return;\r\n tiles.push(new TileModel(result, requestSource));\r\n });\r\n\r\n this.addPage(pageNumber, tiles);\r\n\r\n if (needsReload) {\r\n this.refreshVisibleResults();\r\n }\r\n }\r\n\r\n /**\r\n * Fetches the aggregation buckets for the given prefix filter type.\r\n */\r\n private async fetchPrefixFilterBuckets(\r\n filterType: PrefixFilterType,\r\n ): Promise<Bucket[]> {\r\n const trimmedQuery = this.host.baseQuery?.trim();\r\n if (!this.canPerformSearch) return [];\r\n\r\n const filterAggregationKey = prefixFilterAggregationKeys[filterType];\r\n const sortParams = this.host.sortParam ? [this.host.sortParam] : [];\r\n\r\n const params: SearchParams = {\r\n ...this.pageSpecifierParams,\r\n query: trimmedQuery || '',\r\n rows: 0,\r\n filters: this.filterMap,\r\n // Only fetch the firstTitle or firstCreator aggregation\r\n aggregations: { simpleParams: [filterAggregationKey] },\r\n // Fetch all 26 letter buckets\r\n aggregationsSize: 26,\r\n };\r\n params.uid = await this.requestUID(\r\n { ...params, sort: sortParams },\r\n 'aggregations',\r\n );\r\n\r\n const searchResponse = await this.host.searchService?.search(\r\n params,\r\n this.host.searchType,\r\n );\r\n\r\n return (searchResponse?.success?.response?.aggregations?.[\r\n filterAggregationKey\r\n ]?.buckets ?? []) as Bucket[];\r\n }\r\n\r\n /**\r\n * Fetches and caches the prefix filter counts for the given filter type.\r\n */\r\n async updatePrefixFilterCounts(filterType: PrefixFilterType): Promise<void> {\r\n const { facetFetchQueryKey } = this;\r\n const buckets = await this.fetchPrefixFilterBuckets(filterType);\r\n\r\n // Don't update the filter counts for an outdated query (if it has been changed\r\n // since we sent the request)\r\n const queryChangedSinceFetch =\r\n facetFetchQueryKey !== this.facetFetchQueryKey;\r\n if (queryChangedSinceFetch) return;\r\n\r\n // Unpack the aggregation buckets into a simple map like { 'A': 50, 'B': 25, ... }\r\n this.prefixFilterCountMap = { ...this.prefixFilterCountMap }; // Clone the object to trigger an update\r\n this.prefixFilterCountMap[filterType] = buckets.reduce(\r\n (acc: Record<string, number>, bucket: Bucket) => {\r\n acc[(bucket.key as string).toUpperCase()] = bucket.doc_count;\r\n return acc;\r\n },\r\n {},\r\n );\r\n\r\n this.requestHostUpdate();\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n async updatePrefixFiltersForCurrentSort(): Promise<void> {\r\n if (['title', 'creator'].includes(this.host.selectedSort as SortField)) {\r\n const filterType = this.host.selectedSort as PrefixFilterType;\r\n if (!this.prefixFilterCountMap[filterType]) {\r\n this.updatePrefixFilterCounts(filterType);\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * @inheritdoc\r\n */\r\n refreshLetterCounts(): void {\r\n if (Object.keys(this.prefixFilterCountMap).length > 0) {\r\n this.prefixFilterCountMap = {};\r\n }\r\n this.updatePrefixFiltersForCurrentSort();\r\n this.requestHostUpdate();\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"collection-browser-data-source.js","sourceRoot":"","sources":["../../../src/data-source/collection-browser-data-source.ts"],"names":[],"mappings":"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","sourcesContent":["import type { ReactiveControllerHost } from 'lit';\nimport {\n AccountExtraInfo,\n Aggregation,\n Bucket,\n CollectionExtraInfo,\n FilterConstraint,\n FilterMap,\n FilterMapBuilder,\n PageElementMap,\n SearchParams,\n SearchResponseSessionContext,\n SearchResult,\n SearchType,\n} from '@internetarchive/search-service';\nimport {\n prefixFilterAggregationKeys,\n type FacetBucket,\n type PrefixFilterType,\n TileModel,\n PrefixFilterCounts,\n RequestKind,\n SortField,\n SORT_OPTIONS,\n HitRequestSource,\n} from '../models';\nimport { FACETLESS_PAGE_ELEMENTS, type PageSpecifierParams } from './models';\nimport type { CollectionBrowserDataSourceInterface } from './collection-browser-data-source-interface';\nimport type { CollectionBrowserSearchInterface } from './collection-browser-query-state';\nimport { sha1 } from '../utils/sha1';\nimport { log } from '../utils/log';\nimport { mergeSelectedFacets } from '../utils/facet-utils';\n\nexport class CollectionBrowserDataSource\n implements CollectionBrowserDataSourceInterface\n{\n /**\n * All pages of tile models that have been fetched so far, indexed by their page\n * number (with the first being page 1).\n */\n private pages: Record<string, TileModel[]> = {};\n\n /**\n * Tile offset to apply when looking up tiles in the pages, in order to maintain\n * page alignment after tiles are removed.\n */\n private offset = 0;\n\n /**\n * Total number of tile models stored in this data source's pages\n */\n private numTileModels = 0;\n\n /**\n * How many consecutive pages should be batched together on the initial page fetch.\n * Defaults to 2 pages.\n */\n private numInitialPages = 2;\n\n /**\n * A set of fetch IDs that are valid for the current query state\n */\n private fetchesInProgress = new Set<string>();\n\n /**\n * A record of the query key used for the last search.\n * If this changes, we need to load new results.\n */\n private previousQueryKey: string = '';\n\n /**\n * Whether the initial page of search results for the current query state\n * is presently being fetched.\n */\n private searchResultsLoading = false;\n\n /**\n * Whether the facets (aggregations) for the current query state are\n * presently being fetched.\n */\n private facetsLoading = false;\n\n /**\n * Whether the facets are actually visible -- if not, then we can delay any facet\n * fetches until they become visible.\n */\n private facetsReadyToLoad = false;\n\n /**\n * Whether further query changes should be ignored and not trigger fetches\n */\n private suppressFetches = false;\n\n /**\n * @inheritdoc\n */\n totalResults = 0;\n\n /**\n * @inheritdoc\n */\n endOfDataReached = false;\n\n /**\n * @inheritdoc\n */\n queryInitialized = false;\n\n /**\n * @inheritdoc\n */\n aggregations?: Record<string, Aggregation>;\n\n /**\n * @inheritdoc\n */\n histogramAggregation?: Aggregation;\n\n /**\n * @inheritdoc\n */\n collectionTitles = new Map<string, string>();\n\n /**\n * @inheritdoc\n */\n tvChannelAliases = new Map<string, string>();\n\n /**\n * @inheritdoc\n */\n collectionExtraInfo?: CollectionExtraInfo;\n\n /**\n * @inheritdoc\n */\n accountExtraInfo?: AccountExtraInfo;\n\n /**\n * @inheritdoc\n */\n sessionContext?: SearchResponseSessionContext;\n\n /**\n * @inheritdoc\n */\n pageElements?: PageElementMap;\n\n /**\n * @inheritdoc\n */\n parentCollections?: string[] = [];\n\n /**\n * @inheritdoc\n */\n prefixFilterCountMap: Partial<Record<PrefixFilterType, PrefixFilterCounts>> =\n {};\n\n /**\n * @inheritdoc\n */\n queryErrorMessage?: string;\n\n /**\n * Internal property to store the private value backing the `initialSearchComplete` getter.\n */\n private _initialSearchCompletePromise: Promise<boolean> =\n Promise.resolve(true);\n\n /**\n * @inheritdoc\n */\n get initialSearchComplete(): Promise<boolean> {\n return this._initialSearchCompletePromise;\n }\n\n constructor(\n /** The host element to which this controller should attach listeners */\n private readonly host: ReactiveControllerHost &\n CollectionBrowserSearchInterface,\n /** Default size of result pages */\n private pageSize: number = 50,\n ) {\n // Just setting some property values\n }\n\n hostConnected(): void {\n this.setSearchResultsLoading(this.searchResultsLoading);\n this.setFacetsLoading(this.facetsLoading);\n }\n\n hostUpdate(): void {\n // This reactive controller hook is run whenever the host component (collection-browser) performs an update.\n // We check whether the host's state has changed in a way which should trigger a reset & new results fetch.\n\n // Only the currently-installed data source should react to the update\n if (!this.activeOnHost) return;\n\n // Copy loading states onto the host\n this.setSearchResultsLoading(this.searchResultsLoading);\n this.setFacetsLoading(this.facetsLoading);\n\n // Can't perform searches without a search service\n if (!this.host.searchService) return;\n\n // We should only reset if part of the full query state has changed\n const queryKeyChanged = this.pageFetchQueryKey !== this.previousQueryKey;\n if (!queryKeyChanged) return;\n\n // We should only reset if either:\n // (a) our state permits a valid search, or\n // (b) we have a blank query that we're showing a placeholder/message for\n const queryIsEmpty = !this.host.baseQuery;\n if (!(this.canPerformSearch || queryIsEmpty)) return;\n\n if (this.activeOnHost) this.host.emitQueryStateChanged();\n this.handleQueryChange();\n }\n\n /**\n * Returns whether this data source is the one currently installed on the host component.\n */\n private get activeOnHost(): boolean {\n return this.host.dataSource === this;\n }\n\n /**\n * @inheritdoc\n */\n get size(): number {\n return this.numTileModels;\n }\n\n /**\n * @inheritdoc\n */\n reset(): void {\n log('Resetting CB data source');\n this.pages = {};\n this.aggregations = {};\n this.histogramAggregation = undefined;\n this.pageElements = undefined;\n this.parentCollections = [];\n this.previousQueryKey = '';\n this.queryErrorMessage = undefined;\n\n this.offset = 0;\n this.numTileModels = 0;\n this.endOfDataReached = false;\n this.queryInitialized = false;\n this.facetsLoading = false;\n\n // Invalidate any fetches in progress\n this.fetchesInProgress.clear();\n\n this.setTotalResultCount(0);\n this.requestHostUpdate();\n }\n\n /**\n * @inheritdoc\n */\n resetPages(): void {\n if (Object.keys(this.pages).length < this.host.maxPagesToManage) {\n this.pages = {};\n\n // Invalidate any page fetches in progress (keep facet fetches)\n this.fetchesInProgress.forEach(key => {\n if (!key.startsWith('facets-')) this.fetchesInProgress.delete(key);\n });\n this.requestHostUpdate();\n }\n }\n\n /**\n * @inheritdoc\n */\n addPage(pageNum: number, pageTiles: TileModel[]): void {\n this.pages[pageNum] = pageTiles;\n this.numTileModels += pageTiles.length;\n this.requestHostUpdate();\n }\n\n /**\n * @inheritdoc\n */\n addMultiplePages(firstPageNum: number, tiles: TileModel[]): void {\n const numPages = Math.ceil(tiles.length / this.pageSize);\n for (let i = 0; i < numPages; i += 1) {\n const pageStartIndex = this.pageSize * i;\n this.addPage(\n firstPageNum + i,\n tiles.slice(pageStartIndex, pageStartIndex + this.pageSize),\n );\n }\n\n const visiblePages = this.host.currentVisiblePageNumbers;\n const needsReload = visiblePages.some(\n page => page >= firstPageNum && page <= firstPageNum + numPages,\n );\n if (needsReload) {\n this.refreshVisibleResults();\n }\n }\n\n /**\n * @inheritdoc\n */\n getPage(pageNum: number): TileModel[] {\n return this.pages[pageNum];\n }\n\n /**\n * @inheritdoc\n */\n getAllPages(): Record<string, TileModel[]> {\n return this.pages;\n }\n\n /**\n * @inheritdoc\n */\n hasPage(pageNum: number): boolean {\n return !!this.pages[pageNum];\n }\n\n /**\n * @inheritdoc\n */\n getTileModelAt(index: number): TileModel | undefined {\n const offsetIndex = index + this.offset;\n const expectedPageNum = Math.floor(offsetIndex / this.pageSize) + 1;\n const expectedIndexOnPage = offsetIndex % this.pageSize;\n\n let page = 1;\n let tilesSeen = 0;\n while (tilesSeen <= offsetIndex) {\n if (!this.pages[page]) {\n // If we encounter a missing page, either we're past all the results or the page data is sparse.\n // So just return the tile at the expected position if it exists.\n return this.pages[expectedPageNum]?.[expectedIndexOnPage];\n }\n\n if (tilesSeen + this.pages[page].length > offsetIndex) {\n return this.pages[page][offsetIndex - tilesSeen];\n }\n\n tilesSeen += this.pages[page].length;\n page += 1;\n }\n\n return this.pages[expectedPageNum]?.[expectedIndexOnPage];\n }\n\n /**\n * @inheritdoc\n */\n indexOf(tile: TileModel): number {\n return Object.values(this.pages).flat().indexOf(tile) - this.offset;\n }\n\n /**\n * @inheritdoc\n */\n getPageSize(): number {\n return this.pageSize;\n }\n\n /**\n * @inheritdoc\n */\n setPageSize(pageSize: number): void {\n this.reset();\n this.pageSize = pageSize;\n }\n\n /**\n * @inheritdoc\n */\n setNumInitialPages(numPages: number): void {\n this.numInitialPages = numPages;\n }\n\n /**\n * @inheritdoc\n */\n setTotalResultCount(count: number): void {\n this.totalResults = count;\n if (this.activeOnHost) {\n this.host.setTotalResultCount(count);\n }\n }\n\n /**\n * @inheritdoc\n */\n setFetchesSuppressed(suppressed: boolean): void {\n this.suppressFetches = suppressed;\n }\n\n /**\n * @inheritdoc\n */\n setEndOfDataReached(reached: boolean): void {\n this.endOfDataReached = reached;\n }\n\n /**\n * @inheritdoc\n */\n async handleQueryChange(): Promise<void> {\n // Don't react to the change if fetches are suppressed for this data source\n if (this.suppressFetches) return;\n\n this.reset();\n\n // Reset the `initialSearchComplete` promise with a new value for the imminent search\n let initialSearchCompleteResolver: (value: boolean) => void;\n this._initialSearchCompletePromise = new Promise(res => {\n initialSearchCompleteResolver = res;\n });\n\n // Fire the initial page & facet requests\n this.queryInitialized = true;\n await Promise.all([\n this.doInitialPageFetch(),\n this.canFetchFacets ? this.fetchFacets() : null,\n ]);\n\n // Resolve the `initialSearchComplete` promise for this search\n initialSearchCompleteResolver!(true);\n }\n\n /**\n * @inheritdoc\n */\n async handleFacetReadinessChange(ready: boolean): Promise<void> {\n const facetsBecameReady = !this.facetsReadyToLoad && ready;\n this.facetsReadyToLoad = ready;\n\n const needsFetch = facetsBecameReady && this.canFetchFacets;\n if (needsFetch) {\n this.fetchFacets();\n }\n }\n\n /**\n * Whether the data source & its host are in a state where a facet request should be fired.\n * (i.e., they aren't suppressed or already loading, etc.)\n */\n private get canFetchFacets(): boolean {\n // Don't fetch facets if they are suppressed entirely or not required for the current profile page element\n if (this.host.facetLoadStrategy === 'off') return false;\n if (FACETLESS_PAGE_ELEMENTS.includes(this.host.profileElement!))\n return false;\n\n // If facets are to be lazy-loaded, don't fetch them if they are not going to be visible anyway\n // (wait until they become visible instead)\n if (this.host.facetLoadStrategy !== 'eager' && !this.facetsReadyToLoad)\n return false;\n\n // Don't fetch facets again if they are already fetched or pending\n const facetsAlreadyFetched =\n Object.keys(this.aggregations ?? {}).length > 0;\n if (this.facetsLoading || facetsAlreadyFetched) return false;\n\n return true;\n }\n\n /**\n * @inheritdoc\n */\n map(\n callback: (\n model: TileModel,\n index: number,\n array: TileModel[],\n ) => TileModel,\n ): void {\n if (!Object.keys(this.pages).length) return;\n this.pages = Object.fromEntries(\n Object.entries(this.pages).map(([page, tileModels]) => [\n page,\n tileModels.map((model, index, array) =>\n model ? callback(model, index, array) : model,\n ),\n ]),\n );\n this.requestHostUpdate();\n this.refreshVisibleResults();\n }\n\n /**\n * @inheritdoc\n */\n checkAllTiles = (): void => {\n this.map(model => {\n const cloned = model.clone();\n cloned.checked = true;\n return cloned;\n });\n };\n\n /**\n * @inheritdoc\n */\n uncheckAllTiles = (): void => {\n this.map(model => {\n const cloned = model.clone();\n cloned.checked = false;\n return cloned;\n });\n };\n\n /**\n * @inheritdoc\n */\n removeCheckedTiles = (): void => {\n // To make sure our data source remains page-aligned, we will offset our data source by\n // the number of removed tiles, so that we can just add the offset when the infinite\n // scroller queries for cell contents.\n // This only matters while we're still viewing the same set of results. If the user changes\n // their query/filters/sort, then the data source is overwritten and the offset cleared.\n const { checkedTileModels, uncheckedTileModels } = this;\n const numChecked = checkedTileModels.length;\n if (numChecked === 0) return;\n this.offset += numChecked;\n const newPages: typeof this.pages = {};\n\n // Which page the remaining tile models start on, post-offset\n let offsetPageNumber = Math.floor(this.offset / this.pageSize) + 1;\n let indexOnPage = this.offset % this.pageSize;\n\n // Fill the pages up to that point with empty models\n for (let page = 1; page <= offsetPageNumber; page += 1) {\n const remainingHidden = this.offset - this.pageSize * (page - 1);\n const offsetCellsOnPage = Math.min(this.pageSize, remainingHidden);\n newPages[page] = Array(offsetCellsOnPage).fill(undefined);\n }\n\n // Shift all the remaining tiles into their new positions in the data source\n for (const model of uncheckedTileModels) {\n if (!newPages[offsetPageNumber]) newPages[offsetPageNumber] = [];\n newPages[offsetPageNumber].push(model);\n indexOnPage += 1;\n if (indexOnPage >= this.pageSize) {\n offsetPageNumber += 1;\n indexOnPage = 0;\n }\n }\n\n // Swap in the new pages\n this.pages = newPages;\n this.numTileModels -= numChecked;\n this.totalResults -= numChecked;\n this.host.setTileCount(this.size);\n this.host.setTotalResultCount(this.totalResults);\n this.requestHostUpdate();\n this.refreshVisibleResults();\n };\n\n /**\n * @inheritdoc\n */\n get checkedTileModels(): TileModel[] {\n return this.getFilteredTileModels(model => model.checked);\n }\n\n /**\n * @inheritdoc\n */\n get uncheckedTileModels(): TileModel[] {\n return this.getFilteredTileModels(model => !model.checked);\n }\n\n /**\n * Returns a flattened, filtered array of all the tile models in the data source\n * for which the given predicate returns a truthy value.\n *\n * @param predicate A callback function to apply on each tile model, as with Array.filter\n * @returns A filtered array of tile models satisfying the predicate\n */\n private getFilteredTileModels(\n predicate: (model: TileModel, index: number, array: TileModel[]) => unknown,\n ): TileModel[] {\n return Object.values(this.pages)\n .flat()\n .filter((model, index, array) =>\n model ? predicate(model, index, array) : false,\n );\n }\n\n /**\n * @inheritdoc\n */\n get canPerformSearch(): boolean {\n if (!this.host.searchService) return false;\n\n const trimmedQuery = this.host.baseQuery?.trim();\n const hasNonEmptyQuery = !!trimmedQuery;\n const isCollectionSearch = !!this.host.withinCollection;\n const isProfileSearch = !!this.host.withinProfile;\n const hasProfileElement = !!this.host.profileElement;\n const isDefaultedSearch = this.host.searchType === SearchType.DEFAULT;\n const isMetadataSearch = this.host.searchType === SearchType.METADATA;\n const isTvSearch = this.host.searchType === SearchType.TV;\n\n // Metadata/tv searches within a collection are allowed to have no query.\n const isValidForCollectionSearch =\n isDefaultedSearch || isMetadataSearch || isTvSearch;\n\n // Searches within a profile page may also be performed without a query, provided the profile element is set.\n const isValidForProfileSearch =\n hasProfileElement && (isDefaultedSearch || isMetadataSearch);\n\n // Otherwise, a non-empty query must be set.\n return (\n hasNonEmptyQuery ||\n (isCollectionSearch && isValidForCollectionSearch) ||\n (isProfileSearch && isValidForProfileSearch)\n );\n }\n\n /**\n * Sets the state for whether the initial set of search results for the\n * current query is loading\n */\n private setSearchResultsLoading(loading: boolean): void {\n this.searchResultsLoading = loading;\n if (this.activeOnHost) {\n this.host.setSearchResultsLoading(loading);\n }\n }\n\n /**\n * Sets the state for whether the facets for a query is loading\n */\n private setFacetsLoading(loading: boolean): void {\n this.facetsLoading = loading;\n if (this.activeOnHost) {\n this.host.setFacetsLoading(loading);\n }\n }\n\n /**\n * Requests that the host perform an update, provided this data\n * source is actively installed on it.\n */\n private requestHostUpdate(): void {\n if (this.activeOnHost) {\n this.host.requestUpdate();\n }\n }\n\n /**\n * Requests that the host refresh its visible tiles, provided this\n * data source is actively installed on it.\n */\n private refreshVisibleResults(): void {\n if (this.activeOnHost) {\n this.host.refreshVisibleResults();\n }\n }\n\n /**\n * The query key is a string that uniquely identifies the current search.\n * It consists of:\n * - The current base query\n * - The current collection/profile target & page element\n * - The current search type\n * - Any currently-applied facets\n * - Any currently-applied date range\n * - Any currently-applied prefix filters\n * - The current sort options\n *\n * This lets us internally keep track of queries so we don't persist data that's\n * no longer relevant. Not meant to be human-readable.\n */\n get pageFetchQueryKey(): string {\n const profileKey = `pf;${this.host.withinProfile}--pe;${this.host.profileElement}`;\n const pageTarget = this.host.withinCollection ?? profileKey;\n const sortField = this.host.selectedSort ?? 'none';\n const sortDirection = this.host.sortDirection ?? 'none';\n return `fq:${this.fullQuery}-pt:${pageTarget}-st:${this.host.searchType}-sf:${sortField}-sd:${sortDirection}`;\n }\n\n /**\n * Similar to `pageFetchQueryKey` above, but excludes sort fields since they\n * are not relevant in determining aggregation queries.\n */\n get facetFetchQueryKey(): string {\n const profileKey = `pf;${this.host.withinProfile}--pe;${this.host.profileElement}`;\n const pageTarget = this.host.withinCollection ?? profileKey;\n return `facets-fq:${this.fullQuery}-pt:${pageTarget}-st:${this.host.searchType}`;\n }\n\n /**\n * Constructs a search service FilterMap object from the combination of\n * all the currently-applied filters. This includes any facets, letter\n * filters, and date range.\n */\n get filterMap(): FilterMap {\n const builder = new FilterMapBuilder();\n\n const {\n minSelectedDate,\n maxSelectedDate,\n selectedFacets,\n internalFilters,\n selectedTitleFilter,\n selectedCreatorFilter,\n } = this.host;\n\n const dateField = this.host.searchType === SearchType.TV ? 'date' : 'year';\n\n if (minSelectedDate) {\n builder.addFilter(\n dateField,\n minSelectedDate,\n FilterConstraint.GREATER_OR_EQUAL,\n );\n }\n if (maxSelectedDate) {\n builder.addFilter(\n dateField,\n maxSelectedDate,\n FilterConstraint.LESS_OR_EQUAL,\n );\n }\n\n // Add any selected facets and internal filters\n const combinedFilters = mergeSelectedFacets(\n internalFilters,\n selectedFacets,\n );\n if (combinedFilters) {\n for (const [facetName, facetValues] of Object.entries(combinedFilters)) {\n const { name, values } = this.prepareFacetForFetch(\n facetName,\n facetValues,\n );\n for (const [value, bucket] of Object.entries(values)) {\n let constraint;\n if (bucket.state === 'selected') {\n constraint = FilterConstraint.INCLUDE;\n } else if (bucket.state === 'hidden') {\n constraint = FilterConstraint.EXCLUDE;\n }\n\n if (constraint) {\n builder.addFilter(name, value, constraint);\n }\n }\n }\n }\n\n // Add any letter filters\n if (selectedTitleFilter) {\n builder.addFilter(\n 'firstTitle',\n selectedTitleFilter,\n FilterConstraint.INCLUDE,\n );\n }\n if (selectedCreatorFilter) {\n builder.addFilter(\n 'firstCreator',\n selectedCreatorFilter,\n FilterConstraint.INCLUDE,\n );\n }\n\n // Add any TV clip type filter, if applicable\n if (this.host.searchType === SearchType.TV) {\n switch (this.host.tvClipFilter) {\n case 'commercials':\n builder.addFilter('ad_id', '*', FilterConstraint.INCLUDE);\n break;\n case 'factchecks':\n builder.addFilter('factcheck', '*', FilterConstraint.INCLUDE);\n break;\n case 'quotes':\n builder.addFilter('clip', '1', FilterConstraint.INCLUDE);\n break;\n case 'all':\n default:\n break;\n }\n }\n\n const filterMap = builder.build();\n return filterMap;\n }\n\n /**\n * Produces a compact unique ID for a search request that can help with debugging\n * on the backend by making related requests easier to trace through different services.\n * (e.g., tying the hits/aggregations requests for the same page back to a single hash).\n *\n * @param params The search service parameters for the request\n * @param kind The kind of request (hits-only, aggregations-only, or both)\n * @returns A Promise resolving to the uid to apply to the request\n */\n async requestUID(params: SearchParams, kind: RequestKind): Promise<string> {\n const paramsToHash = JSON.stringify({\n pageType: params.pageType,\n pageTarget: params.pageTarget,\n query: params.query,\n fields: params.fields,\n filters: params.filters,\n sort: params.sort,\n searchType: this.host.searchType,\n });\n\n const fullQueryHash = (await sha1(paramsToHash)).slice(0, 20); // First 80 bits of SHA-1 are plenty for this\n const sessionId = (await this.host.getSessionId()).slice(0, 20); // Likewise\n const page = params.page ?? 0;\n const kindPrefix = kind.charAt(0); // f = full, h = hits, a = aggregations\n const currentTime = Date.now();\n\n return `R:${fullQueryHash}-S:${sessionId}-P:${page}-K:${kindPrefix}-T:${currentTime}`;\n }\n\n /**\n * @inheritdoc\n */\n get pageSpecifierParams(): PageSpecifierParams | null {\n if (this.host.withinCollection) {\n return {\n pageType: 'collection_details',\n pageTarget: this.host.withinCollection,\n };\n }\n if (this.host.withinProfile) {\n return {\n pageType: 'account_details',\n pageTarget: this.host.withinProfile,\n pageElements: this.host.profileElement\n ? [this.host.profileElement]\n : [],\n };\n }\n return null;\n }\n\n /**\n * The full query, including year facets and date range clauses\n */\n private get fullQuery(): string | undefined {\n let fullQuery = this.host.baseQuery?.trim() ?? '';\n\n const { facetQuery, dateRangeQueryClause, sortFilterQueries } = this;\n\n if (facetQuery) {\n fullQuery += ` AND ${facetQuery}`;\n }\n if (dateRangeQueryClause) {\n fullQuery += ` AND ${dateRangeQueryClause}`;\n }\n if (sortFilterQueries) {\n fullQuery += ` AND ${sortFilterQueries}`;\n }\n return fullQuery.trim();\n }\n\n /**\n * Generates a query string representing the current set of applied facets\n *\n * Example: `mediatype:(\"collection\" OR \"audio\" OR -\"etree\") AND year:(\"2000\" OR \"2001\")`\n */\n private get facetQuery(): string | undefined {\n if (!this.host.selectedFacets) return undefined;\n const facetClauses = [];\n for (const [facetName, facetValues] of Object.entries(\n this.host.selectedFacets,\n )) {\n facetClauses.push(this.buildFacetClause(facetName, facetValues));\n }\n return this.joinFacetClauses(facetClauses)?.trim();\n }\n\n private get dateRangeQueryClause(): string | undefined {\n if (!this.host.minSelectedDate || !this.host.maxSelectedDate) {\n return undefined;\n }\n\n return `year:[${this.host.minSelectedDate} TO ${this.host.maxSelectedDate}]`;\n }\n\n private get sortFilterQueries(): string {\n const queries = [this.titleQuery, this.creatorQuery];\n return queries.filter(q => q).join(' AND ');\n }\n\n /**\n * Returns a query clause identifying the currently selected title filter,\n * e.g., `firstTitle:X`.\n */\n private get titleQuery(): string | undefined {\n return this.host.selectedTitleFilter\n ? `firstTitle:${this.host.selectedTitleFilter}`\n : undefined;\n }\n\n /**\n * Returns a query clause identifying the currently selected creator filter,\n * e.g., `firstCreator:X`.\n */\n private get creatorQuery(): string | undefined {\n return this.host.selectedCreatorFilter\n ? `firstCreator:${this.host.selectedCreatorFilter}`\n : undefined;\n }\n\n /**\n * Builds an OR-joined facet clause for the given facet name and values.\n *\n * E.g., for name `subject` and values\n * `{ foo: { state: 'selected' }, bar: { state: 'hidden' } }`\n * this will produce the clause\n * `subject:(\"foo\" OR -\"bar\")`.\n *\n * @param facetName The facet type (e.g., 'collection')\n * @param facetValues The facet buckets, mapped by their keys\n */\n private buildFacetClause(\n facetName: string,\n facetValues: Record<string, FacetBucket>,\n ): string {\n const { name: facetQueryName, values } = this.prepareFacetForFetch(\n facetName,\n facetValues,\n );\n const facetEntries = Object.entries(values);\n if (facetEntries.length === 0) return '';\n\n const facetValuesArray: string[] = [];\n for (const [key, facetData] of facetEntries) {\n const plusMinusPrefix = facetData.state === 'hidden' ? '-' : '';\n facetValuesArray.push(`${plusMinusPrefix}\"${key}\"`);\n }\n\n const valueQuery = facetValuesArray.join(` OR `);\n return `${facetQueryName}:(${valueQuery})`;\n }\n\n /**\n * Handles some special pre-request normalization steps for certain facet types\n * that require them.\n *\n * @param facetName The name of the facet type (e.g., 'language')\n * @param facetValues An array of values for that facet type\n */\n private prepareFacetForFetch(\n facetName: string,\n facetValues: Record<string, FacetBucket>,\n ): { name: string; values: Record<string, FacetBucket> } {\n // eslint-disable-next-line prefer-const\n let [normalizedName, normalizedValues] = [facetName, facetValues];\n\n // The full \"search engine\" name of the lending field is \"lending___status\"\n if (facetName === 'lending') {\n normalizedName = 'lending___status';\n }\n\n return {\n name: normalizedName,\n values: normalizedValues,\n };\n }\n\n /**\n * Takes an array of facet clauses, and combines them into a\n * full AND-joined facet query string. Empty clauses are ignored.\n */\n private joinFacetClauses(facetClauses: string[]): string | undefined {\n const nonEmptyFacetClauses = facetClauses.filter(\n clause => clause.length > 0,\n );\n return nonEmptyFacetClauses.length > 0\n ? `(${nonEmptyFacetClauses.join(' AND ')})`\n : undefined;\n }\n\n /**\n * Fires a backend request to fetch a set of aggregations (representing UI facets) for\n * the current search state.\n */\n private async fetchFacets(): Promise<void> {\n const trimmedQuery = this.host.baseQuery?.trim();\n if (!this.canPerformSearch) return;\n\n const { facetFetchQueryKey } = this;\n if (this.fetchesInProgress.has(facetFetchQueryKey)) return;\n this.fetchesInProgress.add(facetFetchQueryKey);\n\n this.setFacetsLoading(true);\n\n const sortParams = this.host.sortParam ? [this.host.sortParam] : [];\n const params: SearchParams = {\n ...this.pageSpecifierParams,\n query: trimmedQuery || '',\n rows: 0,\n filters: this.filterMap,\n // Fetch a few extra buckets beyond the 6 we show, in case some get suppressed\n aggregationsSize: 10,\n // Note: we don't need an aggregations param to fetch the default aggregations from the PPS.\n // The default aggregations for the search_results page type should be what we need here.\n };\n params.uid = await this.requestUID(\n { ...params, sort: sortParams },\n 'aggregations',\n );\n\n const searchResponse = await this.host.searchService?.search(\n params,\n this.host.searchType,\n );\n const success = searchResponse?.success;\n\n // This is checking to see if the query has changed since the data was fetched.\n // If so, we just want to discard this set of aggregations because they are\n // likely no longer valid for the newer query.\n const queryChangedSinceFetch =\n !this.fetchesInProgress.has(facetFetchQueryKey);\n this.fetchesInProgress.delete(facetFetchQueryKey);\n if (queryChangedSinceFetch) return;\n\n if (!success) {\n const errorMsg = searchResponse?.error?.message;\n const detailMsg = searchResponse?.error?.details?.message;\n\n if (!errorMsg && !detailMsg) {\n // @ts-expect-error: Property 'Sentry' does not exist on type 'Window & typeof globalThis'\n window?.Sentry?.captureMessage?.(\n 'Missing or malformed facet response from backend',\n 'error',\n );\n }\n\n this.setFacetsLoading(false);\n return;\n }\n\n const { aggregations, collectionTitles, tvChannelAliases } =\n success.response;\n this.aggregations = aggregations;\n\n this.histogramAggregation =\n this.host.searchType === SearchType.TV\n ? aggregations?.date_histogram\n : aggregations?.year_histogram;\n\n if (collectionTitles) {\n for (const [id, title] of Object.entries(collectionTitles)) {\n this.collectionTitles.set(id, title);\n }\n }\n if (tvChannelAliases) {\n for (const [channel, network] of Object.entries(tvChannelAliases)) {\n this.tvChannelAliases.set(channel, network);\n }\n }\n\n this.setFacetsLoading(false);\n this.requestHostUpdate();\n }\n\n /**\n * Performs the initial page fetch(es) for the current search state.\n */\n private async doInitialPageFetch(): Promise<void> {\n this.setSearchResultsLoading(true);\n // Try to batch 2 initial page requests when possible\n await this.fetchPage(this.host.initialPageNumber, this.numInitialPages);\n }\n\n /**\n * Fetches one or more pages of results and updates the data source.\n *\n * @param pageNumber The page number to fetch\n * @param numInitialPages If this is an initial page fetch (`pageNumber = 1`),\n * specifies how many pages to batch together in one request. Ignored\n * if `pageNumber != 1`, defaulting to a single page.\n */\n async fetchPage(pageNumber: number, numInitialPages = 1): Promise<void> {\n const trimmedQuery = this.host.baseQuery?.trim();\n // reset loading status\n if (!this.canPerformSearch) {\n this.setSearchResultsLoading(false);\n return;\n }\n\n // if we already have data, don't fetch again\n if (this.hasPage(pageNumber)) return;\n\n if (this.endOfDataReached) return;\n\n // Batch multiple initial page requests together if needed (e.g., can request\n // pages 1 and 2 together in a single request).\n let numPages = pageNumber === 1 ? numInitialPages : 1;\n const numRows = this.pageSize * numPages;\n\n // if a fetch is already in progress for this query and page, don't fetch again\n const { pageFetchQueryKey } = this;\n const currentPageKey = `${pageFetchQueryKey}-p:${pageNumber}`;\n if (this.fetchesInProgress.has(currentPageKey)) return;\n\n for (let i = 0; i < numPages; i += 1) {\n this.fetchesInProgress.add(`${pageFetchQueryKey}-p:${pageNumber + i}`);\n }\n this.previousQueryKey = pageFetchQueryKey;\n\n const { withinCollection, withinProfile } = this.host;\n\n let sortParams = this.host.sortParam ? [this.host.sortParam] : [];\n // TODO eventually the PPS should handle these defaults natively\n const isDefaultProfileSort =\n withinProfile && this.host.selectedSort === SortField.default;\n if (isDefaultProfileSort && this.host.defaultSortField) {\n const sortOption = SORT_OPTIONS[this.host.defaultSortField];\n if (sortOption.searchServiceKey) {\n sortParams = [\n {\n field: sortOption.searchServiceKey,\n direction: 'desc',\n },\n ];\n }\n }\n\n const params: SearchParams = {\n ...this.pageSpecifierParams,\n query: trimmedQuery || '',\n page: pageNumber,\n rows: numRows,\n sort: sortParams,\n filters: this.filterMap,\n aggregations: { omit: true },\n };\n params.uid = await this.requestUID(params, 'hits');\n\n // log('=== FIRING PAGE REQUEST ===', params);\n const searchResponse = await this.host.searchService?.search(\n params,\n this.host.searchType,\n );\n // log('=== RECEIVED PAGE RESPONSE IN CB ===', searchResponse);\n const success = searchResponse?.success;\n\n // This is checking to see if the fetch has been invalidated since it was fired off.\n // If so, we just want to discard the response since it is for an obsolete query state.\n if (!this.fetchesInProgress.has(currentPageKey)) return;\n for (let i = 0; i < numPages; i += 1) {\n this.fetchesInProgress.delete(`${pageFetchQueryKey}-p:${pageNumber + i}`);\n }\n\n if (!success) {\n const errorMsg = searchResponse?.error?.message;\n const detailMsg = searchResponse?.error?.details?.message;\n\n this.queryErrorMessage = `${errorMsg ?? ''}${\n detailMsg ? `; ${detailMsg}` : ''\n }`;\n\n if (!this.queryErrorMessage) {\n this.queryErrorMessage = 'Missing or malformed response from backend';\n // @ts-expect-error: Property 'Sentry' does not exist on type 'Window & typeof globalThis'\n window?.Sentry?.captureMessage?.(this.queryErrorMessage, 'error');\n }\n\n this.setSearchResultsLoading(false);\n this.requestHostUpdate();\n return;\n }\n\n this.setTotalResultCount(success.response.totalResults - this.offset);\n if (this.activeOnHost && this.totalResults === 0) {\n // display event to offshoot when result count is zero.\n this.host.emitEmptyResults();\n }\n\n this.sessionContext = success.sessionContext;\n if (withinCollection) {\n this.collectionExtraInfo = success.response.collectionExtraInfo;\n\n // For collections, we want the UI to respect the default sort option\n // which can be specified in metadata, or otherwise assumed to be week:desc\n if (this.activeOnHost) {\n this.host.applyDefaultCollectionSort(this.collectionExtraInfo);\n }\n\n if (this.collectionExtraInfo) {\n this.parentCollections = [].concat(\n this.collectionExtraInfo.public_metadata?.collection ?? [],\n );\n\n // Update the TV collection status now that we know the parent collections\n this.host.isTVCollection =\n this.host.withinCollection?.startsWith('TV-') ||\n this.host.withinCollection === 'tvnews' ||\n this.host.withinCollection === 'tvarchive' ||\n this.parentCollections.includes('tvnews') ||\n this.parentCollections.includes('tvarchive');\n }\n } else if (withinProfile) {\n this.accountExtraInfo = success.response.accountExtraInfo;\n this.pageElements = success.response.pageElements;\n }\n\n const { results, collectionTitles, tvChannelAliases } = success.response;\n if (results && results.length > 0) {\n // Load any collection titles present on the response into the cache,\n // or queue up preload fetches for them if none were present.\n if (collectionTitles) {\n for (const [id, title] of Object.entries(collectionTitles)) {\n this.collectionTitles.set(id, title);\n }\n\n // Also add the target collection's title if available\n const targetTitle = this.collectionExtraInfo?.public_metadata?.title;\n if (withinCollection && targetTitle) {\n this.collectionTitles.set(withinCollection, targetTitle);\n }\n }\n\n if (tvChannelAliases) {\n for (const [channel, network] of Object.entries(tvChannelAliases)) {\n this.tvChannelAliases.set(channel, network);\n }\n }\n\n // Update the data source for each returned page.\n // For loans and web archives, we must account for receiving more pages than we asked for.\n const isUnpagedElement = ['lending', 'web_archives'].includes(\n this.host.profileElement!,\n );\n if (isUnpagedElement) {\n numPages = Math.ceil(results.length / this.pageSize);\n this.endOfDataReached = true;\n if (this.activeOnHost) this.host.setTileCount(this.totalResults);\n }\n\n for (let i = 0; i < numPages; i += 1) {\n const pageStartIndex = this.pageSize * i;\n this.addFetchedResultsToDataSource(\n pageNumber + i,\n results.slice(pageStartIndex, pageStartIndex + this.pageSize),\n !isUnpagedElement || i === numPages - 1,\n );\n }\n }\n\n // When we reach the end of the data, we can set the infinite scroller's\n // item count to the real total number of results (rather than the\n // temporary estimates based on pages rendered so far).\n if (this.size >= this.totalResults || results.length === 0) {\n this.endOfDataReached = true;\n if (this.activeOnHost) this.host.setTileCount(this.size);\n }\n\n this.setSearchResultsLoading(false);\n this.requestHostUpdate();\n }\n\n /**\n * Returns the type of request that produced the current set of hits,\n * based on the presence of a search query or profile/collection target\n * on the host.\n */\n private get hitRequestSource(): HitRequestSource {\n const { host } = this;\n if (host.baseQuery) return 'search_query';\n if (host.withinProfile) return 'profile_tab';\n if (host.withinCollection) return 'collection_members';\n return 'unknown';\n }\n\n /**\n * Update the datasource from the fetch response\n *\n * @param pageNumber\n * @param results\n */\n private addFetchedResultsToDataSource(\n pageNumber: number,\n results: SearchResult[],\n needsReload = true,\n ): void {\n const tiles: TileModel[] = [];\n const requestSource = this.hitRequestSource;\n results?.forEach(result => {\n if (!result.identifier) return;\n tiles.push(new TileModel(result, requestSource));\n });\n\n this.addPage(pageNumber, tiles);\n\n if (needsReload) {\n this.refreshVisibleResults();\n }\n }\n\n /**\n * Fetches the aggregation buckets for the given prefix filter type.\n */\n private async fetchPrefixFilterBuckets(\n filterType: PrefixFilterType,\n ): Promise<Bucket[]> {\n const trimmedQuery = this.host.baseQuery?.trim();\n if (!this.canPerformSearch) return [];\n\n const filterAggregationKey = prefixFilterAggregationKeys[filterType];\n const sortParams = this.host.sortParam ? [this.host.sortParam] : [];\n\n const params: SearchParams = {\n ...this.pageSpecifierParams,\n query: trimmedQuery || '',\n rows: 0,\n filters: this.filterMap,\n // Only fetch the firstTitle or firstCreator aggregation\n aggregations: { simpleParams: [filterAggregationKey] },\n // Fetch all 26 letter buckets\n aggregationsSize: 26,\n };\n params.uid = await this.requestUID(\n { ...params, sort: sortParams },\n 'aggregations',\n );\n\n const searchResponse = await this.host.searchService?.search(\n params,\n this.host.searchType,\n );\n\n return (searchResponse?.success?.response?.aggregations?.[\n filterAggregationKey\n ]?.buckets ?? []) as Bucket[];\n }\n\n /**\n * Fetches and caches the prefix filter counts for the given filter type.\n */\n async updatePrefixFilterCounts(filterType: PrefixFilterType): Promise<void> {\n const { facetFetchQueryKey } = this;\n const buckets = await this.fetchPrefixFilterBuckets(filterType);\n\n // Don't update the filter counts for an outdated query (if it has been changed\n // since we sent the request)\n const queryChangedSinceFetch =\n facetFetchQueryKey !== this.facetFetchQueryKey;\n if (queryChangedSinceFetch) return;\n\n // Unpack the aggregation buckets into a simple map like { 'A': 50, 'B': 25, ... }\n this.prefixFilterCountMap = { ...this.prefixFilterCountMap }; // Clone the object to trigger an update\n this.prefixFilterCountMap[filterType] = buckets.reduce(\n (acc: Record<string, number>, bucket: Bucket) => {\n acc[(bucket.key as string).toUpperCase()] = bucket.doc_count;\n return acc;\n },\n {},\n );\n\n this.requestHostUpdate();\n }\n\n /**\n * @inheritdoc\n */\n async updatePrefixFiltersForCurrentSort(): Promise<void> {\n if (['title', 'creator'].includes(this.host.selectedSort as SortField)) {\n const filterType = this.host.selectedSort as PrefixFilterType;\n if (!this.prefixFilterCountMap[filterType]) {\n this.updatePrefixFilterCounts(filterType);\n }\n }\n }\n\n /**\n * @inheritdoc\n */\n refreshLetterCounts(): void {\n if (Object.keys(this.prefixFilterCountMap).length > 0) {\n this.prefixFilterCountMap = {};\n }\n this.updatePrefixFiltersForCurrentSort();\n this.requestHostUpdate();\n }\n}\n"]}
@@ -46,6 +46,10 @@ export declare class ManageBar extends LitElement {
46
46
  * @param items Which items to list in the modal
47
47
  */
48
48
  private showRemoveItemsModal;
49
+ /**
50
+ * Shows a modal dialog indicating that item removal was successful
51
+ */
52
+ showRemoveItemsSuccessModal(): void;
49
53
  /**
50
54
  * Shows a modal dialog indicating that item removal is being processed
51
55
  */
@@ -121,6 +121,27 @@ let ManageBar = class ManageBar extends LitElement {
121
121
  },
122
122
  });
123
123
  }
124
+ /**
125
+ * Shows a modal dialog indicating that item removal was successful
126
+ */
127
+ showRemoveItemsSuccessModal() {
128
+ var _a, _b;
129
+ const config = new ModalConfig({
130
+ bodyColor: '#fff',
131
+ showHeaderLogo: true,
132
+ closeOnBackdropClick: true,
133
+ title: html `${msg('Success!')}`,
134
+ message: html `${msg('This entry has been deleted successfully. It may take time for the change to be reflected everywhere.')}`,
135
+ });
136
+ (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.add('remove-items');
137
+ (_b = this.modalManager) === null || _b === void 0 ? void 0 : _b.showModal({
138
+ config,
139
+ userClosedModalCallback: () => {
140
+ var _a;
141
+ (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.remove('remove-items');
142
+ },
143
+ });
144
+ }
124
145
  /**
125
146
  * Shows a modal dialog indicating that item removal is being processed
126
147
  */
@@ -1 +1 @@
1
- {"version":3,"file":"manage-bar.js","sourceRoot":"","sources":["../../../src/manage/manage-bar.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAAkC,MAAM,KAAK,CAAC;AAC5E,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,IAAI,EAAE,MAAM,wBAAwB,CAAC;AAC9C,OAAO,EACL,WAAW,GAEZ,MAAM,gCAAgC,CAAC;AAExC,OAAO,aAAa,MAAM,qBAAqB,CAAC;AAChD,OAAO,8BAA8B,CAAC;AAG/B,IAAM,SAAS,GAAf,MAAM,SAAU,SAAQ,UAAU;IAAlC;;QACL;;WAEG;QACyB,UAAK,GAAG,GAAG,CAAC,wBAAwB,CAAC,CAAC;QAOlE;;WAEG;QACyB,kBAAa,GAA0B,EAAE,CAAC;QAOtE;;WAEG;QAC0B,kBAAa,GAAG,KAAK,CAAC;QAEnD;;WAEG;QAC0B,oBAAe,GAAG,KAAK,CAAC;QAErD;;WAEG;QAC0B,yBAAoB,GAAG,KAAK,CAAC;QAE1D;;WAEG;QAC0B,kBAAa,GAAG,KAAK,CAAC;IAkMrD,CAAC;IAhMC,MAAM;QACJ,OAAO,IAAI,CAAA;;qCAEsB,IAAI,CAAC,KAAK;;kDAEG,IAAI,CAAC,aAAa;cACtD,GAAG,CAAC,QAAQ,CAAC;;;;wBAIH,CAAC,IAAI,CAAC,aAAa;qBACtB,IAAI,CAAC,oBAAoB;;cAEhC,GAAG,CAAC,uBAAuB,CAAC,KAAK,IAAI,CAAC,aAAa,CAAC,MAAM;;YAE5D,IAAI,CACJ,IAAI,CAAC,oBAAoB,EACzB,GAAG,EAAE,CACH,IAAI,CAAA;;4BAEU,CAAC,IAAI,CAAC,aAAa;yBACtB,IAAI,CAAC,kBAAkB;;kBAE9B,GAAG,CAAC,wBAAwB,CAAC,KAAK,IAAI,CAAC,aAAa,CAAC,MAAM;wBACrD,CACb;;cAEG,IAAI,CACJ,IAAI,CAAC,aAAa,EAClB,GAAG,EAAE,CACH,IAAI,CAAA;;2BAEO,IAAI,CAAC,gBAAgB;;oBAE5B,GAAG,CAAC,YAAY,CAAC;0BACX,CACb;cACC,IAAI,CACJ,IAAI,CAAC,eAAe,EACpB,GAAG,EAAE,CACH,IAAI,CAAA;;2BAEO,IAAI,CAAC,kBAAkB;;oBAE9B,GAAG,CAAC,cAAc,CAAC;0BACb,CACb;;;;KAIR,CAAC;IACJ,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC;IAChD,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC;IACrD,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC;IACrD,CAAC;IAEO,gBAAgB;QACtB,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC;IACnD,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC;IACrD,CAAC;IAED;;;OAGG;IACK,oBAAoB;;QAC1B,MAAM,kBAAkB,GAAG,IAAI,CAAA;;iBAElB,IAAI,CAAC,aAAa;mBAChB,IAAI,CAAC,kBAAkB;mBACvB,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,EAAE;;KAE7C,CAAC;QAEF,MAAM,MAAM,GAAG,IAAI,WAAW,CAAC;YAC7B,uBAAuB,EAAE,KAAK;YAC9B,mBAAmB,EAAE,YAAY;YACjC,SAAS,EAAE,MAAM;YACjB,WAAW,EAAE,SAAS;YACtB,cAAc,EAAE,KAAK;YACrB,oBAAoB,EAAE,IAAI;YAC1B,KAAK,EAAE,IAAI,CAAA,GAAG,GAAG,CAAC,8CAA8C,CAAC,EAAE;SACpE,CAAC,CAAC;QAEH,MAAA,IAAI,CAAC,YAAY,0CAAE,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QACjD,MAAA,IAAI,CAAC,YAAY,0CAAE,SAAS,CAAC;YAC3B,MAAM;YACN,kBAAkB;YAClB,uBAAuB,EAAE,GAAG,EAAE;;gBAC5B,MAAA,IAAI,CAAC,YAAY,0CAAE,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;YACtD,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,8BAA8B;;QAC5B,MAAM,MAAM,GAAG,IAAI,WAAW,CAAC;YAC7B,uBAAuB,EAAE,IAAI;YAC7B,mBAAmB,EAAE,YAAY;YACjC,SAAS,EAAE,MAAM;YACjB,WAAW,EAAE,SAAS;YACtB,cAAc,EAAE,KAAK;YACrB,oBAAoB,EAAE,IAAI;YAC1B,KAAK,EAAE,IAAI,CAAA,GAAG,GAAG,CAAC,4BAA4B,CAAC,EAAE;SAClD,CAAC,CAAC;QAEH,MAAA,IAAI,CAAC,YAAY,0CAAE,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QACjD,MAAA,IAAI,CAAC,YAAY,0CAAE,SAAS,CAAC;YAC3B,MAAM;YACN,uBAAuB,EAAE,GAAG,EAAE;;gBAC5B,MAAA,IAAI,CAAC,YAAY,0CAAE,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;YACtD,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,yBAAyB;;QACvB,MAAM,MAAM,GAAG,IAAI,WAAW,CAAC;YAC7B,uBAAuB,EAAE,KAAK;YAC9B,mBAAmB,EAAE,YAAY;YACjC,SAAS,EAAE,MAAM;YACjB,WAAW,EAAE,SAAS;YACtB,cAAc,EAAE,KAAK;YACrB,oBAAoB,EAAE,IAAI;YAC1B,KAAK,EAAE,IAAI,CAAA,GAAG,GAAG,CAAC,+BAA+B,CAAC,EAAE;YACpD,OAAO,EAAE,IAAI,CAAA,GAAG,GAAG,CACjB,4EAA4E,CAC7E,EAAE;SACJ,CAAC,CAAC;QAEH,MAAA,IAAI,CAAC,YAAY,0CAAE,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QACjD,MAAA,IAAI,CAAC,YAAY,0CAAE,SAAS,CAAC;YAC3B,MAAM;YACN,uBAAuB,EAAE,GAAG,EAAE;;gBAC5B,MAAA,IAAI,CAAC,YAAY,0CAAE,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;YACtD,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,MAAM,KAAK,MAAM;QACf,OAAO,GAAG,CAAA;QACN,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAiChB,CAAC;IACJ,CAAC;CACF,CAAA;AArO6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;wCAAuC;AAKtC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;+CAAsC;AAKrC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;gDAA2C;AAK1C;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;qDAA6B;AAK3B;IAA5B,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;gDAAuB;AAKtB;IAA5B,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;kDAAyB;AAKxB;IAA5B,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;uDAA8B;AAK7B;IAA5B,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;gDAAuB;AAvCxC,SAAS;IADrB,aAAa,CAAC,YAAY,CAAC;GACf,SAAS,CAyOrB","sourcesContent":["import { msg } from '@lit/localize';\nimport { LitElement, html, css, TemplateResult, CSSResultGroup } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { when } from 'lit/directives/when.js';\nimport {\n ModalConfig,\n type ModalManagerInterface,\n} from '@internetarchive/modal-manager';\nimport type { ManageableItem } from '../models';\nimport iaButtonStyle from '../styles/ia-button';\nimport './remove-items-modal-content';\n\n@customElement('manage-bar')\nexport class ManageBar extends LitElement {\n /**\n * The label displayed in front of the management buttons\n */\n @property({ type: String }) label = msg('Select items to remove');\n\n /**\n * The shared modal manager component for displaying modal dialogs on this page\n */\n @property({ type: Object }) modalManager?: ModalManagerInterface;\n\n /**\n * Array of items that have been selected for management\n */\n @property({ type: Object }) selectedItems: Array<ManageableItem> = [];\n\n /**\n * Message shows as note in the modal when removing items\n */\n @property({ type: String }) manageViewModalMsg?: string;\n\n /**\n * Whether to show the \"Select All\" button (default false)\n */\n @property({ type: Boolean }) showSelectAll = false;\n\n /**\n * Whether to show the \"Unselect All\" button (default false)\n */\n @property({ type: Boolean }) showUnselectAll = false;\n\n /**\n * Whether to show \"Item Manager the items\" button (default false)\n */\n @property({ type: Boolean }) showItemManageButton = false;\n\n /**\n * Whether to active delete button for selectable items\n */\n @property({ type: Boolean }) removeAllowed = false;\n\n render(): TemplateResult {\n return html`\n <div class=\"manage-container\">\n <span class=\"manage-label\">${this.label}</span>\n <div class=\"manage-buttons\">\n <button class=\"ia-button dark\" @click=${this.cancelClicked}>\n ${msg('Cancel')}\n </button>\n <button\n class=\"ia-button danger\"\n ?disabled=${!this.removeAllowed}\n @click=${this.showRemoveItemsModal}\n >\n ${msg('Remove selected items')} (${this.selectedItems.length})\n </button>\n ${when(\n this.showItemManageButton,\n () =>\n html` <button\n class=\"ia-button warning\"\n ?disabled=${!this.removeAllowed}\n @click=${this.manageItemsClicked}\n >\n ${msg('Item Manager the items')} (${this.selectedItems.length})\n </button>`,\n )}\n <div class=\"selection-buttons\">\n ${when(\n this.showSelectAll,\n () =>\n html` <button\n class=\"ia-button link select-all-btn\"\n @click=${this.selectAllClicked}\n >\n ${msg('Select all')}\n </button>`,\n )}\n ${when(\n this.showUnselectAll,\n () =>\n html` <button\n class=\"ia-button link unselect-all-btn\"\n @click=${this.unselectAllClicked}\n >\n ${msg('Unselect all')}\n </button>`,\n )}\n </div>\n </div>\n </div>\n `;\n }\n\n private cancelClicked(): void {\n this.dispatchEvent(new CustomEvent('cancel'));\n }\n\n private removeItemsClicked(): void {\n this.dispatchEvent(new CustomEvent('removeItems'));\n }\n\n private manageItemsClicked(): void {\n this.dispatchEvent(new CustomEvent('manageItems'));\n }\n\n private selectAllClicked(): void {\n this.dispatchEvent(new CustomEvent('selectAll'));\n }\n\n private unselectAllClicked(): void {\n this.dispatchEvent(new CustomEvent('unselectAll'));\n }\n\n /**\n * Shows a modal dialog confirming the list of items to be removed\n * @param items Which items to list in the modal\n */\n private showRemoveItemsModal(): void {\n const customModalContent = html`\n <remove-items-modal-content\n .items=${this.selectedItems}\n .message=${this.manageViewModalMsg}\n @confirm=${() => this.removeItemsClicked()}\n ></remove-items-modal-content>\n `;\n\n const config = new ModalConfig({\n showProcessingIndicator: false,\n processingImageMode: 'processing',\n bodyColor: '#fff',\n headerColor: '#194880',\n showHeaderLogo: false,\n closeOnBackdropClick: true,\n title: html`${msg('Are you sure you want to remove these items?')}`,\n });\n\n this.modalManager?.classList.add('remove-items');\n this.modalManager?.showModal({\n config,\n customModalContent,\n userClosedModalCallback: () => {\n this.modalManager?.classList.remove('remove-items');\n },\n });\n }\n\n /**\n * Shows a modal dialog indicating that item removal is being processed\n */\n showRemoveItemsProcessingModal(): void {\n const config = new ModalConfig({\n showProcessingIndicator: true,\n processingImageMode: 'processing',\n bodyColor: '#fff',\n headerColor: '#194880',\n showHeaderLogo: false,\n closeOnBackdropClick: true,\n title: html`${msg('Removing selected items...')}`,\n });\n\n this.modalManager?.classList.add('remove-items');\n this.modalManager?.showModal({\n config,\n userClosedModalCallback: () => {\n this.modalManager?.classList.remove('remove-items');\n },\n });\n }\n\n /**\n * Shows a modal dialog indicating that an error occurred while removing items\n */\n showRemoveItemsErrorModal(): void {\n const config = new ModalConfig({\n showProcessingIndicator: false,\n processingImageMode: 'processing',\n bodyColor: '#fff',\n headerColor: '#691916',\n showHeaderLogo: false,\n closeOnBackdropClick: true,\n title: html`${msg('Error: unable to remove items')}`,\n message: html`${msg(\n 'An error occurred while removing items. Please try again in a few minutes.',\n )}`,\n });\n\n this.modalManager?.classList.add('remove-items');\n this.modalManager?.showModal({\n config,\n userClosedModalCallback: () => {\n this.modalManager?.classList.remove('remove-items');\n },\n });\n }\n\n static get styles(): CSSResultGroup {\n return css`\n ${iaButtonStyle}\n .manage-container {\n display: flex;\n align-items: center;\n column-gap: 5px;\n padding: 20px 0 20px;\n flex-wrap: wrap;\n }\n\n .manage-label {\n display: inline-block;\n font-weight: bold;\n font-size: 1.8rem;\n padding-right: 10px;\n }\n\n .manage-buttons {\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n column-gap: 5px;\n }\n\n .selection-buttons {\n display: inherit;\n }\n\n .ia-button,\n button {\n padding: 6px 12px;\n font-size: 1.4rem;\n margin: 3px 0;\n }\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"manage-bar.js","sourceRoot":"","sources":["../../../src/manage/manage-bar.ts"],"names":[],"mappings":"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","sourcesContent":["import { msg } from '@lit/localize';\nimport { LitElement, html, css, TemplateResult, CSSResultGroup } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { when } from 'lit/directives/when.js';\nimport {\n ModalConfig,\n type ModalManagerInterface,\n} from '@internetarchive/modal-manager';\nimport type { ManageableItem } from '../models';\nimport iaButtonStyle from '../styles/ia-button';\nimport './remove-items-modal-content';\n\n@customElement('manage-bar')\nexport class ManageBar extends LitElement {\n /**\n * The label displayed in front of the management buttons\n */\n @property({ type: String }) label = msg('Select items to remove');\n\n /**\n * The shared modal manager component for displaying modal dialogs on this page\n */\n @property({ type: Object }) modalManager?: ModalManagerInterface;\n\n /**\n * Array of items that have been selected for management\n */\n @property({ type: Object }) selectedItems: Array<ManageableItem> = [];\n\n /**\n * Message shows as note in the modal when removing items\n */\n @property({ type: String }) manageViewModalMsg?: string;\n\n /**\n * Whether to show the \"Select All\" button (default false)\n */\n @property({ type: Boolean }) showSelectAll = false;\n\n /**\n * Whether to show the \"Unselect All\" button (default false)\n */\n @property({ type: Boolean }) showUnselectAll = false;\n\n /**\n * Whether to show \"Item Manager the items\" button (default false)\n */\n @property({ type: Boolean }) showItemManageButton = false;\n\n /**\n * Whether to active delete button for selectable items\n */\n @property({ type: Boolean }) removeAllowed = false;\n\n render(): TemplateResult {\n return html`\n <div class=\"manage-container\">\n <span class=\"manage-label\">${this.label}</span>\n <div class=\"manage-buttons\">\n <button class=\"ia-button dark\" @click=${this.cancelClicked}>\n ${msg('Cancel')}\n </button>\n <button\n class=\"ia-button danger\"\n ?disabled=${!this.removeAllowed}\n @click=${this.showRemoveItemsModal}\n >\n ${msg('Remove selected items')} (${this.selectedItems.length})\n </button>\n ${when(\n this.showItemManageButton,\n () =>\n html` <button\n class=\"ia-button warning\"\n ?disabled=${!this.removeAllowed}\n @click=${this.manageItemsClicked}\n >\n ${msg('Item Manager the items')} (${this.selectedItems.length})\n </button>`,\n )}\n <div class=\"selection-buttons\">\n ${when(\n this.showSelectAll,\n () =>\n html` <button\n class=\"ia-button link select-all-btn\"\n @click=${this.selectAllClicked}\n >\n ${msg('Select all')}\n </button>`,\n )}\n ${when(\n this.showUnselectAll,\n () =>\n html` <button\n class=\"ia-button link unselect-all-btn\"\n @click=${this.unselectAllClicked}\n >\n ${msg('Unselect all')}\n </button>`,\n )}\n </div>\n </div>\n </div>\n `;\n }\n\n private cancelClicked(): void {\n this.dispatchEvent(new CustomEvent('cancel'));\n }\n\n private removeItemsClicked(): void {\n this.dispatchEvent(new CustomEvent('removeItems'));\n }\n\n private manageItemsClicked(): void {\n this.dispatchEvent(new CustomEvent('manageItems'));\n }\n\n private selectAllClicked(): void {\n this.dispatchEvent(new CustomEvent('selectAll'));\n }\n\n private unselectAllClicked(): void {\n this.dispatchEvent(new CustomEvent('unselectAll'));\n }\n\n /**\n * Shows a modal dialog confirming the list of items to be removed\n * @param items Which items to list in the modal\n */\n private showRemoveItemsModal(): void {\n const customModalContent = html`\n <remove-items-modal-content\n .items=${this.selectedItems}\n .message=${this.manageViewModalMsg}\n @confirm=${() => this.removeItemsClicked()}\n ></remove-items-modal-content>\n `;\n\n const config = new ModalConfig({\n showProcessingIndicator: false,\n processingImageMode: 'processing',\n bodyColor: '#fff',\n headerColor: '#194880',\n showHeaderLogo: false,\n closeOnBackdropClick: true,\n title: html`${msg('Are you sure you want to remove these items?')}`,\n });\n\n this.modalManager?.classList.add('remove-items');\n this.modalManager?.showModal({\n config,\n customModalContent,\n userClosedModalCallback: () => {\n this.modalManager?.classList.remove('remove-items');\n },\n });\n }\n\n /**\n * Shows a modal dialog indicating that item removal was successful\n */\n showRemoveItemsSuccessModal(): void {\n const config = new ModalConfig({\n bodyColor: '#fff',\n showHeaderLogo: true,\n closeOnBackdropClick: true,\n title: html`${msg('Success!')}`,\n message: html`${msg(\n 'This entry has been deleted successfully. It may take time for the change to be reflected everywhere.',\n )}`,\n });\n\n this.modalManager?.classList.add('remove-items');\n this.modalManager?.showModal({\n config,\n userClosedModalCallback: () => {\n this.modalManager?.classList.remove('remove-items');\n },\n });\n }\n\n /**\n * Shows a modal dialog indicating that item removal is being processed\n */\n showRemoveItemsProcessingModal(): void {\n const config = new ModalConfig({\n showProcessingIndicator: true,\n processingImageMode: 'processing',\n bodyColor: '#fff',\n headerColor: '#194880',\n showHeaderLogo: false,\n closeOnBackdropClick: true,\n title: html`${msg('Removing selected items...')}`,\n });\n\n this.modalManager?.classList.add('remove-items');\n this.modalManager?.showModal({\n config,\n userClosedModalCallback: () => {\n this.modalManager?.classList.remove('remove-items');\n },\n });\n }\n\n /**\n * Shows a modal dialog indicating that an error occurred while removing items\n */\n showRemoveItemsErrorModal(): void {\n const config = new ModalConfig({\n showProcessingIndicator: false,\n processingImageMode: 'processing',\n bodyColor: '#fff',\n headerColor: '#691916',\n showHeaderLogo: false,\n closeOnBackdropClick: true,\n title: html`${msg('Error: unable to remove items')}`,\n message: html`${msg(\n 'An error occurred while removing items. Please try again in a few minutes.',\n )}`,\n });\n\n this.modalManager?.classList.add('remove-items');\n this.modalManager?.showModal({\n config,\n userClosedModalCallback: () => {\n this.modalManager?.classList.remove('remove-items');\n },\n });\n }\n\n static get styles(): CSSResultGroup {\n return css`\n ${iaButtonStyle}\n .manage-container {\n display: flex;\n align-items: center;\n column-gap: 5px;\n padding: 20px 0 20px;\n flex-wrap: wrap;\n }\n\n .manage-label {\n display: inline-block;\n font-weight: bold;\n font-size: 1.8rem;\n padding-right: 10px;\n }\n\n .manage-buttons {\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n column-gap: 5px;\n }\n\n .selection-buttons {\n display: inherit;\n }\n\n .ia-button,\n button {\n padding: 6px 12px;\n font-size: 1.4rem;\n margin: 3px 0;\n }\n `;\n }\n}\n"]}
@@ -73,7 +73,6 @@ let RemoveItemsModalContent = class RemoveItemsModalContent extends LitElement {
73
73
  }
74
74
 
75
75
  .remove-items-btn {
76
- margin-bottom: 10px;
77
76
  padding: 10px;
78
77
  border: 1px solid var(--primaryErrorCTABorder, #d43f3a);
79
78
  border-radius: 4px;
@@ -1 +1 @@
1
- {"version":3,"file":"remove-items-modal-content.js","sourceRoot":"","sources":["../../../src/manage/remove-items-modal-content.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAAE,OAAO,EAA6B,MAAM,KAAK,CAAC;AAChF,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AACpC,OAAO,EAAE,GAAG,EAAE,MAAM,uBAAuB,CAAC;AAIrC,IAAM,uBAAuB,GAA7B,MAAM,uBAAwB,SAAQ,UAAU;IAAhD;;QACuB,UAAK,GAAqB,EAAE,CAAC;IA6F3D,CAAC;IAzFC,MAAM;QACJ,OAAO,IAAI,CAAA;;UAEL,GAAG,CACH,IAAI,CAAC,KAAK,EACV,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAA;;yCAEM,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,YAAY;wCACtB,IAAI,aAAJ,IAAI,cAAJ,IAAI,GAAI,EAAE;;WAEvC,CACF;;QAED,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAA,sBAAsB,IAAI,CAAC,OAAO,MAAM,CAAC,CAAC,CAAC,OAAO;;kDAE3B,IAAI,CAAC,qBAAqB;YAChE,GAAG,CAAC,cAAc,CAAC;;;KAG1B,CAAC;IACJ,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,aAAa,CAChB,IAAI,WAAW,CAA8B,SAAS,EAAE;YACtD,MAAM,EAAE;gBACN,KAAK,EAAE,IAAI,CAAC,KAAK;aAClB;SACF,CAAC,CACH,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,MAAM;QACf,OAAO,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAsDT,CAAC;IACJ,CAAC;CACF,CAAA;AA7F6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;sDAA8B;AAE7B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;wDAAkB;AAHlC,uBAAuB;IADnC,aAAa,CAAC,4BAA4B,CAAC;GAC/B,uBAAuB,CA8FnC","sourcesContent":["import { LitElement, html, css, nothing, TemplateResult, CSSResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { msg } from '@lit/localize';\nimport { map } from 'lit/directives/map.js';\nimport type { ManageableItem } from '../models';\n\n@customElement('remove-items-modal-content')\nexport class RemoveItemsModalContent extends LitElement {\n @property({ type: Object }) items: ManageableItem[] = [];\n\n @property({ type: String }) message?: string;\n\n render(): TemplateResult {\n return html`\n <ul>\n ${map(\n this.items,\n ({ title, date }) => html`\n <li>\n <span class=\"item-title\">${title ?? '[untitled]'}</span>\n <span class=\"item-date\">${date ?? ''}</span>\n </li>\n `,\n )}\n </ul>\n ${this.message ? html`<p class=\"message\">${this.message}</p>` : nothing}\n <div class=\"button-bar\">\n <button class=\"remove-items-btn\" @click=${this.removeItemsBtnClicked}>\n ${msg('Remove items')}\n </button>\n </div>\n `;\n }\n\n private removeItemsBtnClicked(): void {\n this.dispatchEvent(\n new CustomEvent<{ items: ManageableItem[] }>('confirm', {\n detail: {\n items: this.items,\n },\n }),\n );\n }\n\n static get styles(): CSSResult {\n return css`\n ul {\n margin: 0;\n padding: 0 10px;\n font-size: 1.4rem;\n list-style-type: none;\n max-height: min(400px, 40vh);\n overflow-y: auto;\n }\n\n li {\n display: flex;\n justify-content: space-between;\n padding: 2px 0;\n }\n li:not(:last-of-type) {\n border-bottom: 1px solid rgb(232, 232, 232);\n }\n\n .item-title {\n word-break: break-word;\n }\n\n .item-date {\n white-space: nowrap;\n }\n\n .message {\n font-size: 1.4rem;\n padding: 5px 10px;\n }\n\n .button-bar {\n display: flex;\n justify-content: center;\n margin: 10px 5px;\n }\n\n .remove-items-btn {\n margin-bottom: 10px;\n padding: 10px;\n border: 1px solid var(--primaryErrorCTABorder, #d43f3a);\n border-radius: 4px;\n color: white;\n background: var(--primaryErrorCTAFill, #d9534f);\n appearance: none;\n cursor: pointer;\n }\n .remove-items-btn:hover {\n background: rgba(var(--primaryErrorCTAFillRGB, 229, 28, 38), 0.9);\n }\n .remove-items-btn:active {\n background: rgba(var(--primaryErrorCTAFillRGB, 229, 28, 38), 0.7);\n }\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"remove-items-modal-content.js","sourceRoot":"","sources":["../../../src/manage/remove-items-modal-content.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAAE,OAAO,EAA6B,MAAM,KAAK,CAAC;AAChF,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AACpC,OAAO,EAAE,GAAG,EAAE,MAAM,uBAAuB,CAAC;AAIrC,IAAM,uBAAuB,GAA7B,MAAM,uBAAwB,SAAQ,UAAU;IAAhD;;QACuB,UAAK,GAAqB,EAAE,CAAC;IA4F3D,CAAC;IAxFC,MAAM;QACJ,OAAO,IAAI,CAAA;;UAEL,GAAG,CACH,IAAI,CAAC,KAAK,EACV,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAA;;yCAEM,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,YAAY;wCACtB,IAAI,aAAJ,IAAI,cAAJ,IAAI,GAAI,EAAE;;WAEvC,CACF;;QAED,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAA,sBAAsB,IAAI,CAAC,OAAO,MAAM,CAAC,CAAC,CAAC,OAAO;;kDAE3B,IAAI,CAAC,qBAAqB;YAChE,GAAG,CAAC,cAAc,CAAC;;;KAG1B,CAAC;IACJ,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,aAAa,CAChB,IAAI,WAAW,CAA8B,SAAS,EAAE;YACtD,MAAM,EAAE;gBACN,KAAK,EAAE,IAAI,CAAC,KAAK;aAClB;SACF,CAAC,CACH,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,MAAM;QACf,OAAO,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAqDT,CAAC;IACJ,CAAC;CACF,CAAA;AA5F6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;sDAA8B;AAE7B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;wDAAkB;AAHlC,uBAAuB;IADnC,aAAa,CAAC,4BAA4B,CAAC;GAC/B,uBAAuB,CA6FnC","sourcesContent":["import { LitElement, html, css, nothing, TemplateResult, CSSResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { msg } from '@lit/localize';\nimport { map } from 'lit/directives/map.js';\nimport type { ManageableItem } from '../models';\n\n@customElement('remove-items-modal-content')\nexport class RemoveItemsModalContent extends LitElement {\n @property({ type: Object }) items: ManageableItem[] = [];\n\n @property({ type: String }) message?: string;\n\n render(): TemplateResult {\n return html`\n <ul>\n ${map(\n this.items,\n ({ title, date }) => html`\n <li>\n <span class=\"item-title\">${title ?? '[untitled]'}</span>\n <span class=\"item-date\">${date ?? ''}</span>\n </li>\n `,\n )}\n </ul>\n ${this.message ? html`<p class=\"message\">${this.message}</p>` : nothing}\n <div class=\"button-bar\">\n <button class=\"remove-items-btn\" @click=${this.removeItemsBtnClicked}>\n ${msg('Remove items')}\n </button>\n </div>\n `;\n }\n\n private removeItemsBtnClicked(): void {\n this.dispatchEvent(\n new CustomEvent<{ items: ManageableItem[] }>('confirm', {\n detail: {\n items: this.items,\n },\n }),\n );\n }\n\n static get styles(): CSSResult {\n return css`\n ul {\n margin: 0;\n padding: 0 10px;\n font-size: 1.4rem;\n list-style-type: none;\n max-height: min(400px, 40vh);\n overflow-y: auto;\n }\n\n li {\n display: flex;\n justify-content: space-between;\n padding: 2px 0;\n }\n li:not(:last-of-type) {\n border-bottom: 1px solid rgb(232, 232, 232);\n }\n\n .item-title {\n word-break: break-word;\n }\n\n .item-date {\n white-space: nowrap;\n }\n\n .message {\n font-size: 1.4rem;\n padding: 5px 10px;\n }\n\n .button-bar {\n display: flex;\n justify-content: center;\n margin: 10px 5px;\n }\n\n .remove-items-btn {\n padding: 10px;\n border: 1px solid var(--primaryErrorCTABorder, #d43f3a);\n border-radius: 4px;\n color: white;\n background: var(--primaryErrorCTAFill, #d9534f);\n appearance: none;\n cursor: pointer;\n }\n .remove-items-btn:hover {\n background: rgba(var(--primaryErrorCTAFillRGB, 229, 28, 38), 0.9);\n }\n .remove-items-btn:active {\n background: rgba(var(--primaryErrorCTAFillRGB, 229, 28, 38), 0.7);\n }\n `;\n }\n}\n"]}