{
  "version": 3,
  "sources": ["../../src/queried-data/selectors.js"],
  "sourcesContent": ["/**\n * External dependencies\n */\nimport EquivalentKeyMap from 'equivalent-key-map';\n\n/**\n * WordPress dependencies\n */\nimport { createSelector } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport getQueryParts from './get-query-parts';\nimport { setNestedValue } from '../utils';\n\n/**\n * Cache of state keys to EquivalentKeyMap where the inner map tracks queries\n * to their resulting items set. WeakMap allows garbage collection on expired\n * state references.\n *\n * @type {WeakMap<Object,EquivalentKeyMap>}\n */\nconst queriedItemsCacheByState = new WeakMap();\n\n/**\n * Returns items for a given query, or null if the items are not known.\n *\n * @param {Object}  state                      State object.\n * @param {?Object} query                      Optional query.\n * @param {?Object} options                    Optional pagination options.\n * @param {boolean} options.supportsPagination Whether the entity supports pagination. Default true.\n *\n * @return {?Array} Query items.\n */\nfunction getQueriedItemsUncached( state, query, options = {} ) {\n\tconst { supportsPagination = true } = options;\n\tconst {\n\t\tstableKey,\n\t\tpage,\n\t\tperPage,\n\t\toffset: queryOffset,\n\t\tinclude,\n\t\tfields,\n\t\tcontext,\n\t} = getQueryParts( query );\n\n\tconst itemIds = state.queries?.[ context ]?.[ stableKey ]?.itemIds;\n\tif ( ! itemIds ) {\n\t\treturn null;\n\t}\n\n\tconst isPaginated = supportsPagination && perPage !== -1;\n\tconst startOffset = isPaginated ? queryOffset ?? ( page - 1 ) * perPage : 0;\n\tconst endOffset = isPaginated\n\t\t? Math.min( startOffset + perPage, itemIds.length )\n\t\t: itemIds.length;\n\n\t// If the requested page range exceeds the stored itemIds, the data for\n\t// this specific pagination window may not have been fetched yet. Return\n\t// null unless totalItems confirms we already have all available items.\n\tif ( isPaginated && itemIds.length < startOffset + perPage ) {\n\t\tconst totalItems =\n\t\t\tstate.queries[ context ][ stableKey ].meta?.totalItems;\n\t\tif ( Number.isFinite( totalItems ) && itemIds.length < totalItems ) {\n\t\t\treturn null;\n\t\t}\n\t}\n\n\tconst items = [];\n\tfor ( let i = startOffset; i < endOffset; i++ ) {\n\t\tconst itemId = itemIds[ i ];\n\t\tif ( Array.isArray( include ) && ! include.includes( itemId ) ) {\n\t\t\tcontinue;\n\t\t}\n\t\tif ( itemId === undefined ) {\n\t\t\tcontinue;\n\t\t}\n\t\t// Having a target item ID doesn't guarantee that this object has been queried.\n\t\tif ( ! state.items[ context ]?.hasOwnProperty( itemId ) ) {\n\t\t\treturn null;\n\t\t}\n\n\t\tconst item = state.items[ context ][ itemId ];\n\n\t\tlet filteredItem;\n\t\tif ( Array.isArray( fields ) ) {\n\t\t\tfilteredItem = {};\n\n\t\t\tfor ( let f = 0; f < fields.length; f++ ) {\n\t\t\t\tconst field = fields[ f ].split( '.' );\n\t\t\t\tlet value = item;\n\t\t\t\tfield.forEach( ( fieldName ) => {\n\t\t\t\t\tvalue = value?.[ fieldName ];\n\t\t\t\t} );\n\n\t\t\t\tsetNestedValue( filteredItem, field, value );\n\t\t\t}\n\t\t} else {\n\t\t\t// If expecting a complete item, validate that completeness, or\n\t\t\t// otherwise abort.\n\t\t\tif ( ! state.itemIsComplete[ context ]?.[ itemId ] ) {\n\t\t\t\treturn null;\n\t\t\t}\n\n\t\t\tfilteredItem = item;\n\t\t}\n\n\t\titems.push( filteredItem );\n\t}\n\n\treturn items;\n}\n\n/**\n * Returns items for a given query, or null if the items are not known. Caches\n * result both per state (by reference) and per query (by deep equality).\n * The caching approach is intended to be durable to query objects which are\n * deeply but not referentially equal, since otherwise:\n *\n * `getQueriedItems( state, {} ) !== getQueriedItems( state, {} )`\n *\n * @param {Object}  state                      State object.\n * @param {?Object} query                      Optional query.\n * @param {?Object} options                    Optional pagination options.\n * @param {boolean} options.supportsPagination Whether the entity supports pagination. Default true.\n *\n * @return {?Array} Query items.\n */\nexport const getQueriedItems = createSelector(\n\t( state, query = {}, options = {} ) => {\n\t\tlet queriedItemsCache = queriedItemsCacheByState.get( state );\n\t\tif ( queriedItemsCache ) {\n\t\t\tconst queriedItems = queriedItemsCache.get( query );\n\t\t\tif ( queriedItems !== undefined ) {\n\t\t\t\treturn queriedItems;\n\t\t\t}\n\t\t} else {\n\t\t\tqueriedItemsCache = new EquivalentKeyMap();\n\t\t\tqueriedItemsCacheByState.set( state, queriedItemsCache );\n\t\t}\n\n\t\tconst items = getQueriedItemsUncached( state, query, options );\n\t\tqueriedItemsCache.set( query, items );\n\t\treturn items;\n\t}\n);\n\nexport function getQueriedTotalItems( state, query = {} ) {\n\tconst { stableKey, context } = getQueryParts( query );\n\n\treturn state.queries?.[ context ]?.[ stableKey ]?.meta?.totalItems ?? null;\n}\n\nexport function getQueriedTotalPages( state, query = {} ) {\n\tconst { stableKey, context } = getQueryParts( query );\n\n\treturn state.queries?.[ context ]?.[ stableKey ]?.meta?.totalPages ?? null;\n}\n"],
  "mappings": "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",
  "names": ["getQueryParts", "EquivalentKeyMap"]
}
