@preply/ds-visual-coverage-core
Advanced tools
Comparing version 0.97.4 to 0.97.5-beta.30c93b8c642527dc50deae63b8b16639e095a1ab.0
import { defaultReadableCharByPixelType } from '../core/constants.js'; | ||
/* eslint-disable no-plusplus */ | ||
function getReadableBitmap(params) { | ||
@@ -19,2 +18,2 @@ const { width, bitmap, readableCharByPixelType = defaultReadableCharByPixelType } = params; | ||
export { getReadableBitmap }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0UmVhZGFibGVCaXRtYXAuanMiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iaXRtYXAvZ2V0UmVhZGFibGVCaXRtYXAudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tcGx1c3BsdXMgKi9cblxuaW1wb3J0IHsgZGVmYXVsdFJlYWRhYmxlQ2hhckJ5UGl4ZWxUeXBlIH0gZnJvbSAnLi4vY29yZS9jb25zdGFudHMnO1xuaW1wb3J0IHR5cGUgeyBCaXRtYXAsIFJlYWRhYmxlQ2hhckJ5UGl4ZWwgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRSZWFkYWJsZUJpdG1hcChwYXJhbXM6IHtcbiAgICB3aWR0aDogbnVtYmVyO1xuICAgIGJpdG1hcDogQml0bWFwO1xuICAgIHJlYWRhYmxlQ2hhckJ5UGl4ZWxUeXBlPzogUmVhZGFibGVDaGFyQnlQaXhlbDtcbn0pOiBzdHJpbmcge1xuICAgIGNvbnN0IHsgd2lkdGgsIGJpdG1hcCwgcmVhZGFibGVDaGFyQnlQaXhlbFR5cGUgPSBkZWZhdWx0UmVhZGFibGVDaGFyQnlQaXhlbFR5cGUgfSA9IHBhcmFtcztcbiAgICBsZXQgc3RyaW5nID0gJyc7XG5cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGJpdG1hcC5sZW5ndGg7IGkrKykge1xuICAgICAgICBpZiAoaSAlIHdpZHRoID09PSAwKSB7XG4gICAgICAgICAgICBzdHJpbmcgKz0gJ1xcbic7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBwaXhlbCA9IGJpdG1hcFtpXS50b1N0cmluZygpO1xuXG4gICAgICAgIGNvbnN0IHByaW50ZWRQaXhlbCA9IHJlYWRhYmxlQ2hhckJ5UGl4ZWxUeXBlW3BpeGVsXTtcblxuICAgICAgICBzdHJpbmcgKz0gcHJpbnRlZFBpeGVsO1xuICAgIH1cblxuICAgIHJldHVybiBzdHJpbmc7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQTtBQUtNLFNBQVUsaUJBQWlCLENBQUMsTUFJakMsRUFBQTtJQUNHLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLHVCQUF1QixHQUFHLDhCQUE4QixFQUFFLEdBQUcsTUFBTSxDQUFDO0lBQzNGLElBQUksTUFBTSxHQUFHLEVBQUUsQ0FBQztBQUVoQixJQUFBLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFO0FBQ3BDLFFBQUEsSUFBSSxDQUFDLEdBQUcsS0FBSyxLQUFLLENBQUMsRUFBRTtZQUNqQixNQUFNLElBQUksSUFBSSxDQUFDO0FBQ2xCLFNBQUE7UUFFRCxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUM7QUFFbkMsUUFBQSxNQUFNLFlBQVksR0FBRyx1QkFBdUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVwRCxNQUFNLElBQUksWUFBWSxDQUFDO0FBQzFCLEtBQUE7QUFFRCxJQUFBLE9BQU8sTUFBTSxDQUFDO0FBQ2xCOzs7OyJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0UmVhZGFibGVCaXRtYXAuanMiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iaXRtYXAvZ2V0UmVhZGFibGVCaXRtYXAudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZGVmYXVsdFJlYWRhYmxlQ2hhckJ5UGl4ZWxUeXBlIH0gZnJvbSAnLi4vY29yZS9jb25zdGFudHMnO1xuaW1wb3J0IHR5cGUgeyBCaXRtYXAsIFJlYWRhYmxlQ2hhckJ5UGl4ZWwgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRSZWFkYWJsZUJpdG1hcChwYXJhbXM6IHtcbiAgICB3aWR0aDogbnVtYmVyO1xuICAgIGJpdG1hcDogQml0bWFwO1xuICAgIHJlYWRhYmxlQ2hhckJ5UGl4ZWxUeXBlPzogUmVhZGFibGVDaGFyQnlQaXhlbDtcbn0pOiBzdHJpbmcge1xuICAgIGNvbnN0IHsgd2lkdGgsIGJpdG1hcCwgcmVhZGFibGVDaGFyQnlQaXhlbFR5cGUgPSBkZWZhdWx0UmVhZGFibGVDaGFyQnlQaXhlbFR5cGUgfSA9IHBhcmFtcztcbiAgICBsZXQgc3RyaW5nID0gJyc7XG5cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGJpdG1hcC5sZW5ndGg7IGkrKykge1xuICAgICAgICBpZiAoaSAlIHdpZHRoID09PSAwKSB7XG4gICAgICAgICAgICBzdHJpbmcgKz0gJ1xcbic7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBwaXhlbCA9IGJpdG1hcFtpXS50b1N0cmluZygpO1xuXG4gICAgICAgIGNvbnN0IHByaW50ZWRQaXhlbCA9IHJlYWRhYmxlQ2hhckJ5UGl4ZWxUeXBlW3BpeGVsXTtcblxuICAgICAgICBzdHJpbmcgKz0gcHJpbnRlZFBpeGVsO1xuICAgIH1cblxuICAgIHJldHVybiBzdHJpbmc7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFHTSxTQUFVLGlCQUFpQixDQUFDLE1BSWpDLEVBQUE7SUFDRyxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSx1QkFBdUIsR0FBRyw4QkFBOEIsRUFBRSxHQUFHLE1BQU0sQ0FBQztJQUMzRixJQUFJLE1BQU0sR0FBRyxFQUFFLENBQUM7QUFFaEIsSUFBQSxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsTUFBTSxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtBQUNwQyxRQUFBLElBQUksQ0FBQyxHQUFHLEtBQUssS0FBSyxDQUFDLEVBQUU7WUFDakIsTUFBTSxJQUFJLElBQUksQ0FBQztBQUNsQixTQUFBO1FBRUQsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO0FBRW5DLFFBQUEsTUFBTSxZQUFZLEdBQUcsdUJBQXVCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFcEQsTUFBTSxJQUFJLFlBQVksQ0FBQztBQUMxQixLQUFBO0FBRUQsSUFBQSxPQUFPLE1BQU0sQ0FBQztBQUNsQjs7OzsifQ== |
import { getReadableBitmap } from './getReadableBitmap.js'; | ||
/* eslint-disable no-plusplus */ | ||
function logBitmap(params) { | ||
@@ -10,2 +9,2 @@ const { width, logger, bitmap } = params; | ||
export { logBitmap }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nQml0bWFwLmpzIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYml0bWFwL2xvZ0JpdG1hcC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1wbHVzcGx1cyAqL1xuXG5pbXBvcnQgdHlwZSB7IEJpdG1hcCwgTG9nZ2VyIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5pbXBvcnQgeyBnZXRSZWFkYWJsZUJpdG1hcCB9IGZyb20gJy4vZ2V0UmVhZGFibGVCaXRtYXAnO1xuXG5leHBvcnQgZnVuY3Rpb24gbG9nQml0bWFwKHBhcmFtczogeyB3aWR0aDogbnVtYmVyOyBsb2dnZXI6IExvZ2dlcjsgYml0bWFwOiBCaXRtYXAgfSk6IHZvaWQge1xuICAgIGNvbnN0IHsgd2lkdGgsIGxvZ2dlciwgYml0bWFwIH0gPSBwYXJhbXM7XG5cbiAgICBsb2dnZXIoZ2V0UmVhZGFibGVCaXRtYXAoeyB3aWR0aCwgYml0bWFwIH0pKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBO0FBTU0sU0FBVSxTQUFTLENBQUMsTUFBeUQsRUFBQTtJQUMvRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFFekMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUMsQ0FBQztBQUNqRDs7OzsifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nQml0bWFwLmpzIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYml0bWFwL2xvZ0JpdG1hcC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEJpdG1hcCwgTG9nZ2VyIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5pbXBvcnQgeyBnZXRSZWFkYWJsZUJpdG1hcCB9IGZyb20gJy4vZ2V0UmVhZGFibGVCaXRtYXAnO1xuXG5leHBvcnQgZnVuY3Rpb24gbG9nQml0bWFwKHBhcmFtczogeyB3aWR0aDogbnVtYmVyOyBsb2dnZXI6IExvZ2dlcjsgYml0bWFwOiBCaXRtYXAgfSk6IHZvaWQge1xuICAgIGNvbnN0IHsgd2lkdGgsIGxvZ2dlciwgYml0bWFwIH0gPSBwYXJhbXM7XG5cbiAgICBsb2dnZXIoZ2V0UmVhZGFibGVCaXRtYXAoeyB3aWR0aCwgYml0bWFwIH0pKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUlNLFNBQVUsU0FBUyxDQUFDLE1BQXlELEVBQUE7SUFDL0UsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLEdBQUcsTUFBTSxDQUFDO0lBRXpDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDakQ7Ozs7In0= |
@@ -7,4 +7,2 @@ import { createBitmap } from '../bitmap/createBitmap.js'; | ||
/* eslint-disable no-continue */ | ||
/* eslint-disable no-plusplus */ | ||
function countPixels(params) { | ||
@@ -225,2 +223,2 @@ const { logger, offset, elementRect, childrenData, coverageMode, printAsciiArt, pixelByPixelType, weightByComponentName, } = params; | ||
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    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":";;;;;;AAAA;AACA;AA+CM,SAAU,WAAW,CAAC,MAAc,EAAA;AACtC,IAAA,MAAM,EACF,MAAM,EACN,MAAM,EACN,WAAW,EACX,YAAY,EACZ,YAAY,EACZ,aAAa,EACb,gBAAgB,EAChB,qBAAqB,GACxB,GAAG,MAAM,CAAC;AAEX,IAAA,MAAM,KAAK,GAAiB,IAAI,CAAC,GAAG,EAAE,CAAC;AAEvC,IAAA,MAAM,MAAM,GAAG,YAAY,CACvB,iBAAiB,CAAC,WAAW,EAAE,QAAQ,CAAC,EACxC,iBAAiB,CAAC,WAAW,EAAE,OAAO,CAAC,CAC1C,CAAC;AAEF,IAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;AACjD,QAAA,MAAM,SAAS,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;AAClC,QAAA,IAAI,CAAC,SAAS;AACV,YAAA,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAA,sCAAA,CAAwC,CAAC,CAAC;QAElF,MAAM,EAAE,IAAI,EAAE,eAAe,EAAE,sBAAsB,EAAE,eAAe,EAAE,GAAG,SAAS,CAAC;QAErF,MAAM,uBAAuB,GAAkB,sBAAsB;cAC/D,oBAAoB;cACpB,eAAe,CAAC;AAEtB,QAAA,MAAM,KAAK,GAAG,gBAAgB,CAAC,uBAAuB,CAAC,CAAC;AAExD,QAAA,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC;AAC7B,QAAA,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC;QAE/B,MAAM,OAAO,GAAG,iBAAiB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAC/C,MAAM,QAAQ,GAAG,iBAAiB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QACjD,MAAM,SAAS,GAAG,iBAAiB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACnD,MAAM,UAAU,GAAG,iBAAiB,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QACrD,MAAM,SAAS,GAAG,iBAAiB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAC3D,MAAM,YAAY,GAAG,iBAAiB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;AAE7D,QAAA,MAAM,MAAM,GAAG,qBAAqB,CAAC,eAAe,KAAA,IAAA,IAAf,eAAe,KAAA,KAAA,CAAA,GAAf,eAAe,GAAI,gBAAgB,CAAC,CAAC;QAC1E,KAAK,IAAI,UAAU,GAAG,CAAC,EAAE,UAAU,GAAG,MAAM,EAAE,UAAU,EAAE,EAAE;;AAExD,YAAA,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,SAAS,GAAG,UAAU,CAAC,CAAC;AACzD,YAAA,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,SAAS,GAAG,UAAU,GAAG,CAAC,GAAG,UAAU,CAAC,CAAC;AAE7E,YAAA,KAAK,IAAI,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC,GAAI,WAAW,EAAE,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8BvE,gBAAA,MAAM,uBAAuB,GAAG,GAAG,GAAG,MAAM,CAAC;gBAC7C,MAAM,2BAA2B,GAAG,uBAAuB,CAAC;AAE5D,gBAAA,MAAM,mCAAmC,GAAG,YAAY,KAAK,iBAAiB,CAAC;gBAE/E,IAAI,mCAAmC,IAAI,2BAA2B;oBAAE,MAAM;;AAG9E,gBAAA,MAAM,yBAAyB,GAC3B,WAAW,IAAI,QAAQ,GAAG,UAAU,GAAG,SAAS,IAAI,WAAW,IAAI,YAAY,CAAC;AACpF,gBAAA,IAAI,yBAAyB;oBAAE,MAAM;AAErC,gBAAA,MAAM,wBAAwB,GAAG,WAAW,GAAG,CAAC,CAAC;AACjD,gBAAA,IAAI,wBAAwB;oBAAE,SAAS;;;;;;;;;;;;;;gBAevC,MAAM,yBAAyB,GAAG,GAAG,IAAI,CAAC,IAAI,GAAG,GAAG,SAAS,CAAC;AAC9D,gBAAA,IAAI,yBAAyB,EAAE;AAC3B,oBAAA,cAAc,CAAC;wBACX,GAAG;wBACH,MAAM;AACN,wBAAA,IAAI,EAAE,WAAW;AACjB,wBAAA,KAAK,EAAE,KAAK;AACZ,wBAAA,KAAK,EAAE,iBAAiB,CAAC,WAAW,EAAE,OAAO,CAAC;AACjD,qBAAA,CAAC,CAAC;oBAEH,IAAI,YAAY,KAAK,iBAAiB;;wBAElC,MAAM;AACb,iBAAA;;;;;;;;;;;;;;gBAeD,MAAM,4BAA4B,GAAG,MAAM,IAAI,CAAC,IAAI,MAAM,GAAG,SAAS,CAAC;AACvE,gBAAA,IAAI,4BAA4B,EAAE;AAC9B,oBAAA,cAAc,CAAC;AACX,wBAAA,GAAG,EAAE,MAAM;wBACX,MAAM;AACN,wBAAA,IAAI,EAAE,WAAW;AACjB,wBAAA,KAAK,EAAE,KAAK;AACZ,wBAAA,KAAK,EAAE,iBAAiB,CAAC,WAAW,EAAE,OAAO,CAAC;AACjD,qBAAA,CAAC,CAAC;AACN,iBAAA;AACJ,aAAA;;AAGD,YAAA,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,GAAG,UAAU,CAAC,CAAC;AAC5D,YAAA,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,GAAG,SAAS,GAAG,CAAC,GAAG,UAAU,CAAC,CAAC;AAC7E,YAAA,KAAK,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,SAAS,CAAC,GAAI,UAAU,EAAE,EAAE;gBACnE,IAAI,YAAY,KAAK,iBAAiB;;oBAElC,MAAM;;AAGV,gBAAA,MAAM,yBAAyB,GAAG,IAAI,GAAG,KAAK,CAAC;AAC/C,gBAAA,IAAI,yBAAyB;oBAAE,MAAM;;AAGrC,gBAAA,MAAM,0BAA0B,GAC5B,UAAU,IAAI,OAAO,GAAG,SAAS,GAAG,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,SAAS,CAAC;AAEjF,gBAAA,IAAI,0BAA0B;oBAAE,MAAM;AAEtC,gBAAA,MAAM,uBAAuB,GAAG,UAAU,GAAG,CAAC,CAAC;AAC/C,gBAAA,IAAI,uBAAuB;oBAAE,SAAS;;;;;;;;;;;;;;;;;;;;AAqBtC,gBAAA,MAAM,6BAA6B,GAC/B,IAAI,IAAI,CAAC,IAAI,UAAU,GAAG,SAAS,IAAI,IAAI,GAAG,YAAY,CAAC;AAE/D,gBAAA,IAAI,6BAA6B,EAAE;AAC/B,oBAAA,cAAc,CAAC;wBACX,IAAI;wBACJ,MAAM;AACN,wBAAA,GAAG,EAAE,UAAU;AACf,wBAAA,KAAK,EAAE,KAAK;AACZ,wBAAA,KAAK,EAAE,iBAAiB,CAAC,WAAW,EAAE,OAAO,CAAC;AACjD,qBAAA,CAAC,CAAC;AACN,iBAAA;;;;;;;;;;;;;;;;;;;;AAqBD,gBAAA,MAAM,+BAA+B,GACjC,KAAK,IAAI,CAAC,IAAI,UAAU,GAAG,SAAS,IAAI,KAAK,GAAG,YAAY,CAAC;AACjE,gBAAA,IAAI,+BAA+B,EAAE;AACjC,oBAAA,cAAc,CAAC;wBACX,MAAM;AACN,wBAAA,GAAG,EAAE,UAAU;AACf,wBAAA,IAAI,EAAE,KAAK;AACX,wBAAA,KAAK,EAAE,KAAK;AACZ,wBAAA,KAAK,EAAE,iBAAiB,CAAC,WAAW,EAAE,OAAO,CAAC;AACjD,qBAAA,CAAC,CAAC;AACN,iBAAA;AACJ,aAAA;AACJ,SAAA;AACJ,KAAA;AAED,IAAA,MAAM,WAAW,GAAG,iBAAiB,EAAE,CAAC;AACxC,IAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;AAC3C,QAAA,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;AAC5B,KAAA;AAED,IAAA,IAAI,aAAa,EAAE;AACf,QAAA,SAAS,CAAC;YACN,MAAM;YACN,MAAM;AACN,YAAA,KAAK,EAAE,iBAAiB,CAAC,WAAW,EAAE,OAAO,CAAC;AACjD,SAAA,CAAC,CAAC;AACN,KAAA;IAED,OAAO;QACH,MAAM;QACN,WAAW;AACX,QAAA,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK;KAC/B,CAAC;AACN;;;;"} | ||
//# 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        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 { getRectCoordinate } from '../rect/rectProperties.js'; | ||
/* eslint-disable no-plusplus */ | ||
function addSvgRectangles(params) { | ||
@@ -22,3 +21,2 @@ const { svgRenderer, childrenData, weightByComponentName, colorByPixelType } = params; | ||
if (width < 0 || height < 0) { | ||
// eslint-disable-next-line no-continue | ||
continue; | ||
@@ -43,2 +41,2 @@ } | ||
export { addSvgRectangles }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkU3ZnUmVjdGFuZ2xlcy5qcyIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2RlYnVnL2FkZFN2Z1JlY3RhbmdsZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tcGx1c3BsdXMgKi9cblxuaW1wb3J0IHsgZ2V0UmVjdENvb3JkaW5hdGUgfSBmcm9tICcuLi9yZWN0L3JlY3RQcm9wZXJ0aWVzJztcbmltcG9ydCB0eXBlIHsgQ2hpbGREYXRhLCBDb2xvckJ5UGl4ZWxUeXBlLCBDb21wb25lbnRUeXBlLCBXZWlnaHRCeUNvbXBvbmVudE5hbWUgfSBmcm9tICcuLi90eXBlcyc7XG5cbnR5cGUgTG9vcFBhcmFtcyA9IHtcbiAgICBjaGlsZHJlbkRhdGE6IENoaWxkRGF0YVtdO1xuICAgIHN2Z1JlbmRlcmVyOiBTVkdTVkdFbGVtZW50O1xuICAgIGNvbG9yQnlQaXhlbFR5cGU6IENvbG9yQnlQaXhlbFR5cGU7XG4gICAgd2VpZ2h0QnlDb21wb25lbnROYW1lOiBXZWlnaHRCeUNvbXBvbmVudE5hbWU7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gYWRkU3ZnUmVjdGFuZ2xlcyhwYXJhbXM6IExvb3BQYXJhbXMpOiB2b2lkIHtcbiAgICBjb25zdCB7IHN2Z1JlbmRlcmVyLCBjaGlsZHJlbkRhdGEsIHdlaWdodEJ5Q29tcG9uZW50TmFtZSwgY29sb3JCeVBpeGVsVHlwZSB9ID0gcGFyYW1zO1xuXG4gICAgLy8gU1ZHcyBkbyBub3Qgc3VwcG9ydCBpbm5lciBib3JkZXIuIFNvIG11bHRpcGxlIHJlY3RhbmdsZXMgYXJlIGRyYXduIHRvIHNpbXVsYXRlIGl0XG4gICAgZm9yIChsZXQgaSA9IDAsIG4gPSBjaGlsZHJlbkRhdGEubGVuZ3RoOyBpIDwgbjsgaSsrKSB7XG4gICAgICAgIGNvbnN0IGNoaWxkRGF0YSA9IGNoaWxkcmVuRGF0YVtpXTtcbiAgICAgICAgaWYgKCFjaGlsZERhdGEpXG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYE5vIGNoaWxkRGF0YSBhdCAke2l9ICh0aGlzIHNob3VsZCBiZSBhIFRTLW9ubHkgcHJvdGVjdGlvbilgKTtcblxuICAgICAgICBjb25zdCB7IHJlY3QsIGRzQ29tcG9uZW50VHlwZSwgaXNDaGlsZE9mVWlEc0NvbXBvbmVudCwgZHNDb21wb25lbnROYW1lIH0gPSBjaGlsZERhdGE7XG5cbiAgICAgICAgY29uc3QgYWRqdXN0ZWRTc0NvbXBvbmVudFR5cGU6IENvbXBvbmVudFR5cGUgPSBpc0NoaWxkT2ZVaURzQ29tcG9uZW50XG4gICAgICAgICAgICA/ICd1bmtub3duRHNDb21wb25lbnQnIC8vIGNoaWxkcmVuIG9mIHVpIGNvbXBvbmVudHMgYXJlIHRyZWF0ZWQgYXMgRFMgY29tcG9uZW50cyB0b29cbiAgICAgICAgICAgIDogZHNDb21wb25lbnRUeXBlO1xuXG4gICAgICAgIGlmIChzdmdSZW5kZXJlcikge1xuICAgICAgICAgICAgLy8gd2VpZ2h0IGlzIGFsc28gdXNlZCBvdCBkcmF3IGFuIGludGVybmFsIHJlY3RhbmdsZVxuICAgICAgICAgICAgY29uc3Qgd2VpZ2h0ID0gd2VpZ2h0QnlDb21wb25lbnROYW1lW2RzQ29tcG9uZW50TmFtZSA/PyAnbm9uRHNDb21wb25lbnQnXTtcbiAgICAgICAgICAgIGZvciAobGV0IGogPSAwOyBqIDwgd2VpZ2h0OyBqKyspIHtcbiAgICAgICAgICAgICAgICBjb25zdCB3aWR0aCA9IGdldFJlY3RDb29yZGluYXRlKHJlY3QsICd3aWR0aCcpIC0gaiAqIDI7XG4gICAgICAgICAgICAgICAgY29uc3QgaGVpZ2h0ID0gZ2V0UmVjdENvb3JkaW5hdGUocmVjdCwgJ2hlaWdodCcpIC0gaiAqIDI7XG4gICAgICAgICAgICAgICAgaWYgKHdpZHRoIDwgMCB8fCBoZWlnaHQgPCAwKSB7XG4gICAgICAgICAgICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb250aW51ZVxuICAgICAgICAgICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICBjb25zdCBzdmdSZWN0ID0gZ2xvYmFsVGhpcy5kb2N1bWVudC5jcmVhdGVFbGVtZW50TlMoXG4gICAgICAgICAgICAgICAgICAgICdodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZycsXG4gICAgICAgICAgICAgICAgICAgICdyZWN0JyxcbiAgICAgICAgICAgICAgICApO1xuXG4gICAgICAgICAgICAgICAgLy8gYG9mZnNldGAgaXMgbm90IGNvbnNpZGVyZWQgYmVjYXVzZSB0aGUgc3ZnIHNob3VsZCBiZSBwbGFjZWQgYXQgdGhlIHRvcC1sZWZ0IGNvcm5lciBvZiB0aGUgdmlld3BvcnRcbiAgICAgICAgICAgICAgICBzdmdSZWN0LnNldEF0dHJpYnV0ZSgneScsIChnZXRSZWN0Q29vcmRpbmF0ZShyZWN0LCAndG9wJykgKyBqKS50b1N0cmluZygpKTtcbiAgICAgICAgICAgICAgICBzdmdSZWN0LnNldEF0dHJpYnV0ZSgneCcsIChnZXRSZWN0Q29vcmRpbmF0ZShyZWN0LCAnbGVmdCcpICsgaikudG9TdHJpbmcoKSk7XG4gICAgICAgICAgICAgICAgc3ZnUmVjdC5zZXRBdHRyaWJ1dGUoJ3dpZHRoJywgd2lkdGgudG9TdHJpbmcoKSk7XG4gICAgICAgICAgICAgICAgc3ZnUmVjdC5zZXRBdHRyaWJ1dGUoJ2hlaWdodCcsIGhlaWdodC50b1N0cmluZygpKTtcblxuICAgICAgICAgICAgICAgIHN2Z1JlY3Quc2V0QXR0cmlidXRlKCdvcGFjaXR5JywgJzAuMycpO1xuICAgICAgICAgICAgICAgIHN2Z1JlY3Quc2V0QXR0cmlidXRlKCdmaWxsJywgJ25vbmUnKTtcblxuICAgICAgICAgICAgICAgIHN2Z1JlY3Quc2V0QXR0cmlidXRlKCdzdHJva2Utd2lkdGgnLCAnMScpOyAvLyB0byBtYWtlIGl0IG1vcmUgdmlzaWJsZVxuICAgICAgICAgICAgICAgIHN2Z1JlY3Quc2V0QXR0cmlidXRlKCdzdHJva2UnLCBjb2xvckJ5UGl4ZWxUeXBlW2FkanVzdGVkU3NDb21wb25lbnRUeXBlXSk7XG5cbiAgICAgICAgICAgICAgICBzdmdSZW5kZXJlci5hcHBlbmRDaGlsZChzdmdSZWN0KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBO0FBWU0sU0FBVSxnQkFBZ0IsQ0FBQyxNQUFrQixFQUFBO0lBQy9DLE1BQU0sRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLHFCQUFxQixFQUFFLGdCQUFnQixFQUFFLEdBQUcsTUFBTSxDQUFDOztBQUd0RixJQUFBLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxZQUFZLENBQUMsTUFBTSxFQUFFLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUU7QUFDakQsUUFBQSxNQUFNLFNBQVMsR0FBRyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDbEMsUUFBQSxJQUFJLENBQUMsU0FBUztBQUNWLFlBQUEsTUFBTSxJQUFJLEtBQUssQ0FBQyxtQkFBbUIsQ0FBQyxDQUFBLHNDQUFBLENBQXdDLENBQUMsQ0FBQztRQUVsRixNQUFNLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxzQkFBc0IsRUFBRSxlQUFlLEVBQUUsR0FBRyxTQUFTLENBQUM7UUFFckYsTUFBTSx1QkFBdUIsR0FBa0Isc0JBQXNCO2NBQy9ELG9CQUFvQjtjQUNwQixlQUFlLENBQUM7QUFFdEIsUUFBQSxJQUFJLFdBQVcsRUFBRTs7QUFFYixZQUFBLE1BQU0sTUFBTSxHQUFHLHFCQUFxQixDQUFDLGVBQWUsS0FBQSxJQUFBLElBQWYsZUFBZSxLQUFBLEtBQUEsQ0FBQSxHQUFmLGVBQWUsR0FBSSxnQkFBZ0IsQ0FBQyxDQUFDO1lBQzFFLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7QUFDN0IsZ0JBQUEsTUFBTSxLQUFLLEdBQUcsaUJBQWlCLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7QUFDdkQsZ0JBQUEsTUFBTSxNQUFNLEdBQUcsaUJBQWlCLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7QUFDekQsZ0JBQUEsSUFBSSxLQUFLLEdBQUcsQ0FBQyxJQUFJLE1BQU0sR0FBRyxDQUFDLEVBQUU7O29CQUV6QixTQUFTO0FBQ1osaUJBQUE7QUFFRCxnQkFBQSxNQUFNLE9BQU8sR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FDL0MsNEJBQTRCLEVBQzVCLE1BQU0sQ0FDVCxDQUFDOztBQUdGLGdCQUFBLE9BQU8sQ0FBQyxZQUFZLENBQUMsR0FBRyxFQUFFLENBQUMsaUJBQWlCLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO0FBQzNFLGdCQUFBLE9BQU8sQ0FBQyxZQUFZLENBQUMsR0FBRyxFQUFFLENBQUMsaUJBQWlCLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO2dCQUM1RSxPQUFPLENBQUMsWUFBWSxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztnQkFDaEQsT0FBTyxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsTUFBTSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7QUFFbEQsZ0JBQUEsT0FBTyxDQUFDLFlBQVksQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7QUFDdkMsZ0JBQUEsT0FBTyxDQUFDLFlBQVksQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQUM7Z0JBRXJDLE9BQU8sQ0FBQyxZQUFZLENBQUMsY0FBYyxFQUFFLEdBQUcsQ0FBQyxDQUFDO2dCQUMxQyxPQUFPLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRSxnQkFBZ0IsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUM7QUFFMUUsZ0JBQUEsV0FBVyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztBQUNwQyxhQUFBO0FBQ0osU0FBQTtBQUNKLEtBQUE7QUFDTDs7OzsifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkU3ZnUmVjdGFuZ2xlcy5qcyIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2RlYnVnL2FkZFN2Z1JlY3RhbmdsZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0UmVjdENvb3JkaW5hdGUgfSBmcm9tICcuLi9yZWN0L3JlY3RQcm9wZXJ0aWVzJztcbmltcG9ydCB0eXBlIHsgQ2hpbGREYXRhLCBDb2xvckJ5UGl4ZWxUeXBlLCBDb21wb25lbnRUeXBlLCBXZWlnaHRCeUNvbXBvbmVudE5hbWUgfSBmcm9tICcuLi90eXBlcyc7XG5cbnR5cGUgTG9vcFBhcmFtcyA9IHtcbiAgICBjaGlsZHJlbkRhdGE6IENoaWxkRGF0YVtdO1xuICAgIHN2Z1JlbmRlcmVyOiBTVkdTVkdFbGVtZW50O1xuICAgIGNvbG9yQnlQaXhlbFR5cGU6IENvbG9yQnlQaXhlbFR5cGU7XG4gICAgd2VpZ2h0QnlDb21wb25lbnROYW1lOiBXZWlnaHRCeUNvbXBvbmVudE5hbWU7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gYWRkU3ZnUmVjdGFuZ2xlcyhwYXJhbXM6IExvb3BQYXJhbXMpOiB2b2lkIHtcbiAgICBjb25zdCB7IHN2Z1JlbmRlcmVyLCBjaGlsZHJlbkRhdGEsIHdlaWdodEJ5Q29tcG9uZW50TmFtZSwgY29sb3JCeVBpeGVsVHlwZSB9ID0gcGFyYW1zO1xuXG4gICAgLy8gU1ZHcyBkbyBub3Qgc3VwcG9ydCBpbm5lciBib3JkZXIuIFNvIG11bHRpcGxlIHJlY3RhbmdsZXMgYXJlIGRyYXduIHRvIHNpbXVsYXRlIGl0XG4gICAgZm9yIChsZXQgaSA9IDAsIG4gPSBjaGlsZHJlbkRhdGEubGVuZ3RoOyBpIDwgbjsgaSsrKSB7XG4gICAgICAgIGNvbnN0IGNoaWxkRGF0YSA9IGNoaWxkcmVuRGF0YVtpXTtcbiAgICAgICAgaWYgKCFjaGlsZERhdGEpXG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYE5vIGNoaWxkRGF0YSBhdCAke2l9ICh0aGlzIHNob3VsZCBiZSBhIFRTLW9ubHkgcHJvdGVjdGlvbilgKTtcblxuICAgICAgICBjb25zdCB7IHJlY3QsIGRzQ29tcG9uZW50VHlwZSwgaXNDaGlsZE9mVWlEc0NvbXBvbmVudCwgZHNDb21wb25lbnROYW1lIH0gPSBjaGlsZERhdGE7XG5cbiAgICAgICAgY29uc3QgYWRqdXN0ZWRTc0NvbXBvbmVudFR5cGU6IENvbXBvbmVudFR5cGUgPSBpc0NoaWxkT2ZVaURzQ29tcG9uZW50XG4gICAgICAgICAgICA/ICd1bmtub3duRHNDb21wb25lbnQnIC8vIGNoaWxkcmVuIG9mIHVpIGNvbXBvbmVudHMgYXJlIHRyZWF0ZWQgYXMgRFMgY29tcG9uZW50cyB0b29cbiAgICAgICAgICAgIDogZHNDb21wb25lbnRUeXBlO1xuXG4gICAgICAgIGlmIChzdmdSZW5kZXJlcikge1xuICAgICAgICAgICAgLy8gd2VpZ2h0IGlzIGFsc28gdXNlZCBvdCBkcmF3IGFuIGludGVybmFsIHJlY3RhbmdsZVxuICAgICAgICAgICAgY29uc3Qgd2VpZ2h0ID0gd2VpZ2h0QnlDb21wb25lbnROYW1lW2RzQ29tcG9uZW50TmFtZSA/PyAnbm9uRHNDb21wb25lbnQnXTtcbiAgICAgICAgICAgIGZvciAobGV0IGogPSAwOyBqIDwgd2VpZ2h0OyBqKyspIHtcbiAgICAgICAgICAgICAgICBjb25zdCB3aWR0aCA9IGdldFJlY3RDb29yZGluYXRlKHJlY3QsICd3aWR0aCcpIC0gaiAqIDI7XG4gICAgICAgICAgICAgICAgY29uc3QgaGVpZ2h0ID0gZ2V0UmVjdENvb3JkaW5hdGUocmVjdCwgJ2hlaWdodCcpIC0gaiAqIDI7XG4gICAgICAgICAgICAgICAgaWYgKHdpZHRoIDwgMCB8fCBoZWlnaHQgPCAwKSB7XG4gICAgICAgICAgICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgIGNvbnN0IHN2Z1JlY3QgPSBnbG9iYWxUaGlzLmRvY3VtZW50LmNyZWF0ZUVsZW1lbnROUyhcbiAgICAgICAgICAgICAgICAgICAgJ2h0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnJyxcbiAgICAgICAgICAgICAgICAgICAgJ3JlY3QnLFxuICAgICAgICAgICAgICAgICk7XG5cbiAgICAgICAgICAgICAgICAvLyBgb2Zmc2V0YCBpcyBub3QgY29uc2lkZXJlZCBiZWNhdXNlIHRoZSBzdmcgc2hvdWxkIGJlIHBsYWNlZCBhdCB0aGUgdG9wLWxlZnQgY29ybmVyIG9mIHRoZSB2aWV3cG9ydFxuICAgICAgICAgICAgICAgIHN2Z1JlY3Quc2V0QXR0cmlidXRlKCd5JywgKGdldFJlY3RDb29yZGluYXRlKHJlY3QsICd0b3AnKSArIGopLnRvU3RyaW5nKCkpO1xuICAgICAgICAgICAgICAgIHN2Z1JlY3Quc2V0QXR0cmlidXRlKCd4JywgKGdldFJlY3RDb29yZGluYXRlKHJlY3QsICdsZWZ0JykgKyBqKS50b1N0cmluZygpKTtcbiAgICAgICAgICAgICAgICBzdmdSZWN0LnNldEF0dHJpYnV0ZSgnd2lkdGgnLCB3aWR0aC50b1N0cmluZygpKTtcbiAgICAgICAgICAgICAgICBzdmdSZWN0LnNldEF0dHJpYnV0ZSgnaGVpZ2h0JywgaGVpZ2h0LnRvU3RyaW5nKCkpO1xuXG4gICAgICAgICAgICAgICAgc3ZnUmVjdC5zZXRBdHRyaWJ1dGUoJ29wYWNpdHknLCAnMC4zJyk7XG4gICAgICAgICAgICAgICAgc3ZnUmVjdC5zZXRBdHRyaWJ1dGUoJ2ZpbGwnLCAnbm9uZScpO1xuXG4gICAgICAgICAgICAgICAgc3ZnUmVjdC5zZXRBdHRyaWJ1dGUoJ3N0cm9rZS13aWR0aCcsICcxJyk7IC8vIHRvIG1ha2UgaXQgbW9yZSB2aXNpYmxlXG4gICAgICAgICAgICAgICAgc3ZnUmVjdC5zZXRBdHRyaWJ1dGUoJ3N0cm9rZScsIGNvbG9yQnlQaXhlbFR5cGVbYWRqdXN0ZWRTc0NvbXBvbmVudFR5cGVdKTtcblxuICAgICAgICAgICAgICAgIHN2Z1JlbmRlcmVyLmFwcGVuZENoaWxkKHN2Z1JlY3QpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4g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 |
@@ -1,2 +0,1 @@ | ||
/* eslint-disable no-param-reassign */ | ||
function getRectCoordinate(rect, property) { | ||
@@ -45,2 +44,2 @@ if (property === 'top') | ||
export { createEmptyRect, createRect, getRectCoordinate, getRectCoordinates, setRectCoordinate }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjdFByb3BlcnRpZXMuanMiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yZWN0L3JlY3RQcm9wZXJ0aWVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXBhcmFtLXJlYXNzaWduICovXG5cbmltcG9ydCB0eXBlIHsgQ29vcmRpbmF0ZXMsIFJlY3QsIFRvcExlZnRXaWR0aEhlaWdodCB9IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldFJlY3RDb29yZGluYXRlKFxuICAgIHJlY3Q6IFJlY3QsXG4gICAgcHJvcGVydHk6ICd0b3AnIHwgJ2xlZnQnIHwgJ3dpZHRoJyB8ICdoZWlnaHQnLFxuKTogbnVtYmVyIHtcbiAgICBpZiAocHJvcGVydHkgPT09ICd0b3AnKSByZXR1cm4gcmVjdFswXTtcbiAgICBpZiAocHJvcGVydHkgPT09ICdsZWZ0JykgcmV0dXJuIHJlY3RbMV07XG4gICAgaWYgKHByb3BlcnR5ID09PSAnd2lkdGgnKSByZXR1cm4gcmVjdFsyXTtcbiAgICBpZiAocHJvcGVydHkgPT09ICdoZWlnaHQnKSByZXR1cm4gcmVjdFszXTtcblxuICAgIHRocm93IG5ldyBFcnJvcihgSW52YWxpZCBwcm9wZXJ0eTogJHtwcm9wZXJ0eX1gKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldFJlY3RDb29yZGluYXRlcyhyZWN0OiBSZWN0KTogQ29vcmRpbmF0ZXMge1xuICAgIHJldHVybiB7XG4gICAgICAgIHRvcDogcmVjdFswXSxcbiAgICAgICAgbGVmdDogcmVjdFsxXSxcbiAgICAgICAgd2lkdGg6IHJlY3RbMl0sXG4gICAgICAgIGhlaWdodDogcmVjdFszXSxcbiAgICB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2V0UmVjdENvb3JkaW5hdGUoXG4gICAgbXV0YWJsZVJlY3Q6IFJlY3QsXG4gICAgcHJvcGVydHk6ICd0b3AnIHwgJ2xlZnQnIHwgJ3dpZHRoJyB8ICdoZWlnaHQnLFxuICAgIHZhbHVlOiBudW1iZXIsXG4pOiB2b2lkIHtcbiAgICBpZiAocHJvcGVydHkgPT09ICd0b3AnKSBtdXRhYmxlUmVjdFswXSA9IHZhbHVlO1xuICAgIGlmIChwcm9wZXJ0eSA9PT0gJ2xlZnQnKSBtdXRhYmxlUmVjdFsxXSA9IHZhbHVlO1xuICAgIGlmIChwcm9wZXJ0eSA9PT0gJ3dpZHRoJykgbXV0YWJsZVJlY3RbMl0gPSB2YWx1ZTtcbiAgICBpZiAocHJvcGVydHkgPT09ICdoZWlnaHQnKSBtdXRhYmxlUmVjdFszXSA9IHZhbHVlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlRW1wdHlSZWN0KCk6IFRvcExlZnRXaWR0aEhlaWdodCB7XG4gICAgcmV0dXJuIG5ldyBVaW50MTZBcnJheSg0KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVJlY3Qoe1xuICAgIHRvcCxcbiAgICBsZWZ0LFxuICAgIHdpZHRoLFxuICAgIGhlaWdodCxcbn06IHtcbiAgICB0b3A6IG51bWJlcjtcbiAgICBsZWZ0OiBudW1iZXI7XG4gICAgd2lkdGg6IG51bWJlcjtcbiAgICBoZWlnaHQ6IG51bWJlcjtcbn0pOiBUb3BMZWZ0V2lkdGhIZWlnaHQge1xuICAgIGNvbnN0IHJlY3QgPSBjcmVhdGVFbXB0eVJlY3QoKTtcblxuICAgIC8vIGVsZW1lbnRzIG91dHNpZGUgb2YgdGhlIHZpZXdwb3J0IGhhdmUgbmVnYXRpdmUgdmFsdWVzIChpdCBoYXBwZW5lZCB3aXRoIHRoZSBuYXZiYXIgb2YgdGhlIHJlYWN0IG5hdGl2ZSBzYW5kYm94KVxuICAgIHJlY3RbMF0gPSB0b3AgPiAwID8gTWF0aC5mbG9vcih0b3ApIDogMDtcbiAgICByZWN0WzFdID0gbGVmdCA+IDAgPyBNYXRoLmZsb29yKGxlZnQpIDogMDtcblxuICAgIHJlY3RbMl0gPSBNYXRoLmZsb29yKHdpZHRoKTtcbiAgICByZWN0WzNdID0gTWF0aC5mbG9vcihoZWlnaHQpO1xuXG4gICAgcmV0dXJuIHJlY3Q7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7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 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjdFByb3BlcnRpZXMuanMiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yZWN0L3JlY3RQcm9wZXJ0aWVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ29vcmRpbmF0ZXMsIFJlY3QsIFRvcExlZnRXaWR0aEhlaWdodCB9IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldFJlY3RDb29yZGluYXRlKFxuICAgIHJlY3Q6IFJlY3QsXG4gICAgcHJvcGVydHk6ICd0b3AnIHwgJ2xlZnQnIHwgJ3dpZHRoJyB8ICdoZWlnaHQnLFxuKTogbnVtYmVyIHtcbiAgICBpZiAocHJvcGVydHkgPT09ICd0b3AnKSByZXR1cm4gcmVjdFswXTtcbiAgICBpZiAocHJvcGVydHkgPT09ICdsZWZ0JykgcmV0dXJuIHJlY3RbMV07XG4gICAgaWYgKHByb3BlcnR5ID09PSAnd2lkdGgnKSByZXR1cm4gcmVjdFsyXTtcbiAgICBpZiAocHJvcGVydHkgPT09ICdoZWlnaHQnKSByZXR1cm4gcmVjdFszXTtcblxuICAgIHRocm93IG5ldyBFcnJvcihgSW52YWxpZCBwcm9wZXJ0eTogJHtwcm9wZXJ0eX1gKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldFJlY3RDb29yZGluYXRlcyhyZWN0OiBSZWN0KTogQ29vcmRpbmF0ZXMge1xuICAgIHJldHVybiB7XG4gICAgICAgIHRvcDogcmVjdFswXSxcbiAgICAgICAgbGVmdDogcmVjdFsxXSxcbiAgICAgICAgd2lkdGg6IHJlY3RbMl0sXG4gICAgICAgIGhlaWdodDogcmVjdFszXSxcbiAgICB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2V0UmVjdENvb3JkaW5hdGUoXG4gICAgbXV0YWJsZVJlY3Q6IFJlY3QsXG4gICAgcHJvcGVydHk6ICd0b3AnIHwgJ2xlZnQnIHwgJ3dpZHRoJyB8ICdoZWlnaHQnLFxuICAgIHZhbHVlOiBudW1iZXIsXG4pOiB2b2lkIHtcbiAgICBpZiAocHJvcGVydHkgPT09ICd0b3AnKSBtdXRhYmxlUmVjdFswXSA9IHZhbHVlO1xuICAgIGlmIChwcm9wZXJ0eSA9PT0gJ2xlZnQnKSBtdXRhYmxlUmVjdFsxXSA9IHZhbHVlO1xuICAgIGlmIChwcm9wZXJ0eSA9PT0gJ3dpZHRoJykgbXV0YWJsZVJlY3RbMl0gPSB2YWx1ZTtcbiAgICBpZiAocHJvcGVydHkgPT09ICdoZWlnaHQnKSBtdXRhYmxlUmVjdFszXSA9IHZhbHVlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlRW1wdHlSZWN0KCk6IFRvcExlZnRXaWR0aEhlaWdodCB7XG4gICAgcmV0dXJuIG5ldyBVaW50MTZBcnJheSg0KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVJlY3Qoe1xuICAgIHRvcCxcbiAgICBsZWZ0LFxuICAgIHdpZHRoLFxuICAgIGhlaWdodCxcbn06IHtcbiAgICB0b3A6IG51bWJlcjtcbiAgICBsZWZ0OiBudW1iZXI7XG4gICAgd2lkdGg6IG51bWJlcjtcbiAgICBoZWlnaHQ6IG51bWJlcjtcbn0pOiBUb3BMZWZ0V2lkdGhIZWlnaHQge1xuICAgIGNvbnN0IHJlY3QgPSBjcmVhdGVFbXB0eVJlY3QoKTtcblxuICAgIC8vIGVsZW1lbnRzIG91dHNpZGUgb2YgdGhlIHZpZXdwb3J0IGhhdmUgbmVnYXRpdmUgdmFsdWVzIChpdCBoYXBwZW5lZCB3aXRoIHRoZSBuYXZiYXIgb2YgdGhlIHJlYWN0IG5hdGl2ZSBzYW5kYm94KVxuICAgIHJlY3RbMF0gPSB0b3AgPiAwID8gTWF0aC5mbG9vcih0b3ApIDogMDtcbiAgICByZWN0WzFdID0gbGVmdCA+IDAgPyBNYXRoLmZsb29yKGxlZnQpIDogMDtcblxuICAgIHJlY3RbMl0gPSBNYXRoLmZsb29yKHdpZHRoKTtcbiAgICByZWN0WzNdID0gTWF0aC5mbG9vcihoZWlnaHQpO1xuXG4gICAgcmV0dXJuIHJlY3Q7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRWdCLFNBQUEsaUJBQWlCLENBQzdCLElBQVUsRUFDVixRQUE2QyxFQUFBO0lBRTdDLElBQUksUUFBUSxLQUFLLEtBQUs7QUFBRSxRQUFBLE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3ZDLElBQUksUUFBUSxLQUFLLE1BQU07QUFBRSxRQUFBLE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3hDLElBQUksUUFBUSxLQUFLLE9BQU87QUFBRSxRQUFBLE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3pDLElBQUksUUFBUSxLQUFLLFFBQVE7QUFBRSxRQUFBLE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBRTFDLElBQUEsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsUUFBUSxDQUFBLENBQUUsQ0FBQyxDQUFDO0FBQ3JELENBQUM7QUFFSyxTQUFVLGtCQUFrQixDQUFDLElBQVUsRUFBQTtJQUN6QyxPQUFPO0FBQ0gsUUFBQSxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztBQUNaLFFBQUEsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDYixRQUFBLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDO0FBQ2QsUUFBQSxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztLQUNsQixDQUFDO0FBQ04sQ0FBQztTQUVlLGlCQUFpQixDQUM3QixXQUFpQixFQUNqQixRQUE2QyxFQUM3QyxLQUFhLEVBQUE7SUFFYixJQUFJLFFBQVEsS0FBSyxLQUFLO0FBQUUsUUFBQSxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDO0lBQy9DLElBQUksUUFBUSxLQUFLLE1BQU07QUFBRSxRQUFBLFdBQVcsQ0FBQyxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUM7SUFDaEQsSUFBSSxRQUFRLEtBQUssT0FBTztBQUFFLFFBQUEsV0FBVyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQztJQUNqRCxJQUFJLFFBQVEsS0FBSyxRQUFRO0FBQUUsUUFBQSxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDO0FBQ3RELENBQUM7U0FFZSxlQUFlLEdBQUE7QUFDM0IsSUFBQSxPQUFPLElBQUksV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQzlCLENBQUM7QUFFSyxTQUFVLFVBQVUsQ0FBQyxFQUN2QixHQUFHLEVBQ0gsSUFBSSxFQUNKLEtBQUssRUFDTCxNQUFNLEdBTVQsRUFBQTtBQUNHLElBQUEsTUFBTSxJQUFJLEdBQUcsZUFBZSxFQUFFLENBQUM7O0lBRy9CLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3hDLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRTFDLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVCLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBRTdCLElBQUEsT0FBTyxJQUFJLENBQUM7QUFDaEI7Ozs7In0= |
@@ -1,2 +0,1 @@ | ||
/* eslint-disable no-console */ | ||
function logger(...args) { | ||
@@ -16,2 +15,2 @@ console.log(`%c Path coverage `, 'background: #FF7AAC; color: #121117; padding: 2px; border-radius: 2px;', ...args); | ||
export { createLogger, isActiveLogger }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlTG9nZ2VyLmpzIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvY3JlYXRlTG9nZ2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLWNvbnNvbGUgKi9cblxuaW1wb3J0IHsgTG9nZ2VyIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5mdW5jdGlvbiBsb2dnZXIoLi4uYXJnczogdW5rbm93bltdKSB7XG4gICAgY29uc29sZS5sb2coXG4gICAgICAgIGAlYyBQYXRoIGNvdmVyYWdlIGAsXG4gICAgICAgICdiYWNrZ3JvdW5kOiAjRkY3QUFDOyBjb2xvcjogIzEyMTExNzsgcGFkZGluZzogMnB4OyBib3JkZXItcmFkaXVzOiAycHg7JyxcbiAgICAgICAgLi4uYXJncyxcbiAgICApO1xufVxuXG5mdW5jdGlvbiBzaWxlbnRMb2dnZXIoKSB7XG4gICAgLy8gTG9ncyBub3RoaW5nLi4uXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVMb2dnZXIobG9nSXNFbmFibGVkOiBib29sZWFuKTogTG9nZ2VyIHtcbiAgICByZXR1cm4gbG9nSXNFbmFibGVkID8gbG9nZ2VyIDogc2lsZW50TG9nZ2VyO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNBY3RpdmVMb2dnZXIobWF5YmVGYWtlTG9nZ2VyOiB1bmtub3duKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIG1heWJlRmFrZUxvZ2dlciA9PT0gbG9nZ2VyO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0FBSUEsU0FBUyxNQUFNLENBQUMsR0FBRyxJQUFlLEVBQUE7SUFDOUIsT0FBTyxDQUFDLEdBQUcsQ0FDUCxDQUFtQixpQkFBQSxDQUFBLEVBQ25CLHdFQUF3RSxFQUN4RSxHQUFHLElBQUksQ0FDVixDQUFDO0FBQ04sQ0FBQztBQUVELFNBQVMsWUFBWSxHQUFBOztBQUVyQixDQUFDO0FBRUssU0FBVSxZQUFZLENBQUMsWUFBcUIsRUFBQTtJQUM5QyxPQUFPLFlBQVksR0FBRyxNQUFNLEdBQUcsWUFBWSxDQUFDO0FBQ2hELENBQUM7QUFFSyxTQUFVLGNBQWMsQ0FBQyxlQUF3QixFQUFBO0lBQ25ELE9BQU8sZUFBZSxLQUFLLE1BQU0sQ0FBQztBQUN0Qzs7OzsifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlTG9nZ2VyLmpzIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvY3JlYXRlTG9nZ2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExvZ2dlciB9IGZyb20gJy4uL3R5cGVzJztcblxuZnVuY3Rpb24gbG9nZ2VyKC4uLmFyZ3M6IHVua25vd25bXSkge1xuICAgIGNvbnNvbGUubG9nKFxuICAgICAgICBgJWMgUGF0aCBjb3ZlcmFnZSBgLFxuICAgICAgICAnYmFja2dyb3VuZDogI0ZGN0FBQzsgY29sb3I6ICMxMjExMTc7IHBhZGRpbmc6IDJweDsgYm9yZGVyLXJhZGl1czogMnB4OycsXG4gICAgICAgIC4uLmFyZ3MsXG4gICAgKTtcbn1cblxuZnVuY3Rpb24gc2lsZW50TG9nZ2VyKCkge1xuICAgIC8vIExvZ3Mgbm90aGluZy4uLlxufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlTG9nZ2VyKGxvZ0lzRW5hYmxlZDogYm9vbGVhbik6IExvZ2dlciB7XG4gICAgcmV0dXJuIGxvZ0lzRW5hYmxlZCA/IGxvZ2dlciA6IHNpbGVudExvZ2dlcjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQWN0aXZlTG9nZ2VyKG1heWJlRmFrZUxvZ2dlcjogdW5rbm93bik6IGJvb2xlYW4ge1xuICAgIHJldHVybiBtYXliZUZha2VMb2dnZXIgPT09IGxvZ2dlcjtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxTQUFTLE1BQU0sQ0FBQyxHQUFHLElBQWUsRUFBQTtJQUM5QixPQUFPLENBQUMsR0FBRyxDQUNQLENBQW1CLGlCQUFBLENBQUEsRUFDbkIsd0VBQXdFLEVBQ3hFLEdBQUcsSUFBSSxDQUNWLENBQUM7QUFDTixDQUFDO0FBRUQsU0FBUyxZQUFZLEdBQUE7O0FBRXJCLENBQUM7QUFFSyxTQUFVLFlBQVksQ0FBQyxZQUFxQixFQUFBO0lBQzlDLE9BQU8sWUFBWSxHQUFHLE1BQU0sR0FBRyxZQUFZLENBQUM7QUFDaEQsQ0FBQztBQUVLLFNBQVUsY0FBYyxDQUFDLGVBQXdCLEVBQUE7SUFDbkQsT0FBTyxlQUFlLEtBQUssTUFBTSxDQUFDO0FBQ3RDOzs7OyJ9 |
{ | ||
"name": "@preply/ds-visual-coverage-core", | ||
"version": "0.97.4", | ||
"version": "0.97.5-beta.30c93b8c642527dc50deae63b8b16639e095a1ab.0+30c93b8", | ||
"publishConfig": { | ||
@@ -15,3 +15,2 @@ "access": "public" | ||
"clean": "rm -rf dist", | ||
"lint": "run --top-level eslint --ext .js,.ts,.tsx,.mdx *.config.js src/", | ||
"test": "run --top-level vitest --coverage --watch=false", | ||
@@ -23,3 +22,3 @@ "build": "NODE_ENV=production && run build:rollup", | ||
"dependencies": { | ||
"@preply/ds-visual-coverage-component-names": "0.97.4" | ||
"@preply/ds-visual-coverage-component-names": "^0.97.5-beta.30c93b8c642527dc50deae63b8b16639e095a1ab.0+30c93b8" | ||
}, | ||
@@ -29,3 +28,3 @@ "peerDependencies": { | ||
}, | ||
"gitHead": "251484f5af8a10366d791c624c7c08f2abee997d" | ||
"gitHead": "30c93b8c642527dc50deae63b8b16639e095a1ab" | ||
} |
@@ -12,2 +12,3 @@ # `@preply/ds-visual-coverage-core` | ||
As a reminder, the general idea is to | ||
1. Collect components coordinates and size | ||
@@ -18,2 +19,3 @@ 2. Convert the coordinates and size into a virtual representation of the UI tree | ||
To visualize it: think of a page like the following, where we highlight outline the components (green = DS components, red = non-DS components) | ||
``` | ||
@@ -41,3 +43,5 @@ 🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥 | ||
``` | ||
the visual coverage utils convert them to an array like | ||
```js | ||
@@ -67,2 +71,3 @@ [ | ||
``` | ||
and then counts the coverage %. | ||
@@ -69,0 +74,0 @@ |
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
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
80
194346
1701
1
3