@preply/ds-visual-coverage-core
Advanced tools
Comparing version 0.97.1 to 0.97.2
import type { Coverage, PixelCounts } from '../types'; | ||
declare type Params = { | ||
type Params = { | ||
pixelCounts: PixelCounts; | ||
@@ -4,0 +4,0 @@ }; |
import type { Bitmap, ChildData, CoverageMode, Logger, Milliseconds, PixelByPixelType, PixelCounts, Rect, WeightByComponentName } from '../types'; | ||
declare type Params = { | ||
type Params = { | ||
logger: Logger; | ||
@@ -23,3 +23,3 @@ elementRect: Rect; | ||
}; | ||
declare type CountPixelsResult = { | ||
type CountPixelsResult = { | ||
bitmap: Bitmap; | ||
@@ -26,0 +26,0 @@ pixelCounts: PixelCounts; |
@@ -5,2 +5,3 @@ import { createBitmap } from '../bitmap/createBitmap.js'; | ||
import { getRectCoordinate } from '../rect/rectProperties.js'; | ||
import { createPixelCounts } from './createPixelCounts.js'; | ||
@@ -205,4 +206,3 @@ /* eslint-disable no-continue */ | ||
} | ||
const length = 8; | ||
const pixelCounts = new Uint32Array(length + 1); | ||
const pixelCounts = createPixelCounts(); | ||
for (let i = 0, n = bitmap.length; i < n; i++) { | ||
@@ -226,2 +226,2 @@ pixelCounts[bitmap[i]]++; | ||
export { countPixels }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"countPixels.js","sources":["../../src/core/countPixels.ts"],"sourcesContent":["/* eslint-disable no-continue */\n/* eslint-disable no-plusplus */\n\nimport { 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    HighestNumber,\n    Logger,\n    Milliseconds,\n    PixelByPixelType,\n    PixelCounts,\n    Rect,\n    WeightByComponentName,\n} from '../types';\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        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 length: HighestNumber = 8;\n    const pixelCounts = new Uint32Array(length + 1);\n    for (let i = 0, n = bitmap.length; i < n; i++) {\n        pixelCounts[bitmap[i]]++;\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":["/* eslint-disable no-continue */\n/* eslint-disable no-plusplus */\n\nimport { 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        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        pixelCounts[bitmap[i]]++;\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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"} |
import type { DsVisualCoverageDeNormalizedResult, Logger } from '../types'; | ||
declare type Params = { | ||
type Params = { | ||
results: DsVisualCoverageDeNormalizedResult[]; | ||
@@ -4,0 +4,0 @@ logger: Logger; |
import type { ComponentType, PixelCounts } from '../types'; | ||
declare type Params = { | ||
type Params = { | ||
componentType: ComponentType; | ||
@@ -4,0 +4,0 @@ pixelCounts: PixelCounts; |
import type { ChildData, ColorByPixelType, WeightByComponentName } from '../types'; | ||
declare type LoopParams = { | ||
type LoopParams = { | ||
childrenData: ChildData[]; | ||
@@ -4,0 +4,0 @@ svgRenderer: SVGSVGElement; |
@@ -1,2 +0,2 @@ | ||
export type { Rect, Pixel, Bitmap, Logger, ChildData, TreeStats, 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, CoverageMode, ComponentType, HighestNumber, ColorByPixelType, PixelByPixelType, CoverageContainer, ReadableCharByPixel, WeightByComponentName, DsVisualCoverageResult, DsVisualCoverageRunResult, CoverageContainerDomAttributeValue, DsVisualCoverageDeNormalizedResult, } from './types'; | ||
export { logBitmap } from './bitmap/logBitmap'; | ||
@@ -6,9 +6,9 @@ export { countPixels } from './core/countPixels'; | ||
export { setBitmapPixel } from './bitmap/setBitmapPixel'; | ||
export { createTreeStats } from './utils/createTreeStats'; | ||
export { getComponentType } from './core/getComponentType'; | ||
export { addSvgRectangles } from './debug/addSvgRectangles'; | ||
export { calculateCoverage } from './core/calculateCoverage'; | ||
export { calculateTreeStats } from './utils/calculateTreeStats'; | ||
export { createPixelCounts } from './core/createPixelCounts'; | ||
export { createLogger, isActiveLogger } from './utils/createLogger'; | ||
export { filterOutEmptyContainers } from './core/filterOutEmptyContainers'; | ||
export { isEmptyCoverageContainer } from './core/isEmptyCoverageContainer'; | ||
export { getPixelCountByComponentType } from './core/getPixelCountByComponentType'; | ||
@@ -15,0 +15,0 @@ export { getDenormalizedCoverageResult } from './utils/getDenormalizedCoverageResult'; |
@@ -5,9 +5,9 @@ export { logBitmap } from './bitmap/logBitmap.js'; | ||
export { setBitmapPixel } from './bitmap/setBitmapPixel.js'; | ||
export { createTreeStats } from './utils/createTreeStats.js'; | ||
export { getComponentType } from './core/getComponentType.js'; | ||
export { addSvgRectangles } from './debug/addSvgRectangles.js'; | ||
export { calculateCoverage } from './core/calculateCoverage.js'; | ||
export { calculateTreeStats } from './utils/calculateTreeStats.js'; | ||
export { createPixelCounts } from './core/createPixelCounts.js'; | ||
export { createLogger, isActiveLogger } from './utils/createLogger.js'; | ||
export { filterOutEmptyContainers } from './core/filterOutEmptyContainers.js'; | ||
export { isEmptyCoverageContainer } from './core/isEmptyCoverageContainer.js'; | ||
export { getPixelCountByComponentType } from './core/getPixelCountByComponentType.js'; | ||
@@ -14,0 +14,0 @@ export { getDenormalizedCoverageResult } from './utils/getDenormalizedCoverageResult.js'; |
import type { ComponentNames } from '@preply/ds-visual-coverage-component-names'; | ||
import { coverageContainerDomAttributeName } from './core/constants'; | ||
export declare type CoverageContainer<TEAM extends string = string, COMPONENT extends string = string> = { | ||
export type CoverageContainer<TEAM extends string = string, COMPONENT extends string = string> = { | ||
team: TEAM; | ||
@@ -12,4 +12,4 @@ component: COMPONENT; | ||
*/ | ||
export declare type CoverageContainerDomAttributeName = typeof coverageContainerDomAttributeName; | ||
export declare type CoverageContainerDomAttributeValue = string; | ||
export type CoverageContainerDomAttributeName = typeof coverageContainerDomAttributeName; | ||
export type CoverageContainerDomAttributeValue = string; | ||
/** | ||
@@ -34,14 +34,13 @@ * Virtual representation of the pixels of the page. Its length is the page's width*height | ||
*/ | ||
export declare type Bitmap = Uint8Array; | ||
export declare type EmptyPixel = 0; | ||
export declare type NonDsComponentPixel = 1; | ||
export declare type DsComponentPixels = 2 | 3 | 4 | 5 | 6 | 7 | 8; | ||
export declare type ComponentPixels = NonDsComponentPixel | DsComponentPixels; | ||
export declare type Pixel = EmptyPixel | ComponentPixels; | ||
export declare type HighestNumber = 8; | ||
export declare type ComponentType = 'nonDsComponent' | 'uiDsComponent' | 'utilDsComponent' | 'rebrandComponent' | 'layoutDsComponent' | 'unknownDsComponent' | 'dsCandidateComponent' | 'outdatedDsComponent'; | ||
export declare type PixelType = 'emptyPixel' | ComponentType; | ||
export declare type DsVisualCoverageResult = { | ||
export type Bitmap = Uint8Array; | ||
export type EmptyPixel = 0; | ||
export type NonDsComponentPixel = 1; | ||
export type DsComponentPixels = 2 | 3 | 4 | 5 | 6 | 7 | 8; | ||
export type ComponentPixels = NonDsComponentPixel | DsComponentPixels; | ||
export type Pixel = EmptyPixel | ComponentPixels; | ||
export type HighestNumber = 8; | ||
export type ComponentType = 'nonDsComponent' | 'uiDsComponent' | 'utilDsComponent' | 'rebrandComponent' | 'layoutDsComponent' | 'unknownDsComponent' | 'dsCandidateComponent' | 'outdatedDsComponent'; | ||
export type PixelType = 'emptyPixel' | ComponentType; | ||
export type DsVisualCoverageResult = { | ||
stopped: boolean; | ||
treeStats: TreeStats; | ||
duration: Duration; | ||
@@ -51,9 +50,9 @@ pixelCounts: PixelCounts; | ||
}; | ||
declare type Percentage = number; | ||
export declare type Coverage = Percentage; | ||
type Percentage = number; | ||
export type Coverage = Percentage; | ||
/** | ||
* See countPixels for the differences between the two modes. | ||
*/ | ||
export declare type CoverageMode = 'countComponents' | 'countPerimeters'; | ||
export declare type DsVisualCoverageDeNormalizedResult = DsVisualCoverageResult & { | ||
export type CoverageMode = 'countComponents' | 'countPerimeters'; | ||
export type DsVisualCoverageDeNormalizedResult = DsVisualCoverageResult & { | ||
team: string; | ||
@@ -65,3 +64,3 @@ component: string; | ||
}; | ||
export declare type DsVisualCoverageRunResult = { | ||
export type DsVisualCoverageRunResult = { | ||
stopped: boolean; | ||
@@ -71,10 +70,5 @@ totalDuration: Milliseconds; | ||
}; | ||
declare type ComponentName = string; | ||
export declare type TreeStats = { | ||
totalComponentsByName: Record<ComponentName, number>; | ||
totalComponentsByType: Record<ComponentType, number>; | ||
}; | ||
export declare type Logger = (...args: unknown[]) => void; | ||
export declare type PixelCounts = Uint32Array; | ||
export declare type Coordinates = { | ||
export type Logger = (...args: unknown[]) => void; | ||
export type PixelCounts = Uint32Array; | ||
export type Coordinates = { | ||
top: number; | ||
@@ -85,6 +79,6 @@ left: number; | ||
}; | ||
export declare type TopLeftWidthHeight = Uint16Array; | ||
export declare type Rect = TopLeftWidthHeight; | ||
export declare type Milliseconds = number; | ||
export declare type Duration = { | ||
export type TopLeftWidthHeight = Uint16Array; | ||
export type Rect = TopLeftWidthHeight; | ||
export type Milliseconds = number; | ||
export type Duration = { | ||
blockingDuration: Milliseconds; | ||
@@ -95,3 +89,3 @@ nonBlockingDuration: Milliseconds; | ||
}; | ||
export declare type ChildData = { | ||
export type ChildData = { | ||
rect: Rect; | ||
@@ -102,9 +96,9 @@ dsComponentType: ComponentType; | ||
}; | ||
export declare type RgbColor = string; | ||
export declare type ReadableChar = string; | ||
export declare type WeightByComponentName = Record<'emptyPixel' | 'nonDsComponent' | 'unknownDsComponent' | ComponentNames, number>; | ||
export declare type PixelByPixelType = Record<PixelType, Pixel>; | ||
export declare type ColorByPixelType = Record<PixelType, RgbColor>; | ||
export declare type ReadableCharByPixel = Record<Pixel, ReadableChar>; | ||
export type RgbColor = string; | ||
export type ReadableChar = string; | ||
export type WeightByComponentName = Record<'emptyPixel' | 'nonDsComponent' | 'unknownDsComponent' | ComponentNames, number>; | ||
export type PixelByPixelType = Record<PixelType, Pixel>; | ||
export type ColorByPixelType = Record<PixelType, RgbColor>; | ||
export type ReadableCharByPixel = Record<Pixel, ReadableChar>; | ||
export {}; | ||
//# sourceMappingURL=types.d.ts.map |
import type { CoverageContainer, DsVisualCoverageDeNormalizedResult, DsVisualCoverageResult, Rect } from '../types'; | ||
declare type Params = { | ||
type Params = { | ||
result: DsVisualCoverageResult; | ||
@@ -4,0 +4,0 @@ dsVisualCoverageContainerData: { |
{ | ||
"name": "@preply/ds-visual-coverage-core", | ||
"version": "0.97.1", | ||
"version": "0.97.2", | ||
"publishConfig": { | ||
@@ -16,3 +16,3 @@ "access": "public" | ||
"lint": "run --top-level eslint --ext .js,.ts,.tsx,.mdx *.config.js src/", | ||
"test": "run --top-level jest --coverage", | ||
"test": "run --top-level vitest --coverage --watch=false", | ||
"build": "NODE_ENV=production && run build:rollup", | ||
@@ -23,8 +23,8 @@ "build:rollup": "run --top-level rollup -c rollup.config.js", | ||
"dependencies": { | ||
"@preply/ds-visual-coverage-component-names": "0.97.1" | ||
"@preply/ds-visual-coverage-component-names": "0.97.2" | ||
}, | ||
"peerDependencies": { | ||
"@preply/ds-visual-coverage-component-names": "0.97.1" | ||
"@preply/ds-visual-coverage-component-names": "0.97.2" | ||
}, | ||
"gitHead": "4f0b9b1b6e755137bf53d7f19f5b2833f6609053" | ||
"gitHead": "baae2278c4ff001f6e4381207576816c74cc7146" | ||
} |
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
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
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
189406
1660
+ Added@preply/ds-visual-coverage-component-names@0.97.2(transitive)
- Removed@preply/ds-visual-coverage-component-names@0.97.1(transitive)