@preply/ds-visual-coverage-core
Advanced tools
Comparing version 0.99.1-beta.22520120a5c75760a7e3556443f375b03c4fe7c1.0 to 0.99.1-beta.6fcddb3f3b82fb62293b4c54958750a8ce252183.0
@@ -1,2 +0,2 @@ | ||
import type { Bitmap, ChildData, CoverageMode, Logger, Milliseconds, PixelByPixelType, PixelCounts, Rect, WeightByComponentName } from '../types'; | ||
import type { Bitmap, ChildData, Logger, Milliseconds, PixelByPixelType, PixelCounts, Rect, WeightByComponentName } from '../types'; | ||
type Params = { | ||
@@ -13,11 +13,2 @@ logger: Logger; | ||
weightByComponentName: WeightByComponentName; | ||
/** | ||
* When perimeters count, the bigger the component the more important it is for the coverage. | ||
* But bigger components are containers, while smaller components are DS and generic UI ones. | ||
* `countComponents` solves this problem by drawing just some pixels for every component. | ||
* On the paper, this sounds like just counting the DOM elements, and weighting them by the | ||
* component weight, but in reality it also consider the depth (even if it's not perfect since | ||
* it's not the CSS one). Look at the tests to better understand it. | ||
*/ | ||
coverageMode: CoverageMode; | ||
}; | ||
@@ -24,0 +15,0 @@ type CountPixelsResult = { |
@@ -8,3 +8,3 @@ import { createBitmap } from '../bitmap/createBitmap.js'; | ||
function countPixels(params) { | ||
const { logger, offset, elementRect, childrenData, coverageMode, printAsciiArt, pixelByPixelType, weightByComponentName, } = params; | ||
const { logger, offset, elementRect, childrenData, printAsciiArt, pixelByPixelType, weightByComponentName, } = params; | ||
const start = Date.now(); | ||
@@ -68,4 +68,3 @@ const bitmap = createBitmap(getRectCoordinate(elementRect, 'height'), getRectCoordinate(elementRect, 'width')); | ||
const noMoreHorizontalLinesToDraw = topRowCrossedHalfHeight; | ||
const pixelsMustRemainInsideComponentArea = coverageMode === 'countPerimeters'; | ||
if (pixelsMustRemainInsideComponentArea && noMoreHorizontalLinesToDraw) | ||
if (noMoreHorizontalLinesToDraw) | ||
break; | ||
@@ -101,5 +100,2 @@ // This is the loop condition, here it's more readable | ||
}); | ||
if (coverageMode === 'countComponents') | ||
// The goal is write one pixel for every row | ||
break; | ||
} | ||
@@ -134,5 +130,2 @@ // "Draw" the bottom row | ||
for (let currentTop = Math.floor(rectTop - offsetTop);; currentTop++) { | ||
if (coverageMode === 'countComponents') | ||
// The goal is write one pixel for every row | ||
break; | ||
// Happens when the weight is higher than half the height of the element, and so top and bottom flip. Look at noMoreHorizontalLinesToDraw's comment | ||
@@ -233,2 +226,2 @@ const noMoreVerticalLinesToDraw = left > right; | ||
export { countPixels }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"countPixels.js","sources":["../../src/core/countPixels.ts"],"sourcesContent":["import { createBitmap } from '../bitmap/createBitmap';\nimport { logBitmap } from '../bitmap/logBitmap';\nimport { setBitmapPixel } from '../bitmap/setBitmapPixel';\nimport { getRectCoordinate } from '../rect/rectProperties';\nimport type {\n    Bitmap,\n    ChildData,\n    ComponentType,\n    CoverageMode,\n    Logger,\n    Milliseconds,\n    PixelByPixelType,\n    PixelCounts,\n    Rect,\n    WeightByComponentName,\n} from '../types';\n\nimport { createPixelCounts } from './createPixelCounts';\n\ntype Params = {\n    logger: Logger;\n    elementRect: Rect;\n    printAsciiArt: boolean;\n    childrenData: ChildData[];\n    pixelByPixelType: PixelByPixelType;\n    offset: { top: number; left: number };\n    weightByComponentName: WeightByComponentName;\n\n    /**\n     * When perimeters count, the bigger the component the more important it is for the coverage.\n     * But bigger components are containers, while smaller components are DS and generic UI ones.\n     * `countComponents` solves this problem by drawing just some pixels for every component.\n     * On the paper, this sounds like just counting the DOM elements, and weighting them by the\n     * component weight, but in reality it also consider the depth (even if it's not perfect since\n     * it's not the CSS one). Look at the tests to better understand it.\n     */\n    coverageMode: CoverageMode;\n};\n\ntype CountPixelsResult = {\n    bitmap: Bitmap;\n    pixelCounts: PixelCounts;\n    duration: Milliseconds;\n};\n\nexport function countPixels(params: Params): CountPixelsResult {\n    const {\n        logger,\n        offset,\n        elementRect,\n        childrenData,\n        coverageMode,\n        printAsciiArt,\n        pixelByPixelType,\n        weightByComponentName,\n    } = params;\n\n    const start: Milliseconds = Date.now();\n\n    const bitmap = createBitmap(\n        getRectCoordinate(elementRect, 'height'),\n        getRectCoordinate(elementRect, 'width'),\n    );\n\n    for (let i = 0, n = childrenData.length; i < n; i++) {\n        const childData = childrenData[i];\n        if (!childData)\n            throw new Error(`No childData at ${i} (this should be a TS-only protection)`);\n\n        const { rect, dsComponentType, isChildOfUiDsComponent, dsComponentName } = childData;\n\n        const adjustedSsComponentType: ComponentType = isChildOfUiDsComponent\n            ? 'unknownDsComponent' // children of ui components are treated as DS components too\n            : dsComponentType;\n\n        const pixel = pixelByPixelType[adjustedSsComponentType];\n\n        const offsetTop = offset.top;\n        const offsetLeft = offset.left;\n\n        const rectTop = getRectCoordinate(rect, 'top');\n        const rectLeft = getRectCoordinate(rect, 'left');\n        const rectWidth = getRectCoordinate(rect, 'width');\n        const rectHeight = getRectCoordinate(rect, 'height');\n        const rowLength = getRectCoordinate(elementRect, 'height');\n        const columnLength = getRectCoordinate(elementRect, 'width');\n\n        const weight = weightByComponentName[dsComponentName ?? 'nonDsComponent'];\n\n        if (weight === undefined) {\n            throw new Error(`No weight for ${elementRect} (this should be a TS-only protection)`);\n        }\n\n        for (let weightLine = 0; weightLine < weight; weightLine++) {\n            // \"Draw\" the rows in bitmap\n            const top = Math.floor(rectTop - offsetTop + weightLine);\n            const bottom = Math.floor(rectTop - offsetTop + rectHeight - 1 - weightLine);\n\n            for (let currentLeft = Math.floor(rectLeft - offsetLeft); ; currentLeft++) {\n                // Happens when the weight is higher than half the height of the element, and so top and bottom flip\n                // Ex. first loop with weight = 5\n                // [\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 top\n                //              [ , , , , ,L, , , , ,],\n                //              [ , , , , ,L, , , , ,],\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 bottom\n                //              [ , , , , , , , , , ,],\n                // ]\n                // second iteration with weight = 5\n                // [\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 top\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 bottom\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , , , , , , ,],\n                // ]\n                // third iteration with weight = 5 (the loop must break)\n                // [\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 bottom\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 top\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , , , , , , ,],\n                // ]\n\n                const topRowCrossedHalfHeight = top > bottom;\n                const noMoreHorizontalLinesToDraw = topRowCrossedHalfHeight;\n\n                const pixelsMustRemainInsideComponentArea = coverageMode === 'countPerimeters';\n\n                if (pixelsMustRemainInsideComponentArea && noMoreHorizontalLinesToDraw) break;\n\n                // This is the loop condition, here it's more readable\n                const isAtTheRightOfTheViewport =\n                    currentLeft >= rectLeft - offsetLeft + rectWidth || currentLeft >= columnLength;\n                if (isAtTheRightOfTheViewport) break;\n\n                const isAtTheLeftOfTheViewport = currentLeft < 0; // can happen for elements placed outside the viewport\n                if (isAtTheLeftOfTheViewport) continue;\n\n                // \"Draw\" the top row\n                // [\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //        👉👉👉 [ , , , , ,L,L,L,L,L,], 👈👈👈\n                //              [ , , , , ,L, , , ,L,],\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                // ]\n                const topRowIsInsideTheViewport = top >= 0 && top < rowLength;\n                if (topRowIsInsideTheViewport) {\n                    setBitmapPixel({\n                        top,\n                        bitmap,\n                        left: currentLeft,\n                        value: pixel,\n                        width: getRectCoordinate(elementRect, 'width'),\n                    });\n\n                    if (coverageMode === 'countComponents')\n                        // The goal is write one pixel for every row\n                        break;\n                }\n\n                // \"Draw\" the bottom row\n                // [\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , ,L, , , ,L,],\n                //        👉👉👉 [ , , , , ,L,L,L,L,L,], 👈👈👈\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                // ]\n                const bottomRowIsInsideTheViewport = bottom >= 0 && bottom < rowLength;\n                if (bottomRowIsInsideTheViewport) {\n                    setBitmapPixel({\n                        top: bottom,\n                        bitmap,\n                        left: currentLeft,\n                        value: pixel,\n                        width: getRectCoordinate(elementRect, 'width'),\n                    });\n                }\n            }\n\n            // \"Draw\" the columns in bitmap\n            const left = Math.floor(rectLeft - offsetLeft + weightLine);\n            const right = Math.floor(rectLeft - offsetLeft + rectWidth - 1 - weightLine);\n            for (let currentTop = Math.floor(rectTop - offsetTop); ; currentTop++) {\n                if (coverageMode === 'countComponents')\n                    // The goal is write one pixel for every row\n                    break;\n\n                // Happens when the weight is higher than half the height of the element, and so top and bottom flip. Look at noMoreHorizontalLinesToDraw's comment\n                const noMoreVerticalLinesToDraw = left > right;\n                if (noMoreVerticalLinesToDraw) break;\n\n                // This is the loop condition, here it's more readable\n                const isAtTheBottomOfTheViewport =\n                    currentTop >= rectTop - offsetTop + rectHeight - 1 || currentTop > rowLength;\n\n                if (isAtTheBottomOfTheViewport) break;\n\n                const isAtTheTopOfTheViewport = currentTop < 0; // can happen for elements placed outside the viewport\n                if (isAtTheTopOfTheViewport) continue;\n\n                // \"Draw\" the left column\n                // [\n                //               👇\n                //               👇\n                //               👇\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , ,L,L,L,L,L,],\n                //    [ , , , , ,L, , , ,L,],\n                //    [ , , , , ,L,L,L,L,L,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //               👆\n                //               👆\n                //               👆\n                // ]\n                const leftColumnIsInsideTheViewport =\n                    left >= 0 && currentTop < rowLength && left < columnLength;\n\n                if (leftColumnIsInsideTheViewport) {\n                    setBitmapPixel({\n                        left,\n                        bitmap,\n                        top: currentTop,\n                        value: pixel,\n                        width: getRectCoordinate(elementRect, 'width'),\n                    });\n                }\n\n                // \"Draw\" the right column\n                // [\n                //                       👇\n                //                       👇\n                //                       👇\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , ,L,L,L,L,L,],\n                //    [ , , , , ,L, , , ,L,],\n                //    [ , , , , ,L,L,L,L,L,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //                       👆\n                //                       👆\n                //                       👆\n                // ]\n                const rigthtColumnIsInsideTheViewport =\n                    right >= 0 && currentTop < rowLength && right < columnLength;\n                if (rigthtColumnIsInsideTheViewport) {\n                    setBitmapPixel({\n                        bitmap,\n                        top: currentTop,\n                        left: right,\n                        value: pixel,\n                        width: getRectCoordinate(elementRect, 'width'),\n                    });\n                }\n            }\n        }\n    }\n\n    const pixelCounts = createPixelCounts();\n    for (let i = 0, n = bitmap.length; i < n; i++) {\n        const pixelAsNumber = bitmap[i];\n        if (pixelAsNumber === undefined) {\n            throw new Error(`No pixel at ${i} (this should be a TS-only protection)`);\n        }\n        pixelCounts[pixelAsNumber]++;\n    }\n\n    if (printAsciiArt) {\n        logBitmap({\n            logger,\n            bitmap,\n            width: getRectCoordinate(elementRect, 'width'),\n        });\n    }\n\n    return {\n        bitmap,\n        pixelCounts,\n        duration: Date.now() - start,\n    };\n}\n"],"names":[],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"countPixels.js","sources":["../../src/core/countPixels.ts"],"sourcesContent":["import { createBitmap } from '../bitmap/createBitmap';\nimport { logBitmap } from '../bitmap/logBitmap';\nimport { setBitmapPixel } from '../bitmap/setBitmapPixel';\nimport { getRectCoordinate } from '../rect/rectProperties';\nimport type {\n    Bitmap,\n    ChildData,\n    ComponentType,\n    Logger,\n    Milliseconds,\n    PixelByPixelType,\n    PixelCounts,\n    Rect,\n    WeightByComponentName,\n} from '../types';\n\nimport { createPixelCounts } from './createPixelCounts';\n\ntype Params = {\n    logger: Logger;\n    elementRect: Rect;\n    printAsciiArt: boolean;\n    childrenData: ChildData[];\n    pixelByPixelType: PixelByPixelType;\n    offset: { top: number; left: number };\n    weightByComponentName: WeightByComponentName;\n};\n\ntype CountPixelsResult = {\n    bitmap: Bitmap;\n    pixelCounts: PixelCounts;\n    duration: Milliseconds;\n};\n\nexport function countPixels(params: Params): CountPixelsResult {\n    const {\n        logger,\n        offset,\n        elementRect,\n        childrenData,\n        printAsciiArt,\n        pixelByPixelType,\n        weightByComponentName,\n    } = params;\n\n    const start: Milliseconds = Date.now();\n\n    const bitmap = createBitmap(\n        getRectCoordinate(elementRect, 'height'),\n        getRectCoordinate(elementRect, 'width'),\n    );\n\n    for (let i = 0, n = childrenData.length; i < n; i++) {\n        const childData = childrenData[i];\n        if (!childData)\n            throw new Error(`No childData at ${i} (this should be a TS-only protection)`);\n\n        const { rect, dsComponentType, isChildOfUiDsComponent, dsComponentName } = childData;\n\n        const adjustedSsComponentType: ComponentType = isChildOfUiDsComponent\n            ? 'unknownDsComponent' // children of ui components are treated as DS components too\n            : dsComponentType;\n\n        const pixel = pixelByPixelType[adjustedSsComponentType];\n\n        const offsetTop = offset.top;\n        const offsetLeft = offset.left;\n\n        const rectTop = getRectCoordinate(rect, 'top');\n        const rectLeft = getRectCoordinate(rect, 'left');\n        const rectWidth = getRectCoordinate(rect, 'width');\n        const rectHeight = getRectCoordinate(rect, 'height');\n        const rowLength = getRectCoordinate(elementRect, 'height');\n        const columnLength = getRectCoordinate(elementRect, 'width');\n\n        const weight = weightByComponentName[dsComponentName ?? 'nonDsComponent'];\n\n        if (weight === undefined) {\n            throw new Error(`No weight for ${elementRect} (this should be a TS-only protection)`);\n        }\n\n        for (let weightLine = 0; weightLine < weight; weightLine++) {\n            // \"Draw\" the rows in bitmap\n            const top = Math.floor(rectTop - offsetTop + weightLine);\n            const bottom = Math.floor(rectTop - offsetTop + rectHeight - 1 - weightLine);\n\n            for (let currentLeft = Math.floor(rectLeft - offsetLeft); ; currentLeft++) {\n                // Happens when the weight is higher than half the height of the element, and so top and bottom flip\n                // Ex. first loop with weight = 5\n                // [\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 top\n                //              [ , , , , ,L, , , , ,],\n                //              [ , , , , ,L, , , , ,],\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 bottom\n                //              [ , , , , , , , , , ,],\n                // ]\n                // second iteration with weight = 5\n                // [\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 top\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 bottom\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , , , , , , ,],\n                // ]\n                // third iteration with weight = 5 (the loop must break)\n                // [\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 bottom\n                //              [ , , , , ,L,L,L,L,L,], 👈👈👈 top\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , , , , , , ,],\n                // ]\n\n                const topRowCrossedHalfHeight = top > bottom;\n                const noMoreHorizontalLinesToDraw = topRowCrossedHalfHeight;\n\n                if (noMoreHorizontalLinesToDraw) break;\n\n                // This is the loop condition, here it's more readable\n                const isAtTheRightOfTheViewport =\n                    currentLeft >= rectLeft - offsetLeft + rectWidth || currentLeft >= columnLength;\n                if (isAtTheRightOfTheViewport) break;\n\n                const isAtTheLeftOfTheViewport = currentLeft < 0; // can happen for elements placed outside the viewport\n                if (isAtTheLeftOfTheViewport) continue;\n\n                // \"Draw\" the top row\n                // [\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //        👉👉👉 [ , , , , ,L,L,L,L,L,], 👈👈👈\n                //              [ , , , , ,L, , , ,L,],\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                // ]\n                const topRowIsInsideTheViewport = top >= 0 && top < rowLength;\n                if (topRowIsInsideTheViewport) {\n                    setBitmapPixel({\n                        top,\n                        bitmap,\n                        left: currentLeft,\n                        value: pixel,\n                        width: getRectCoordinate(elementRect, 'width'),\n                    });\n                }\n\n                // \"Draw\" the bottom row\n                // [\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , ,L,L,L,L,L,],\n                //              [ , , , , ,L, , , ,L,],\n                //        👉👉👉 [ , , , , ,L,L,L,L,L,], 👈👈👈\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                //              [ , , , , , , , , , ,],\n                // ]\n                const bottomRowIsInsideTheViewport = bottom >= 0 && bottom < rowLength;\n                if (bottomRowIsInsideTheViewport) {\n                    setBitmapPixel({\n                        top: bottom,\n                        bitmap,\n                        left: currentLeft,\n                        value: pixel,\n                        width: getRectCoordinate(elementRect, 'width'),\n                    });\n                }\n            }\n\n            // \"Draw\" the columns in bitmap\n            const left = Math.floor(rectLeft - offsetLeft + weightLine);\n            const right = Math.floor(rectLeft - offsetLeft + rectWidth - 1 - weightLine);\n            for (let currentTop = Math.floor(rectTop - offsetTop); ; currentTop++) {\n                // Happens when the weight is higher than half the height of the element, and so top and bottom flip. Look at noMoreHorizontalLinesToDraw's comment\n                const noMoreVerticalLinesToDraw = left > right;\n                if (noMoreVerticalLinesToDraw) break;\n\n                // This is the loop condition, here it's more readable\n                const isAtTheBottomOfTheViewport =\n                    currentTop >= rectTop - offsetTop + rectHeight - 1 || currentTop > rowLength;\n\n                if (isAtTheBottomOfTheViewport) break;\n\n                const isAtTheTopOfTheViewport = currentTop < 0; // can happen for elements placed outside the viewport\n                if (isAtTheTopOfTheViewport) continue;\n\n                // \"Draw\" the left column\n                // [\n                //               👇\n                //               👇\n                //               👇\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , ,L,L,L,L,L,],\n                //    [ , , , , ,L, , , ,L,],\n                //    [ , , , , ,L,L,L,L,L,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //               👆\n                //               👆\n                //               👆\n                // ]\n                const leftColumnIsInsideTheViewport =\n                    left >= 0 && currentTop < rowLength && left < columnLength;\n\n                if (leftColumnIsInsideTheViewport) {\n                    setBitmapPixel({\n                        left,\n                        bitmap,\n                        top: currentTop,\n                        value: pixel,\n                        width: getRectCoordinate(elementRect, 'width'),\n                    });\n                }\n\n                // \"Draw\" the right column\n                // [\n                //                       👇\n                //                       👇\n                //                       👇\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , ,L,L,L,L,L,],\n                //    [ , , , , ,L, , , ,L,],\n                //    [ , , , , ,L,L,L,L,L,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //    [ , , , , , , , , , ,],\n                //                       👆\n                //                       👆\n                //                       👆\n                // ]\n                const rigthtColumnIsInsideTheViewport =\n                    right >= 0 && currentTop < rowLength && right < columnLength;\n                if (rigthtColumnIsInsideTheViewport) {\n                    setBitmapPixel({\n                        bitmap,\n                        top: currentTop,\n                        left: right,\n                        value: pixel,\n                        width: getRectCoordinate(elementRect, 'width'),\n                    });\n                }\n            }\n        }\n    }\n\n    const pixelCounts = createPixelCounts();\n    for (let i = 0, n = bitmap.length; i < n; i++) {\n        const pixelAsNumber = bitmap[i];\n        if (pixelAsNumber === undefined) {\n            throw new Error(`No pixel at ${i} (this should be a TS-only protection)`);\n        }\n        pixelCounts[pixelAsNumber]++;\n    }\n\n    if (printAsciiArt) {\n        logBitmap({\n            logger,\n            bitmap,\n            width: getRectCoordinate(elementRect, 'width'),\n        });\n    }\n\n    return {\n        bitmap,\n        pixelCounts,\n        duration: Date.now() - start,\n    };\n}\n"],"names":[],"mappings":"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"} |
@@ -1,2 +0,2 @@ | ||
export type { Rect, Pixel, Bitmap, Logger, ChildData, PixelCounts, Milliseconds, CoverageMode, ComponentType, HighestNumber, ColorByPixelType, PixelByPixelType, CoverageContainer, ReadableCharByPixel, WeightByComponentName, DsVisualCoverageResult, DsVisualCoverageRunResult, CoverageContainerDomAttributeValue, DsVisualCoverageDeNormalizedResult, } from './types'; | ||
export type { Rect, Pixel, Bitmap, Logger, ChildData, PixelCounts, Milliseconds, ComponentType, HighestNumber, ColorByPixelType, PixelByPixelType, CoverageContainer, ReadableCharByPixel, WeightByComponentName, DsVisualCoverageResult, DsVisualCoverageRunResult, CoverageContainerDomAttributeValue, DsVisualCoverageDeNormalizedResult, } from './types'; | ||
export { logBitmap } from './bitmap/logBitmap'; | ||
@@ -3,0 +3,0 @@ export { countPixels } from './core/countPixels'; |
@@ -50,6 +50,2 @@ import type { ComponentNames } from '@preply/ds-visual-coverage-component-names'; | ||
export type Coverage = Percentage; | ||
/** | ||
* See countPixels for the differences between the two modes. | ||
*/ | ||
export type CoverageMode = 'countComponents' | 'countPerimeters'; | ||
export type DsVisualCoverageDeNormalizedResult = DsVisualCoverageResult & { | ||
@@ -56,0 +52,0 @@ team: string; |
{ | ||
"name": "@preply/ds-visual-coverage-core", | ||
"version": "0.99.1-beta.22520120a5c75760a7e3556443f375b03c4fe7c1.0+2252012", | ||
"version": "0.99.1-beta.6fcddb3f3b82fb62293b4c54958750a8ce252183.0+6fcddb3", | ||
"type": "module", | ||
@@ -22,3 +22,3 @@ "publishConfig": { | ||
"dependencies": { | ||
"@preply/ds-visual-coverage-component-names": "^0.99.1-beta.22520120a5c75760a7e3556443f375b03c4fe7c1.0+2252012" | ||
"@preply/ds-visual-coverage-component-names": "^0.99.1-beta.6fcddb3f3b82fb62293b4c54958750a8ce252183.0+6fcddb3" | ||
}, | ||
@@ -28,3 +28,3 @@ "peerDependencies": { | ||
}, | ||
"gitHead": "22520120a5c75760a7e3556443f375b03c4fe7c1" | ||
"gitHead": "6fcddb3f3b82fb62293b4c54958750a8ce252183" | ||
} |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Manifest confusion
Supply chain riskThis package has inconsistent metadata. This could be malicious or caused by an error when publishing the package.
Found 1 instance in 1 package
Manifest confusion
Supply chain riskThis package has inconsistent metadata. This could be malicious or caused by an error when publishing the package.
Found 1 instance in 1 package
202749
1760