@graphql-box/connection-resolver 4.1.3 → 5.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -5
- package/dist/cjs/index.cjs +703 -0
- package/dist/cjs/index.cjs.map +1 -0
- package/dist/esm/index.mjs +700 -0
- package/dist/esm/index.mjs.map +1 -0
- package/dist/types/cjs/__testUtils__/generateCursorCache.d.cts +10 -0
- package/dist/types/cjs/__testUtils__/generateCursorCache.d.cts.map +1 -0
- package/dist/types/cjs/__testUtils__/generatePageResponse.d.cts +9 -0
- package/dist/types/cjs/__testUtils__/generatePageResponse.d.cts.map +1 -0
- package/dist/types/cjs/__testUtils__/generatePages.d.cts +2 -0
- package/dist/types/cjs/__testUtils__/generatePages.d.cts.map +1 -0
- package/dist/types/cjs/helpers/cacheCursors.d.cts +12 -0
- package/dist/types/cjs/helpers/cacheCursors.d.cts.map +1 -0
- package/dist/types/cjs/helpers/extractEdges.d.cts +3 -0
- package/dist/types/cjs/helpers/extractEdges.d.cts.map +1 -0
- package/dist/types/cjs/helpers/extractNodes.d.cts +3 -0
- package/dist/types/cjs/helpers/extractNodes.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getCount.d.cts +3 -0
- package/dist/types/cjs/helpers/getCount.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getCurrentPageStartAndEndIndexes.d.cts +14 -0
- package/dist/types/cjs/helpers/getCurrentPageStartAndEndIndexes.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getCursor.d.cts +3 -0
- package/dist/types/cjs/helpers/getCursor.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getDirection.d.cts +3 -0
- package/dist/types/cjs/helpers/getDirection.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getInRangeCachedEdges.d.cts +8 -0
- package/dist/types/cjs/helpers/getInRangeCachedEdges.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getIndexesOnCurrentPage.d.cts +10 -0
- package/dist/types/cjs/helpers/getIndexesOnCurrentPage.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getIndexesOnLastPage.d.cts +3 -0
- package/dist/types/cjs/helpers/getIndexesOnLastPage.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getPageNumbersToRequest.d.cts +12 -0
- package/dist/types/cjs/helpers/getPageNumbersToRequest.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getPagesMissingFromCache.d.cts +3 -0
- package/dist/types/cjs/helpers/getPagesMissingFromCache.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getResultsOnLastPage.d.cts +6 -0
- package/dist/types/cjs/helpers/getResultsOnLastPage.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getStartAndEndCursors.d.cts +4 -0
- package/dist/types/cjs/helpers/getStartAndEndCursors.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getStartAndEndIndexes.d.cts +15 -0
- package/dist/types/cjs/helpers/getStartAndEndIndexes.d.cts.map +1 -0
- package/dist/types/cjs/helpers/getStartAndEndPageNumbers.d.cts +13 -0
- package/dist/types/cjs/helpers/getStartAndEndPageNumbers.d.cts.map +1 -0
- package/dist/types/cjs/helpers/hasPreviousNextPage.d.cts +14 -0
- package/dist/types/cjs/helpers/hasPreviousNextPage.d.cts.map +1 -0
- package/dist/types/cjs/helpers/isCursorFirst.d.cts +7 -0
- package/dist/types/cjs/helpers/isCursorFirst.d.cts.map +1 -0
- package/dist/types/cjs/helpers/isCursorLast.d.cts +10 -0
- package/dist/types/cjs/helpers/isCursorLast.d.cts.map +1 -0
- package/dist/types/cjs/helpers/isCursorSupplied.d.cts +4 -0
- package/dist/types/cjs/helpers/isCursorSupplied.d.cts.map +1 -0
- package/dist/types/cjs/helpers/isFirstPage.d.cts +2 -0
- package/dist/types/cjs/helpers/isFirstPage.d.cts.map +1 -0
- package/dist/types/cjs/helpers/isLastPage.d.cts +6 -0
- package/dist/types/cjs/helpers/isLastPage.d.cts.map +1 -0
- package/dist/types/cjs/helpers/makeEdges.d.cts +6 -0
- package/dist/types/cjs/helpers/makeEdges.d.cts.map +1 -0
- package/dist/types/cjs/helpers/makeEntry.d.cts +10 -0
- package/dist/types/cjs/helpers/makeEntry.d.cts.map +1 -0
- package/dist/types/cjs/helpers/mergeCachedEdges.d.cts +3 -0
- package/dist/types/cjs/helpers/mergeCachedEdges.d.cts.map +1 -0
- package/dist/types/cjs/helpers/removeConnectionInputOptions.d.cts +2 -0
- package/dist/types/cjs/helpers/removeConnectionInputOptions.d.cts.map +1 -0
- package/dist/types/cjs/helpers/requestAndCachePages.d.cts +21 -0
- package/dist/types/cjs/helpers/requestAndCachePages.d.cts.map +1 -0
- package/dist/types/cjs/helpers/requestOutstandingPages.d.cts +18 -0
- package/dist/types/cjs/helpers/requestOutstandingPages.d.cts.map +1 -0
- package/dist/types/cjs/helpers/resolveConnection.d.cts +24 -0
- package/dist/types/cjs/helpers/resolveConnection.d.cts.map +1 -0
- package/dist/types/cjs/helpers/retrieveCachedConnection.d.cts +25 -0
- package/dist/types/cjs/helpers/retrieveCachedConnection.d.cts.map +1 -0
- package/dist/types/cjs/helpers/retrieveCachedEdgesByPage.d.cts +11 -0
- package/dist/types/cjs/helpers/retrieveCachedEdgesByPage.d.cts.map +1 -0
- package/dist/types/cjs/helpers/retrieveEntry.d.cts +8 -0
- package/dist/types/cjs/helpers/retrieveEntry.d.cts.map +1 -0
- package/dist/types/cjs/helpers/validateCursor.d.cts +10 -0
- package/dist/types/cjs/helpers/validateCursor.d.cts.map +1 -0
- package/dist/types/cjs/index.d.cts +4 -0
- package/dist/types/cjs/index.d.cts.map +1 -0
- package/dist/types/cjs/main/index.d.cts +5 -0
- package/dist/types/cjs/main/index.d.cts.map +1 -0
- package/{lib/types/defs/index.d.ts → dist/types/cjs/types.d.cts} +22 -27
- package/dist/types/cjs/types.d.cts.map +1 -0
- package/dist/types/esm/__testUtils__/generateCursorCache.d.ts +10 -0
- package/dist/types/esm/__testUtils__/generateCursorCache.d.ts.map +1 -0
- package/dist/types/esm/__testUtils__/generatePageResponse.d.ts +9 -0
- package/dist/types/esm/__testUtils__/generatePageResponse.d.ts.map +1 -0
- package/dist/types/esm/__testUtils__/generatePages.d.ts +2 -0
- package/dist/types/esm/__testUtils__/generatePages.d.ts.map +1 -0
- package/dist/types/esm/helpers/cacheCursors.d.ts +12 -0
- package/dist/types/esm/helpers/cacheCursors.d.ts.map +1 -0
- package/dist/types/esm/helpers/extractEdges.d.ts +3 -0
- package/dist/types/esm/helpers/extractEdges.d.ts.map +1 -0
- package/dist/types/esm/helpers/extractNodes.d.ts +3 -0
- package/dist/types/esm/helpers/extractNodes.d.ts.map +1 -0
- package/dist/types/esm/helpers/getCount.d.ts +3 -0
- package/dist/types/esm/helpers/getCount.d.ts.map +1 -0
- package/{lib/types → dist/types/esm}/helpers/getCurrentPageStartAndEndIndexes.d.ts +3 -3
- package/dist/types/esm/helpers/getCurrentPageStartAndEndIndexes.d.ts.map +1 -0
- package/dist/types/esm/helpers/getCursor.d.ts +3 -0
- package/dist/types/esm/helpers/getCursor.d.ts.map +1 -0
- package/dist/types/esm/helpers/getDirection.d.ts +3 -0
- package/dist/types/esm/helpers/getDirection.d.ts.map +1 -0
- package/dist/types/esm/helpers/getInRangeCachedEdges.d.ts +8 -0
- package/dist/types/esm/helpers/getInRangeCachedEdges.d.ts.map +1 -0
- package/dist/types/esm/helpers/getIndexesOnCurrentPage.d.ts +10 -0
- package/dist/types/esm/helpers/getIndexesOnCurrentPage.d.ts.map +1 -0
- package/dist/types/esm/helpers/getIndexesOnLastPage.d.ts +3 -0
- package/dist/types/esm/helpers/getIndexesOnLastPage.d.ts.map +1 -0
- package/dist/types/esm/helpers/getPageNumbersToRequest.d.ts +12 -0
- package/dist/types/esm/helpers/getPageNumbersToRequest.d.ts.map +1 -0
- package/dist/types/esm/helpers/getPagesMissingFromCache.d.ts +3 -0
- package/dist/types/esm/helpers/getPagesMissingFromCache.d.ts.map +1 -0
- package/dist/types/esm/helpers/getResultsOnLastPage.d.ts +6 -0
- package/dist/types/esm/helpers/getResultsOnLastPage.d.ts.map +1 -0
- package/dist/types/esm/helpers/getStartAndEndCursors.d.ts +4 -0
- package/dist/types/esm/helpers/getStartAndEndCursors.d.ts.map +1 -0
- package/dist/types/esm/helpers/getStartAndEndIndexes.d.ts +15 -0
- package/dist/types/esm/helpers/getStartAndEndIndexes.d.ts.map +1 -0
- package/dist/types/esm/helpers/getStartAndEndPageNumbers.d.ts +13 -0
- package/dist/types/esm/helpers/getStartAndEndPageNumbers.d.ts.map +1 -0
- package/{lib/types → dist/types/esm}/helpers/hasPreviousNextPage.d.ts +3 -3
- package/dist/types/esm/helpers/hasPreviousNextPage.d.ts.map +1 -0
- package/dist/types/esm/helpers/isCursorFirst.d.ts +7 -0
- package/dist/types/esm/helpers/isCursorFirst.d.ts.map +1 -0
- package/dist/types/esm/helpers/isCursorLast.d.ts +10 -0
- package/dist/types/esm/helpers/isCursorLast.d.ts.map +1 -0
- package/dist/types/esm/helpers/isCursorSupplied.d.ts +4 -0
- package/dist/types/esm/helpers/isCursorSupplied.d.ts.map +1 -0
- package/dist/types/esm/helpers/isFirstPage.d.ts +2 -0
- package/dist/types/esm/helpers/isFirstPage.d.ts.map +1 -0
- package/dist/types/esm/helpers/isLastPage.d.ts +6 -0
- package/dist/types/esm/helpers/isLastPage.d.ts.map +1 -0
- package/dist/types/esm/helpers/makeEdges.d.ts +6 -0
- package/dist/types/esm/helpers/makeEdges.d.ts.map +1 -0
- package/dist/types/esm/helpers/makeEntry.d.ts +10 -0
- package/dist/types/esm/helpers/makeEntry.d.ts.map +1 -0
- package/dist/types/esm/helpers/mergeCachedEdges.d.ts +3 -0
- package/dist/types/esm/helpers/mergeCachedEdges.d.ts.map +1 -0
- package/dist/types/esm/helpers/removeConnectionInputOptions.d.ts +2 -0
- package/dist/types/esm/helpers/removeConnectionInputOptions.d.ts.map +1 -0
- package/dist/types/esm/helpers/requestAndCachePages.d.ts +21 -0
- package/dist/types/esm/helpers/requestAndCachePages.d.ts.map +1 -0
- package/dist/types/esm/helpers/requestOutstandingPages.d.ts +18 -0
- package/dist/types/esm/helpers/requestOutstandingPages.d.ts.map +1 -0
- package/dist/types/esm/helpers/resolveConnection.d.ts +24 -0
- package/dist/types/esm/helpers/resolveConnection.d.ts.map +1 -0
- package/{lib/types → dist/types/esm}/helpers/retrieveCachedConnection.d.ts +5 -6
- package/dist/types/esm/helpers/retrieveCachedConnection.d.ts.map +1 -0
- package/dist/types/esm/helpers/retrieveCachedEdgesByPage.d.ts +11 -0
- package/dist/types/esm/helpers/retrieveCachedEdgesByPage.d.ts.map +1 -0
- package/dist/types/esm/helpers/retrieveEntry.d.ts +8 -0
- package/dist/types/esm/helpers/retrieveEntry.d.ts.map +1 -0
- package/dist/types/esm/helpers/validateCursor.d.ts +10 -0
- package/dist/types/esm/helpers/validateCursor.d.ts.map +1 -0
- package/dist/types/esm/index.d.ts +4 -0
- package/dist/types/esm/index.d.ts.map +1 -0
- package/dist/types/esm/main/index.d.ts +5 -0
- package/dist/types/esm/main/index.d.ts.map +1 -0
- package/dist/types/esm/types.d.ts +77 -0
- package/dist/types/esm/types.d.ts.map +1 -0
- package/dist/types/tsconfig.build.tsbuildinfo +1 -0
- package/package.json +54 -38
- package/src/__testUtils__/generateCursorCache.ts +20 -14
- package/src/__testUtils__/generatePageResponse.ts +17 -12
- package/src/__testUtils__/generatePages.ts +5 -5
- package/src/helpers/cacheCursors.ts +10 -7
- package/src/helpers/extractEdges.ts +3 -3
- package/src/helpers/extractNodes.ts +2 -2
- package/src/helpers/getCount.test.ts +10 -6
- package/src/helpers/getCount.ts +2 -2
- package/src/helpers/getCurrentPageStartAndEndIndexes.ts +1 -1
- package/src/helpers/getCursor.test.ts +10 -6
- package/src/helpers/getCursor.ts +2 -2
- package/src/helpers/getDirection.test.ts +10 -6
- package/src/helpers/getDirection.ts +3 -1
- package/src/helpers/getInRangeCachedEdges.ts +10 -7
- package/src/helpers/getIndexesOnCurrentPage.test.ts +14 -10
- package/src/helpers/getIndexesOnCurrentPage.ts +11 -6
- package/src/helpers/getIndexesOnLastPage.test.ts +10 -6
- package/src/helpers/getIndexesOnLastPage.ts +3 -2
- package/src/helpers/getPageNumbersToRequest.test.ts +15 -11
- package/src/helpers/getPageNumbersToRequest.ts +17 -6
- package/src/helpers/getPagesMissingFromCache.ts +5 -5
- package/src/helpers/getResultsOnLastPage.test.ts +10 -6
- package/src/helpers/getResultsOnLastPage.ts +1 -1
- package/src/helpers/getStartAndEndCursors.ts +1 -1
- package/src/helpers/getStartAndEndIndexes.test.ts +77 -57
- package/src/helpers/getStartAndEndIndexes.ts +28 -22
- package/src/helpers/getStartAndEndPageNumbers.test.ts +46 -28
- package/src/helpers/getStartAndEndPageNumbers.ts +12 -12
- package/src/helpers/hasPreviousNextPage.test.ts +17 -8
- package/src/helpers/hasPreviousNextPage.ts +6 -4
- package/src/helpers/isCursorFirst.test.ts +13 -7
- package/src/helpers/isCursorFirst.ts +3 -2
- package/src/helpers/isCursorLast.test.ts +27 -23
- package/src/helpers/isCursorLast.ts +4 -4
- package/src/helpers/isCursorSupplied.test.ts +18 -10
- package/src/helpers/isCursorSupplied.ts +3 -2
- package/src/helpers/isFirstPage.test.ts +10 -6
- package/src/helpers/isFirstPage.ts +1 -1
- package/src/helpers/isLastPage.test.ts +10 -6
- package/src/helpers/isLastPage.ts +1 -1
- package/src/helpers/makeEdges.ts +3 -3
- package/src/helpers/makeEntry.ts +8 -5
- package/src/helpers/mergeCachedEdges.ts +5 -5
- package/src/helpers/removeConnectionInputOptions.test.ts +10 -8
- package/src/helpers/removeConnectionInputOptions.ts +4 -3
- package/src/helpers/requestAndCachePages.ts +14 -11
- package/src/helpers/requestOutstandingPages.ts +18 -19
- package/src/helpers/resolveConnection.ts +20 -34
- package/src/helpers/retrieveCachedConnection.test.ts +703 -338
- package/src/helpers/retrieveCachedConnection.ts +28 -20
- package/src/helpers/retrieveCachedEdgesByPage.ts +10 -10
- package/src/helpers/retrieveEntry.ts +32 -0
- package/src/helpers/validateCursor.test.ts +88 -61
- package/src/helpers/validateCursor.ts +30 -26
- package/src/index.ts +3 -3
- package/src/main/__snapshots__/index.test.ts.snap +258 -258
- package/src/main/index.test.ts +405 -287
- package/src/main/index.ts +37 -35
- package/src/{defs/index.ts → types.ts} +12 -18
- package/tsconfig.build.json +10 -0
- package/tsconfig.json +11 -0
- package/lib/browser/index.js +0 -2
- package/lib/browser/index.js.map +0 -1
- package/lib/browser/production.analysis.txt +0 -314
- package/lib/main/__testUtils__/generateCursorCache.js +0 -88
- package/lib/main/__testUtils__/generateCursorCache.js.map +0 -1
- package/lib/main/__testUtils__/generatePageResponse.js +0 -33
- package/lib/main/__testUtils__/generatePageResponse.js.map +0 -1
- package/lib/main/__testUtils__/generatePages.js +0 -23
- package/lib/main/__testUtils__/generatePages.js.map +0 -1
- package/lib/main/defs/index.js +0 -2
- package/lib/main/defs/index.js.map +0 -1
- package/lib/main/helpers/cacheCursors.js +0 -40
- package/lib/main/helpers/cacheCursors.js.map +0 -1
- package/lib/main/helpers/extractEdges.js +0 -11
- package/lib/main/helpers/extractEdges.js.map +0 -1
- package/lib/main/helpers/extractNodes.js +0 -11
- package/lib/main/helpers/extractNodes.js.map +0 -1
- package/lib/main/helpers/getCount.js +0 -14
- package/lib/main/helpers/getCount.js.map +0 -1
- package/lib/main/helpers/getCurrentPageStartAndEndIndexes.js +0 -23
- package/lib/main/helpers/getCurrentPageStartAndEndIndexes.js.map +0 -1
- package/lib/main/helpers/getCursor.js +0 -14
- package/lib/main/helpers/getCursor.js.map +0 -1
- package/lib/main/helpers/getDirection.js +0 -11
- package/lib/main/helpers/getDirection.js.map +0 -1
- package/lib/main/helpers/getInRangeCachedEdges.js +0 -36
- package/lib/main/helpers/getInRangeCachedEdges.js.map +0 -1
- package/lib/main/helpers/getIndexesOnCurrentPage.js +0 -30
- package/lib/main/helpers/getIndexesOnCurrentPage.js.map +0 -1
- package/lib/main/helpers/getIndexesOnLastPage.js +0 -21
- package/lib/main/helpers/getIndexesOnLastPage.js.map +0 -1
- package/lib/main/helpers/getPageNumbersToRequest.js +0 -43
- package/lib/main/helpers/getPageNumbersToRequest.js.map +0 -1
- package/lib/main/helpers/getPagesMissingFromCache.js +0 -19
- package/lib/main/helpers/getPagesMissingFromCache.js.map +0 -1
- package/lib/main/helpers/getResultsOnLastPage.js +0 -17
- package/lib/main/helpers/getResultsOnLastPage.js.map +0 -1
- package/lib/main/helpers/getStartAndEndCursors.js +0 -22
- package/lib/main/helpers/getStartAndEndCursors.js.map +0 -1
- package/lib/main/helpers/getStartAndEndIndexes.js +0 -105
- package/lib/main/helpers/getStartAndEndIndexes.js.map +0 -1
- package/lib/main/helpers/getStartAndEndPageNumbers.js +0 -51
- package/lib/main/helpers/getStartAndEndPageNumbers.js.map +0 -1
- package/lib/main/helpers/hasPreviousNextPage.js +0 -33
- package/lib/main/helpers/hasPreviousNextPage.js.map +0 -1
- package/lib/main/helpers/isCursorFirst.js +0 -17
- package/lib/main/helpers/isCursorFirst.js.map +0 -1
- package/lib/main/helpers/isCursorLast.js +0 -27
- package/lib/main/helpers/isCursorLast.js.map +0 -1
- package/lib/main/helpers/isCursorSupplied.js +0 -14
- package/lib/main/helpers/isCursorSupplied.js.map +0 -1
- package/lib/main/helpers/isFirstPage.js +0 -11
- package/lib/main/helpers/isFirstPage.js.map +0 -1
- package/lib/main/helpers/isLastPage.js +0 -14
- package/lib/main/helpers/isLastPage.js.map +0 -1
- package/lib/main/helpers/makeEdges.js +0 -14
- package/lib/main/helpers/makeEdges.js.map +0 -1
- package/lib/main/helpers/makeEntry.js +0 -38
- package/lib/main/helpers/makeEntry.js.map +0 -1
- package/lib/main/helpers/mergeCachedEdges.js +0 -21
- package/lib/main/helpers/mergeCachedEdges.js.map +0 -1
- package/lib/main/helpers/removeConnectionInputOptions.js +0 -17
- package/lib/main/helpers/removeConnectionInputOptions.js.map +0 -1
- package/lib/main/helpers/requestAndCachePages.js +0 -66
- package/lib/main/helpers/requestAndCachePages.js.map +0 -1
- package/lib/main/helpers/requestOutstandingPages.js +0 -67
- package/lib/main/helpers/requestOutstandingPages.js.map +0 -1
- package/lib/main/helpers/resolveConnection.js +0 -95
- package/lib/main/helpers/resolveConnection.js.map +0 -1
- package/lib/main/helpers/retrieveCachedConnection.js +0 -90
- package/lib/main/helpers/retrieveCachedConnection.js.map +0 -1
- package/lib/main/helpers/retrieveCachedEdgesByPage.js +0 -45
- package/lib/main/helpers/retrieveCachedEdgesByPage.js.map +0 -1
- package/lib/main/helpers/validateCursor.js +0 -88
- package/lib/main/helpers/validateCursor.js.map +0 -1
- package/lib/main/index.js +0 -52
- package/lib/main/index.js.map +0 -1
- package/lib/main/main/index.js +0 -100
- package/lib/main/main/index.js.map +0 -1
- package/lib/module/__testUtils__/generateCursorCache.js +0 -71
- package/lib/module/__testUtils__/generateCursorCache.js.map +0 -1
- package/lib/module/__testUtils__/generatePageResponse.js +0 -23
- package/lib/module/__testUtils__/generatePageResponse.js.map +0 -1
- package/lib/module/__testUtils__/generatePages.js +0 -11
- package/lib/module/__testUtils__/generatePages.js.map +0 -1
- package/lib/module/defs/index.js +0 -2
- package/lib/module/defs/index.js.map +0 -1
- package/lib/module/helpers/cacheCursors.js +0 -30
- package/lib/module/helpers/cacheCursors.js.map +0 -1
- package/lib/module/helpers/extractEdges.js +0 -2
- package/lib/module/helpers/extractEdges.js.map +0 -1
- package/lib/module/helpers/extractNodes.js +0 -2
- package/lib/module/helpers/extractNodes.js.map +0 -1
- package/lib/module/helpers/getCount.js +0 -5
- package/lib/module/helpers/getCount.js.map +0 -1
- package/lib/module/helpers/getCurrentPageStartAndEndIndexes.js +0 -11
- package/lib/module/helpers/getCurrentPageStartAndEndIndexes.js.map +0 -1
- package/lib/module/helpers/getCursor.js +0 -5
- package/lib/module/helpers/getCursor.js.map +0 -1
- package/lib/module/helpers/getDirection.js +0 -2
- package/lib/module/helpers/getDirection.js.map +0 -1
- package/lib/module/helpers/getInRangeCachedEdges.js +0 -26
- package/lib/module/helpers/getInRangeCachedEdges.js.map +0 -1
- package/lib/module/helpers/getIndexesOnCurrentPage.js +0 -17
- package/lib/module/helpers/getIndexesOnCurrentPage.js.map +0 -1
- package/lib/module/helpers/getIndexesOnLastPage.js +0 -9
- package/lib/module/helpers/getIndexesOnLastPage.js.map +0 -1
- package/lib/module/helpers/getPageNumbersToRequest.js +0 -30
- package/lib/module/helpers/getPageNumbersToRequest.js.map +0 -1
- package/lib/module/helpers/getPagesMissingFromCache.js +0 -10
- package/lib/module/helpers/getPagesMissingFromCache.js.map +0 -1
- package/lib/module/helpers/getResultsOnLastPage.js +0 -8
- package/lib/module/helpers/getResultsOnLastPage.js.map +0 -1
- package/lib/module/helpers/getStartAndEndCursors.js +0 -10
- package/lib/module/helpers/getStartAndEndCursors.js.map +0 -1
- package/lib/module/helpers/getStartAndEndIndexes.js +0 -86
- package/lib/module/helpers/getStartAndEndIndexes.js.map +0 -1
- package/lib/module/helpers/getStartAndEndPageNumbers.js +0 -35
- package/lib/module/helpers/getStartAndEndPageNumbers.js.map +0 -1
- package/lib/module/helpers/hasPreviousNextPage.js +0 -18
- package/lib/module/helpers/hasPreviousNextPage.js.map +0 -1
- package/lib/module/helpers/isCursorFirst.js +0 -8
- package/lib/module/helpers/isCursorFirst.js.map +0 -1
- package/lib/module/helpers/isCursorLast.js +0 -15
- package/lib/module/helpers/isCursorLast.js.map +0 -1
- package/lib/module/helpers/isCursorSupplied.js +0 -5
- package/lib/module/helpers/isCursorSupplied.js.map +0 -1
- package/lib/module/helpers/isFirstPage.js +0 -2
- package/lib/module/helpers/isFirstPage.js.map +0 -1
- package/lib/module/helpers/isLastPage.js +0 -5
- package/lib/module/helpers/isLastPage.js.map +0 -1
- package/lib/module/helpers/makeEdges.js +0 -5
- package/lib/module/helpers/makeEdges.js.map +0 -1
- package/lib/module/helpers/makeEntry.js +0 -25
- package/lib/module/helpers/makeEntry.js.map +0 -1
- package/lib/module/helpers/mergeCachedEdges.js +0 -12
- package/lib/module/helpers/mergeCachedEdges.js.map +0 -1
- package/lib/module/helpers/removeConnectionInputOptions.js +0 -4
- package/lib/module/helpers/removeConnectionInputOptions.js.map +0 -1
- package/lib/module/helpers/requestAndCachePages.js +0 -54
- package/lib/module/helpers/requestAndCachePages.js.map +0 -1
- package/lib/module/helpers/requestOutstandingPages.js +0 -57
- package/lib/module/helpers/requestOutstandingPages.js.map +0 -1
- package/lib/module/helpers/resolveConnection.js +0 -78
- package/lib/module/helpers/resolveConnection.js.map +0 -1
- package/lib/module/helpers/retrieveCachedConnection.js +0 -70
- package/lib/module/helpers/retrieveCachedConnection.js.map +0 -1
- package/lib/module/helpers/retrieveCachedEdgesByPage.js +0 -35
- package/lib/module/helpers/retrieveCachedEdgesByPage.js.map +0 -1
- package/lib/module/helpers/validateCursor.js +0 -71
- package/lib/module/helpers/validateCursor.js.map +0 -1
- package/lib/module/index.js +0 -4
- package/lib/module/index.js.map +0 -1
- package/lib/module/main/index.js +0 -83
- package/lib/module/main/index.js.map +0 -1
- package/lib/types/__testUtils__/generateCursorCache.d.ts +0 -11
- package/lib/types/__testUtils__/generateCursorCache.d.ts.map +0 -1
- package/lib/types/__testUtils__/generatePageResponse.d.ts +0 -18
- package/lib/types/__testUtils__/generatePageResponse.d.ts.map +0 -1
- package/lib/types/__testUtils__/generatePages.d.ts +0 -3
- package/lib/types/__testUtils__/generatePages.d.ts.map +0 -1
- package/lib/types/defs/index.d.ts.map +0 -1
- package/lib/types/helpers/cacheCursors.d.ts +0 -13
- package/lib/types/helpers/cacheCursors.d.ts.map +0 -1
- package/lib/types/helpers/extractEdges.d.ts +0 -4
- package/lib/types/helpers/extractEdges.d.ts.map +0 -1
- package/lib/types/helpers/extractNodes.d.ts +0 -4
- package/lib/types/helpers/extractNodes.d.ts.map +0 -1
- package/lib/types/helpers/getCount.d.ts +0 -4
- package/lib/types/helpers/getCount.d.ts.map +0 -1
- package/lib/types/helpers/getCount.test.d.ts +0 -2
- package/lib/types/helpers/getCount.test.d.ts.map +0 -1
- package/lib/types/helpers/getCurrentPageStartAndEndIndexes.d.ts.map +0 -1
- package/lib/types/helpers/getCursor.d.ts +0 -4
- package/lib/types/helpers/getCursor.d.ts.map +0 -1
- package/lib/types/helpers/getCursor.test.d.ts +0 -2
- package/lib/types/helpers/getCursor.test.d.ts.map +0 -1
- package/lib/types/helpers/getDirection.d.ts +0 -3
- package/lib/types/helpers/getDirection.d.ts.map +0 -1
- package/lib/types/helpers/getDirection.test.d.ts +0 -2
- package/lib/types/helpers/getDirection.test.d.ts.map +0 -1
- package/lib/types/helpers/getInRangeCachedEdges.d.ts +0 -9
- package/lib/types/helpers/getInRangeCachedEdges.d.ts.map +0 -1
- package/lib/types/helpers/getIndexesOnCurrentPage.d.ts +0 -7
- package/lib/types/helpers/getIndexesOnCurrentPage.d.ts.map +0 -1
- package/lib/types/helpers/getIndexesOnCurrentPage.test.d.ts +0 -2
- package/lib/types/helpers/getIndexesOnCurrentPage.test.d.ts.map +0 -1
- package/lib/types/helpers/getIndexesOnLastPage.d.ts +0 -4
- package/lib/types/helpers/getIndexesOnLastPage.d.ts.map +0 -1
- package/lib/types/helpers/getIndexesOnLastPage.test.d.ts +0 -2
- package/lib/types/helpers/getIndexesOnLastPage.test.d.ts.map +0 -1
- package/lib/types/helpers/getPageNumbersToRequest.d.ts +0 -8
- package/lib/types/helpers/getPageNumbersToRequest.d.ts.map +0 -1
- package/lib/types/helpers/getPageNumbersToRequest.test.d.ts +0 -2
- package/lib/types/helpers/getPageNumbersToRequest.test.d.ts.map +0 -1
- package/lib/types/helpers/getPagesMissingFromCache.d.ts +0 -4
- package/lib/types/helpers/getPagesMissingFromCache.d.ts.map +0 -1
- package/lib/types/helpers/getResultsOnLastPage.d.ts +0 -7
- package/lib/types/helpers/getResultsOnLastPage.d.ts.map +0 -1
- package/lib/types/helpers/getResultsOnLastPage.test.d.ts +0 -2
- package/lib/types/helpers/getResultsOnLastPage.test.d.ts.map +0 -1
- package/lib/types/helpers/getStartAndEndCursors.d.ts +0 -4
- package/lib/types/helpers/getStartAndEndCursors.d.ts.map +0 -1
- package/lib/types/helpers/getStartAndEndIndexes.d.ts +0 -10
- package/lib/types/helpers/getStartAndEndIndexes.d.ts.map +0 -1
- package/lib/types/helpers/getStartAndEndIndexes.test.d.ts +0 -2
- package/lib/types/helpers/getStartAndEndIndexes.test.d.ts.map +0 -1
- package/lib/types/helpers/getStartAndEndPageNumbers.d.ts +0 -9
- package/lib/types/helpers/getStartAndEndPageNumbers.d.ts.map +0 -1
- package/lib/types/helpers/getStartAndEndPageNumbers.test.d.ts +0 -2
- package/lib/types/helpers/getStartAndEndPageNumbers.test.d.ts.map +0 -1
- package/lib/types/helpers/hasPreviousNextPage.d.ts.map +0 -1
- package/lib/types/helpers/hasPreviousNextPage.test.d.ts +0 -2
- package/lib/types/helpers/hasPreviousNextPage.test.d.ts.map +0 -1
- package/lib/types/helpers/isCursorFirst.d.ts +0 -8
- package/lib/types/helpers/isCursorFirst.d.ts.map +0 -1
- package/lib/types/helpers/isCursorFirst.test.d.ts +0 -2
- package/lib/types/helpers/isCursorFirst.test.d.ts.map +0 -1
- package/lib/types/helpers/isCursorLast.d.ts +0 -11
- package/lib/types/helpers/isCursorLast.d.ts.map +0 -1
- package/lib/types/helpers/isCursorLast.test.d.ts +0 -2
- package/lib/types/helpers/isCursorLast.test.d.ts.map +0 -1
- package/lib/types/helpers/isCursorSupplied.d.ts +0 -4
- package/lib/types/helpers/isCursorSupplied.d.ts.map +0 -1
- package/lib/types/helpers/isCursorSupplied.test.d.ts +0 -2
- package/lib/types/helpers/isCursorSupplied.test.d.ts.map +0 -1
- package/lib/types/helpers/isFirstPage.d.ts +0 -3
- package/lib/types/helpers/isFirstPage.d.ts.map +0 -1
- package/lib/types/helpers/isFirstPage.test.d.ts +0 -2
- package/lib/types/helpers/isFirstPage.test.d.ts.map +0 -1
- package/lib/types/helpers/isLastPage.d.ts +0 -7
- package/lib/types/helpers/isLastPage.d.ts.map +0 -1
- package/lib/types/helpers/isLastPage.test.d.ts +0 -2
- package/lib/types/helpers/isLastPage.test.d.ts.map +0 -1
- package/lib/types/helpers/makeEdges.d.ts +0 -7
- package/lib/types/helpers/makeEdges.d.ts.map +0 -1
- package/lib/types/helpers/makeEntry.d.ts +0 -11
- package/lib/types/helpers/makeEntry.d.ts.map +0 -1
- package/lib/types/helpers/mergeCachedEdges.d.ts +0 -4
- package/lib/types/helpers/mergeCachedEdges.d.ts.map +0 -1
- package/lib/types/helpers/removeConnectionInputOptions.d.ts +0 -3
- package/lib/types/helpers/removeConnectionInputOptions.d.ts.map +0 -1
- package/lib/types/helpers/removeConnectionInputOptions.test.d.ts +0 -2
- package/lib/types/helpers/removeConnectionInputOptions.test.d.ts.map +0 -1
- package/lib/types/helpers/requestAndCachePages.d.ts +0 -21
- package/lib/types/helpers/requestAndCachePages.d.ts.map +0 -1
- package/lib/types/helpers/requestOutstandingPages.d.ts +0 -18
- package/lib/types/helpers/requestOutstandingPages.d.ts.map +0 -1
- package/lib/types/helpers/resolveConnection.d.ts +0 -24
- package/lib/types/helpers/resolveConnection.d.ts.map +0 -1
- package/lib/types/helpers/retrieveCachedConnection.d.ts.map +0 -1
- package/lib/types/helpers/retrieveCachedConnection.test.d.ts +0 -2
- package/lib/types/helpers/retrieveCachedConnection.test.d.ts.map +0 -1
- package/lib/types/helpers/retrieveCachedEdgesByPage.d.ts +0 -12
- package/lib/types/helpers/retrieveCachedEdgesByPage.d.ts.map +0 -1
- package/lib/types/helpers/validateCursor.d.ts +0 -11
- package/lib/types/helpers/validateCursor.d.ts.map +0 -1
- package/lib/types/helpers/validateCursor.test.d.ts +0 -2
- package/lib/types/helpers/validateCursor.test.d.ts.map +0 -1
- package/lib/types/index.d.ts +0 -4
- package/lib/types/index.d.ts.map +0 -1
- package/lib/types/main/index.d.ts +0 -5
- package/lib/types/main/index.d.ts.map +0 -1
- package/lib/types/main/index.test.d.ts +0 -2
- package/lib/types/main/index.test.d.ts.map +0 -1
- package/package-lock.json +0 -18
package/package.json
CHANGED
@@ -1,52 +1,68 @@
|
|
1
1
|
{
|
2
2
|
"name": "@graphql-box/connection-resolver",
|
3
|
-
"
|
4
|
-
"
|
5
|
-
"
|
6
|
-
|
7
|
-
"graphql",
|
8
|
-
"client",
|
9
|
-
"server",
|
10
|
-
"isomorphic"
|
11
|
-
],
|
3
|
+
"description": "The GraphQL Box connection resolver module.",
|
4
|
+
"version": "5.0.0",
|
5
|
+
"author": "Dylan Aubrey",
|
6
|
+
"license": "MIT",
|
12
7
|
"homepage": "https://github.com/badbatch/graphql-box",
|
13
|
-
"bugs": {
|
14
|
-
"url": "https://github.com/badbatch/graphql-box/issues"
|
15
|
-
},
|
16
8
|
"repository": {
|
9
|
+
"directory": "packages/connection-resolver",
|
17
10
|
"type": "git",
|
18
|
-
"url": "https://github.com/badbatch/graphql-box"
|
19
|
-
|
11
|
+
"url": "https://github.com/badbatch/graphql-box"
|
12
|
+
},
|
13
|
+
"bugs": "https://github.com/badbatch/graphql-box/issues",
|
14
|
+
"type": "module",
|
15
|
+
"main": "./dist/cjs/index.cjs",
|
16
|
+
"module": "./dist/esm/index.mjs",
|
17
|
+
"types": "./dist/types/cjs/index.d.cts",
|
18
|
+
"exports": {
|
19
|
+
"types": {
|
20
|
+
"import": "./dist/types/esm/index.d.ts",
|
21
|
+
"require": "./dist/types/cjs/index.d.cts"
|
22
|
+
},
|
23
|
+
"import": "./dist/esm/index.mjs",
|
24
|
+
"require": "./dist/cjs/index.cjs"
|
20
25
|
},
|
21
26
|
"publishConfig": {
|
22
27
|
"access": "public"
|
23
28
|
},
|
24
|
-
"license": "MIT",
|
25
|
-
"author": "Dylan Aubrey <dylanaubrey@gmail.com>",
|
26
|
-
"main": "lib/main/index.js",
|
27
|
-
"module": "lib/module/index.js",
|
28
|
-
"browser": "lib/browser/index.js",
|
29
|
-
"types": "lib/types/index.d.ts",
|
30
|
-
"scripts": {
|
31
|
-
"compile": "concurrently npm:compile:*",
|
32
|
-
"compile-watch": "concurrently npm:compile-watch:*",
|
33
|
-
"compile-watch:main": "yarn run compile:main --watch",
|
34
|
-
"compile-watch:types": "yarn run compile:types --watch",
|
35
|
-
"compile:browser": "cross-env BABEL_ENV=browser rollup -c ../../rollup.config.js",
|
36
|
-
"compile:main": "cross-env BABEL_ENV=main babel ./src --out-dir ./lib/main --extensions \".ts\" --source-maps --config-file ../../babel.config.js",
|
37
|
-
"compile:module": "cross-env BABEL_ENV=module babel ./src --out-dir ./lib/module --extensions \".ts\" --source-maps --config-file ../../babel.config.js",
|
38
|
-
"compile:types": "tsc --build",
|
39
|
-
"docs": "typedoc --includes ./src/main --out ./docs --options ../../typedoc.js"
|
40
|
-
},
|
41
29
|
"dependencies": {
|
42
|
-
"
|
43
|
-
"
|
30
|
+
"@cachemap/core": "^5.0.6",
|
31
|
+
"js-base64": "^3.7.5",
|
32
|
+
"type-fest": "^4.5.0",
|
33
|
+
"@graphql-box/core": "5.0.0"
|
44
34
|
},
|
45
35
|
"peerDependencies": {
|
46
|
-
"@babel/runtime": "<
|
47
|
-
"
|
48
|
-
"
|
49
|
-
"
|
50
|
-
|
36
|
+
"@babel/runtime": "<8",
|
37
|
+
"core-js": "<4",
|
38
|
+
"graphql": "<17",
|
39
|
+
"lodash-es": "<5"
|
40
|
+
},
|
41
|
+
"devDependencies": {
|
42
|
+
"@babel/runtime": "^7.20.13",
|
43
|
+
"@cachemap/map": "^5.0.4",
|
44
|
+
"@jest/globals": "^29.3.1",
|
45
|
+
"@types/lodash-es": "^4.14.191",
|
46
|
+
"core-js": "^3.27.2",
|
47
|
+
"cts-types": "^0.0.5",
|
48
|
+
"del-cli": "^5.1.0",
|
49
|
+
"graphql": "^16.8.1",
|
50
|
+
"lodash-es": "^4.17.21"
|
51
|
+
},
|
52
|
+
"keywords": [
|
53
|
+
"client",
|
54
|
+
"graphql",
|
55
|
+
"graphql-box",
|
56
|
+
"isomorphic",
|
57
|
+
"server"
|
58
|
+
],
|
59
|
+
"scripts": {
|
60
|
+
"build": "pnpm run clean:dist && pnpm run compile",
|
61
|
+
"clean:deps": "del-cli ./node_modules",
|
62
|
+
"clean:dist": "del-cli ./dist",
|
63
|
+
"compile": "pnpm run /^compile:.*/",
|
64
|
+
"compile:cjs": "MODULE_SYSTEM=cjs rollup -c ../../rollup.config.cjs",
|
65
|
+
"compile:esm": "rollup -c ../../rollup.config.cjs",
|
66
|
+
"compile:types": "tsc --project ./tsconfig.build.json && cts-types build dist/types/esm dist/types/cjs"
|
51
67
|
}
|
52
68
|
}
|
@@ -1,8 +1,8 @@
|
|
1
|
-
import
|
2
|
-
import map from
|
3
|
-
import { encode } from
|
4
|
-
import cacheCursors from
|
5
|
-
import generatePages from
|
1
|
+
import { Core } from '@cachemap/core';
|
2
|
+
import { init as map } from '@cachemap/map';
|
3
|
+
import { encode } from 'js-base64';
|
4
|
+
import { cacheCursors } from '../helpers/cacheCursors.ts';
|
5
|
+
import { generatePages } from './generatePages.ts';
|
6
6
|
|
7
7
|
export type Params = {
|
8
8
|
group: string;
|
@@ -12,16 +12,22 @@ export type Params = {
|
|
12
12
|
totalResults: number;
|
13
13
|
};
|
14
14
|
|
15
|
-
export
|
16
|
-
|
17
|
-
|
15
|
+
export const generateCursorCache = async ({
|
16
|
+
group,
|
17
|
+
pageRanges = [],
|
18
|
+
resultsPerPage,
|
19
|
+
totalPages,
|
20
|
+
totalResults,
|
21
|
+
}: Params) => {
|
22
|
+
const cursorCache = new Core({
|
23
|
+
name: 'cursorCache',
|
18
24
|
store: map(),
|
19
|
-
type:
|
25
|
+
type: 'someType',
|
20
26
|
});
|
21
27
|
|
22
|
-
const headers = new Headers({
|
28
|
+
const headers = new Headers({ 'Cache-Control': 'max-age=60' });
|
23
29
|
|
24
|
-
if (pageRanges.length && resultsPerPage) {
|
30
|
+
if (pageRanges.length > 0 && resultsPerPage) {
|
25
31
|
const pages = generatePages(pageRanges);
|
26
32
|
|
27
33
|
await Promise.all(
|
@@ -36,19 +42,19 @@ export default async ({ group, pageRanges = [], resultsPerPage, totalPages, tota
|
|
36
42
|
resultsOnCurrentPage = resultsPerPage;
|
37
43
|
}
|
38
44
|
|
39
|
-
const edges = Array.from({ length: resultsOnCurrentPage }, (_v,
|
45
|
+
const edges = Array.from({ length: resultsOnCurrentPage }, (_v, index) => index).map(index => {
|
40
46
|
const id = encode(`${index}::${page}`);
|
41
47
|
return { cursor: `${id}::${group}`, node: { id } };
|
42
48
|
});
|
43
49
|
|
44
50
|
await cacheCursors(cursorCache, { edges, group, headers, page, totalPages, totalResults });
|
45
|
-
})
|
51
|
+
})
|
46
52
|
);
|
47
53
|
} else {
|
48
54
|
await cursorCache.set(
|
49
55
|
`${group}-metadata`,
|
50
56
|
{ totalPages, totalResults },
|
51
|
-
{ cacheHeaders: { cacheControl: headers.get(
|
57
|
+
{ cacheHeaders: { cacheControl: headers.get('cache-control') ?? undefined } }
|
52
58
|
);
|
53
59
|
}
|
54
60
|
|
@@ -1,4 +1,6 @@
|
|
1
|
-
import {
|
1
|
+
import type { PlainObject } from '@graphql-box/core';
|
2
|
+
import { encode } from 'js-base64';
|
3
|
+
import type { ResourceResponse } from '../types.ts';
|
2
4
|
|
3
5
|
export type Params = {
|
4
6
|
resultsPerPage: number;
|
@@ -6,14 +8,17 @@ export type Params = {
|
|
6
8
|
totalResults: number;
|
7
9
|
};
|
8
10
|
|
9
|
-
export
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
11
|
+
export const generatePageResponse =
|
12
|
+
({ resultsPerPage, totalPages, totalResults }: Params) =>
|
13
|
+
(page: number) =>
|
14
|
+
Promise.resolve({
|
15
|
+
data: {
|
16
|
+
page,
|
17
|
+
results: Array.from({ length: resultsPerPage }, (_v, index) => index).map(index => {
|
18
|
+
return { id: encode(`${index}::${page}`) };
|
19
|
+
}),
|
20
|
+
totalPages,
|
21
|
+
totalResults,
|
22
|
+
},
|
23
|
+
headers: new Headers({ 'Cache-Control': 'max-age=60' }),
|
24
|
+
}) as unknown as Promise<ResourceResponse<PlainObject>>;
|
@@ -1,12 +1,12 @@
|
|
1
|
-
import { range } from
|
1
|
+
import { range } from 'lodash-es';
|
2
2
|
|
3
|
-
export
|
4
|
-
pageRanges.reduce((pages, pageRange) => {
|
5
|
-
const [start, end] = pageRange.split(
|
3
|
+
export const generatePages = (pageRanges: string[]) =>
|
4
|
+
pageRanges.reduce<number[]>((pages, pageRange) => {
|
5
|
+
const [start, end] = pageRange.split('-');
|
6
6
|
|
7
7
|
if (!end) {
|
8
8
|
return [...pages, Number(start)];
|
9
9
|
}
|
10
10
|
|
11
11
|
return [...pages, ...range(Number(start), Number(end)), Number(end)];
|
12
|
-
}, []
|
12
|
+
}, []);
|
@@ -1,5 +1,5 @@
|
|
1
|
-
import
|
2
|
-
import { Edge } from
|
1
|
+
import { type Core } from '@cachemap/core';
|
2
|
+
import { type Edge } from '../types.ts';
|
3
3
|
|
4
4
|
export type Params = {
|
5
5
|
edges: Edge[];
|
@@ -10,13 +10,16 @@ export type Params = {
|
|
10
10
|
totalResults: number;
|
11
11
|
};
|
12
12
|
|
13
|
-
export
|
14
|
-
|
15
|
-
|
13
|
+
export const cacheCursors = async (
|
14
|
+
cursorCache: Core,
|
15
|
+
{ edges, group, headers, page, totalPages, totalResults }: Params
|
16
|
+
) => {
|
17
|
+
const cacheControl = headers.get('cache-control');
|
18
|
+
const options = cacheControl ? { cacheHeaders: { cacheControl } } : undefined;
|
16
19
|
|
17
20
|
await Promise.all(
|
18
|
-
edges.map(async ({ cursor, node }, index) => cursorCache.set(cursor, {
|
21
|
+
edges.map(async ({ cursor, node }, index) => cursorCache.set(cursor, { group, index, node, page }, options))
|
19
22
|
);
|
20
23
|
|
21
|
-
await cursorCache.set(`${group}-metadata`, { totalPages, totalResults },
|
24
|
+
await cursorCache.set(`${group}-metadata`, { totalPages, totalResults }, options);
|
22
25
|
};
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { CachedEdges, Edge } from
|
1
|
+
import { type CachedEdges, type Edge } from '../types.ts';
|
2
2
|
|
3
|
-
export
|
4
|
-
cachedEdges.reduce((edges, cachedEdge) => [...edges, ...cachedEdge.edges], []
|
3
|
+
export const extractEdges = (cachedEdges: CachedEdges[]) =>
|
4
|
+
cachedEdges.reduce<Edge[]>((edges, cachedEdge) => [...edges, ...cachedEdge.edges], []);
|
@@ -1,3 +1,3 @@
|
|
1
|
-
import { Edge } from
|
1
|
+
import { type Edge } from '../types.ts';
|
2
2
|
|
3
|
-
export
|
3
|
+
export const extractNodes = (edges: Edge[]) => edges.map(edge => edge.node);
|
@@ -1,11 +1,15 @@
|
|
1
|
-
import getCount from
|
1
|
+
import { getCount } from './getCount.ts';
|
2
2
|
|
3
|
-
describe(
|
4
|
-
|
5
|
-
|
3
|
+
describe('getCount', () => {
|
4
|
+
describe('when `first` is provided', () => {
|
5
|
+
it('should return the correct value', () => {
|
6
|
+
expect(getCount({ first: 5 })).toBe(5);
|
7
|
+
});
|
6
8
|
});
|
7
9
|
|
8
|
-
|
9
|
-
|
10
|
+
describe('when `last` is provided', () => {
|
11
|
+
it('should return the correct value', () => {
|
12
|
+
expect(getCount({ last: 5 })).toBe(5);
|
13
|
+
});
|
10
14
|
});
|
11
15
|
});
|
package/src/helpers/getCount.ts
CHANGED
@@ -1,3 +1,3 @@
|
|
1
|
-
import { ConnectionInputOptions } from
|
1
|
+
import { type ConnectionInputOptions } from '../types.ts';
|
2
2
|
|
3
|
-
export
|
3
|
+
export const getCount = ({ first, last }: ConnectionInputOptions) => first ?? last!;
|
@@ -1,11 +1,15 @@
|
|
1
|
-
import getCursor from
|
1
|
+
import { getCursor } from './getCursor.ts';
|
2
2
|
|
3
|
-
describe(
|
4
|
-
|
5
|
-
|
3
|
+
describe('getCursor', () => {
|
4
|
+
describe('when `before` is provided', () => {
|
5
|
+
it('should return the correct value', () => {
|
6
|
+
expect(getCursor({ before: 'abcdefg' })).toBe('abcdefg');
|
7
|
+
});
|
6
8
|
});
|
7
9
|
|
8
|
-
|
9
|
-
|
10
|
+
describe('when `after` is provided', () => {
|
11
|
+
it('should return the correct value', () => {
|
12
|
+
expect(getCursor({ after: 'abcdefg' })).toBe('abcdefg');
|
13
|
+
});
|
10
14
|
});
|
11
15
|
});
|
package/src/helpers/getCursor.ts
CHANGED
@@ -1,3 +1,3 @@
|
|
1
|
-
import { ConnectionInputOptions } from
|
1
|
+
import { type ConnectionInputOptions } from '../types.ts';
|
2
2
|
|
3
|
-
export
|
3
|
+
export const getCursor = ({ after, before }: ConnectionInputOptions) => before ?? after;
|
@@ -1,11 +1,15 @@
|
|
1
|
-
import getDirection from
|
1
|
+
import { getDirection } from './getDirection.ts';
|
2
2
|
|
3
|
-
describe(
|
4
|
-
|
5
|
-
|
3
|
+
describe('getDirection', () => {
|
4
|
+
describe('when last is provided', () => {
|
5
|
+
it('should return "backward"', () => {
|
6
|
+
expect(getDirection(5)).toBe('backward');
|
7
|
+
});
|
6
8
|
});
|
7
9
|
|
8
|
-
|
9
|
-
|
10
|
+
describe('when last is NOT provided', () => {
|
11
|
+
it('should return "forward"', () => {
|
12
|
+
expect(getDirection()).toBe('forward');
|
13
|
+
});
|
10
14
|
});
|
11
15
|
});
|
@@ -1,5 +1,5 @@
|
|
1
|
-
import { CachedEdges, Indexes } from
|
2
|
-
import { getCurrentPageEndIndex, getCurrentPageStartIndex } from
|
1
|
+
import { type CachedEdges, type Indexes } from '../types.ts';
|
2
|
+
import { getCurrentPageEndIndex, getCurrentPageStartIndex } from './getCurrentPageStartAndEndIndexes.ts';
|
3
3
|
|
4
4
|
export type Context = {
|
5
5
|
endIndex: Indexes;
|
@@ -7,13 +7,16 @@ export type Context = {
|
|
7
7
|
startIndex: Indexes;
|
8
8
|
};
|
9
9
|
|
10
|
-
export
|
11
|
-
|
12
|
-
|
10
|
+
export const getInRangeCachedEdges = (
|
11
|
+
cachedEdgesByPage: CachedEdges[],
|
12
|
+
{ endIndex, resultsPerPage, startIndex }: Context
|
13
|
+
) => {
|
14
|
+
return cachedEdgesByPage.reduce<CachedEdges[]>((inRange, cachedEdgesPage, index) => {
|
15
|
+
const currentPageStartIndex = getCurrentPageStartIndex({ pageIndex: index, startIndex });
|
13
16
|
|
14
17
|
const currentPageEndIndex = getCurrentPageEndIndex({
|
15
18
|
endIndex,
|
16
|
-
pageIndex:
|
19
|
+
pageIndex: index,
|
17
20
|
resultsPerPage,
|
18
21
|
totalCachedPages: cachedEdgesByPage.length,
|
19
22
|
});
|
@@ -21,5 +24,5 @@ export default (cachedEdgesByPage: CachedEdges[], { endIndex, resultsPerPage, st
|
|
21
24
|
const cachedEdges = cachedEdgesPage.edges.slice(currentPageStartIndex, currentPageEndIndex + 1);
|
22
25
|
inRange.push({ edges: cachedEdges, pageNumber: cachedEdgesPage.pageNumber });
|
23
26
|
return inRange;
|
24
|
-
}, []
|
27
|
+
}, []);
|
25
28
|
};
|
@@ -1,15 +1,19 @@
|
|
1
|
-
import getIndexesOnCurrentPage from
|
1
|
+
import { getIndexesOnCurrentPage } from './getIndexesOnCurrentPage.ts';
|
2
2
|
|
3
|
-
describe(
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
3
|
+
describe('getIndexesOnCurrentPage', () => {
|
4
|
+
describe('when current page is last page', () => {
|
5
|
+
it('should return the correct value', () => {
|
6
|
+
expect(
|
7
|
+
getIndexesOnCurrentPage({ metadata: { totalPages: 6, totalResults: 53 }, page: 6, resultsPerPage: 10 })
|
8
|
+
).toBe(2);
|
9
|
+
});
|
8
10
|
});
|
9
11
|
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
12
|
+
describe('when current page is NOT last page', () => {
|
13
|
+
it('should return the correct value', () => {
|
14
|
+
expect(
|
15
|
+
getIndexesOnCurrentPage({ metadata: { totalPages: 6, totalResults: 53 }, page: 5, resultsPerPage: 10 })
|
16
|
+
).toBe(9);
|
17
|
+
});
|
14
18
|
});
|
15
19
|
});
|
@@ -1,14 +1,19 @@
|
|
1
|
-
import {
|
2
|
-
import getResultsOnLastPage from
|
3
|
-
import isLastPage from
|
1
|
+
import type { CursorGroupMetadata } from '../types.ts';
|
2
|
+
import { getResultsOnLastPage } from './getResultsOnLastPage.ts';
|
3
|
+
import { isLastPage } from './isLastPage.ts';
|
4
4
|
|
5
5
|
export type IndexesOnCurrentPageContext = {
|
6
6
|
page: number;
|
7
7
|
};
|
8
8
|
|
9
|
-
export
|
10
|
-
|
9
|
+
export type Context = {
|
10
|
+
metadata: CursorGroupMetadata;
|
11
|
+
resultsPerPage: number;
|
12
|
+
};
|
13
|
+
|
14
|
+
export const getIndexesOnCurrentPage = ({
|
11
15
|
metadata: { totalPages, totalResults },
|
16
|
+
page,
|
12
17
|
resultsPerPage,
|
13
|
-
}: IndexesOnCurrentPageContext &
|
18
|
+
}: IndexesOnCurrentPageContext & Context) =>
|
14
19
|
(isLastPage({ page, totalPages }) ? getResultsOnLastPage({ resultsPerPage, totalResults }) : resultsPerPage) - 1;
|
@@ -1,11 +1,15 @@
|
|
1
|
-
import getIndexesOnLastPage from
|
1
|
+
import { getIndexesOnLastPage } from './getIndexesOnLastPage.ts';
|
2
2
|
|
3
|
-
describe(
|
4
|
-
|
5
|
-
|
3
|
+
describe('getIndexesOnLastPage', () => {
|
4
|
+
describe('when results on last page equal results per page', () => {
|
5
|
+
it('should return the correct value', () => {
|
6
|
+
expect(getIndexesOnLastPage({ resultsPerPage: 10, totalResults: 50 })).toBe(9);
|
7
|
+
});
|
6
8
|
});
|
7
9
|
|
8
|
-
|
9
|
-
|
10
|
+
describe('when results on last page do NOT equal results per page', () => {
|
11
|
+
it('should return the correct value', () => {
|
12
|
+
expect(getIndexesOnLastPage({ resultsPerPage: 10, totalResults: 53 })).toBe(2);
|
13
|
+
});
|
10
14
|
});
|
11
15
|
});
|
@@ -1,3 +1,4 @@
|
|
1
|
-
import
|
1
|
+
import { type Params, getResultsOnLastPage } from './getResultsOnLastPage.ts';
|
2
2
|
|
3
|
-
export
|
3
|
+
export const getIndexesOnLastPage = ({ resultsPerPage, totalResults }: Params) =>
|
4
|
+
getResultsOnLastPage({ resultsPerPage, totalResults }) - 1;
|
@@ -1,17 +1,17 @@
|
|
1
|
-
import getPageNumbersToRequest from
|
1
|
+
import { getPageNumbersToRequest } from './getPageNumbersToRequest.ts';
|
2
2
|
|
3
|
-
describe(
|
4
|
-
|
3
|
+
describe('getPageNumbersToRequest', () => {
|
4
|
+
describe('when direction is forward', () => {
|
5
5
|
const args = {
|
6
|
-
after:
|
6
|
+
after: 'abcdefg',
|
7
7
|
};
|
8
8
|
|
9
9
|
const ctx = {
|
10
10
|
endIndex: { absolute: 22, relative: 5 },
|
11
11
|
entry: {
|
12
|
-
group:
|
12
|
+
group: 'group',
|
13
13
|
index: 2,
|
14
|
-
node: { id:
|
14
|
+
node: { id: '123' },
|
15
15
|
page: 2,
|
16
16
|
},
|
17
17
|
metadata: {
|
@@ -22,10 +22,12 @@ describe("getPageNumbersToRequest", () => {
|
|
22
22
|
startIndex: { absolute: 3, relative: 3 },
|
23
23
|
};
|
24
24
|
|
25
|
-
|
25
|
+
it('should return the correct value', () => {
|
26
|
+
expect(getPageNumbersToRequest(args, ctx)).toEqual([2, 3, 4]);
|
27
|
+
});
|
26
28
|
});
|
27
29
|
|
28
|
-
|
30
|
+
describe('when direction is backward', () => {
|
29
31
|
const args = {
|
30
32
|
last: 5,
|
31
33
|
};
|
@@ -33,9 +35,9 @@ describe("getPageNumbersToRequest", () => {
|
|
33
35
|
const ctx = {
|
34
36
|
endIndex: { absolute: 4, relative: 4 },
|
35
37
|
entry: {
|
36
|
-
group:
|
38
|
+
group: 'group',
|
37
39
|
index: 3,
|
38
|
-
node: { id:
|
40
|
+
node: { id: '123' },
|
39
41
|
page: 4,
|
40
42
|
},
|
41
43
|
metadata: {
|
@@ -47,6 +49,8 @@ describe("getPageNumbersToRequest", () => {
|
|
47
49
|
startIndex: { absolute: -5, relative: 6 },
|
48
50
|
};
|
49
51
|
|
50
|
-
|
52
|
+
it('should return the correct value', () => {
|
53
|
+
expect(getPageNumbersToRequest(args, ctx)).toEqual([3, 4]);
|
54
|
+
});
|
51
55
|
});
|
52
56
|
});
|
@@ -1,17 +1,28 @@
|
|
1
|
-
import { range } from
|
2
|
-
import {
|
3
|
-
|
1
|
+
import { range } from 'lodash-es';
|
2
|
+
import {
|
3
|
+
type ConnectionInputOptions,
|
4
|
+
type CursorGroupMetadata,
|
5
|
+
type Indexes,
|
6
|
+
type PartialCursorCacheEntry,
|
7
|
+
} from '../types.ts';
|
8
|
+
import { getEndPageNumber, getStartPageNumber } from './getStartAndEndPageNumbers.ts';
|
4
9
|
|
5
10
|
export type GetPageNumbersToRequestContext = {
|
6
11
|
endIndex: Indexes;
|
7
12
|
startIndex: Indexes;
|
8
13
|
};
|
9
14
|
|
10
|
-
export
|
15
|
+
export type Context = {
|
16
|
+
entry: PartialCursorCacheEntry;
|
17
|
+
metadata: CursorGroupMetadata;
|
18
|
+
resultsPerPage: number;
|
19
|
+
};
|
20
|
+
|
21
|
+
export const getPageNumbersToRequest = (
|
11
22
|
args: ConnectionInputOptions,
|
12
|
-
{ endIndex, entry: { page }, metadata, resultsPerPage, startIndex }: GetPageNumbersToRequestContext & Context
|
23
|
+
{ endIndex, entry: { page }, metadata, resultsPerPage, startIndex }: GetPageNumbersToRequestContext & Context
|
13
24
|
) => {
|
14
|
-
const startPageNumber = getStartPageNumber(args, { page,
|
25
|
+
const startPageNumber = getStartPageNumber(args, { page, resultsPerPage, startIndex });
|
15
26
|
const endPageNumber = getEndPageNumber(args, { endIndex, metadata, page, resultsPerPage });
|
16
27
|
|
17
28
|
if (startPageNumber === endPageNumber) {
|
@@ -1,11 +1,11 @@
|
|
1
|
-
import { CachedEdges } from
|
1
|
+
import { type CachedEdges } from '../types.ts';
|
2
2
|
|
3
|
-
export
|
4
|
-
return cachedEdgesByPage.reduce((missing, cachedEdgesPage) => {
|
5
|
-
if (
|
3
|
+
export const getPagesMissingFromCache = (cachedEdgesByPage: CachedEdges[]) => {
|
4
|
+
return cachedEdgesByPage.reduce<number[]>((missing, cachedEdgesPage) => {
|
5
|
+
if (cachedEdgesPage.edges.length === 0) {
|
6
6
|
missing.push(cachedEdgesPage.pageNumber);
|
7
7
|
}
|
8
8
|
|
9
9
|
return missing;
|
10
|
-
}, []
|
10
|
+
}, []);
|
11
11
|
};
|
@@ -1,11 +1,15 @@
|
|
1
|
-
import getResultsOnLastPage from
|
1
|
+
import { getResultsOnLastPage } from './getResultsOnLastPage.ts';
|
2
2
|
|
3
|
-
describe(
|
4
|
-
|
5
|
-
|
3
|
+
describe('getResultsOnLastPage', () => {
|
4
|
+
describe('when results on last page equal results per page', () => {
|
5
|
+
it('should return the correct value', () => {
|
6
|
+
expect(getResultsOnLastPage({ resultsPerPage: 10, totalResults: 50 })).toBe(10);
|
7
|
+
});
|
6
8
|
});
|
7
9
|
|
8
|
-
|
9
|
-
|
10
|
+
describe('when results on last page do NOT equal results per page', () => {
|
11
|
+
it('should return the correct value', () => {
|
12
|
+
expect(getResultsOnLastPage({ resultsPerPage: 10, totalResults: 53 })).toBe(3);
|
13
|
+
});
|
10
14
|
});
|
11
15
|
});
|