diff --git a/.github/workflows/next.yml b/.github/workflows/next.yml index 0f0b0308bd..b267c02da1 100644 --- a/.github/workflows/next.yml +++ b/.github/workflows/next.yml @@ -6,7 +6,7 @@ jobs: npm: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 - name: Use Node.js 16 uses: actions/setup-node@v3 with: diff --git a/.github/workflows/npm.yml b/.github/workflows/npm.yml index 38d2e10858..0eb6887380 100644 --- a/.github/workflows/npm.yml +++ b/.github/workflows/npm.yml @@ -6,7 +6,7 @@ jobs: npm: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 - name: Use Node.js 16 uses: actions/setup-node@v3 with: diff --git a/.github/workflows/publish-tag.yml b/.github/workflows/publish-tag.yml index eb22651477..69a8f50593 100644 --- a/.github/workflows/publish-tag.yml +++ b/.github/workflows/publish-tag.yml @@ -9,7 +9,7 @@ jobs: npm: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 - name: Use Node.js 16 uses: actions/setup-node@v3 with: diff --git a/.github/workflows/release3.yml b/.github/workflows/release3.yml deleted file mode 100644 index 0e5ed3ec49..0000000000 --- a/.github/workflows/release3.yml +++ /dev/null @@ -1,22 +0,0 @@ -name: release3 -on: - push: - branches: ['3.x'] -jobs: - npm: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - - name: Use Node.js 14 - uses: actions/setup-node@v3 - with: - node-version: 14 - registry-url: 'https://registry.npmjs.org/' - cache: yarn - - run: npm i -g yarn@1 - - run: yarn config set network-timeout 300000 - - run: yarn --frozen-lockfile - - run: yarn build - - run: npx pleb@5 publish --tag release-3.x - env: - NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} diff --git a/.github/workflows/release5.yml b/.github/workflows/release5.yml new file mode 100644 index 0000000000..5df351882e --- /dev/null +++ b/.github/workflows/release5.yml @@ -0,0 +1,20 @@ +name: release5 +on: + push: + branches: ['5.x'] +jobs: + npm: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - name: Use Node.js 16 + uses: actions/setup-node@v3 + with: + node-version: 16 + registry-url: 'https://registry.npmjs.org/' + cache: npm + - run: npm ci + - run: npm run build + - run: npx pleb@5 publish --tag release-5.x + env: + NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index c58c288333..bad4b665c0 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -8,10 +8,10 @@ jobs: strategy: fail-fast: false matrix: - node-version: [18, 16, 14] + node-version: [18, 16] os: [ubuntu-latest, windows-latest, macOS-latest] steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 - name: Use Node.js ${{ matrix.node-version }} uses: actions/setup-node@v3 with: diff --git a/.vscode/launch.json b/.vscode/launch.json index dd145fa041..e9d9f33620 100644 --- a/.vscode/launch.json +++ b/.vscode/launch.json @@ -11,7 +11,7 @@ "program": "${workspaceFolder}/scripts/test-runner.js", "args": ["--glob", "packages/*/dist/**/${fileBasenameNoExtension}.js", "--timeout", "999999"], "runtimeArgs": ["--enable-source-maps"], - "preLaunchTask": "npm: build", + "preLaunchTask": "npm: build:dev", "internalConsoleOptions": "openOnSessionStart", "skipFiles": ["/**"], "resolveSourceMapLocations": ["${workspaceFolder}/**", "!**/node_modules/**"], diff --git a/package-lock.json b/package-lock.json index 7b16e30726..9681b2c021 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,84 +10,106 @@ "packages/*" ], "devDependencies": { - "@file-services/memory": "^7.2.5", - "@file-services/node": "^7.2.5", - "@rollup/plugin-html": "^1.0.2", - "@rollup/plugin-node-resolve": "^15.0.2", - "@types/balanced-match": "^1.0.2", - "@types/chai": "^4.3.5", - "@types/chai-subset": "^1.3.3", - "@types/css-selector-tokenizer": "^0.7.1", - "@types/cssesc": "^3.0.0", - "@types/csso": "^5.0.0", - "@types/find-config": "^1.0.1", - "@types/flat": "^5.0.2", - "@types/js-beautify": "^1.13.3", - "@types/json-schema": "^7.0.11", - "@types/lodash.camelcase": "^4.3.7", - "@types/lodash.clonedeep": "^4.5.7", - "@types/lodash.clonedeepwith": "^4.5.7", - "@types/lodash.findlast": "^4.6.7", - "@types/lodash.upperfirst": "^4.3.7", - "@types/memory-fs": "^0.3.3", - "@types/mime": "^3.0.1", - "@types/mocha": "^10.0.1", + "@file-services/memory": "^8.3.3", + "@file-services/node": "^8.3.3", + "@rollup/plugin-html": "^1.0.3", + "@rollup/plugin-node-resolve": "^15.2.3", + "@types/balanced-match": "^3.0.2", + "@types/chai": "^4.3.11", + "@types/chai-subset": "^1.3.5", + "@types/css-selector-tokenizer": "^0.7.4", + "@types/cssesc": "^3.0.2", + "@types/csso": "^5.0.4", + "@types/find-config": "^1.0.4", + "@types/flat": "^5.0.5", + "@types/js-beautify": "^1.14.3", + "@types/json-schema": "^7.0.15", + "@types/lodash.camelcase": "^4.3.9", + "@types/lodash.clonedeep": "^4.5.9", + "@types/lodash.clonedeepwith": "^4.5.9", + "@types/lodash.findlast": "^4.6.9", + "@types/lodash.upperfirst": "^4.3.9", + "@types/memory-fs": "^0.3.7", + "@types/mime": "^3.0.4", + "@types/mocha": "^10.0.6", "@types/node": "14", - "@types/postcss-safe-parser": "^5.0.1", - "@types/react": "^18.2.0", - "@types/react-dom": "^18.2.1", - "@types/semver": "^7.3.13", - "@types/validate-npm-package-name": "^4.0.0", - "@types/yargs": "^17.0.24", - "@typescript-eslint/eslint-plugin": "^5.59.2", - "@typescript-eslint/parser": "^5.59.2", - "autoprefixer": "^10.4.14", - "c8": "^7.13.0", - "chai": "^4.3.7", + "@types/postcss-safe-parser": "^5.0.4", + "@types/react": "^18.2.46", + "@types/react-dom": "^18.2.18", + "@types/semver": "^7.5.6", + "@types/validate-npm-package-name": "^4.0.2", + "@types/yargs": "^17.0.32", + "@typescript-eslint/eslint-plugin": "^5.61.0", + "@typescript-eslint/parser": "^5.61.0", + "autoprefixer": "^10.4.16", + "c8": "^8.0.1", + "chai": "^4.3.10", "chai-subset": "^1.6.0", "create-listening-server": "^2.1.0", - "eslint": "^8.39.0", - "eslint-config-prettier": "^8.8.0", - "eslint-plugin-react": "^7.32.2", - "eslint-plugin-react-hooks": "^4.6.0", + "eslint": "^8.56.0", + "eslint-config-prettier": "^9.1.0", "file-loader": "^6.2.0", - "html-webpack-plugin": "^5.5.1", - "mini-css-extract-plugin": "^2.7.5", + "html-webpack-plugin": "^5.6.0", + "mini-css-extract-plugin": "^2.7.6", "mocha": "^10.2.0", "node-eval": "^2.0.0", "npm-run-all": "^4.1.5", - "playwright-chromium": "^1.33.0", - "postcss": "^8.4.23", + "playwright-chromium": "^1.40.1", + "postcss": "^8.4.32", "promise-assist": "^2.0.1", "raw-loader": "^4.0.2", "react": "^18.2.0", "react-dom": "^18.2.0", - "rimraf": "^5.0.0", - "rollup": "^3.21.3", + "rimraf": "^5.0.5", + "rollup": "^4.9.2", "source-map": "^0.7.4", - "source-map-loader": "^4.0.1", - "style-loader": "^3.3.2", + "source-map-loader": "^4.0.2", + "style-loader": "^3.3.3", "ts-expect": "^1.3.0", - "tsconfig-paths-webpack-plugin": "^4.0.1", - "typescript": "~5.0.4", + "tsconfig-paths-webpack-plugin": "^4.1.0", + "typescript": "~5.2.2", "url-loader": "^4.1.1", - "webpack": "^5.81.0", + "webpack": "^5.89.0", "yargs": "^17.7.2" }, "engines": { "node": ">=14.14.0" } }, + "node_modules/@aashutoshrathi/word-wrap": { + "version": "1.2.6", + "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", + "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/@bcoe/v8-coverage": { "version": "0.2.3", "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", "dev": true }, + "node_modules/@esbuild/aix-ppc64": { + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.19.11.tgz", + "integrity": "sha512-FnzU0LyE3ySQk7UntJO4+qIiQgI7KoODnZg5xzXIrFJlKd2P2gwHsHY4927xj9y5PJmJSzULiUCWmv7iWnNa7g==", + "cpu": [ + "ppc64" + ], + "optional": true, + "os": [ + "aix" + ], + "peer": true, + "engines": { + "node": ">=12" + } + }, "node_modules/@esbuild/android-arm": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.18.tgz", - "integrity": "sha512-EmwL+vUBZJ7mhFCs5lA4ZimpUH3WMAoqvOIYhVQwdIgSpHC8ImHdsRyhHAVxpDYUSm0lWvd63z0XH1IlImS2Qw==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.19.11.tgz", + "integrity": "sha512-5OVapq0ClabvKvQ58Bws8+wkLCV+Rxg7tUVbo9xu034Nm536QTII4YzhaFriQ7rMrorfnFKUsArD2lqKbFY4vw==", "cpu": [ "arm" ], @@ -101,9 +123,9 @@ } }, "node_modules/@esbuild/android-arm64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.18.tgz", - "integrity": "sha512-/iq0aK0eeHgSC3z55ucMAHO05OIqmQehiGay8eP5l/5l+iEr4EIbh4/MI8xD9qRFjqzgkc0JkX0LculNC9mXBw==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.19.11.tgz", + "integrity": "sha512-aiu7K/5JnLj//KOnOfEZ0D90obUkRzDMyqd/wNAUQ34m4YUPVhRZpnqKV9uqDGxT7cToSDnIHsGooyIczu9T+Q==", "cpu": [ "arm64" ], @@ -117,9 +139,9 @@ } }, "node_modules/@esbuild/android-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.18.tgz", - "integrity": "sha512-x+0efYNBF3NPW2Xc5bFOSFW7tTXdAcpfEg2nXmxegm4mJuVeS+i109m/7HMiOQ6M12aVGGFlqJX3RhNdYM2lWg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.19.11.tgz", + "integrity": "sha512-eccxjlfGw43WYoY9QgB82SgGgDbibcqyDTlk3l3C0jOVHKxrjdc9CTwDUQd0vkvYg5um0OH+GpxYvp39r+IPOg==", "cpu": [ "x64" ], @@ -133,9 +155,9 @@ } }, "node_modules/@esbuild/darwin-arm64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.18.tgz", - "integrity": "sha512-6tY+djEAdF48M1ONWnQb1C+6LiXrKjmqjzPNPWXhu/GzOHTHX2nh8Mo2ZAmBFg0kIodHhciEgUBtcYCAIjGbjQ==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.19.11.tgz", + "integrity": "sha512-ETp87DRWuSt9KdDVkqSoKoLFHYTrkyz2+65fj9nfXsaV3bMhTCjtQfw3y+um88vGRKRiF7erPrh/ZuIdLUIVxQ==", "cpu": [ "arm64" ], @@ -149,9 +171,9 @@ } }, "node_modules/@esbuild/darwin-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.18.tgz", - "integrity": "sha512-Qq84ykvLvya3dO49wVC9FFCNUfSrQJLbxhoQk/TE1r6MjHo3sFF2tlJCwMjhkBVq3/ahUisj7+EpRSz0/+8+9A==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.19.11.tgz", + "integrity": "sha512-fkFUiS6IUK9WYUO/+22omwetaSNl5/A8giXvQlcinLIjVkxwTLSktbF5f/kJMftM2MJp9+fXqZ5ezS7+SALp4g==", "cpu": [ "x64" ], @@ -165,9 +187,9 @@ } }, "node_modules/@esbuild/freebsd-arm64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.18.tgz", - "integrity": "sha512-fw/ZfxfAzuHfaQeMDhbzxp9mc+mHn1Y94VDHFHjGvt2Uxl10mT4CDavHm+/L9KG441t1QdABqkVYwakMUeyLRA==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.19.11.tgz", + "integrity": "sha512-lhoSp5K6bxKRNdXUtHoNc5HhbXVCS8V0iZmDvyWvYq9S5WSfTIHU2UGjcGt7UeS6iEYp9eeymIl5mJBn0yiuxA==", "cpu": [ "arm64" ], @@ -181,9 +203,9 @@ } }, "node_modules/@esbuild/freebsd-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.18.tgz", - "integrity": "sha512-FQFbRtTaEi8ZBi/A6kxOC0V0E9B/97vPdYjY9NdawyLd4Qk5VD5g2pbWN2VR1c0xhzcJm74HWpObPszWC+qTew==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.19.11.tgz", + "integrity": "sha512-JkUqn44AffGXitVI6/AbQdoYAq0TEullFdqcMY/PCUZ36xJ9ZJRtQabzMA+Vi7r78+25ZIBosLTOKnUXBSi1Kw==", "cpu": [ "x64" ], @@ -197,9 +219,9 @@ } }, "node_modules/@esbuild/linux-arm": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.18.tgz", - "integrity": "sha512-jW+UCM40LzHcouIaqv3e/oRs0JM76JfhHjCavPxMUti7VAPh8CaGSlS7cmyrdpzSk7A+8f0hiedHqr/LMnfijg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.19.11.tgz", + "integrity": "sha512-3CRkr9+vCV2XJbjwgzjPtO8T0SZUmRZla+UL1jw+XqHZPkPgZiyWvbDvl9rqAN8Zl7qJF0O/9ycMtjU67HN9/Q==", "cpu": [ "arm" ], @@ -213,9 +235,9 @@ } }, "node_modules/@esbuild/linux-arm64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.18.tgz", - "integrity": "sha512-R7pZvQZFOY2sxUG8P6A21eq6q+eBv7JPQYIybHVf1XkQYC+lT7nDBdC7wWKTrbvMXKRaGudp/dzZCwL/863mZQ==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.19.11.tgz", + "integrity": "sha512-LneLg3ypEeveBSMuoa0kwMpCGmpu8XQUh+mL8XXwoYZ6Be2qBnVtcDI5azSvh7vioMDhoJFZzp9GWp9IWpYoUg==", "cpu": [ "arm64" ], @@ -229,9 +251,9 @@ } }, "node_modules/@esbuild/linux-ia32": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.18.tgz", - "integrity": "sha512-ygIMc3I7wxgXIxk6j3V00VlABIjq260i967Cp9BNAk5pOOpIXmd1RFQJQX9Io7KRsthDrQYrtcx7QCof4o3ZoQ==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.19.11.tgz", + "integrity": "sha512-caHy++CsD8Bgq2V5CodbJjFPEiDPq8JJmBdeyZ8GWVQMjRD0sU548nNdwPNvKjVpamYYVL40AORekgfIubwHoA==", "cpu": [ "ia32" ], @@ -245,9 +267,9 @@ } }, "node_modules/@esbuild/linux-loong64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.18.tgz", - "integrity": "sha512-bvPG+MyFs5ZlwYclCG1D744oHk1Pv7j8psF5TfYx7otCVmcJsEXgFEhQkbhNW8otDHL1a2KDINW20cfCgnzgMQ==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.19.11.tgz", + "integrity": "sha512-ppZSSLVpPrwHccvC6nQVZaSHlFsvCQyjnvirnVjbKSHuE5N24Yl8F3UwYUUR1UEPaFObGD2tSvVKbvR+uT1Nrg==", "cpu": [ "loong64" ], @@ -261,9 +283,9 @@ } }, "node_modules/@esbuild/linux-mips64el": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.18.tgz", - "integrity": "sha512-oVqckATOAGuiUOa6wr8TXaVPSa+6IwVJrGidmNZS1cZVx0HqkTMkqFGD2HIx9H1RvOwFeWYdaYbdY6B89KUMxA==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.19.11.tgz", + "integrity": "sha512-B5x9j0OgjG+v1dF2DkH34lr+7Gmv0kzX6/V0afF41FkPMMqaQ77pH7CrhWeR22aEeHKaeZVtZ6yFwlxOKPVFyg==", "cpu": [ "mips64el" ], @@ -277,9 +299,9 @@ } }, "node_modules/@esbuild/linux-ppc64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.18.tgz", - "integrity": "sha512-3dLlQO+b/LnQNxgH4l9rqa2/IwRJVN9u/bK63FhOPB4xqiRqlQAU0qDU3JJuf0BmaH0yytTBdoSBHrb2jqc5qQ==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.19.11.tgz", + "integrity": "sha512-MHrZYLeCG8vXblMetWyttkdVRjQlQUb/oMgBNurVEnhj4YWOr4G5lmBfZjHYQHHN0g6yDmCAQRR8MUHldvvRDA==", "cpu": [ "ppc64" ], @@ -293,9 +315,9 @@ } }, "node_modules/@esbuild/linux-riscv64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.18.tgz", - "integrity": "sha512-/x7leOyDPjZV3TcsdfrSI107zItVnsX1q2nho7hbbQoKnmoeUWjs+08rKKt4AUXju7+3aRZSsKrJtaRmsdL1xA==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.19.11.tgz", + "integrity": "sha512-f3DY++t94uVg141dozDu4CCUkYW+09rWtaWfnb3bqe4w5NqmZd6nPVBm+qbz7WaHZCoqXqHz5p6CM6qv3qnSSQ==", "cpu": [ "riscv64" ], @@ -309,9 +331,9 @@ } }, "node_modules/@esbuild/linux-s390x": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.18.tgz", - "integrity": "sha512-cX0I8Q9xQkL/6F5zWdYmVf5JSQt+ZfZD2bJudZrWD+4mnUvoZ3TDDXtDX2mUaq6upMFv9FlfIh4Gfun0tbGzuw==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.19.11.tgz", + "integrity": "sha512-A5xdUoyWJHMMlcSMcPGVLzYzpcY8QP1RtYzX5/bS4dvjBGVxdhuiYyFwp7z74ocV7WDc0n1harxmpq2ePOjI0Q==", "cpu": [ "s390x" ], @@ -325,9 +347,9 @@ } }, "node_modules/@esbuild/linux-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.18.tgz", - "integrity": "sha512-66RmRsPlYy4jFl0vG80GcNRdirx4nVWAzJmXkevgphP1qf4dsLQCpSKGM3DUQCojwU1hnepI63gNZdrr02wHUA==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.19.11.tgz", + "integrity": "sha512-grbyMlVCvJSfxFQUndw5mCtWs5LO1gUlwP4CDi4iJBbVpZcqLVT29FxgGuBJGSzyOxotFG4LoO5X+M1350zmPA==", "cpu": [ "x64" ], @@ -341,9 +363,9 @@ } }, "node_modules/@esbuild/netbsd-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.18.tgz", - "integrity": "sha512-95IRY7mI2yrkLlTLb1gpDxdC5WLC5mZDi+kA9dmM5XAGxCME0F8i4bYH4jZreaJ6lIZ0B8hTrweqG1fUyW7jbg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.19.11.tgz", + "integrity": "sha512-13jvrQZJc3P230OhU8xgwUnDeuC/9egsjTkXN49b3GcS5BKvJqZn86aGM8W9pd14Kd+u7HuFBMVtrNGhh6fHEQ==", "cpu": [ "x64" ], @@ -357,9 +379,9 @@ } }, "node_modules/@esbuild/openbsd-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.18.tgz", - "integrity": "sha512-WevVOgcng+8hSZ4Q3BKL3n1xTv5H6Nb53cBrtzzEjDbbnOmucEVcZeGCsCOi9bAOcDYEeBZbD2SJNBxlfP3qiA==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.19.11.tgz", + "integrity": "sha512-ysyOGZuTp6SNKPE11INDUeFVVQFrhcNDVUgSQVDzqsqX38DjhPEPATpid04LCoUr2WXhQTEZ8ct/EgJCUDpyNw==", "cpu": [ "x64" ], @@ -373,9 +395,9 @@ } }, "node_modules/@esbuild/sunos-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.18.tgz", - "integrity": "sha512-Rzf4QfQagnwhQXVBS3BYUlxmEbcV7MY+BH5vfDZekU5eYpcffHSyjU8T0xucKVuOcdCsMo+Ur5wmgQJH2GfNrg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.19.11.tgz", + "integrity": "sha512-Hf+Sad9nVwvtxy4DXCZQqLpgmRTQqyFyhT3bZ4F2XlJCjxGmRFF0Shwn9rzhOYRB61w9VMXUkxlBy56dk9JJiQ==", "cpu": [ "x64" ], @@ -389,9 +411,9 @@ } }, "node_modules/@esbuild/win32-arm64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.18.tgz", - "integrity": "sha512-Kb3Ko/KKaWhjeAm2YoT/cNZaHaD1Yk/pa3FTsmqo9uFh1D1Rfco7BBLIPdDOozrObj2sahslFuAQGvWbgWldAg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.19.11.tgz", + "integrity": "sha512-0P58Sbi0LctOMOQbpEOvOL44Ne0sqbS0XWHMvvrg6NE5jQ1xguCSSw9jQeUk2lfrXYsKDdOe6K+oZiwKPilYPQ==", "cpu": [ "arm64" ], @@ -405,9 +427,9 @@ } }, "node_modules/@esbuild/win32-ia32": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.18.tgz", - "integrity": "sha512-0/xUMIdkVHwkvxfbd5+lfG7mHOf2FRrxNbPiKWg9C4fFrB8H0guClmaM3BFiRUYrznVoyxTIyC/Ou2B7QQSwmw==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.19.11.tgz", + "integrity": "sha512-6YOrWS+sDJDmshdBIQU+Uoyh7pQKrdykdefC1avn76ss5c+RN6gut3LZA4E2cH5xUEp5/cA0+YxRaVtRAb0xBg==", "cpu": [ "ia32" ], @@ -421,9 +443,9 @@ } }, "node_modules/@esbuild/win32-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.18.tgz", - "integrity": "sha512-qU25Ma1I3NqTSHJUOKi9sAH1/Mzuvlke0ioMJRthLXKm7JiSKVwFghlGbDLOO2sARECGhja4xYfRAZNPAkooYg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.19.11.tgz", + "integrity": "sha512-vfkhltrjCAb603XaFhqhAF4LGDi2M4OrCRrFusyQ+iTLQ/o60QQXxc9cZC/FFpihBI9N1Grn6SMKVJ4KP7Fuiw==", "cpu": [ "x64" ], @@ -437,9 +459,9 @@ } }, "node_modules/@eslint-community/eslint-utils": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.2.0.tgz", - "integrity": "sha512-gB8T4H4DEfX2IV9zGDJPOBgP1e/DbfCPDTtEqUMckpvzS1OYtva8JdFYBqMwYk7xAQ429WGF/UPqn8uQ//h2vQ==", + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", + "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", "dependencies": { "eslint-visitor-keys": "^3.3.0" }, @@ -451,21 +473,21 @@ } }, "node_modules/@eslint-community/regexpp": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.4.0.tgz", - "integrity": "sha512-A9983Q0LnDGdLPjxyXQ00sbV+K+O+ko2Dr+CZigbHWtX9pNfxlaBkMR8X1CztI73zuEyEBXTVjx7CE+/VSwDiQ==", + "version": "4.10.0", + "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", + "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==", "engines": { "node": "^12.0.0 || ^14.0.0 || >=16.0.0" } }, "node_modules/@eslint/eslintrc": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.0.2.tgz", - "integrity": "sha512-3W4f5tDUra+pA+FzgugqL2pRimUTDJWKr7BINqOpkZrC0uYI0NIc0/JFgBROCU07HR6GieA5m3/rsPIhDmCXTQ==", + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", + "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", "dependencies": { "ajv": "^6.12.4", "debug": "^4.3.2", - "espree": "^9.5.1", + "espree": "^9.6.0", "globals": "^13.19.0", "ignore": "^5.2.0", "import-fresh": "^3.2.1", @@ -481,73 +503,73 @@ } }, "node_modules/@eslint/js": { - "version": "8.39.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.39.0.tgz", - "integrity": "sha512-kf9RB0Fg7NZfap83B3QOqOGg9QmD9yBudqQXzzOtn3i4y7ZUXe5ONeW34Gwi+TxhH4mvj72R1Zc300KUMa9Bng==", + "version": "8.56.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.56.0.tgz", + "integrity": "sha512-gMsVel9D7f2HLkBma9VbtzZRehRogVRfbr++f06nL2vnCGCNlzOD+/MUov/F4p8myyAHspEhVobgjpX64q5m6A==", "engines": { "node": "^12.22.0 || ^14.17.0 || >=16.0.0" } }, "node_modules/@file-services/memory": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/memory/-/memory-7.2.5.tgz", - "integrity": "sha512-SQ3QNcPZQ0w6jGCqcr4pgY2z80nCuGfNJkQ/ETEm3+iA0js6j/RZgOsXYL3W1VW9jIr7d+qFGLXHek3cqUuuBw==", + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/memory/-/memory-8.3.3.tgz", + "integrity": "sha512-WBgpmTvO2Bkl9zD0Vdyt4hjScZ5p5ytqcpG9y7pMAZITSw9Slv/pjK0jKkJMg4reb2nHjzEEgYzggfd2FibDsA==", "dependencies": { - "@file-services/path": "^7.2.5", - "@file-services/types": "^7.2.5", - "@file-services/utils": "^7.2.5" + "@file-services/path": "^8.3.3", + "@file-services/types": "^8.3.3", + "@file-services/utils": "^8.3.3" } }, "node_modules/@file-services/node": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/node/-/node-7.2.5.tgz", - "integrity": "sha512-aujaIg8f0kOKGlW1LBTM+dk8MrhMp3sQSRoZ1lJyeZOlHpOcfL/TrncW34Co0S5sxd3FyOptJo+kBlyfsPVLoQ==", + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/node/-/node-8.3.3.tgz", + "integrity": "sha512-gZH5C4QRs4DurIxu/xa44zfqELHYtxjyQAx9NwDD7eNjst1jVbSOKtWD6beDXw88OI/6KzpxnbOnhwksQphJ6g==", "dependencies": { - "@file-services/types": "^7.2.5", - "@file-services/utils": "^7.2.5" + "@file-services/types": "^8.3.3", + "@file-services/utils": "^8.3.3" }, "engines": { "node": ">=14" } }, "node_modules/@file-services/path": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/path/-/path-7.2.5.tgz", - "integrity": "sha512-ovs34aWZ3TL0WotKKi/dywmNu5ndiRh7K/AvvEoWmXuilZFFbFknQG2/vwNLm4A4phCqIbEvy0zNToL6tU7CBA==", + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/path/-/path-8.3.3.tgz", + "integrity": "sha512-zM2/I4uIA+Hq8fC0XhBfo7ZC3t/shX3gjwl3z+lmtHxtNfxProf6hsmR1VI0qLDEFcIog7tB89HOR7H5DWj+qQ==", "dependencies": { - "@file-services/types": "^7.2.5" + "@file-services/types": "^8.3.3" } }, "node_modules/@file-services/types": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/types/-/types-7.2.5.tgz", - "integrity": "sha512-+ED491/MHemP0Kg6AjWmrUGz7BMTE0eP7rTWt6csUPkW6valBsVpZhdAm+5N4d0xkhlcRwIyZ5wRSq4lReWIKg==" + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/types/-/types-8.3.3.tgz", + "integrity": "sha512-b6IM6MNZ6HKm5GicSKI61Rj1UZy87UtBCUvBiqT+w16biEYxeV7fBCj6gCeu8fWdPdfXgUK2QFKAB0RST+D4GQ==" }, "node_modules/@file-services/typescript": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/typescript/-/typescript-7.2.5.tgz", - "integrity": "sha512-uSpLPShjGxbiR7097oa7FPF6NGecJYgG9JRWoAFbQ/N6OppoMk4eEjaIO/lfDo8BMOihiUfk6Tzj92K63FSXUQ==", + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/typescript/-/typescript-8.3.3.tgz", + "integrity": "sha512-NHT1AG0sC7sf695ZYg3iCjSlD4lVKL81og2/W+ilreAqRWWEJ5R4BxuFtrB3H2D7S6PChxooPQkrYhrnB5hbZg==", "dependencies": { - "@file-services/types": "^7.2.5" + "@file-services/types": "^8.3.3" }, "peerDependencies": { "typescript": ">=2.8.0" } }, "node_modules/@file-services/utils": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/utils/-/utils-7.2.5.tgz", - "integrity": "sha512-ta3Um+scOxT+eNg+/wrNOF9Fgt2ila5temox35p5hNQUvRcJDRiqrfSqvKJhN/cwQu6yseJtkZiXX4sezkBKng==", + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/utils/-/utils-8.3.3.tgz", + "integrity": "sha512-mCVe/x8cqvMxR/JE1SdPxxcReXvinYhrGgS3Ub33pHKmYMvRLPqt7tmxJV6zV8hjptx/CuxG6+yh9iSQo5sRvA==", "dependencies": { - "@file-services/types": "^7.2.5" + "@file-services/types": "^8.3.3" } }, "node_modules/@humanwhocodes/config-array": { - "version": "0.11.8", - "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.8.tgz", - "integrity": "sha512-UybHIJzJnR5Qc/MsD9Kr+RpO2h+/P1GhOwdiLPXK5TWk5sgTdu88bTD9UP+CKbPPh5Rni1u0GjAdYQLemG8g+g==", + "version": "0.11.13", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.13.tgz", + "integrity": "sha512-JSBDMiDKSzQVngfRjOdFXgFfklaXI4K9nLF49Auh21lmBWRLIK3+xTErTWD4KU54pb6coM6ESE7Awz/FNU3zgQ==", "dependencies": { - "@humanwhocodes/object-schema": "^1.2.1", + "@humanwhocodes/object-schema": "^2.0.1", "debug": "^4.1.1", "minimatch": "^3.0.5" }, @@ -568,9 +590,98 @@ } }, "node_modules/@humanwhocodes/object-schema": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", - "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==" + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.1.tgz", + "integrity": "sha512-dvuCeX5fC9dXgJn9t+X5atfmgQAzUOWqS1254Gh0m6i8wKd10ebXkfNKiRK+1GWi/yTvvLDHpoxLr0xxxeslWw==" + }, + "node_modules/@isaacs/cliui": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", + "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", + "dependencies": { + "string-width": "^5.1.2", + "string-width-cjs": "npm:string-width@^4.2.0", + "strip-ansi": "^7.0.1", + "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", + "wrap-ansi": "^8.1.0", + "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/@isaacs/cliui/node_modules/ansi-regex": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", + "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-regex?sponsor=1" + } + }, + "node_modules/@isaacs/cliui/node_modules/ansi-styles": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", + "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/@isaacs/cliui/node_modules/emoji-regex": { + "version": "9.2.2", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", + "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==" + }, + "node_modules/@isaacs/cliui/node_modules/string-width": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", + "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", + "dependencies": { + "eastasianwidth": "^0.2.0", + "emoji-regex": "^9.2.2", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@isaacs/cliui/node_modules/strip-ansi": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", + "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "dependencies": { + "ansi-regex": "^6.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/strip-ansi?sponsor=1" + } + }, + "node_modules/@isaacs/cliui/node_modules/wrap-ansi": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", + "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", + "dependencies": { + "ansi-styles": "^6.1.0", + "string-width": "^5.0.1", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } }, "node_modules/@istanbuljs/schema": { "version": "0.1.3", @@ -582,9 +693,9 @@ } }, "node_modules/@jridgewell/gen-mapping": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", - "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", + "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", "dependencies": { "@jridgewell/set-array": "^1.0.1", "@jridgewell/sourcemap-codec": "^1.4.10", @@ -595,9 +706,9 @@ } }, "node_modules/@jridgewell/resolve-uri": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", - "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz", + "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==", "engines": { "node": ">=6.0.0" } @@ -611,26 +722,26 @@ } }, "node_modules/@jridgewell/source-map": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.2.tgz", - "integrity": "sha512-m7O9o2uR8k2ObDysZYzdfhb08VuEml5oWGiosa1VdaPZ/A6QyPkAJuwN0Q1lhULOf6B7MtQmHENS743hWtCrgw==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.5.tgz", + "integrity": "sha512-UTYAUj/wviwdsMfzoSJspJxbkH5o1snzwX0//0ENX1u/55kkZZkcTZP6u9bwKGkv+dkk9at4m1Cpt0uY80kcpQ==", "dependencies": { "@jridgewell/gen-mapping": "^0.3.0", "@jridgewell/trace-mapping": "^0.3.9" } }, "node_modules/@jridgewell/sourcemap-codec": { - "version": "1.4.14", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", - "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==" + "version": "1.4.15", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", + "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==" }, "node_modules/@jridgewell/trace-mapping": { - "version": "0.3.17", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz", - "integrity": "sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g==", + "version": "0.3.20", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.20.tgz", + "integrity": "sha512-R8LcPeWZol2zR8mmH3JeKQ6QRCFb7XgUhV9ZlGhHLGyg4wpPiPZNQOOWhFZhxKw8u//yTbNGI42Bx/3paXEQ+Q==", "dependencies": { - "@jridgewell/resolve-uri": "3.1.0", - "@jridgewell/sourcemap-codec": "1.4.14" + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" } }, "node_modules/@nodelib/fs.scandir": { @@ -665,6 +776,11 @@ "node": ">= 8" } }, + "node_modules/@one-ini/wasm": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@one-ini/wasm/-/wasm-0.1.1.tgz", + "integrity": "sha512-XuySG1E38YScSJoMlqovLru4KTUNSjgVTIjyh7qMX6aNN5HY5Ct5LhRJdxO79JtTzKfzV/bnWpz+zquYrISsvw==" + }, "node_modules/@pkgjs/parseargs": { "version": "0.11.0", "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", @@ -675,15 +791,15 @@ } }, "node_modules/@rollup/plugin-html": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/@rollup/plugin-html/-/plugin-html-1.0.2.tgz", - "integrity": "sha512-jGqb45BPj5kwvb/bq1jIzUDLebsm1xmfnY1rwgTIZyjpsMyMKLuQO27n4z5qv6kZmxqxh+CBRD7d1rjAu85Uzg==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/@rollup/plugin-html/-/plugin-html-1.0.3.tgz", + "integrity": "sha512-bbjQciNXitHX+Bgk0xsW3/0wFWih/356/r7/kvmdz4wzWhAU/a0zYBWTczihrlzz/6Qpw/kZ0yXqOJwsETgg7A==", "dev": true, "engines": { "node": ">=14.0.0" }, "peerDependencies": { - "rollup": "^1.20.0||^2.0.0||^3.0.0" + "rollup": "^1.20.0||^2.0.0||^3.0.0||^4.0.0" }, "peerDependenciesMeta": { "rollup": { @@ -692,9 +808,9 @@ } }, "node_modules/@rollup/plugin-node-resolve": { - "version": "15.0.2", - "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-15.0.2.tgz", - "integrity": "sha512-Y35fRGUjC3FaurG722uhUuG8YHOJRJQbI6/CkbRkdPotSpDj9NtIN85z1zrcyDcCQIW4qp5mgG72U+gJ0TAFEg==", + "version": "15.2.3", + "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-15.2.3.tgz", + "integrity": "sha512-j/lym8nf5E21LwBT4Df1VD6hRO2L2iwUeUmP7litikRsVp1H6NWx20NEp0Y7su+7XGc476GnXXc4kFeZNGmaSQ==", "dev": true, "dependencies": { "@rollup/pluginutils": "^5.0.1", @@ -708,7 +824,7 @@ "node": ">=14.0.0" }, "peerDependencies": { - "rollup": "^2.78.0||^3.0.0" + "rollup": "^2.78.0||^3.0.0||^4.0.0" }, "peerDependenciesMeta": { "rollup": { @@ -717,9 +833,9 @@ } }, "node_modules/@rollup/pluginutils": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.0.2.tgz", - "integrity": "sha512-pTd9rIsP92h+B6wWwFbW8RkZv4hiR/xKsqre4SIuAOaOEQRxi0lqLke9k2/7WegC85GgUs9pjmOjCUi3In4vwA==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.1.0.tgz", + "integrity": "sha512-XTIWOPPcpvyKI6L1NHo0lFlCyznUEyPmPY1mc3KpPVDYulHSTvyeLNVW00QTLIAFNhR3kYnJTQHeGqU4M3n09g==", "dev": true, "dependencies": { "@types/estree": "^1.0.0", @@ -730,7 +846,7 @@ "node": ">=14.0.0" }, "peerDependencies": { - "rollup": "^1.20.0||^2.0.0||^3.0.0" + "rollup": "^1.20.0||^2.0.0||^3.0.0||^4.0.0" }, "peerDependenciesMeta": { "rollup": { @@ -738,6 +854,162 @@ } } }, + "node_modules/@rollup/rollup-android-arm-eabi": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.9.2.tgz", + "integrity": "sha512-RKzxFxBHq9ysZ83fn8Iduv3A283K7zPPYuhL/z9CQuyFrjwpErJx0h4aeb/bnJ+q29GRLgJpY66ceQ/Wcsn3wA==", + "cpu": [ + "arm" + ], + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-android-arm64": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.9.2.tgz", + "integrity": "sha512-yZ+MUbnwf3SHNWQKJyWh88ii2HbuHCFQnAYTeeO1Nb8SyEiWASEi5dQUygt3ClHWtA9My9RQAYkjvrsZ0WK8Xg==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-darwin-arm64": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.9.2.tgz", + "integrity": "sha512-vqJ/pAUh95FLc/G/3+xPqlSBgilPnauVf2EXOQCZzhZJCXDXt/5A8mH/OzU6iWhb3CNk5hPJrh8pqJUPldN5zw==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-darwin-x64": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.9.2.tgz", + "integrity": "sha512-otPHsN5LlvedOprd3SdfrRNhOahhVBwJpepVKUN58L0RnC29vOAej1vMEaVU6DadnpjivVsNTM5eNt0CcwTahw==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-linux-arm-gnueabihf": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.9.2.tgz", + "integrity": "sha512-ewG5yJSp+zYKBYQLbd1CUA7b1lSfIdo9zJShNTyc2ZP1rcPrqyZcNlsHgs7v1zhgfdS+kW0p5frc0aVqhZCiYQ==", + "cpu": [ + "arm" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-gnu": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.9.2.tgz", + "integrity": "sha512-pL6QtV26W52aCWTG1IuFV3FMPL1m4wbsRG+qijIvgFO/VBsiXJjDPE/uiMdHBAO6YcpV4KvpKtd0v3WFbaxBtg==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-musl": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.9.2.tgz", + "integrity": "sha512-On+cc5EpOaTwPSNetHXBuqylDW+765G/oqB9xGmWU3npEhCh8xu0xqHGUA+4xwZLqBbIZNcBlKSIYfkBm6ko7g==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-riscv64-gnu": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.9.2.tgz", + "integrity": "sha512-Wnx/IVMSZ31D/cO9HSsU46FjrPWHqtdF8+0eyZ1zIB5a6hXaZXghUKpRrC4D5DcRTZOjml2oBhXoqfGYyXKipw==", + "cpu": [ + "riscv64" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-gnu": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.9.2.tgz", + "integrity": "sha512-ym5x1cj4mUAMBummxxRkI4pG5Vht1QMsJexwGP8547TZ0sox9fCLDHw9KCH9c1FO5d9GopvkaJsBIOkTKxksdw==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-musl": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.9.2.tgz", + "integrity": "sha512-m0hYELHGXdYx64D6IDDg/1vOJEaiV8f1G/iO+tejvRCJNSwK4jJ15e38JQy5Q6dGkn1M/9KcyEOwqmlZ2kqaZg==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-win32-arm64-msvc": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.9.2.tgz", + "integrity": "sha512-x1CWburlbN5JjG+juenuNa4KdedBdXLjZMp56nHFSHTOsb/MI2DYiGzLtRGHNMyydPGffGId+VgjOMrcltOksA==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-ia32-msvc": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.9.2.tgz", + "integrity": "sha512-VVzCB5yXR1QlfsH1Xw1zdzQ4Pxuzv+CPr5qpElpKhVxlxD3CRdfubAG9mJROl6/dmj5gVYDDWk8sC+j9BI9/kQ==", + "cpu": [ + "ia32" + ], + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-x64-msvc": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.9.2.tgz", + "integrity": "sha512-SYRedJi+mweatroB+6TTnJYLts0L0bosg531xnQWtklOI6dezEagx4Q0qDyvRdK+qgdA3YZpjjGuPFtxBmddBA==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "win32" + ] + }, "node_modules/@stylable/build-tools": { "resolved": "packages/build-tools", "link": true @@ -827,24 +1099,24 @@ "link": true }, "node_modules/@tokey/core": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/@tokey/core/-/core-1.3.0.tgz", - "integrity": "sha512-qeJ181Jsp+fIGJRUlYPtIhm86WyRF8P7LiW0mJ2xCTWNmPHKHmY5a8Yzi0EXWTLGTA3HBFK/1pw/S83uatmWcQ==" + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@tokey/core/-/core-1.4.0.tgz", + "integrity": "sha512-U+xr5ue/iKQJsOP+rWNS0U6M9kUQn9L7bgsa7jnYQwSlHjyeZO4e4ngRmbcf/bfB0IpxWGAlhdpwgwI7vTFftg==" }, "node_modules/@tokey/css-selector-parser": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/@tokey/css-selector-parser/-/css-selector-parser-0.6.1.tgz", - "integrity": "sha512-nyAtoXUvlNqzdArJQLJ1B0zPH4bqCtmKzF4PNtrMNFn6SljPyKn2cWS/A2sHjJuR197opBgA5NjmnZslsRqdmw==", + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/@tokey/css-selector-parser/-/css-selector-parser-0.6.2.tgz", + "integrity": "sha512-4nD20RbiLitUP7MmDCJ5+PMKe4bSaNs7glEGKK7I9gmd2iYETbjh7OS8PWZ5vBXfr9LzaI++ssQFlxwPdh3MXQ==", "dependencies": { - "@tokey/core": "^1.3.0" + "@tokey/core": "^1.4.0" } }, "node_modules/@tokey/css-value-parser": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/@tokey/css-value-parser/-/css-value-parser-0.1.2.tgz", - "integrity": "sha512-wrNVsMoLaUIDIzlQZrYs6qIRXMoekYfYLu7bmV1kpejUSB4SxJyPrqI/vjGTqyxELFm3WUGUgw/o6sEmWbYkrQ==", + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/@tokey/css-value-parser/-/css-value-parser-0.1.4.tgz", + "integrity": "sha512-zHkHmNGnzVI31D3rkpXAh9KioMJd8Fwpe0Y6rwh87kTjUPzhpYSzy6ZziAQv2Ol1GqExrLj5ips9zlrCxeeJWw==", "dependencies": { - "@tokey/core": "^1.3.0" + "@tokey/core": "^1.4.0" } }, "node_modules/@tokey/imports-parser": { @@ -856,86 +1128,86 @@ } }, "node_modules/@types/balanced-match": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/@types/balanced-match/-/balanced-match-1.0.2.tgz", - "integrity": "sha512-KgomuqUNYgN+Sibk22j7HB6vo8gziGz/k3Y8RkauF2duMZfMeIkyUKARef2eIIQuXGrkbIvcOfY5DNF/nQrDZQ==", + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@types/balanced-match/-/balanced-match-3.0.2.tgz", + "integrity": "sha512-It1j6doJHkoGoxfOj3c7sHVHQXYMHo3c0kpcnPhEO4KfitNE5SqiSGKV0Hx5/cwyYKJfEhin0tZYBmqpjEcavw==", "dev": true }, "node_modules/@types/chai": { - "version": "4.3.5", - "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.5.tgz", - "integrity": "sha512-mEo1sAde+UCE6b2hxn332f1g1E8WfYRu6p5SvTKr2ZKC1f7gFJXk4h5PyGP9Dt6gCaG8y8XhwnXWC6Iy2cmBng==", + "version": "4.3.11", + "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.11.tgz", + "integrity": "sha512-qQR1dr2rGIHYlJulmr8Ioq3De0Le9E4MJ5AiaeAETJJpndT1uUNHsGFK3L/UIu+rbkQSdj8J/w2bCsBZc/Y5fQ==", "dev": true }, "node_modules/@types/chai-subset": { - "version": "1.3.3", - "resolved": "https://registry.npmjs.org/@types/chai-subset/-/chai-subset-1.3.3.tgz", - "integrity": "sha512-frBecisrNGz+F4T6bcc+NLeolfiojh5FxW2klu669+8BARtyQv2C/GkNW6FUodVe4BroGMP/wER/YDGc7rEllw==", + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/@types/chai-subset/-/chai-subset-1.3.5.tgz", + "integrity": "sha512-c2mPnw+xHtXDoHmdtcCXGwyLMiauiAyxWMzhGpqHC4nqI/Y5G2XhTampslK2rb59kpcuHon03UH8W6iYUzw88A==", "dev": true, "dependencies": { "@types/chai": "*" } }, "node_modules/@types/css-selector-tokenizer": { - "version": "0.7.1", - "resolved": "https://registry.npmjs.org/@types/css-selector-tokenizer/-/css-selector-tokenizer-0.7.1.tgz", - "integrity": "sha512-DdGXO+tC5ZWFDIytbNOa55lUoEXXnRJqnEUJ3P5DE+TCEEoAcpKYq48klKRLGS9Uo22Dk1s0aTt9nAUDK7W8tg==", + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/@types/css-selector-tokenizer/-/css-selector-tokenizer-0.7.4.tgz", + "integrity": "sha512-X/on8gnLmrSHASIouMtbsctR1Bwgf+ceqbwALnsLjK1WbQUpCWLVgoNCMM39D1T9IdmAGL5teQWx6W4gaIHrKQ==", "dev": true }, "node_modules/@types/css-tree": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/@types/css-tree/-/css-tree-2.0.0.tgz", - "integrity": "sha512-mY2sXRLBnUPMYw6mkOT+6dABeaNxAEKZz6scE9kQPNJx8fKe1fOsm8Honl7+xFYe6TKX8WNk2+7oMp2vBArJ9Q==", + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/@types/css-tree/-/css-tree-2.3.4.tgz", + "integrity": "sha512-wdxxe7zEpOXfy5C3FmwinAIc/6p6du/wOKMGZf07JHuHHRIvLtLq8h66zi3Yn7PCyswxbp3Ujx9h+vSuMvfN/w==", "dev": true }, "node_modules/@types/cssesc": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@types/cssesc/-/cssesc-3.0.0.tgz", - "integrity": "sha512-4mBnOrTpVKn+tYzlnMO7cwDkDa6wlQ2bBXW+79/6ahMd36GF216kxWYxgz+S4d5Ev1ByFbnQbPGxV4P5BSL8MA==", + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@types/cssesc/-/cssesc-3.0.2.tgz", + "integrity": "sha512-Qii6nTRktvtI380EloxH/V7MwgrYxkPgBI+NklUjQuhzgAd1AqT3QDJd+eD+0doRADgfwvtagLRo7JFa7aMHXg==", "dev": true }, "node_modules/@types/csso": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/@types/csso/-/csso-5.0.0.tgz", - "integrity": "sha512-EMrCTGpXRUsbFfZBzn2jcW6Sqg8kxWXkJcpvAGYSEzFqAJ2THDJSwiMeS2fPUw+0p6RQNT/n8F/skEc9hUBc0g==", + "version": "5.0.4", + "resolved": "https://registry.npmjs.org/@types/csso/-/csso-5.0.4.tgz", + "integrity": "sha512-W/FsRkm/9c04x9ON+bj+HQ0cSgNkG1LvcfuBCpkP7cpikM7+RkrNFLGtiofb++xBG6KGMUycLoDbi9/K621ZCw==", "dev": true, "dependencies": { "@types/css-tree": "*" } }, "node_modules/@types/eslint": { - "version": "8.4.10", - "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.4.10.tgz", - "integrity": "sha512-Sl/HOqN8NKPmhWo2VBEPm0nvHnu2LL3v9vKo8MEq0EtbJ4eVzGPl41VNPvn5E1i5poMk4/XD8UriLHpJvEP/Nw==", + "version": "8.56.0", + "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.56.0.tgz", + "integrity": "sha512-FlsN0p4FhuYRjIxpbdXovvHQhtlG05O1GG/RNWvdAxTboR438IOTwmrY/vLA+Xfgg06BTkP045M3vpFwTMv1dg==", "dependencies": { "@types/estree": "*", "@types/json-schema": "*" } }, "node_modules/@types/eslint-scope": { - "version": "3.7.4", - "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.4.tgz", - "integrity": "sha512-9K4zoImiZc3HlIp6AVUDE4CWYx22a+lhSZMYNpbjW04+YF0KWj4pJXnEMjdnFTiQibFFmElcsasJXDbdI/EPhA==", + "version": "3.7.7", + "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.7.tgz", + "integrity": "sha512-MzMFlSLBqNF2gcHWO0G1vP/YQyfvrxZ0bF+u7mzUdZ1/xK4A4sru+nraZz5i3iEIk1l1uyicaDVTB4QbbEkAYg==", "dependencies": { "@types/eslint": "*", "@types/estree": "*" } }, "node_modules/@types/estree": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.0.tgz", - "integrity": "sha512-WulqXMDUTYAXCjZnk6JtIHPigp55cVtDgDrO2gHRwhyJto21+1zbVCtOYB2L1F9w4qCQ0rOGWBnBe0FNTiEJIQ==" + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", + "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==" }, "node_modules/@types/find-config": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/@types/find-config/-/find-config-1.0.1.tgz", - "integrity": "sha512-H4DFIQMwxCKRgVWMSqALg6aowTOgZi5D4pSPBBuOQFJLRwfNZaByhC9+s870CZgTRJoyVg5J+iesdF5uvnJ0mA==", + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/@types/find-config/-/find-config-1.0.4.tgz", + "integrity": "sha512-BCXaKgzHK7KnfCQBRQBWGTA+QajOE9uFolXPt+9EktiiMS56D8oXF2ZCh9eCxuEyfqDmX/mYIcmWg9j9f659eg==", "dev": true }, "node_modules/@types/flat": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@types/flat/-/flat-5.0.2.tgz", - "integrity": "sha512-3zsplnP2djeps5P9OyarTxwRpMLoe5Ash8aL9iprw0JxB+FAHjY+ifn4yZUuW4/9hqtnmor6uvjSRzJhiVbrEQ==", + "version": "5.0.5", + "resolved": "https://registry.npmjs.org/@types/flat/-/flat-5.0.5.tgz", + "integrity": "sha512-nPLljZQKSnac53KDUDzuzdRfGI0TDb5qPrb+SrQyN3MtdQrOnGsKniHN1iYZsJEBIVQve94Y6gNz22sgISZq+Q==", "dev": true }, "node_modules/@types/html-minifier-terser": { @@ -945,118 +1217,118 @@ "dev": true }, "node_modules/@types/istanbul-lib-coverage": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", - "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz", + "integrity": "sha512-2QF/t/auWm0lsy8XtKVPG19v3sSOQlJe/YHZgfjb/KBBHOGSV+J2q/S671rcq9uTBrLAXmZpqJiaQbMT+zNU1w==", "dev": true }, "node_modules/@types/js-beautify": { - "version": "1.13.3", - "resolved": "https://registry.npmjs.org/@types/js-beautify/-/js-beautify-1.13.3.tgz", - "integrity": "sha512-ucIPw5gmNyvRKi6mpeojlqp+T+6ZBJeU+kqMDnIEDlijEU4QhLTon90sZ3cz9HZr+QTwXILjNsMZImzA7+zuJA==", + "version": "1.14.3", + "resolved": "https://registry.npmjs.org/@types/js-beautify/-/js-beautify-1.14.3.tgz", + "integrity": "sha512-FMbQHz+qd9DoGvgLHxeqqVPaNRffpIu5ZjozwV8hf9JAGpIOzuAf4wGbRSo8LNITHqGjmmVjaMggTT5P4v4IHg==", "dev": true }, "node_modules/@types/json-schema": { - "version": "7.0.11", - "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", - "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==" + "version": "7.0.15", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", + "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==" }, "node_modules/@types/lodash": { - "version": "4.14.191", - "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.191.tgz", - "integrity": "sha512-BdZ5BCCvho3EIXw6wUCXHe7rS53AIDPLE+JzwgT+OsJk53oBfbSmZZ7CX4VaRoN78N+TJpFi9QPlfIVNmJYWxQ==", + "version": "4.14.202", + "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.202.tgz", + "integrity": "sha512-OvlIYQK9tNneDlS0VN54LLd5uiPCBOp7gS5Z0f1mjoJYBrtStzgmJBxONW3U6OZqdtNzZPmn9BS/7WI7BFFcFQ==", "dev": true }, "node_modules/@types/lodash.camelcase": { - "version": "4.3.7", - "resolved": "https://registry.npmjs.org/@types/lodash.camelcase/-/lodash.camelcase-4.3.7.tgz", - "integrity": "sha512-Nfi6jpo9vuEOSIJP+mpbTezKyEt75DQlbwjiDvs/JctWkbnHDoyQo5lWqdvgNiJmVUjcmkfvlrvSEgJYvurOKg==", + "version": "4.3.9", + "resolved": "https://registry.npmjs.org/@types/lodash.camelcase/-/lodash.camelcase-4.3.9.tgz", + "integrity": "sha512-ys9/hGBfsKxzmFI8hckII40V0ASQ83UM2pxfQRghHAwekhH4/jWtjz/3/9YDy7ZpUd/H0k2STSqmPR28dnj7Zg==", "dev": true, "dependencies": { "@types/lodash": "*" } }, "node_modules/@types/lodash.clonedeep": { - "version": "4.5.7", - "resolved": "https://registry.npmjs.org/@types/lodash.clonedeep/-/lodash.clonedeep-4.5.7.tgz", - "integrity": "sha512-ccNqkPptFIXrpVqUECi60/DFxjNKsfoQxSQsgcBJCX/fuX1wgyQieojkcWH/KpE3xzLoWN/2k+ZeGqIN3paSvw==", + "version": "4.5.9", + "resolved": "https://registry.npmjs.org/@types/lodash.clonedeep/-/lodash.clonedeep-4.5.9.tgz", + "integrity": "sha512-19429mWC+FyaAhOLzsS8kZUsI+/GmBAQ0HFiCPsKGU+7pBXOQWhyrY6xNNDwUSX8SMZMJvuFVMF9O5dQOlQK9Q==", "dev": true, "dependencies": { "@types/lodash": "*" } }, "node_modules/@types/lodash.clonedeepwith": { - "version": "4.5.7", - "resolved": "https://registry.npmjs.org/@types/lodash.clonedeepwith/-/lodash.clonedeepwith-4.5.7.tgz", - "integrity": "sha512-QPCMby+Glpme6mv/ds4YUSP06bD0FdRVzYF9NjfAP/cKFyjj3BV8bDodx1Npqf/M979WNds1r6K1I7cFwBTmWA==", + "version": "4.5.9", + "resolved": "https://registry.npmjs.org/@types/lodash.clonedeepwith/-/lodash.clonedeepwith-4.5.9.tgz", + "integrity": "sha512-bruhfxIJlj36oWYmYQ7KFbylCGgzyIi+TLypub+wcAd29mV4llKdvru8Pp9qwILX//I5vK3FIcJ0VzszElhLuA==", "dev": true, "dependencies": { "@types/lodash": "*" } }, "node_modules/@types/lodash.findlast": { - "version": "4.6.7", - "resolved": "https://registry.npmjs.org/@types/lodash.findlast/-/lodash.findlast-4.6.7.tgz", - "integrity": "sha512-QP9cSvp2creZZlRHdfz/S1v70ctGShDiK/NdJGQZwhD+IOWmjBO8ldIVEi8La6GTgfyC2ZtIMX3USOvBFYorNg==", + "version": "4.6.9", + "resolved": "https://registry.npmjs.org/@types/lodash.findlast/-/lodash.findlast-4.6.9.tgz", + "integrity": "sha512-mP9/ZOWgVpYTreiKROJKYJxyqA/OBxDPuHEs4xxVBPSJtKZqZgjBwFmPXygQJceGyW0DGxp7zkc5LgCQFDrgjw==", "dev": true, "dependencies": { "@types/lodash": "*" } }, "node_modules/@types/lodash.upperfirst": { - "version": "4.3.7", - "resolved": "https://registry.npmjs.org/@types/lodash.upperfirst/-/lodash.upperfirst-4.3.7.tgz", - "integrity": "sha512-CrBjoB4lO6h7tXNMBUl1eh/w0KdMosiEOXOoD5DMECsA/kDWo/WQfOt1KyGKVvgwK3I6cKAY6z8LymKiMazLFg==", + "version": "4.3.9", + "resolved": "https://registry.npmjs.org/@types/lodash.upperfirst/-/lodash.upperfirst-4.3.9.tgz", + "integrity": "sha512-bYhT1QEsk9/ggrFjK86Pb5bnKJgTBbpVA77Ygbb1aW1oiWJNGRbVjSlQ9We/ihB9vVpX5WqDJvbISXlukGR+dQ==", "dev": true, "dependencies": { "@types/lodash": "*" } }, "node_modules/@types/memory-fs": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@types/memory-fs/-/memory-fs-0.3.3.tgz", - "integrity": "sha512-rLEYzl1xODshz+Lm+YX8NYws8Xw7/qcYbQInMkotl96VpLZmUvoCfYYGxfajMSiugANV02QO5Fc+R98KKeE4gQ==", + "version": "0.3.7", + "resolved": "https://registry.npmjs.org/@types/memory-fs/-/memory-fs-0.3.7.tgz", + "integrity": "sha512-wCRjyqBTpCsnPWDjYkG8x1Ym0ylHUXu2loom+CIXoP9syXvLAROnfghoNKAMSxvetmRXThMd1XSK2AffVT1WMQ==", "dev": true, "dependencies": { "@types/node": "*" } }, "node_modules/@types/mime": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@types/mime/-/mime-3.0.1.tgz", - "integrity": "sha512-Y4XFY5VJAuw0FgAqPNd6NNoV44jbq9Bz2L7Rh/J6jLTiHBSBJa9fxqQIvkIld4GsoDOcCbvzOUAbLPsSKKg+uA==", + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/@types/mime/-/mime-3.0.4.tgz", + "integrity": "sha512-iJt33IQnVRkqeqC7PzBHPTC6fDlRNRW8vjrgqtScAhrmMwe8c4Eo7+fUGTa+XdWrpEgpyKWMYmi2dIwMAYRzPw==", "dev": true }, "node_modules/@types/mocha": { - "version": "10.0.1", - "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-10.0.1.tgz", - "integrity": "sha512-/fvYntiO1GeICvqbQ3doGDIP97vWmvFt83GKguJ6prmQM2iXZfFcq6YE8KteFyRtX2/h5Hf91BYvPodJKFYv5Q==", + "version": "10.0.6", + "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-10.0.6.tgz", + "integrity": "sha512-dJvrYWxP/UcXm36Qn36fxhUKu8A/xMRXVT2cliFF1Z7UA9liG5Psj3ezNSZw+5puH2czDXRLcXQxf8JbJt0ejg==", "dev": true }, "node_modules/@types/node": { - "version": "14.18.34", - "resolved": "https://registry.npmjs.org/@types/node/-/node-14.18.34.tgz", - "integrity": "sha512-hcU9AIQVHmPnmjRK+XUUYlILlr9pQrsqSrwov/JK1pnf3GTQowVBhx54FbvM0AU/VXGH4i3+vgXS5EguR7fysA==" + "version": "14.18.63", + "resolved": "https://registry.npmjs.org/@types/node/-/node-14.18.63.tgz", + "integrity": "sha512-fAtCfv4jJg+ExtXhvCkCqUKZ+4ok/JQk01qDKhL5BDDoS3AxKXhV5/MAVUZyQnSEd2GT92fkgZl0pz0Q0AzcIQ==" }, "node_modules/@types/postcss-safe-parser": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/@types/postcss-safe-parser/-/postcss-safe-parser-5.0.1.tgz", - "integrity": "sha512-/yt27wx9N+HmpCAUS/Wyk1d17qFCmi8cYAnIDar0U0jO4QMG1UFqsvVhg7Cy4xjmEAfAzeyBJmXH5Sti4/fDOQ==", + "version": "5.0.4", + "resolved": "https://registry.npmjs.org/@types/postcss-safe-parser/-/postcss-safe-parser-5.0.4.tgz", + "integrity": "sha512-5zGTm1jsW3j4+omgND1SIDbrZOcigTuxa4ihppvKbLkg2INUGBHV/fWNRSRFibK084tU3fxqZ/kVoSIGqRHnrQ==", "dev": true, "dependencies": { "postcss": "^8.4.4" } }, "node_modules/@types/prop-types": { - "version": "15.7.5", - "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.5.tgz", - "integrity": "sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==", + "version": "15.7.11", + "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.11.tgz", + "integrity": "sha512-ga8y9v9uyeiLdpKddhxYQkxNDrfvuPrlFb0N1qnZZByvcElJaXthF1UhvCh9TLWJBEHeNtdnbysW7Y6Uq8CVng==", "dev": true }, "node_modules/@types/react": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.0.tgz", - "integrity": "sha512-0FLj93y5USLHdnhIhABk83rm8XEGA7kH3cr+YUlvxoUGp1xNt/DINUMvqPxLyOQMzLmZe8i4RTHbvb8MC7NmrA==", + "version": "18.2.46", + "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.46.tgz", + "integrity": "sha512-nNCvVBcZlvX4NU1nRRNV/mFl1nNRuTuslAJglQsq+8ldXe5Xv0Wd2f7WTE3jOxhLH2BFfiZGC6GCp+kHQbgG+w==", "dev": true, "dependencies": { "@types/prop-types": "*", @@ -1065,9 +1337,9 @@ } }, "node_modules/@types/react-dom": { - "version": "18.2.1", - "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.1.tgz", - "integrity": "sha512-8QZEV9+Kwy7tXFmjJrp3XUKQSs9LTnE0KnoUb0YCguWBiNW0Yfb2iBMYZ08WPg35IR6P3Z0s00B15SwZnO26+w==", + "version": "18.2.18", + "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.18.tgz", + "integrity": "sha512-TJxDm6OfAX2KJWJdMEVTwWke5Sc/E/RlnPGvGfS0W7+6ocy2xhDVQVh/KvC2Uf7kACs+gDytdusDSdWfWkaNzw==", "dev": true, "dependencies": { "@types/react": "*" @@ -1080,49 +1352,49 @@ "dev": true }, "node_modules/@types/scheduler": { - "version": "0.16.2", - "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.2.tgz", - "integrity": "sha512-hppQEBDmlwhFAXKJX2KnWLYu5yMfi91yazPb2l+lbJiwW+wdo1gNeRA+3RgNSO39WYX2euey41KEwnqesU2Jew==", + "version": "0.16.8", + "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.8.tgz", + "integrity": "sha512-WZLiwShhwLRmeV6zH+GkbOFT6Z6VklCItrDioxUnv+u4Ll+8vKeFySoFyK/0ctcRpOmwAicELfmys1sDc/Rw+A==", "dev": true }, "node_modules/@types/semver": { - "version": "7.3.13", - "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.3.13.tgz", - "integrity": "sha512-21cFJr9z3g5dW8B0CVI9g2O9beqaThGQ6ZFBqHfwhzLDKUxaqTIy3vnfah/UPkfOiF2pLq+tGz+W8RyCskuslw==" + "version": "7.5.6", + "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.6.tgz", + "integrity": "sha512-dn1l8LaMea/IjDoHNd9J52uBbInB796CDffS6VdIxvqYCPSG0V0DzHp76GpaWnlhg88uYyPbXCDIowa86ybd5A==" }, "node_modules/@types/validate-npm-package-name": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/@types/validate-npm-package-name/-/validate-npm-package-name-4.0.0.tgz", - "integrity": "sha512-RpO62vB2lkjEkyLbwTheA2+uwYmtVMWTr/kWRI++UAgVdZqNqdAuIQl/SxBCGeMKfdjWaXPbyhZbiCc4PAj+KA==", + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/@types/validate-npm-package-name/-/validate-npm-package-name-4.0.2.tgz", + "integrity": "sha512-lrpDziQipxCEeK5kWxvljWYhUvOiB2A9izZd9B2AFarYAkqZshb4lPbRs7zKEic6eGtH8V/2qJW+dPp9OtF6bw==", "dev": true }, "node_modules/@types/yargs": { - "version": "17.0.24", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.24.tgz", - "integrity": "sha512-6i0aC7jV6QzQB8ne1joVZ0eSFIstHsCrobmOtghM11yGlH0j43FKL2UhWdELkyps0zuf7qVTUVCCR+tgSlyLLw==", + "version": "17.0.32", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.32.tgz", + "integrity": "sha512-xQ67Yc/laOG5uMfX/093MRlGGCIBzZMarVa+gfNKJxWAIgykYpVGkBdbqEzGDDfCrVUj6Hiff4mTZ5BA6TmAog==", "dev": true, "dependencies": { "@types/yargs-parser": "*" } }, "node_modules/@types/yargs-parser": { - "version": "21.0.0", - "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz", - "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==", + "version": "21.0.3", + "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.3.tgz", + "integrity": "sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==", "dev": true }, "node_modules/@typescript-eslint/eslint-plugin": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.59.2.tgz", - "integrity": "sha512-yVrXupeHjRxLDcPKL10sGQ/QlVrA8J5IYOEWVqk0lJaSZP7X5DfnP7Ns3cc74/blmbipQ1htFNVGsHX6wsYm0A==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.62.0.tgz", + "integrity": "sha512-TiZzBSJja/LbhNPvk6yc0JrX9XqhQ0hdh6M2svYfsHGejaKFIAGd9MQ+ERIMzLGlN/kZoYIgdxFV0PuljTKXag==", "dev": true, "dependencies": { "@eslint-community/regexpp": "^4.4.0", - "@typescript-eslint/scope-manager": "5.59.2", - "@typescript-eslint/type-utils": "5.59.2", - "@typescript-eslint/utils": "5.59.2", + "@typescript-eslint/scope-manager": "5.62.0", + "@typescript-eslint/type-utils": "5.62.0", + "@typescript-eslint/utils": "5.62.0", "debug": "^4.3.4", - "grapheme-splitter": "^1.0.4", + "graphemer": "^1.4.0", "ignore": "^5.2.0", "natural-compare-lite": "^1.4.0", "semver": "^7.3.7", @@ -1145,33 +1417,15 @@ } } }, - "node_modules/@typescript-eslint/experimental-utils": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-5.59.2.tgz", - "integrity": "sha512-JLw2UImsjHDuVukpA8Nt+UK7JKE/LQAeV3tU5f7wJo2/NNYVwcakzkWjoYzu/2qzWY/Z9c7zojngNDfecNt92g==", - "dependencies": { - "@typescript-eslint/utils": "5.59.2" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependencies": { - "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" - } - }, "node_modules/@typescript-eslint/parser": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.59.2.tgz", - "integrity": "sha512-uq0sKyw6ao1iFOZZGk9F8Nro/8+gfB5ezl1cA06SrqbgJAt0SRoFhb9pXaHvkrxUpZaoLxt8KlovHNk8Gp6/HQ==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.62.0.tgz", + "integrity": "sha512-VlJEV0fOQ7BExOsHYAGrgbEiZoi8D+Bl2+f6V2RrXerRSylnp+ZBHmPvaIa8cz0Ajx7WO7Z5RqfgYg7ED1nRhA==", "dev": true, "dependencies": { - "@typescript-eslint/scope-manager": "5.59.2", - "@typescript-eslint/types": "5.59.2", - "@typescript-eslint/typescript-estree": "5.59.2", + "@typescript-eslint/scope-manager": "5.62.0", + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/typescript-estree": "5.62.0", "debug": "^4.3.4" }, "engines": { @@ -1191,12 +1445,12 @@ } }, "node_modules/@typescript-eslint/scope-manager": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.59.2.tgz", - "integrity": "sha512-dB1v7ROySwQWKqQ8rEWcdbTsFjh2G0vn8KUyvTXdPoyzSL6lLGkiXEV5CvpJsEe9xIdKV+8Zqb7wif2issoOFA==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.62.0.tgz", + "integrity": "sha512-VXuvVvZeQCQb5Zgf4HAxc04q5j+WrNAtNh9OwCsCgpKqESMTu3tF/jhZ3xG6T4NZwWl65Bg8KuS2uEvhSfLl0w==", "dependencies": { - "@typescript-eslint/types": "5.59.2", - "@typescript-eslint/visitor-keys": "5.59.2" + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/visitor-keys": "5.62.0" }, "engines": { "node": "^12.22.0 || ^14.17.0 || >=16.0.0" @@ -1207,13 +1461,13 @@ } }, "node_modules/@typescript-eslint/type-utils": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.59.2.tgz", - "integrity": "sha512-b1LS2phBOsEy/T381bxkkywfQXkV1dWda/z0PhnIy3bC5+rQWQDS7fk9CSpcXBccPY27Z6vBEuaPBCKCgYezyQ==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.62.0.tgz", + "integrity": "sha512-xsSQreu+VnfbqQpW5vnCJdq1Z3Q0U31qiWmRhr98ONQmcp/yhiPJFPq8MXiJVLiksmOKSjIldZzkebzHuCGzew==", "dev": true, "dependencies": { - "@typescript-eslint/typescript-estree": "5.59.2", - "@typescript-eslint/utils": "5.59.2", + "@typescript-eslint/typescript-estree": "5.62.0", + "@typescript-eslint/utils": "5.62.0", "debug": "^4.3.4", "tsutils": "^3.21.0" }, @@ -1234,9 +1488,9 @@ } }, "node_modules/@typescript-eslint/types": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.59.2.tgz", - "integrity": "sha512-LbJ/HqoVs2XTGq5shkiKaNTuVv5tTejdHgfdjqRUGdYhjW1crm/M7og2jhVskMt8/4wS3T1+PfFvL1K3wqYj4w==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.62.0.tgz", + "integrity": "sha512-87NVngcbVXUahrRTqIK27gD2t5Cu1yuCXxbLcFtCzZGlfyVWWh8mLHkoxzjsB6DDNnvdL+fW8MiwPEJyGJQDgQ==", "engines": { "node": "^12.22.0 || ^14.17.0 || >=16.0.0" }, @@ -1246,12 +1500,12 @@ } }, "node_modules/@typescript-eslint/typescript-estree": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.59.2.tgz", - "integrity": "sha512-+j4SmbwVmZsQ9jEyBMgpuBD0rKwi9RxRpjX71Brr73RsYnEr3Lt5QZ624Bxphp8HUkSKfqGnPJp1kA5nl0Sh7Q==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.62.0.tgz", + "integrity": "sha512-CmcQ6uY7b9y694lKdRB8FEel7JbU/40iSAPomu++SjLMntB+2Leay2LO6i8VnJk58MtE9/nQSFIH6jpyRWyYzA==", "dependencies": { - "@typescript-eslint/types": "5.59.2", - "@typescript-eslint/visitor-keys": "5.59.2", + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/visitor-keys": "5.62.0", "debug": "^4.3.4", "globby": "^11.1.0", "is-glob": "^4.0.3", @@ -1272,16 +1526,16 @@ } }, "node_modules/@typescript-eslint/utils": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.59.2.tgz", - "integrity": "sha512-kSuF6/77TZzyGPhGO4uVp+f0SBoYxCDf+lW3GKhtKru/L8k/Hd7NFQxyWUeY7Z/KGB2C6Fe3yf2vVi4V9TsCSQ==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.62.0.tgz", + "integrity": "sha512-n8oxjeb5aIbPFEtmQxQYOLI0i9n5ySBEY/ZEHHZqKQSFnxio1rv6dthascc9dLuwrL0RC5mPCxB7vnAVGAYWAQ==", "dependencies": { "@eslint-community/eslint-utils": "^4.2.0", "@types/json-schema": "^7.0.9", "@types/semver": "^7.3.12", - "@typescript-eslint/scope-manager": "5.59.2", - "@typescript-eslint/types": "5.59.2", - "@typescript-eslint/typescript-estree": "5.59.2", + "@typescript-eslint/scope-manager": "5.62.0", + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/typescript-estree": "5.62.0", "eslint-scope": "^5.1.1", "semver": "^7.3.7" }, @@ -1297,11 +1551,11 @@ } }, "node_modules/@typescript-eslint/visitor-keys": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.59.2.tgz", - "integrity": "sha512-EEpsO8m3RASrKAHI9jpavNv9NlEUebV4qmF1OWxSTtKSFBpC1NCmWazDQHFivRf0O1DV11BA645yrLEVQ0/Lig==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.62.0.tgz", + "integrity": "sha512-07ny+LHRzQXepkGg6w0mFY41fVUNBrL2Roj/++7V1txKugfjm/Ci/qSND03r2RhlJhJYMcTn9AhhSSqQp0Ysyw==", "dependencies": { - "@typescript-eslint/types": "5.59.2", + "@typescript-eslint/types": "5.62.0", "eslint-visitor-keys": "^3.3.0" }, "engines": { @@ -1312,139 +1566,144 @@ "url": "https://opencollective.com/typescript-eslint" } }, + "node_modules/@ungap/structured-clone": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", + "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==" + }, "node_modules/@vscode/l10n": { - "version": "0.0.13", - "resolved": "https://registry.npmjs.org/@vscode/l10n/-/l10n-0.0.13.tgz", - "integrity": "sha512-A3uY356uOU9nGa+TQIT/i3ziWUgJjVMUrGGXSrtRiTwklyCFjGVWIOHoEIHbJpiyhDkJd9kvIWUOfXK1IkK8XQ==" + "version": "0.0.16", + "resolved": "https://registry.npmjs.org/@vscode/l10n/-/l10n-0.0.16.tgz", + "integrity": "sha512-JT5CvrIYYCrmB+dCana8sUqJEcGB1ZDXNLMQ2+42bW995WmNoenijWMUdZfwmuQUTQcEVVIa2OecZzTYWUW9Cg==" }, "node_modules/@webassemblyjs/ast": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.11.5.tgz", - "integrity": "sha512-LHY/GSAZZRpsNQH+/oHqhRQ5FT7eoULcBqgfyTB5nQHogFnK3/7QoN7dLnwSE/JkUAF0SrRuclT7ODqMFtWxxQ==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.11.6.tgz", + "integrity": "sha512-IN1xI7PwOvLPgjcf180gC1bqn3q/QaOCwYUahIOhbYUu8KA/3tw2RT/T0Gidi1l7Hhj5D/INhJxiICObqpMu4Q==", "dependencies": { - "@webassemblyjs/helper-numbers": "1.11.5", - "@webassemblyjs/helper-wasm-bytecode": "1.11.5" + "@webassemblyjs/helper-numbers": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6" } }, "node_modules/@webassemblyjs/floating-point-hex-parser": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.5.tgz", - "integrity": "sha512-1j1zTIC5EZOtCplMBG/IEwLtUojtwFVwdyVMbL/hwWqbzlQoJsWCOavrdnLkemwNoC/EOwtUFch3fuo+cbcXYQ==" + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.6.tgz", + "integrity": "sha512-ejAj9hfRJ2XMsNHk/v6Fu2dGS+i4UaXBXGemOfQ/JfQ6mdQg/WXtwleQRLLS4OvfDhv8rYnVwH27YJLMyYsxhw==" }, "node_modules/@webassemblyjs/helper-api-error": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.5.tgz", - "integrity": "sha512-L65bDPmfpY0+yFrsgz8b6LhXmbbs38OnwDCf6NpnMUYqa+ENfE5Dq9E42ny0qz/PdR0LJyq/T5YijPnU8AXEpA==" + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.6.tgz", + "integrity": "sha512-o0YkoP4pVu4rN8aTJgAyj9hC2Sv5UlkzCHhxqWj8butaLvnpdc2jOwh4ewE6CX0txSfLn/UYaV/pheS2Txg//Q==" }, "node_modules/@webassemblyjs/helper-buffer": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.5.tgz", - "integrity": "sha512-fDKo1gstwFFSfacIeH5KfwzjykIE6ldh1iH9Y/8YkAZrhmu4TctqYjSh7t0K2VyDSXOZJ1MLhht/k9IvYGcIxg==" + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.6.tgz", + "integrity": "sha512-z3nFzdcp1mb8nEOFFk8DrYLpHvhKC3grJD2ardfKOzmbmJvEf/tPIqCY+sNcwZIY8ZD7IkB2l7/pqhUhqm7hLA==" }, "node_modules/@webassemblyjs/helper-numbers": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.5.tgz", - "integrity": "sha512-DhykHXM0ZABqfIGYNv93A5KKDw/+ywBFnuWybZZWcuzWHfbp21wUfRkbtz7dMGwGgT4iXjWuhRMA2Mzod6W4WA==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.6.tgz", + "integrity": "sha512-vUIhZ8LZoIWHBohiEObxVm6hwP034jwmc9kuq5GdHZH0wiLVLIPcMCdpJzG4C11cHoQ25TFIQj9kaVADVX7N3g==", "dependencies": { - "@webassemblyjs/floating-point-hex-parser": "1.11.5", - "@webassemblyjs/helper-api-error": "1.11.5", + "@webassemblyjs/floating-point-hex-parser": "1.11.6", + "@webassemblyjs/helper-api-error": "1.11.6", "@xtuc/long": "4.2.2" } }, "node_modules/@webassemblyjs/helper-wasm-bytecode": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.5.tgz", - "integrity": "sha512-oC4Qa0bNcqnjAowFn7MPCETQgDYytpsfvz4ujZz63Zu/a/v71HeCAAmZsgZ3YVKec3zSPYytG3/PrRCqbtcAvA==" + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.6.tgz", + "integrity": "sha512-sFFHKwcmBprO9e7Icf0+gddyWYDViL8bpPjJJl0WHxCdETktXdmtWLGVzoHbqUcY4Be1LkNfwTmXOJUFZYSJdA==" }, "node_modules/@webassemblyjs/helper-wasm-section": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.5.tgz", - "integrity": "sha512-uEoThA1LN2NA+K3B9wDo3yKlBfVtC6rh0i4/6hvbz071E8gTNZD/pT0MsBf7MeD6KbApMSkaAK0XeKyOZC7CIA==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.6.tgz", + "integrity": "sha512-LPpZbSOwTpEC2cgn4hTydySy1Ke+XEu+ETXuoyvuyezHO3Kjdu90KK95Sh9xTbmjrCsUwvWwCOQQNta37VrS9g==", "dependencies": { - "@webassemblyjs/ast": "1.11.5", - "@webassemblyjs/helper-buffer": "1.11.5", - "@webassemblyjs/helper-wasm-bytecode": "1.11.5", - "@webassemblyjs/wasm-gen": "1.11.5" + "@webassemblyjs/ast": "1.11.6", + "@webassemblyjs/helper-buffer": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/wasm-gen": "1.11.6" } }, "node_modules/@webassemblyjs/ieee754": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.5.tgz", - "integrity": "sha512-37aGq6qVL8A8oPbPrSGMBcp38YZFXcHfiROflJn9jxSdSMMM5dS5P/9e2/TpaJuhE+wFrbukN2WI6Hw9MH5acg==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.6.tgz", + "integrity": "sha512-LM4p2csPNvbij6U1f19v6WR56QZ8JcHg3QIJTlSwzFcmx6WSORicYj6I63f9yU1kEUtrpG+kjkiIAkevHpDXrg==", "dependencies": { "@xtuc/ieee754": "^1.2.0" } }, "node_modules/@webassemblyjs/leb128": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.5.tgz", - "integrity": "sha512-ajqrRSXaTJoPW+xmkfYN6l8VIeNnR4vBOTQO9HzR7IygoCcKWkICbKFbVTNMjMgMREqXEr0+2M6zukzM47ZUfQ==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.6.tgz", + "integrity": "sha512-m7a0FhE67DQXgouf1tbN5XQcdWoNgaAuoULHIfGFIEVKA6tu/edls6XnIlkmS6FrXAquJRPni3ZZKjw6FSPjPQ==", "dependencies": { "@xtuc/long": "4.2.2" } }, "node_modules/@webassemblyjs/utf8": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.5.tgz", - "integrity": "sha512-WiOhulHKTZU5UPlRl53gHR8OxdGsSOxqfpqWeA2FmcwBMaoEdz6b2x2si3IwC9/fSPLfe8pBMRTHVMk5nlwnFQ==" + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.6.tgz", + "integrity": "sha512-vtXf2wTQ3+up9Zsg8sa2yWiQpzSsMyXj0qViVP6xKGCUT8p8YJ6HqI7l5eCnWx1T/FYdsv07HQs2wTFbbof/RA==" }, "node_modules/@webassemblyjs/wasm-edit": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.5.tgz", - "integrity": "sha512-C0p9D2fAu3Twwqvygvf42iGCQ4av8MFBLiTb+08SZ4cEdwzWx9QeAHDo1E2k+9s/0w1DM40oflJOpkZ8jW4HCQ==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.6.tgz", + "integrity": "sha512-Ybn2I6fnfIGuCR+Faaz7YcvtBKxvoLV3Lebn1tM4o/IAJzmi9AWYIPWpyBfU8cC+JxAO57bk4+zdsTjJR+VTOw==", "dependencies": { - "@webassemblyjs/ast": "1.11.5", - "@webassemblyjs/helper-buffer": "1.11.5", - "@webassemblyjs/helper-wasm-bytecode": "1.11.5", - "@webassemblyjs/helper-wasm-section": "1.11.5", - "@webassemblyjs/wasm-gen": "1.11.5", - "@webassemblyjs/wasm-opt": "1.11.5", - "@webassemblyjs/wasm-parser": "1.11.5", - "@webassemblyjs/wast-printer": "1.11.5" + "@webassemblyjs/ast": "1.11.6", + "@webassemblyjs/helper-buffer": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/helper-wasm-section": "1.11.6", + "@webassemblyjs/wasm-gen": "1.11.6", + "@webassemblyjs/wasm-opt": "1.11.6", + "@webassemblyjs/wasm-parser": "1.11.6", + "@webassemblyjs/wast-printer": "1.11.6" } }, "node_modules/@webassemblyjs/wasm-gen": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.5.tgz", - "integrity": "sha512-14vteRlRjxLK9eSyYFvw1K8Vv+iPdZU0Aebk3j6oB8TQiQYuO6hj9s4d7qf6f2HJr2khzvNldAFG13CgdkAIfA==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.6.tgz", + "integrity": "sha512-3XOqkZP/y6B4F0PBAXvI1/bky7GryoogUtfwExeP/v7Nzwo1QLcq5oQmpKlftZLbT+ERUOAZVQjuNVak6UXjPA==", "dependencies": { - "@webassemblyjs/ast": "1.11.5", - "@webassemblyjs/helper-wasm-bytecode": "1.11.5", - "@webassemblyjs/ieee754": "1.11.5", - "@webassemblyjs/leb128": "1.11.5", - "@webassemblyjs/utf8": "1.11.5" + "@webassemblyjs/ast": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/ieee754": "1.11.6", + "@webassemblyjs/leb128": "1.11.6", + "@webassemblyjs/utf8": "1.11.6" } }, "node_modules/@webassemblyjs/wasm-opt": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.5.tgz", - "integrity": "sha512-tcKwlIXstBQgbKy1MlbDMlXaxpucn42eb17H29rawYLxm5+MsEmgPzeCP8B1Cl69hCice8LeKgZpRUAPtqYPgw==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.6.tgz", + "integrity": "sha512-cOrKuLRE7PCe6AsOVl7WasYf3wbSo4CeOk6PkrjS7g57MFfVUF9u6ysQBBODX0LdgSvQqRiGz3CXvIDKcPNy4g==", "dependencies": { - "@webassemblyjs/ast": "1.11.5", - "@webassemblyjs/helper-buffer": "1.11.5", - "@webassemblyjs/wasm-gen": "1.11.5", - "@webassemblyjs/wasm-parser": "1.11.5" + "@webassemblyjs/ast": "1.11.6", + "@webassemblyjs/helper-buffer": "1.11.6", + "@webassemblyjs/wasm-gen": "1.11.6", + "@webassemblyjs/wasm-parser": "1.11.6" } }, "node_modules/@webassemblyjs/wasm-parser": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.5.tgz", - "integrity": "sha512-SVXUIwsLQlc8srSD7jejsfTU83g7pIGr2YYNb9oHdtldSxaOhvA5xwvIiWIfcX8PlSakgqMXsLpLfbbJ4cBYew==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.6.tgz", + "integrity": "sha512-6ZwPeGzMJM3Dqp3hCsLgESxBGtT/OeCvCZ4TA1JUPYgmhAx38tTPR9JaKy0S5H3evQpO/h2uWs2j6Yc/fjkpTQ==", "dependencies": { - "@webassemblyjs/ast": "1.11.5", - "@webassemblyjs/helper-api-error": "1.11.5", - "@webassemblyjs/helper-wasm-bytecode": "1.11.5", - "@webassemblyjs/ieee754": "1.11.5", - "@webassemblyjs/leb128": "1.11.5", - "@webassemblyjs/utf8": "1.11.5" + "@webassemblyjs/ast": "1.11.6", + "@webassemblyjs/helper-api-error": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/ieee754": "1.11.6", + "@webassemblyjs/leb128": "1.11.6", + "@webassemblyjs/utf8": "1.11.6" } }, "node_modules/@webassemblyjs/wast-printer": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.11.5.tgz", - "integrity": "sha512-f7Pq3wvg3GSPUPzR0F6bmI89Hdb+u9WXrSKc4v+N0aV0q6r42WoF92Jp2jEorBEBRoRNXgjp53nBniDXcqZYPA==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.11.6.tgz", + "integrity": "sha512-JM7AhRcE+yW2GWYaKeHL5vt4xqee5N2WcezptmgyhNS+ScggqcT1OtXykhAb13Sn5Yas0j2uv9tHgrjwvzAP4A==", "dependencies": { - "@webassemblyjs/ast": "1.11.5", + "@webassemblyjs/ast": "1.11.6", "@xtuc/long": "4.2.2" } }, @@ -1469,9 +1728,9 @@ } }, "node_modules/@wixc3/resolve-directory-context/node_modules/minimatch": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.0.tgz", - "integrity": "sha512-0jJj8AvgKqWN05mrwuqi8QYKx1WmYSUoKSxu5Qhs9prezTz10sxAHGNZe9J9cqIJzta8DWsleh2KaVaLl6Ru2w==", + "version": "9.0.3", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", + "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", "dependencies": { "brace-expansion": "^2.0.1" }, @@ -1483,9 +1742,9 @@ } }, "node_modules/@wixc3/resolve-directory-context/node_modules/type-fest": { - "version": "3.8.0", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-3.8.0.tgz", - "integrity": "sha512-FVNSzGQz9Th+/9R6Lvv7WIAkstylfHN2/JYxkyhhmKFYh9At2DST8t6L6Lref9eYO8PXFTfG9Sg1Agg0K3vq3Q==", + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-3.13.1.tgz", + "integrity": "sha512-tLq3bSNx+xSpwvAJnzrK0Ep5CLNWjvFTOp71URMaAEWBfRb9nnJiBoUe0tF8bI4ZFO3omgBR6NvnbzVUT3Ly4g==", "engines": { "node": ">=14.16" }, @@ -1503,21 +1762,18 @@ "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==" }, - "node_modules/abab": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.6.tgz", - "integrity": "sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==", - "dev": true - }, "node_modules/abbrev": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", - "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-2.0.0.tgz", + "integrity": "sha512-6/mh1E2u2YgEsCHdY0Yx5oW+61gZU+1vXaoiHHrpKeuRNNgFvS+/jrwHiQhB5apAf5oB7UB7E19ol2R2LKH8hQ==", + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } }, "node_modules/acorn": { - "version": "8.8.1", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.1.tgz", - "integrity": "sha512-7zFpHzhnqYKrkYdUjF1HI1bzd0VygEGX8lFk4k5zVMqHEoES+P+7TKI+EvLO9WVMJ8eekdO0aDEK044xTXwPPA==", + "version": "8.11.3", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", + "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", "bin": { "acorn": "bin/acorn" }, @@ -1526,9 +1782,9 @@ } }, "node_modules/acorn-import-assertions": { - "version": "1.8.0", - "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.8.0.tgz", - "integrity": "sha512-m7VZ3jwz4eK6A4Vtt8Ew1/mNbP24u0FhdyfA7fSvnJR6LMdfOYnmuIrrJAgrYfYJ10F/otaHTtrtrtmHdMNzEw==", + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.9.0.tgz", + "integrity": "sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==", "peerDependencies": { "acorn": "^8" } @@ -1574,9 +1830,9 @@ } }, "node_modules/ajv-formats/node_modules/ajv": { - "version": "8.11.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.11.2.tgz", - "integrity": "sha512-E4bfmKAhGiSTvMfL1Myyycaub+cUEU2/IvpylXkUu7CHBkBj1f/ikdzbD7YQ6FKUbixDxeYvB/xY4fvyroDlQg==", + "version": "8.12.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.12.0.tgz", + "integrity": "sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==", "dev": true, "dependencies": { "fast-deep-equal": "^3.1.1", @@ -1652,20 +1908,14 @@ "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==" }, - "node_modules/array-includes": { - "version": "3.1.6", - "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.6.tgz", - "integrity": "sha512-sgTbLvL6cNnw24FnbaDyjmvddQ2ML8arZsgaJhoABMoplz/4QRhtrYS+alr1BUM1Bwp6dhx8vVCBSLG+StwOFw==", + "node_modules/array-buffer-byte-length": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz", + "integrity": "sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==", "dev": true, "dependencies": { "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "get-intrinsic": "^1.1.3", - "is-string": "^1.0.7" - }, - "engines": { - "node": ">= 0.4" + "is-array-buffer": "^3.0.1" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -1679,16 +1929,19 @@ "node": ">=8" } }, - "node_modules/array.prototype.flatmap": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.1.tgz", - "integrity": "sha512-8UGn9O1FDVvMNB0UlLv4voxRMze7+FpHyF5mSMRjWHUMlpoDViniy05870VlxhfgTnLbpuwTzvD76MTtWxB/mQ==", + "node_modules/arraybuffer.prototype.slice": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.2.tgz", + "integrity": "sha512-yMBKppFur/fbHu9/6USUe03bZ4knMYiwFBcyiaXB8Go0qNehwX6inYPzK9U0NeQvGxKthcmHcaR8P5MStSRBAw==", "dev": true, "dependencies": { + "array-buffer-byte-length": "^1.0.0", "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "es-shim-unscopables": "^1.0.0" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "get-intrinsic": "^1.2.1", + "is-array-buffer": "^3.0.2", + "is-shared-array-buffer": "^1.0.2" }, "engines": { "node": ">= 0.4" @@ -1697,19 +1950,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/array.prototype.tosorted": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.1.tgz", - "integrity": "sha512-pZYPXPRl2PqWcsUs6LOMn+1f1532nEoPTYowBtqLwAW+W8vSVhkIGnmOX1t/UQjD6YGI0vcD2B1U7ZFGQH9jnQ==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "es-shim-unscopables": "^1.0.0", - "get-intrinsic": "^1.1.3" - } - }, "node_modules/assertion-error": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", @@ -1719,9 +1959,9 @@ } }, "node_modules/autoprefixer": { - "version": "10.4.14", - "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.14.tgz", - "integrity": "sha512-FQzyfOsTlwVzjHxKEqRIAdJx9niO6VCBCoEwax/VLSoQF29ggECcPuBqUMZ+u8jCZOPSy8b8/8KnuFbp0SaFZQ==", + "version": "10.4.16", + "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.16.tgz", + "integrity": "sha512-7vd3UC6xKp0HLfua5IjZlcXvGAGy7cBAXTg2lyQ/8WpNhd6SiZ8Be+xm3FyBSYJx5GKcpRCzBh7RH4/0dnY+uQ==", "dev": true, "funding": [ { @@ -1731,12 +1971,16 @@ { "type": "tidelift", "url": "https://tidelift.com/funding/github/npm/autoprefixer" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" } ], "dependencies": { - "browserslist": "^4.21.5", - "caniuse-lite": "^1.0.30001464", - "fraction.js": "^4.2.0", + "browserslist": "^4.21.10", + "caniuse-lite": "^1.0.30001538", + "fraction.js": "^4.3.6", "normalize-range": "^0.1.2", "picocolors": "^1.0.0", "postcss-value-parser": "^4.2.0" @@ -1751,6 +1995,18 @@ "postcss": "^8.1.0" } }, + "node_modules/available-typed-arrays": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", + "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/balanced-match": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", @@ -1807,9 +2063,9 @@ "dev": true }, "node_modules/browserslist": { - "version": "4.21.5", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.5.tgz", - "integrity": "sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w==", + "version": "4.22.2", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.22.2.tgz", + "integrity": "sha512-0UgcrvQmBDvZHFGdYUehrCNIazki7/lUP3kkoi/r3YB2amZbFM9J43ZRkJTXBUZK4gmx56+Sqk9+Vs9mwZx9+A==", "funding": [ { "type": "opencollective", @@ -1818,13 +2074,17 @@ { "type": "tidelift", "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" } ], "dependencies": { - "caniuse-lite": "^1.0.30001449", - "electron-to-chromium": "^1.4.284", - "node-releases": "^2.0.8", - "update-browserslist-db": "^1.0.10" + "caniuse-lite": "^1.0.30001565", + "electron-to-chromium": "^1.4.601", + "node-releases": "^2.0.14", + "update-browserslist-db": "^1.0.13" }, "bin": { "browserslist": "cli.js" @@ -1859,9 +2119,9 @@ } }, "node_modules/c8": { - "version": "7.13.0", - "resolved": "https://registry.npmjs.org/c8/-/c8-7.13.0.tgz", - "integrity": "sha512-/NL4hQTv1gBL6J6ei80zu3IiTrmePDKXKXOTLpHvcIWZTVYQlDhVWjjWvkhICylE8EwwnMVzDZugCvdx0/DIIA==", + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/c8/-/c8-8.0.1.tgz", + "integrity": "sha512-EINpopxZNH1mETuI0DzRA4MZpAUH+IFiRhnmFD3vFr3vdrgxqi3VfE3KL0AIL+zDq8rC9bZqwM/VDmmoe04y7w==", "dev": true, "dependencies": { "@bcoe/v8-coverage": "^0.2.3", @@ -1869,30 +2129,19 @@ "find-up": "^5.0.0", "foreground-child": "^2.0.0", "istanbul-lib-coverage": "^3.2.0", - "istanbul-lib-report": "^3.0.0", - "istanbul-reports": "^3.1.4", + "istanbul-lib-report": "^3.0.1", + "istanbul-reports": "^3.1.6", "rimraf": "^3.0.2", "test-exclude": "^6.0.0", "v8-to-istanbul": "^9.0.0", - "yargs": "^16.2.0", - "yargs-parser": "^20.2.9" + "yargs": "^17.7.2", + "yargs-parser": "^21.1.1" }, "bin": { "c8": "bin/c8.js" }, "engines": { - "node": ">=10.12.0" - } - }, - "node_modules/c8/node_modules/cliui": { - "version": "7.0.4", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", - "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", - "dev": true, - "dependencies": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.0", - "wrap-ansi": "^7.0.0" + "node": ">=12" } }, "node_modules/c8/node_modules/rimraf": { @@ -1910,32 +2159,15 @@ "url": "https://github.com/sponsors/isaacs" } }, - "node_modules/c8/node_modules/yargs": { - "version": "16.2.0", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", - "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", - "dev": true, - "dependencies": { - "cliui": "^7.0.2", - "escalade": "^3.1.1", - "get-caller-file": "^2.0.5", - "require-directory": "^2.1.1", - "string-width": "^4.2.0", - "y18n": "^5.0.5", - "yargs-parser": "^20.2.2" - }, - "engines": { - "node": ">=10" - } - }, "node_modules/call-bind": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", - "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.5.tgz", + "integrity": "sha512-C3nQxfFZxFRVoJoGKKI8y3MOEo129NQ+FgQ08iye+Mk4zNZZGdjfs06bVTr+DBSlA66Q2VEcMki/cUCP4SercQ==", "dev": true, "dependencies": { - "function-bind": "^1.1.1", - "get-intrinsic": "^1.0.2" + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.1", + "set-function-length": "^1.1.1" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -1967,6 +2199,18 @@ "tslib": "^2.0.3" } }, + "node_modules/camelcase": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", + "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/camelcase-css": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/camelcase-css/-/camelcase-css-2.0.1.tgz", @@ -1976,9 +2220,9 @@ } }, "node_modules/caniuse-lite": { - "version": "1.0.30001466", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001466.tgz", - "integrity": "sha512-ewtFBSfWjEmxUgNBSZItFSmVtvk9zkwkl1OfRZlKA8slltRN+/C/tuGVrF9styXkN36Yu3+SeJ1qkXxDEyNZ5w==", + "version": "1.0.30001572", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001572.tgz", + "integrity": "sha512-1Pbh5FLmn5y4+QhNyJE9j3/7dK44dGB83/ZMjv/qJk86TvDbjk0LosiZo0i0WB0Vx607qMX9jYrn1VLHCkN4rw==", "funding": [ { "type": "opencollective", @@ -1987,21 +2231,25 @@ { "type": "tidelift", "url": "https://tidelift.com/funding/github/npm/caniuse-lite" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" } ] }, "node_modules/chai": { - "version": "4.3.7", - "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.7.tgz", - "integrity": "sha512-HLnAzZ2iupm25PlN0xFreAlBA5zaBSv3og0DdeGA4Ar6h6rJ3A0rolRUKJhSF2V10GZKDgWF/VmAEsNWjCRB+A==", + "version": "4.3.10", + "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.10.tgz", + "integrity": "sha512-0UXG04VuVbruMUYbJ6JctvH0YnC/4q3/AkT18q4NaITo91CUm0liMS9VqzT9vZhVQ/1eqPanMWjBM+Juhfb/9g==", "dependencies": { "assertion-error": "^1.1.0", - "check-error": "^1.0.2", - "deep-eql": "^4.1.2", - "get-func-name": "^2.0.0", - "loupe": "^2.3.1", + "check-error": "^1.0.3", + "deep-eql": "^4.1.3", + "get-func-name": "^2.0.2", + "loupe": "^2.3.6", "pathval": "^1.1.1", - "type-detect": "^4.0.5" + "type-detect": "^4.0.8" }, "engines": { "node": ">=4" @@ -2032,9 +2280,12 @@ } }, "node_modules/check-error": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", - "integrity": "sha512-BrgHpW9NURQgzoNyjfq0Wu6VFO6D7IZEmJNdtgNqpzGG8RuNFHt2jQxWlAs4HMe119chBnv+34syEZtc6IhLtA==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.3.tgz", + "integrity": "sha512-iKEoDYaRmd1mxM90a2OEfWhjsjPpYPuQ+lMYsoxB126+t8fw7ySEO48nmDg5COTjxDI65/Y2OWpeEHk3ZOe8zg==", + "dependencies": { + "get-func-name": "^2.0.2" + }, "engines": { "node": "*" } @@ -2087,9 +2338,9 @@ } }, "node_modules/clean-css": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-5.3.1.tgz", - "integrity": "sha512-lCr8OHhiWCTw4v8POJovCoh4T7I9U11yVsPjMWWnnMmp9ZowCxyad1Pathle/9HjaDp+fdQKjO9fQydE6RHTZg==", + "version": "5.3.3", + "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-5.3.3.tgz", + "integrity": "sha512-D5J+kHaVb/wKSFcyyV75uCn8fiY4sV38XJoe4CUyGQ+mOU/fMVYUdH1hJC+CJQ5uY3EnW27SbJYS4X8BiLrAFg==", "dev": true, "dependencies": { "source-map": "~0.6.0" @@ -2160,9 +2411,9 @@ } }, "node_modules/convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", + "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", "dev": true }, "node_modules/create-listening-server": { @@ -2192,14 +2443,14 @@ } }, "node_modules/css-loader": { - "version": "6.7.3", - "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-6.7.3.tgz", - "integrity": "sha512-qhOH1KlBMnZP8FzRO6YCH9UHXQhVMcEGLyNdb7Hv2cpcmJbW0YrddO+tG1ab5nT41KpHIYGsbeHqxB9xPu1pKQ==", + "version": "6.8.1", + "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-6.8.1.tgz", + "integrity": "sha512-xDAXtEVGlD0gJ07iclwWVkLoZOpEvAWaSyf6W18S2pOC//K8+qUDIx8IIT3D+HjnmkJPQeesOPv5aiUaJsCM2g==", "dependencies": { "icss-utils": "^5.1.0", - "postcss": "^8.4.19", + "postcss": "^8.4.21", "postcss-modules-extract-imports": "^3.0.0", - "postcss-modules-local-by-default": "^4.0.0", + "postcss-modules-local-by-default": "^4.0.3", "postcss-modules-scope": "^3.0.0", "postcss-modules-values": "^4.0.0", "postcss-value-parser": "^4.2.0", @@ -2290,9 +2541,9 @@ } }, "node_modules/csstype": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.1.tgz", - "integrity": "sha512-DJR/VvkAvSZW9bTouZue2sSxDwdTN92uHjqeKVm+0dAqdfNykRzQ95tay8aXMBAAPpUiq4Qcug2L7neoRh2Egw==", + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", + "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", "dev": true }, "node_modules/debug": { @@ -2312,9 +2563,9 @@ } }, "node_modules/decache": { - "version": "4.6.1", - "resolved": "https://registry.npmjs.org/decache/-/decache-4.6.1.tgz", - "integrity": "sha512-ohApBM8u9ygepJCjgBrEZSSxPjc0T/PJkD+uNyxXPkqudyUpdXpwJYp0VISm2WrPVzASU6DZyIi6BWdyw7uJ2Q==", + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/decache/-/decache-4.6.2.tgz", + "integrity": "sha512-2LPqkLeu8XWHU8qNCS3kcF6sCcb5zIzvWaAHYSvPfwhdd7mHuah29NssMzrTYyHN4F5oFy2ko9OBYxegtU0FEw==", "dependencies": { "callsite": "^1.0.0" } @@ -2348,20 +2599,35 @@ "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==" }, "node_modules/deepmerge": { - "version": "4.2.2", - "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz", - "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==", + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", + "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", "dev": true, "engines": { "node": ">=0.10.0" } }, + "node_modules/define-data-property": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.1.tgz", + "integrity": "sha512-E7uGkTzkk1d0ByLeSc6ZsFS79Axg+m1P/VsgYsxHgiuc3tFSj+MjMIwe90FC4lOAZzNBdY7kkO2P2wKdsQ1vgQ==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.1", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, "node_modules/define-properties": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.4.tgz", - "integrity": "sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA==", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", + "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", "dev": true, "dependencies": { + "define-data-property": "^1.0.1", "has-property-descriptors": "^1.0.0", "object-keys": "^1.1.1" }, @@ -2434,15 +2700,6 @@ "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1" } }, - "node_modules/dom-serializer/node_modules/entities": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", - "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", - "dev": true, - "funding": { - "url": "https://github.com/fb55/entities?sponsor=1" - } - }, "node_modules/domelementtype": { "version": "2.3.0", "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz", @@ -2494,51 +2751,62 @@ "tslib": "^2.0.3" } }, + "node_modules/eastasianwidth": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", + "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==" + }, "node_modules/editorconfig": { - "version": "0.15.3", - "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-0.15.3.tgz", - "integrity": "sha512-M9wIMFx96vq0R4F+gRpY3o2exzb8hEj/n9S8unZtHSvYjibBp/iMufSzvmOcV/laG0ZtuTVGtiJggPOSW2r93g==", + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-1.0.4.tgz", + "integrity": "sha512-L9Qe08KWTlqYMVvMcTIvMAdl1cDUubzRNYL+WfA4bLDMHe4nemKkpmYzkznE1FwLKu0EEmy6obgQKzMJrg4x9Q==", "dependencies": { - "commander": "^2.19.0", - "lru-cache": "^4.1.5", - "semver": "^5.6.0", - "sigmund": "^1.0.1" + "@one-ini/wasm": "0.1.1", + "commander": "^10.0.0", + "minimatch": "9.0.1", + "semver": "^7.5.3" }, "bin": { "editorconfig": "bin/editorconfig" + }, + "engines": { + "node": ">=14" } }, - "node_modules/editorconfig/node_modules/commander": { - "version": "2.20.3", - "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", - "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==" - }, - "node_modules/editorconfig/node_modules/lru-cache": { - "version": "4.1.5", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", - "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", + "node_modules/editorconfig/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", "dependencies": { - "pseudomap": "^1.0.2", - "yallist": "^2.1.2" + "balanced-match": "^1.0.0" } }, - "node_modules/editorconfig/node_modules/semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", - "bin": { - "semver": "bin/semver" + "node_modules/editorconfig/node_modules/commander": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-10.0.1.tgz", + "integrity": "sha512-y4Mg2tXshplEbSGzx7amzPwKKOCGuoSRP/CjEdwwk0FOGlUbq6lKuoyDZTNZkmxHdJtp54hdfY/JUrdL7Xfdug==", + "engines": { + "node": ">=14" } }, - "node_modules/editorconfig/node_modules/yallist": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", - "integrity": "sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A==" + "node_modules/editorconfig/node_modules/minimatch": { + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.1.tgz", + "integrity": "sha512-0jWhJpD/MdhPXwPuiRkCbfYfSKp2qnn2eOc279qI7f+osl/l+prKSrvhg157zSYvx/1nmgn2NqdT6k2Z7zSH9w==", + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } }, "node_modules/electron-to-chromium": { - "version": "1.4.284", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.284.tgz", - "integrity": "sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA==" + "version": "1.4.616", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.616.tgz", + "integrity": "sha512-1n7zWYh8eS0L9Uy+GskE0lkBUNK83cXTVJI0pU3mGprFsbfSdAc15VTFbo+A+Bq4pwstmL30AVcEU3Fo463lNg==" }, "node_modules/emoji-regex": { "version": "8.0.0", @@ -2555,9 +2823,9 @@ } }, "node_modules/enhanced-resolve": { - "version": "5.13.0", - "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.13.0.tgz", - "integrity": "sha512-eyV8f0y1+bzyfh8xAwW/WTSZpLbjhqc4ne9eGSH4Zo2ejdyiNG9pU6mf9DG8a7+Auk6MFTlNOT4Y2y/9k8GKVg==", + "version": "5.15.0", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.15.0.tgz", + "integrity": "sha512-LXYT42KJ7lpIKECr2mAXIaMldcNCh/7E0KBKOu4KSfkHmP+mZmSs+8V5gBAqisWBy0OO4W5Oyys0GO1Y8KtdKg==", "dependencies": { "graceful-fs": "^4.2.4", "tapable": "^2.2.0" @@ -2566,6 +2834,15 @@ "node": ">=10.13.0" } }, + "node_modules/entities": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", + "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", + "dev": true, + "funding": { + "url": "https://github.com/fb55/entities?sponsor=1" + } + }, "node_modules/error-ex": { "version": "1.3.2", "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", @@ -2576,36 +2853,50 @@ } }, "node_modules/es-abstract": { - "version": "1.20.5", - "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.20.5.tgz", - "integrity": "sha512-7h8MM2EQhsCA7pU/Nv78qOXFpD8Rhqd12gYiSJVkrH9+e8VuA8JlPJK/hQjjlLv6pJvx/z1iRFKzYb0XT/RuAQ==", + "version": "1.22.3", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.3.tgz", + "integrity": "sha512-eiiY8HQeYfYH2Con2berK+To6GrK2RxbPawDkGq4UiCQQfZHb6wX9qQqkbpPqaxQFcl8d9QzZqo0tGE0VcrdwA==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", + "array-buffer-byte-length": "^1.0.0", + "arraybuffer.prototype.slice": "^1.0.2", + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.5", + "es-set-tostringtag": "^2.0.1", "es-to-primitive": "^1.2.1", - "function-bind": "^1.1.1", - "function.prototype.name": "^1.1.5", - "get-intrinsic": "^1.1.3", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.2", "get-symbol-description": "^1.0.0", + "globalthis": "^1.0.3", "gopd": "^1.0.1", - "has": "^1.0.3", "has-property-descriptors": "^1.0.0", + "has-proto": "^1.0.1", "has-symbols": "^1.0.3", - "internal-slot": "^1.0.3", + "hasown": "^2.0.0", + "internal-slot": "^1.0.5", + "is-array-buffer": "^3.0.2", "is-callable": "^1.2.7", "is-negative-zero": "^2.0.2", "is-regex": "^1.1.4", "is-shared-array-buffer": "^1.0.2", "is-string": "^1.0.7", + "is-typed-array": "^1.1.12", "is-weakref": "^1.0.2", - "object-inspect": "^1.12.2", + "object-inspect": "^1.13.1", "object-keys": "^1.1.1", "object.assign": "^4.1.4", - "regexp.prototype.flags": "^1.4.3", + "regexp.prototype.flags": "^1.5.1", + "safe-array-concat": "^1.0.1", "safe-regex-test": "^1.0.0", - "string.prototype.trimend": "^1.0.6", - "string.prototype.trimstart": "^1.0.6", - "unbox-primitive": "^1.0.2" + "string.prototype.trim": "^1.2.8", + "string.prototype.trimend": "^1.0.7", + "string.prototype.trimstart": "^1.0.7", + "typed-array-buffer": "^1.0.0", + "typed-array-byte-length": "^1.0.0", + "typed-array-byte-offset": "^1.0.0", + "typed-array-length": "^1.0.4", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.13" }, "engines": { "node": ">= 0.4" @@ -2615,17 +2906,22 @@ } }, "node_modules/es-module-lexer": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.2.1.tgz", - "integrity": "sha512-9978wrXM50Y4rTMmW5kXIC09ZdXQZqkE4mxhwkd8VbzsGkXGPgV4zWuqQJgCEzYngdo2dYDa0l8xhX4fkSwJSg==" + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.4.1.tgz", + "integrity": "sha512-cXLGjP0c4T3flZJKQSuziYoq7MlT+rnvfZjfp7h+I7K9BNX54kP9nyWvdbwjQ4u1iWbOL4u96fgeZLToQlZC7w==" }, - "node_modules/es-shim-unscopables": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.0.tgz", - "integrity": "sha512-Jm6GPcCdC30eMLbZ2x8z2WuRwAws3zTBBKuusffYVUrNj/GVSUAZ+xKMaUpfNDR5IbyNA5LJbaecoUVbmUcB1w==", + "node_modules/es-set-tostringtag": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.2.tgz", + "integrity": "sha512-BuDyupZt65P9D2D2vA/zqcI3G5xRsklm5N3xCwuiy+/vKy8i0ifdsQP1sLgO4tZDSCaQUSnmC48khknGMV3D2Q==", "dev": true, "dependencies": { - "has": "^1.0.3" + "get-intrinsic": "^1.2.2", + "has-tostringtag": "^1.0.0", + "hasown": "^2.0.0" + }, + "engines": { + "node": ">= 0.4" } }, "node_modules/es-to-primitive": { @@ -2646,9 +2942,9 @@ } }, "node_modules/esbuild": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.18.tgz", - "integrity": "sha512-z1lix43jBs6UKjcZVKOw2xx69ffE2aG0PygLL5qJ9OS/gy0Ewd1gW/PUQIOIQGXBHWNywSc0floSKoMFF8aK2w==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.19.11.tgz", + "integrity": "sha512-HJ96Hev2hX/6i5cDVwcqiJBBtuo9+FeIJOtZ9W1kA5M6AMJRHUZlpYZ1/SbEwtO0ioNAW8rUooVpC/WehY2SfA==", "hasInstallScript": true, "peer": true, "bin": { @@ -2658,28 +2954,29 @@ "node": ">=12" }, "optionalDependencies": { - "@esbuild/android-arm": "0.17.18", - "@esbuild/android-arm64": "0.17.18", - "@esbuild/android-x64": "0.17.18", - "@esbuild/darwin-arm64": "0.17.18", - "@esbuild/darwin-x64": "0.17.18", - "@esbuild/freebsd-arm64": "0.17.18", - "@esbuild/freebsd-x64": "0.17.18", - "@esbuild/linux-arm": "0.17.18", - "@esbuild/linux-arm64": "0.17.18", - "@esbuild/linux-ia32": "0.17.18", - "@esbuild/linux-loong64": "0.17.18", - "@esbuild/linux-mips64el": "0.17.18", - "@esbuild/linux-ppc64": "0.17.18", - "@esbuild/linux-riscv64": "0.17.18", - "@esbuild/linux-s390x": "0.17.18", - "@esbuild/linux-x64": "0.17.18", - "@esbuild/netbsd-x64": "0.17.18", - "@esbuild/openbsd-x64": "0.17.18", - "@esbuild/sunos-x64": "0.17.18", - "@esbuild/win32-arm64": "0.17.18", - "@esbuild/win32-ia32": "0.17.18", - "@esbuild/win32-x64": "0.17.18" + "@esbuild/aix-ppc64": "0.19.11", + "@esbuild/android-arm": "0.19.11", + "@esbuild/android-arm64": "0.19.11", + "@esbuild/android-x64": "0.19.11", + "@esbuild/darwin-arm64": "0.19.11", + "@esbuild/darwin-x64": "0.19.11", + "@esbuild/freebsd-arm64": "0.19.11", + "@esbuild/freebsd-x64": "0.19.11", + "@esbuild/linux-arm": "0.19.11", + "@esbuild/linux-arm64": "0.19.11", + "@esbuild/linux-ia32": "0.19.11", + "@esbuild/linux-loong64": "0.19.11", + "@esbuild/linux-mips64el": "0.19.11", + "@esbuild/linux-ppc64": "0.19.11", + "@esbuild/linux-riscv64": "0.19.11", + "@esbuild/linux-s390x": "0.19.11", + "@esbuild/linux-x64": "0.19.11", + "@esbuild/netbsd-x64": "0.19.11", + "@esbuild/openbsd-x64": "0.19.11", + "@esbuild/sunos-x64": "0.19.11", + "@esbuild/win32-arm64": "0.19.11", + "@esbuild/win32-ia32": "0.19.11", + "@esbuild/win32-x64": "0.19.11" } }, "node_modules/escalade": { @@ -2702,26 +2999,27 @@ } }, "node_modules/eslint": { - "version": "8.39.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.39.0.tgz", - "integrity": "sha512-mwiok6cy7KTW7rBpo05k6+p4YVZByLNjAZ/ACB9DRCu4YDRwjXI01tWHp6KAUWelsBetTxKK/2sHB0vdS8Z2Og==", + "version": "8.56.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.56.0.tgz", + "integrity": "sha512-Go19xM6T9puCOWntie1/P997aXxFsOi37JIHRWI514Hc6ZnaHGKY9xFhrU65RT6CcBEzZoGG1e6Nq+DT04ZtZQ==", "dependencies": { "@eslint-community/eslint-utils": "^4.2.0", - "@eslint-community/regexpp": "^4.4.0", - "@eslint/eslintrc": "^2.0.2", - "@eslint/js": "8.39.0", - "@humanwhocodes/config-array": "^0.11.8", + "@eslint-community/regexpp": "^4.6.1", + "@eslint/eslintrc": "^2.1.4", + "@eslint/js": "8.56.0", + "@humanwhocodes/config-array": "^0.11.13", "@humanwhocodes/module-importer": "^1.0.1", "@nodelib/fs.walk": "^1.2.8", - "ajv": "^6.10.0", + "@ungap/structured-clone": "^1.2.0", + "ajv": "^6.12.4", "chalk": "^4.0.0", "cross-spawn": "^7.0.2", "debug": "^4.3.2", "doctrine": "^3.0.0", "escape-string-regexp": "^4.0.0", - "eslint-scope": "^7.2.0", - "eslint-visitor-keys": "^3.4.0", - "espree": "^9.5.1", + "eslint-scope": "^7.2.2", + "eslint-visitor-keys": "^3.4.3", + "espree": "^9.6.1", "esquery": "^1.4.2", "esutils": "^2.0.2", "fast-deep-equal": "^3.1.3", @@ -2729,22 +3027,19 @@ "find-up": "^5.0.0", "glob-parent": "^6.0.2", "globals": "^13.19.0", - "grapheme-splitter": "^1.0.4", + "graphemer": "^1.4.0", "ignore": "^5.2.0", - "import-fresh": "^3.0.0", "imurmurhash": "^0.1.4", "is-glob": "^4.0.0", "is-path-inside": "^3.0.3", - "js-sdsl": "^4.1.4", "js-yaml": "^4.1.0", "json-stable-stringify-without-jsonify": "^1.0.1", "levn": "^0.4.1", "lodash.merge": "^4.6.2", "minimatch": "^3.1.2", "natural-compare": "^1.4.0", - "optionator": "^0.9.1", + "optionator": "^0.9.3", "strip-ansi": "^6.0.1", - "strip-json-comments": "^3.1.0", "text-table": "^0.2.0" }, "bin": { @@ -2758,9 +3053,9 @@ } }, "node_modules/eslint-config-prettier": { - "version": "8.8.0", - "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.8.0.tgz", - "integrity": "sha512-wLbQiFre3tdGgpDv67NQKnJuTlcUVYHas3k+DZCc2U2BadthoEY4B7hLPvAxaqdyOGCzuLfii2fqGph10va7oA==", + "version": "9.1.0", + "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-9.1.0.tgz", + "integrity": "sha512-NSWl5BFQWEPi1j4TjVNItzYV7dZXZ+wP6I6ZhrBGpChQhZRUaElihE9uRRkcbRnNb76UMKDF3r+WTmNcGPKsqw==", "dev": true, "bin": { "eslint-config-prettier": "bin/cli.js" @@ -2769,85 +3064,6 @@ "eslint": ">=7.0.0" } }, - "node_modules/eslint-plugin-react": { - "version": "7.32.2", - "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.32.2.tgz", - "integrity": "sha512-t2fBMa+XzonrrNkyVirzKlvn5RXzzPwRHtMvLAtVZrt8oxgnTQaYbU6SXTOO1mwQgp1y5+toMSKInnzGr0Knqg==", - "dev": true, - "dependencies": { - "array-includes": "^3.1.6", - "array.prototype.flatmap": "^1.3.1", - "array.prototype.tosorted": "^1.1.1", - "doctrine": "^2.1.0", - "estraverse": "^5.3.0", - "jsx-ast-utils": "^2.4.1 || ^3.0.0", - "minimatch": "^3.1.2", - "object.entries": "^1.1.6", - "object.fromentries": "^2.0.6", - "object.hasown": "^1.1.2", - "object.values": "^1.1.6", - "prop-types": "^15.8.1", - "resolve": "^2.0.0-next.4", - "semver": "^6.3.0", - "string.prototype.matchall": "^4.0.8" - }, - "engines": { - "node": ">=4" - }, - "peerDependencies": { - "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8" - } - }, - "node_modules/eslint-plugin-react-hooks": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz", - "integrity": "sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g==", - "dev": true, - "engines": { - "node": ">=10" - }, - "peerDependencies": { - "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0" - } - }, - "node_modules/eslint-plugin-react/node_modules/doctrine": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", - "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", - "dev": true, - "dependencies": { - "esutils": "^2.0.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/eslint-plugin-react/node_modules/resolve": { - "version": "2.0.0-next.4", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.4.tgz", - "integrity": "sha512-iMDbmAWtfU+MHpxt/I5iWI7cY6YVEZUQ3MBgPQ++XD1PELuJHIl82xBmObyP2KyQmkNB2dsqF7seoQQiAn5yDQ==", - "dev": true, - "dependencies": { - "is-core-module": "^2.9.0", - "path-parse": "^1.0.7", - "supports-preserve-symlinks-flag": "^1.0.0" - }, - "bin": { - "resolve": "bin/resolve" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/eslint-plugin-react/node_modules/semver": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", - "dev": true, - "bin": { - "semver": "bin/semver.js" - } - }, "node_modules/eslint-plugin-stylable": { "resolved": "packages/eslint-plugin-stylable", "link": true @@ -2864,18 +3080,10 @@ "node": ">=8.0.0" } }, - "node_modules/eslint-scope/node_modules/estraverse": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", - "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", - "engines": { - "node": ">=4.0" - } - }, "node_modules/eslint-visitor-keys": { - "version": "3.4.0", - "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.0.tgz", - "integrity": "sha512-HPpKPUBQcAsZOsHAFwTtIKcYlCje62XB7SEAcxjtmW6TD1WVpkS6i6/hOVtTZIl4zGj/mBqpFVGvaDneik+VoQ==", + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", + "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", "engines": { "node": "^12.22.0 || ^14.17.0 || >=16.0.0" }, @@ -2884,9 +3092,9 @@ } }, "node_modules/eslint/node_modules/eslint-scope": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.0.tgz", - "integrity": "sha512-DYj5deGlHBfMt15J7rdtyKNq/Nqlv5KfU4iodrQ019XESsRnwXH9KAE0y3cwtUHDo2ob7CypAnCqefh6vioWRw==", + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", + "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", "dependencies": { "esrecurse": "^4.3.0", "estraverse": "^5.2.0" @@ -2898,14 +3106,22 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/eslint/node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "engines": { + "node": ">=4.0" + } + }, "node_modules/espree": { - "version": "9.5.1", - "resolved": "https://registry.npmjs.org/espree/-/espree-9.5.1.tgz", - "integrity": "sha512-5yxtHSZXRSW5pvv3hAlXM5+/Oswi1AUFqBmbibKb5s6bp3rGIDkyXU6xCoyuuLhijr4SFwPrXRoZjz0AZDN9tg==", + "version": "9.6.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", + "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", "dependencies": { - "acorn": "^8.8.0", + "acorn": "^8.9.0", "acorn-jsx": "^5.3.2", - "eslint-visitor-keys": "^3.4.0" + "eslint-visitor-keys": "^3.4.1" }, "engines": { "node": "^12.22.0 || ^14.17.0 || >=16.0.0" @@ -2915,9 +3131,9 @@ } }, "node_modules/esquery": { - "version": "1.4.2", - "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.2.tgz", - "integrity": "sha512-JVSoLdTlTDkmjFmab7H/9SL9qGSyjElT3myyKp7krqjVFQCDLmj1QFaCLRFBszBKI0XVZaiiXvuPIX3ZwHe1Ng==", + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", + "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", "dependencies": { "estraverse": "^5.1.0" }, @@ -2925,6 +3141,14 @@ "node": ">=0.10" } }, + "node_modules/esquery/node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "engines": { + "node": ">=4.0" + } + }, "node_modules/esrecurse": { "version": "4.3.0", "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", @@ -2936,7 +3160,7 @@ "node": ">=4.0" } }, - "node_modules/estraverse": { + "node_modules/esrecurse/node_modules/estraverse": { "version": "5.3.0", "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", @@ -2944,6 +3168,14 @@ "node": ">=4.0" } }, + "node_modules/estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "engines": { + "node": ">=4.0" + } + }, "node_modules/estree-walker": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", @@ -2972,9 +3204,9 @@ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" }, "node_modules/fast-glob": { - "version": "3.2.12", - "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.12.tgz", - "integrity": "sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==", + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", + "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", "dependencies": { "@nodelib/fs.stat": "^2.0.2", "@nodelib/fs.walk": "^1.2.3", @@ -3013,9 +3245,9 @@ "integrity": "sha512-483XLLxTVIwWK3QTrMGRqUfUpoOs/0hbQrl2oz4J0pAcm3A3bu84wxTFqGqkJzewCLdME38xJLJAxBABfQT8sQ==" }, "node_modules/fastq": { - "version": "1.14.0", - "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.14.0.tgz", - "integrity": "sha512-eR2D+V9/ExcbF9ls441yIuN6TI2ED1Y2ZcA5BmMtJsOkWOFRJQ0Jt0g1UwqXJJVAb+V+umH5Dfr8oh4EVP7VVg==", + "version": "1.16.0", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.16.0.tgz", + "integrity": "sha512-ifCoaXsDrsdkWTtiNJX5uzHDsrck5TzfKKDcuFFTIrrc/BS076qgEIfoIy1VeZqViznfKiysPYTh/QeHtnIsYA==", "dependencies": { "reusify": "^1.0.4" } @@ -3097,11 +3329,12 @@ } }, "node_modules/flat-cache": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", - "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", + "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", "dependencies": { - "flatted": "^3.1.0", + "flatted": "^3.2.9", + "keyv": "^4.5.3", "rimraf": "^3.0.2" }, "engines": { @@ -3123,9 +3356,18 @@ } }, "node_modules/flatted": { - "version": "3.2.7", - "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz", - "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==" + "version": "3.2.9", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz", + "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==" + }, + "node_modules/for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "dependencies": { + "is-callable": "^1.1.3" + } }, "node_modules/foreground-child": { "version": "2.0.0", @@ -3141,16 +3383,16 @@ } }, "node_modules/fraction.js": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.2.0.tgz", - "integrity": "sha512-MhLuK+2gUcnZe8ZHlaaINnQLl0xRIGRfcGk2yl8xoQAfHrSsL3rYu6FCmBdkdbhc9EPlwyGHewaRsvwRMJtAlA==", + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.3.7.tgz", + "integrity": "sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew==", "dev": true, "engines": { "node": "*" }, "funding": { "type": "patreon", - "url": "https://www.patreon.com/infusion" + "url": "https://github.com/sponsors/rawify" } }, "node_modules/fs.realpath": { @@ -3159,9 +3401,9 @@ "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" }, "node_modules/fsevents": { - "version": "2.3.2", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", - "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", + "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", "hasInstallScript": true, "optional": true, "os": [ @@ -3172,21 +3414,24 @@ } }, "node_modules/function-bind": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", - "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", - "dev": true + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } }, "node_modules/function.prototype.name": { - "version": "1.1.5", - "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.5.tgz", - "integrity": "sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA==", + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", + "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", "dev": true, "dependencies": { "call-bind": "^1.0.2", - "define-properties": "^1.1.3", - "es-abstract": "^1.19.0", - "functions-have-names": "^1.2.2" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "functions-have-names": "^1.2.3" }, "engines": { "node": ">= 0.4" @@ -3213,22 +3458,23 @@ } }, "node_modules/get-func-name": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", - "integrity": "sha512-Hm0ixYtaSZ/V7C8FJrtZIuBBI+iSgL+1Aq82zSu8VQNB4S3Gk8e7Qs3VwBDJAhmRZcFqkl3tQu36g/Foh5I5ig==", + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.2.tgz", + "integrity": "sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ==", "engines": { "node": "*" } }, "node_modules/get-intrinsic": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.3.tgz", - "integrity": "sha512-QJVz1Tj7MS099PevUG5jvnt9tSkXN8K14dxQlikJuPt4uD9hHAHjLyLBiLR5zELelBdD9QNRAXZzsJx0WaDL9A==", + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.2.tgz", + "integrity": "sha512-0gSo4ml/0j98Y3lngkFEot/zhiCeWsbYIlZ+uZOVgzLyLaUw7wxUL+nCTP0XJvJg1AXulJRI3UJi8GsbDuxdGA==", "dev": true, "dependencies": { - "function-bind": "^1.1.1", - "has": "^1.0.3", - "has-symbols": "^1.0.3" + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -3286,9 +3532,9 @@ "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==" }, "node_modules/globals": { - "version": "13.20.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-13.20.0.tgz", - "integrity": "sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ==", + "version": "13.24.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", + "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", "dependencies": { "type-fest": "^0.20.2" }, @@ -3299,13 +3545,28 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/globby": { - "version": "11.1.0", - "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", - "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", + "node_modules/globalthis": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", + "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", + "dev": true, "dependencies": { - "array-union": "^2.1.0", - "dir-glob": "^3.0.1", + "define-properties": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/globby": { + "version": "11.1.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", + "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", + "dependencies": { + "array-union": "^2.1.0", + "dir-glob": "^3.0.1", "fast-glob": "^3.2.9", "ignore": "^5.2.0", "merge2": "^1.4.1", @@ -3331,26 +3592,14 @@ } }, "node_modules/graceful-fs": { - "version": "4.2.10", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", - "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==" - }, - "node_modules/grapheme-splitter": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz", - "integrity": "sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==" + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" }, - "node_modules/has": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", - "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", - "dev": true, - "dependencies": { - "function-bind": "^1.1.1" - }, - "engines": { - "node": ">= 0.4.0" - } + "node_modules/graphemer": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", + "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==" }, "node_modules/has-bigints": { "version": "1.0.2", @@ -3370,12 +3619,24 @@ } }, "node_modules/has-property-descriptors": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz", - "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==", + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.1.tgz", + "integrity": "sha512-VsX8eaIewvas0xnvinAe9bw4WfIeODpGYikiWYLH+dma0Jw6KHYqWiWfhQlgOVK8D6PvjubK5Uc4P0iIhIcNVg==", "dev": true, "dependencies": { - "get-intrinsic": "^1.1.1" + "get-intrinsic": "^1.2.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", + "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", + "dev": true, + "engines": { + "node": ">= 0.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -3408,6 +3669,18 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/hasown": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.0.tgz", + "integrity": "sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA==", + "dev": true, + "dependencies": { + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, "node_modules/he": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", @@ -3451,9 +3724,9 @@ } }, "node_modules/html-webpack-plugin": { - "version": "5.5.1", - "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-5.5.1.tgz", - "integrity": "sha512-cTUzZ1+NqjGEKjmVgZKLMdiFg3m9MdRXkZW2OEe69WYVi5ONLMmlnSZdXzGGMOq0C8jGDrL6EWyEDDUioHO/pA==", + "version": "5.6.0", + "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-5.6.0.tgz", + "integrity": "sha512-iwaY4wzbe48AfKLZ/Cc8k0L+FKG6oSNRaZ8x5A/T/IVDGyXcbHncM9TdDa93wn0FsSm82FhTKW7f3vS61thXAw==", "dev": true, "dependencies": { "@types/html-minifier-terser": "^6.0.0", @@ -3470,7 +3743,16 @@ "url": "https://opencollective.com/html-webpack-plugin" }, "peerDependencies": { + "@rspack/core": "0.x || 1.x", "webpack": "^5.20.0" + }, + "peerDependenciesMeta": { + "@rspack/core": { + "optional": true + }, + "webpack": { + "optional": true + } } }, "node_modules/htmlparser2": { @@ -3492,13 +3774,16 @@ "entities": "^2.0.0" } }, - "node_modules/htmlparser2/node_modules/entities": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", - "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", + "node_modules/iconv-lite": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", + "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", "dev": true, - "funding": { - "url": "https://github.com/fb55/entities?sponsor=1" + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" } }, "node_modules/icss-utils": { @@ -3513,9 +3798,9 @@ } }, "node_modules/ignore": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.1.tgz", - "integrity": "sha512-d2qQLzTJ9WxQftPAuEQpSPmKqzxePjzVbpAVv62AQ64NTL+wR4JkrVqR/LqFsFEUsHDAiId52mJteHDFuDkElA==", + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.0.tgz", + "integrity": "sha512-g7dmpshy+gD7mh88OC9NwSGTKoc3kyLAZQRU1mt53Aw/vnvfXnbC+F/7F7QoYVKbV+KNvJx8wArewKy1vXMtlg==", "engines": { "node": ">= 4" } @@ -3563,19 +3848,33 @@ "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" }, "node_modules/internal-slot": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.4.tgz", - "integrity": "sha512-tA8URYccNzMo94s5MQZgH8NB/XTa6HsOo0MLfXTKKEnHVVdegzaQoFZ7Jp44bdvLvY2waT5dc+j5ICEswhi7UQ==", + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.6.tgz", + "integrity": "sha512-Xj6dv+PsbtwyPpEflsejS+oIZxmMlV44zAhG479uYu89MsjcYOhCFnNyKrkJrihbsiasQyY0afoCl/9BLR65bg==", "dev": true, "dependencies": { - "get-intrinsic": "^1.1.3", - "has": "^1.0.3", + "get-intrinsic": "^1.2.2", + "hasown": "^2.0.0", "side-channel": "^1.0.4" }, "engines": { "node": ">= 0.4" } }, + "node_modules/is-array-buffer": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz", + "integrity": "sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.0", + "is-typed-array": "^1.1.10" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/is-arrayish": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", @@ -3650,12 +3949,12 @@ } }, "node_modules/is-core-module": { - "version": "2.11.0", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz", - "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==", + "version": "2.13.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", + "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", "dev": true, "dependencies": { - "has": "^1.0.3" + "hasown": "^2.0.0" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -3819,6 +4118,21 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/is-typed-array": { + "version": "1.1.12", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.12.tgz", + "integrity": "sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg==", + "dev": true, + "dependencies": { + "which-typed-array": "^1.1.11" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/is-unicode-supported": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", @@ -3851,38 +4165,44 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/isarray": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", + "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", + "dev": true + }, "node_modules/isexe": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" }, "node_modules/istanbul-lib-coverage": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", - "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz", + "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==", "dev": true, "engines": { "node": ">=8" } }, "node_modules/istanbul-lib-report": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", - "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz", + "integrity": "sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==", "dev": true, "dependencies": { "istanbul-lib-coverage": "^3.0.0", - "make-dir": "^3.0.0", + "make-dir": "^4.0.0", "supports-color": "^7.1.0" }, "engines": { - "node": ">=8" + "node": ">=10" } }, "node_modules/istanbul-reports": { - "version": "3.1.5", - "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz", - "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==", + "version": "3.1.6", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.6.tgz", + "integrity": "sha512-TLgnMkKg3iTDsQ9PbPTdpfAK2DzjF9mqUG7RMgcQl8oFjad8ob4laGxv5XV5U9MAfx8D6tSJiUyuAwzLicaxlg==", "dev": true, "dependencies": { "html-escaper": "^2.0.0", @@ -3893,11 +4213,11 @@ } }, "node_modules/jackspeak": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.0.3.tgz", - "integrity": "sha512-0Jud3OMUdMbrlr3PyUMKESq51LXVAB+a239Ywdvd+Kgxj3MaBRml/nVRxf8tQFyfthMjuRkxkv7Vg58pmIMfuQ==", + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.3.6.tgz", + "integrity": "sha512-N3yCS/NegsOBokc8GAdM8UcmfsKiSS8cipheD/nivzr700H+nsMOxJjQnvwOcRYVuFkdH0wGUvW2WbXGmrZGbQ==", "dependencies": { - "cliui": "^7.0.4" + "@isaacs/cliui": "^8.0.2" }, "engines": { "node": ">=14" @@ -3909,20 +4229,10 @@ "@pkgjs/parseargs": "^0.11.0" } }, - "node_modules/jackspeak/node_modules/cliui": { - "version": "7.0.4", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", - "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", - "dependencies": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.0", - "wrap-ansi": "^7.0.0" - } - }, "node_modules/jest-docblock": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.4.3.tgz", - "integrity": "sha512-fzdTftThczeSD9nZ3fzA/4KkHtnmllawWrXO69vtI+L9WjEIuXWs4AmyME7lN5hU7dB0sHhuPfcKofRsUb/2Fg==", + "version": "29.7.0", + "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.7.0.tgz", + "integrity": "sha512-q617Auw3A612guyaFgsbFeYpNP5t2aoUNLwBUbc/0kD1R4t9ixDbyFTHd1nok4epoVFpr7PmeWHrhvuV3XaJ4g==", "dependencies": { "detect-newline": "^3.0.0" }, @@ -3958,14 +4268,14 @@ } }, "node_modules/js-beautify": { - "version": "1.14.7", - "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.14.7.tgz", - "integrity": "sha512-5SOX1KXPFKx+5f6ZrPsIPEY7NwKeQz47n3jm2i+XeHx9MoRsfQenlOP13FQhWvg8JRS0+XLO6XYUQ2GX+q+T9A==", + "version": "1.14.11", + "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.14.11.tgz", + "integrity": "sha512-rPogWqAfoYh1Ryqqh2agUpVfbxAhbjuN1SmU86dskQUKouRiggUTCO4+2ym9UPXllc2WAp0J+T5qxn7Um3lCdw==", "dependencies": { "config-chain": "^1.1.13", - "editorconfig": "^0.15.3", - "glob": "^8.0.3", - "nopt": "^6.0.0" + "editorconfig": "^1.0.3", + "glob": "^10.3.3", + "nopt": "^7.2.0" }, "bin": { "css-beautify": "js/bin/css-beautify.js", @@ -3973,7 +4283,7 @@ "js-beautify": "js/bin/js-beautify.js" }, "engines": { - "node": ">=10" + "node": ">=14" } }, "node_modules/js-beautify/node_modules/brace-expansion": { @@ -3984,42 +4294,65 @@ "balanced-match": "^1.0.0" } }, + "node_modules/js-beautify/node_modules/foreground-child": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.1.1.tgz", + "integrity": "sha512-TMKDUnIte6bfb5nWv7V/caI169OHgvwjb7V4WkeUvbQQdjr5rWKqHFiKWb/fcOwB+CzBT+qbWjvj+DVwRskpIg==", + "dependencies": { + "cross-spawn": "^7.0.0", + "signal-exit": "^4.0.1" + }, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, "node_modules/js-beautify/node_modules/glob": { - "version": "8.0.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-8.0.3.tgz", - "integrity": "sha512-ull455NHSHI/Y1FqGaaYFaLGkNMMJbavMrEGFXG/PGrg6y7sutWHUHrz6gy6WEBH6akM1M414dWKCNs+IhKdiQ==", + "version": "10.3.10", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.10.tgz", + "integrity": "sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g==", "dependencies": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^5.0.1", - "once": "^1.3.0" + "foreground-child": "^3.1.0", + "jackspeak": "^2.3.5", + "minimatch": "^9.0.1", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0", + "path-scurry": "^1.10.1" + }, + "bin": { + "glob": "dist/esm/bin.mjs" }, "engines": { - "node": ">=12" + "node": ">=16 || 14 >=14.17" }, "funding": { "url": "https://github.com/sponsors/isaacs" } }, "node_modules/js-beautify/node_modules/minimatch": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.1.tgz", - "integrity": "sha512-362NP+zlprccbEt/SkxKfRMHnNY85V74mVnpUpNyr3F35covl09Kec7/sEFLt3RA4oXmewtoaanoIf67SE5Y5g==", + "version": "9.0.3", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", + "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", "dependencies": { "brace-expansion": "^2.0.1" }, "engines": { - "node": ">=10" + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" } }, - "node_modules/js-sdsl": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.2.0.tgz", - "integrity": "sha512-dyBIzQBDkCqCu+0upx25Y2jGdbTGxE9fshMsCdK0ViOongpV+n5tXRcZY9v7CaVQ79AGS9KA1KHtojxiM7aXSQ==", + "node_modules/js-beautify/node_modules/signal-exit": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", + "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", + "engines": { + "node": ">=14" + }, "funding": { - "type": "opencollective", - "url": "https://opencollective.com/js-sdsl" + "url": "https://github.com/sponsors/isaacs" } }, "node_modules/js-tokens": { @@ -4039,6 +4372,11 @@ "js-yaml": "bin/js-yaml.js" } }, + "node_modules/json-buffer": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", + "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==" + }, "node_modules/json-parse-better-errors": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", @@ -4061,9 +4399,9 @@ "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==" }, "node_modules/json5": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.2.tgz", - "integrity": "sha512-46Tk9JiOL2z7ytNQWFLpj99RZkVgeHf87yGQKsIkaPz1qSH9UczKH1rO7K3wgRselo0tYMUNfecYpm/p1vC7tQ==", + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", + "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", "dev": true, "bin": { "json5": "lib/cli.js" @@ -4072,17 +4410,12 @@ "node": ">=6" } }, - "node_modules/jsx-ast-utils": { - "version": "3.3.3", - "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.3.tgz", - "integrity": "sha512-fYQHZTZ8jSfmWZ0iyzfwiU4WDX4HpHbMCZ3gPlWYiCl3BoeOTsqKBqnTVfH2rYT7eP5c3sVbeSPHnnJOaTrWiw==", - "dev": true, + "node_modules/keyv": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", + "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", "dependencies": { - "array-includes": "^3.1.5", - "object.assign": "^4.1.3" - }, - "engines": { - "node": ">=4.0" + "json-buffer": "3.0.1" } }, "node_modules/levn": { @@ -4208,11 +4541,11 @@ } }, "node_modules/loupe": { - "version": "2.3.6", - "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.6.tgz", - "integrity": "sha512-RaPMZKiMy8/JruncMU5Bt6na1eftNoo++R4Y+N2FrxkDVTrGvcyzFTsaGif4QTeKESheMGegbhw6iUAq+5A8zA==", + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.7.tgz", + "integrity": "sha512-zSMINGVYkdpYSOBmLi0D1Uo7JU9nVdQKrHxC8eYlV+9YKK9WePqAlL7lSlorG/U2Fw1w0hTBmaa/jrQ3UbPHtA==", "dependencies": { - "get-func-name": "^2.0.0" + "get-func-name": "^2.0.1" } }, "node_modules/lower-case": { @@ -4236,29 +4569,20 @@ } }, "node_modules/make-dir": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", - "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz", + "integrity": "sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==", "dev": true, "dependencies": { - "semver": "^6.0.0" + "semver": "^7.5.3" }, "engines": { - "node": ">=8" + "node": ">=10" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/make-dir/node_modules/semver": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", - "dev": true, - "bin": { - "semver": "bin/semver.js" - } - }, "node_modules/mdn-data": { "version": "2.0.28", "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.28.tgz", @@ -4329,9 +4653,9 @@ } }, "node_modules/mini-css-extract-plugin": { - "version": "2.7.5", - "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-2.7.5.tgz", - "integrity": "sha512-9HaR++0mlgom81s95vvNjxkg52n2b5s//3ZTI1EtzFb98awsLSivs2LMsVqnQ3ay0PVhqWcGNyDaTE961FOcjQ==", + "version": "2.7.6", + "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-2.7.6.tgz", + "integrity": "sha512-Qk7HcgaPkGG6eD77mLvZS1nmxlao3j+9PkrT9Uc7HAE1id3F41+DdBRYRYkbyfNRGzm8/YWtzhw7nVPmwhqTQw==", "dev": true, "dependencies": { "schema-utils": "^4.0.0" @@ -4348,9 +4672,9 @@ } }, "node_modules/mini-css-extract-plugin/node_modules/ajv": { - "version": "8.11.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.11.2.tgz", - "integrity": "sha512-E4bfmKAhGiSTvMfL1Myyycaub+cUEU2/IvpylXkUu7CHBkBj1f/ikdzbD7YQ6FKUbixDxeYvB/xY4fvyroDlQg==", + "version": "8.12.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.12.0.tgz", + "integrity": "sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==", "dev": true, "dependencies": { "fast-deep-equal": "^3.1.1", @@ -4382,15 +4706,15 @@ "dev": true }, "node_modules/mini-css-extract-plugin/node_modules/schema-utils": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.0.0.tgz", - "integrity": "sha512-1edyXKgh6XnJsJSQ8mKWXnN/BVaIbFMLpouRUrXgVq7WYne5kw3MW7UPhO44uRXQSIpTSXoJbmrR2X0w9kUTyg==", + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.2.0.tgz", + "integrity": "sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw==", "dev": true, "dependencies": { "@types/json-schema": "^7.0.9", - "ajv": "^8.8.0", + "ajv": "^8.9.0", "ajv-formats": "^2.1.1", - "ajv-keywords": "^5.0.0" + "ajv-keywords": "^5.1.0" }, "engines": { "node": ">= 12.13.0" @@ -4421,11 +4745,11 @@ } }, "node_modules/minipass": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz", - "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==", + "version": "7.0.4", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.0.4.tgz", + "integrity": "sha512-jYofLM5Dam9279rdkWzqHozUo4ybjdZmCsDHePy5V/PbBcVMiSZR97gmAy45aqi8CK1lG2ECd356FU86avfwUQ==", "engines": { - "node": ">=8" + "node": ">=16 || 14 >=14.17" } }, "node_modules/mocha": { @@ -4609,22 +4933,22 @@ } }, "node_modules/node-releases": { - "version": "2.0.10", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.10.tgz", - "integrity": "sha512-5GFldHPXVG/YZmFzJvKK2zDSzPKhEp0+ZR5SVaoSag9fsL5YgHbUHDfnG5494ISANDcK4KwPXAx2xqVEydmd7w==" + "version": "2.0.14", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", + "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==" }, "node_modules/nopt": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/nopt/-/nopt-6.0.0.tgz", - "integrity": "sha512-ZwLpbTgdhuZUnZzjd7nb1ZV+4DoiC6/sfiVKok72ym/4Tlf+DFdlHYmT2JPmcNNWV6Pi3SDf1kT+A4r9RTuT9g==", + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/nopt/-/nopt-7.2.0.tgz", + "integrity": "sha512-CVDtwCdhYIvnAzFoJ6NJ6dX3oga9/HyciQDnG1vQDjSLMeKLJ4A93ZqYKDrgYSr1FBY5/hMYC+2VCi24pgpkGA==", "dependencies": { - "abbrev": "^1.0.0" + "abbrev": "^2.0.0" }, "bin": { "nopt": "bin/nopt.js" }, "engines": { - "node": "^12.13.0 || ^14.15.0 || >=16.0.0" + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" } }, "node_modules/normalize-package-data": { @@ -4640,9 +4964,9 @@ } }, "node_modules/normalize-package-data/node_modules/semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", "dev": true, "bin": { "semver": "bin/semver" @@ -4776,9 +5100,9 @@ } }, "node_modules/npm-run-all/node_modules/semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", "dev": true, "bin": { "semver": "bin/semver" @@ -4841,19 +5165,10 @@ "url": "https://github.com/fb55/nth-check?sponsor=1" } }, - "node_modules/object-assign": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", - "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/object-inspect": { - "version": "1.12.2", - "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", - "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==", + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", + "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", "dev": true, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -4869,13 +5184,13 @@ } }, "node_modules/object.assign": { - "version": "4.1.4", - "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.4.tgz", - "integrity": "sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ==", + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", + "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", "has-symbols": "^1.0.3", "object-keys": "^1.1.1" }, @@ -4886,67 +5201,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/object.entries": { - "version": "1.1.6", - "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.6.tgz", - "integrity": "sha512-leTPzo4Zvg3pmbQ3rDK69Rl8GQvIqMWubrkxONG9/ojtFE2rD9fjMKfSI5BxW3osRH1m6VdzmqK8oAY9aT4x5w==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - }, - "engines": { - "node": ">= 0.4" - } - }, - "node_modules/object.fromentries": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.6.tgz", - "integrity": "sha512-VciD13dswC4j1Xt5394WR4MzmAQmlgN72phd/riNp9vtD7tp4QQWJ0R4wvclXcafgcYK8veHRed2W6XeGBvcfg==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/object.hasown": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/object.hasown/-/object.hasown-1.1.2.tgz", - "integrity": "sha512-B5UIT3J1W+WuWIU55h0mjlwaqxiE5vYENJXIXZ4VFe05pNYrkKuK0U/6aFcb0pKywYJh7IhfoqUfKVmrJJHZHw==", - "dev": true, - "dependencies": { - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/object.values": { - "version": "1.1.6", - "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.6.tgz", - "integrity": "sha512-FVVTkD1vENCsAcwNs9k6jea2uHC/X0+JcjG8YA60FN5CMaJmG95wT9jek/xX9nornqGRrBkKtzuAu2wuHpKqvw==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/once": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", @@ -4956,16 +5210,16 @@ } }, "node_modules/optionator": { - "version": "0.9.1", - "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", - "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", + "version": "0.9.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", + "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", "dependencies": { + "@aashutoshrathi/word-wrap": "^1.2.3", "deep-is": "^0.1.3", "fast-levenshtein": "^2.0.6", "levn": "^0.4.1", "prelude-ls": "^1.2.1", - "type-check": "^0.4.0", - "word-wrap": "^1.2.3" + "type-check": "^0.4.0" }, "engines": { "node": ">= 0.8.0" @@ -5082,12 +5336,12 @@ "dev": true }, "node_modules/path-scurry": { - "version": "1.7.0", - "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.7.0.tgz", - "integrity": "sha512-UkZUeDjczjYRE495+9thsgcVgsaCPkaw80slmfVFgllxY+IO8ubTsOpFVjDPROBqJdHfVPUFRHPBV/WciOVfWg==", + "version": "1.10.1", + "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.10.1.tgz", + "integrity": "sha512-MkhCqzzBEpPvxxQ71Md0b1Kk51W01lrYvlMzSUaIzNsODdd7mqhiimSZlr+VegAz5Z6Vzt9Xg2ttE//XBhH3EQ==", "dependencies": { - "lru-cache": "^9.0.0", - "minipass": "^5.0.0" + "lru-cache": "^9.1.1 || ^10.0.0", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" }, "engines": { "node": ">=16 || 14 >=14.17" @@ -5097,9 +5351,9 @@ } }, "node_modules/path-scurry/node_modules/lru-cache": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-9.1.0.tgz", - "integrity": "sha512-qFXQEwchrZcMVen2uIDceR8Tii6kCJak5rzDStfEM0qA3YLMswaxIEZO0DhIbJ3aqaJiDjt+3crlplOb0tDtKQ==", + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.1.0.tgz", + "integrity": "sha512-/1clY/ui8CzjKFyjdvwPWJUYKiFVXG2I2cY0ssG7h4+hwk+XOIX7ZSG9Q7TW8TW3Kp3BUSqgFWBLgL4PJ+Blag==", "engines": { "node": "14 || >=16.14" } @@ -5158,36 +5412,36 @@ } }, "node_modules/playwright-chromium": { - "version": "1.33.0", - "resolved": "https://registry.npmjs.org/playwright-chromium/-/playwright-chromium-1.33.0.tgz", - "integrity": "sha512-aG2IqRp7Q6vRltZFT+N2stWwDUH2fEUTOTv8RxSKMK5QmIQQoNL9nJvNMIJ3yLuin8+coaa3mhJXjjUheo0+/A==", + "version": "1.40.1", + "resolved": "https://registry.npmjs.org/playwright-chromium/-/playwright-chromium-1.40.1.tgz", + "integrity": "sha512-3atylP47OCTBW0siGI7LOEG/XKL/vnrFH8xdr4uaTnqMsc0Xq4gOLk2gGwniPJ76LSc++9ASc0w/nfqtLAmm3A==", "dev": true, "hasInstallScript": true, "dependencies": { - "playwright-core": "1.33.0" + "playwright-core": "1.40.1" }, "bin": { "playwright": "cli.js" }, "engines": { - "node": ">=14" + "node": ">=16" } }, "node_modules/playwright-core": { - "version": "1.33.0", - "resolved": "https://registry.npmjs.org/playwright-core/-/playwright-core-1.33.0.tgz", - "integrity": "sha512-aizyPE1Cj62vAECdph1iaMILpT0WUDCq3E6rW6I+dleSbBoGbktvJtzS6VHkZ4DKNEOG9qJpiom/ZxO+S15LAw==", + "version": "1.40.1", + "resolved": "https://registry.npmjs.org/playwright-core/-/playwright-core-1.40.1.tgz", + "integrity": "sha512-+hkOycxPiV534c4HhpfX6yrlawqVUzITRKwHAmYfmsVreltEl6fAZJ3DPfLMOODw0H3s1Itd6MDCWmP1fl/QvQ==", "bin": { - "playwright": "cli.js" + "playwright-core": "cli.js" }, "engines": { - "node": ">=14" + "node": ">=16" } }, "node_modules/postcss": { - "version": "8.4.23", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.23.tgz", - "integrity": "sha512-bQ3qMcpF6A/YjR55xtoTr0jGOlnPOKAIMdOWiv0EIT6HVPEaJiJB4NLljSbiHoC2RX7DN5Uvjtpbg1NPdwv1oA==", + "version": "8.4.32", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.32.tgz", + "integrity": "sha512-D/kj5JNu6oo2EIy+XL/26JEDTlIbB8hw85G8StOE6L74RQAVVP5rej6wxCNqyMbR4RkPfqvezVbPw81Ngd6Kcw==", "funding": [ { "type": "opencollective", @@ -5203,7 +5457,7 @@ } ], "dependencies": { - "nanoid": "^3.3.6", + "nanoid": "^3.3.7", "picocolors": "^1.0.0", "source-map-js": "^1.0.2" }, @@ -5241,9 +5495,9 @@ } }, "node_modules/postcss-modules-local-by-default": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.0.tgz", - "integrity": "sha512-sT7ihtmGSF9yhm6ggikHdV0hlziDTX7oFoXtuVWeDd3hHObNkcHRo9V3yg7vCAY7cONyxJC/XXCmmiHHcvX7bQ==", + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.3.tgz", + "integrity": "sha512-2/u2zraspoACtrbFRnTijMiQtb4GW4BvatjaG/bCjYQo8kLTdevCUlwuBHx2sCnSyrI3x3qj4ZK1j5LQBgzmwA==", "dependencies": { "icss-utils": "^5.0.0", "postcss-selector-parser": "^6.0.2", @@ -5257,9 +5511,9 @@ } }, "node_modules/postcss-modules-scope": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-3.0.0.tgz", - "integrity": "sha512-hncihwFA2yPath8oZ15PZqvWGkWf+XUfQgUGamS4LqoP1anQLOsOJw0vr7J7IwLpoY9fatA2qiGUGmuZL0Iqlg==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-3.1.0.tgz", + "integrity": "sha512-SaIbK8XW+MZbd0xHPf7kdfA/3eOt7vxJ72IRecn3EzuZVLr1r0orzf0MX/pN8m+NMDoo6X/SQd8oeKqGZd8PXg==", "dependencies": { "postcss-selector-parser": "^6.0.4" }, @@ -5318,9 +5572,9 @@ } }, "node_modules/postcss-selector-parser": { - "version": "6.0.11", - "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.11.tgz", - "integrity": "sha512-zbARubNdogI9j7WY4nQJBiNqQf3sLS3wCP4WfOidu+p28LofJqDH1tcXypGrcmMHhDk2t9wGhCsYe/+szLTy1g==", + "version": "6.0.15", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.15.tgz", + "integrity": "sha512-rEYkQOMUCEMhsKbK66tbEU9QVIxbhN18YiniAwA7XQYTVBqrBy+P2p5JcdqsHgKM2zWylp8d7J6eszocfds5Sw==", "dependencies": { "cssesc": "^3.0.0", "util-deprecate": "^1.0.2" @@ -5335,9 +5589,9 @@ "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==" }, "node_modules/postcss/node_modules/nanoid": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", - "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==", + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", + "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", "funding": [ { "type": "github", @@ -5378,26 +5632,18 @@ "node": ">=14" } }, - "node_modules/prop-types": { - "version": "15.8.1", - "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", - "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", - "dev": true, - "dependencies": { - "loose-envify": "^1.4.0", - "object-assign": "^4.1.1", - "react-is": "^16.13.1" - } - }, "node_modules/proto-list": { "version": "1.2.4", "resolved": "https://registry.npmjs.org/proto-list/-/proto-list-1.2.4.tgz", "integrity": "sha512-vtK/94akxsTMhe0/cbfpR+syPuszcuwhqVjJq26CuNDgFGj682oRBXOP5MJpv2r7JtE8MsiepGIqvvOTBwn2vA==" }, - "node_modules/pseudomap": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", - "integrity": "sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ==" + "node_modules/punycode": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", + "engines": { + "node": ">=6" + } }, "node_modules/queue-microtask": { "version": "1.2.3", @@ -5471,12 +5717,6 @@ "react": "^18.2.0" } }, - "node_modules/react-is": { - "version": "16.13.1", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", - "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", - "dev": true - }, "node_modules/read-pkg": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", @@ -5516,14 +5756,14 @@ } }, "node_modules/regexp.prototype.flags": { - "version": "1.4.3", - "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.4.3.tgz", - "integrity": "sha512-fjggEOO3slI6Wvgjwflkc4NFRCTZAu5CnNfBd5qOMYhWdn67nJBBu34/TkD++eeFmd8C9r9jfXJ27+nSiRkSUA==", + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz", + "integrity": "sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg==", "dev": true, "dependencies": { "call-bind": "^1.0.2", - "define-properties": "^1.1.3", - "functions-have-names": "^1.2.2" + "define-properties": "^1.2.0", + "set-function-name": "^2.0.0" }, "engines": { "node": ">= 0.4" @@ -5572,12 +5812,12 @@ } }, "node_modules/resolve": { - "version": "1.22.1", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", - "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", + "version": "1.22.8", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", + "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", "dev": true, "dependencies": { - "is-core-module": "^2.9.0", + "is-core-module": "^2.13.0", "path-parse": "^1.0.7", "supports-preserve-symlinks-flag": "^1.0.0" }, @@ -5606,14 +5846,14 @@ } }, "node_modules/rimraf": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-5.0.0.tgz", - "integrity": "sha512-Jf9llaP+RvaEVS5nPShYFhtXIrb3LRKP281ib3So0KkeZKo2wIKyq0Re7TOSwanasA423PSr6CCIL4bP6T040g==", + "version": "5.0.5", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-5.0.5.tgz", + "integrity": "sha512-CqDakW+hMe/Bz202FPEymy68P+G50RfMQK+Qo5YUqc9SPipvbGjCGKd0RSKEelbsfQuw3g5NZDSrlZZAJurH1A==", "dependencies": { - "glob": "^10.0.0" + "glob": "^10.3.7" }, "bin": { - "rimraf": "dist/cjs/src/bin.js" + "rimraf": "dist/esm/bin.mjs" }, "engines": { "node": ">=14" @@ -5646,19 +5886,18 @@ } }, "node_modules/rimraf/node_modules/glob": { - "version": "10.2.1", - "resolved": "https://registry.npmjs.org/glob/-/glob-10.2.1.tgz", - "integrity": "sha512-ngom3wq2UhjdbmRE/krgkD8BQyi1KZ5l+D2dVm4+Yj+jJIBp74/ZGunL6gNGc/CYuQmvUBiavWEXIotRiv5R6A==", + "version": "10.3.10", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.10.tgz", + "integrity": "sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g==", "dependencies": { "foreground-child": "^3.1.0", - "fs.realpath": "^1.0.0", - "jackspeak": "^2.0.3", - "minimatch": "^9.0.0", - "minipass": "^5.0.0", - "path-scurry": "^1.7.0" + "jackspeak": "^2.3.5", + "minimatch": "^9.0.1", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0", + "path-scurry": "^1.10.1" }, "bin": { - "glob": "dist/cjs/src/bin.js" + "glob": "dist/esm/bin.mjs" }, "engines": { "node": ">=16 || 14 >=14.17" @@ -5668,9 +5907,9 @@ } }, "node_modules/rimraf/node_modules/minimatch": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.0.tgz", - "integrity": "sha512-0jJj8AvgKqWN05mrwuqi8QYKx1WmYSUoKSxu5Qhs9prezTz10sxAHGNZe9J9cqIJzta8DWsleh2KaVaLl6Ru2w==", + "version": "9.0.3", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", + "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", "dependencies": { "brace-expansion": "^2.0.1" }, @@ -5682,9 +5921,9 @@ } }, "node_modules/rimraf/node_modules/signal-exit": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.0.1.tgz", - "integrity": "sha512-uUWsN4aOxJAS8KOuf3QMyFtgm1pkb6I+KRZbRF/ghdf5T7sM+B1lLLzPDxswUjkmHyxQAVzEgG35E3NzDM9GVw==", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", + "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", "engines": { "node": ">=14" }, @@ -5693,17 +5932,30 @@ } }, "node_modules/rollup": { - "version": "3.21.3", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.21.3.tgz", - "integrity": "sha512-VnPfEG51nIv2xPLnZaekkuN06q9ZbnyDcLkaBdJa/W7UddyhOfMP2yOPziYQfeY7k++fZM8FdQIummFN5y14kA==", + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.9.2.tgz", + "integrity": "sha512-66RB8OtFKUTozmVEh3qyNfH+b+z2RXBVloqO2KCC/pjFaGaHtxP9fVfOQKPSGXg2mElmjmxjW/fZ7iKrEpMH5Q==", "bin": { "rollup": "dist/bin/rollup" }, "engines": { - "node": ">=14.18.0", + "node": ">=18.0.0", "npm": ">=8.0.0" }, "optionalDependencies": { + "@rollup/rollup-android-arm-eabi": "4.9.2", + "@rollup/rollup-android-arm64": "4.9.2", + "@rollup/rollup-darwin-arm64": "4.9.2", + "@rollup/rollup-darwin-x64": "4.9.2", + "@rollup/rollup-linux-arm-gnueabihf": "4.9.2", + "@rollup/rollup-linux-arm64-gnu": "4.9.2", + "@rollup/rollup-linux-arm64-musl": "4.9.2", + "@rollup/rollup-linux-riscv64-gnu": "4.9.2", + "@rollup/rollup-linux-x64-gnu": "4.9.2", + "@rollup/rollup-linux-x64-musl": "4.9.2", + "@rollup/rollup-win32-arm64-msvc": "4.9.2", + "@rollup/rollup-win32-ia32-msvc": "4.9.2", + "@rollup/rollup-win32-x64-msvc": "4.9.2", "fsevents": "~2.3.2" } }, @@ -5729,16 +5981,34 @@ "queue-microtask": "^1.2.2" } }, - "node_modules/safe-buffer": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", - "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { + "node_modules/safe-array-concat": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.0.1.tgz", + "integrity": "sha512-6XbUAseYE2KtOuGueyeobCySj9L4+66Tn6KQMOPQJrAJEowYKW/YR/MGJZl7FdydUdaFu4LYyDZjxf4/Nmo23Q==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1", + "has-symbols": "^1.0.3", + "isarray": "^2.0.5" + }, + "engines": { + "node": ">=0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { "type": "patreon", "url": "https://www.patreon.com/feross" }, @@ -5778,9 +6048,9 @@ } }, "node_modules/schema-utils": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.1.2.tgz", - "integrity": "sha512-pvjEHOgWc9OWA/f/DE3ohBWTD6EleVLf7iFUkoSwAxttdBhB9QUebQgxER2kWueOvRJXPHNnyrvvh9eZINB8Eg==", + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz", + "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==", "dependencies": { "@types/json-schema": "^7.0.8", "ajv": "^6.12.5", @@ -5795,9 +6065,9 @@ } }, "node_modules/semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", + "version": "7.5.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", + "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", "dependencies": { "lru-cache": "^6.0.0" }, @@ -5817,6 +6087,35 @@ "randombytes": "^2.1.0" } }, + "node_modules/set-function-length": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.1.1.tgz", + "integrity": "sha512-VoaqjbBJKiWtg4yRcKBQ7g7wnGnLV3M8oLvVWwOk2PdYY6PEFegR1vezXR0tw6fZGF9csVakIRjrJiy2veSBFQ==", + "dev": true, + "dependencies": { + "define-data-property": "^1.1.1", + "get-intrinsic": "^1.2.1", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/set-function-name": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.1.tgz", + "integrity": "sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA==", + "dev": true, + "dependencies": { + "define-data-property": "^1.0.1", + "functions-have-names": "^1.2.3", + "has-property-descriptors": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, "node_modules/shebang-command": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", @@ -5837,9 +6136,9 @@ } }, "node_modules/shell-quote": { - "version": "1.7.4", - "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.4.tgz", - "integrity": "sha512-8o/QEhSSRb1a5i7TFR0iM4G16Z0vYB2OQVs4G3aAFXjn3T6yEx8AZxy1PgDF7I00LZHYA3WxaSYIf5e5sAX8Rw==", + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.8.1.tgz", + "integrity": "sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==", "dev": true, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -5859,11 +6158,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/sigmund": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/sigmund/-/sigmund-1.0.1.tgz", - "integrity": "sha512-fCvEXfh6NWpm+YSuY2bpXb/VIihqWA6hLsgboC+0nl71Q7N7o2eaCW8mJa/NLvQhs6jpd3VZV4UiUQlV6+lc8g==" - }, "node_modules/signal-exit": { "version": "3.0.7", "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", @@ -5896,12 +6190,11 @@ } }, "node_modules/source-map-loader": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/source-map-loader/-/source-map-loader-4.0.1.tgz", - "integrity": "sha512-oqXpzDIByKONVY8g1NUPOTQhe0UTU5bWUl32GSkqK2LjJj0HmwTMVKxcUip0RgAYhY1mqgOxjbQM48a0mmeNfA==", + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/source-map-loader/-/source-map-loader-4.0.2.tgz", + "integrity": "sha512-oYwAqCuL0OZhBoSgmdrLa7mv9MjommVMiQIWgcztf+eS4+8BfcUee6nenFnDhKOhzAVnk5gpZdfnz1iiBv+5sg==", "dev": true, "dependencies": { - "abab": "^2.0.6", "iconv-lite": "^0.6.3", "source-map-js": "^1.0.2" }, @@ -5916,18 +6209,6 @@ "webpack": "^5.72.1" } }, - "node_modules/source-map-loader/node_modules/iconv-lite": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", - "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", - "dev": true, - "dependencies": { - "safer-buffer": ">= 2.1.2 < 3.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/source-map-support": { "version": "0.5.21", "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", @@ -5946,9 +6227,9 @@ } }, "node_modules/spdx-correct": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", - "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz", + "integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==", "dev": true, "dependencies": { "spdx-expression-parse": "^3.0.0", @@ -5972,9 +6253,9 @@ } }, "node_modules/spdx-license-ids": { - "version": "3.0.12", - "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.12.tgz", - "integrity": "sha512-rr+VVSXtRhO4OHbXUiAF7xW3Bo9DuuF6C5jH+q/x15j2jniycgKbxU09Hr0WqlSLUs4i4ltHGXqTe7VHclYWyA==", + "version": "3.0.16", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.16.tgz", + "integrity": "sha512-eWN+LnM3GR6gPu35WxNgbGl8rmY1AEmoMDvL/QD6zYmPWgywxWqJWNdLGT+ke8dKNWrcYgYjPpG5gbTfghP8rw==", "dev": true }, "node_modules/string-width": { @@ -5990,34 +6271,46 @@ "node": ">=8" } }, - "node_modules/string.prototype.matchall": { - "version": "4.0.8", - "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.8.tgz", - "integrity": "sha512-6zOCOcJ+RJAQshcTvXPHoxoQGONa3e/Lqx90wUA+wEzX78sg5Bo+1tQo4N0pohS0erG9qtCqJDjNCQBjeWVxyg==", + "node_modules/string-width-cjs": { + "name": "string-width", + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/string.prototype.padend": { + "version": "3.1.5", + "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.5.tgz", + "integrity": "sha512-DOB27b/2UTTD+4myKUFh+/fXWcu/UDyASIXfg+7VzoCNNGOfWvoyU/x5pvVHr++ztyt/oSYI1BcWBBG/hmlNjA==", "dev": true, "dependencies": { "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "get-intrinsic": "^1.1.3", - "has-symbols": "^1.0.3", - "internal-slot": "^1.0.3", - "regexp.prototype.flags": "^1.4.3", - "side-channel": "^1.0.4" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" + }, + "engines": { + "node": ">= 0.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/string.prototype.padend": { - "version": "3.1.4", - "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.4.tgz", - "integrity": "sha512-67otBXoksdjsnXXRUq+KMVTdlVRZ2af422Y0aTyTjVaoQkGr3mxl2Bc5emi7dOQ3OGVVQQskmLEWwFXwommpNw==", + "node_modules/string.prototype.trim": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz", + "integrity": "sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==", "dev": true, "dependencies": { "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" }, "engines": { "node": ">= 0.4" @@ -6027,28 +6320,28 @@ } }, "node_modules/string.prototype.trimend": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.6.tgz", - "integrity": "sha512-JySq+4mrPf9EsDBEDYMOb/lM7XQLulwg5R/m1r0PXEFqrV0qHvl58sdTilSXtKOflCsK2E8jxf+GKC0T07RWwQ==", + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz", + "integrity": "sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==", "dev": true, "dependencies": { "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" }, "funding": { "url": "https://github.com/sponsors/ljharb" } }, "node_modules/string.prototype.trimstart": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.6.tgz", - "integrity": "sha512-omqjMDaY92pbn5HOX7f9IccLA+U1tA9GvtU4JrodiXFfYB7jPzzHpRzpglLAjtUV6bB557zwClJezTqnAiYnQA==", + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", + "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", "dev": true, "dependencies": { "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -6065,6 +6358,18 @@ "node": ">=8" } }, + "node_modules/strip-ansi-cjs": { + "name": "strip-ansi", + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, "node_modules/strip-bom": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", @@ -6086,9 +6391,9 @@ } }, "node_modules/style-loader": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/style-loader/-/style-loader-3.3.2.tgz", - "integrity": "sha512-RHs/vcrKdQK8wZliteNK4NKzxvLBzpuHMqYmUVWeKa6MkaIQ97ZTOS0b+zapZhy6GcrgWnvWYCMHRirC3FsUmw==", + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/style-loader/-/style-loader-3.3.3.tgz", + "integrity": "sha512-53BiGLXAcll9maCYtZi2RCQZKa8NQQai5C4horqKyRmHj9H7QmcUyucrH+4KW/gBQbXM2AsB0axoEcFZPlfPcw==", "dev": true, "engines": { "node": ">= 12.13.0" @@ -6133,12 +6438,12 @@ } }, "node_modules/terser": { - "version": "5.17.1", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.17.1.tgz", - "integrity": "sha512-hVl35zClmpisy6oaoKALOpS0rDYLxRFLHhRuDlEGTKey9qHjS1w9GMORjuwIMt70Wan4lwsLYyWDVnWgF+KUEw==", + "version": "5.26.0", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.26.0.tgz", + "integrity": "sha512-dytTGoE2oHgbNV9nTzgBEPaqAWvcJNl66VZ0BkJqlvp71IjO8CxdBx/ykCNb47cLnCmCvRZ6ZR0tLkqvZCdVBQ==", "dependencies": { - "@jridgewell/source-map": "^0.3.2", - "acorn": "^8.5.0", + "@jridgewell/source-map": "^0.3.3", + "acorn": "^8.8.2", "commander": "^2.20.0", "source-map-support": "~0.5.20" }, @@ -6150,15 +6455,15 @@ } }, "node_modules/terser-webpack-plugin": { - "version": "5.3.7", - "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.7.tgz", - "integrity": "sha512-AfKwIktyP7Cu50xNjXF/6Qb5lBNzYaWpU6YfoX3uZicTx0zTy0stDDCsvjDapKsSDvOeWo5MEq4TmdBy2cNoHw==", + "version": "5.3.10", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.10.tgz", + "integrity": "sha512-BKFPWlPDndPs+NGGCr1U59t0XScL5317Y0UReNrHaw9/FwhPENlq6bfgs+4yPfyP51vqC1bQ4rp1EfXW5ZSH9w==", "dependencies": { - "@jridgewell/trace-mapping": "^0.3.17", + "@jridgewell/trace-mapping": "^0.3.20", "jest-worker": "^27.4.5", "schema-utils": "^3.1.1", "serialize-javascript": "^6.0.1", - "terser": "^5.16.5" + "terser": "^5.26.0" }, "engines": { "node": ">= 10.13.0" @@ -6232,9 +6537,9 @@ "dev": true }, "node_modules/tsconfig-paths": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-4.1.2.tgz", - "integrity": "sha512-uhxiMgnXQp1IR622dUXI+9Ehnws7i/y6xvpZB9IbUVOPy0muvdvgXeZOn88UcGPiT98Vp3rJPTa8bFoalZ3Qhw==", + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-4.2.0.tgz", + "integrity": "sha512-NoZ4roiN7LnbKn9QqE1amc9DJfzvZXxF4xDavcOWt1BPkdx+m+0gJuPM+S0vCe7zTJMYUP0R8pO2XMr+Y8oLIg==", "dev": true, "dependencies": { "json5": "^2.2.2", @@ -6246,9 +6551,9 @@ } }, "node_modules/tsconfig-paths-webpack-plugin": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/tsconfig-paths-webpack-plugin/-/tsconfig-paths-webpack-plugin-4.0.1.tgz", - "integrity": "sha512-m5//KzLoKmqu2MVix+dgLKq70MnFi8YL8sdzQZ6DblmCdfuq/y3OqvJd5vMndg2KEVCOeNz8Es4WVZhYInteLw==", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/tsconfig-paths-webpack-plugin/-/tsconfig-paths-webpack-plugin-4.1.0.tgz", + "integrity": "sha512-xWFISjviPydmtmgeUAuXp4N1fky+VCtfhOkDUFIv5ea7p4wuTomI4QTrXvFBX2S4jZsmyTSrStQl+E+4w+RzxA==", "dev": true, "dependencies": { "chalk": "^4.1.0", @@ -6260,9 +6565,9 @@ } }, "node_modules/tslib": { - "version": "2.4.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.1.tgz", - "integrity": "sha512-tGyy4dAjRIEwI7BzsB0lynWgOpfqjUdq91XXAlIWD2OwKBH7oCl/GZG/HT4BOHrTlPMOASlMQ7veyTqpmRcrNA==", + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", + "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", "dev": true }, "node_modules/tsutils": { @@ -6314,16 +6619,81 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/typed-array-buffer": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz", + "integrity": "sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1", + "is-typed-array": "^1.1.10" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/typed-array-byte-length": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz", + "integrity": "sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "has-proto": "^1.0.1", + "is-typed-array": "^1.1.10" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz", + "integrity": "sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "has-proto": "^1.0.1", + "is-typed-array": "^1.1.10" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-length": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz", + "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "is-typed-array": "^1.1.9" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/typescript": { - "version": "5.0.4", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.0.4.tgz", - "integrity": "sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw==", + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.2.2.tgz", + "integrity": "sha512-mI4WrpHsbCIcwT9cF4FZvr80QUeKvsUsUvKDoR+X/7XHQH98xYD8YHZg7ANtz2GtZt/CBq2QJ0thkGJMHfqc1w==", "bin": { "tsc": "bin/tsc", "tsserver": "bin/tsserver" }, "engines": { - "node": ">=12.20" + "node": ">=14.17" } }, "node_modules/unbox-primitive": { @@ -6342,9 +6712,9 @@ } }, "node_modules/update-browserslist-db": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz", - "integrity": "sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ==", + "version": "1.0.13", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", + "integrity": "sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==", "funding": [ { "type": "opencollective", @@ -6353,6 +6723,10 @@ { "type": "tidelift", "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" } ], "dependencies": { @@ -6360,7 +6734,7 @@ "picocolors": "^1.0.0" }, "bin": { - "browserslist-lint": "cli.js" + "update-browserslist-db": "cli.js" }, "peerDependencies": { "browserslist": ">= 4.21.0" @@ -6374,14 +6748,6 @@ "punycode": "^2.1.0" } }, - "node_modules/uri-js/node_modules/punycode": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", - "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", - "engines": { - "node": ">=6" - } - }, "node_modules/url-loader": { "version": "4.1.1", "resolved": "https://registry.npmjs.org/url-loader/-/url-loader-4.1.1.tgz", @@ -6432,14 +6798,14 @@ "dev": true }, "node_modules/v8-to-istanbul": { - "version": "9.0.1", - "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.0.1.tgz", - "integrity": "sha512-74Y4LqY74kLE6IFyIjPtkSTWzUZmj8tdHT9Ii/26dvQ6K9Dl2NbEfj0XgU2sHCtKgt5VupqhlO/5aWuqS+IY1w==", + "version": "9.2.0", + "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.2.0.tgz", + "integrity": "sha512-/EH/sDgxU2eGxajKdwLCDmQ4FWq+kpi3uCmBGpw1xJtnAxEjlD8j8PEiGWpCIMIs3ciNAgH0d3TTJiUkYzyZjA==", "dev": true, "dependencies": { "@jridgewell/trace-mapping": "^0.3.12", "@types/istanbul-lib-coverage": "^2.0.1", - "convert-source-map": "^1.6.0" + "convert-source-map": "^2.0.0" }, "engines": { "node": ">=10.12.0" @@ -6525,58 +6891,58 @@ "integrity": "sha512-aodjPa2wPQFkra1G8CzJBTHXhgk3EVSwxSWXNPr1fgdFLUb8kvLV1iEb6rFgasIsjP82HWI6dsb5Io26DDnasA==" }, "node_modules/vscode-css-languageservice": { - "version": "6.2.5", - "resolved": "https://registry.npmjs.org/vscode-css-languageservice/-/vscode-css-languageservice-6.2.5.tgz", - "integrity": "sha512-/1oyBZK3jfx6A0cA46FCUpy6OlqEsMT47LUIldCIP1YMKRYezJ9No+aNj9IM0AqhRZ92DxZ1DmU5lJ+biuiacA==", + "version": "6.2.11", + "resolved": "https://registry.npmjs.org/vscode-css-languageservice/-/vscode-css-languageservice-6.2.11.tgz", + "integrity": "sha512-qn49Wa6K94LnizpVxmlYrcPf1Cb36gq1nNueW0COhi4shylXBzET5wuDbH8ZWQlJD0HM5Mmnn7WE9vQVVs+ULA==", "dependencies": { - "@vscode/l10n": "^0.0.13", - "vscode-languageserver-textdocument": "^1.0.8", - "vscode-languageserver-types": "^3.17.3", - "vscode-uri": "^3.0.7" + "@vscode/l10n": "^0.0.16", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-languageserver-types": "3.17.5", + "vscode-uri": "^3.0.8" } }, "node_modules/vscode-jsonrpc": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/vscode-jsonrpc/-/vscode-jsonrpc-8.1.0.tgz", - "integrity": "sha512-6TDy/abTQk+zDGYazgbIPc+4JoXdwC8NHU9Pbn4UJP1fehUyZmM4RHp5IthX7A6L5KS30PRui+j+tbbMMMafdw==", + "version": "8.2.0", + "resolved": "https://registry.npmjs.org/vscode-jsonrpc/-/vscode-jsonrpc-8.2.0.tgz", + "integrity": "sha512-C+r0eKJUIfiDIfwJhria30+TYWPtuHJXHtI7J0YlOmKAo7ogxP20T0zxB7HZQIFhIyvoBPwWskjxrvAtfjyZfA==", "engines": { "node": ">=14.0.0" } }, "node_modules/vscode-languageserver": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/vscode-languageserver/-/vscode-languageserver-8.1.0.tgz", - "integrity": "sha512-eUt8f1z2N2IEUDBsKaNapkz7jl5QpskN2Y0G01T/ItMxBxw1fJwvtySGB9QMecatne8jFIWJGWI61dWjyTLQsw==", + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/vscode-languageserver/-/vscode-languageserver-9.0.1.tgz", + "integrity": "sha512-woByF3PDpkHFUreUa7Hos7+pUWdeWMXRd26+ZX2A8cFx6v/JPTtd4/uN0/jB6XQHYaOlHbio03NTHCqrgG5n7g==", "dependencies": { - "vscode-languageserver-protocol": "3.17.3" + "vscode-languageserver-protocol": "3.17.5" }, "bin": { "installServerIntoExtension": "bin/installServerIntoExtension" } }, "node_modules/vscode-languageserver-protocol": { - "version": "3.17.3", - "resolved": "https://registry.npmjs.org/vscode-languageserver-protocol/-/vscode-languageserver-protocol-3.17.3.tgz", - "integrity": "sha512-924/h0AqsMtA5yK22GgMtCYiMdCOtWTSGgUOkgEDX+wk2b0x4sAfLiO4NxBxqbiVtz7K7/1/RgVrVI0NClZwqA==", + "version": "3.17.5", + "resolved": "https://registry.npmjs.org/vscode-languageserver-protocol/-/vscode-languageserver-protocol-3.17.5.tgz", + "integrity": "sha512-mb1bvRJN8SVznADSGWM9u/b07H7Ecg0I3OgXDuLdn307rl/J3A9YD6/eYOssqhecL27hK1IPZAsaqh00i/Jljg==", "dependencies": { - "vscode-jsonrpc": "8.1.0", - "vscode-languageserver-types": "3.17.3" + "vscode-jsonrpc": "8.2.0", + "vscode-languageserver-types": "3.17.5" } }, "node_modules/vscode-languageserver-textdocument": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/vscode-languageserver-textdocument/-/vscode-languageserver-textdocument-1.0.8.tgz", - "integrity": "sha512-1bonkGqQs5/fxGT5UchTgjGVnfysL0O8v1AYMBjqTbWQTFn721zaPGDYFkOKtfDgFiSgXM3KwaG3FMGfW4Ed9Q==" + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/vscode-languageserver-textdocument/-/vscode-languageserver-textdocument-1.0.11.tgz", + "integrity": "sha512-X+8T3GoiwTVlJbicx/sIAF+yuJAqz8VvwJyoMVhwEMoEKE/fkDmrqUgDMyBECcM2A2frVZIUj5HI/ErRXCfOeA==" }, "node_modules/vscode-languageserver-types": { - "version": "3.17.3", - "resolved": "https://registry.npmjs.org/vscode-languageserver-types/-/vscode-languageserver-types-3.17.3.tgz", - "integrity": "sha512-SYU4z1dL0PyIMd4Vj8YOqFvHu7Hz/enbWtpfnVbJHU4Nd1YNYx8u0ennumc6h48GQNeOLxmwySmnADouT/AuZA==" + "version": "3.17.5", + "resolved": "https://registry.npmjs.org/vscode-languageserver-types/-/vscode-languageserver-types-3.17.5.tgz", + "integrity": "sha512-Ld1VelNuX9pdF39h2Hgaeb5hEZM2Z3jUrrMgWQAu82jMtZp7p3vJT3BzToKtZI7NgQssZje5o0zryOrhQvzQAg==" }, "node_modules/vscode-uri": { - "version": "3.0.7", - "resolved": "https://registry.npmjs.org/vscode-uri/-/vscode-uri-3.0.7.tgz", - "integrity": "sha512-eOpPHogvorZRobNqJGhapa0JdwaxpjVvyBp0QIUMRMSf8ZAlqOdEquKuRmw9Qwu0qXtJIWqFtMkmvJjUZmMjVA==" + "version": "3.0.8", + "resolved": "https://registry.npmjs.org/vscode-uri/-/vscode-uri-3.0.8.tgz", + "integrity": "sha512-AyFQ0EVmsOZOlAnxoFOGOq1SQDWAB7C6aqMGS23svWAllfOaxbuFvcT8D1i8z3Gyn8fraVeZNNmN6e9bxxXkKw==" }, "node_modules/watchpack": { "version": "2.4.0", @@ -6591,9 +6957,9 @@ } }, "node_modules/webpack": { - "version": "5.81.0", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.81.0.tgz", - "integrity": "sha512-AAjaJ9S4hYCVODKLQTgG5p5e11hiMawBwV2v8MYLE0C/6UAGLuAF4n1qa9GOwdxnicaP+5k6M5HrLmD4+gIB8Q==", + "version": "5.89.0", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.89.0.tgz", + "integrity": "sha512-qyfIC10pOr70V+jkmud8tMfajraGCZMBWJtrmuBymQKCrLTRejBI8STDp1MCyZu/QTdZSeacCQYpYNQVOzX5kw==", "dependencies": { "@types/eslint-scope": "^3.7.3", "@types/estree": "^1.0.0", @@ -6601,10 +6967,10 @@ "@webassemblyjs/wasm-edit": "^1.11.5", "@webassemblyjs/wasm-parser": "^1.11.5", "acorn": "^8.7.1", - "acorn-import-assertions": "^1.7.6", + "acorn-import-assertions": "^1.9.0", "browserslist": "^4.14.5", "chrome-trace-event": "^1.0.2", - "enhanced-resolve": "^5.13.0", + "enhanced-resolve": "^5.15.0", "es-module-lexer": "^1.2.1", "eslint-scope": "5.1.1", "events": "^3.2.0", @@ -6614,7 +6980,7 @@ "loader-runner": "^4.2.0", "mime-types": "^2.1.27", "neo-async": "^2.6.2", - "schema-utils": "^3.1.2", + "schema-utils": "^3.2.0", "tapable": "^2.1.1", "terser-webpack-plugin": "^5.3.7", "watchpack": "^2.4.0", @@ -6674,12 +7040,23 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/word-wrap": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", - "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", + "node_modules/which-typed-array": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.13.tgz", + "integrity": "sha512-P5Nra0qjSncduVPEAr7xhoF5guty49ArDTwzJ/yNuPIbZppyRxFQsRCWrocxIY+CnMVG+qfbU2FmDKyvSGClow==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.4", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.0" + }, "engines": { - "node": ">=0.10.0" + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" } }, "node_modules/workerpool": { @@ -6704,6 +7081,23 @@ "url": "https://github.com/chalk/wrap-ansi?sponsor=1" } }, + "node_modules/wrap-ansi-cjs": { + "name": "wrap-ansi", + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, "node_modules/wrappy": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", @@ -6740,12 +7134,11 @@ } }, "node_modules/yargs-parser": { - "version": "20.2.9", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", - "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", - "dev": true, + "version": "21.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", + "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", "engines": { - "node": ">=10" + "node": ">=12" } }, "node_modules/yargs-unparser": { @@ -6763,26 +7156,6 @@ "node": ">=10" } }, - "node_modules/yargs-unparser/node_modules/camelcase": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", - "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/yargs/node_modules/yargs-parser": { - "version": "21.1.1", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", - "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", - "engines": { - "node": ">=12" - } - }, "node_modules/yocto-queue": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", @@ -6796,10 +7169,10 @@ }, "packages/build-tools": { "name": "@stylable/build-tools", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/core": "^5.11.0", + "@stylable/core": "^5.17.0", "find-config": "^1.0.0" }, "engines": { @@ -6808,19 +7181,19 @@ }, "packages/cli": { "name": "@stylable/cli", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@file-services/node": "^7.2.5", - "@file-services/types": "^7.2.5", - "@stylable/build-tools": "^5.11.0", - "@stylable/code-formatter": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", + "@file-services/node": "^8.3.3", + "@file-services/types": "^8.3.3", + "@stylable/build-tools": "^5.17.0", + "@stylable/code-formatter": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", "@wixc3/resolve-directory-context": "^3.0.5", - "decache": "^4.6.1", + "decache": "^4.6.2", "lodash.camelcase": "^4.3.0", "lodash.upperfirst": "^4.3.1", "mime": "^3.0.0", @@ -6835,15 +7208,25 @@ "node": ">=14.14.0" } }, + "packages/cli/node_modules/mime": { + "version": "3.0.0", + "license": "MIT", + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=10.0.0" + } + }, "packages/code-formatter": { "name": "@stylable/code-formatter", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/core": "^5.11.0", - "@tokey/css-value-parser": "^0.1.2", - "js-beautify": "^1.14.7", - "postcss": "^8.4.23" + "@stylable/core": "^5.17.0", + "@tokey/css-value-parser": "^0.1.4", + "js-beautify": "^1.14.11", + "postcss": "^8.4.32" }, "engines": { "node": ">=14.14.0" @@ -6851,19 +7234,20 @@ }, "packages/core": { "name": "@stylable/core", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@tokey/css-selector-parser": "^0.6.1", + "@tokey/css-selector-parser": "^0.6.2", + "@tokey/css-value-parser": "^0.1.4", "@tokey/imports-parser": "^1.0.0", "balanced-match": "^2.0.0", "css-selector-tokenizer": "^0.8.0", "cssesc": "^3.0.0", - "enhanced-resolve": "^5.13.0", + "enhanced-resolve": "^5.15.0", "is-vendor-prefixed": "^4.0.0", "lodash.clonedeep": "^4.5.0", "lodash.clonedeepwith": "^4.5.0", - "postcss": "^8.4.23", + "postcss": "^8.4.32", "postcss-js": "^4.0.1", "postcss-nested": "^6.0.1", "postcss-safe-parser": "^6.0.0", @@ -6875,14 +7259,14 @@ }, "packages/core-test-kit": { "name": "@stylable/core-test-kit", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@file-services/memory": "^7.2.5", - "@stylable/core": "^5.11.0", - "chai": "^4.3.7", + "@file-services/memory": "^8.3.3", + "@stylable/core": "^5.17.0", + "chai": "^4.3.10", "flat": "^5.0.2", - "postcss": "^8.4.23" + "postcss": "^8.4.32" }, "engines": { "node": ">=14.14.0" @@ -6890,11 +7274,10 @@ }, "packages/core/node_modules/balanced-match": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-2.0.0.tgz", - "integrity": "sha512-1ugUSr8BHXRnK23KfuYS+gVMC3LB8QGH9W1iGtDPsNWoQbgtXSExkBu2aDR4epiGWZOjZsj6lDl/N/AqqTC3UA==" + "license": "MIT" }, "packages/create-stylable-app": { - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { "validate-npm-package-name": "^5.0.0", @@ -6909,10 +7292,10 @@ }, "packages/custom-value": { "name": "@stylable/custom-value", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/core": "^5.11.0" + "@stylable/core": "^5.17.0" }, "engines": { "node": ">=14.14.0" @@ -6920,12 +7303,12 @@ }, "packages/dom-test-kit": { "name": "@stylable/dom-test-kit", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/core": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "@tokey/css-selector-parser": "^0.6.1" + "@stylable/core": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "@tokey/css-selector-parser": "^0.6.2" }, "engines": { "node": ">=14.14.0" @@ -6933,13 +7316,13 @@ }, "packages/e2e-test-kit": { "name": "@stylable/e2e-test-kit", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/runtime": "^5.11.0", + "@stylable/runtime": "^5.17.0", "node-eval": "^2.0.0", - "playwright-core": "^1.33.0", - "rimraf": "^5.0.0" + "playwright-core": "^1.40.1", + "rimraf": "^5.0.5" }, "engines": { "node": ">=14.14.0" @@ -6950,62 +7333,60 @@ }, "packages/esbuild": { "name": "@stylable/esbuild", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/build-tools": "^5.11.0", - "@stylable/cli": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "decache": "^4.6.1" + "@stylable/build-tools": "^5.17.0", + "@stylable/cli": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "decache": "^4.6.2" }, "engines": { "node": ">=14.14.0" }, "peerDependencies": { - "esbuild": "^0.17.18" + "esbuild": ">=0.17.18" } }, "packages/eslint-plugin-stylable": { - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/core": "^5.11.0", - "@typescript-eslint/experimental-utils": "^5.59.2" + "@stylable/core": "^5.17.0", + "@typescript-eslint/utils": "^5.61.0" } }, "packages/experimental-loader": { "name": "@stylable/experimental-loader", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/core": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "css-loader": "^6.7.3", - "decache": "^4.6.1", + "@stylable/core": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "css-loader": "^6.8.1", + "decache": "^4.6.2", "loader-utils": "^3.2.1" } }, "packages/experimental-loader/node_modules/loader-utils": { "version": "3.2.1", - "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-3.2.1.tgz", - "integrity": "sha512-ZvFw1KWS3GVyYBYb7qkmRM/WwL2TQQBxgCK62rlvm4WpVQ23Nb4tYjApUlfjrEGvOs7KHEsmyUn75OHZrJMWPw==", + "license": "MIT", "engines": { "node": ">= 12.13.0" } }, "packages/jest": { "name": "@stylable/jest", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/runtime": "^5.11.0" + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/runtime": "^5.17.0" }, "engines": { "node": ">=14.14.0" @@ -7013,23 +7394,23 @@ }, "packages/language-service": { "name": "@stylable/language-service", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@file-services/types": "^7.2.5", - "@file-services/typescript": "^7.2.5", - "@stylable/code-formatter": "^5.11.0", - "@stylable/core": "^5.11.0", - "@tokey/core": "^1.3.0", - "@tokey/css-selector-parser": "^0.6.1", - "@tokey/css-value-parser": "^0.1.2", + "@file-services/types": "^8.3.3", + "@file-services/typescript": "^8.3.3", + "@stylable/code-formatter": "^5.17.0", + "@stylable/core": "^5.17.0", + "@tokey/core": "^1.4.0", + "@tokey/css-selector-parser": "^0.6.2", + "@tokey/css-value-parser": "^0.1.4", "css-selector-tokenizer": "^0.8.0", - "postcss": "^8.4.23", + "postcss": "^8.4.32", "postcss-value-parser": "^4.2.0", - "vscode-css-languageservice": "^6.2.5", - "vscode-languageserver": "^8.1.0", - "vscode-languageserver-textdocument": "^1.0.8", - "vscode-uri": "^3.0.7" + "vscode-css-languageservice": "^6.2.11", + "vscode-languageserver": "^9.0.1", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-uri": "^3.0.8" }, "engines": { "node": ">=14.14.0" @@ -7040,11 +7421,11 @@ }, "packages/module-utils": { "name": "@stylable/module-utils", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/core": "^5.11.0", - "@tokey/core": "^1.3.0", + "@stylable/core": "^5.17.0", + "@tokey/core": "^1.4.0", "vlq": "^2.0.4" }, "engines": { @@ -7053,12 +7434,12 @@ }, "packages/node": { "name": "@stylable/node", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/build-tools": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", + "@stylable/build-tools": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", "find-config": "^1.0.0" }, "engines": { @@ -7067,13 +7448,13 @@ }, "packages/optimizer": { "name": "@stylable/optimizer", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/core": "^5.11.0", - "@tokey/css-selector-parser": "^0.6.1", + "@stylable/core": "^5.17.0", + "@tokey/css-selector-parser": "^0.6.2", "csso": "^5.0.5", - "postcss": "^8.4.23" + "postcss": "^8.4.32" }, "engines": { "node": ">=14.14.0" @@ -7081,28 +7462,38 @@ }, "packages/rollup-plugin": { "name": "@stylable/rollup-plugin", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/build-tools": "^5.11.0", - "@stylable/cli": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "decache": "^4.6.1", + "@stylable/build-tools": "^5.17.0", + "@stylable/cli": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "decache": "^4.6.2", "mime": "^3.0.0" }, "engines": { "node": ">=14.14.0" }, "peerDependencies": { - "rollup": "^2.70.0 || ^3.0.0" + "rollup": "^2.70.0 || ^3.0.0 || ^4.0.0" + } + }, + "packages/rollup-plugin/node_modules/mime": { + "version": "3.0.0", + "license": "MIT", + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=10.0.0" } }, "packages/runtime": { "name": "@stylable/runtime", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "engines": { "node": ">=14.14.0" @@ -7110,11 +7501,11 @@ }, "packages/schema-extract": { "name": "@stylable/schema-extract", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/core": "^5.11.0", - "jest-docblock": "^29.4.3" + "@stylable/core": "^5.17.0", + "jest-docblock": "^29.7.0" }, "engines": { "node": ">=14.14.0" @@ -7122,7 +7513,7 @@ }, "packages/uni-driver": { "name": "@stylable/uni-driver", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "engines": { "node": ">=14.14.0" @@ -7168,13 +7559,13 @@ }, "packages/webpack-extensions": { "name": "@stylable/webpack-extensions", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/core": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/webpack-plugin": "^5.11.0", - "@tokey/css-selector-parser": "^0.6.1", + "@stylable/core": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/webpack-plugin": "^5.17.0", + "@tokey/css-selector-parser": "^0.6.2", "find-config": "^1.0.0", "lodash.clonedeep": "^4.5.0" }, @@ -7187,19 +7578,19 @@ }, "packages/webpack-plugin": { "name": "@stylable/webpack-plugin", - "version": "5.11.0", + "version": "5.17.0", "license": "MIT", "dependencies": { - "@stylable/build-tools": "^5.11.0", - "@stylable/cli": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "decache": "^4.6.1", + "@stylable/build-tools": "^5.17.0", + "@stylable/cli": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "decache": "^4.6.2", "lodash.clonedeep": "^4.5.0", - "postcss": "^8.4.23" + "postcss": "^8.4.32" }, "engines": { "node": ">=14.14.0" @@ -7210,187 +7601,199 @@ } }, "dependencies": { + "@aashutoshrathi/word-wrap": { + "version": "1.2.6", + "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", + "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==" + }, "@bcoe/v8-coverage": { "version": "0.2.3", "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", "dev": true }, + "@esbuild/aix-ppc64": { + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.19.11.tgz", + "integrity": "sha512-FnzU0LyE3ySQk7UntJO4+qIiQgI7KoODnZg5xzXIrFJlKd2P2gwHsHY4927xj9y5PJmJSzULiUCWmv7iWnNa7g==", + "optional": true, + "peer": true + }, "@esbuild/android-arm": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.18.tgz", - "integrity": "sha512-EmwL+vUBZJ7mhFCs5lA4ZimpUH3WMAoqvOIYhVQwdIgSpHC8ImHdsRyhHAVxpDYUSm0lWvd63z0XH1IlImS2Qw==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.19.11.tgz", + "integrity": "sha512-5OVapq0ClabvKvQ58Bws8+wkLCV+Rxg7tUVbo9xu034Nm536QTII4YzhaFriQ7rMrorfnFKUsArD2lqKbFY4vw==", "optional": true, "peer": true }, "@esbuild/android-arm64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.18.tgz", - "integrity": "sha512-/iq0aK0eeHgSC3z55ucMAHO05OIqmQehiGay8eP5l/5l+iEr4EIbh4/MI8xD9qRFjqzgkc0JkX0LculNC9mXBw==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.19.11.tgz", + "integrity": "sha512-aiu7K/5JnLj//KOnOfEZ0D90obUkRzDMyqd/wNAUQ34m4YUPVhRZpnqKV9uqDGxT7cToSDnIHsGooyIczu9T+Q==", "optional": true, "peer": true }, "@esbuild/android-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.18.tgz", - "integrity": "sha512-x+0efYNBF3NPW2Xc5bFOSFW7tTXdAcpfEg2nXmxegm4mJuVeS+i109m/7HMiOQ6M12aVGGFlqJX3RhNdYM2lWg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.19.11.tgz", + "integrity": "sha512-eccxjlfGw43WYoY9QgB82SgGgDbibcqyDTlk3l3C0jOVHKxrjdc9CTwDUQd0vkvYg5um0OH+GpxYvp39r+IPOg==", "optional": true, "peer": true }, "@esbuild/darwin-arm64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.18.tgz", - "integrity": "sha512-6tY+djEAdF48M1ONWnQb1C+6LiXrKjmqjzPNPWXhu/GzOHTHX2nh8Mo2ZAmBFg0kIodHhciEgUBtcYCAIjGbjQ==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.19.11.tgz", + "integrity": "sha512-ETp87DRWuSt9KdDVkqSoKoLFHYTrkyz2+65fj9nfXsaV3bMhTCjtQfw3y+um88vGRKRiF7erPrh/ZuIdLUIVxQ==", "optional": true, "peer": true }, "@esbuild/darwin-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.18.tgz", - "integrity": "sha512-Qq84ykvLvya3dO49wVC9FFCNUfSrQJLbxhoQk/TE1r6MjHo3sFF2tlJCwMjhkBVq3/ahUisj7+EpRSz0/+8+9A==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.19.11.tgz", + "integrity": "sha512-fkFUiS6IUK9WYUO/+22omwetaSNl5/A8giXvQlcinLIjVkxwTLSktbF5f/kJMftM2MJp9+fXqZ5ezS7+SALp4g==", "optional": true, "peer": true }, "@esbuild/freebsd-arm64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.18.tgz", - "integrity": "sha512-fw/ZfxfAzuHfaQeMDhbzxp9mc+mHn1Y94VDHFHjGvt2Uxl10mT4CDavHm+/L9KG441t1QdABqkVYwakMUeyLRA==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.19.11.tgz", + "integrity": "sha512-lhoSp5K6bxKRNdXUtHoNc5HhbXVCS8V0iZmDvyWvYq9S5WSfTIHU2UGjcGt7UeS6iEYp9eeymIl5mJBn0yiuxA==", "optional": true, "peer": true }, "@esbuild/freebsd-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.18.tgz", - "integrity": "sha512-FQFbRtTaEi8ZBi/A6kxOC0V0E9B/97vPdYjY9NdawyLd4Qk5VD5g2pbWN2VR1c0xhzcJm74HWpObPszWC+qTew==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.19.11.tgz", + "integrity": "sha512-JkUqn44AffGXitVI6/AbQdoYAq0TEullFdqcMY/PCUZ36xJ9ZJRtQabzMA+Vi7r78+25ZIBosLTOKnUXBSi1Kw==", "optional": true, "peer": true }, "@esbuild/linux-arm": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.18.tgz", - "integrity": "sha512-jW+UCM40LzHcouIaqv3e/oRs0JM76JfhHjCavPxMUti7VAPh8CaGSlS7cmyrdpzSk7A+8f0hiedHqr/LMnfijg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.19.11.tgz", + "integrity": "sha512-3CRkr9+vCV2XJbjwgzjPtO8T0SZUmRZla+UL1jw+XqHZPkPgZiyWvbDvl9rqAN8Zl7qJF0O/9ycMtjU67HN9/Q==", "optional": true, "peer": true }, "@esbuild/linux-arm64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.18.tgz", - "integrity": "sha512-R7pZvQZFOY2sxUG8P6A21eq6q+eBv7JPQYIybHVf1XkQYC+lT7nDBdC7wWKTrbvMXKRaGudp/dzZCwL/863mZQ==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.19.11.tgz", + "integrity": "sha512-LneLg3ypEeveBSMuoa0kwMpCGmpu8XQUh+mL8XXwoYZ6Be2qBnVtcDI5azSvh7vioMDhoJFZzp9GWp9IWpYoUg==", "optional": true, "peer": true }, "@esbuild/linux-ia32": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.18.tgz", - "integrity": "sha512-ygIMc3I7wxgXIxk6j3V00VlABIjq260i967Cp9BNAk5pOOpIXmd1RFQJQX9Io7KRsthDrQYrtcx7QCof4o3ZoQ==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.19.11.tgz", + "integrity": "sha512-caHy++CsD8Bgq2V5CodbJjFPEiDPq8JJmBdeyZ8GWVQMjRD0sU548nNdwPNvKjVpamYYVL40AORekgfIubwHoA==", "optional": true, "peer": true }, "@esbuild/linux-loong64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.18.tgz", - "integrity": "sha512-bvPG+MyFs5ZlwYclCG1D744oHk1Pv7j8psF5TfYx7otCVmcJsEXgFEhQkbhNW8otDHL1a2KDINW20cfCgnzgMQ==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.19.11.tgz", + "integrity": "sha512-ppZSSLVpPrwHccvC6nQVZaSHlFsvCQyjnvirnVjbKSHuE5N24Yl8F3UwYUUR1UEPaFObGD2tSvVKbvR+uT1Nrg==", "optional": true, "peer": true }, "@esbuild/linux-mips64el": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.18.tgz", - "integrity": "sha512-oVqckATOAGuiUOa6wr8TXaVPSa+6IwVJrGidmNZS1cZVx0HqkTMkqFGD2HIx9H1RvOwFeWYdaYbdY6B89KUMxA==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.19.11.tgz", + "integrity": "sha512-B5x9j0OgjG+v1dF2DkH34lr+7Gmv0kzX6/V0afF41FkPMMqaQ77pH7CrhWeR22aEeHKaeZVtZ6yFwlxOKPVFyg==", "optional": true, "peer": true }, "@esbuild/linux-ppc64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.18.tgz", - "integrity": "sha512-3dLlQO+b/LnQNxgH4l9rqa2/IwRJVN9u/bK63FhOPB4xqiRqlQAU0qDU3JJuf0BmaH0yytTBdoSBHrb2jqc5qQ==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.19.11.tgz", + "integrity": "sha512-MHrZYLeCG8vXblMetWyttkdVRjQlQUb/oMgBNurVEnhj4YWOr4G5lmBfZjHYQHHN0g6yDmCAQRR8MUHldvvRDA==", "optional": true, "peer": true }, "@esbuild/linux-riscv64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.18.tgz", - "integrity": "sha512-/x7leOyDPjZV3TcsdfrSI107zItVnsX1q2nho7hbbQoKnmoeUWjs+08rKKt4AUXju7+3aRZSsKrJtaRmsdL1xA==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.19.11.tgz", + "integrity": "sha512-f3DY++t94uVg141dozDu4CCUkYW+09rWtaWfnb3bqe4w5NqmZd6nPVBm+qbz7WaHZCoqXqHz5p6CM6qv3qnSSQ==", "optional": true, "peer": true }, "@esbuild/linux-s390x": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.18.tgz", - "integrity": "sha512-cX0I8Q9xQkL/6F5zWdYmVf5JSQt+ZfZD2bJudZrWD+4mnUvoZ3TDDXtDX2mUaq6upMFv9FlfIh4Gfun0tbGzuw==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.19.11.tgz", + "integrity": "sha512-A5xdUoyWJHMMlcSMcPGVLzYzpcY8QP1RtYzX5/bS4dvjBGVxdhuiYyFwp7z74ocV7WDc0n1harxmpq2ePOjI0Q==", "optional": true, "peer": true }, "@esbuild/linux-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.18.tgz", - "integrity": "sha512-66RmRsPlYy4jFl0vG80GcNRdirx4nVWAzJmXkevgphP1qf4dsLQCpSKGM3DUQCojwU1hnepI63gNZdrr02wHUA==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.19.11.tgz", + "integrity": "sha512-grbyMlVCvJSfxFQUndw5mCtWs5LO1gUlwP4CDi4iJBbVpZcqLVT29FxgGuBJGSzyOxotFG4LoO5X+M1350zmPA==", "optional": true, "peer": true }, "@esbuild/netbsd-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.18.tgz", - "integrity": "sha512-95IRY7mI2yrkLlTLb1gpDxdC5WLC5mZDi+kA9dmM5XAGxCME0F8i4bYH4jZreaJ6lIZ0B8hTrweqG1fUyW7jbg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.19.11.tgz", + "integrity": "sha512-13jvrQZJc3P230OhU8xgwUnDeuC/9egsjTkXN49b3GcS5BKvJqZn86aGM8W9pd14Kd+u7HuFBMVtrNGhh6fHEQ==", "optional": true, "peer": true }, "@esbuild/openbsd-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.18.tgz", - "integrity": "sha512-WevVOgcng+8hSZ4Q3BKL3n1xTv5H6Nb53cBrtzzEjDbbnOmucEVcZeGCsCOi9bAOcDYEeBZbD2SJNBxlfP3qiA==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.19.11.tgz", + "integrity": "sha512-ysyOGZuTp6SNKPE11INDUeFVVQFrhcNDVUgSQVDzqsqX38DjhPEPATpid04LCoUr2WXhQTEZ8ct/EgJCUDpyNw==", "optional": true, "peer": true }, "@esbuild/sunos-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.18.tgz", - "integrity": "sha512-Rzf4QfQagnwhQXVBS3BYUlxmEbcV7MY+BH5vfDZekU5eYpcffHSyjU8T0xucKVuOcdCsMo+Ur5wmgQJH2GfNrg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.19.11.tgz", + "integrity": "sha512-Hf+Sad9nVwvtxy4DXCZQqLpgmRTQqyFyhT3bZ4F2XlJCjxGmRFF0Shwn9rzhOYRB61w9VMXUkxlBy56dk9JJiQ==", "optional": true, "peer": true }, "@esbuild/win32-arm64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.18.tgz", - "integrity": "sha512-Kb3Ko/KKaWhjeAm2YoT/cNZaHaD1Yk/pa3FTsmqo9uFh1D1Rfco7BBLIPdDOozrObj2sahslFuAQGvWbgWldAg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.19.11.tgz", + "integrity": "sha512-0P58Sbi0LctOMOQbpEOvOL44Ne0sqbS0XWHMvvrg6NE5jQ1xguCSSw9jQeUk2lfrXYsKDdOe6K+oZiwKPilYPQ==", "optional": true, "peer": true }, "@esbuild/win32-ia32": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.18.tgz", - "integrity": "sha512-0/xUMIdkVHwkvxfbd5+lfG7mHOf2FRrxNbPiKWg9C4fFrB8H0guClmaM3BFiRUYrznVoyxTIyC/Ou2B7QQSwmw==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.19.11.tgz", + "integrity": "sha512-6YOrWS+sDJDmshdBIQU+Uoyh7pQKrdykdefC1avn76ss5c+RN6gut3LZA4E2cH5xUEp5/cA0+YxRaVtRAb0xBg==", "optional": true, "peer": true }, "@esbuild/win32-x64": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.18.tgz", - "integrity": "sha512-qU25Ma1I3NqTSHJUOKi9sAH1/Mzuvlke0ioMJRthLXKm7JiSKVwFghlGbDLOO2sARECGhja4xYfRAZNPAkooYg==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.19.11.tgz", + "integrity": "sha512-vfkhltrjCAb603XaFhqhAF4LGDi2M4OrCRrFusyQ+iTLQ/o60QQXxc9cZC/FFpihBI9N1Grn6SMKVJ4KP7Fuiw==", "optional": true, "peer": true }, "@eslint-community/eslint-utils": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.2.0.tgz", - "integrity": "sha512-gB8T4H4DEfX2IV9zGDJPOBgP1e/DbfCPDTtEqUMckpvzS1OYtva8JdFYBqMwYk7xAQ429WGF/UPqn8uQ//h2vQ==", + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", + "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", "requires": { "eslint-visitor-keys": "^3.3.0" } }, "@eslint-community/regexpp": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.4.0.tgz", - "integrity": "sha512-A9983Q0LnDGdLPjxyXQ00sbV+K+O+ko2Dr+CZigbHWtX9pNfxlaBkMR8X1CztI73zuEyEBXTVjx7CE+/VSwDiQ==" + "version": "4.10.0", + "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", + "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==" }, "@eslint/eslintrc": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.0.2.tgz", - "integrity": "sha512-3W4f5tDUra+pA+FzgugqL2pRimUTDJWKr7BINqOpkZrC0uYI0NIc0/JFgBROCU07HR6GieA5m3/rsPIhDmCXTQ==", + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", + "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", "requires": { "ajv": "^6.12.4", "debug": "^4.3.2", - "espree": "^9.5.1", + "espree": "^9.6.0", "globals": "^13.19.0", "ignore": "^5.2.0", "import-fresh": "^3.2.1", @@ -7400,64 +7803,64 @@ } }, "@eslint/js": { - "version": "8.39.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.39.0.tgz", - "integrity": "sha512-kf9RB0Fg7NZfap83B3QOqOGg9QmD9yBudqQXzzOtn3i4y7ZUXe5ONeW34Gwi+TxhH4mvj72R1Zc300KUMa9Bng==" + "version": "8.56.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.56.0.tgz", + "integrity": "sha512-gMsVel9D7f2HLkBma9VbtzZRehRogVRfbr++f06nL2vnCGCNlzOD+/MUov/F4p8myyAHspEhVobgjpX64q5m6A==" }, "@file-services/memory": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/memory/-/memory-7.2.5.tgz", - "integrity": "sha512-SQ3QNcPZQ0w6jGCqcr4pgY2z80nCuGfNJkQ/ETEm3+iA0js6j/RZgOsXYL3W1VW9jIr7d+qFGLXHek3cqUuuBw==", + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/memory/-/memory-8.3.3.tgz", + "integrity": "sha512-WBgpmTvO2Bkl9zD0Vdyt4hjScZ5p5ytqcpG9y7pMAZITSw9Slv/pjK0jKkJMg4reb2nHjzEEgYzggfd2FibDsA==", "requires": { - "@file-services/path": "^7.2.5", - "@file-services/types": "^7.2.5", - "@file-services/utils": "^7.2.5" + "@file-services/path": "^8.3.3", + "@file-services/types": "^8.3.3", + "@file-services/utils": "^8.3.3" } }, "@file-services/node": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/node/-/node-7.2.5.tgz", - "integrity": "sha512-aujaIg8f0kOKGlW1LBTM+dk8MrhMp3sQSRoZ1lJyeZOlHpOcfL/TrncW34Co0S5sxd3FyOptJo+kBlyfsPVLoQ==", + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/node/-/node-8.3.3.tgz", + "integrity": "sha512-gZH5C4QRs4DurIxu/xa44zfqELHYtxjyQAx9NwDD7eNjst1jVbSOKtWD6beDXw88OI/6KzpxnbOnhwksQphJ6g==", "requires": { - "@file-services/types": "^7.2.5", - "@file-services/utils": "^7.2.5" + "@file-services/types": "^8.3.3", + "@file-services/utils": "^8.3.3" } }, "@file-services/path": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/path/-/path-7.2.5.tgz", - "integrity": "sha512-ovs34aWZ3TL0WotKKi/dywmNu5ndiRh7K/AvvEoWmXuilZFFbFknQG2/vwNLm4A4phCqIbEvy0zNToL6tU7CBA==", + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/path/-/path-8.3.3.tgz", + "integrity": "sha512-zM2/I4uIA+Hq8fC0XhBfo7ZC3t/shX3gjwl3z+lmtHxtNfxProf6hsmR1VI0qLDEFcIog7tB89HOR7H5DWj+qQ==", "requires": { - "@file-services/types": "^7.2.5" + "@file-services/types": "^8.3.3" } }, "@file-services/types": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/types/-/types-7.2.5.tgz", - "integrity": "sha512-+ED491/MHemP0Kg6AjWmrUGz7BMTE0eP7rTWt6csUPkW6valBsVpZhdAm+5N4d0xkhlcRwIyZ5wRSq4lReWIKg==" + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/types/-/types-8.3.3.tgz", + "integrity": "sha512-b6IM6MNZ6HKm5GicSKI61Rj1UZy87UtBCUvBiqT+w16biEYxeV7fBCj6gCeu8fWdPdfXgUK2QFKAB0RST+D4GQ==" }, "@file-services/typescript": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/typescript/-/typescript-7.2.5.tgz", - "integrity": "sha512-uSpLPShjGxbiR7097oa7FPF6NGecJYgG9JRWoAFbQ/N6OppoMk4eEjaIO/lfDo8BMOihiUfk6Tzj92K63FSXUQ==", + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/typescript/-/typescript-8.3.3.tgz", + "integrity": "sha512-NHT1AG0sC7sf695ZYg3iCjSlD4lVKL81og2/W+ilreAqRWWEJ5R4BxuFtrB3H2D7S6PChxooPQkrYhrnB5hbZg==", "requires": { - "@file-services/types": "^7.2.5" + "@file-services/types": "^8.3.3" } }, "@file-services/utils": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/@file-services/utils/-/utils-7.2.5.tgz", - "integrity": "sha512-ta3Um+scOxT+eNg+/wrNOF9Fgt2ila5temox35p5hNQUvRcJDRiqrfSqvKJhN/cwQu6yseJtkZiXX4sezkBKng==", + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/@file-services/utils/-/utils-8.3.3.tgz", + "integrity": "sha512-mCVe/x8cqvMxR/JE1SdPxxcReXvinYhrGgS3Ub33pHKmYMvRLPqt7tmxJV6zV8hjptx/CuxG6+yh9iSQo5sRvA==", "requires": { - "@file-services/types": "^7.2.5" + "@file-services/types": "^8.3.3" } }, "@humanwhocodes/config-array": { - "version": "0.11.8", - "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.8.tgz", - "integrity": "sha512-UybHIJzJnR5Qc/MsD9Kr+RpO2h+/P1GhOwdiLPXK5TWk5sgTdu88bTD9UP+CKbPPh5Rni1u0GjAdYQLemG8g+g==", + "version": "0.11.13", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.13.tgz", + "integrity": "sha512-JSBDMiDKSzQVngfRjOdFXgFfklaXI4K9nLF49Auh21lmBWRLIK3+xTErTWD4KU54pb6coM6ESE7Awz/FNU3zgQ==", "requires": { - "@humanwhocodes/object-schema": "^1.2.1", + "@humanwhocodes/object-schema": "^2.0.1", "debug": "^4.1.1", "minimatch": "^3.0.5" } @@ -7468,9 +7871,67 @@ "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==" }, "@humanwhocodes/object-schema": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", - "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==" + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.1.tgz", + "integrity": "sha512-dvuCeX5fC9dXgJn9t+X5atfmgQAzUOWqS1254Gh0m6i8wKd10ebXkfNKiRK+1GWi/yTvvLDHpoxLr0xxxeslWw==" + }, + "@isaacs/cliui": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", + "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", + "requires": { + "string-width": "^5.1.2", + "string-width-cjs": "npm:string-width@^4.2.0", + "strip-ansi": "^7.0.1", + "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", + "wrap-ansi": "^8.1.0", + "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", + "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==" + }, + "ansi-styles": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", + "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==" + }, + "emoji-regex": { + "version": "9.2.2", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", + "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==" + }, + "string-width": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", + "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", + "requires": { + "eastasianwidth": "^0.2.0", + "emoji-regex": "^9.2.2", + "strip-ansi": "^7.0.1" + } + }, + "strip-ansi": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", + "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "requires": { + "ansi-regex": "^6.0.1" + } + }, + "wrap-ansi": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", + "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", + "requires": { + "ansi-styles": "^6.1.0", + "string-width": "^5.0.1", + "strip-ansi": "^7.0.1" + } + } + } }, "@istanbuljs/schema": { "version": "0.1.3", @@ -7479,9 +7940,9 @@ "dev": true }, "@jridgewell/gen-mapping": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", - "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", + "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", "requires": { "@jridgewell/set-array": "^1.0.1", "@jridgewell/sourcemap-codec": "^1.4.10", @@ -7489,9 +7950,9 @@ } }, "@jridgewell/resolve-uri": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", - "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==" + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz", + "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==" }, "@jridgewell/set-array": { "version": "1.1.2", @@ -7499,26 +7960,26 @@ "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==" }, "@jridgewell/source-map": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.2.tgz", - "integrity": "sha512-m7O9o2uR8k2ObDysZYzdfhb08VuEml5oWGiosa1VdaPZ/A6QyPkAJuwN0Q1lhULOf6B7MtQmHENS743hWtCrgw==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.5.tgz", + "integrity": "sha512-UTYAUj/wviwdsMfzoSJspJxbkH5o1snzwX0//0ENX1u/55kkZZkcTZP6u9bwKGkv+dkk9at4m1Cpt0uY80kcpQ==", "requires": { "@jridgewell/gen-mapping": "^0.3.0", "@jridgewell/trace-mapping": "^0.3.9" } }, "@jridgewell/sourcemap-codec": { - "version": "1.4.14", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", - "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==" + "version": "1.4.15", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", + "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==" }, "@jridgewell/trace-mapping": { - "version": "0.3.17", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz", - "integrity": "sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g==", + "version": "0.3.20", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.20.tgz", + "integrity": "sha512-R8LcPeWZol2zR8mmH3JeKQ6QRCFb7XgUhV9ZlGhHLGyg4wpPiPZNQOOWhFZhxKw8u//yTbNGI42Bx/3paXEQ+Q==", "requires": { - "@jridgewell/resolve-uri": "3.1.0", - "@jridgewell/sourcemap-codec": "1.4.14" + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" } }, "@nodelib/fs.scandir": { @@ -7544,6 +8005,11 @@ "fastq": "^1.6.0" } }, + "@one-ini/wasm": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@one-ini/wasm/-/wasm-0.1.1.tgz", + "integrity": "sha512-XuySG1E38YScSJoMlqovLru4KTUNSjgVTIjyh7qMX6aNN5HY5Ct5LhRJdxO79JtTzKfzV/bnWpz+zquYrISsvw==" + }, "@pkgjs/parseargs": { "version": "0.11.0", "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", @@ -7551,16 +8017,16 @@ "optional": true }, "@rollup/plugin-html": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/@rollup/plugin-html/-/plugin-html-1.0.2.tgz", - "integrity": "sha512-jGqb45BPj5kwvb/bq1jIzUDLebsm1xmfnY1rwgTIZyjpsMyMKLuQO27n4z5qv6kZmxqxh+CBRD7d1rjAu85Uzg==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/@rollup/plugin-html/-/plugin-html-1.0.3.tgz", + "integrity": "sha512-bbjQciNXitHX+Bgk0xsW3/0wFWih/356/r7/kvmdz4wzWhAU/a0zYBWTczihrlzz/6Qpw/kZ0yXqOJwsETgg7A==", "dev": true, "requires": {} }, "@rollup/plugin-node-resolve": { - "version": "15.0.2", - "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-15.0.2.tgz", - "integrity": "sha512-Y35fRGUjC3FaurG722uhUuG8YHOJRJQbI6/CkbRkdPotSpDj9NtIN85z1zrcyDcCQIW4qp5mgG72U+gJ0TAFEg==", + "version": "15.2.3", + "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-15.2.3.tgz", + "integrity": "sha512-j/lym8nf5E21LwBT4Df1VD6hRO2L2iwUeUmP7litikRsVp1H6NWx20NEp0Y7su+7XGc476GnXXc4kFeZNGmaSQ==", "dev": true, "requires": { "@rollup/pluginutils": "^5.0.1", @@ -7572,9 +8038,9 @@ } }, "@rollup/pluginutils": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.0.2.tgz", - "integrity": "sha512-pTd9rIsP92h+B6wWwFbW8RkZv4hiR/xKsqre4SIuAOaOEQRxi0lqLke9k2/7WegC85GgUs9pjmOjCUi3In4vwA==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.1.0.tgz", + "integrity": "sha512-XTIWOPPcpvyKI6L1NHo0lFlCyznUEyPmPY1mc3KpPVDYulHSTvyeLNVW00QTLIAFNhR3kYnJTQHeGqU4M3n09g==", "dev": true, "requires": { "@types/estree": "^1.0.0", @@ -7582,54 +8048,138 @@ "picomatch": "^2.3.1" } }, + "@rollup/rollup-android-arm-eabi": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.9.2.tgz", + "integrity": "sha512-RKzxFxBHq9ysZ83fn8Iduv3A283K7zPPYuhL/z9CQuyFrjwpErJx0h4aeb/bnJ+q29GRLgJpY66ceQ/Wcsn3wA==", + "optional": true + }, + "@rollup/rollup-android-arm64": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.9.2.tgz", + "integrity": "sha512-yZ+MUbnwf3SHNWQKJyWh88ii2HbuHCFQnAYTeeO1Nb8SyEiWASEi5dQUygt3ClHWtA9My9RQAYkjvrsZ0WK8Xg==", + "optional": true + }, + "@rollup/rollup-darwin-arm64": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.9.2.tgz", + "integrity": "sha512-vqJ/pAUh95FLc/G/3+xPqlSBgilPnauVf2EXOQCZzhZJCXDXt/5A8mH/OzU6iWhb3CNk5hPJrh8pqJUPldN5zw==", + "optional": true + }, + "@rollup/rollup-darwin-x64": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.9.2.tgz", + "integrity": "sha512-otPHsN5LlvedOprd3SdfrRNhOahhVBwJpepVKUN58L0RnC29vOAej1vMEaVU6DadnpjivVsNTM5eNt0CcwTahw==", + "optional": true + }, + "@rollup/rollup-linux-arm-gnueabihf": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.9.2.tgz", + "integrity": "sha512-ewG5yJSp+zYKBYQLbd1CUA7b1lSfIdo9zJShNTyc2ZP1rcPrqyZcNlsHgs7v1zhgfdS+kW0p5frc0aVqhZCiYQ==", + "optional": true + }, + "@rollup/rollup-linux-arm64-gnu": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.9.2.tgz", + "integrity": "sha512-pL6QtV26W52aCWTG1IuFV3FMPL1m4wbsRG+qijIvgFO/VBsiXJjDPE/uiMdHBAO6YcpV4KvpKtd0v3WFbaxBtg==", + "optional": true + }, + "@rollup/rollup-linux-arm64-musl": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.9.2.tgz", + "integrity": "sha512-On+cc5EpOaTwPSNetHXBuqylDW+765G/oqB9xGmWU3npEhCh8xu0xqHGUA+4xwZLqBbIZNcBlKSIYfkBm6ko7g==", + "optional": true + }, + "@rollup/rollup-linux-riscv64-gnu": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.9.2.tgz", + "integrity": "sha512-Wnx/IVMSZ31D/cO9HSsU46FjrPWHqtdF8+0eyZ1zIB5a6hXaZXghUKpRrC4D5DcRTZOjml2oBhXoqfGYyXKipw==", + "optional": true + }, + "@rollup/rollup-linux-x64-gnu": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.9.2.tgz", + "integrity": "sha512-ym5x1cj4mUAMBummxxRkI4pG5Vht1QMsJexwGP8547TZ0sox9fCLDHw9KCH9c1FO5d9GopvkaJsBIOkTKxksdw==", + "optional": true + }, + "@rollup/rollup-linux-x64-musl": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.9.2.tgz", + "integrity": "sha512-m0hYELHGXdYx64D6IDDg/1vOJEaiV8f1G/iO+tejvRCJNSwK4jJ15e38JQy5Q6dGkn1M/9KcyEOwqmlZ2kqaZg==", + "optional": true + }, + "@rollup/rollup-win32-arm64-msvc": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.9.2.tgz", + "integrity": "sha512-x1CWburlbN5JjG+juenuNa4KdedBdXLjZMp56nHFSHTOsb/MI2DYiGzLtRGHNMyydPGffGId+VgjOMrcltOksA==", + "optional": true + }, + "@rollup/rollup-win32-ia32-msvc": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.9.2.tgz", + "integrity": "sha512-VVzCB5yXR1QlfsH1Xw1zdzQ4Pxuzv+CPr5qpElpKhVxlxD3CRdfubAG9mJROl6/dmj5gVYDDWk8sC+j9BI9/kQ==", + "optional": true + }, + "@rollup/rollup-win32-x64-msvc": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.9.2.tgz", + "integrity": "sha512-SYRedJi+mweatroB+6TTnJYLts0L0bosg531xnQWtklOI6dezEagx4Q0qDyvRdK+qgdA3YZpjjGuPFtxBmddBA==", + "optional": true + }, "@stylable/build-tools": { "version": "file:packages/build-tools", "requires": { - "@stylable/core": "^5.11.0", + "@stylable/core": "^5.17.0", "find-config": "^1.0.0" } }, "@stylable/cli": { "version": "file:packages/cli", "requires": { - "@file-services/node": "^7.2.5", - "@file-services/types": "^7.2.5", - "@stylable/build-tools": "^5.11.0", - "@stylable/code-formatter": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", + "@file-services/node": "^8.3.3", + "@file-services/types": "^8.3.3", + "@stylable/build-tools": "^5.17.0", + "@stylable/code-formatter": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", "@wixc3/resolve-directory-context": "^3.0.5", - "decache": "^4.6.1", + "decache": "^4.6.2", "lodash.camelcase": "^4.3.0", "lodash.upperfirst": "^4.3.1", "mime": "^3.0.0", "yargs": "^17.7.2" + }, + "dependencies": { + "mime": { + "version": "3.0.0" + } } }, "@stylable/code-formatter": { "version": "file:packages/code-formatter", "requires": { - "@stylable/core": "^5.11.0", - "@tokey/css-value-parser": "^0.1.2", - "js-beautify": "^1.14.7", - "postcss": "^8.4.23" + "@stylable/core": "^5.17.0", + "@tokey/css-value-parser": "^0.1.4", + "js-beautify": "^1.14.11", + "postcss": "^8.4.32" } }, "@stylable/core": { "version": "file:packages/core", "requires": { - "@tokey/css-selector-parser": "^0.6.1", + "@tokey/css-selector-parser": "^0.6.2", + "@tokey/css-value-parser": "^0.1.4", "@tokey/imports-parser": "^1.0.0", "balanced-match": "^2.0.0", "css-selector-tokenizer": "^0.8.0", "cssesc": "^3.0.0", - "enhanced-resolve": "^5.13.0", + "enhanced-resolve": "^5.15.0", "is-vendor-prefixed": "^4.0.0", "lodash.clonedeep": "^4.5.0", "lodash.clonedeepwith": "^4.5.0", - "postcss": "^8.4.23", + "postcss": "^8.4.32", "postcss-js": "^4.0.1", "postcss-nested": "^6.0.1", "postcss-safe-parser": "^6.0.0", @@ -7637,140 +8187,140 @@ }, "dependencies": { "balanced-match": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-2.0.0.tgz", - "integrity": "sha512-1ugUSr8BHXRnK23KfuYS+gVMC3LB8QGH9W1iGtDPsNWoQbgtXSExkBu2aDR4epiGWZOjZsj6lDl/N/AqqTC3UA==" + "version": "2.0.0" } } }, "@stylable/core-test-kit": { "version": "file:packages/core-test-kit", "requires": { - "@file-services/memory": "^7.2.5", - "@stylable/core": "^5.11.0", - "chai": "^4.3.7", + "@file-services/memory": "^8.3.3", + "@stylable/core": "^5.17.0", + "chai": "^4.3.10", "flat": "^5.0.2", - "postcss": "^8.4.23" + "postcss": "^8.4.32" } }, "@stylable/custom-value": { "version": "file:packages/custom-value", "requires": { - "@stylable/core": "^5.11.0" + "@stylable/core": "^5.17.0" } }, "@stylable/dom-test-kit": { "version": "file:packages/dom-test-kit", "requires": { - "@stylable/core": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "@tokey/css-selector-parser": "^0.6.1" + "@stylable/core": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "@tokey/css-selector-parser": "^0.6.2" } }, "@stylable/e2e-test-kit": { "version": "file:packages/e2e-test-kit", "requires": { - "@stylable/runtime": "^5.11.0", + "@stylable/runtime": "^5.17.0", "node-eval": "^2.0.0", - "playwright-core": "^1.33.0", - "rimraf": "^5.0.0" + "playwright-core": "^1.40.1", + "rimraf": "^5.0.5" } }, "@stylable/esbuild": { "version": "file:packages/esbuild", "requires": { - "@stylable/build-tools": "^5.11.0", - "@stylable/cli": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "decache": "^4.6.1" + "@stylable/build-tools": "^5.17.0", + "@stylable/cli": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "decache": "^4.6.2" } }, "@stylable/experimental-loader": { "version": "file:packages/experimental-loader", "requires": { - "@stylable/core": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "css-loader": "^6.7.3", - "decache": "^4.6.1", + "@stylable/core": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "css-loader": "^6.8.1", + "decache": "^4.6.2", "loader-utils": "^3.2.1" }, "dependencies": { "loader-utils": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-3.2.1.tgz", - "integrity": "sha512-ZvFw1KWS3GVyYBYb7qkmRM/WwL2TQQBxgCK62rlvm4WpVQ23Nb4tYjApUlfjrEGvOs7KHEsmyUn75OHZrJMWPw==" + "version": "3.2.1" } } }, "@stylable/jest": { "version": "file:packages/jest", "requires": { - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/runtime": "^5.11.0" + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/runtime": "^5.17.0" } }, "@stylable/language-service": { "version": "file:packages/language-service", "requires": { - "@file-services/types": "^7.2.5", - "@file-services/typescript": "^7.2.5", - "@stylable/code-formatter": "^5.11.0", - "@stylable/core": "^5.11.0", - "@tokey/core": "^1.3.0", - "@tokey/css-selector-parser": "^0.6.1", - "@tokey/css-value-parser": "^0.1.2", + "@file-services/types": "^8.3.3", + "@file-services/typescript": "^8.3.3", + "@stylable/code-formatter": "^5.17.0", + "@stylable/core": "^5.17.0", + "@tokey/core": "^1.4.0", + "@tokey/css-selector-parser": "^0.6.2", + "@tokey/css-value-parser": "^0.1.4", "css-selector-tokenizer": "^0.8.0", - "postcss": "^8.4.23", + "postcss": "^8.4.32", "postcss-value-parser": "^4.2.0", - "vscode-css-languageservice": "^6.2.5", - "vscode-languageserver": "^8.1.0", - "vscode-languageserver-textdocument": "^1.0.8", - "vscode-uri": "^3.0.7" + "vscode-css-languageservice": "^6.2.11", + "vscode-languageserver": "^9.0.1", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-uri": "^3.0.8" } }, "@stylable/module-utils": { "version": "file:packages/module-utils", "requires": { - "@stylable/core": "^5.11.0", - "@tokey/core": "^1.3.0", + "@stylable/core": "^5.17.0", + "@tokey/core": "^1.4.0", "vlq": "^2.0.4" } }, "@stylable/node": { "version": "file:packages/node", "requires": { - "@stylable/build-tools": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", + "@stylable/build-tools": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", "find-config": "^1.0.0" } }, "@stylable/optimizer": { "version": "file:packages/optimizer", "requires": { - "@stylable/core": "^5.11.0", - "@tokey/css-selector-parser": "^0.6.1", + "@stylable/core": "^5.17.0", + "@tokey/css-selector-parser": "^0.6.2", "csso": "^5.0.5", - "postcss": "^8.4.23" + "postcss": "^8.4.32" } }, "@stylable/rollup-plugin": { "version": "file:packages/rollup-plugin", "requires": { - "@stylable/build-tools": "^5.11.0", - "@stylable/cli": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "decache": "^4.6.1", + "@stylable/build-tools": "^5.17.0", + "@stylable/cli": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "decache": "^4.6.2", "mime": "^3.0.0" + }, + "dependencies": { + "mime": { + "version": "3.0.0" + } } }, "@stylable/runtime": { @@ -7779,8 +8329,8 @@ "@stylable/schema-extract": { "version": "file:packages/schema-extract", "requires": { - "@stylable/core": "^5.11.0", - "jest-docblock": "^29.4.3" + "@stylable/core": "^5.17.0", + "jest-docblock": "^29.7.0" } }, "@stylable/uni-driver": { @@ -7802,10 +8352,10 @@ "@stylable/webpack-extensions": { "version": "file:packages/webpack-extensions", "requires": { - "@stylable/core": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/webpack-plugin": "^5.11.0", - "@tokey/css-selector-parser": "^0.6.1", + "@stylable/core": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/webpack-plugin": "^5.17.0", + "@tokey/css-selector-parser": "^0.6.2", "find-config": "^1.0.0", "lodash.clonedeep": "^4.5.0" } @@ -7813,37 +8363,37 @@ "@stylable/webpack-plugin": { "version": "file:packages/webpack-plugin", "requires": { - "@stylable/build-tools": "^5.11.0", - "@stylable/cli": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "decache": "^4.6.1", + "@stylable/build-tools": "^5.17.0", + "@stylable/cli": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "decache": "^4.6.2", "lodash.clonedeep": "^4.5.0", - "postcss": "^8.4.23" + "postcss": "^8.4.32" } }, "@tokey/core": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/@tokey/core/-/core-1.3.0.tgz", - "integrity": "sha512-qeJ181Jsp+fIGJRUlYPtIhm86WyRF8P7LiW0mJ2xCTWNmPHKHmY5a8Yzi0EXWTLGTA3HBFK/1pw/S83uatmWcQ==" + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@tokey/core/-/core-1.4.0.tgz", + "integrity": "sha512-U+xr5ue/iKQJsOP+rWNS0U6M9kUQn9L7bgsa7jnYQwSlHjyeZO4e4ngRmbcf/bfB0IpxWGAlhdpwgwI7vTFftg==" }, "@tokey/css-selector-parser": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/@tokey/css-selector-parser/-/css-selector-parser-0.6.1.tgz", - "integrity": "sha512-nyAtoXUvlNqzdArJQLJ1B0zPH4bqCtmKzF4PNtrMNFn6SljPyKn2cWS/A2sHjJuR197opBgA5NjmnZslsRqdmw==", + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/@tokey/css-selector-parser/-/css-selector-parser-0.6.2.tgz", + "integrity": "sha512-4nD20RbiLitUP7MmDCJ5+PMKe4bSaNs7glEGKK7I9gmd2iYETbjh7OS8PWZ5vBXfr9LzaI++ssQFlxwPdh3MXQ==", "requires": { - "@tokey/core": "^1.3.0" + "@tokey/core": "^1.4.0" } }, "@tokey/css-value-parser": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/@tokey/css-value-parser/-/css-value-parser-0.1.2.tgz", - "integrity": "sha512-wrNVsMoLaUIDIzlQZrYs6qIRXMoekYfYLu7bmV1kpejUSB4SxJyPrqI/vjGTqyxELFm3WUGUgw/o6sEmWbYkrQ==", + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/@tokey/css-value-parser/-/css-value-parser-0.1.4.tgz", + "integrity": "sha512-zHkHmNGnzVI31D3rkpXAh9KioMJd8Fwpe0Y6rwh87kTjUPzhpYSzy6ZziAQv2Ol1GqExrLj5ips9zlrCxeeJWw==", "requires": { - "@tokey/core": "^1.3.0" + "@tokey/core": "^1.4.0" } }, "@tokey/imports-parser": { @@ -7855,86 +8405,86 @@ } }, "@types/balanced-match": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/@types/balanced-match/-/balanced-match-1.0.2.tgz", - "integrity": "sha512-KgomuqUNYgN+Sibk22j7HB6vo8gziGz/k3Y8RkauF2duMZfMeIkyUKARef2eIIQuXGrkbIvcOfY5DNF/nQrDZQ==", + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@types/balanced-match/-/balanced-match-3.0.2.tgz", + "integrity": "sha512-It1j6doJHkoGoxfOj3c7sHVHQXYMHo3c0kpcnPhEO4KfitNE5SqiSGKV0Hx5/cwyYKJfEhin0tZYBmqpjEcavw==", "dev": true }, "@types/chai": { - "version": "4.3.5", - "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.5.tgz", - "integrity": "sha512-mEo1sAde+UCE6b2hxn332f1g1E8WfYRu6p5SvTKr2ZKC1f7gFJXk4h5PyGP9Dt6gCaG8y8XhwnXWC6Iy2cmBng==", + "version": "4.3.11", + "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.11.tgz", + "integrity": "sha512-qQR1dr2rGIHYlJulmr8Ioq3De0Le9E4MJ5AiaeAETJJpndT1uUNHsGFK3L/UIu+rbkQSdj8J/w2bCsBZc/Y5fQ==", "dev": true }, "@types/chai-subset": { - "version": "1.3.3", - "resolved": "https://registry.npmjs.org/@types/chai-subset/-/chai-subset-1.3.3.tgz", - "integrity": "sha512-frBecisrNGz+F4T6bcc+NLeolfiojh5FxW2klu669+8BARtyQv2C/GkNW6FUodVe4BroGMP/wER/YDGc7rEllw==", + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/@types/chai-subset/-/chai-subset-1.3.5.tgz", + "integrity": "sha512-c2mPnw+xHtXDoHmdtcCXGwyLMiauiAyxWMzhGpqHC4nqI/Y5G2XhTampslK2rb59kpcuHon03UH8W6iYUzw88A==", "dev": true, "requires": { "@types/chai": "*" } }, "@types/css-selector-tokenizer": { - "version": "0.7.1", - "resolved": "https://registry.npmjs.org/@types/css-selector-tokenizer/-/css-selector-tokenizer-0.7.1.tgz", - "integrity": "sha512-DdGXO+tC5ZWFDIytbNOa55lUoEXXnRJqnEUJ3P5DE+TCEEoAcpKYq48klKRLGS9Uo22Dk1s0aTt9nAUDK7W8tg==", + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/@types/css-selector-tokenizer/-/css-selector-tokenizer-0.7.4.tgz", + "integrity": "sha512-X/on8gnLmrSHASIouMtbsctR1Bwgf+ceqbwALnsLjK1WbQUpCWLVgoNCMM39D1T9IdmAGL5teQWx6W4gaIHrKQ==", "dev": true }, "@types/css-tree": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/@types/css-tree/-/css-tree-2.0.0.tgz", - "integrity": "sha512-mY2sXRLBnUPMYw6mkOT+6dABeaNxAEKZz6scE9kQPNJx8fKe1fOsm8Honl7+xFYe6TKX8WNk2+7oMp2vBArJ9Q==", + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/@types/css-tree/-/css-tree-2.3.4.tgz", + "integrity": "sha512-wdxxe7zEpOXfy5C3FmwinAIc/6p6du/wOKMGZf07JHuHHRIvLtLq8h66zi3Yn7PCyswxbp3Ujx9h+vSuMvfN/w==", "dev": true }, "@types/cssesc": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@types/cssesc/-/cssesc-3.0.0.tgz", - "integrity": "sha512-4mBnOrTpVKn+tYzlnMO7cwDkDa6wlQ2bBXW+79/6ahMd36GF216kxWYxgz+S4d5Ev1ByFbnQbPGxV4P5BSL8MA==", + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@types/cssesc/-/cssesc-3.0.2.tgz", + "integrity": "sha512-Qii6nTRktvtI380EloxH/V7MwgrYxkPgBI+NklUjQuhzgAd1AqT3QDJd+eD+0doRADgfwvtagLRo7JFa7aMHXg==", "dev": true }, "@types/csso": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/@types/csso/-/csso-5.0.0.tgz", - "integrity": "sha512-EMrCTGpXRUsbFfZBzn2jcW6Sqg8kxWXkJcpvAGYSEzFqAJ2THDJSwiMeS2fPUw+0p6RQNT/n8F/skEc9hUBc0g==", + "version": "5.0.4", + "resolved": "https://registry.npmjs.org/@types/csso/-/csso-5.0.4.tgz", + "integrity": "sha512-W/FsRkm/9c04x9ON+bj+HQ0cSgNkG1LvcfuBCpkP7cpikM7+RkrNFLGtiofb++xBG6KGMUycLoDbi9/K621ZCw==", "dev": true, "requires": { "@types/css-tree": "*" } }, "@types/eslint": { - "version": "8.4.10", - "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.4.10.tgz", - "integrity": "sha512-Sl/HOqN8NKPmhWo2VBEPm0nvHnu2LL3v9vKo8MEq0EtbJ4eVzGPl41VNPvn5E1i5poMk4/XD8UriLHpJvEP/Nw==", + "version": "8.56.0", + "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.56.0.tgz", + "integrity": "sha512-FlsN0p4FhuYRjIxpbdXovvHQhtlG05O1GG/RNWvdAxTboR438IOTwmrY/vLA+Xfgg06BTkP045M3vpFwTMv1dg==", "requires": { "@types/estree": "*", "@types/json-schema": "*" } }, "@types/eslint-scope": { - "version": "3.7.4", - "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.4.tgz", - "integrity": "sha512-9K4zoImiZc3HlIp6AVUDE4CWYx22a+lhSZMYNpbjW04+YF0KWj4pJXnEMjdnFTiQibFFmElcsasJXDbdI/EPhA==", + "version": "3.7.7", + "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.7.tgz", + "integrity": "sha512-MzMFlSLBqNF2gcHWO0G1vP/YQyfvrxZ0bF+u7mzUdZ1/xK4A4sru+nraZz5i3iEIk1l1uyicaDVTB4QbbEkAYg==", "requires": { "@types/eslint": "*", "@types/estree": "*" } }, "@types/estree": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.0.tgz", - "integrity": "sha512-WulqXMDUTYAXCjZnk6JtIHPigp55cVtDgDrO2gHRwhyJto21+1zbVCtOYB2L1F9w4qCQ0rOGWBnBe0FNTiEJIQ==" + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", + "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==" }, "@types/find-config": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/@types/find-config/-/find-config-1.0.1.tgz", - "integrity": "sha512-H4DFIQMwxCKRgVWMSqALg6aowTOgZi5D4pSPBBuOQFJLRwfNZaByhC9+s870CZgTRJoyVg5J+iesdF5uvnJ0mA==", + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/@types/find-config/-/find-config-1.0.4.tgz", + "integrity": "sha512-BCXaKgzHK7KnfCQBRQBWGTA+QajOE9uFolXPt+9EktiiMS56D8oXF2ZCh9eCxuEyfqDmX/mYIcmWg9j9f659eg==", "dev": true }, "@types/flat": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@types/flat/-/flat-5.0.2.tgz", - "integrity": "sha512-3zsplnP2djeps5P9OyarTxwRpMLoe5Ash8aL9iprw0JxB+FAHjY+ifn4yZUuW4/9hqtnmor6uvjSRzJhiVbrEQ==", + "version": "5.0.5", + "resolved": "https://registry.npmjs.org/@types/flat/-/flat-5.0.5.tgz", + "integrity": "sha512-nPLljZQKSnac53KDUDzuzdRfGI0TDb5qPrb+SrQyN3MtdQrOnGsKniHN1iYZsJEBIVQve94Y6gNz22sgISZq+Q==", "dev": true }, "@types/html-minifier-terser": { @@ -7944,118 +8494,118 @@ "dev": true }, "@types/istanbul-lib-coverage": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", - "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz", + "integrity": "sha512-2QF/t/auWm0lsy8XtKVPG19v3sSOQlJe/YHZgfjb/KBBHOGSV+J2q/S671rcq9uTBrLAXmZpqJiaQbMT+zNU1w==", "dev": true }, "@types/js-beautify": { - "version": "1.13.3", - "resolved": "https://registry.npmjs.org/@types/js-beautify/-/js-beautify-1.13.3.tgz", - "integrity": "sha512-ucIPw5gmNyvRKi6mpeojlqp+T+6ZBJeU+kqMDnIEDlijEU4QhLTon90sZ3cz9HZr+QTwXILjNsMZImzA7+zuJA==", + "version": "1.14.3", + "resolved": "https://registry.npmjs.org/@types/js-beautify/-/js-beautify-1.14.3.tgz", + "integrity": "sha512-FMbQHz+qd9DoGvgLHxeqqVPaNRffpIu5ZjozwV8hf9JAGpIOzuAf4wGbRSo8LNITHqGjmmVjaMggTT5P4v4IHg==", "dev": true }, "@types/json-schema": { - "version": "7.0.11", - "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", - "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==" + "version": "7.0.15", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", + "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==" }, "@types/lodash": { - "version": "4.14.191", - "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.191.tgz", - "integrity": "sha512-BdZ5BCCvho3EIXw6wUCXHe7rS53AIDPLE+JzwgT+OsJk53oBfbSmZZ7CX4VaRoN78N+TJpFi9QPlfIVNmJYWxQ==", + "version": "4.14.202", + "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.202.tgz", + "integrity": "sha512-OvlIYQK9tNneDlS0VN54LLd5uiPCBOp7gS5Z0f1mjoJYBrtStzgmJBxONW3U6OZqdtNzZPmn9BS/7WI7BFFcFQ==", "dev": true }, "@types/lodash.camelcase": { - "version": "4.3.7", - "resolved": "https://registry.npmjs.org/@types/lodash.camelcase/-/lodash.camelcase-4.3.7.tgz", - "integrity": "sha512-Nfi6jpo9vuEOSIJP+mpbTezKyEt75DQlbwjiDvs/JctWkbnHDoyQo5lWqdvgNiJmVUjcmkfvlrvSEgJYvurOKg==", + "version": "4.3.9", + "resolved": "https://registry.npmjs.org/@types/lodash.camelcase/-/lodash.camelcase-4.3.9.tgz", + "integrity": "sha512-ys9/hGBfsKxzmFI8hckII40V0ASQ83UM2pxfQRghHAwekhH4/jWtjz/3/9YDy7ZpUd/H0k2STSqmPR28dnj7Zg==", "dev": true, "requires": { "@types/lodash": "*" } }, "@types/lodash.clonedeep": { - "version": "4.5.7", - "resolved": "https://registry.npmjs.org/@types/lodash.clonedeep/-/lodash.clonedeep-4.5.7.tgz", - "integrity": "sha512-ccNqkPptFIXrpVqUECi60/DFxjNKsfoQxSQsgcBJCX/fuX1wgyQieojkcWH/KpE3xzLoWN/2k+ZeGqIN3paSvw==", + "version": "4.5.9", + "resolved": "https://registry.npmjs.org/@types/lodash.clonedeep/-/lodash.clonedeep-4.5.9.tgz", + "integrity": "sha512-19429mWC+FyaAhOLzsS8kZUsI+/GmBAQ0HFiCPsKGU+7pBXOQWhyrY6xNNDwUSX8SMZMJvuFVMF9O5dQOlQK9Q==", "dev": true, "requires": { "@types/lodash": "*" } }, "@types/lodash.clonedeepwith": { - "version": "4.5.7", - "resolved": "https://registry.npmjs.org/@types/lodash.clonedeepwith/-/lodash.clonedeepwith-4.5.7.tgz", - "integrity": "sha512-QPCMby+Glpme6mv/ds4YUSP06bD0FdRVzYF9NjfAP/cKFyjj3BV8bDodx1Npqf/M979WNds1r6K1I7cFwBTmWA==", + "version": "4.5.9", + "resolved": "https://registry.npmjs.org/@types/lodash.clonedeepwith/-/lodash.clonedeepwith-4.5.9.tgz", + "integrity": "sha512-bruhfxIJlj36oWYmYQ7KFbylCGgzyIi+TLypub+wcAd29mV4llKdvru8Pp9qwILX//I5vK3FIcJ0VzszElhLuA==", "dev": true, "requires": { "@types/lodash": "*" } }, "@types/lodash.findlast": { - "version": "4.6.7", - "resolved": "https://registry.npmjs.org/@types/lodash.findlast/-/lodash.findlast-4.6.7.tgz", - "integrity": "sha512-QP9cSvp2creZZlRHdfz/S1v70ctGShDiK/NdJGQZwhD+IOWmjBO8ldIVEi8La6GTgfyC2ZtIMX3USOvBFYorNg==", + "version": "4.6.9", + "resolved": "https://registry.npmjs.org/@types/lodash.findlast/-/lodash.findlast-4.6.9.tgz", + "integrity": "sha512-mP9/ZOWgVpYTreiKROJKYJxyqA/OBxDPuHEs4xxVBPSJtKZqZgjBwFmPXygQJceGyW0DGxp7zkc5LgCQFDrgjw==", "dev": true, "requires": { "@types/lodash": "*" } }, "@types/lodash.upperfirst": { - "version": "4.3.7", - "resolved": "https://registry.npmjs.org/@types/lodash.upperfirst/-/lodash.upperfirst-4.3.7.tgz", - "integrity": "sha512-CrBjoB4lO6h7tXNMBUl1eh/w0KdMosiEOXOoD5DMECsA/kDWo/WQfOt1KyGKVvgwK3I6cKAY6z8LymKiMazLFg==", + "version": "4.3.9", + "resolved": "https://registry.npmjs.org/@types/lodash.upperfirst/-/lodash.upperfirst-4.3.9.tgz", + "integrity": "sha512-bYhT1QEsk9/ggrFjK86Pb5bnKJgTBbpVA77Ygbb1aW1oiWJNGRbVjSlQ9We/ihB9vVpX5WqDJvbISXlukGR+dQ==", "dev": true, "requires": { "@types/lodash": "*" } }, "@types/memory-fs": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@types/memory-fs/-/memory-fs-0.3.3.tgz", - "integrity": "sha512-rLEYzl1xODshz+Lm+YX8NYws8Xw7/qcYbQInMkotl96VpLZmUvoCfYYGxfajMSiugANV02QO5Fc+R98KKeE4gQ==", + "version": "0.3.7", + "resolved": "https://registry.npmjs.org/@types/memory-fs/-/memory-fs-0.3.7.tgz", + "integrity": "sha512-wCRjyqBTpCsnPWDjYkG8x1Ym0ylHUXu2loom+CIXoP9syXvLAROnfghoNKAMSxvetmRXThMd1XSK2AffVT1WMQ==", "dev": true, "requires": { "@types/node": "*" } }, "@types/mime": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@types/mime/-/mime-3.0.1.tgz", - "integrity": "sha512-Y4XFY5VJAuw0FgAqPNd6NNoV44jbq9Bz2L7Rh/J6jLTiHBSBJa9fxqQIvkIld4GsoDOcCbvzOUAbLPsSKKg+uA==", + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/@types/mime/-/mime-3.0.4.tgz", + "integrity": "sha512-iJt33IQnVRkqeqC7PzBHPTC6fDlRNRW8vjrgqtScAhrmMwe8c4Eo7+fUGTa+XdWrpEgpyKWMYmi2dIwMAYRzPw==", "dev": true }, "@types/mocha": { - "version": "10.0.1", - "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-10.0.1.tgz", - "integrity": "sha512-/fvYntiO1GeICvqbQ3doGDIP97vWmvFt83GKguJ6prmQM2iXZfFcq6YE8KteFyRtX2/h5Hf91BYvPodJKFYv5Q==", + "version": "10.0.6", + "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-10.0.6.tgz", + "integrity": "sha512-dJvrYWxP/UcXm36Qn36fxhUKu8A/xMRXVT2cliFF1Z7UA9liG5Psj3ezNSZw+5puH2czDXRLcXQxf8JbJt0ejg==", "dev": true }, "@types/node": { - "version": "14.18.34", - "resolved": "https://registry.npmjs.org/@types/node/-/node-14.18.34.tgz", - "integrity": "sha512-hcU9AIQVHmPnmjRK+XUUYlILlr9pQrsqSrwov/JK1pnf3GTQowVBhx54FbvM0AU/VXGH4i3+vgXS5EguR7fysA==" + "version": "14.18.63", + "resolved": "https://registry.npmjs.org/@types/node/-/node-14.18.63.tgz", + "integrity": "sha512-fAtCfv4jJg+ExtXhvCkCqUKZ+4ok/JQk01qDKhL5BDDoS3AxKXhV5/MAVUZyQnSEd2GT92fkgZl0pz0Q0AzcIQ==" }, "@types/postcss-safe-parser": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/@types/postcss-safe-parser/-/postcss-safe-parser-5.0.1.tgz", - "integrity": "sha512-/yt27wx9N+HmpCAUS/Wyk1d17qFCmi8cYAnIDar0U0jO4QMG1UFqsvVhg7Cy4xjmEAfAzeyBJmXH5Sti4/fDOQ==", + "version": "5.0.4", + "resolved": "https://registry.npmjs.org/@types/postcss-safe-parser/-/postcss-safe-parser-5.0.4.tgz", + "integrity": "sha512-5zGTm1jsW3j4+omgND1SIDbrZOcigTuxa4ihppvKbLkg2INUGBHV/fWNRSRFibK084tU3fxqZ/kVoSIGqRHnrQ==", "dev": true, "requires": { "postcss": "^8.4.4" } }, "@types/prop-types": { - "version": "15.7.5", - "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.5.tgz", - "integrity": "sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==", + "version": "15.7.11", + "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.11.tgz", + "integrity": "sha512-ga8y9v9uyeiLdpKddhxYQkxNDrfvuPrlFb0N1qnZZByvcElJaXthF1UhvCh9TLWJBEHeNtdnbysW7Y6Uq8CVng==", "dev": true }, "@types/react": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.0.tgz", - "integrity": "sha512-0FLj93y5USLHdnhIhABk83rm8XEGA7kH3cr+YUlvxoUGp1xNt/DINUMvqPxLyOQMzLmZe8i4RTHbvb8MC7NmrA==", + "version": "18.2.46", + "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.46.tgz", + "integrity": "sha512-nNCvVBcZlvX4NU1nRRNV/mFl1nNRuTuslAJglQsq+8ldXe5Xv0Wd2f7WTE3jOxhLH2BFfiZGC6GCp+kHQbgG+w==", "dev": true, "requires": { "@types/prop-types": "*", @@ -8064,9 +8614,9 @@ } }, "@types/react-dom": { - "version": "18.2.1", - "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.1.tgz", - "integrity": "sha512-8QZEV9+Kwy7tXFmjJrp3XUKQSs9LTnE0KnoUb0YCguWBiNW0Yfb2iBMYZ08WPg35IR6P3Z0s00B15SwZnO26+w==", + "version": "18.2.18", + "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.18.tgz", + "integrity": "sha512-TJxDm6OfAX2KJWJdMEVTwWke5Sc/E/RlnPGvGfS0W7+6ocy2xhDVQVh/KvC2Uf7kACs+gDytdusDSdWfWkaNzw==", "dev": true, "requires": { "@types/react": "*" @@ -8079,108 +8629,100 @@ "dev": true }, "@types/scheduler": { - "version": "0.16.2", - "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.2.tgz", - "integrity": "sha512-hppQEBDmlwhFAXKJX2KnWLYu5yMfi91yazPb2l+lbJiwW+wdo1gNeRA+3RgNSO39WYX2euey41KEwnqesU2Jew==", + "version": "0.16.8", + "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.8.tgz", + "integrity": "sha512-WZLiwShhwLRmeV6zH+GkbOFT6Z6VklCItrDioxUnv+u4Ll+8vKeFySoFyK/0ctcRpOmwAicELfmys1sDc/Rw+A==", "dev": true }, "@types/semver": { - "version": "7.3.13", - "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.3.13.tgz", - "integrity": "sha512-21cFJr9z3g5dW8B0CVI9g2O9beqaThGQ6ZFBqHfwhzLDKUxaqTIy3vnfah/UPkfOiF2pLq+tGz+W8RyCskuslw==" + "version": "7.5.6", + "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.6.tgz", + "integrity": "sha512-dn1l8LaMea/IjDoHNd9J52uBbInB796CDffS6VdIxvqYCPSG0V0DzHp76GpaWnlhg88uYyPbXCDIowa86ybd5A==" }, "@types/validate-npm-package-name": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/@types/validate-npm-package-name/-/validate-npm-package-name-4.0.0.tgz", - "integrity": "sha512-RpO62vB2lkjEkyLbwTheA2+uwYmtVMWTr/kWRI++UAgVdZqNqdAuIQl/SxBCGeMKfdjWaXPbyhZbiCc4PAj+KA==", + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/@types/validate-npm-package-name/-/validate-npm-package-name-4.0.2.tgz", + "integrity": "sha512-lrpDziQipxCEeK5kWxvljWYhUvOiB2A9izZd9B2AFarYAkqZshb4lPbRs7zKEic6eGtH8V/2qJW+dPp9OtF6bw==", "dev": true }, "@types/yargs": { - "version": "17.0.24", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.24.tgz", - "integrity": "sha512-6i0aC7jV6QzQB8ne1joVZ0eSFIstHsCrobmOtghM11yGlH0j43FKL2UhWdELkyps0zuf7qVTUVCCR+tgSlyLLw==", + "version": "17.0.32", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.32.tgz", + "integrity": "sha512-xQ67Yc/laOG5uMfX/093MRlGGCIBzZMarVa+gfNKJxWAIgykYpVGkBdbqEzGDDfCrVUj6Hiff4mTZ5BA6TmAog==", "dev": true, "requires": { "@types/yargs-parser": "*" } }, "@types/yargs-parser": { - "version": "21.0.0", - "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz", - "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==", + "version": "21.0.3", + "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.3.tgz", + "integrity": "sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==", "dev": true }, "@typescript-eslint/eslint-plugin": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.59.2.tgz", - "integrity": "sha512-yVrXupeHjRxLDcPKL10sGQ/QlVrA8J5IYOEWVqk0lJaSZP7X5DfnP7Ns3cc74/blmbipQ1htFNVGsHX6wsYm0A==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.62.0.tgz", + "integrity": "sha512-TiZzBSJja/LbhNPvk6yc0JrX9XqhQ0hdh6M2svYfsHGejaKFIAGd9MQ+ERIMzLGlN/kZoYIgdxFV0PuljTKXag==", "dev": true, "requires": { "@eslint-community/regexpp": "^4.4.0", - "@typescript-eslint/scope-manager": "5.59.2", - "@typescript-eslint/type-utils": "5.59.2", - "@typescript-eslint/utils": "5.59.2", + "@typescript-eslint/scope-manager": "5.62.0", + "@typescript-eslint/type-utils": "5.62.0", + "@typescript-eslint/utils": "5.62.0", "debug": "^4.3.4", - "grapheme-splitter": "^1.0.4", + "graphemer": "^1.4.0", "ignore": "^5.2.0", "natural-compare-lite": "^1.4.0", "semver": "^7.3.7", "tsutils": "^3.21.0" } }, - "@typescript-eslint/experimental-utils": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-5.59.2.tgz", - "integrity": "sha512-JLw2UImsjHDuVukpA8Nt+UK7JKE/LQAeV3tU5f7wJo2/NNYVwcakzkWjoYzu/2qzWY/Z9c7zojngNDfecNt92g==", - "requires": { - "@typescript-eslint/utils": "5.59.2" - } - }, "@typescript-eslint/parser": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.59.2.tgz", - "integrity": "sha512-uq0sKyw6ao1iFOZZGk9F8Nro/8+gfB5ezl1cA06SrqbgJAt0SRoFhb9pXaHvkrxUpZaoLxt8KlovHNk8Gp6/HQ==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.62.0.tgz", + "integrity": "sha512-VlJEV0fOQ7BExOsHYAGrgbEiZoi8D+Bl2+f6V2RrXerRSylnp+ZBHmPvaIa8cz0Ajx7WO7Z5RqfgYg7ED1nRhA==", "dev": true, "requires": { - "@typescript-eslint/scope-manager": "5.59.2", - "@typescript-eslint/types": "5.59.2", - "@typescript-eslint/typescript-estree": "5.59.2", + "@typescript-eslint/scope-manager": "5.62.0", + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/typescript-estree": "5.62.0", "debug": "^4.3.4" } }, "@typescript-eslint/scope-manager": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.59.2.tgz", - "integrity": "sha512-dB1v7ROySwQWKqQ8rEWcdbTsFjh2G0vn8KUyvTXdPoyzSL6lLGkiXEV5CvpJsEe9xIdKV+8Zqb7wif2issoOFA==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.62.0.tgz", + "integrity": "sha512-VXuvVvZeQCQb5Zgf4HAxc04q5j+WrNAtNh9OwCsCgpKqESMTu3tF/jhZ3xG6T4NZwWl65Bg8KuS2uEvhSfLl0w==", "requires": { - "@typescript-eslint/types": "5.59.2", - "@typescript-eslint/visitor-keys": "5.59.2" + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/visitor-keys": "5.62.0" } }, "@typescript-eslint/type-utils": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.59.2.tgz", - "integrity": "sha512-b1LS2phBOsEy/T381bxkkywfQXkV1dWda/z0PhnIy3bC5+rQWQDS7fk9CSpcXBccPY27Z6vBEuaPBCKCgYezyQ==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.62.0.tgz", + "integrity": "sha512-xsSQreu+VnfbqQpW5vnCJdq1Z3Q0U31qiWmRhr98ONQmcp/yhiPJFPq8MXiJVLiksmOKSjIldZzkebzHuCGzew==", "dev": true, "requires": { - "@typescript-eslint/typescript-estree": "5.59.2", - "@typescript-eslint/utils": "5.59.2", + "@typescript-eslint/typescript-estree": "5.62.0", + "@typescript-eslint/utils": "5.62.0", "debug": "^4.3.4", "tsutils": "^3.21.0" } }, "@typescript-eslint/types": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.59.2.tgz", - "integrity": "sha512-LbJ/HqoVs2XTGq5shkiKaNTuVv5tTejdHgfdjqRUGdYhjW1crm/M7og2jhVskMt8/4wS3T1+PfFvL1K3wqYj4w==" + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.62.0.tgz", + "integrity": "sha512-87NVngcbVXUahrRTqIK27gD2t5Cu1yuCXxbLcFtCzZGlfyVWWh8mLHkoxzjsB6DDNnvdL+fW8MiwPEJyGJQDgQ==" }, "@typescript-eslint/typescript-estree": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.59.2.tgz", - "integrity": "sha512-+j4SmbwVmZsQ9jEyBMgpuBD0rKwi9RxRpjX71Brr73RsYnEr3Lt5QZ624Bxphp8HUkSKfqGnPJp1kA5nl0Sh7Q==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.62.0.tgz", + "integrity": "sha512-CmcQ6uY7b9y694lKdRB8FEel7JbU/40iSAPomu++SjLMntB+2Leay2LO6i8VnJk58MtE9/nQSFIH6jpyRWyYzA==", "requires": { - "@typescript-eslint/types": "5.59.2", - "@typescript-eslint/visitor-keys": "5.59.2", + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/visitor-keys": "5.62.0", "debug": "^4.3.4", "globby": "^11.1.0", "is-glob": "^4.0.3", @@ -8189,162 +8731,167 @@ } }, "@typescript-eslint/utils": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.59.2.tgz", - "integrity": "sha512-kSuF6/77TZzyGPhGO4uVp+f0SBoYxCDf+lW3GKhtKru/L8k/Hd7NFQxyWUeY7Z/KGB2C6Fe3yf2vVi4V9TsCSQ==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.62.0.tgz", + "integrity": "sha512-n8oxjeb5aIbPFEtmQxQYOLI0i9n5ySBEY/ZEHHZqKQSFnxio1rv6dthascc9dLuwrL0RC5mPCxB7vnAVGAYWAQ==", "requires": { "@eslint-community/eslint-utils": "^4.2.0", "@types/json-schema": "^7.0.9", "@types/semver": "^7.3.12", - "@typescript-eslint/scope-manager": "5.59.2", - "@typescript-eslint/types": "5.59.2", - "@typescript-eslint/typescript-estree": "5.59.2", + "@typescript-eslint/scope-manager": "5.62.0", + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/typescript-estree": "5.62.0", "eslint-scope": "^5.1.1", "semver": "^7.3.7" } }, "@typescript-eslint/visitor-keys": { - "version": "5.59.2", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.59.2.tgz", - "integrity": "sha512-EEpsO8m3RASrKAHI9jpavNv9NlEUebV4qmF1OWxSTtKSFBpC1NCmWazDQHFivRf0O1DV11BA645yrLEVQ0/Lig==", + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.62.0.tgz", + "integrity": "sha512-07ny+LHRzQXepkGg6w0mFY41fVUNBrL2Roj/++7V1txKugfjm/Ci/qSND03r2RhlJhJYMcTn9AhhSSqQp0Ysyw==", "requires": { - "@typescript-eslint/types": "5.59.2", + "@typescript-eslint/types": "5.62.0", "eslint-visitor-keys": "^3.3.0" } }, + "@ungap/structured-clone": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", + "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==" + }, "@vscode/l10n": { - "version": "0.0.13", - "resolved": "https://registry.npmjs.org/@vscode/l10n/-/l10n-0.0.13.tgz", - "integrity": "sha512-A3uY356uOU9nGa+TQIT/i3ziWUgJjVMUrGGXSrtRiTwklyCFjGVWIOHoEIHbJpiyhDkJd9kvIWUOfXK1IkK8XQ==" + "version": "0.0.16", + "resolved": "https://registry.npmjs.org/@vscode/l10n/-/l10n-0.0.16.tgz", + "integrity": "sha512-JT5CvrIYYCrmB+dCana8sUqJEcGB1ZDXNLMQ2+42bW995WmNoenijWMUdZfwmuQUTQcEVVIa2OecZzTYWUW9Cg==" }, "@webassemblyjs/ast": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.11.5.tgz", - "integrity": "sha512-LHY/GSAZZRpsNQH+/oHqhRQ5FT7eoULcBqgfyTB5nQHogFnK3/7QoN7dLnwSE/JkUAF0SrRuclT7ODqMFtWxxQ==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.11.6.tgz", + "integrity": "sha512-IN1xI7PwOvLPgjcf180gC1bqn3q/QaOCwYUahIOhbYUu8KA/3tw2RT/T0Gidi1l7Hhj5D/INhJxiICObqpMu4Q==", "requires": { - "@webassemblyjs/helper-numbers": "1.11.5", - "@webassemblyjs/helper-wasm-bytecode": "1.11.5" + "@webassemblyjs/helper-numbers": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6" } }, "@webassemblyjs/floating-point-hex-parser": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.5.tgz", - "integrity": "sha512-1j1zTIC5EZOtCplMBG/IEwLtUojtwFVwdyVMbL/hwWqbzlQoJsWCOavrdnLkemwNoC/EOwtUFch3fuo+cbcXYQ==" + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.6.tgz", + "integrity": "sha512-ejAj9hfRJ2XMsNHk/v6Fu2dGS+i4UaXBXGemOfQ/JfQ6mdQg/WXtwleQRLLS4OvfDhv8rYnVwH27YJLMyYsxhw==" }, "@webassemblyjs/helper-api-error": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.5.tgz", - "integrity": "sha512-L65bDPmfpY0+yFrsgz8b6LhXmbbs38OnwDCf6NpnMUYqa+ENfE5Dq9E42ny0qz/PdR0LJyq/T5YijPnU8AXEpA==" + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.6.tgz", + "integrity": "sha512-o0YkoP4pVu4rN8aTJgAyj9hC2Sv5UlkzCHhxqWj8butaLvnpdc2jOwh4ewE6CX0txSfLn/UYaV/pheS2Txg//Q==" }, "@webassemblyjs/helper-buffer": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.5.tgz", - "integrity": "sha512-fDKo1gstwFFSfacIeH5KfwzjykIE6ldh1iH9Y/8YkAZrhmu4TctqYjSh7t0K2VyDSXOZJ1MLhht/k9IvYGcIxg==" + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.6.tgz", + "integrity": "sha512-z3nFzdcp1mb8nEOFFk8DrYLpHvhKC3grJD2ardfKOzmbmJvEf/tPIqCY+sNcwZIY8ZD7IkB2l7/pqhUhqm7hLA==" }, "@webassemblyjs/helper-numbers": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.5.tgz", - "integrity": "sha512-DhykHXM0ZABqfIGYNv93A5KKDw/+ywBFnuWybZZWcuzWHfbp21wUfRkbtz7dMGwGgT4iXjWuhRMA2Mzod6W4WA==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.6.tgz", + "integrity": "sha512-vUIhZ8LZoIWHBohiEObxVm6hwP034jwmc9kuq5GdHZH0wiLVLIPcMCdpJzG4C11cHoQ25TFIQj9kaVADVX7N3g==", "requires": { - "@webassemblyjs/floating-point-hex-parser": "1.11.5", - "@webassemblyjs/helper-api-error": "1.11.5", + "@webassemblyjs/floating-point-hex-parser": "1.11.6", + "@webassemblyjs/helper-api-error": "1.11.6", "@xtuc/long": "4.2.2" } }, "@webassemblyjs/helper-wasm-bytecode": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.5.tgz", - "integrity": "sha512-oC4Qa0bNcqnjAowFn7MPCETQgDYytpsfvz4ujZz63Zu/a/v71HeCAAmZsgZ3YVKec3zSPYytG3/PrRCqbtcAvA==" + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.6.tgz", + "integrity": "sha512-sFFHKwcmBprO9e7Icf0+gddyWYDViL8bpPjJJl0WHxCdETktXdmtWLGVzoHbqUcY4Be1LkNfwTmXOJUFZYSJdA==" }, "@webassemblyjs/helper-wasm-section": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.5.tgz", - "integrity": "sha512-uEoThA1LN2NA+K3B9wDo3yKlBfVtC6rh0i4/6hvbz071E8gTNZD/pT0MsBf7MeD6KbApMSkaAK0XeKyOZC7CIA==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.6.tgz", + "integrity": "sha512-LPpZbSOwTpEC2cgn4hTydySy1Ke+XEu+ETXuoyvuyezHO3Kjdu90KK95Sh9xTbmjrCsUwvWwCOQQNta37VrS9g==", "requires": { - "@webassemblyjs/ast": "1.11.5", - "@webassemblyjs/helper-buffer": "1.11.5", - "@webassemblyjs/helper-wasm-bytecode": "1.11.5", - "@webassemblyjs/wasm-gen": "1.11.5" + "@webassemblyjs/ast": "1.11.6", + "@webassemblyjs/helper-buffer": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/wasm-gen": "1.11.6" } }, "@webassemblyjs/ieee754": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.5.tgz", - "integrity": "sha512-37aGq6qVL8A8oPbPrSGMBcp38YZFXcHfiROflJn9jxSdSMMM5dS5P/9e2/TpaJuhE+wFrbukN2WI6Hw9MH5acg==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.6.tgz", + "integrity": "sha512-LM4p2csPNvbij6U1f19v6WR56QZ8JcHg3QIJTlSwzFcmx6WSORicYj6I63f9yU1kEUtrpG+kjkiIAkevHpDXrg==", "requires": { "@xtuc/ieee754": "^1.2.0" } }, "@webassemblyjs/leb128": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.5.tgz", - "integrity": "sha512-ajqrRSXaTJoPW+xmkfYN6l8VIeNnR4vBOTQO9HzR7IygoCcKWkICbKFbVTNMjMgMREqXEr0+2M6zukzM47ZUfQ==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.6.tgz", + "integrity": "sha512-m7a0FhE67DQXgouf1tbN5XQcdWoNgaAuoULHIfGFIEVKA6tu/edls6XnIlkmS6FrXAquJRPni3ZZKjw6FSPjPQ==", "requires": { "@xtuc/long": "4.2.2" } }, "@webassemblyjs/utf8": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.5.tgz", - "integrity": "sha512-WiOhulHKTZU5UPlRl53gHR8OxdGsSOxqfpqWeA2FmcwBMaoEdz6b2x2si3IwC9/fSPLfe8pBMRTHVMk5nlwnFQ==" + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.6.tgz", + "integrity": "sha512-vtXf2wTQ3+up9Zsg8sa2yWiQpzSsMyXj0qViVP6xKGCUT8p8YJ6HqI7l5eCnWx1T/FYdsv07HQs2wTFbbof/RA==" }, "@webassemblyjs/wasm-edit": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.5.tgz", - "integrity": "sha512-C0p9D2fAu3Twwqvygvf42iGCQ4av8MFBLiTb+08SZ4cEdwzWx9QeAHDo1E2k+9s/0w1DM40oflJOpkZ8jW4HCQ==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.6.tgz", + "integrity": "sha512-Ybn2I6fnfIGuCR+Faaz7YcvtBKxvoLV3Lebn1tM4o/IAJzmi9AWYIPWpyBfU8cC+JxAO57bk4+zdsTjJR+VTOw==", "requires": { - "@webassemblyjs/ast": "1.11.5", - "@webassemblyjs/helper-buffer": "1.11.5", - "@webassemblyjs/helper-wasm-bytecode": "1.11.5", - "@webassemblyjs/helper-wasm-section": "1.11.5", - "@webassemblyjs/wasm-gen": "1.11.5", - "@webassemblyjs/wasm-opt": "1.11.5", - "@webassemblyjs/wasm-parser": "1.11.5", - "@webassemblyjs/wast-printer": "1.11.5" + "@webassemblyjs/ast": "1.11.6", + "@webassemblyjs/helper-buffer": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/helper-wasm-section": "1.11.6", + "@webassemblyjs/wasm-gen": "1.11.6", + "@webassemblyjs/wasm-opt": "1.11.6", + "@webassemblyjs/wasm-parser": "1.11.6", + "@webassemblyjs/wast-printer": "1.11.6" } }, "@webassemblyjs/wasm-gen": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.5.tgz", - "integrity": "sha512-14vteRlRjxLK9eSyYFvw1K8Vv+iPdZU0Aebk3j6oB8TQiQYuO6hj9s4d7qf6f2HJr2khzvNldAFG13CgdkAIfA==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.6.tgz", + "integrity": "sha512-3XOqkZP/y6B4F0PBAXvI1/bky7GryoogUtfwExeP/v7Nzwo1QLcq5oQmpKlftZLbT+ERUOAZVQjuNVak6UXjPA==", "requires": { - "@webassemblyjs/ast": "1.11.5", - "@webassemblyjs/helper-wasm-bytecode": "1.11.5", - "@webassemblyjs/ieee754": "1.11.5", - "@webassemblyjs/leb128": "1.11.5", - "@webassemblyjs/utf8": "1.11.5" + "@webassemblyjs/ast": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/ieee754": "1.11.6", + "@webassemblyjs/leb128": "1.11.6", + "@webassemblyjs/utf8": "1.11.6" } }, "@webassemblyjs/wasm-opt": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.5.tgz", - "integrity": "sha512-tcKwlIXstBQgbKy1MlbDMlXaxpucn42eb17H29rawYLxm5+MsEmgPzeCP8B1Cl69hCice8LeKgZpRUAPtqYPgw==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.6.tgz", + "integrity": "sha512-cOrKuLRE7PCe6AsOVl7WasYf3wbSo4CeOk6PkrjS7g57MFfVUF9u6ysQBBODX0LdgSvQqRiGz3CXvIDKcPNy4g==", "requires": { - "@webassemblyjs/ast": "1.11.5", - "@webassemblyjs/helper-buffer": "1.11.5", - "@webassemblyjs/wasm-gen": "1.11.5", - "@webassemblyjs/wasm-parser": "1.11.5" + "@webassemblyjs/ast": "1.11.6", + "@webassemblyjs/helper-buffer": "1.11.6", + "@webassemblyjs/wasm-gen": "1.11.6", + "@webassemblyjs/wasm-parser": "1.11.6" } }, "@webassemblyjs/wasm-parser": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.5.tgz", - "integrity": "sha512-SVXUIwsLQlc8srSD7jejsfTU83g7pIGr2YYNb9oHdtldSxaOhvA5xwvIiWIfcX8PlSakgqMXsLpLfbbJ4cBYew==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.6.tgz", + "integrity": "sha512-6ZwPeGzMJM3Dqp3hCsLgESxBGtT/OeCvCZ4TA1JUPYgmhAx38tTPR9JaKy0S5H3evQpO/h2uWs2j6Yc/fjkpTQ==", "requires": { - "@webassemblyjs/ast": "1.11.5", - "@webassemblyjs/helper-api-error": "1.11.5", - "@webassemblyjs/helper-wasm-bytecode": "1.11.5", - "@webassemblyjs/ieee754": "1.11.5", - "@webassemblyjs/leb128": "1.11.5", - "@webassemblyjs/utf8": "1.11.5" + "@webassemblyjs/ast": "1.11.6", + "@webassemblyjs/helper-api-error": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/ieee754": "1.11.6", + "@webassemblyjs/leb128": "1.11.6", + "@webassemblyjs/utf8": "1.11.6" } }, "@webassemblyjs/wast-printer": { - "version": "1.11.5", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.11.5.tgz", - "integrity": "sha512-f7Pq3wvg3GSPUPzR0F6bmI89Hdb+u9WXrSKc4v+N0aV0q6r42WoF92Jp2jEorBEBRoRNXgjp53nBniDXcqZYPA==", + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.11.6.tgz", + "integrity": "sha512-JM7AhRcE+yW2GWYaKeHL5vt4xqee5N2WcezptmgyhNS+ScggqcT1OtXykhAb13Sn5Yas0j2uv9tHgrjwvzAP4A==", "requires": { - "@webassemblyjs/ast": "1.11.5", + "@webassemblyjs/ast": "1.11.6", "@xtuc/long": "4.2.2" } }, @@ -8366,17 +8913,17 @@ } }, "minimatch": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.0.tgz", - "integrity": "sha512-0jJj8AvgKqWN05mrwuqi8QYKx1WmYSUoKSxu5Qhs9prezTz10sxAHGNZe9J9cqIJzta8DWsleh2KaVaLl6Ru2w==", + "version": "9.0.3", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", + "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", "requires": { "brace-expansion": "^2.0.1" } }, "type-fest": { - "version": "3.8.0", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-3.8.0.tgz", - "integrity": "sha512-FVNSzGQz9Th+/9R6Lvv7WIAkstylfHN2/JYxkyhhmKFYh9At2DST8t6L6Lref9eYO8PXFTfG9Sg1Agg0K3vq3Q==" + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-3.13.1.tgz", + "integrity": "sha512-tLq3bSNx+xSpwvAJnzrK0Ep5CLNWjvFTOp71URMaAEWBfRb9nnJiBoUe0tF8bI4ZFO3omgBR6NvnbzVUT3Ly4g==" } } }, @@ -8390,26 +8937,20 @@ "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==" }, - "abab": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.6.tgz", - "integrity": "sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==", - "dev": true - }, "abbrev": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", - "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-2.0.0.tgz", + "integrity": "sha512-6/mh1E2u2YgEsCHdY0Yx5oW+61gZU+1vXaoiHHrpKeuRNNgFvS+/jrwHiQhB5apAf5oB7UB7E19ol2R2LKH8hQ==" }, "acorn": { - "version": "8.8.1", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.1.tgz", - "integrity": "sha512-7zFpHzhnqYKrkYdUjF1HI1bzd0VygEGX8lFk4k5zVMqHEoES+P+7TKI+EvLO9WVMJ8eekdO0aDEK044xTXwPPA==" + "version": "8.11.3", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", + "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==" }, "acorn-import-assertions": { - "version": "1.8.0", - "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.8.0.tgz", - "integrity": "sha512-m7VZ3jwz4eK6A4Vtt8Ew1/mNbP24u0FhdyfA7fSvnJR6LMdfOYnmuIrrJAgrYfYJ10F/otaHTtrtrtmHdMNzEw==", + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.9.0.tgz", + "integrity": "sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==", "requires": {} }, "acorn-jsx": { @@ -8439,9 +8980,9 @@ }, "dependencies": { "ajv": { - "version": "8.11.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.11.2.tgz", - "integrity": "sha512-E4bfmKAhGiSTvMfL1Myyycaub+cUEU2/IvpylXkUu7CHBkBj1f/ikdzbD7YQ6FKUbixDxeYvB/xY4fvyroDlQg==", + "version": "8.12.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.12.0.tgz", + "integrity": "sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==", "dev": true, "requires": { "fast-deep-equal": "^3.1.1", @@ -8498,17 +9039,14 @@ "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==" }, - "array-includes": { - "version": "3.1.6", - "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.6.tgz", - "integrity": "sha512-sgTbLvL6cNnw24FnbaDyjmvddQ2ML8arZsgaJhoABMoplz/4QRhtrYS+alr1BUM1Bwp6dhx8vVCBSLG+StwOFw==", + "array-buffer-byte-length": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz", + "integrity": "sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==", "dev": true, "requires": { "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "get-intrinsic": "^1.1.3", - "is-string": "^1.0.7" + "is-array-buffer": "^3.0.1" } }, "array-union": { @@ -8516,29 +9054,19 @@ "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==" }, - "array.prototype.flatmap": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.1.tgz", - "integrity": "sha512-8UGn9O1FDVvMNB0UlLv4voxRMze7+FpHyF5mSMRjWHUMlpoDViniy05870VlxhfgTnLbpuwTzvD76MTtWxB/mQ==", - "dev": true, - "requires": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "es-shim-unscopables": "^1.0.0" - } - }, - "array.prototype.tosorted": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.1.tgz", - "integrity": "sha512-pZYPXPRl2PqWcsUs6LOMn+1f1532nEoPTYowBtqLwAW+W8vSVhkIGnmOX1t/UQjD6YGI0vcD2B1U7ZFGQH9jnQ==", + "arraybuffer.prototype.slice": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.2.tgz", + "integrity": "sha512-yMBKppFur/fbHu9/6USUe03bZ4knMYiwFBcyiaXB8Go0qNehwX6inYPzK9U0NeQvGxKthcmHcaR8P5MStSRBAw==", "dev": true, "requires": { + "array-buffer-byte-length": "^1.0.0", "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "es-shim-unscopables": "^1.0.0", - "get-intrinsic": "^1.1.3" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "get-intrinsic": "^1.2.1", + "is-array-buffer": "^3.0.2", + "is-shared-array-buffer": "^1.0.2" } }, "assertion-error": { @@ -8547,19 +9075,25 @@ "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==" }, "autoprefixer": { - "version": "10.4.14", - "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.14.tgz", - "integrity": "sha512-FQzyfOsTlwVzjHxKEqRIAdJx9niO6VCBCoEwax/VLSoQF29ggECcPuBqUMZ+u8jCZOPSy8b8/8KnuFbp0SaFZQ==", + "version": "10.4.16", + "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.16.tgz", + "integrity": "sha512-7vd3UC6xKp0HLfua5IjZlcXvGAGy7cBAXTg2lyQ/8WpNhd6SiZ8Be+xm3FyBSYJx5GKcpRCzBh7RH4/0dnY+uQ==", "dev": true, "requires": { - "browserslist": "^4.21.5", - "caniuse-lite": "^1.0.30001464", - "fraction.js": "^4.2.0", + "browserslist": "^4.21.10", + "caniuse-lite": "^1.0.30001538", + "fraction.js": "^4.3.6", "normalize-range": "^0.1.2", "picocolors": "^1.0.0", "postcss-value-parser": "^4.2.0" } }, + "available-typed-arrays": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", + "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==", + "dev": true + }, "balanced-match": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", @@ -8607,14 +9141,14 @@ "dev": true }, "browserslist": { - "version": "4.21.5", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.5.tgz", - "integrity": "sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w==", + "version": "4.22.2", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.22.2.tgz", + "integrity": "sha512-0UgcrvQmBDvZHFGdYUehrCNIazki7/lUP3kkoi/r3YB2amZbFM9J43ZRkJTXBUZK4gmx56+Sqk9+Vs9mwZx9+A==", "requires": { - "caniuse-lite": "^1.0.30001449", - "electron-to-chromium": "^1.4.284", - "node-releases": "^2.0.8", - "update-browserslist-db": "^1.0.10" + "caniuse-lite": "^1.0.30001565", + "electron-to-chromium": "^1.4.601", + "node-releases": "^2.0.14", + "update-browserslist-db": "^1.0.13" } }, "buffer-from": { @@ -8637,9 +9171,9 @@ } }, "c8": { - "version": "7.13.0", - "resolved": "https://registry.npmjs.org/c8/-/c8-7.13.0.tgz", - "integrity": "sha512-/NL4hQTv1gBL6J6ei80zu3IiTrmePDKXKXOTLpHvcIWZTVYQlDhVWjjWvkhICylE8EwwnMVzDZugCvdx0/DIIA==", + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/c8/-/c8-8.0.1.tgz", + "integrity": "sha512-EINpopxZNH1mETuI0DzRA4MZpAUH+IFiRhnmFD3vFr3vdrgxqi3VfE3KL0AIL+zDq8rC9bZqwM/VDmmoe04y7w==", "dev": true, "requires": { "@bcoe/v8-coverage": "^0.2.3", @@ -8647,26 +9181,15 @@ "find-up": "^5.0.0", "foreground-child": "^2.0.0", "istanbul-lib-coverage": "^3.2.0", - "istanbul-lib-report": "^3.0.0", - "istanbul-reports": "^3.1.4", + "istanbul-lib-report": "^3.0.1", + "istanbul-reports": "^3.1.6", "rimraf": "^3.0.2", "test-exclude": "^6.0.0", "v8-to-istanbul": "^9.0.0", - "yargs": "^16.2.0", - "yargs-parser": "^20.2.9" + "yargs": "^17.7.2", + "yargs-parser": "^21.1.1" }, "dependencies": { - "cliui": { - "version": "7.0.4", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", - "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", - "dev": true, - "requires": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.0", - "wrap-ansi": "^7.0.0" - } - }, "rimraf": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", @@ -8675,32 +9198,18 @@ "requires": { "glob": "^7.1.3" } - }, - "yargs": { - "version": "16.2.0", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", - "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", - "dev": true, - "requires": { - "cliui": "^7.0.2", - "escalade": "^3.1.1", - "get-caller-file": "^2.0.5", - "require-directory": "^2.1.1", - "string-width": "^4.2.0", - "y18n": "^5.0.5", - "yargs-parser": "^20.2.2" - } } } }, "call-bind": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", - "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.5.tgz", + "integrity": "sha512-C3nQxfFZxFRVoJoGKKI8y3MOEo129NQ+FgQ08iye+Mk4zNZZGdjfs06bVTr+DBSlA66Q2VEcMki/cUCP4SercQ==", "dev": true, "requires": { - "function-bind": "^1.1.1", - "get-intrinsic": "^1.0.2" + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.1", + "set-function-length": "^1.1.1" } }, "callsite": { @@ -8723,28 +9232,34 @@ "tslib": "^2.0.3" } }, + "camelcase": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", + "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", + "dev": true + }, "camelcase-css": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/camelcase-css/-/camelcase-css-2.0.1.tgz", "integrity": "sha512-QOSvevhslijgYwRx6Rv7zKdMF8lbRmx+uQGx2+vDc+KI/eBnsy9kit5aj23AgGu3pa4t9AgwbnXWqS+iOY+2aA==" }, "caniuse-lite": { - "version": "1.0.30001466", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001466.tgz", - "integrity": "sha512-ewtFBSfWjEmxUgNBSZItFSmVtvk9zkwkl1OfRZlKA8slltRN+/C/tuGVrF9styXkN36Yu3+SeJ1qkXxDEyNZ5w==" + "version": "1.0.30001572", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001572.tgz", + "integrity": "sha512-1Pbh5FLmn5y4+QhNyJE9j3/7dK44dGB83/ZMjv/qJk86TvDbjk0LosiZo0i0WB0Vx607qMX9jYrn1VLHCkN4rw==" }, "chai": { - "version": "4.3.7", - "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.7.tgz", - "integrity": "sha512-HLnAzZ2iupm25PlN0xFreAlBA5zaBSv3og0DdeGA4Ar6h6rJ3A0rolRUKJhSF2V10GZKDgWF/VmAEsNWjCRB+A==", + "version": "4.3.10", + "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.10.tgz", + "integrity": "sha512-0UXG04VuVbruMUYbJ6JctvH0YnC/4q3/AkT18q4NaITo91CUm0liMS9VqzT9vZhVQ/1eqPanMWjBM+Juhfb/9g==", "requires": { "assertion-error": "^1.1.0", - "check-error": "^1.0.2", - "deep-eql": "^4.1.2", - "get-func-name": "^2.0.0", - "loupe": "^2.3.1", + "check-error": "^1.0.3", + "deep-eql": "^4.1.3", + "get-func-name": "^2.0.2", + "loupe": "^2.3.6", "pathval": "^1.1.1", - "type-detect": "^4.0.5" + "type-detect": "^4.0.8" } }, "chai-subset": { @@ -8763,9 +9278,12 @@ } }, "check-error": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", - "integrity": "sha512-BrgHpW9NURQgzoNyjfq0Wu6VFO6D7IZEmJNdtgNqpzGG8RuNFHt2jQxWlAs4HMe119chBnv+34syEZtc6IhLtA==" + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.3.tgz", + "integrity": "sha512-iKEoDYaRmd1mxM90a2OEfWhjsjPpYPuQ+lMYsoxB126+t8fw7ySEO48nmDg5COTjxDI65/Y2OWpeEHk3ZOe8zg==", + "requires": { + "get-func-name": "^2.0.2" + } }, "chokidar": { "version": "3.5.3", @@ -8800,9 +9318,9 @@ "integrity": "sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==" }, "clean-css": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-5.3.1.tgz", - "integrity": "sha512-lCr8OHhiWCTw4v8POJovCoh4T7I9U11yVsPjMWWnnMmp9ZowCxyad1Pathle/9HjaDp+fdQKjO9fQydE6RHTZg==", + "version": "5.3.3", + "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-5.3.3.tgz", + "integrity": "sha512-D5J+kHaVb/wKSFcyyV75uCn8fiY4sV38XJoe4CUyGQ+mOU/fMVYUdH1hJC+CJQ5uY3EnW27SbJYS4X8BiLrAFg==", "dev": true, "requires": { "source-map": "~0.6.0" @@ -8860,9 +9378,9 @@ } }, "convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", + "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", "dev": true }, "create-listening-server": { @@ -8889,14 +9407,14 @@ } }, "css-loader": { - "version": "6.7.3", - "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-6.7.3.tgz", - "integrity": "sha512-qhOH1KlBMnZP8FzRO6YCH9UHXQhVMcEGLyNdb7Hv2cpcmJbW0YrddO+tG1ab5nT41KpHIYGsbeHqxB9xPu1pKQ==", + "version": "6.8.1", + "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-6.8.1.tgz", + "integrity": "sha512-xDAXtEVGlD0gJ07iclwWVkLoZOpEvAWaSyf6W18S2pOC//K8+qUDIx8IIT3D+HjnmkJPQeesOPv5aiUaJsCM2g==", "requires": { "icss-utils": "^5.1.0", - "postcss": "^8.4.19", + "postcss": "^8.4.21", "postcss-modules-extract-imports": "^3.0.0", - "postcss-modules-local-by-default": "^4.0.0", + "postcss-modules-local-by-default": "^4.0.3", "postcss-modules-scope": "^3.0.0", "postcss-modules-values": "^4.0.0", "postcss-value-parser": "^4.2.0", @@ -8954,9 +9472,9 @@ } }, "csstype": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.1.tgz", - "integrity": "sha512-DJR/VvkAvSZW9bTouZue2sSxDwdTN92uHjqeKVm+0dAqdfNykRzQ95tay8aXMBAAPpUiq4Qcug2L7neoRh2Egw==", + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", + "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", "dev": true }, "debug": { @@ -8968,9 +9486,9 @@ } }, "decache": { - "version": "4.6.1", - "resolved": "https://registry.npmjs.org/decache/-/decache-4.6.1.tgz", - "integrity": "sha512-ohApBM8u9ygepJCjgBrEZSSxPjc0T/PJkD+uNyxXPkqudyUpdXpwJYp0VISm2WrPVzASU6DZyIi6BWdyw7uJ2Q==", + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/decache/-/decache-4.6.2.tgz", + "integrity": "sha512-2LPqkLeu8XWHU8qNCS3kcF6sCcb5zIzvWaAHYSvPfwhdd7mHuah29NssMzrTYyHN4F5oFy2ko9OBYxegtU0FEw==", "requires": { "callsite": "^1.0.0" } @@ -8995,17 +9513,29 @@ "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==" }, "deepmerge": { - "version": "4.2.2", - "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz", - "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==", + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", + "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", "dev": true }, + "define-data-property": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.1.tgz", + "integrity": "sha512-E7uGkTzkk1d0ByLeSc6ZsFS79Axg+m1P/VsgYsxHgiuc3tFSj+MjMIwe90FC4lOAZzNBdY7kkO2P2wKdsQ1vgQ==", + "dev": true, + "requires": { + "get-intrinsic": "^1.2.1", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.0" + } + }, "define-properties": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.4.tgz", - "integrity": "sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA==", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", + "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", "dev": true, "requires": { + "define-data-property": "^1.0.1", "has-property-descriptors": "^1.0.0", "object-keys": "^1.1.1" } @@ -9055,14 +9585,6 @@ "domelementtype": "^2.0.1", "domhandler": "^4.2.0", "entities": "^2.0.0" - }, - "dependencies": { - "entities": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", - "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", - "dev": true - } } }, "domelementtype": { @@ -9101,47 +9623,49 @@ "tslib": "^2.0.3" } }, + "eastasianwidth": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", + "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==" + }, "editorconfig": { - "version": "0.15.3", - "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-0.15.3.tgz", - "integrity": "sha512-M9wIMFx96vq0R4F+gRpY3o2exzb8hEj/n9S8unZtHSvYjibBp/iMufSzvmOcV/laG0ZtuTVGtiJggPOSW2r93g==", + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-1.0.4.tgz", + "integrity": "sha512-L9Qe08KWTlqYMVvMcTIvMAdl1cDUubzRNYL+WfA4bLDMHe4nemKkpmYzkznE1FwLKu0EEmy6obgQKzMJrg4x9Q==", "requires": { - "commander": "^2.19.0", - "lru-cache": "^4.1.5", - "semver": "^5.6.0", - "sigmund": "^1.0.1" + "@one-ini/wasm": "0.1.1", + "commander": "^10.0.0", + "minimatch": "9.0.1", + "semver": "^7.5.3" }, "dependencies": { - "commander": { - "version": "2.20.3", - "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", - "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==" - }, - "lru-cache": { - "version": "4.1.5", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", - "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", + "brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", "requires": { - "pseudomap": "^1.0.2", - "yallist": "^2.1.2" + "balanced-match": "^1.0.0" } }, - "semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + "commander": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-10.0.1.tgz", + "integrity": "sha512-y4Mg2tXshplEbSGzx7amzPwKKOCGuoSRP/CjEdwwk0FOGlUbq6lKuoyDZTNZkmxHdJtp54hdfY/JUrdL7Xfdug==" }, - "yallist": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", - "integrity": "sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A==" + "minimatch": { + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.1.tgz", + "integrity": "sha512-0jWhJpD/MdhPXwPuiRkCbfYfSKp2qnn2eOc279qI7f+osl/l+prKSrvhg157zSYvx/1nmgn2NqdT6k2Z7zSH9w==", + "requires": { + "brace-expansion": "^2.0.1" + } } } }, "electron-to-chromium": { - "version": "1.4.284", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.284.tgz", - "integrity": "sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA==" + "version": "1.4.616", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.616.tgz", + "integrity": "sha512-1n7zWYh8eS0L9Uy+GskE0lkBUNK83cXTVJI0pU3mGprFsbfSdAc15VTFbo+A+Bq4pwstmL30AVcEU3Fo463lNg==" }, "emoji-regex": { "version": "8.0.0", @@ -9155,14 +9679,20 @@ "dev": true }, "enhanced-resolve": { - "version": "5.13.0", - "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.13.0.tgz", - "integrity": "sha512-eyV8f0y1+bzyfh8xAwW/WTSZpLbjhqc4ne9eGSH4Zo2ejdyiNG9pU6mf9DG8a7+Auk6MFTlNOT4Y2y/9k8GKVg==", + "version": "5.15.0", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.15.0.tgz", + "integrity": "sha512-LXYT42KJ7lpIKECr2mAXIaMldcNCh/7E0KBKOu4KSfkHmP+mZmSs+8V5gBAqisWBy0OO4W5Oyys0GO1Y8KtdKg==", "requires": { "graceful-fs": "^4.2.4", "tapable": "^2.2.0" } }, + "entities": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", + "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", + "dev": true + }, "error-ex": { "version": "1.3.2", "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", @@ -9173,50 +9703,66 @@ } }, "es-abstract": { - "version": "1.20.5", - "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.20.5.tgz", - "integrity": "sha512-7h8MM2EQhsCA7pU/Nv78qOXFpD8Rhqd12gYiSJVkrH9+e8VuA8JlPJK/hQjjlLv6pJvx/z1iRFKzYb0XT/RuAQ==", + "version": "1.22.3", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.3.tgz", + "integrity": "sha512-eiiY8HQeYfYH2Con2berK+To6GrK2RxbPawDkGq4UiCQQfZHb6wX9qQqkbpPqaxQFcl8d9QzZqo0tGE0VcrdwA==", "dev": true, "requires": { - "call-bind": "^1.0.2", + "array-buffer-byte-length": "^1.0.0", + "arraybuffer.prototype.slice": "^1.0.2", + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.5", + "es-set-tostringtag": "^2.0.1", "es-to-primitive": "^1.2.1", - "function-bind": "^1.1.1", - "function.prototype.name": "^1.1.5", - "get-intrinsic": "^1.1.3", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.2", "get-symbol-description": "^1.0.0", + "globalthis": "^1.0.3", "gopd": "^1.0.1", - "has": "^1.0.3", "has-property-descriptors": "^1.0.0", + "has-proto": "^1.0.1", "has-symbols": "^1.0.3", - "internal-slot": "^1.0.3", + "hasown": "^2.0.0", + "internal-slot": "^1.0.5", + "is-array-buffer": "^3.0.2", "is-callable": "^1.2.7", "is-negative-zero": "^2.0.2", "is-regex": "^1.1.4", "is-shared-array-buffer": "^1.0.2", "is-string": "^1.0.7", + "is-typed-array": "^1.1.12", "is-weakref": "^1.0.2", - "object-inspect": "^1.12.2", + "object-inspect": "^1.13.1", "object-keys": "^1.1.1", "object.assign": "^4.1.4", - "regexp.prototype.flags": "^1.4.3", + "regexp.prototype.flags": "^1.5.1", + "safe-array-concat": "^1.0.1", "safe-regex-test": "^1.0.0", - "string.prototype.trimend": "^1.0.6", - "string.prototype.trimstart": "^1.0.6", - "unbox-primitive": "^1.0.2" + "string.prototype.trim": "^1.2.8", + "string.prototype.trimend": "^1.0.7", + "string.prototype.trimstart": "^1.0.7", + "typed-array-buffer": "^1.0.0", + "typed-array-byte-length": "^1.0.0", + "typed-array-byte-offset": "^1.0.0", + "typed-array-length": "^1.0.4", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.13" } }, "es-module-lexer": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.2.1.tgz", - "integrity": "sha512-9978wrXM50Y4rTMmW5kXIC09ZdXQZqkE4mxhwkd8VbzsGkXGPgV4zWuqQJgCEzYngdo2dYDa0l8xhX4fkSwJSg==" + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.4.1.tgz", + "integrity": "sha512-cXLGjP0c4T3flZJKQSuziYoq7MlT+rnvfZjfp7h+I7K9BNX54kP9nyWvdbwjQ4u1iWbOL4u96fgeZLToQlZC7w==" }, - "es-shim-unscopables": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.0.tgz", - "integrity": "sha512-Jm6GPcCdC30eMLbZ2x8z2WuRwAws3zTBBKuusffYVUrNj/GVSUAZ+xKMaUpfNDR5IbyNA5LJbaecoUVbmUcB1w==", + "es-set-tostringtag": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.2.tgz", + "integrity": "sha512-BuDyupZt65P9D2D2vA/zqcI3G5xRsklm5N3xCwuiy+/vKy8i0ifdsQP1sLgO4tZDSCaQUSnmC48khknGMV3D2Q==", "dev": true, "requires": { - "has": "^1.0.3" + "get-intrinsic": "^1.2.2", + "has-tostringtag": "^1.0.0", + "hasown": "^2.0.0" } }, "es-to-primitive": { @@ -9231,33 +9777,34 @@ } }, "esbuild": { - "version": "0.17.18", - "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.18.tgz", - "integrity": "sha512-z1lix43jBs6UKjcZVKOw2xx69ffE2aG0PygLL5qJ9OS/gy0Ewd1gW/PUQIOIQGXBHWNywSc0floSKoMFF8aK2w==", + "version": "0.19.11", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.19.11.tgz", + "integrity": "sha512-HJ96Hev2hX/6i5cDVwcqiJBBtuo9+FeIJOtZ9W1kA5M6AMJRHUZlpYZ1/SbEwtO0ioNAW8rUooVpC/WehY2SfA==", "peer": true, "requires": { - "@esbuild/android-arm": "0.17.18", - "@esbuild/android-arm64": "0.17.18", - "@esbuild/android-x64": "0.17.18", - "@esbuild/darwin-arm64": "0.17.18", - "@esbuild/darwin-x64": "0.17.18", - "@esbuild/freebsd-arm64": "0.17.18", - "@esbuild/freebsd-x64": "0.17.18", - "@esbuild/linux-arm": "0.17.18", - "@esbuild/linux-arm64": "0.17.18", - "@esbuild/linux-ia32": "0.17.18", - "@esbuild/linux-loong64": "0.17.18", - "@esbuild/linux-mips64el": "0.17.18", - "@esbuild/linux-ppc64": "0.17.18", - "@esbuild/linux-riscv64": "0.17.18", - "@esbuild/linux-s390x": "0.17.18", - "@esbuild/linux-x64": "0.17.18", - "@esbuild/netbsd-x64": "0.17.18", - "@esbuild/openbsd-x64": "0.17.18", - "@esbuild/sunos-x64": "0.17.18", - "@esbuild/win32-arm64": "0.17.18", - "@esbuild/win32-ia32": "0.17.18", - "@esbuild/win32-x64": "0.17.18" + "@esbuild/aix-ppc64": "0.19.11", + "@esbuild/android-arm": "0.19.11", + "@esbuild/android-arm64": "0.19.11", + "@esbuild/android-x64": "0.19.11", + "@esbuild/darwin-arm64": "0.19.11", + "@esbuild/darwin-x64": "0.19.11", + "@esbuild/freebsd-arm64": "0.19.11", + "@esbuild/freebsd-x64": "0.19.11", + "@esbuild/linux-arm": "0.19.11", + "@esbuild/linux-arm64": "0.19.11", + "@esbuild/linux-ia32": "0.19.11", + "@esbuild/linux-loong64": "0.19.11", + "@esbuild/linux-mips64el": "0.19.11", + "@esbuild/linux-ppc64": "0.19.11", + "@esbuild/linux-riscv64": "0.19.11", + "@esbuild/linux-s390x": "0.19.11", + "@esbuild/linux-x64": "0.19.11", + "@esbuild/netbsd-x64": "0.19.11", + "@esbuild/openbsd-x64": "0.19.11", + "@esbuild/sunos-x64": "0.19.11", + "@esbuild/win32-arm64": "0.19.11", + "@esbuild/win32-ia32": "0.19.11", + "@esbuild/win32-x64": "0.19.11" } }, "escalade": { @@ -9271,26 +9818,27 @@ "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==" }, "eslint": { - "version": "8.39.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.39.0.tgz", - "integrity": "sha512-mwiok6cy7KTW7rBpo05k6+p4YVZByLNjAZ/ACB9DRCu4YDRwjXI01tWHp6KAUWelsBetTxKK/2sHB0vdS8Z2Og==", + "version": "8.56.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.56.0.tgz", + "integrity": "sha512-Go19xM6T9puCOWntie1/P997aXxFsOi37JIHRWI514Hc6ZnaHGKY9xFhrU65RT6CcBEzZoGG1e6Nq+DT04ZtZQ==", "requires": { "@eslint-community/eslint-utils": "^4.2.0", - "@eslint-community/regexpp": "^4.4.0", - "@eslint/eslintrc": "^2.0.2", - "@eslint/js": "8.39.0", - "@humanwhocodes/config-array": "^0.11.8", + "@eslint-community/regexpp": "^4.6.1", + "@eslint/eslintrc": "^2.1.4", + "@eslint/js": "8.56.0", + "@humanwhocodes/config-array": "^0.11.13", "@humanwhocodes/module-importer": "^1.0.1", "@nodelib/fs.walk": "^1.2.8", - "ajv": "^6.10.0", + "@ungap/structured-clone": "^1.2.0", + "ajv": "^6.12.4", "chalk": "^4.0.0", "cross-spawn": "^7.0.2", "debug": "^4.3.2", "doctrine": "^3.0.0", "escape-string-regexp": "^4.0.0", - "eslint-scope": "^7.2.0", - "eslint-visitor-keys": "^3.4.0", - "espree": "^9.5.1", + "eslint-scope": "^7.2.2", + "eslint-visitor-keys": "^3.4.3", + "espree": "^9.6.1", "esquery": "^1.4.2", "esutils": "^2.0.2", "fast-deep-equal": "^3.1.3", @@ -9298,106 +9846,50 @@ "find-up": "^5.0.0", "glob-parent": "^6.0.2", "globals": "^13.19.0", - "grapheme-splitter": "^1.0.4", + "graphemer": "^1.4.0", "ignore": "^5.2.0", - "import-fresh": "^3.0.0", "imurmurhash": "^0.1.4", "is-glob": "^4.0.0", "is-path-inside": "^3.0.3", - "js-sdsl": "^4.1.4", "js-yaml": "^4.1.0", "json-stable-stringify-without-jsonify": "^1.0.1", "levn": "^0.4.1", "lodash.merge": "^4.6.2", "minimatch": "^3.1.2", "natural-compare": "^1.4.0", - "optionator": "^0.9.1", + "optionator": "^0.9.3", "strip-ansi": "^6.0.1", - "strip-json-comments": "^3.1.0", "text-table": "^0.2.0" }, "dependencies": { "eslint-scope": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.0.tgz", - "integrity": "sha512-DYj5deGlHBfMt15J7rdtyKNq/Nqlv5KfU4iodrQ019XESsRnwXH9KAE0y3cwtUHDo2ob7CypAnCqefh6vioWRw==", + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", + "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", "requires": { "esrecurse": "^4.3.0", "estraverse": "^5.2.0" } - } - } - }, - "eslint-config-prettier": { - "version": "8.8.0", - "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.8.0.tgz", - "integrity": "sha512-wLbQiFre3tdGgpDv67NQKnJuTlcUVYHas3k+DZCc2U2BadthoEY4B7hLPvAxaqdyOGCzuLfii2fqGph10va7oA==", - "dev": true, - "requires": {} - }, - "eslint-plugin-react": { - "version": "7.32.2", - "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.32.2.tgz", - "integrity": "sha512-t2fBMa+XzonrrNkyVirzKlvn5RXzzPwRHtMvLAtVZrt8oxgnTQaYbU6SXTOO1mwQgp1y5+toMSKInnzGr0Knqg==", - "dev": true, - "requires": { - "array-includes": "^3.1.6", - "array.prototype.flatmap": "^1.3.1", - "array.prototype.tosorted": "^1.1.1", - "doctrine": "^2.1.0", - "estraverse": "^5.3.0", - "jsx-ast-utils": "^2.4.1 || ^3.0.0", - "minimatch": "^3.1.2", - "object.entries": "^1.1.6", - "object.fromentries": "^2.0.6", - "object.hasown": "^1.1.2", - "object.values": "^1.1.6", - "prop-types": "^15.8.1", - "resolve": "^2.0.0-next.4", - "semver": "^6.3.0", - "string.prototype.matchall": "^4.0.8" - }, - "dependencies": { - "doctrine": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", - "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", - "dev": true, - "requires": { - "esutils": "^2.0.2" - } - }, - "resolve": { - "version": "2.0.0-next.4", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.4.tgz", - "integrity": "sha512-iMDbmAWtfU+MHpxt/I5iWI7cY6YVEZUQ3MBgPQ++XD1PELuJHIl82xBmObyP2KyQmkNB2dsqF7seoQQiAn5yDQ==", - "dev": true, - "requires": { - "is-core-module": "^2.9.0", - "path-parse": "^1.0.7", - "supports-preserve-symlinks-flag": "^1.0.0" - } }, - "semver": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", - "dev": true + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==" } } }, - "eslint-plugin-react-hooks": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz", - "integrity": "sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g==", + "eslint-config-prettier": { + "version": "9.1.0", + "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-9.1.0.tgz", + "integrity": "sha512-NSWl5BFQWEPi1j4TjVNItzYV7dZXZ+wP6I6ZhrBGpChQhZRUaElihE9uRRkcbRnNb76UMKDF3r+WTmNcGPKsqw==", "dev": true, "requires": {} }, "eslint-plugin-stylable": { "version": "file:packages/eslint-plugin-stylable", "requires": { - "@stylable/core": "^5.11.0", - "@typescript-eslint/experimental-utils": "^5.59.2" + "@stylable/core": "^5.17.0", + "@typescript-eslint/utils": "^5.61.0" } }, "eslint-scope": { @@ -9407,36 +9899,36 @@ "requires": { "esrecurse": "^4.3.0", "estraverse": "^4.1.1" - }, - "dependencies": { - "estraverse": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", - "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==" - } } }, "eslint-visitor-keys": { - "version": "3.4.0", - "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.0.tgz", - "integrity": "sha512-HPpKPUBQcAsZOsHAFwTtIKcYlCje62XB7SEAcxjtmW6TD1WVpkS6i6/hOVtTZIl4zGj/mBqpFVGvaDneik+VoQ==" + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", + "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==" }, "espree": { - "version": "9.5.1", - "resolved": "https://registry.npmjs.org/espree/-/espree-9.5.1.tgz", - "integrity": "sha512-5yxtHSZXRSW5pvv3hAlXM5+/Oswi1AUFqBmbibKb5s6bp3rGIDkyXU6xCoyuuLhijr4SFwPrXRoZjz0AZDN9tg==", + "version": "9.6.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", + "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", "requires": { - "acorn": "^8.8.0", + "acorn": "^8.9.0", "acorn-jsx": "^5.3.2", - "eslint-visitor-keys": "^3.4.0" + "eslint-visitor-keys": "^3.4.1" } }, "esquery": { - "version": "1.4.2", - "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.2.tgz", - "integrity": "sha512-JVSoLdTlTDkmjFmab7H/9SL9qGSyjElT3myyKp7krqjVFQCDLmj1QFaCLRFBszBKI0XVZaiiXvuPIX3ZwHe1Ng==", + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", + "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", "requires": { "estraverse": "^5.1.0" + }, + "dependencies": { + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==" + } } }, "esrecurse": { @@ -9445,12 +9937,19 @@ "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", "requires": { "estraverse": "^5.2.0" + }, + "dependencies": { + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==" + } } }, "estraverse": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", - "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==" + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==" }, "estree-walker": { "version": "2.0.2", @@ -9474,9 +9973,9 @@ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" }, "fast-glob": { - "version": "3.2.12", - "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.12.tgz", - "integrity": "sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==", + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", + "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", "requires": { "@nodelib/fs.stat": "^2.0.2", "@nodelib/fs.walk": "^1.2.3", @@ -9511,9 +10010,9 @@ "integrity": "sha512-483XLLxTVIwWK3QTrMGRqUfUpoOs/0hbQrl2oz4J0pAcm3A3bu84wxTFqGqkJzewCLdME38xJLJAxBABfQT8sQ==" }, "fastq": { - "version": "1.14.0", - "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.14.0.tgz", - "integrity": "sha512-eR2D+V9/ExcbF9ls441yIuN6TI2ED1Y2ZcA5BmMtJsOkWOFRJQ0Jt0g1UwqXJJVAb+V+umH5Dfr8oh4EVP7VVg==", + "version": "1.16.0", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.16.0.tgz", + "integrity": "sha512-ifCoaXsDrsdkWTtiNJX5uzHDsrck5TzfKKDcuFFTIrrc/BS076qgEIfoIy1VeZqViznfKiysPYTh/QeHtnIsYA==", "requires": { "reusify": "^1.0.4" } @@ -9567,11 +10066,12 @@ "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==" }, "flat-cache": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", - "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", + "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", "requires": { - "flatted": "^3.1.0", + "flatted": "^3.2.9", + "keyv": "^4.5.3", "rimraf": "^3.0.2" }, "dependencies": { @@ -9586,9 +10086,18 @@ } }, "flatted": { - "version": "3.2.7", - "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz", - "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==" + "version": "3.2.9", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz", + "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==" + }, + "for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "requires": { + "is-callable": "^1.1.3" + } }, "foreground-child": { "version": "2.0.0", @@ -9601,9 +10110,9 @@ } }, "fraction.js": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.2.0.tgz", - "integrity": "sha512-MhLuK+2gUcnZe8ZHlaaINnQLl0xRIGRfcGk2yl8xoQAfHrSsL3rYu6FCmBdkdbhc9EPlwyGHewaRsvwRMJtAlA==", + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.3.7.tgz", + "integrity": "sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew==", "dev": true }, "fs.realpath": { @@ -9612,27 +10121,27 @@ "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" }, "fsevents": { - "version": "2.3.2", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", - "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", + "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", "optional": true }, "function-bind": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", - "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", "dev": true }, "function.prototype.name": { - "version": "1.1.5", - "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.5.tgz", - "integrity": "sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA==", + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", + "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", "dev": true, "requires": { "call-bind": "^1.0.2", - "define-properties": "^1.1.3", - "es-abstract": "^1.19.0", - "functions-have-names": "^1.2.2" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "functions-have-names": "^1.2.3" } }, "functions-have-names": { @@ -9647,19 +10156,20 @@ "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==" }, "get-func-name": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", - "integrity": "sha512-Hm0ixYtaSZ/V7C8FJrtZIuBBI+iSgL+1Aq82zSu8VQNB4S3Gk8e7Qs3VwBDJAhmRZcFqkl3tQu36g/Foh5I5ig==" + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.2.tgz", + "integrity": "sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ==" }, "get-intrinsic": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.3.tgz", - "integrity": "sha512-QJVz1Tj7MS099PevUG5jvnt9tSkXN8K14dxQlikJuPt4uD9hHAHjLyLBiLR5zELelBdD9QNRAXZzsJx0WaDL9A==", + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.2.tgz", + "integrity": "sha512-0gSo4ml/0j98Y3lngkFEot/zhiCeWsbYIlZ+uZOVgzLyLaUw7wxUL+nCTP0XJvJg1AXulJRI3UJi8GsbDuxdGA==", "dev": true, "requires": { - "function-bind": "^1.1.1", - "has": "^1.0.3", - "has-symbols": "^1.0.3" + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" } }, "get-symbol-description": { @@ -9699,13 +10209,22 @@ "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==" }, "globals": { - "version": "13.20.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-13.20.0.tgz", - "integrity": "sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ==", + "version": "13.24.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", + "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", "requires": { "type-fest": "^0.20.2" } }, + "globalthis": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", + "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", + "dev": true, + "requires": { + "define-properties": "^1.1.3" + } + }, "globby": { "version": "11.1.0", "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", @@ -9729,23 +10248,14 @@ } }, "graceful-fs": { - "version": "4.2.10", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", - "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==" - }, - "grapheme-splitter": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz", - "integrity": "sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==" + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" }, - "has": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", - "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", - "dev": true, - "requires": { - "function-bind": "^1.1.1" - } + "graphemer": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", + "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==" }, "has-bigints": { "version": "1.0.2", @@ -9759,14 +10269,20 @@ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" }, "has-property-descriptors": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz", - "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==", + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.1.tgz", + "integrity": "sha512-VsX8eaIewvas0xnvinAe9bw4WfIeODpGYikiWYLH+dma0Jw6KHYqWiWfhQlgOVK8D6PvjubK5Uc4P0iIhIcNVg==", "dev": true, "requires": { - "get-intrinsic": "^1.1.1" + "get-intrinsic": "^1.2.2" } }, + "has-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", + "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", + "dev": true + }, "has-symbols": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", @@ -9782,6 +10298,15 @@ "has-symbols": "^1.0.2" } }, + "hasown": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.0.tgz", + "integrity": "sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA==", + "dev": true, + "requires": { + "function-bind": "^1.1.2" + } + }, "he": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", @@ -9816,9 +10341,9 @@ } }, "html-webpack-plugin": { - "version": "5.5.1", - "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-5.5.1.tgz", - "integrity": "sha512-cTUzZ1+NqjGEKjmVgZKLMdiFg3m9MdRXkZW2OEe69WYVi5ONLMmlnSZdXzGGMOq0C8jGDrL6EWyEDDUioHO/pA==", + "version": "5.6.0", + "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-5.6.0.tgz", + "integrity": "sha512-iwaY4wzbe48AfKLZ/Cc8k0L+FKG6oSNRaZ8x5A/T/IVDGyXcbHncM9TdDa93wn0FsSm82FhTKW7f3vS61thXAw==", "dev": true, "requires": { "@types/html-minifier-terser": "^6.0.0", @@ -9838,14 +10363,15 @@ "domhandler": "^4.0.0", "domutils": "^2.5.2", "entities": "^2.0.0" - }, - "dependencies": { - "entities": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", - "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", - "dev": true - } + } + }, + "iconv-lite": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", + "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", + "dev": true, + "requires": { + "safer-buffer": ">= 2.1.2 < 3.0.0" } }, "icss-utils": { @@ -9855,9 +10381,9 @@ "requires": {} }, "ignore": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.1.tgz", - "integrity": "sha512-d2qQLzTJ9WxQftPAuEQpSPmKqzxePjzVbpAVv62AQ64NTL+wR4JkrVqR/LqFsFEUsHDAiId52mJteHDFuDkElA==" + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.0.tgz", + "integrity": "sha512-g7dmpshy+gD7mh88OC9NwSGTKoc3kyLAZQRU1mt53Aw/vnvfXnbC+F/7F7QoYVKbV+KNvJx8wArewKy1vXMtlg==" }, "import-fresh": { "version": "3.3.0", @@ -9893,16 +10419,27 @@ "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" }, "internal-slot": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.4.tgz", - "integrity": "sha512-tA8URYccNzMo94s5MQZgH8NB/XTa6HsOo0MLfXTKKEnHVVdegzaQoFZ7Jp44bdvLvY2waT5dc+j5ICEswhi7UQ==", + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.6.tgz", + "integrity": "sha512-Xj6dv+PsbtwyPpEflsejS+oIZxmMlV44zAhG479uYu89MsjcYOhCFnNyKrkJrihbsiasQyY0afoCl/9BLR65bg==", "dev": true, "requires": { - "get-intrinsic": "^1.1.3", - "has": "^1.0.3", + "get-intrinsic": "^1.2.2", + "hasown": "^2.0.0", "side-channel": "^1.0.4" } }, + "is-array-buffer": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz", + "integrity": "sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.0", + "is-typed-array": "^1.1.10" + } + }, "is-arrayish": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", @@ -9953,12 +10490,12 @@ "dev": true }, "is-core-module": { - "version": "2.11.0", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz", - "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==", + "version": "2.13.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", + "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", "dev": true, "requires": { - "has": "^1.0.3" + "hasown": "^2.0.0" } }, "is-date-object": { @@ -10062,6 +10599,15 @@ "has-symbols": "^1.0.2" } }, + "is-typed-array": { + "version": "1.1.12", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.12.tgz", + "integrity": "sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg==", + "dev": true, + "requires": { + "which-typed-array": "^1.1.11" + } + }, "is-unicode-supported": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", @@ -10085,32 +10631,38 @@ "call-bind": "^1.0.2" } }, + "isarray": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", + "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", + "dev": true + }, "isexe": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" }, "istanbul-lib-coverage": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", - "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz", + "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==", "dev": true }, "istanbul-lib-report": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", - "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz", + "integrity": "sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==", "dev": true, "requires": { "istanbul-lib-coverage": "^3.0.0", - "make-dir": "^3.0.0", + "make-dir": "^4.0.0", "supports-color": "^7.1.0" } }, "istanbul-reports": { - "version": "3.1.5", - "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz", - "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==", + "version": "3.1.6", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.6.tgz", + "integrity": "sha512-TLgnMkKg3iTDsQ9PbPTdpfAK2DzjF9mqUG7RMgcQl8oFjad8ob4laGxv5XV5U9MAfx8D6tSJiUyuAwzLicaxlg==", "dev": true, "requires": { "html-escaper": "^2.0.0", @@ -10118,30 +10670,18 @@ } }, "jackspeak": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.0.3.tgz", - "integrity": "sha512-0Jud3OMUdMbrlr3PyUMKESq51LXVAB+a239Ywdvd+Kgxj3MaBRml/nVRxf8tQFyfthMjuRkxkv7Vg58pmIMfuQ==", + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.3.6.tgz", + "integrity": "sha512-N3yCS/NegsOBokc8GAdM8UcmfsKiSS8cipheD/nivzr700H+nsMOxJjQnvwOcRYVuFkdH0wGUvW2WbXGmrZGbQ==", "requires": { - "@pkgjs/parseargs": "^0.11.0", - "cliui": "^7.0.4" - }, - "dependencies": { - "cliui": { - "version": "7.0.4", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", - "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", - "requires": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.0", - "wrap-ansi": "^7.0.0" - } - } + "@isaacs/cliui": "^8.0.2", + "@pkgjs/parseargs": "^0.11.0" } }, "jest-docblock": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.4.3.tgz", - "integrity": "sha512-fzdTftThczeSD9nZ3fzA/4KkHtnmllawWrXO69vtI+L9WjEIuXWs4AmyME7lN5hU7dB0sHhuPfcKofRsUb/2Fg==", + "version": "29.7.0", + "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.7.0.tgz", + "integrity": "sha512-q617Auw3A612guyaFgsbFeYpNP5t2aoUNLwBUbc/0kD1R4t9ixDbyFTHd1nok4epoVFpr7PmeWHrhvuV3XaJ4g==", "requires": { "detect-newline": "^3.0.0" } @@ -10167,14 +10707,14 @@ } }, "js-beautify": { - "version": "1.14.7", - "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.14.7.tgz", - "integrity": "sha512-5SOX1KXPFKx+5f6ZrPsIPEY7NwKeQz47n3jm2i+XeHx9MoRsfQenlOP13FQhWvg8JRS0+XLO6XYUQ2GX+q+T9A==", + "version": "1.14.11", + "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.14.11.tgz", + "integrity": "sha512-rPogWqAfoYh1Ryqqh2agUpVfbxAhbjuN1SmU86dskQUKouRiggUTCO4+2ym9UPXllc2WAp0J+T5qxn7Um3lCdw==", "requires": { "config-chain": "^1.1.13", - "editorconfig": "^0.15.3", - "glob": "^8.0.3", - "nopt": "^6.0.0" + "editorconfig": "^1.0.3", + "glob": "^10.3.3", + "nopt": "^7.2.0" }, "dependencies": { "brace-expansion": { @@ -10185,33 +10725,42 @@ "balanced-match": "^1.0.0" } }, + "foreground-child": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.1.1.tgz", + "integrity": "sha512-TMKDUnIte6bfb5nWv7V/caI169OHgvwjb7V4WkeUvbQQdjr5rWKqHFiKWb/fcOwB+CzBT+qbWjvj+DVwRskpIg==", + "requires": { + "cross-spawn": "^7.0.0", + "signal-exit": "^4.0.1" + } + }, "glob": { - "version": "8.0.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-8.0.3.tgz", - "integrity": "sha512-ull455NHSHI/Y1FqGaaYFaLGkNMMJbavMrEGFXG/PGrg6y7sutWHUHrz6gy6WEBH6akM1M414dWKCNs+IhKdiQ==", + "version": "10.3.10", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.10.tgz", + "integrity": "sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g==", "requires": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^5.0.1", - "once": "^1.3.0" + "foreground-child": "^3.1.0", + "jackspeak": "^2.3.5", + "minimatch": "^9.0.1", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0", + "path-scurry": "^1.10.1" } }, "minimatch": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.1.tgz", - "integrity": "sha512-362NP+zlprccbEt/SkxKfRMHnNY85V74mVnpUpNyr3F35covl09Kec7/sEFLt3RA4oXmewtoaanoIf67SE5Y5g==", + "version": "9.0.3", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", + "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", "requires": { "brace-expansion": "^2.0.1" } + }, + "signal-exit": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", + "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==" } } }, - "js-sdsl": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.2.0.tgz", - "integrity": "sha512-dyBIzQBDkCqCu+0upx25Y2jGdbTGxE9fshMsCdK0ViOongpV+n5tXRcZY9v7CaVQ79AGS9KA1KHtojxiM7aXSQ==" - }, "js-tokens": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", @@ -10226,6 +10775,11 @@ "argparse": "^2.0.1" } }, + "json-buffer": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", + "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==" + }, "json-parse-better-errors": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", @@ -10248,19 +10802,17 @@ "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==" }, "json5": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.2.tgz", - "integrity": "sha512-46Tk9JiOL2z7ytNQWFLpj99RZkVgeHf87yGQKsIkaPz1qSH9UczKH1rO7K3wgRselo0tYMUNfecYpm/p1vC7tQ==", + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", + "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", "dev": true }, - "jsx-ast-utils": { - "version": "3.3.3", - "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.3.tgz", - "integrity": "sha512-fYQHZTZ8jSfmWZ0iyzfwiU4WDX4HpHbMCZ3gPlWYiCl3BoeOTsqKBqnTVfH2rYT7eP5c3sVbeSPHnnJOaTrWiw==", - "dev": true, + "keyv": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", + "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", "requires": { - "array-includes": "^3.1.5", - "object.assign": "^4.1.3" + "json-buffer": "3.0.1" } }, "levn": { @@ -10359,11 +10911,11 @@ } }, "loupe": { - "version": "2.3.6", - "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.6.tgz", - "integrity": "sha512-RaPMZKiMy8/JruncMU5Bt6na1eftNoo++R4Y+N2FrxkDVTrGvcyzFTsaGif4QTeKESheMGegbhw6iUAq+5A8zA==", + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.7.tgz", + "integrity": "sha512-zSMINGVYkdpYSOBmLi0D1Uo7JU9nVdQKrHxC8eYlV+9YKK9WePqAlL7lSlorG/U2Fw1w0hTBmaa/jrQ3UbPHtA==", "requires": { - "get-func-name": "^2.0.0" + "get-func-name": "^2.0.1" } }, "lower-case": { @@ -10384,20 +10936,12 @@ } }, "make-dir": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", - "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz", + "integrity": "sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==", "dev": true, "requires": { - "semver": "^6.0.0" - }, - "dependencies": { - "semver": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", - "dev": true - } + "semver": "^7.5.3" } }, "mdn-data": { @@ -10449,18 +10993,18 @@ } }, "mini-css-extract-plugin": { - "version": "2.7.5", - "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-2.7.5.tgz", - "integrity": "sha512-9HaR++0mlgom81s95vvNjxkg52n2b5s//3ZTI1EtzFb98awsLSivs2LMsVqnQ3ay0PVhqWcGNyDaTE961FOcjQ==", + "version": "2.7.6", + "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-2.7.6.tgz", + "integrity": "sha512-Qk7HcgaPkGG6eD77mLvZS1nmxlao3j+9PkrT9Uc7HAE1id3F41+DdBRYRYkbyfNRGzm8/YWtzhw7nVPmwhqTQw==", "dev": true, "requires": { "schema-utils": "^4.0.0" }, "dependencies": { "ajv": { - "version": "8.11.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.11.2.tgz", - "integrity": "sha512-E4bfmKAhGiSTvMfL1Myyycaub+cUEU2/IvpylXkUu7CHBkBj1f/ikdzbD7YQ6FKUbixDxeYvB/xY4fvyroDlQg==", + "version": "8.12.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.12.0.tgz", + "integrity": "sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==", "dev": true, "requires": { "fast-deep-equal": "^3.1.1", @@ -10485,15 +11029,15 @@ "dev": true }, "schema-utils": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.0.0.tgz", - "integrity": "sha512-1edyXKgh6XnJsJSQ8mKWXnN/BVaIbFMLpouRUrXgVq7WYne5kw3MW7UPhO44uRXQSIpTSXoJbmrR2X0w9kUTyg==", + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.2.0.tgz", + "integrity": "sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw==", "dev": true, "requires": { "@types/json-schema": "^7.0.9", - "ajv": "^8.8.0", + "ajv": "^8.9.0", "ajv-formats": "^2.1.1", - "ajv-keywords": "^5.0.0" + "ajv-keywords": "^5.1.0" } } } @@ -10513,9 +11057,9 @@ "dev": true }, "minipass": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz", - "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==" + "version": "7.0.4", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.0.4.tgz", + "integrity": "sha512-jYofLM5Dam9279rdkWzqHozUo4ybjdZmCsDHePy5V/PbBcVMiSZR97gmAy45aqi8CK1lG2ECd356FU86avfwUQ==" }, "mocha": { "version": "10.2.0", @@ -10665,16 +11209,16 @@ } }, "node-releases": { - "version": "2.0.10", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.10.tgz", - "integrity": "sha512-5GFldHPXVG/YZmFzJvKK2zDSzPKhEp0+ZR5SVaoSag9fsL5YgHbUHDfnG5494ISANDcK4KwPXAx2xqVEydmd7w==" + "version": "2.0.14", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", + "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==" }, "nopt": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/nopt/-/nopt-6.0.0.tgz", - "integrity": "sha512-ZwLpbTgdhuZUnZzjd7nb1ZV+4DoiC6/sfiVKok72ym/4Tlf+DFdlHYmT2JPmcNNWV6Pi3SDf1kT+A4r9RTuT9g==", + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/nopt/-/nopt-7.2.0.tgz", + "integrity": "sha512-CVDtwCdhYIvnAzFoJ6NJ6dX3oga9/HyciQDnG1vQDjSLMeKLJ4A93ZqYKDrgYSr1FBY5/hMYC+2VCi24pgpkGA==", "requires": { - "abbrev": "^1.0.0" + "abbrev": "^2.0.0" } }, "normalize-package-data": { @@ -10690,9 +11234,9 @@ }, "dependencies": { "semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", "dev": true } } @@ -10793,9 +11337,9 @@ "dev": true }, "semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", "dev": true }, "shebang-command": { @@ -10842,16 +11386,10 @@ "boolbase": "^1.0.0" } }, - "object-assign": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", - "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", - "dev": true - }, "object-inspect": { - "version": "1.12.2", - "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", - "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==", + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", + "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", "dev": true }, "object-keys": { @@ -10861,60 +11399,17 @@ "dev": true }, "object.assign": { - "version": "4.1.4", - "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.4.tgz", - "integrity": "sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ==", + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", + "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", "dev": true, "requires": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", "has-symbols": "^1.0.3", "object-keys": "^1.1.1" } }, - "object.entries": { - "version": "1.1.6", - "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.6.tgz", - "integrity": "sha512-leTPzo4Zvg3pmbQ3rDK69Rl8GQvIqMWubrkxONG9/ojtFE2rD9fjMKfSI5BxW3osRH1m6VdzmqK8oAY9aT4x5w==", - "dev": true, - "requires": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - } - }, - "object.fromentries": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.6.tgz", - "integrity": "sha512-VciD13dswC4j1Xt5394WR4MzmAQmlgN72phd/riNp9vtD7tp4QQWJ0R4wvclXcafgcYK8veHRed2W6XeGBvcfg==", - "dev": true, - "requires": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - } - }, - "object.hasown": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/object.hasown/-/object.hasown-1.1.2.tgz", - "integrity": "sha512-B5UIT3J1W+WuWIU55h0mjlwaqxiE5vYENJXIXZ4VFe05pNYrkKuK0U/6aFcb0pKywYJh7IhfoqUfKVmrJJHZHw==", - "dev": true, - "requires": { - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - } - }, - "object.values": { - "version": "1.1.6", - "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.6.tgz", - "integrity": "sha512-FVVTkD1vENCsAcwNs9k6jea2uHC/X0+JcjG8YA60FN5CMaJmG95wT9jek/xX9nornqGRrBkKtzuAu2wuHpKqvw==", - "dev": true, - "requires": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - } - }, "once": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", @@ -10924,16 +11419,16 @@ } }, "optionator": { - "version": "0.9.1", - "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", - "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", + "version": "0.9.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", + "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", "requires": { + "@aashutoshrathi/word-wrap": "^1.2.3", "deep-is": "^0.1.3", "fast-levenshtein": "^2.0.6", "levn": "^0.4.1", "prelude-ls": "^1.2.1", - "type-check": "^0.4.0", - "word-wrap": "^1.2.3" + "type-check": "^0.4.0" } }, "os-homedir": { @@ -11017,18 +11512,18 @@ "dev": true }, "path-scurry": { - "version": "1.7.0", - "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.7.0.tgz", - "integrity": "sha512-UkZUeDjczjYRE495+9thsgcVgsaCPkaw80slmfVFgllxY+IO8ubTsOpFVjDPROBqJdHfVPUFRHPBV/WciOVfWg==", + "version": "1.10.1", + "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.10.1.tgz", + "integrity": "sha512-MkhCqzzBEpPvxxQ71Md0b1Kk51W01lrYvlMzSUaIzNsODdd7mqhiimSZlr+VegAz5Z6Vzt9Xg2ttE//XBhH3EQ==", "requires": { - "lru-cache": "^9.0.0", - "minipass": "^5.0.0" + "lru-cache": "^9.1.1 || ^10.0.0", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" }, "dependencies": { "lru-cache": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-9.1.0.tgz", - "integrity": "sha512-qFXQEwchrZcMVen2uIDceR8Tii6kCJak5rzDStfEM0qA3YLMswaxIEZO0DhIbJ3aqaJiDjt+3crlplOb0tDtKQ==" + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.1.0.tgz", + "integrity": "sha512-/1clY/ui8CzjKFyjdvwPWJUYKiFVXG2I2cY0ssG7h4+hwk+XOIX7ZSG9Q7TW8TW3Kp3BUSqgFWBLgL4PJ+Blag==" } } }, @@ -11065,33 +11560,33 @@ "dev": true }, "playwright-chromium": { - "version": "1.33.0", - "resolved": "https://registry.npmjs.org/playwright-chromium/-/playwright-chromium-1.33.0.tgz", - "integrity": "sha512-aG2IqRp7Q6vRltZFT+N2stWwDUH2fEUTOTv8RxSKMK5QmIQQoNL9nJvNMIJ3yLuin8+coaa3mhJXjjUheo0+/A==", + "version": "1.40.1", + "resolved": "https://registry.npmjs.org/playwright-chromium/-/playwright-chromium-1.40.1.tgz", + "integrity": "sha512-3atylP47OCTBW0siGI7LOEG/XKL/vnrFH8xdr4uaTnqMsc0Xq4gOLk2gGwniPJ76LSc++9ASc0w/nfqtLAmm3A==", "dev": true, "requires": { - "playwright-core": "1.33.0" + "playwright-core": "1.40.1" } }, "playwright-core": { - "version": "1.33.0", - "resolved": "https://registry.npmjs.org/playwright-core/-/playwright-core-1.33.0.tgz", - "integrity": "sha512-aizyPE1Cj62vAECdph1iaMILpT0WUDCq3E6rW6I+dleSbBoGbktvJtzS6VHkZ4DKNEOG9qJpiom/ZxO+S15LAw==" + "version": "1.40.1", + "resolved": "https://registry.npmjs.org/playwright-core/-/playwright-core-1.40.1.tgz", + "integrity": "sha512-+hkOycxPiV534c4HhpfX6yrlawqVUzITRKwHAmYfmsVreltEl6fAZJ3DPfLMOODw0H3s1Itd6MDCWmP1fl/QvQ==" }, "postcss": { - "version": "8.4.23", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.23.tgz", - "integrity": "sha512-bQ3qMcpF6A/YjR55xtoTr0jGOlnPOKAIMdOWiv0EIT6HVPEaJiJB4NLljSbiHoC2RX7DN5Uvjtpbg1NPdwv1oA==", + "version": "8.4.32", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.32.tgz", + "integrity": "sha512-D/kj5JNu6oo2EIy+XL/26JEDTlIbB8hw85G8StOE6L74RQAVVP5rej6wxCNqyMbR4RkPfqvezVbPw81Ngd6Kcw==", "requires": { - "nanoid": "^3.3.6", + "nanoid": "^3.3.7", "picocolors": "^1.0.0", "source-map-js": "^1.0.2" }, "dependencies": { "nanoid": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", - "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==" + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", + "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==" } } }, @@ -11110,9 +11605,9 @@ "requires": {} }, "postcss-modules-local-by-default": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.0.tgz", - "integrity": "sha512-sT7ihtmGSF9yhm6ggikHdV0hlziDTX7oFoXtuVWeDd3hHObNkcHRo9V3yg7vCAY7cONyxJC/XXCmmiHHcvX7bQ==", + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.3.tgz", + "integrity": "sha512-2/u2zraspoACtrbFRnTijMiQtb4GW4BvatjaG/bCjYQo8kLTdevCUlwuBHx2sCnSyrI3x3qj4ZK1j5LQBgzmwA==", "requires": { "icss-utils": "^5.0.0", "postcss-selector-parser": "^6.0.2", @@ -11120,9 +11615,9 @@ } }, "postcss-modules-scope": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-3.0.0.tgz", - "integrity": "sha512-hncihwFA2yPath8oZ15PZqvWGkWf+XUfQgUGamS4LqoP1anQLOsOJw0vr7J7IwLpoY9fatA2qiGUGmuZL0Iqlg==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-3.1.0.tgz", + "integrity": "sha512-SaIbK8XW+MZbd0xHPf7kdfA/3eOt7vxJ72IRecn3EzuZVLr1r0orzf0MX/pN8m+NMDoo6X/SQd8oeKqGZd8PXg==", "requires": { "postcss-selector-parser": "^6.0.4" } @@ -11150,9 +11645,9 @@ "requires": {} }, "postcss-selector-parser": { - "version": "6.0.11", - "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.11.tgz", - "integrity": "sha512-zbARubNdogI9j7WY4nQJBiNqQf3sLS3wCP4WfOidu+p28LofJqDH1tcXypGrcmMHhDk2t9wGhCsYe/+szLTy1g==", + "version": "6.0.15", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.15.tgz", + "integrity": "sha512-rEYkQOMUCEMhsKbK66tbEU9QVIxbhN18YiniAwA7XQYTVBqrBy+P2p5JcdqsHgKM2zWylp8d7J6eszocfds5Sw==", "requires": { "cssesc": "^3.0.0", "util-deprecate": "^1.0.2" @@ -11184,26 +11679,15 @@ "integrity": "sha512-hKLG+bqLZt7WjuGqgwa12pWyph23bEiqYR16WCnZQxpuveDBABKP4tRcSdMWlxIcEBN0MLsUs+VBH+TlaIHtgA==", "dev": true }, - "prop-types": { - "version": "15.8.1", - "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", - "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", - "dev": true, - "requires": { - "loose-envify": "^1.4.0", - "object-assign": "^4.1.1", - "react-is": "^16.13.1" - } - }, "proto-list": { "version": "1.2.4", "resolved": "https://registry.npmjs.org/proto-list/-/proto-list-1.2.4.tgz", "integrity": "sha512-vtK/94akxsTMhe0/cbfpR+syPuszcuwhqVjJq26CuNDgFGj682oRBXOP5MJpv2r7JtE8MsiepGIqvvOTBwn2vA==" }, - "pseudomap": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", - "integrity": "sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ==" + "punycode": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==" }, "queue-microtask": { "version": "1.2.3", @@ -11247,12 +11731,6 @@ "scheduler": "^0.23.0" } }, - "react-is": { - "version": "16.13.1", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", - "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", - "dev": true - }, "read-pkg": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", @@ -11285,14 +11763,14 @@ } }, "regexp.prototype.flags": { - "version": "1.4.3", - "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.4.3.tgz", - "integrity": "sha512-fjggEOO3slI6Wvgjwflkc4NFRCTZAu5CnNfBd5qOMYhWdn67nJBBu34/TkD++eeFmd8C9r9jfXJ27+nSiRkSUA==", + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz", + "integrity": "sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg==", "dev": true, "requires": { "call-bind": "^1.0.2", - "define-properties": "^1.1.3", - "functions-have-names": "^1.2.2" + "define-properties": "^1.2.0", + "set-function-name": "^2.0.0" } }, "relateurl": { @@ -11326,12 +11804,12 @@ "dev": true }, "resolve": { - "version": "1.22.1", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", - "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", + "version": "1.22.8", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", + "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", "dev": true, "requires": { - "is-core-module": "^2.9.0", + "is-core-module": "^2.13.0", "path-parse": "^1.0.7", "supports-preserve-symlinks-flag": "^1.0.0" } @@ -11347,11 +11825,11 @@ "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==" }, "rimraf": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-5.0.0.tgz", - "integrity": "sha512-Jf9llaP+RvaEVS5nPShYFhtXIrb3LRKP281ib3So0KkeZKo2wIKyq0Re7TOSwanasA423PSr6CCIL4bP6T040g==", + "version": "5.0.5", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-5.0.5.tgz", + "integrity": "sha512-CqDakW+hMe/Bz202FPEymy68P+G50RfMQK+Qo5YUqc9SPipvbGjCGKd0RSKEelbsfQuw3g5NZDSrlZZAJurH1A==", "requires": { - "glob": "^10.0.0" + "glob": "^10.3.7" }, "dependencies": { "brace-expansion": { @@ -11372,38 +11850,50 @@ } }, "glob": { - "version": "10.2.1", - "resolved": "https://registry.npmjs.org/glob/-/glob-10.2.1.tgz", - "integrity": "sha512-ngom3wq2UhjdbmRE/krgkD8BQyi1KZ5l+D2dVm4+Yj+jJIBp74/ZGunL6gNGc/CYuQmvUBiavWEXIotRiv5R6A==", + "version": "10.3.10", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.10.tgz", + "integrity": "sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g==", "requires": { "foreground-child": "^3.1.0", - "fs.realpath": "^1.0.0", - "jackspeak": "^2.0.3", - "minimatch": "^9.0.0", - "minipass": "^5.0.0", - "path-scurry": "^1.7.0" + "jackspeak": "^2.3.5", + "minimatch": "^9.0.1", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0", + "path-scurry": "^1.10.1" } }, "minimatch": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.0.tgz", - "integrity": "sha512-0jJj8AvgKqWN05mrwuqi8QYKx1WmYSUoKSxu5Qhs9prezTz10sxAHGNZe9J9cqIJzta8DWsleh2KaVaLl6Ru2w==", + "version": "9.0.3", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", + "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", "requires": { "brace-expansion": "^2.0.1" } }, "signal-exit": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.0.1.tgz", - "integrity": "sha512-uUWsN4aOxJAS8KOuf3QMyFtgm1pkb6I+KRZbRF/ghdf5T7sM+B1lLLzPDxswUjkmHyxQAVzEgG35E3NzDM9GVw==" + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", + "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==" } } }, "rollup": { - "version": "3.21.3", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.21.3.tgz", - "integrity": "sha512-VnPfEG51nIv2xPLnZaekkuN06q9ZbnyDcLkaBdJa/W7UddyhOfMP2yOPziYQfeY7k++fZM8FdQIummFN5y14kA==", - "requires": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.9.2.tgz", + "integrity": "sha512-66RB8OtFKUTozmVEh3qyNfH+b+z2RXBVloqO2KCC/pjFaGaHtxP9fVfOQKPSGXg2mElmjmxjW/fZ7iKrEpMH5Q==", + "requires": { + "@rollup/rollup-android-arm-eabi": "4.9.2", + "@rollup/rollup-android-arm64": "4.9.2", + "@rollup/rollup-darwin-arm64": "4.9.2", + "@rollup/rollup-darwin-x64": "4.9.2", + "@rollup/rollup-linux-arm-gnueabihf": "4.9.2", + "@rollup/rollup-linux-arm64-gnu": "4.9.2", + "@rollup/rollup-linux-arm64-musl": "4.9.2", + "@rollup/rollup-linux-riscv64-gnu": "4.9.2", + "@rollup/rollup-linux-x64-gnu": "4.9.2", + "@rollup/rollup-linux-x64-musl": "4.9.2", + "@rollup/rollup-win32-arm64-msvc": "4.9.2", + "@rollup/rollup-win32-ia32-msvc": "4.9.2", + "@rollup/rollup-win32-x64-msvc": "4.9.2", "fsevents": "~2.3.2" } }, @@ -11415,6 +11905,18 @@ "queue-microtask": "^1.2.2" } }, + "safe-array-concat": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.0.1.tgz", + "integrity": "sha512-6XbUAseYE2KtOuGueyeobCySj9L4+66Tn6KQMOPQJrAJEowYKW/YR/MGJZl7FdydUdaFu4LYyDZjxf4/Nmo23Q==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1", + "has-symbols": "^1.0.3", + "isarray": "^2.0.5" + } + }, "safe-buffer": { "version": "5.2.1", "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", @@ -11447,9 +11949,9 @@ } }, "schema-utils": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.1.2.tgz", - "integrity": "sha512-pvjEHOgWc9OWA/f/DE3ohBWTD6EleVLf7iFUkoSwAxttdBhB9QUebQgxER2kWueOvRJXPHNnyrvvh9eZINB8Eg==", + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz", + "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==", "requires": { "@types/json-schema": "^7.0.8", "ajv": "^6.12.5", @@ -11457,9 +11959,9 @@ } }, "semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", + "version": "7.5.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", + "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", "requires": { "lru-cache": "^6.0.0" } @@ -11473,6 +11975,29 @@ "randombytes": "^2.1.0" } }, + "set-function-length": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.1.1.tgz", + "integrity": "sha512-VoaqjbBJKiWtg4yRcKBQ7g7wnGnLV3M8oLvVWwOk2PdYY6PEFegR1vezXR0tw6fZGF9csVakIRjrJiy2veSBFQ==", + "dev": true, + "requires": { + "define-data-property": "^1.1.1", + "get-intrinsic": "^1.2.1", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.0" + } + }, + "set-function-name": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.1.tgz", + "integrity": "sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA==", + "dev": true, + "requires": { + "define-data-property": "^1.0.1", + "functions-have-names": "^1.2.3", + "has-property-descriptors": "^1.0.0" + } + }, "shebang-command": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", @@ -11487,9 +12012,9 @@ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==" }, "shell-quote": { - "version": "1.7.4", - "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.4.tgz", - "integrity": "sha512-8o/QEhSSRb1a5i7TFR0iM4G16Z0vYB2OQVs4G3aAFXjn3T6yEx8AZxy1PgDF7I00LZHYA3WxaSYIf5e5sAX8Rw==", + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.8.1.tgz", + "integrity": "sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==", "dev": true }, "side-channel": { @@ -11503,11 +12028,6 @@ "object-inspect": "^1.9.0" } }, - "sigmund": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/sigmund/-/sigmund-1.0.1.tgz", - "integrity": "sha512-fCvEXfh6NWpm+YSuY2bpXb/VIihqWA6hLsgboC+0nl71Q7N7o2eaCW8mJa/NLvQhs6jpd3VZV4UiUQlV6+lc8g==" - }, "signal-exit": { "version": "3.0.7", "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", @@ -11531,25 +12051,13 @@ "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==" }, "source-map-loader": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/source-map-loader/-/source-map-loader-4.0.1.tgz", - "integrity": "sha512-oqXpzDIByKONVY8g1NUPOTQhe0UTU5bWUl32GSkqK2LjJj0HmwTMVKxcUip0RgAYhY1mqgOxjbQM48a0mmeNfA==", + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/source-map-loader/-/source-map-loader-4.0.2.tgz", + "integrity": "sha512-oYwAqCuL0OZhBoSgmdrLa7mv9MjommVMiQIWgcztf+eS4+8BfcUee6nenFnDhKOhzAVnk5gpZdfnz1iiBv+5sg==", "dev": true, "requires": { - "abab": "^2.0.6", "iconv-lite": "^0.6.3", "source-map-js": "^1.0.2" - }, - "dependencies": { - "iconv-lite": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", - "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", - "dev": true, - "requires": { - "safer-buffer": ">= 2.1.2 < 3.0.0" - } - } } }, "source-map-support": { @@ -11569,9 +12077,9 @@ } }, "spdx-correct": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", - "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz", + "integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==", "dev": true, "requires": { "spdx-expression-parse": "^3.0.0", @@ -11595,9 +12103,9 @@ } }, "spdx-license-ids": { - "version": "3.0.12", - "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.12.tgz", - "integrity": "sha512-rr+VVSXtRhO4OHbXUiAF7xW3Bo9DuuF6C5jH+q/x15j2jniycgKbxU09Hr0WqlSLUs4i4ltHGXqTe7VHclYWyA==", + "version": "3.0.16", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.16.tgz", + "integrity": "sha512-eWN+LnM3GR6gPu35WxNgbGl8rmY1AEmoMDvL/QD6zYmPWgywxWqJWNdLGT+ke8dKNWrcYgYjPpG5gbTfghP8rw==", "dev": true }, "string-width": { @@ -11610,53 +12118,58 @@ "strip-ansi": "^6.0.1" } }, - "string.prototype.matchall": { - "version": "4.0.8", - "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.8.tgz", - "integrity": "sha512-6zOCOcJ+RJAQshcTvXPHoxoQGONa3e/Lqx90wUA+wEzX78sg5Bo+1tQo4N0pohS0erG9qtCqJDjNCQBjeWVxyg==", + "string-width-cjs": { + "version": "npm:string-width@4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + } + }, + "string.prototype.padend": { + "version": "3.1.5", + "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.5.tgz", + "integrity": "sha512-DOB27b/2UTTD+4myKUFh+/fXWcu/UDyASIXfg+7VzoCNNGOfWvoyU/x5pvVHr++ztyt/oSYI1BcWBBG/hmlNjA==", "dev": true, "requires": { "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "get-intrinsic": "^1.1.3", - "has-symbols": "^1.0.3", - "internal-slot": "^1.0.3", - "regexp.prototype.flags": "^1.4.3", - "side-channel": "^1.0.4" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" } }, - "string.prototype.padend": { - "version": "3.1.4", - "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.4.tgz", - "integrity": "sha512-67otBXoksdjsnXXRUq+KMVTdlVRZ2af422Y0aTyTjVaoQkGr3mxl2Bc5emi7dOQ3OGVVQQskmLEWwFXwommpNw==", + "string.prototype.trim": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz", + "integrity": "sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==", "dev": true, "requires": { "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" } }, "string.prototype.trimend": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.6.tgz", - "integrity": "sha512-JySq+4mrPf9EsDBEDYMOb/lM7XQLulwg5R/m1r0PXEFqrV0qHvl58sdTilSXtKOflCsK2E8jxf+GKC0T07RWwQ==", + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz", + "integrity": "sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==", "dev": true, "requires": { "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" } }, "string.prototype.trimstart": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.6.tgz", - "integrity": "sha512-omqjMDaY92pbn5HOX7f9IccLA+U1tA9GvtU4JrodiXFfYB7jPzzHpRzpglLAjtUV6bB557zwClJezTqnAiYnQA==", + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", + "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", "dev": true, "requires": { "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" } }, "strip-ansi": { @@ -11667,6 +12180,14 @@ "ansi-regex": "^5.0.1" } }, + "strip-ansi-cjs": { + "version": "npm:strip-ansi@6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "requires": { + "ansi-regex": "^5.0.1" + } + }, "strip-bom": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", @@ -11679,9 +12200,9 @@ "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==" }, "style-loader": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/style-loader/-/style-loader-3.3.2.tgz", - "integrity": "sha512-RHs/vcrKdQK8wZliteNK4NKzxvLBzpuHMqYmUVWeKa6MkaIQ97ZTOS0b+zapZhy6GcrgWnvWYCMHRirC3FsUmw==", + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/style-loader/-/style-loader-3.3.3.tgz", + "integrity": "sha512-53BiGLXAcll9maCYtZi2RCQZKa8NQQai5C4horqKyRmHj9H7QmcUyucrH+4KW/gBQbXM2AsB0axoEcFZPlfPcw==", "dev": true, "requires": {} }, @@ -11705,12 +12226,12 @@ "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==" }, "terser": { - "version": "5.17.1", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.17.1.tgz", - "integrity": "sha512-hVl35zClmpisy6oaoKALOpS0rDYLxRFLHhRuDlEGTKey9qHjS1w9GMORjuwIMt70Wan4lwsLYyWDVnWgF+KUEw==", + "version": "5.26.0", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.26.0.tgz", + "integrity": "sha512-dytTGoE2oHgbNV9nTzgBEPaqAWvcJNl66VZ0BkJqlvp71IjO8CxdBx/ykCNb47cLnCmCvRZ6ZR0tLkqvZCdVBQ==", "requires": { - "@jridgewell/source-map": "^0.3.2", - "acorn": "^8.5.0", + "@jridgewell/source-map": "^0.3.3", + "acorn": "^8.8.2", "commander": "^2.20.0", "source-map-support": "~0.5.20" }, @@ -11723,15 +12244,15 @@ } }, "terser-webpack-plugin": { - "version": "5.3.7", - "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.7.tgz", - "integrity": "sha512-AfKwIktyP7Cu50xNjXF/6Qb5lBNzYaWpU6YfoX3uZicTx0zTy0stDDCsvjDapKsSDvOeWo5MEq4TmdBy2cNoHw==", + "version": "5.3.10", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.10.tgz", + "integrity": "sha512-BKFPWlPDndPs+NGGCr1U59t0XScL5317Y0UReNrHaw9/FwhPENlq6bfgs+4yPfyP51vqC1bQ4rp1EfXW5ZSH9w==", "requires": { - "@jridgewell/trace-mapping": "^0.3.17", + "@jridgewell/trace-mapping": "^0.3.20", "jest-worker": "^27.4.5", "schema-utils": "^3.1.1", "serialize-javascript": "^6.0.1", - "terser": "^5.16.5" + "terser": "^5.26.0" }, "dependencies": { "serialize-javascript": { @@ -11775,9 +12296,9 @@ "dev": true }, "tsconfig-paths": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-4.1.2.tgz", - "integrity": "sha512-uhxiMgnXQp1IR622dUXI+9Ehnws7i/y6xvpZB9IbUVOPy0muvdvgXeZOn88UcGPiT98Vp3rJPTa8bFoalZ3Qhw==", + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-4.2.0.tgz", + "integrity": "sha512-NoZ4roiN7LnbKn9QqE1amc9DJfzvZXxF4xDavcOWt1BPkdx+m+0gJuPM+S0vCe7zTJMYUP0R8pO2XMr+Y8oLIg==", "dev": true, "requires": { "json5": "^2.2.2", @@ -11786,9 +12307,9 @@ } }, "tsconfig-paths-webpack-plugin": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/tsconfig-paths-webpack-plugin/-/tsconfig-paths-webpack-plugin-4.0.1.tgz", - "integrity": "sha512-m5//KzLoKmqu2MVix+dgLKq70MnFi8YL8sdzQZ6DblmCdfuq/y3OqvJd5vMndg2KEVCOeNz8Es4WVZhYInteLw==", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/tsconfig-paths-webpack-plugin/-/tsconfig-paths-webpack-plugin-4.1.0.tgz", + "integrity": "sha512-xWFISjviPydmtmgeUAuXp4N1fky+VCtfhOkDUFIv5ea7p4wuTomI4QTrXvFBX2S4jZsmyTSrStQl+E+4w+RzxA==", "dev": true, "requires": { "chalk": "^4.1.0", @@ -11797,9 +12318,9 @@ } }, "tslib": { - "version": "2.4.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.1.tgz", - "integrity": "sha512-tGyy4dAjRIEwI7BzsB0lynWgOpfqjUdq91XXAlIWD2OwKBH7oCl/GZG/HT4BOHrTlPMOASlMQ7veyTqpmRcrNA==", + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", + "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", "dev": true }, "tsutils": { @@ -11835,10 +12356,57 @@ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==" }, + "typed-array-buffer": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz", + "integrity": "sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1", + "is-typed-array": "^1.1.10" + } + }, + "typed-array-byte-length": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz", + "integrity": "sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "has-proto": "^1.0.1", + "is-typed-array": "^1.1.10" + } + }, + "typed-array-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz", + "integrity": "sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg==", + "dev": true, + "requires": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "has-proto": "^1.0.1", + "is-typed-array": "^1.1.10" + } + }, + "typed-array-length": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz", + "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "is-typed-array": "^1.1.9" + } + }, "typescript": { - "version": "5.0.4", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.0.4.tgz", - "integrity": "sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw==" + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.2.2.tgz", + "integrity": "sha512-mI4WrpHsbCIcwT9cF4FZvr80QUeKvsUsUvKDoR+X/7XHQH98xYD8YHZg7ANtz2GtZt/CBq2QJ0thkGJMHfqc1w==" }, "unbox-primitive": { "version": "1.0.2", @@ -11853,9 +12421,9 @@ } }, "update-browserslist-db": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz", - "integrity": "sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ==", + "version": "1.0.13", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", + "integrity": "sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==", "requires": { "escalade": "^3.1.1", "picocolors": "^1.0.0" @@ -11867,13 +12435,6 @@ "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", "requires": { "punycode": "^2.1.0" - }, - "dependencies": { - "punycode": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", - "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" - } } }, "url-loader": { @@ -11907,14 +12468,14 @@ "dev": true }, "v8-to-istanbul": { - "version": "9.0.1", - "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.0.1.tgz", - "integrity": "sha512-74Y4LqY74kLE6IFyIjPtkSTWzUZmj8tdHT9Ii/26dvQ6K9Dl2NbEfj0XgU2sHCtKgt5VupqhlO/5aWuqS+IY1w==", + "version": "9.2.0", + "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.2.0.tgz", + "integrity": "sha512-/EH/sDgxU2eGxajKdwLCDmQ4FWq+kpi3uCmBGpw1xJtnAxEjlD8j8PEiGWpCIMIs3ciNAgH0d3TTJiUkYzyZjA==", "dev": true, "requires": { "@jridgewell/trace-mapping": "^0.3.12", "@types/istanbul-lib-coverage": "^2.0.1", - "convert-source-map": "^1.6.0" + "convert-source-map": "^2.0.0" } }, "validate-npm-package-license": { @@ -11958,52 +12519,52 @@ "integrity": "sha512-aodjPa2wPQFkra1G8CzJBTHXhgk3EVSwxSWXNPr1fgdFLUb8kvLV1iEb6rFgasIsjP82HWI6dsb5Io26DDnasA==" }, "vscode-css-languageservice": { - "version": "6.2.5", - "resolved": "https://registry.npmjs.org/vscode-css-languageservice/-/vscode-css-languageservice-6.2.5.tgz", - "integrity": "sha512-/1oyBZK3jfx6A0cA46FCUpy6OlqEsMT47LUIldCIP1YMKRYezJ9No+aNj9IM0AqhRZ92DxZ1DmU5lJ+biuiacA==", + "version": "6.2.11", + "resolved": "https://registry.npmjs.org/vscode-css-languageservice/-/vscode-css-languageservice-6.2.11.tgz", + "integrity": "sha512-qn49Wa6K94LnizpVxmlYrcPf1Cb36gq1nNueW0COhi4shylXBzET5wuDbH8ZWQlJD0HM5Mmnn7WE9vQVVs+ULA==", "requires": { - "@vscode/l10n": "^0.0.13", - "vscode-languageserver-textdocument": "^1.0.8", - "vscode-languageserver-types": "^3.17.3", - "vscode-uri": "^3.0.7" + "@vscode/l10n": "^0.0.16", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-languageserver-types": "3.17.5", + "vscode-uri": "^3.0.8" } }, "vscode-jsonrpc": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/vscode-jsonrpc/-/vscode-jsonrpc-8.1.0.tgz", - "integrity": "sha512-6TDy/abTQk+zDGYazgbIPc+4JoXdwC8NHU9Pbn4UJP1fehUyZmM4RHp5IthX7A6L5KS30PRui+j+tbbMMMafdw==" + "version": "8.2.0", + "resolved": "https://registry.npmjs.org/vscode-jsonrpc/-/vscode-jsonrpc-8.2.0.tgz", + "integrity": "sha512-C+r0eKJUIfiDIfwJhria30+TYWPtuHJXHtI7J0YlOmKAo7ogxP20T0zxB7HZQIFhIyvoBPwWskjxrvAtfjyZfA==" }, "vscode-languageserver": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/vscode-languageserver/-/vscode-languageserver-8.1.0.tgz", - "integrity": "sha512-eUt8f1z2N2IEUDBsKaNapkz7jl5QpskN2Y0G01T/ItMxBxw1fJwvtySGB9QMecatne8jFIWJGWI61dWjyTLQsw==", + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/vscode-languageserver/-/vscode-languageserver-9.0.1.tgz", + "integrity": "sha512-woByF3PDpkHFUreUa7Hos7+pUWdeWMXRd26+ZX2A8cFx6v/JPTtd4/uN0/jB6XQHYaOlHbio03NTHCqrgG5n7g==", "requires": { - "vscode-languageserver-protocol": "3.17.3" + "vscode-languageserver-protocol": "3.17.5" } }, "vscode-languageserver-protocol": { - "version": "3.17.3", - "resolved": "https://registry.npmjs.org/vscode-languageserver-protocol/-/vscode-languageserver-protocol-3.17.3.tgz", - "integrity": "sha512-924/h0AqsMtA5yK22GgMtCYiMdCOtWTSGgUOkgEDX+wk2b0x4sAfLiO4NxBxqbiVtz7K7/1/RgVrVI0NClZwqA==", + "version": "3.17.5", + "resolved": "https://registry.npmjs.org/vscode-languageserver-protocol/-/vscode-languageserver-protocol-3.17.5.tgz", + "integrity": "sha512-mb1bvRJN8SVznADSGWM9u/b07H7Ecg0I3OgXDuLdn307rl/J3A9YD6/eYOssqhecL27hK1IPZAsaqh00i/Jljg==", "requires": { - "vscode-jsonrpc": "8.1.0", - "vscode-languageserver-types": "3.17.3" + "vscode-jsonrpc": "8.2.0", + "vscode-languageserver-types": "3.17.5" } }, "vscode-languageserver-textdocument": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/vscode-languageserver-textdocument/-/vscode-languageserver-textdocument-1.0.8.tgz", - "integrity": "sha512-1bonkGqQs5/fxGT5UchTgjGVnfysL0O8v1AYMBjqTbWQTFn721zaPGDYFkOKtfDgFiSgXM3KwaG3FMGfW4Ed9Q==" + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/vscode-languageserver-textdocument/-/vscode-languageserver-textdocument-1.0.11.tgz", + "integrity": "sha512-X+8T3GoiwTVlJbicx/sIAF+yuJAqz8VvwJyoMVhwEMoEKE/fkDmrqUgDMyBECcM2A2frVZIUj5HI/ErRXCfOeA==" }, "vscode-languageserver-types": { - "version": "3.17.3", - "resolved": "https://registry.npmjs.org/vscode-languageserver-types/-/vscode-languageserver-types-3.17.3.tgz", - "integrity": "sha512-SYU4z1dL0PyIMd4Vj8YOqFvHu7Hz/enbWtpfnVbJHU4Nd1YNYx8u0ennumc6h48GQNeOLxmwySmnADouT/AuZA==" + "version": "3.17.5", + "resolved": "https://registry.npmjs.org/vscode-languageserver-types/-/vscode-languageserver-types-3.17.5.tgz", + "integrity": "sha512-Ld1VelNuX9pdF39h2Hgaeb5hEZM2Z3jUrrMgWQAu82jMtZp7p3vJT3BzToKtZI7NgQssZje5o0zryOrhQvzQAg==" }, "vscode-uri": { - "version": "3.0.7", - "resolved": "https://registry.npmjs.org/vscode-uri/-/vscode-uri-3.0.7.tgz", - "integrity": "sha512-eOpPHogvorZRobNqJGhapa0JdwaxpjVvyBp0QIUMRMSf8ZAlqOdEquKuRmw9Qwu0qXtJIWqFtMkmvJjUZmMjVA==" + "version": "3.0.8", + "resolved": "https://registry.npmjs.org/vscode-uri/-/vscode-uri-3.0.8.tgz", + "integrity": "sha512-AyFQ0EVmsOZOlAnxoFOGOq1SQDWAB7C6aqMGS23svWAllfOaxbuFvcT8D1i8z3Gyn8fraVeZNNmN6e9bxxXkKw==" }, "watchpack": { "version": "2.4.0", @@ -12015,9 +12576,9 @@ } }, "webpack": { - "version": "5.81.0", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.81.0.tgz", - "integrity": "sha512-AAjaJ9S4hYCVODKLQTgG5p5e11hiMawBwV2v8MYLE0C/6UAGLuAF4n1qa9GOwdxnicaP+5k6M5HrLmD4+gIB8Q==", + "version": "5.89.0", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.89.0.tgz", + "integrity": "sha512-qyfIC10pOr70V+jkmud8tMfajraGCZMBWJtrmuBymQKCrLTRejBI8STDp1MCyZu/QTdZSeacCQYpYNQVOzX5kw==", "requires": { "@types/eslint-scope": "^3.7.3", "@types/estree": "^1.0.0", @@ -12025,10 +12586,10 @@ "@webassemblyjs/wasm-edit": "^1.11.5", "@webassemblyjs/wasm-parser": "^1.11.5", "acorn": "^8.7.1", - "acorn-import-assertions": "^1.7.6", + "acorn-import-assertions": "^1.9.0", "browserslist": "^4.14.5", "chrome-trace-event": "^1.0.2", - "enhanced-resolve": "^5.13.0", + "enhanced-resolve": "^5.15.0", "es-module-lexer": "^1.2.1", "eslint-scope": "5.1.1", "events": "^3.2.0", @@ -12038,7 +12599,7 @@ "loader-runner": "^4.2.0", "mime-types": "^2.1.27", "neo-async": "^2.6.2", - "schema-utils": "^3.1.2", + "schema-utils": "^3.2.0", "tapable": "^2.1.1", "terser-webpack-plugin": "^5.3.7", "watchpack": "^2.4.0", @@ -12071,10 +12632,18 @@ "is-symbol": "^1.0.3" } }, - "word-wrap": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", - "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==" + "which-typed-array": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.13.tgz", + "integrity": "sha512-P5Nra0qjSncduVPEAr7xhoF5guty49ArDTwzJ/yNuPIbZppyRxFQsRCWrocxIY+CnMVG+qfbU2FmDKyvSGClow==", + "dev": true, + "requires": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.4", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.0" + } }, "workerpool": { "version": "6.2.1", @@ -12092,6 +12661,16 @@ "strip-ansi": "^6.0.0" } }, + "wrap-ansi-cjs": { + "version": "npm:wrap-ansi@7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "requires": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + } + }, "wrappy": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", @@ -12119,20 +12698,12 @@ "string-width": "^4.2.3", "y18n": "^5.0.5", "yargs-parser": "^21.1.1" - }, - "dependencies": { - "yargs-parser": { - "version": "21.1.1", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", - "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==" - } } }, "yargs-parser": { - "version": "20.2.9", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", - "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", - "dev": true + "version": "21.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", + "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==" }, "yargs-unparser": { "version": "2.0.0", @@ -12144,14 +12715,6 @@ "decamelize": "^4.0.0", "flat": "^5.0.2", "is-plain-obj": "^2.1.0" - }, - "dependencies": { - "camelcase": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", - "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", - "dev": true - } } }, "yocto-queue": { diff --git a/package.json b/package.json index 9629603582..c7d65204ee 100644 --- a/package.json +++ b/package.json @@ -6,8 +6,9 @@ ], "scripts": { "clean": "rimraf -g ./packages/*/{dist,cjs,esm}", - "build": "tsc --build", - "watch": "npm run build -- -w", + "build": "tsc --build && node scripts/build.js", + "build:dev": "tsc --build", + "watch": "tsc --build -w", "lint": "eslint .", "pretest": "npm run build", "test": "node --enable-source-maps scripts/test-runner.js --parallel", @@ -17,68 +18,66 @@ "prettify": "npx prettier . --write" }, "devDependencies": { - "@file-services/memory": "^7.2.5", - "@file-services/node": "^7.2.5", - "@rollup/plugin-html": "^1.0.2", - "@rollup/plugin-node-resolve": "^15.0.2", - "@types/balanced-match": "^1.0.2", - "@types/chai": "^4.3.5", - "@types/chai-subset": "^1.3.3", - "@types/css-selector-tokenizer": "^0.7.1", - "@types/cssesc": "^3.0.0", - "@types/csso": "^5.0.0", - "@types/find-config": "^1.0.1", - "@types/flat": "^5.0.2", - "@types/js-beautify": "^1.13.3", - "@types/json-schema": "^7.0.11", - "@types/lodash.camelcase": "^4.3.7", - "@types/lodash.clonedeep": "^4.5.7", - "@types/lodash.clonedeepwith": "^4.5.7", - "@types/lodash.findlast": "^4.6.7", - "@types/lodash.upperfirst": "^4.3.7", - "@types/memory-fs": "^0.3.3", - "@types/mime": "^3.0.1", - "@types/mocha": "^10.0.1", + "@file-services/memory": "^8.3.3", + "@file-services/node": "^8.3.3", + "@rollup/plugin-html": "^1.0.3", + "@rollup/plugin-node-resolve": "^15.2.3", + "@types/balanced-match": "^3.0.2", + "@types/chai": "^4.3.11", + "@types/chai-subset": "^1.3.5", + "@types/css-selector-tokenizer": "^0.7.4", + "@types/cssesc": "^3.0.2", + "@types/csso": "^5.0.4", + "@types/find-config": "^1.0.4", + "@types/flat": "^5.0.5", + "@types/js-beautify": "^1.14.3", + "@types/json-schema": "^7.0.15", + "@types/lodash.camelcase": "^4.3.9", + "@types/lodash.clonedeep": "^4.5.9", + "@types/lodash.clonedeepwith": "^4.5.9", + "@types/lodash.findlast": "^4.6.9", + "@types/lodash.upperfirst": "^4.3.9", + "@types/memory-fs": "^0.3.7", + "@types/mime": "^3.0.4", + "@types/mocha": "^10.0.6", "@types/node": "14", - "@types/postcss-safe-parser": "^5.0.1", - "@types/react": "^18.2.0", - "@types/react-dom": "^18.2.1", - "@types/semver": "^7.3.13", - "@types/validate-npm-package-name": "^4.0.0", - "@types/yargs": "^17.0.24", - "@typescript-eslint/eslint-plugin": "^5.59.2", - "@typescript-eslint/parser": "^5.59.2", - "autoprefixer": "^10.4.14", - "c8": "^7.13.0", - "chai": "^4.3.7", + "@types/postcss-safe-parser": "^5.0.4", + "@types/react": "^18.2.46", + "@types/react-dom": "^18.2.18", + "@types/semver": "^7.5.6", + "@types/validate-npm-package-name": "^4.0.2", + "@types/yargs": "^17.0.32", + "@typescript-eslint/eslint-plugin": "^5.61.0", + "@typescript-eslint/parser": "^5.61.0", + "autoprefixer": "^10.4.16", + "c8": "^8.0.1", + "chai": "^4.3.10", "chai-subset": "^1.6.0", "create-listening-server": "^2.1.0", - "eslint": "^8.39.0", - "eslint-config-prettier": "^8.8.0", - "eslint-plugin-react": "^7.32.2", - "eslint-plugin-react-hooks": "^4.6.0", + "eslint": "^8.56.0", + "eslint-config-prettier": "^9.1.0", "file-loader": "^6.2.0", - "html-webpack-plugin": "^5.5.1", - "mini-css-extract-plugin": "^2.7.5", + "html-webpack-plugin": "^5.6.0", + "mini-css-extract-plugin": "^2.7.6", "mocha": "^10.2.0", "node-eval": "^2.0.0", "npm-run-all": "^4.1.5", - "playwright-chromium": "^1.33.0", - "postcss": "^8.4.23", + "playwright-chromium": "^1.40.1", + "postcss": "^8.4.32", "promise-assist": "^2.0.1", "raw-loader": "^4.0.2", "react": "^18.2.0", "react-dom": "^18.2.0", - "rimraf": "^5.0.0", - "rollup": "^3.21.3", + "rimraf": "^5.0.5", + "rollup": "^4.9.2", "source-map": "^0.7.4", - "source-map-loader": "^4.0.1", - "style-loader": "^3.3.2", + "source-map-loader": "^4.0.2", + "style-loader": "^3.3.3", "ts-expect": "^1.3.0", - "tsconfig-paths-webpack-plugin": "^4.0.1", - "typescript": "~5.0.4", + "tsconfig-paths-webpack-plugin": "^4.1.0", + "typescript": "~5.2.2", "url-loader": "^4.1.1", - "webpack": "^5.81.0", + "webpack": "^5.89.0", "yargs": "^17.7.2" }, "engines": { diff --git a/packages/build-tools/package.json b/packages/build-tools/package.json index b580e631e3..4302a653bc 100644 --- a/packages/build-tools/package.json +++ b/packages/build-tools/package.json @@ -1,13 +1,13 @@ { "name": "@stylable/build-tools", - "version": "5.11.0", + "version": "5.17.0", "description": "Collection of helper functions for Stylable based tooling.", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\" --timeout 20000" }, "dependencies": { - "@stylable/core": "^5.11.0", + "@stylable/core": "^5.17.0", "find-config": "^1.0.0" }, "files": [ diff --git a/packages/cli/package.json b/packages/cli/package.json index 0f17ed42ae..76e09ed3f2 100644 --- a/packages/cli/package.json +++ b/packages/cli/package.json @@ -1,6 +1,6 @@ { "name": "@stylable/cli", - "version": "5.11.0", + "version": "5.17.0", "description": "A low-level utility used for working with Stylable projects", "main": "dist/index.js", "bin": { @@ -12,16 +12,16 @@ "test": "mocha \"./dist/test/**/*.spec.js\" --timeout 25000" }, "dependencies": { - "@file-services/node": "^7.2.5", - "@file-services/types": "^7.2.5", - "@stylable/build-tools": "^5.11.0", - "@stylable/code-formatter": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", + "@file-services/node": "^8.3.3", + "@file-services/types": "^8.3.3", + "@stylable/build-tools": "^5.17.0", + "@stylable/code-formatter": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", "@wixc3/resolve-directory-context": "^3.0.5", - "decache": "^4.6.1", + "decache": "^4.6.2", "lodash.camelcase": "^4.3.0", "lodash.upperfirst": "^4.3.1", "mime": "^3.0.0", diff --git a/packages/cli/src/build-single-file.ts b/packages/cli/src/build-single-file.ts index e71f84af4e..0dd7a92534 100644 --- a/packages/cli/src/build-single-file.ts +++ b/packages/cli/src/build-single-file.ts @@ -1,10 +1,10 @@ -import type { Stylable, StylableResults } from '@stylable/core'; -import { isAsset, isRelativeNativeCss } from '@stylable/core/dist/index-internal'; import { - generateDTSContent, - generateDTSSourceMap, + type Stylable, + type StylableResults, generateStylableJSModuleSource, -} from '@stylable/module-utils'; +} from '@stylable/core'; +import { isAsset, isRelativeNativeCss } from '@stylable/core/dist/index-internal'; +import { generateDTSContent, generateDTSSourceMap } from '@stylable/module-utils'; import { StylableOptimizer } from '@stylable/optimizer'; import type { IFileSystem } from '@file-services/types'; import { hasImportedSideEffects, processUrlDependencies } from '@stylable/build-tools'; @@ -86,7 +86,6 @@ export function buildSingleFile({ const outputLogs: string[] = []; log(mode, filePath); - tryRun(() => ensureDirectory(outDirPath, fs), `Ensure directory: ${outDirPath}`); let content: string = tryRun( () => fs.readFileSync(filePath).toString(), `Read File Error: ${filePath}` @@ -95,6 +94,7 @@ export function buildSingleFile({ () => stylable.transform(stylable.analyze(filePath)), errorMessages.STYLABLE_PROCESS(filePath) ); + const optimizer = new StylableOptimizer(); if (optimize) { optimizer.optimize( @@ -117,6 +117,10 @@ export function buildSingleFile({ }); } + if (outputSources || outputCSS || dts || moduleFormats.length) { + tryRun(() => ensureDirectory(outDirPath, fs), `Ensure directory: ${outDirPath}`); + } + // st.css if (outputSources) { if (targetFilePath === filePath) { diff --git a/packages/cli/src/build.ts b/packages/cli/src/build.ts index 572cd3fbae..57ed639070 100644 --- a/packages/cli/src/build.ts +++ b/packages/cli/src/build.ts @@ -212,6 +212,7 @@ export async function build( for (const { filePath, content, files } of outputs) { processGeneratedFiles.add(filePath); log(mode, buildMessages.EMIT_BUNDLE(filePath, files.length)); + fs.ensureDirectorySync(dirname(filePath)); fs.writeFileSync(filePath, content); } }, 'failed to write or minify bundle file'); diff --git a/packages/cli/src/config/projects-config.ts b/packages/cli/src/config/projects-config.ts index 8593229098..e71a5e47f7 100644 --- a/packages/cli/src/config/projects-config.ts +++ b/packages/cli/src/config/projects-config.ts @@ -13,15 +13,19 @@ import type { import { processProjects } from './process-projects'; import { createDefaultOptions, mergeBuildOptions, validateOptions } from './resolve-options'; import { resolveNpmRequests } from './resolve-requests'; -import type { ModuleResolver } from '@stylable/core/dist/index-internal'; -import type { MinimalFS, processNamespace } from '@stylable/core'; +import type { MinimalFS } from '@stylable/core'; +import type { StylableConfig } from '@stylable/core'; interface StylableRuntimeConfigs { stcConfig?: Configuration | undefined; - defaultConfig?: { - resolveModule?: ModuleResolver; - resolveNamespace?: typeof processNamespace; - }; + defaultConfig?: Pick< + StylableConfig, + | 'resolveNamespace' + | 'requireModule' + | 'resolveModule' + | 'flags' + | 'experimentalSelectorInference' + >; } export async function projectsConfig( diff --git a/packages/cli/test/directory-process-service/directory-process-service.spec.ts b/packages/cli/test/directory-process-service/directory-process-service.spec.ts index 6e2fe05588..93a4e3588e 100644 --- a/packages/cli/test/directory-process-service/directory-process-service.spec.ts +++ b/packages/cli/test/directory-process-service/directory-process-service.spec.ts @@ -3,21 +3,7 @@ import type { IFileSystem } from '@file-services/types'; import { expect } from 'chai'; import { waitFor } from 'promise-assist'; import { DirectoryProcessService } from '@stylable/cli'; - -function createSpy any>(fn?: T) { - const spy = (...args: any[]) => { - spy.calls.push(args); - spy.callCount++; - return fn?.(...args); - }; - spy.calls = [] as unknown[][]; - spy.callCount = 0; - spy.resetHistory = () => { - spy.calls.length = 0; - spy.callCount = 0; - }; - return spy; -} +import { logCalls } from '@stylable/core-test-kit'; const project1 = { '0.template.js': ` @@ -106,7 +92,7 @@ describe('DirectoryWatchService', () => { }); it('should handle directory added after watch started', async () => { - const changeSpy = createSpy(); + const changeSpy = logCalls(); const watcher = new DirectoryProcessService(fs, { watchMode: true, @@ -234,7 +220,7 @@ describe('DirectoryWatchService', () => { }); it('should report affectedFiles and no changeOrigin when watch started', async () => { - const changeSpy = createSpy(); + const changeSpy = logCalls(); const watcher = new DirectoryProcessService(fs, { watchMode: true, @@ -297,7 +283,7 @@ describe('DirectoryWatchService', () => { }); it('should report change for all files affected by the changeOrigin', async () => { - const changeSpy = createSpy(); + const changeSpy = logCalls(); const watcher = new DirectoryProcessService(fs, { watchMode: true, fileFilter: isTemplateFile, diff --git a/packages/code-formatter/package.json b/packages/code-formatter/package.json index 39c59c1bd0..c36ef81b6e 100644 --- a/packages/code-formatter/package.json +++ b/packages/code-formatter/package.json @@ -1,16 +1,16 @@ { "name": "@stylable/code-formatter", - "version": "5.11.0", + "version": "5.17.0", "description": "A code formatting utility for Stylable stylesheets", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\"" }, "dependencies": { - "@stylable/core": "^5.11.0", - "@tokey/css-value-parser": "^0.1.2", - "js-beautify": "^1.14.7", - "postcss": "^8.4.23" + "@stylable/core": "^5.17.0", + "@tokey/css-value-parser": "^0.1.4", + "js-beautify": "^1.14.11", + "postcss": "^8.4.32" }, "files": [ "dist", diff --git a/packages/core-test-kit/package.json b/packages/core-test-kit/package.json index 11e44e016a..9b05018b11 100644 --- a/packages/core-test-kit/package.json +++ b/packages/core-test-kit/package.json @@ -1,17 +1,17 @@ { "name": "@stylable/core-test-kit", - "version": "5.11.0", + "version": "5.17.0", "description": "Stylable core test-kit", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\"" }, "dependencies": { - "@file-services/memory": "^7.2.5", - "@stylable/core": "^5.11.0", - "chai": "^4.3.7", + "@file-services/memory": "^8.3.3", + "@stylable/core": "^5.17.0", + "chai": "^4.3.10", "flat": "^5.0.2", - "postcss": "^8.4.23" + "postcss": "^8.4.32" }, "files": [ "dist", diff --git a/packages/core-test-kit/src/generate-test-util.ts b/packages/core-test-kit/src/generate-test-util.ts index a94af7f17a..72f0130664 100644 --- a/packages/core-test-kit/src/generate-test-util.ts +++ b/packages/core-test-kit/src/generate-test-util.ts @@ -15,6 +15,7 @@ import { createStylableFileProcessor, postProcessor, replaceValueHook, + defaultFeatureFlags, } from '@stylable/core/dist/index-internal'; import { isAbsolute } from 'path'; import * as postcss from 'postcss'; @@ -107,9 +108,9 @@ export function processSource( options: { from?: string } = {}, resolveNamespace?: typeof processNamespace ) { - return new StylableProcessor(new Diagnostics(), resolveNamespace).process( - postcss.parse(source, options) - ); + return new StylableProcessor(new Diagnostics(), resolveNamespace, { + ...defaultFeatureFlags, + }).process(postcss.parse(source, options)); } export function createProcess( diff --git a/packages/core-test-kit/src/index.ts b/packages/core-test-kit/src/index.ts index 185c78f9c9..98318b5e5b 100644 --- a/packages/core-test-kit/src/index.ts +++ b/packages/core-test-kit/src/index.ts @@ -30,3 +30,4 @@ export { deindent } from './deindent'; export { MinimalDocument, MinimalElement } from './minimal-dom'; export { createTempDirectorySync, copyDirectory } from './native-temp-dir'; export { assertAtRule, assertComment, assertDecl, assertRule } from './postcss-node-asserts'; +export { spyCalls, logCalls } from './spy'; diff --git a/packages/core-test-kit/src/spy.ts b/packages/core-test-kit/src/spy.ts new file mode 100644 index 0000000000..276eddc675 --- /dev/null +++ b/packages/core-test-kit/src/spy.ts @@ -0,0 +1,36 @@ +// type FuncParameters = F extends (...args: any[]) => any ? Parameters : never; + +export const spyCalls = (target: T, funcName: N) => { + const origin = target[funcName]; + + if (typeof origin !== 'function') { + throw new Error('spy only supports functions'); + } + + // proxy + const logFunc = logCalls(origin); + target[funcName] = logFunc as T[N]; + + return { + calls: logFunc.calls, + resetSpy: logFunc.resetHistory, + restoreSpy() { + target[funcName] = origin; + }, + }; +}; + +export function logCalls(fn?: T) { + const spy = (...args: any[]) => { + spy.calls.push(args); + spy.callCount++; + return fn?.(...args); + }; + spy.calls = [] as unknown[][]; + spy.callCount = 0; + spy.resetHistory = () => { + spy.calls.length = 0; + spy.callCount = 0; + }; + return spy; +} diff --git a/packages/core-test-kit/test/test-stylable-core.spec.ts b/packages/core-test-kit/test/test-stylable-core.spec.ts index 92095a80cc..8dd9f2d79b 100644 --- a/packages/core-test-kit/test/test-stylable-core.spec.ts +++ b/packages/core-test-kit/test/test-stylable-core.spec.ts @@ -9,10 +9,9 @@ describe(`testStylableCore()`, () => { const { meta, exports } = sheets[`/entry.st.css`]; - expect(CSSClass.get(meta, `root`), `meta`).to.contain({ - _kind: `class`, - name: `root`, - }); + expect(CSSClass.get(meta, `root`), `meta`).to.deep.contain( + CSSClass.createSymbol({ name: `root` }) + ); expect(exports.classes.root, `exports.classes`).to.equal(`entry__root`); }); it(`should inline test stylable content`, () => { diff --git a/packages/core/package.json b/packages/core/package.json index df6a95e990..be38438134 100644 --- a/packages/core/package.json +++ b/packages/core/package.json @@ -1,6 +1,6 @@ { "name": "@stylable/core", - "version": "5.11.0", + "version": "5.17.0", "description": "CSS for Components", "main": "dist/index.js", "scripts": { @@ -10,16 +10,17 @@ "module": "./dist/module-with-extensions.js" }, "dependencies": { - "@tokey/css-selector-parser": "^0.6.1", + "@tokey/css-selector-parser": "^0.6.2", + "@tokey/css-value-parser": "^0.1.4", "@tokey/imports-parser": "^1.0.0", "balanced-match": "^2.0.0", "css-selector-tokenizer": "^0.8.0", "cssesc": "^3.0.0", - "enhanced-resolve": "^5.13.0", + "enhanced-resolve": "^5.15.0", "is-vendor-prefixed": "^4.0.0", "lodash.clonedeep": "^4.5.0", "lodash.clonedeepwith": "^4.5.0", - "postcss": "^8.4.23", + "postcss": "^8.4.32", "postcss-js": "^4.0.1", "postcss-nested": "^6.0.1", "postcss-safe-parser": "^6.0.0", diff --git a/packages/core/src/create-stylable-processor.ts b/packages/core/src/create-stylable-processor.ts index c64284dda4..23e8d0d037 100644 --- a/packages/core/src/create-stylable-processor.ts +++ b/packages/core/src/create-stylable-processor.ts @@ -3,6 +3,7 @@ import { cssParse, CssParser } from './parser'; import { processNamespace, StylableProcessor } from './stylable-processor'; import type { StylableMeta } from './stylable-meta'; import type { Diagnostics } from './diagnostics'; +import { defaultFeatureFlags, type FeatureFlags } from './features/feature'; export function createStylableFileProcessor({ fileSystem, @@ -11,8 +12,10 @@ export function createStylableFileProcessor({ cssParser = cssParse, cache, createDiagnostics, + flags = { ...defaultFeatureFlags }, }: { fileSystem: MinimalFS; + flags?: FeatureFlags; onProcess?: (meta: StylableMeta, path: string) => StylableMeta; resolveNamespace?: typeof processNamespace; cssParser?: CssParser; @@ -21,9 +24,11 @@ export function createStylableFileProcessor({ }) { return cachedProcessFile( (from, content) => { - return new StylableProcessor(createDiagnostics?.(from), resolveNamespace).process( - cssParser(content, { from }) - ); + return new StylableProcessor( + createDiagnostics?.(from), + resolveNamespace, + flags + ).process(cssParser(content, { from })); }, (resolvedPath: string) => { return fileSystem.readFileSync(resolvedPath, 'utf8'); diff --git a/packages/core/src/enhanced-resolve-alias.ts b/packages/core/src/enhanced-resolve-alias.ts new file mode 100644 index 0000000000..69cbb83b9a --- /dev/null +++ b/packages/core/src/enhanced-resolve-alias.ts @@ -0,0 +1,9 @@ +// we don't want to bundle the entire enhanced-resolve package for the browser +// it will throw if Stylable is used in the browser without a custom resolver +export default { + createResolver: () => { + throw new Error( + 'Stylable requires a custom resolver in lib bundles. please provide `resolveModule` options to the Stylable constructor.' + ); + }, +}; diff --git a/packages/core/src/features/css-class.ts b/packages/core/src/features/css-class.ts index d20e12a933..dd8b31199e 100644 --- a/packages/core/src/features/css-class.ts +++ b/packages/core/src/features/css-class.ts @@ -4,7 +4,7 @@ import * as STSymbol from './st-symbol'; import type { StylableSymbol } from './st-symbol'; import type { ImportSymbol } from './st-import'; import type { ElementSymbol } from './css-type'; -import * as STPart from './st-part'; +import type * as STStructure from './st-structure'; import * as STCustomState from './st-custom-state'; import { getOriginDefinition } from '../helpers/resolve'; import { namespace } from '../helpers/namespace'; @@ -20,7 +20,7 @@ import { } from '../helpers/selector'; import { getAlias } from '../stylable-utils'; import type { StylableMeta } from '../stylable-meta'; -import { validateRuleStateDefinition, MappedStates } from '../helpers/custom-state'; +import { validateRuleStateDefinition } from '../helpers/custom-state'; import type { Stylable } from '../stylable'; import { ImmutableClass, @@ -34,10 +34,10 @@ import * as postcss from 'postcss'; import { basename } from 'path'; import { createDiagnosticReporter } from '../diagnostics'; import postcssValueParser from 'postcss-value-parser'; +import { plugableRecord } from '../helpers/plugable-record'; -export interface StPartDirectives { +export interface StPartDirectives extends STStructure.HasParts, Partial { '-st-root'?: boolean; - '-st-states'?: MappedStates; '-st-extends'?: ImportSymbol | ClassSymbol | ElementSymbol; '-st-global'?: SelectorNode[]; } @@ -119,8 +119,27 @@ export const diagnostics = { 'error', (name: string) => `cannot use alias for unknown import "${name}"` ), + DISABLED_DIRECTIVE: createDiagnosticReporter( + '00009', + 'error', + (className: string, directive: keyof typeof stPartDirectives) => { + const alternative = + directive === '-st-extends' + ? ` use "@st .${className} :is(.base)" instead` + : directive === '-st-global' + ? `use "@st .${className} => :global()" instead` + : directive === '-st-states' + ? `use "@st .${className} { @st .state; }" instead` + : ''; + return `cannot use ${directive} on .${className} since class is defined with "@st" - ${alternative}`; + } + ), }; +const dataKey = plugableRecord.key<{ + classesDefinedWithAtSt: Set; +}>('st-structure'); + // HOOKS export const hooks = createFeature<{ @@ -128,6 +147,11 @@ export const hooks = createFeature<{ IMMUTABLE_SELECTOR: ImmutableClass; RESOLVED: Record; }>({ + metaInit({ meta }) { + plugableRecord.set(meta.data, dataKey, { + classesDefinedWithAtSt: new Set(), + }); + }, analyzeSelectorNode({ context, node, rule }): void { if (node.nodes) { // error on functional class @@ -142,7 +166,7 @@ export const hooks = createFeature<{ addClass(context, node.value, rule); }, analyzeDeclaration({ context, decl }) { - if (context.meta.type === 'stylable' && decl.prop in stPartDirectives) { + if (context.meta.type === 'stylable' && isDirectiveDeclaration(decl)) { handleDirectives(context, decl); } }, @@ -201,7 +225,7 @@ export const hooks = createFeature<{ // used to namespace classes from js mixins since js mixins // are scoped in the context of the mixed-in stylesheet // which might not have a definition for the mixed-in class - { _kind: 'css', meta: originMeta, symbol: { _kind: 'class', name: node.value } }, + { _kind: 'css', meta: originMeta, symbol: createSymbol({ name: node.value }) }, ]; selectorContext.setNextSelectorScope(resolved, node, node.value); const { symbol, meta } = getOriginDefinition(resolved); @@ -259,7 +283,12 @@ export function getAll(meta: StylableMeta): Record { return STSymbol.getAllByType(meta, `class`); } -export function addClass(context: FeatureContext, name: string, rule?: postcss.Rule): ClassSymbol { +export function createSymbol(input: Partial & { name: string }): ClassSymbol { + const parts = input['-st-parts'] || {}; + return { ...input, _kind: 'class', '-st-parts': parts }; +} + +export function addClass(context: FeatureContext, name: string, rule?: postcss.Node): ClassSymbol { let symbol = STSymbol.get(context.meta, name, `class`); if (!symbol) { let alias = STSymbol.get(context.meta, name); @@ -268,15 +297,10 @@ export function addClass(context: FeatureContext, name: string, rule?: postcss.R } symbol = STSymbol.addSymbol({ context, - symbol: { - _kind: 'class', - name, - alias, - }, + symbol: createSymbol({ name, alias }), node: rule, safeRedeclare: !!alias, }) as ClassSymbol; - STPart.registerLegacyPart(context.meta, name, { mapTo: symbol }); } // mark native css as global if (context.meta.type === 'css' && !symbol['-st-global']) { @@ -362,6 +386,7 @@ export function createWarningRule( ) { const message = `"class extending component '${extendingNode} => ${scopedExtendingNode}' in stylesheet '${extendingFile}' was set on a node that does not extend '${extendedNode} => ${scopedExtendedNode}' from stylesheet '${extendedFile}'" !important`; return postcss.rule({ + raws: { between: ' ' }, selector: `${scopedExtendingNode}:not(${scopedExtendedNode})::before`, nodes: [ postcss.decl({ @@ -456,7 +481,22 @@ export function checkForScopedNodeAfter( return false; } -function handleDirectives(context: FeatureContext, decl: postcss.Declaration) { +function isDirectiveDeclaration( + decl: postcss.Declaration +): decl is postcss.Declaration & { prop: keyof typeof stPartDirectives } { + return decl.prop in stPartDirectives; +} +export function disableDirectivesForClass(context: FeatureContext, className: string) { + // ToDo: move directive analyze to @st-structure + // called when class is defined with @st + const { classesDefinedWithAtSt } = plugableRecord.getUnsafe(context.meta.data, dataKey); + classesDefinedWithAtSt.add(className); +} + +function handleDirectives( + context: FeatureContext, + decl: postcss.Declaration & { prop: keyof typeof stPartDirectives } +) { const rule = decl.parent as postcss.Rule; if (rule?.type !== 'rule') { return; @@ -466,7 +506,17 @@ function handleDirectives(context: FeatureContext, decl: postcss.Declaration) { return !accType ? type : accType !== type ? `complex` : type; }, `` as (typeof isSimplePerSelector)[number]['type']); const isSimple = type !== `complex`; - if (decl.prop === `-st-states`) { + + const { classesDefinedWithAtSt } = plugableRecord.getUnsafe(context.meta.data, dataKey); + if (type === 'class' && classesDefinedWithAtSt.has(rule.selector.replace('.', ''))) { + context.diagnostics.report( + diagnostics.DISABLED_DIRECTIVE(rule.selector.replace('.', ''), decl.prop), + { + node: decl, + } + ); + return; + } else if (decl.prop === `-st-states`) { if (isSimple && type !== 'type') { extendTypedRule( context, @@ -534,7 +584,7 @@ function handleDirectives(context: FeatureContext, decl: postcss.Declaration) { } } -function extendTypedRule( +export function extendTypedRule( context: FeatureContext, node: postcss.Node, selector: string, diff --git a/packages/core/src/features/css-custom-property.ts b/packages/core/src/features/css-custom-property.ts index a32175e69f..20dad9bb50 100644 --- a/packages/core/src/features/css-custom-property.ts +++ b/packages/core/src/features/css-custom-property.ts @@ -60,6 +60,12 @@ export const diagnostics = { 'error', () => `missing custom property name for "var(--[PROP NAME])"` ), + UNDEFINED_CSS_CUSTOM_PROP: createDiagnosticReporter( + '01011', + 'error', + (name) => + `Undefined "${name}" custom property. Please define the property using '@property' or import it with '@st-import' when 'strictCustomProperty' is enabled.` + ), }; const dataKey = plugableRecord.key<{ @@ -248,8 +254,19 @@ function addCSSProperty({ return; } // usages bailout: addition of weak definition reference `--x: var(--x)` - if (!final && !!STSymbol.get(context.meta, name, `cssVar`)) { - return; + if (!final) { + const existing = STSymbol.get(context.meta, name, `cssVar`); + if (existing) { + // already defined + return; + // eslint-disable-next-line no-constant-condition + } else if (context.meta.type === 'stylable' && context.meta.flags.strictCustomProperty) { + // strict mode + context.diagnostics.report(diagnostics.UNDEFINED_CSS_CUSTOM_PROP(name), { + node, + word: name, + }); + } } // define symbol diff --git a/packages/core/src/features/css-pseudo-class.ts b/packages/core/src/features/css-pseudo-class.ts index c1c87c2e9a..57b66077df 100644 --- a/packages/core/src/features/css-pseudo-class.ts +++ b/packages/core/src/features/css-pseudo-class.ts @@ -1,6 +1,7 @@ import { createFeature } from './feature'; import { nativePseudoClasses } from '../native-reserved-lists'; import * as STCustomState from './st-custom-state'; +import * as CSSType from './css-type'; import { createDiagnosticReporter } from '../diagnostics'; import type { Selector } from '@tokey/css-selector-parser'; import isVendorPrefixed from 'is-vendor-prefixed'; @@ -50,7 +51,7 @@ export const hooks = createFeature({ { _kind: 'css', meta: context.meta, - symbol: { _kind: 'element', name: '*' }, + symbol: CSSType.createSymbol({ name: '*' }), }, ], node diff --git a/packages/core/src/features/css-type.ts b/packages/core/src/features/css-type.ts index c69787cad2..50014077a2 100644 --- a/packages/core/src/features/css-type.ts +++ b/packages/core/src/features/css-type.ts @@ -65,7 +65,7 @@ export const hooks = createFeature<{ { _kind: 'css', meta: context.meta, - symbol: { _kind: 'element', name: node.value }, + symbol: createSymbol({ name: '*' }), }, ]; } @@ -93,6 +93,11 @@ export function getAll(meta: StylableMeta): Record { return STSymbol.getAllByType(meta, `element`); } +export function createSymbol(input: Partial & { name: string }): ElementSymbol { + const parts = input['-st-parts'] || {}; + return { ...input, _kind: 'element', '-st-parts': parts }; +} + export function addType(context: FeatureContext, name: string, rule?: postcss.Rule): ElementSymbol { const typeSymbol = STSymbol.get(context.meta, name, `element`); if (!typeSymbol && isCompRoot(name)) { @@ -102,11 +107,7 @@ export function addType(context: FeatureContext, name: string, rule?: postcss.Ru } STSymbol.addSymbol({ context, - symbol: { - _kind: 'element', - name, - alias, - }, + symbol: createSymbol({ name, alias }), node: rule, safeRedeclare: !!alias, }); diff --git a/packages/core/src/features/feature.ts b/packages/core/src/features/feature.ts index 9f5d5793be..b9947ad2cb 100644 --- a/packages/core/src/features/feature.ts +++ b/packages/core/src/features/feature.ts @@ -1,5 +1,10 @@ import type { StylableMeta } from '../stylable-meta'; -import type { ScopeContext, StylableExports, StylableTransformer } from '../stylable-transformer'; +import type { + InferredSelector, + ScopeContext, + StylableExports, + StylableTransformer, +} from '../stylable-transformer'; import type { StylableResolver, MetaResolvedSymbols } from '../stylable-resolver'; import type { StylableEvaluator, EvalValueData } from '../functions'; import type * as postcss from 'postcss'; @@ -7,6 +12,13 @@ import type { ImmutableSelectorNode } from '@tokey/css-selector-parser'; import type { Diagnostics } from '../diagnostics'; import type { ParsedValue } from '../types'; +export interface FeatureFlags { + strictCustomProperty: boolean; +} +export const defaultFeatureFlags: FeatureFlags = { + strictCustomProperty: false, +}; + export type SelectorNodeContext = [ index: number, nodes: ImmutableSelectorNode[], @@ -22,6 +34,7 @@ export interface FeatureTransformContext extends FeatureContext { evaluator: StylableEvaluator; getResolvedSymbols: (meta: StylableMeta) => MetaResolvedSymbols; passedThrough?: string[]; + inferredSelectorMixin?: InferredSelector; } export interface NodeTypes { diff --git a/packages/core/src/features/index.ts b/packages/core/src/features/index.ts index 745a207876..81931a363a 100644 --- a/packages/core/src/features/index.ts +++ b/packages/core/src/features/index.ts @@ -15,8 +15,6 @@ export * as STScope from './st-scope'; export * as STVar from './st-var'; export type { VarSymbol, ComputedStVar, FlatComputedStVar } from './st-var'; -export * as STPart from './st-part'; - export * as STCustomSelector from './st-custom-selector'; export * as STCustomState from './st-custom-state'; @@ -45,3 +43,5 @@ export * as CSSContains from './css-contains'; export type { ContainerSymbol } from './css-contains'; export * as CSSMedia from './css-media'; + +export * as STStructure from './st-structure'; diff --git a/packages/core/src/features/st-custom-selector.ts b/packages/core/src/features/st-custom-selector.ts index dba1eba299..d09b119ad0 100644 --- a/packages/core/src/features/st-custom-selector.ts +++ b/packages/core/src/features/st-custom-selector.ts @@ -6,7 +6,6 @@ import { CustomSelectorMap, } from '../helpers/custom-selector'; import { parseSelectorWithCache } from '../helpers/selector'; -import * as STPart from './st-part'; import * as postcss from 'postcss'; import { SelectorList, stringifySelectorAst } from '@tokey/css-selector-parser'; import type { StylableMeta } from '../stylable-meta'; @@ -20,13 +19,14 @@ export const diagnostics = { ), }; -const dataKey = - plugableRecord.key< - Record< - string, - { selector: string; ast: SelectorList; isScoped: boolean; def: postcss.AtRule } - > - >('st-custom-selector'); +interface AnalyzedCustomSelector { + selector: string; + ast: SelectorList; + isScoped: boolean; + def: postcss.AtRule; +} + +const dataKey = plugableRecord.key>('st-custom-selector'); export const CUSTOM_SELECTOR_RE = /:--[\w-]+/g; @@ -49,7 +49,6 @@ export const hooks = createFeature({ const analyzed = plugableRecord.getUnsafe(context.meta.data, dataKey); const name = customSelector.slice(3); analyzed[name] = { selector, ast, isScoped, def: atRule }; - STPart.registerLegacyPart(context.meta, name, { mapTo: ast }); } else { // TODO: add warn there are two types one is not valid name and the other is empty name. } @@ -122,8 +121,14 @@ export function isScoped(meta: StylableMeta, name: string) { } export function getCustomSelector(meta: StylableMeta, name: string): SelectorList | undefined { + return plugableRecord.getUnsafe(meta.data, dataKey)[name]?.ast; +} +export function getCustomSelectors(meta: StylableMeta) { const analyzed = plugableRecord.getUnsafe(meta.data, dataKey); - return analyzed[name]?.ast; + return Object.entries(analyzed).reduce((acc, [name, { ast }]) => { + acc[name] = ast; + return acc; + }, {} as Record); } export function getCustomSelectorExpended(meta: StylableMeta, name: string): string | undefined { diff --git a/packages/core/src/features/st-custom-state.ts b/packages/core/src/features/st-custom-state.ts index 8dcf77508c..2641d3e54e 100644 --- a/packages/core/src/features/st-custom-state.ts +++ b/packages/core/src/features/st-custom-state.ts @@ -2,6 +2,7 @@ import { createFeature } from './feature'; import { stateDiagnostics, parsePseudoStates, + parseStateValue, transformPseudoClassToCustomState, booleanStateDelimiter, stateMiddleDelimiter, @@ -12,8 +13,13 @@ import { validationErrors as sysValidationErrors, resolveStateParam, isTemplateState, + MappedStates, } from '../helpers/custom-state'; +export interface HasStates { + '-st-states': MappedStates; +} + export const diagnostics = { ...stateDiagnostics, }; @@ -29,6 +35,7 @@ const delimiters = { }; export { parsePseudoStates, + parseStateValue, transformPseudoClassToCustomState, delimiters, createBooleanStateClassName, @@ -37,4 +44,5 @@ export { sysValidationErrors, resolveStateParam, isTemplateState, + MappedStates, }; diff --git a/packages/core/src/features/st-mixin.ts b/packages/core/src/features/st-mixin.ts index 71f8c6f98b..00dbc82080 100644 --- a/packages/core/src/features/st-mixin.ts +++ b/packages/core/src/features/st-mixin.ts @@ -63,6 +63,7 @@ export const diagnostics = { VALUE_CANNOT_BE_STRING: mixinHelperDiagnostics.VALUE_CANNOT_BE_STRING, INVALID_NAMED_PARAMS: mixinHelperDiagnostics.INVALID_NAMED_PARAMS, INVALID_MERGE_OF: utilDiagnostics.INVALID_MERGE_OF, + INVALID_RECURSIVE_MIXIN: utilDiagnostics.INVALID_RECURSIVE_MIXIN, PARTIAL_MIXIN_MISSING_ARGUMENTS: createDiagnosticReporter( '10001', 'error', @@ -236,20 +237,23 @@ function collectRuleMixins( const resolvedSymbols = context.getResolvedSymbols(context.meta); const { mainNamespace } = resolvedSymbols; const decls: postcss.Declaration[] = []; - rule.walkDecls((decl) => { - if (decl.prop === `-st-mixin` || decl.prop === `-st-partial-mixin`) { - decls.push(decl); + for (const node of rule.nodes) { + if ( + node.type === 'decl' && + (node.prop === `-st-mixin` || node.prop === `-st-partial-mixin`) + ) { + decls.push(node); mixins = collectDeclMixins( context, resolvedSymbols, - decl, + node, (mixinSymbolName) => { return mainNamespace[mixinSymbolName] === 'js' ? 'args' : 'named'; }, mixins ); } - }); + } return [decls, mixins]; } @@ -417,7 +421,7 @@ function handleJSMixin( const meta = context.meta; const mixDef = config.mixDef; const res = mixinFunction((mixDef.data.options as any[]).map((v) => v.value)); - const mixinRoot = cssObjectToAst(res).root; + const mixinRoot = cssObjectToAst(res); mixinRoot.walkDecls((decl) => { if (!isValidDeclaration(decl)) { @@ -534,8 +538,9 @@ function collectOptionalArgs( mixinRoot: postcss.Root, optionalArgs: Set = new Set() ) { - mixinRoot.walkDecls((decl) => { - const varNames = STVar.parseVarsFromExpr(decl.value); + mixinRoot.walk((node) => { + const value = node.type === 'decl' ? node.value : node.type === 'atrule' ? node.params : ''; + const varNames = STVar.parseVarsFromExpr(value); for (const name of varNames) { for (const refName of STVar.resolveReferencedVarNames(context, name)) { optionalArgs.add(refName); diff --git a/packages/core/src/features/st-namespace.ts b/packages/core/src/features/st-namespace.ts index 6703e7a60e..d2d7a9a41b 100644 --- a/packages/core/src/features/st-namespace.ts +++ b/packages/core/src/features/st-namespace.ts @@ -34,11 +34,17 @@ export const diagnostics = { 'error', () => 'st-namespace-reference dose not have any value' ), + NATIVE_OVERRIDE_DEPRECATION: createDiagnosticReporter( + '11014', + 'info', + () => '@namespace will stop working in version 6, use @st-namespace instead' + ), }; const dataKey = plugableRecord.key<{ namespaces: string[]; usedNativeNamespace: string[]; + usedNativeNamespaceNodes: AtRule[]; foundStNamespace: boolean; }>('namespace'); @@ -49,6 +55,7 @@ export const hooks = createFeature({ plugableRecord.set(meta.data, dataKey, { namespaces: [], usedNativeNamespace: [], + usedNativeNamespaceNodes: [], foundStNamespace: false, }); }, @@ -69,14 +76,24 @@ export const hooks = createFeature({ data.namespaces.push(match); if (isNamespace) { data.usedNativeNamespace.push(atRule.params); + data.usedNativeNamespaceNodes.push(atRule); } else { // clear @namespace matches once @st-namespace if found data.usedNativeNamespace.length = 0; + data.usedNativeNamespaceNodes.length = 0; // mark to prevent any further @namespace collection data.foundStNamespace = true; } } }, + analyzeDone(context) { + const { usedNativeNamespaceNodes } = plugableRecord.getUnsafe(context.meta.data, dataKey); + for (const node of usedNativeNamespaceNodes) { + context.diagnostics.report(diagnostics.NATIVE_OVERRIDE_DEPRECATION(), { + node, + }); + } + }, prepareAST({ context, node, toRemove }) { // remove @st-namespace or @namespace that was used as @st-namespace const { usedNativeNamespace } = plugableRecord.getUnsafe(context.meta.data, dataKey); diff --git a/packages/core/src/features/st-part.ts b/packages/core/src/features/st-part.ts deleted file mode 100644 index e254483ce2..0000000000 --- a/packages/core/src/features/st-part.ts +++ /dev/null @@ -1,49 +0,0 @@ -import { createFeature } from './feature'; -// import { createDiagnosticReporter } from '../diagnostics'; -import { plugableRecord } from '../helpers/plugable-record'; -import type { StylableMeta } from '../stylable-meta'; -import type { SelectorList } from '@tokey/css-selector-parser'; -import type { ClassSymbol } from './css-class'; - -export const diagnostics = {}; - -type PartData = { - mapTo: SelectorList | ClassSymbol; -}; -const dataKey = plugableRecord.key<{ - legacyParts: Record; -}>('part'); - -// HOOKS - -export const hooks = createFeature({ - metaInit({ meta }) { - plugableRecord.set(meta.data, dataKey, { legacyParts: {} }); - }, -}); - -// API - -export function registerLegacyPart( - meta: StylableMeta, - name: string, - options: { mapTo: SelectorList | ClassSymbol } -) { - const { legacyParts } = plugableRecord.getUnsafe(meta.data, dataKey); - const isCustomSelector = Array.isArray(options.mapTo); - // register custom selector mapped parts over class - if (!legacyParts[name] || (isCustomSelector && !Array.isArray(legacyParts[name].mapTo))) { - legacyParts[name] = options; - } else { - // report? - } -} -export function getPart(meta: StylableMeta, name: string): PartData | undefined { - const { legacyParts } = plugableRecord.getUnsafe(meta.data, dataKey); - return legacyParts[name]; -} - -export function getPartNames(meta: StylableMeta) { - const { legacyParts } = plugableRecord.getUnsafe(meta.data, dataKey); - return Object.keys(legacyParts); -} diff --git a/packages/core/src/features/st-scope.ts b/packages/core/src/features/st-scope.ts index 30fe5cc7a0..2bea117f9e 100644 --- a/packages/core/src/features/st-scope.ts +++ b/packages/core/src/features/st-scope.ts @@ -4,14 +4,13 @@ import type { Stylable } from '../stylable'; import type { ImmutablePseudoClass } from '@tokey/css-selector-parser'; import * as postcss from 'postcss'; import type { SRule } from '../deprecated/postcss-ast-extension'; -import { createDiagnosticReporter } from '../diagnostics'; export const diagnostics = { - MISSING_SCOPING_PARAM: createDiagnosticReporter( - '11009', - 'error', - () => '"@st-scope" missing scoping selector parameter' - ), + // INVALID_SCOPING: createDiagnosticReporter( + // '11009', + // 'error', + // () => '"@st-scope" requires a valid selector or empty value' + // ), }; // HOOKS @@ -21,9 +20,8 @@ export const hooks = createFeature<{ IMMUTABLE_SELECTOR: ImmutablePseudoClass }> if (!isStScopeStatement(atRule)) { return; } - if (!atRule.params) { - context.diagnostics.report(diagnostics.MISSING_SCOPING_PARAM(), { node: atRule }); - } + // notice: any value from params would be taken as a scoping + // selector to be prepended to nested selectors analyzeRule( postcss.rule({ selector: atRule.params, @@ -44,12 +42,14 @@ export const hooks = createFeature<{ IMMUTABLE_SELECTOR: ImmutablePseudoClass }> toRemove.push(() => node.replaceWith(node.nodes || [])); } }, - transformAtRuleNode({ context: { meta }, atRule, transformer }) { + transformAtRuleNode({ context: { meta, inferredSelectorMixin }, atRule, transformer }) { if (isStScopeStatement(atRule)) { const { selector, inferredSelector } = transformer.scopeSelector( meta, atRule.params, - atRule + atRule, + undefined, + inferredSelectorMixin ); // transform selector in params atRule.params = selector; diff --git a/packages/core/src/features/st-structure.ts b/packages/core/src/features/st-structure.ts new file mode 100644 index 0000000000..b189e8ded0 --- /dev/null +++ b/packages/core/src/features/st-structure.ts @@ -0,0 +1,854 @@ +import { plugableRecord } from '../helpers/plugable-record'; +import { FeatureContext, createFeature } from './feature'; +import type { StylableMeta } from '../stylable-meta'; +import * as STSymbol from './st-symbol'; +import * as STCustomSelector from './st-custom-selector'; +import * as STCustomState from './st-custom-state'; +import type { MappedStates } from './st-custom-state'; +import * as CSSClass from './css-class'; +import { warnOnce } from '../helpers/deprecation'; +import postcss from 'postcss'; +import { parseCSSValue, stringifyCSSValue, BaseAstNode } from '@tokey/css-value-parser'; +import { parseSelectorWithCache, walkSelector } from '../helpers/selector'; +import { + ImmutableSelector, + stringifySelectorAst, + ImmutablePseudoClass, + ImmutableSelectorList, +} from '@tokey/css-selector-parser'; +import { createDiagnosticReporter } from '../diagnostics'; +import { getAlias } from '../stylable-utils'; +import { + findAnything, + findFatArrow, + findNextClassNode, + findNextPseudoClassNode, + findPseudoElementNode, + isExactLiteral, +} from '../helpers/css-value-seeker'; + +export const diagnostics = { + GLOBAL_MAPPING_LIMITATION: createDiagnosticReporter( + '21000', + 'error', + () => `Currently class mapping is limited to single global selector: :global()` + ), + UNSUPPORTED_TOP_DEF: createDiagnosticReporter( + '21001', + 'error', + () => 'top level @st must start with a class' + ), + MISSING_EXTEND: createDiagnosticReporter( + '21002', + 'error', + () => `missing required class reference to extend a class (e.g. ":is(.class-name)"` + ), + OVERRIDE_IMPORTED_CLASS: createDiagnosticReporter( + '21003', + 'error', + () => `cannot override imported class definition` + ), + STATE_OUT_OF_CONTEXT: createDiagnosticReporter( + '21004', + 'error', + () => 'pseudo-state definition must be directly nested in a `@st .class{}` definition' + ), + // 31005 - unused + MISSING_MAPPED_SELECTOR: createDiagnosticReporter( + '21006', + 'error', + () => `missing mapped selector after "=>"` + ), + MULTI_MAPPED_SELECTOR: createDiagnosticReporter( + '21007', + 'error', + () => + 'mapped selector accepts only a single selector.\nuse `:is()` or `:where()` to map multiple selectors)' + ), + ELEMENT_OUT_OF_CONTEXT: createDiagnosticReporter( + '21008', + 'error', + () => 'pseudo-element definition must be directly nested in a `@st .class{}` definition' + ), + MISSING_MAPPING: createDiagnosticReporter( + '21009', + 'error', + () => 'expected selector mapping (e.g. "=> ")' + ), + REDECLARE: createDiagnosticReporter( + '21010', + 'error', + (type: string, src: string) => `redeclare ${type} definition: "${src}"` + ), + INVALID_ST_DEF: createDiagnosticReporter( + '21011', + 'error', + (params: string) => `invalid @st "${params}" definition` + ), + MAPPING_UNSUPPORTED_NESTING: createDiagnosticReporter( + '21012', + 'error', + () => 'mapped selector can only contain `&` as an initial selector' + ), + UNEXPECTED_EXTRA_VALUE: createDiagnosticReporter( + '21013', + 'error', + (extraValue: string) => `found unexpected extra value definition: "${extraValue}"` + ), + CLASS_OUT_OF_CONTEXT: createDiagnosticReporter( + '21014', + 'error', + () => 'class definition must be top level' + ), +}; + +export interface PartSymbol extends HasParts, STCustomState.HasStates { + _kind: 'part'; + name: string; + id: string; + mapTo: ImmutableSelectorList | CSSClass.ClassSymbol; +} +export interface HasParts { + '-st-parts': Record; +} + +export const experimentalMsg = '[experimental feature] stylable structure (@st): API might change!'; + +const dataKey = plugableRecord.key<{ + isStructureMode: boolean; + analyzedDefs: WeakMap; + analyzedDefToPartSymbol: Map; + declaredClasses: Set; +}>('st-structure'); + +// HOOKS + +export const hooks = createFeature({ + analyzeInit(context) { + const { meta } = context; + if (meta.type !== 'stylable') { + return; + } + const stAtRule = meta.sourceAst.nodes.find((node) => isStAtRule(node)); + if (stAtRule) { + warnOnce(experimentalMsg); + const metaAnalysis = plugableRecord.getUnsafe(context.meta.data, dataKey); + metaAnalysis.isStructureMode = true; + } else { + // set implicit root for legacy mode (root with flat structure) + meta.root = 'root'; + const rootSymbol = CSSClass.addClass(context, 'root'); + rootSymbol[`-st-root`] = true; + } + }, + metaInit({ meta }) { + plugableRecord.set(meta.data, dataKey, { + // default to legacy flat mode + isStructureMode: false, + analyzedDefs: new WeakMap(), + analyzedDefToPartSymbol: new Map(), + declaredClasses: new Set(), + }); + }, + analyzeAtRule({ context, atRule, analyzeRule }) { + if (!isStAtRule(atRule) || context.meta.type !== 'stylable') { + return; + } + + const { analyzedDefToPartSymbol, declaredClasses } = plugableRecord.getUnsafe( + context.meta.data, + dataKey + ); + const analyzed = analyzeStAtRule(atRule, context); + if (!analyzed) { + // not valid + } else if (analyzed.type === 'topLevelClass') { + declaredClasses.add(analyzed.name); + CSSClass.addClass(context, analyzed.name, atRule); + CSSClass.disableDirectivesForClass(context, analyzed.name); + // extend class + if (analyzed.extendedClass) { + const extendedSymbol = + CSSClass.get(context.meta, analyzed.extendedClass) || + CSSClass.addClass(context, analyzed.extendedClass); + CSSClass.extendTypedRule( + context, + atRule, + '.' + analyzed.name, + '-st-extends', + getAlias(extendedSymbol) || extendedSymbol + ); + } + // class mapping + if (analyzed.mappedSelector) { + // ToDo: support non global mapping + const globalNode = findGlobalPseudo(analyzed); + if (globalNode && globalNode.nodes?.length === 1) { + const mappedSelectorAst = globalNode.nodes[0]; + // analyze mapped selector + analyzeRule( + postcss.rule({ + selector: stringifySelectorAst(mappedSelectorAst), + source: atRule.source, + }), + { + isScoped: false, + originalNode: atRule, + } + ); + // register global mapping to class + CSSClass.extendTypedRule( + context, + atRule, + analyzed.name, + '-st-global', + mappedSelectorAst.nodes + ); + } + } + } else if (analyzed.type === 'part') { + const parentSymbol = getPartParentSymbol(context, analyzed, analyzedDefToPartSymbol); + if (!parentSymbol) { + // unreachable: assuming analyzing @st definitions dfs - class/part must be defined + context.diagnostics.report(diagnostics.ELEMENT_OUT_OF_CONTEXT(), { + node: atRule, + }); + return; + } + const partName = analyzed.name; + // check re-declare + if (getPart(parentSymbol, partName)) { + const srcWord = '::' + partName; + context.diagnostics.report(diagnostics.REDECLARE('pseudo-element', srcWord), { + node: atRule, + word: srcWord, + }); + return; + } + // analyze mapped selector + analyzeRule( + postcss.rule({ + selector: stringifySelectorAst(analyzed.mappedSelector), + source: atRule.source, + }), + { + isScoped: true, + originalNode: atRule, + } + ); + // register part mapping to parent definition + const partSymbol = setPart(parentSymbol, getSymbolId(parentSymbol), partName, [ + analyzed.mappedSelector, + ]); + analyzedDefToPartSymbol.set(analyzed, partSymbol); + } else if (analyzed.type === 'state') { + const parentSymbol = + analyzed.parentAnalyze.type === 'topLevelClass' + ? CSSClass.get(context.meta, analyzed.parentAnalyze.name) + : analyzedDefToPartSymbol.get(analyzed.parentAnalyze); + if (!parentSymbol) { + // unreachable: assuming analyzing @st definitions dfs - class/part must be defined + context.diagnostics.report(diagnostics.STATE_OUT_OF_CONTEXT(), { + node: atRule, + }); + return; + } + const mappedStates = (parentSymbol['-st-states'] ||= {}); + const stateName = analyzed.name; + if (mappedStates[stateName]) { + // first state definition wins + const srcWord = ':' + stateName; + context.diagnostics.report(diagnostics.REDECLARE('pseudo-state', srcWord), { + node: atRule, + word: srcWord, + }); + return; + } + mappedStates[stateName] = analyzed.stateDef; + } + }, + analyzeDone({ meta }) { + const { isStructureMode } = plugableRecord.getUnsafe(meta.data, dataKey); + if (meta.type === 'stylable' && !isStructureMode) { + // legacy flat mode: + // classes and custom-selectors are registered as .root pseudo-elements + const customSelectors = STCustomSelector.getCustomSelectors(meta); + const classes = CSSClass.getAll(meta); + const rootClass = classes['root']!; + const rootId = getSymbolId(rootClass); + // custom-selector definition precedence over class definition + for (const [partName, mapTo] of Object.entries(customSelectors)) { + setPart(rootClass, rootId, partName, mapTo); + } + for (const [className, classSymbol] of Object.entries(classes)) { + if (className === 'root' || customSelectors[className]) { + continue; + } + setPart(rootClass, rootId, className, classSymbol); + } + } + }, +}); + +// API + +function isStAtRule(node: postcss.AnyNode): node is postcss.AtRule { + return node?.type === 'atrule' && node.name === 'st'; +} + +function getPartParentSymbol( + context: FeatureContext, + { parentAnalyze }: ParsedStPart, + analyzedDefToPartSymbol: Map +) { + return parentAnalyze.type === 'topLevelClass' + ? CSSClass.get(context.meta, parentAnalyze.name) + : analyzedDefToPartSymbol.get(parentAnalyze); +} + +export function isStructureMode(meta: StylableMeta) { + return plugableRecord.getUnsafe(meta.data, dataKey).isStructureMode; +} + +export function createPartSymbol( + input: Partial & Pick +): PartSymbol { + const parts = input['-st-parts'] || {}; + const states = input['-st-states'] || {}; + return { ...input, _kind: 'part', '-st-parts': parts, '-st-states': states }; +} + +export function setPart( + symbol: HasParts, + parentId: string, + partName: string, + mapTo: PartSymbol['mapTo'] +) { + const partSymbol = createPartSymbol({ + name: partName, + id: parentId + '::' + partName, + mapTo, + }); + symbol['-st-parts'][partName] = partSymbol; + return partSymbol; +} + +export function getParts(symbol: HasParts) { + return symbol['-st-parts']; +} + +export function getPart(symbol: HasParts, name: string): PartSymbol | undefined { + return symbol['-st-parts'][name]; +} + +export function getPartNames(symbol: HasParts) { + return Object.keys(symbol['-st-parts']); +} + +function getSymbolId(symbol: CSSClass.ClassSymbol | PartSymbol) { + return symbol._kind === 'class' ? '.' + symbol.name : symbol.id; +} + +type ParsedStClass = { + type: 'topLevelClass'; + params: BaseAstNode[]; + match: boolean; + ranges: Record<'class' | 'extend' | 'mapArrow' | 'mapTo' | 'leftoverValue', BaseAstNode[]>; + name: string; + extendedClass?: string; + mappedSelector?: ImmutableSelector; +}; + +interface ParsedStPart { + type: 'part'; + params: BaseAstNode[]; + match: boolean; + ranges: Record<'pseudoElement' | 'mapArrow' | 'mapTo' | 'leftoverValue', BaseAstNode[]>; + name: string; + parentAnalyze: ParsedStClass | ParsedStPart; + mappedArrow: boolean; + mappedSelector: ImmutableSelector; +} + +interface ParsedStState { + type: 'state'; + params: BaseAstNode[]; + match: boolean; + ranges: Record<'leftoverValue', BaseAstNode[]>; + name: string; + parentAnalyze: ParsedStClass | ParsedStPart; + stateDef: MappedStates[string]; +} + +function isMatch(result: any): result is AnalyzedStDef { + return result.match; +} + +type AnalyzedStDef = ParsedStClass | ParsedStPart | ParsedStState; +function analyzeStAtRule( + atRule: postcss.AtRule, + context: FeatureContext +): AnalyzedStDef | undefined { + // cache + const { analyzedDefs } = plugableRecord.getUnsafe(context.meta.data, dataKey); + if (analyzedDefs.has(atRule)) { + return analyzedDefs.get(atRule); + } + // parse + const params = parseCSSValue(atRuleFullParams(atRule)); + + const def = + params.length === 0 + ? undefined + : parseClassDefinition(atRule, params) || + parsePseudoElementDefinition(context, atRule, params) || + parseStateDefinition(context, atRule, params); + + if (!def) { + if (atRule.parent?.type === 'root') { + context.diagnostics.report(diagnostics.UNSUPPORTED_TOP_DEF(), { + node: atRule, + }); + } else { + context.diagnostics.report(diagnostics.INVALID_ST_DEF(atRule.params), { + node: atRule, + }); + } + return; + } + + // validate + switch (def.type) { + case 'topLevelClass': { + if (!validateTopLevelClass({ def, atRule, context })) { + return; + } + break; + } + case 'part': { + if (!validatePart({ def, atRule, context })) { + return; + } + break; + } + case 'state': { + if (!validateState({ def, atRule, context })) { + return; + } + break; + } + } + if (!isMatch(def)) { + return; + } + + analyzedDefs.set(atRule, def); + return def; +} + +function validateTopLevelClass({ + def, + atRule, + context, +}: { + def: Partial; + atRule: postcss.AtRule; + context: FeatureContext; +}) { + const { declaredClasses } = plugableRecord.getUnsafe(context.meta.data, dataKey); + if (!def.ranges || !def.params) { + // should always be provided by parser + return false; + } + if (!def.name) { + // ToDo: fix type to have name required + return false; + } + if (def.ranges.extend.length && !def.extendedClass) { + context.diagnostics.report(diagnostics.MISSING_EXTEND(), { + node: atRule, + word: stringifyCSSValue(def.ranges.extend), + }); + } + if (def.ranges.leftoverValue.find((node) => node.type !== 'comment' && node.type !== 'space')) { + const unexpectedValue = stringifyCSSValue(def.ranges.leftoverValue).trim(); + context.diagnostics.report(diagnostics.UNEXPECTED_EXTRA_VALUE(unexpectedValue), { + node: atRule, + word: unexpectedValue, + }); + return false; + } + if (atRule.parent?.type !== 'root') { + context.diagnostics.report(diagnostics.CLASS_OUT_OF_CONTEXT(), { + node: atRule, + }); + return false; + } + const existingSymbol = STSymbol.get(context.meta, def.name); + if (existingSymbol?._kind === 'import') { + context.diagnostics.report(diagnostics.OVERRIDE_IMPORTED_CLASS(), { + node: atRule, + }); + return false; + } + if (declaredClasses.has(def.name)) { + // ToDo: use st-symbol redeclare api; improve st-symbol/css-class "final" marking and diagnostics + const srcWord = '.' + def.name; + context.diagnostics.report(diagnostics.REDECLARE('class', srcWord), { + node: atRule, + word: srcWord, + }); + return false; + } + if (def.ranges.mapArrow.length) { + if (!def.mappedSelector) { + // report missing selector + const arrowEnd = def.ranges.mapArrow[def.ranges.mapArrow.length - 1]; + for (let i = def.params.length - 1; i >= 0; i--) { + const node = def.params[i]; + if (node === arrowEnd) { + break; + } else if (isExactLiteral(node, ',')) { + context.diagnostics.report(diagnostics.MULTI_MAPPED_SELECTOR(), { + node: atRule, + }); + return false; + } + } + context.diagnostics.report(diagnostics.MISSING_MAPPED_SELECTOR(), { + node: atRule, + }); + return false; + } + const globalNode = findGlobalPseudo(def, true); + if (!globalNode || !globalNode.nodes || globalNode.nodes.length !== 1) { + context.diagnostics.report(diagnostics.GLOBAL_MAPPING_LIMITATION(), { + node: atRule, + word: stringifySelectorAst(def.mappedSelector).trim(), + }); + return false; + } + } + return true; +} +function validatePart({ + def, + atRule, + context, +}: { + def: Partial; + atRule: postcss.AtRule; + context: FeatureContext; +}) { + if (!def.parentAnalyze) { + context.diagnostics.report(diagnostics.ELEMENT_OUT_OF_CONTEXT(), { + node: atRule, + }); + return false; + } + if (!def.mappedSelector) { + if (!def.mappedArrow) { + context.diagnostics.report(diagnostics.MISSING_MAPPING(), { + node: atRule, + }); + return false; + } + // report missing selector + const arrowEnd = def.ranges!.mapArrow[def.ranges!.mapArrow.length - 1]; + for (let i = def.params!.length - 1; i >= 0; i--) { + const node = def.params![i]; + if (node === arrowEnd) { + break; + } else if (isExactLiteral(node, ',')) { + context.diagnostics.report(diagnostics.MULTI_MAPPED_SELECTOR(), { + node: atRule, + }); + return false; + } + } + context.diagnostics.report(diagnostics.MISSING_MAPPED_SELECTOR(), { + node: atRule, + }); + return false; + } + if (validateNestingInMapping(def.mappedSelector, context, atRule)) { + return false; + } + return true; +} +function validateState({ + def, + atRule, + context, +}: { + def: Partial; + atRule: postcss.AtRule; + context: FeatureContext; +}) { + if (!def.parentAnalyze) { + context.diagnostics.report(diagnostics.STATE_OUT_OF_CONTEXT(), { + node: atRule, + }); + return false; + } + const [amountToActualValue] = findAnything(def.ranges!.leftoverValue, 0); + if (amountToActualValue) { + const unexpectedValue = stringifyCSSValue(def.ranges!.leftoverValue).trim(); + context.diagnostics.report(diagnostics.UNEXPECTED_EXTRA_VALUE(unexpectedValue), { + node: atRule, + word: unexpectedValue, + }); + return false; + } + + return true; +} +function findGlobalPseudo(def: Partial, checkAfter = false) { + if (!def.mappedSelector) { + return; + } + let globalNode: ImmutablePseudoClass | undefined = undefined; + let foundUnexpectedSelector = false; + for (const node of def.mappedSelector.nodes) { + if (node.type === 'pseudo_class' && node.value === 'global' && !globalNode) { + globalNode = node; + if (!checkAfter) { + break; + } + } else if (node.type !== 'comment') { + foundUnexpectedSelector = true; + } + } + return foundUnexpectedSelector ? undefined : globalNode; +} + +function parseStateDefinition( + context: FeatureContext, + atRule: postcss.AtRule, + params: BaseAstNode[] +) { + const result: Partial = { + type: 'state', + params, + match: true, + ranges: { leftoverValue: [] }, + }; + + let index = 0; + + const { analyzedDefs } = plugableRecord.getUnsafe(context.meta.data, dataKey); // name + const [amountToName, nameNode] = findNextPseudoClassNode(params, 0); + if (nameNode) { + result.name = nameNode.value; + } else { + // not a pseudo-state definition + return; + } + index += amountToName; + // parent + const parentRule = atRule.parent; + const parentAnalyze = parentRule && analyzedDefs.get(parentRule as any); + if ( + parentAnalyze && + (parentAnalyze.type === 'topLevelClass' || parentAnalyze.type === 'part') + ) { + result.parentAnalyze = parentAnalyze; + } + // state + const [amountToStateDef, stateDef] = STCustomState.parseStateValue( + params.slice(index - 1), + atRule, + context.diagnostics + ); + if (stateDef !== undefined) { + index += amountToStateDef; + result.stateDef = stateDef; + } else { + result.match = false; + } + // leftover + const amountTaken = index - 1; + result.ranges!.leftoverValue.push(...params.slice(amountTaken)); + const [amountToUnexpected] = findAnything(params, index); + if (amountToUnexpected) { + result.match = false; + } + return result; +} + +function parsePseudoElementDefinition( + context: FeatureContext, + atRule: postcss.AtRule, + params: BaseAstNode[] +) { + const { analyzedDefs } = plugableRecord.getUnsafe(context.meta.data, dataKey); + const result: Partial = { + type: 'part', + params, + match: true, + name: '', + ranges: { pseudoElement: [], mapArrow: [], mapTo: [], leftoverValue: [] }, + }; + + let index = 0; + + // collect pseudo element name + const [amountToName, nameNode, nameInspectAmount] = findPseudoElementNode(params, 0); + result.ranges!.pseudoElement.push(...params.slice(index, index + nameInspectAmount)); + index += amountToName; + if (nameNode) { + result.name = nameNode.value; + } else { + // not a pseudo-element definition + return false; + } + // get symbol to extend + const parentRule = atRule.parent; + const parentAnalyze = parentRule && analyzedDefs.get(parentRule as any); + if (parentAnalyze?.type === 'topLevelClass' || parentAnalyze?.type === 'part') { + result.parentAnalyze = parentAnalyze; + } + // collect mapped selector + const [amountToMapping, mappingOpenNode, mapArrowInspectAmount] = findFatArrow(params, index, { + stopOnFail: false, + }); + result.ranges!.mapArrow.push(...params.slice(index, index + mapArrowInspectAmount)); + index += amountToMapping; + if (mappingOpenNode) { + result.mappedArrow = true; + // selector + result.ranges!.mapTo.push(...params.slice(index)); + index = params.length - 1; + const selectorStr = atRuleFullParams(atRule).slice(mappingOpenNode.end); + const mappedSelectors = parseSelectorWithCache(selectorStr.trim()); + const filteredSelector = + mappedSelectors.length === 1 && filterCommentsAndSpaces(mappedSelectors[0]); + if (filteredSelector && filteredSelector.nodes.length) { + result.mappedSelector = filteredSelector; + } + } else { + result.match = false; + } + // check unexpected extra + result.ranges!.leftoverValue.push(...params.slice(index + 1)); + + return result; +} + +function parseClassDefinition(atRule: postcss.AtRule, params: BaseAstNode[]) { + const result: ParsedStClass = { + type: 'topLevelClass', + params, + match: true, + ranges: { class: [], extend: [], mapArrow: [], mapTo: [], leftoverValue: [] }, + name: '', + }; + + let index = 0; + // top level class + const [amountToClass, classNameNode, classInspectedAmount] = findNextClassNode(params, index, { + stopOnFail: true, + }); + result.ranges.class.push(...params.slice(index, index + classInspectedAmount)); + index += amountToClass; + if (classNameNode) { + result.name = classNameNode.value; + } else { + // not a class definition + return false; + } + // collect extends class + const [amountToExtends, extendsNode, extendInspectAmount] = findNextPseudoClassNode( + params, + index, + { + name: 'is', + stopOnFail: true, + stopOnMatch: (_node, index, nodes) => { + const [amountToFatArrow] = findFatArrow(nodes, index, { stopOnFail: true }); + return amountToFatArrow > 0; + }, + } + ); + if (extendsNode) { + result.ranges.extend.push(...params.slice(index, index + extendInspectAmount)); + index += amountToExtends; + if (extendsNode.type === 'call') { + const [amountToExtendedClass, nameNode] = findNextClassNode(extendsNode.args, 0, { + stopOnFail: true, + }); + if (amountToExtendedClass) { + index += amountToExtends; + // check leftover nodes + const [amountToUnexpectedNode] = findAnything( + extendsNode.args, + amountToExtendedClass + ); + if (!amountToUnexpectedNode) { + result.extendedClass = nameNode!.value; + } + } + } + } + // collect mapped selector + const [amountToMapping, mappingOpenNode, mapArrowInspectAmount] = findFatArrow(params, index, { + stopOnFail: false, + }); + if (mappingOpenNode) { + result.ranges.mapArrow.push(...params.slice(index, index + mapArrowInspectAmount)); + index += amountToMapping; + // selector + result.ranges.mapTo.push(...params.slice(index)); + index = params.length; + const selectorStr = atRuleFullParams(atRule).slice(mappingOpenNode.end); + const mappedSelectors = parseSelectorWithCache(selectorStr); + const filteredSelector = + mappedSelectors.length === 1 && filterCommentsAndSpaces(mappedSelectors[0]); + if (filteredSelector && filteredSelector.nodes.length) { + result.mappedSelector = filteredSelector; + } + } + // unexpected extra value + result.ranges.leftoverValue.push(...params.slice(index)); + + return result; +} + +function validateNestingInMapping( + selector: ImmutableSelector, + context: FeatureContext, + atRule: postcss.AtRule +) { + // check for unsupported & anywhere except first + let invalid = false; + let passedActualSelector = false; + walkSelector(selector, (node) => { + if (passedActualSelector && node.type === 'nesting') { + context.diagnostics.report(diagnostics.MAPPING_UNSUPPORTED_NESTING(), { + node: atRule, + }); + invalid = true; + return walkSelector.stopAll; + } else if (node.type !== 'comment' && node.type !== 'selector') { + passedActualSelector = true; + } + return; + }); + return invalid; +} + +function atRuleFullParams(atRule: postcss.AtRule) { + const afterName = atRule.raws.afterName || ''; + const between = atRule.raws.between || ''; + return afterName + atRule.params + between; +} + +function filterCommentsAndSpaces(selector: ImmutableSelector) { + const filteredSelector: ImmutableSelector = { + ...selector, + after: '', + before: '', + nodes: selector.nodes.filter((node) => node.type !== 'comment'), + }; + return filteredSelector; +} diff --git a/packages/core/src/features/st-var.ts b/packages/core/src/features/st-var.ts index dc75f5d7f8..aa52d4d74e 100644 --- a/packages/core/src/features/st-var.ts +++ b/packages/core/src/features/st-var.ts @@ -96,6 +96,13 @@ export const diagnostics = { 'error', (name: string) => `unknown var "${name}"` ), + UNKNOWN_CUSTOM_PROP: createDiagnosticReporter('07011', 'info', (names: string[]) => { + const msgStart = + names.length > 1 + ? `Unknown custom-properties "${names.join(', ')}" are` + : `Unknown custom-property "${names[0]}" is`; + return `${msgStart} currently not namespaced. However, in Stylable 6, it will be namespaced to the stylesheet. To maintain the current behavior, either wrap the value in quotes or establish a global custom property. If you intend for the custom property to be namespaced based on a different stylesheet context where the variable may be utilized, please reconsider your approach, as this will not be supported in future versions.`; + }), }; // HOOKS @@ -125,6 +132,33 @@ export const hooks = createFeature<{ } return; }, + transformInit({ context }) { + const { cssVar } = context.getResolvedSymbols(context.meta); + for (const [_localName, localSymbol] of Object.entries( + STSymbol.getAllByType(context.meta, 'var') + )) { + const value = postcssValueParser(stripQuotation(localSymbol.text)); + const unknownUsedProps: string[] = []; + value.walk((node) => { + if (node.type === 'function' && node.value.toLowerCase() === 'var') { + for (const argNode of node.nodes) { + if ( + argNode.type === 'word' && + argNode.value.startsWith('--') && + !cssVar[argNode.value] + ) { + unknownUsedProps.push(argNode.value); + } + } + } + }); + if (unknownUsedProps.length) { + context.diagnostics.report(diagnostics.UNKNOWN_CUSTOM_PROP(unknownUsedProps), { + node: localSymbol.node, + }); + } + } + }, prepareAST({ node, toRemove }) { if (node.type === 'rule' && node.selector === ':vars') { toRemove.push(node); diff --git a/packages/core/src/functions.ts b/packages/core/src/functions.ts index 5ac4d8d84e..9bf44bc386 100644 --- a/packages/core/src/functions.ts +++ b/packages/core/src/functions.ts @@ -2,7 +2,7 @@ import { dirname, relative } from 'path'; import postcssValueParser from 'postcss-value-parser'; import type * as postcss from 'postcss'; import { createDiagnosticReporter, Diagnostics } from './diagnostics'; -import { isCssNativeFunction } from './native-reserved-lists'; +import { nativeFunctionsDic } from './native-reserved-lists'; import { assureRelativeUrlPrefix } from './stylable-assets'; import type { StylableMeta } from './stylable-meta'; import { @@ -180,7 +180,7 @@ export function processDeclarationValue( ); } } else if (value === 'format') { - // preserve native format function quotation + // preserve native format function arg quotation parsedNode.resolvedValue = stringifyFunction(value, parsedNode, true); } else if (resolvedSymbols.js[value]) { const formatter = resolvedSymbols.js[value]; @@ -232,8 +232,9 @@ export function processDeclarationValue( }, node: parsedNode, }); - } else if (isCssNativeFunction(value)) { - parsedNode.resolvedValue = stringifyFunction(value, parsedNode); + } else if (nativeFunctionsDic[value]) { + const { preserveQuotes } = nativeFunctionsDic[value]; + parsedNode.resolvedValue = stringifyFunction(value, parsedNode, preserveQuotes); } else if (node) { parsedNode.resolvedValue = stringifyFunction(value, parsedNode); diagnostics.report(functionDiagnostics.UNKNOWN_FORMATTER(value), { diff --git a/packages/core/src/helpers/css-value-seeker.ts b/packages/core/src/helpers/css-value-seeker.ts new file mode 100644 index 0000000000..508733275d --- /dev/null +++ b/packages/core/src/helpers/css-value-seeker.ts @@ -0,0 +1,218 @@ +import type { BaseAstNode, Call, CustomIdent, Literal } from '@tokey/css-value-parser'; + +export interface FindAstOptions { + stopOnFail: boolean; + ignoreWhitespace: boolean; + ignoreComments: boolean; + stopOnMatch?: (node: BaseAstNode, index: number, nodes: BaseAstNode[]) => boolean; + name?: string; +} + +type FindAstResult = [ + takenNodeAmount: number, + matchedNode: T | undefined, + inspectedAmount: number +]; + +export function findAnything( + value: BaseAstNode[], + startIndex: number, + options?: Partial +) { + return findValueAstNode(value, startIndex, () => true, options); +} + +export function findFatArrow( + value: BaseAstNode[], + startIndex: number, + options?: Partial +): FindAstResult' }> { + const [amountToEql, _eqlNode, eqlNodeInspectAmount] = findLiteral(value, startIndex, { + ...options, + name: '=', + }); + if (amountToEql) { + const nextNode = value[startIndex + amountToEql]; + if (isExactLiteral(nextNode, '>')) { + return [amountToEql + 1, nextNode, amountToEql + 1]; + } + } + return [0, undefined, eqlNodeInspectAmount]; +} +export function isExactLiteral( + token: BaseAstNode, + name: T +): token is Literal & { value: '>' } { + return token && token.type === 'literal' && token.value === name; +} +export function findNextClassNode( + value: BaseAstNode[], + startIndex: number, + options?: Partial +): FindAstResult { + const name = options?.name || ''; + let index = startIndex; + while (index < value.length) { + const [amountToDot, _dotNode] = findLiteral(value, index, { ...options, name: '.' }); + if (amountToDot) { + index += amountToDot; + const [amountToName, nameNode] = findCustomIdent(value, index, { + name, + stopOnFail: true, + }); + if (amountToName) { + return [amountToDot + amountToName, nameNode, index - startIndex + 1]; + } + } + if (options?.stopOnFail) { + break; + } + index++; + } + return [0, undefined, value.length - startIndex]; +} +export function findNextPseudoClassNode( + value: BaseAstNode[], + startIndex: number, + options?: Partial +): FindAstResult { + const name = options?.name || ''; + let index = startIndex; + while (index < value.length) { + const [amountToColon] = findLiteral(value, index, { ...options, name: ':' }); + if (amountToColon) { + index += amountToColon; + const nameOptions: FindAstOptions = { + name, + stopOnFail: true, + ignoreComments: true, + ignoreWhitespace: false, + }; + const [amountToName, nameNode] = findCustomIdent(value, index, nameOptions); + + if (amountToName) { + return [amountToColon + amountToName, nameNode, index - startIndex + 1]; + } else { + const [amountToCall, callNode] = findNextCallNode(value, index, nameOptions); + if (amountToCall) { + return [amountToColon + amountToCall, callNode, index - startIndex + 1]; + } else { + break; + } + } + } else if (options?.stopOnFail) { + break; + } else { + index++; + } + } + return [0, undefined, value.length - startIndex]; +} + +export function findPseudoElementNode( + value: BaseAstNode[], + startIndex: number, + options?: Partial +): FindAstResult { + let index = startIndex; + while (index < value.length) { + // first colon + const [amountToColon] = findLiteral(value, index, { ...options, name: ':' }); // second colon + if (amountToColon) { + index += amountToColon; // name + const [amountToSecondColon] = findLiteral(value, index, { + ...options, + name: ':', + stopOnFail: true, + ignoreWhitespace: false, + }); + if (amountToSecondColon) { + index += amountToSecondColon; + const [amountToName, nameNode] = findCustomIdent(value, index, { + ...options, + stopOnFail: true, + }); + if (nameNode) { + return [ + index - startIndex + amountToName, + nameNode, + index - startIndex + amountToName, + ]; + } + } + } + if (options?.stopOnFail) { + break; + } + index++; + } + return [0, undefined, index - startIndex]; +} + +export function findLiteral( + value: BaseAstNode[], + startIndex: number, + options?: Partial +): FindAstResult { + const name = options?.name || ''; + return findValueAstNode( + value, + startIndex, + (node) => node.type === 'literal' && (!name || node.value === name), + options + ); +} +export function findCustomIdent( + value: BaseAstNode[], + startIndex: number, + options?: Partial +): FindAstResult { + const name = options?.name || ''; + return findValueAstNode( + value, + startIndex, + (node) => node.type === '' && (!name || node.value === name), + options + ); +} +export function findNextCallNode( + value: BaseAstNode[], + startIndex: number, + options?: Partial +): FindAstResult { + const name = options?.name || ''; + return findValueAstNode( + value, + startIndex, + (node) => node.type === 'call' && (!name || node.value === name), + options + ); +} + +export function findValueAstNode( + valueAst: BaseAstNode[], + startIndex: number, + check: (node: BaseAstNode) => boolean, + { + stopOnFail = true, + ignoreWhitespace = true, + ignoreComments = true, + stopOnMatch, + }: Partial = {} +): FindAstResult { + let index = startIndex; + while (index < valueAst.length) { + const node = valueAst[index]; + if (ignoreComments && node.type === 'comment') { + // continue; + } else if (ignoreWhitespace && node.type === 'space') { + // continue; + } else if (check(node)) { + return [index - startIndex + 1, node as T, index - startIndex + 1]; + } else if (stopOnFail || stopOnMatch?.(node, index, valueAst)) { + break; + } + index++; + } + return [0, undefined, index - startIndex]; +} diff --git a/packages/core/src/helpers/custom-state.ts b/packages/core/src/helpers/custom-state.ts index 31a68d8e36..1cd8ef0da3 100644 --- a/packages/core/src/helpers/custom-state.ts +++ b/packages/core/src/helpers/custom-state.ts @@ -21,6 +21,8 @@ import type { StylableResolver } from '../stylable-resolver'; import type { ParsedValue } from '../types'; import { CSSClass } from '../features'; import { reservedFunctionalPseudoClasses } from '../native-reserved-lists'; +import { BaseAstNode, stringifyCSSValue } from '@tokey/css-value-parser'; +import { findCustomIdent, findNextCallNode } from './css-value-seeker'; export interface MappedStates { [s: string]: StateParsedValue | string | TemplateStateParsedValue | null; @@ -152,6 +154,12 @@ export const stateDiagnostics = { (state: string, finalSelector: string) => `pseudo-state "${state}" result cannot start with a type or universal selector "${finalSelector}"` ), + NO_PARAM_REQUIRED: createDiagnosticReporter( + '08018', + 'error', + (name: string, param: string) => + `pseudo-state "${name}" accepts no parameter, but received "${param}"` + ), }; // parse @@ -167,17 +175,8 @@ export function parsePseudoStates( statesSplitByComma.forEach((workingState: ParsedValue[]) => { const [stateDefinition, ...stateDefault] = workingState; - - if (stateDefinition.value.startsWith('-')) { - diagnostics.report(stateDiagnostics.STATE_STARTS_WITH_HYPHEN(stateDefinition.value), { - node: decl, - word: stateDefinition.value, - }); - } else if (reservedFunctionalPseudoClasses.includes(stateDefinition.value)) { - diagnostics.report(stateDiagnostics.RESERVED_NATIVE_STATE(stateDefinition.value), { - node: decl, - word: stateDefinition.value, - }); + const stateName = stateDefinition.value; + if (!validateStateName(stateName, diagnostics, decl)) { return; } @@ -198,6 +197,64 @@ export function parsePseudoStates( return mappedStates; } +function validateStateName(name: string, diagnostics: Diagnostics, node: postcss.Node) { + if (name.startsWith('-')) { + diagnostics.report(stateDiagnostics.STATE_STARTS_WITH_HYPHEN(name), { + node: node, + word: name, + }); + } else if (reservedFunctionalPseudoClasses.includes(name)) { + diagnostics.report(stateDiagnostics.RESERVED_NATIVE_STATE(name), { + node: node, + word: name, + }); + return false; + } + return true; +} +export function parseStateValue( + value: BaseAstNode[], + node: postcss.Node, + diagnostics: Diagnostics +): [amountTaken: number, stateDef: MappedStates[string] | undefined] { + let stateName = ''; + let stateDef: MappedStates[string] = null; /*boolean*/ + let amountTaken = 0; + const customIdentResult = findCustomIdent(value, 0); + const [amountToName, nameNode] = customIdentResult[0] + ? customIdentResult + : findNextCallNode(value, 0); + if (nameNode && validateStateName(nameNode.value, diagnostics, node)) { + amountTaken += amountToName; + stateName = nameNode.value; + // state with parameter + if (nameNode.type === 'call') { + // take all of the definition since default value takes the rest + amountTaken = value.length; + // ToDo: translate resolveStateType to tokey and remove the double parsing + const postcssStateValue = postcssValueParser( + stringifyCSSValue(value.slice(amountToName - 1)) + ); + // get state definition + const [stateDefinition, ...stateDefault] = postcssStateValue.nodes; + const stateMap: MappedStates = {}; + resolveStateType( + stateDefinition as FunctionNode, + stateMap, + stateDefault, + diagnostics, + node as postcss.Declaration // ToDo: change to accept any postcss node + ); + if (stateMap[stateName]) { + stateDef = stateMap[stateName]; + } + } + } + if (stateName) { + return [amountTaken, stateDef]; + } + return [0, undefined]; +} function resolveBooleanState(mappedStates: MappedStates, stateDefinition: ParsedValue) { const currentState = mappedStates[stateDefinition.value]; if (!currentState) { @@ -724,8 +781,8 @@ export function validateRuleStateDefinition( !!stateParam.defaultValue ); if (errors) { - selectorNode.walkDecls((decl) => { - if (decl.prop === `-st-states`) { + for (const node of selectorNode.nodes) { + if (node.type === 'decl' && node.prop === `-st-states`) { diagnostics.report( stateDiagnostics.DEFAULT_PARAM_FAILS_VALIDATION( stateName, @@ -733,14 +790,13 @@ export function validateRuleStateDefinition( errors ), { - node: decl, - word: decl.value, + node: node, + word: node.value, } ); - return false; + break; } - return; - }); + } } } } @@ -805,12 +861,24 @@ export function transformPseudoClassToCustomState( diagnostics: Diagnostics, selectorNode?: postcss.Node ) { - if (stateDef === null) { - convertToClass(stateNode).value = createBooleanStateClassName(name, namespace); - delete stateNode.nodes; - } else if (typeof stateDef === 'string') { - // simply concat global mapped selector - ToDo: maybe change to 'selector' - convertToInvalid(stateNode).value = stateDef; + if (stateDef === null || typeof stateDef === 'string') { + if (stateNode.nodes && selectorNode) { + diagnostics.report( + stateDiagnostics.NO_PARAM_REQUIRED(name, stringifySelector(stateNode.nodes)), + { + node: selectorNode, + word: stringifySelector(stateNode), + } + ); + } + if (stateDef === null) { + // boolean + convertToClass(stateNode).value = createBooleanStateClassName(name, namespace); + } else { + // static template selector + // simply concat global mapped selector - ToDo: maybe change to 'selector' + convertToInvalid(stateNode).value = stateDef; + } delete stateNode.nodes; } else if (typeof stateDef === 'object') { if (isTemplateState(stateDef)) { diff --git a/packages/core/src/helpers/import.ts b/packages/core/src/helpers/import.ts index e966831c24..a43f1f1fe2 100644 --- a/packages/core/src/helpers/import.ts +++ b/packages/core/src/helpers/import.ts @@ -413,7 +413,10 @@ function createPseudoImportProps( function patchDecls(node: Rule, named: string[], pseudoImport: Imported) { const namedDecls: Declaration[] = []; const defaultDecls: Declaration[] = []; - node.walkDecls((decl) => { + for (const decl of node.nodes) { + if (decl.type !== 'decl') { + continue; + } if (decl.prop === '-st-named') { decl.assign({ value: named.join(', ') }); namedDecls.push(decl); @@ -421,7 +424,7 @@ function patchDecls(node: Rule, named: string[], pseudoImport: Imported) { decl.assign({ value: pseudoImport.defaultExport }); defaultDecls.push(decl); } - }); + } return { defaultDecls, namedDecls }; } diff --git a/packages/core/src/helpers/resolve.ts b/packages/core/src/helpers/resolve.ts index 4eb33a4268..1fcb17594a 100644 --- a/packages/core/src/helpers/resolve.ts +++ b/packages/core/src/helpers/resolve.ts @@ -1,7 +1,9 @@ -import type { ClassSymbol, ElementSymbol } from '../features'; +import type { ClassSymbol, ElementSymbol, STStructure } from '../features'; import type { CSSResolve } from '../stylable-resolver'; -export function getOriginDefinition(resolved: Array>) { +export function getOriginDefinition( + resolved: CSSResolve[] +) { for (const r of resolved) { const { symbol } = r; if (symbol._kind === 'class' || symbol._kind === 'element') { diff --git a/packages/core/src/helpers/rule.ts b/packages/core/src/helpers/rule.ts index 850a7d9f9c..f04c36d2b7 100644 --- a/packages/core/src/helpers/rule.ts +++ b/packages/core/src/helpers/rule.ts @@ -18,11 +18,17 @@ import * as postcss from 'postcss'; import { transformInlineCustomSelectors } from './custom-selector'; export function isChildOfAtRule(rule: postcss.Container, atRuleName: string) { - return !!( - rule.parent && - rule.parent.type === 'atrule' && - (rule.parent as postcss.AtRule).name === atRuleName - ); + let currentParent = rule.parent; + while (currentParent) { + if ( + currentParent.type === 'atrule' && + (currentParent as postcss.AtRule).name === atRuleName + ) { + return true; + } + currentParent = currentParent.parent; + } + return false; } export function isInConditionalGroup(node: postcss.Rule | postcss.AtRule, includeRoot = true) { @@ -100,14 +106,14 @@ export function createSubsetAst containsPrefix(node)); if (matchesSelectors.length) { - isNestedInMixin = true; + atruleHasMixin = true; scopeSelector = stringifySelector( matchesSelectors.map((selectorNode) => { if (!isRoot) { @@ -128,7 +134,7 @@ export function createSubsetAst(s: T): T { +export function cloneSelector(s: T): T { return cloneDeep(s); } diff --git a/packages/core/src/index-internal.ts b/packages/core/src/index-internal.ts index d4a2807223..2597b1341f 100644 --- a/packages/core/src/index-internal.ts +++ b/packages/core/src/index-internal.ts @@ -15,7 +15,6 @@ export { STImport, STGlobal, STNamespace, - STPart, STCustomSelector, STCustomState, CSSClass, @@ -24,7 +23,9 @@ export { CSSLayer, CSSContains, CSSCustomProperty, + STStructure, } from './features'; +export { defaultFeatureFlags } from './features/feature'; export type { MappedStates, StateParsedValue, diff --git a/packages/core/src/index.ts b/packages/core/src/index.ts index db5188b969..cd0ea213d8 100644 --- a/packages/core/src/index.ts +++ b/packages/core/src/index.ts @@ -37,3 +37,5 @@ export { createDefaultResolver } from './module-resolver'; // low-level api export { parseModuleImportStatement, ensureModuleImport } from './helpers/import'; export { validateCustomPropertyName } from './helpers/css-custom-property'; + +export { generateStylableJSModuleSource } from './stylable-js-module-source'; diff --git a/packages/core/src/native-reserved-lists.ts b/packages/core/src/native-reserved-lists.ts index 972161fc38..2f0f47bc86 100644 --- a/packages/core/src/native-reserved-lists.ts +++ b/packages/core/src/native-reserved-lists.ts @@ -4,6 +4,7 @@ export const nativePseudoClasses = [ 'any', 'any-link', 'checked', + 'indeterminate', 'default', 'defined', 'dir', @@ -48,6 +49,14 @@ export const nativePseudoClasses = [ 'valid', 'visited', 'where', + 'user-valid', + 'user-invalid', + 'autofill', + 'modal', + 'popover-open', + 'future', + 'past', + 'picture-in-picture', ]; export const CSSWideKeywords = ['initial', 'inherit', 'unset']; @@ -100,88 +109,120 @@ export const nativePseudoElements = [ 'selection', 'slotted', 'spelling-error', + 'file-selector-button', + 'highlight', + 'part', + 'target-text', + 'view-transition', + 'view-transition-group', + 'view-transition-image-pair', + 'view-transition-new', + 'view-transition-old', ]; -export const nativeFunctionsDic = { - annotation: true, - attr: true, - blur: true, - brightness: true, - calc: true, - 'character-variant': true, - circle: true, - clamp: true, - 'conic-gradient': true, - constant: true, - contrast: true, - counter: true, - counters: true, - 'cubic-bezier': true, - 'drop-shadow': true, - ellipse: true, - env: true, - 'fit-content': true, - format: true, - grayscale: true, - hsl: true, - hsla: true, - 'hue-rotate': true, - hwb: true, - image: true, - inset: true, - invert: true, - leader: true, - 'linear-gradient': true, - local: true, - matrix: true, - matrix3d: true, - max: true, - min: true, - minmax: true, - opacity: true, - ornaments: true, - paint: true, - path: true, - perspective: true, - polygon: true, - 'radial-gradient': true, - rect: true, - repeat: true, - 'repeating-linear-gradient': true, - 'repeating-radial-gradient': true, - 'repeating-conic-gradient': true, - rgb: true, - rgba: true, - rotate: true, - rotate3d: true, - rotateX: true, - rotateY: true, - rotateZ: true, - saturate: true, - scale: true, - scale3d: true, - scaleX: true, - scaleY: true, - scaleZ: true, - sepia: true, - skew: true, - skewX: true, - skewY: true, - steps: true, - styleset: true, - stylistic: true, - swash: true, - symbols: true, - translate: true, - translate3d: true, - translateX: true, - translateY: true, - translateZ: true, - url: true, - var: true, +export const nativeFunctionsDic: Record = { + annotation: { preserveQuotes: false }, + attr: { preserveQuotes: false }, + blur: { preserveQuotes: false }, + brightness: { preserveQuotes: false }, + calc: { preserveQuotes: false }, + 'character-variant': { preserveQuotes: false }, + circle: { preserveQuotes: false }, + clamp: { preserveQuotes: false }, + 'conic-gradient': { preserveQuotes: false }, + constant: { preserveQuotes: false }, + contrast: { preserveQuotes: false }, + counter: { preserveQuotes: false }, + counters: { preserveQuotes: false }, + 'cubic-bezier': { preserveQuotes: false }, + 'drop-shadow': { preserveQuotes: false }, + ellipse: { preserveQuotes: false }, + env: { preserveQuotes: false }, + 'fit-content': { preserveQuotes: false }, + format: { preserveQuotes: false }, + grayscale: { preserveQuotes: false }, + hsl: { preserveQuotes: false }, + hsla: { preserveQuotes: false }, + 'hue-rotate': { preserveQuotes: false }, + hwb: { preserveQuotes: false }, + image: { preserveQuotes: false }, + inset: { preserveQuotes: false }, + invert: { preserveQuotes: false }, + leader: { preserveQuotes: false }, + 'linear-gradient': { preserveQuotes: false }, + local: { preserveQuotes: false }, + matrix: { preserveQuotes: false }, + matrix3d: { preserveQuotes: false }, + max: { preserveQuotes: false }, + min: { preserveQuotes: false }, + minmax: { preserveQuotes: false }, + opacity: { preserveQuotes: false }, + ornaments: { preserveQuotes: false }, + paint: { preserveQuotes: false }, + path: { preserveQuotes: true }, + perspective: { preserveQuotes: false }, + polygon: { preserveQuotes: false }, + 'radial-gradient': { preserveQuotes: false }, + rect: { preserveQuotes: false }, + repeat: { preserveQuotes: false }, + 'repeating-linear-gradient': { preserveQuotes: false }, + 'repeating-radial-gradient': { preserveQuotes: false }, + 'repeating-conic-gradient': { preserveQuotes: false }, + rgb: { preserveQuotes: false }, + rgba: { preserveQuotes: false }, + rotate: { preserveQuotes: false }, + rotate3d: { preserveQuotes: false }, + rotateX: { preserveQuotes: false }, + rotateY: { preserveQuotes: false }, + rotateZ: { preserveQuotes: false }, + saturate: { preserveQuotes: false }, + scale: { preserveQuotes: false }, + scale3d: { preserveQuotes: false }, + scaleX: { preserveQuotes: false }, + scaleY: { preserveQuotes: false }, + scaleZ: { preserveQuotes: false }, + scroll: { preserveQuotes: false }, + view: { preserveQuotes: true }, + sepia: { preserveQuotes: false }, + skew: { preserveQuotes: false }, + skewX: { preserveQuotes: false }, + skewY: { preserveQuotes: false }, + steps: { preserveQuotes: false }, + styleset: { preserveQuotes: false }, + stylistic: { preserveQuotes: false }, + swash: { preserveQuotes: false }, + symbols: { preserveQuotes: false }, + translate: { preserveQuotes: false }, + translate3d: { preserveQuotes: false }, + translateX: { preserveQuotes: false }, + translateY: { preserveQuotes: false }, + translateZ: { preserveQuotes: false }, + url: { preserveQuotes: false }, + var: { preserveQuotes: false }, + color: { preserveQuotes: true }, + 'color-mix': { preserveQuotes: true }, + lab: { preserveQuotes: true }, + oklab: { preserveQuotes: true }, + lch: { preserveQuotes: true }, + oklch: { preserveQuotes: true }, + supports: { preserveQuotes: true }, + anchor: { preserveQuotes: true }, + 'anchor-size': { preserveQuotes: true }, + selector: { preserveQuotes: true /* TODO:transform the nested selector */ }, + style: { preserveQuotes: true /* TODO: transform the dashed ident property */ }, + 'image-set': { preserveQuotes: true }, + sin: { preserveQuotes: true }, + cos: { preserveQuotes: true }, + tan: { preserveQuotes: true }, + asin: { preserveQuotes: true }, + acos: { preserveQuotes: true }, + atan: { preserveQuotes: true }, + atan2: { preserveQuotes: true }, + pow: { preserveQuotes: true }, + sqrt: { preserveQuotes: true }, + hypot: { preserveQuotes: true }, + log: { preserveQuotes: true }, + exp: { preserveQuotes: true }, + abs: { preserveQuotes: true }, + sign: { preserveQuotes: true }, }; - -export type nativeFunctions = keyof typeof nativeFunctionsDic; -export function isCssNativeFunction(name: string): name is nativeFunctions { - return nativeFunctionsDic[name as nativeFunctions]; -} diff --git a/packages/core/src/parser.ts b/packages/core/src/parser.ts index 379b7ef528..ca0ddf763e 100644 --- a/packages/core/src/parser.ts +++ b/packages/core/src/parser.ts @@ -8,7 +8,8 @@ export type CSSObject = any & object; const processor = postcss([postcssNested()]); export function cssObjectToAst(cssObject: CSSObject, sourceFile = '') { - return processor.process(cssObject, { from: sourceFile, parser: postcssJS }); + const r = processor.process(cssObject, { from: sourceFile, parser: postcssJS }); + return r.root.type === 'document' ? r.root.nodes[0] : r.root; } export type CssParser = typeof safeParse; diff --git a/packages/module-utils/src/stylable-js-module-source.ts b/packages/core/src/stylable-js-module-source.ts similarity index 98% rename from packages/module-utils/src/stylable-js-module-source.ts rename to packages/core/src/stylable-js-module-source.ts index b9db3ecb52..46cef00301 100644 --- a/packages/module-utils/src/stylable-js-module-source.ts +++ b/packages/core/src/stylable-js-module-source.ts @@ -1,4 +1,4 @@ -import type { StylableExports } from '@stylable/core/dist/index-internal'; +import type { StylableExports } from './stylable-transformer'; interface InjectCSSOptions { /** diff --git a/packages/core/src/stylable-meta.ts b/packages/core/src/stylable-meta.ts index a8da810182..b96c39d2da 100644 --- a/packages/core/src/stylable-meta.ts +++ b/packages/core/src/stylable-meta.ts @@ -12,7 +12,6 @@ import { STGlobal, STScope, STVar, - STPart, STCustomSelector, STCustomState, STMixin, @@ -23,7 +22,9 @@ import { CSSKeyframes, CSSLayer, CSSContains, + STStructure, } from './features'; +import type { FeatureFlags } from './features/feature'; const features = [ STSymbol, @@ -32,7 +33,6 @@ const features = [ STGlobal, STScope, STVar, - STPart, STCustomSelector, STCustomState, STMixin, @@ -43,6 +43,7 @@ const features = [ CSSKeyframes, CSSLayer, CSSContains, + STStructure, ]; export class StylableMeta { @@ -61,18 +62,16 @@ export class StylableMeta { // Generated during transform public targetAst?: postcss.Root; public globals: Record = {}; - constructor(public sourceAst: postcss.Root, public diagnostics: Diagnostics) { + constructor( + public sourceAst: postcss.Root, + public diagnostics: Diagnostics, + public flags: FeatureFlags + ) { // initiate features const context: FeatureContext = { meta: this, diagnostics }; for (const { hooks } of features) { hooks.metaInit(context); } - // set default root - if (this.type === 'stylable') { - this.root = 'root'; - const rootSymbol = CSSClass.addClass(context, 'root'); - rootSymbol[`-st-root`] = true; - } } getSymbol(name: string) { return STSymbol.get(this, name); diff --git a/packages/core/src/stylable-processor.ts b/packages/core/src/stylable-processor.ts index 937cd57f36..8e7c9b44ec 100644 --- a/packages/core/src/stylable-processor.ts +++ b/packages/core/src/stylable-processor.ts @@ -16,6 +16,7 @@ import { CSSKeyframes, CSSLayer, CSSContains, + STStructure, } from './features'; import { processDeclarationFunctions } from './process-declaration-functions'; import { @@ -25,16 +26,19 @@ import { stringifySelector, } from './helpers/selector'; import { isChildOfAtRule } from './helpers/rule'; +import { defaultFeatureFlags, type FeatureFlags } from './features/feature'; export class StylableProcessor implements FeatureContext { public meta!: StylableMeta; constructor( public diagnostics = new Diagnostics(), - private resolveNamespace = STNamespace.defaultProcessNamespace + private resolveNamespace = STNamespace.defaultProcessNamespace, + public flags: FeatureFlags = { ...defaultFeatureFlags } ) {} public process(root: postcss.Root): StylableMeta { - this.meta = new StylableMeta(root, this.diagnostics); + this.meta = new StylableMeta(root, this.diagnostics, this.flags); + STStructure.hooks.analyzeInit(this); STImport.hooks.analyzeInit(this); CSSCustomProperty.hooks.analyzeInit(this); @@ -64,7 +68,9 @@ export class StylableProcessor implements FeatureContext { this.collectUrls(decl); }); + STNamespace.hooks.analyzeDone(this); STCustomSelector.hooks.analyzeDone(this); + STStructure.hooks.analyzeDone(this); STNamespace.setMetaNamespace(this, this.resolveNamespace); @@ -161,6 +167,14 @@ export class StylableProcessor implements FeatureContext { }); break; } + case 'st': { + STStructure.hooks.analyzeAtRule({ + context: this, + atRule, + analyzeRule, + }); + break; + } } }); } diff --git a/packages/core/src/stylable-resolver.ts b/packages/core/src/stylable-resolver.ts index 13b51aff0b..8f268341d5 100644 --- a/packages/core/src/stylable-resolver.ts +++ b/packages/core/src/stylable-resolver.ts @@ -18,6 +18,7 @@ import { CSSKeyframes, CSSLayer, CSSContains, + STStructure, } from './features'; import type { StylableTransformer } from './stylable-transformer'; import { findRule } from './helpers/rule'; @@ -64,7 +65,7 @@ export type CachedModuleEntity = export type StylableResolverCache = Map; -export interface CSSResolve { +export interface CSSResolve { _kind: 'css'; symbol: T; meta: StylableMeta; @@ -361,11 +362,7 @@ export class StylableResolver { deepResolved = { _kind: `css`, meta, - symbol: { - _kind: 'class', - name, - alias: symbol, - }, + symbol: CSSClass.createSymbol({ name, alias: symbol }), }; } } else { @@ -502,7 +499,7 @@ export class StylableResolver { break; } } else { - current = { _kind: 'css', symbol: parent, meta }; + current = { _kind: 'css', symbol: parent, meta: current.meta }; } } else { break; diff --git a/packages/core/src/stylable-transformer.ts b/packages/core/src/stylable-transformer.ts index 12dd999885..4716a17be5 100644 --- a/packages/core/src/stylable-transformer.ts +++ b/packages/core/src/stylable-transformer.ts @@ -23,16 +23,13 @@ import { import { isChildOfAtRule } from './helpers/rule'; import { getOriginDefinition } from './helpers/resolve'; import { - STPart, ClassSymbol, CSSContains, CSSMedia, ElementSymbol, FeatureTransformContext, STNamespace, -} from './features'; -import type { StylableMeta } from './stylable-meta'; -import { + STStructure, STImport, STGlobal, STScope, @@ -46,6 +43,7 @@ import { CSSLayer, CSSCustomProperty, } from './features'; +import type { StylableMeta } from './stylable-meta'; import { CSSResolve, StylableResolverCache, @@ -177,6 +175,7 @@ export class StylableTransformer { }; STImport.hooks.transformInit({ context }); STGlobal.hooks.transformInit({ context }); + STVar.hooks.transformInit({ context }); if (!this.experimentalSelectorInference) { meta.transformedScopes = validateScopes(this, meta); } @@ -210,6 +209,7 @@ export class StylableTransformer { evaluator, getResolvedSymbols: this.getResolvedSymbols, passedThrough: path.slice(), + inferredSelectorMixin, }; const transformResolveOptions = { context: transformContext, @@ -304,25 +304,19 @@ export class StylableTransformer { }); } - if (this.mode === 'production') { - if (decl.prop.startsWith('-st-')) { + if (decl.prop.startsWith('-st-')) { + if (this.mode === 'production') { this.directiveNodes.push(decl); } + return; } - switch (decl.prop) { - case `-st-partial-mixin`: - case `-st-mixin`: - case `-st-states`: - break; - default: - decl.value = this.evaluator.evaluateValue(transformContext, { - value: decl.value, - meta, - node: decl, - cssVarsMapping, - }).outputValue; - } + decl.value = this.evaluator.evaluateValue(transformContext, { + value: decl.value, + meta, + node: decl, + cssVarsMapping, + }).outputValue; }; ast.walk((node) => { @@ -496,7 +490,7 @@ export class StylableTransformer { { _kind: 'css', meta: context.originMeta, - symbol: { _kind: 'element', name: '*' }, + symbol: CSSType.createSymbol({ name: '*' }), }, ], node @@ -513,7 +507,7 @@ export class StylableTransformer { // reset current anchor for all except last selector context.inferredSelector = new InferredSelector( this, - context.inferredSelectorContext + context.inferredSelectorStart ); } } @@ -644,25 +638,36 @@ function validateScopes(transformer: StylableTransformer, meta: StylableMeta) { return transformedScopes; } -function removeFirstRootInFirstCompound(selector: Selector, meta: StylableMeta) { - let hadRoot = false; +function removeInitialCompoundMarker( + selector: Selector, + meta: StylableMeta, + structureMode: boolean +) { + let hadCompoundStart = false; const compoundedSelector = groupCompoundSelectors(selector); const first = compoundedSelector.nodes.find( ({ type }) => type === `compound_selector` ) as CompoundSelector; if (first) { - first.nodes = first.nodes.filter((node) => { - if (node.type === 'class' && node.value === meta.root) { - hadRoot = true; - return false; + const matchNode = structureMode + ? (node: SelectorNode) => node.type === 'nesting' + : (node: SelectorNode) => node.type === 'class' && node.value === meta.root; + for (let i = 0; i < first.nodes.length; i++) { + const node = first.nodes[i]; + if (node.type === 'comment') { + continue; } - return true; - }); + if (matchNode(node)) { + hadCompoundStart = true; + first.nodes.splice(i, 1); + } + break; + } } - return { selector: splitCompoundSelectors(compoundedSelector), hadRoot }; + return { selector: splitCompoundSelectors(compoundedSelector), hadCompoundStart }; } -type SelectorSymbol = ClassSymbol | ElementSymbol; +type SelectorSymbol = ClassSymbol | ElementSymbol | STStructure.PartSymbol; type InferredResolve = CSSResolve; type InferredPseudoElement = { inferred: InferredSelector; @@ -677,7 +682,10 @@ export class InferredSelector { constructor( private api: Pick< StylableTransformer, - 'getResolvedSymbols' | 'createSelectorContext' | 'scopeSelectorAst' + | 'getResolvedSymbols' + | 'createSelectorContext' + | 'scopeSelectorAst' + | 'createInferredSelector' >, resolve?: InferredResolve[] | InferredSelector ) { @@ -710,6 +718,21 @@ export class InferredSelector { this.resolveSet.add(resolve); } } + /** + * Takes a CSS part resolve and use it extend the current set of inferred resolved. + * Used to expand the resolved mapped selector with the part definition + * e.g. part can add nested states/parts that override the inferred mapped selector. + */ + private addPartOverride(partResolve: CSSResolve) { + const newSet = new Set(); + for (const resolve of this.resolveSet) { + newSet.add([partResolve, ...resolve]); + } + if (!this.resolveSet.size) { + newSet.add([partResolve]); + } + this.resolveSet = newSet; + } public getPseudoClasses({ name: searchedName }: { name?: string } = {}) { const collectedStates: Record = {}; const resolvedCount: Record = {}; @@ -784,7 +807,7 @@ export class InferredSelector { }) { const collectedElements: Record = {}; const resolvedCount: Record = {}; - const checked: Record> = {}; + const checked: Record> = {}; const expectedIntersectionCount = this.resolveSet.size; // ToDo: dec for any types const addInferredElement = ( name: string, @@ -809,26 +832,41 @@ export class InferredSelector { for (const resolvedContext of this.resolveSet.values()) { /** * search for elements in each resolved selector. - * start at 1 for extended symbols to prefer inherited elements over local + * start at 1 for legacy flat mode to prefer inherited elements over local */ - const startIndex = resolvedContext.length === 1 ? 0 : 1; + const startIndex = + resolvedContext.length === 1 || + (resolvedContext[0] && + (STStructure.isStructureMode(resolvedContext[0].meta) || + resolvedContext[0].symbol._kind === 'part')) + ? 0 + : 1; resolved: for (let i = startIndex; i < resolvedContext.length; i++) { const { symbol, meta } = resolvedContext[i]; - if (!symbol['-st-root'] || symbol.alias) { + const structureMode = STStructure.isStructureMode(meta); + if ( + symbol._kind !== 'part' && + (symbol.alias || (!structureMode && !symbol['-st-root'])) + ) { // non-root & alias classes don't have parts: bailout continue; } if (name) { + const cacheContext = symbol._kind === 'part' ? symbol.id : symbol.name; + const uniqueId = meta.source + '::' + cacheContext; resolvedCount[name] ??= 0; - checked[name] ||= new Set(); - const uniqueId = meta.source + '::' + name; + checked[name] ||= new Map(); if (checked[name].has(uniqueId)) { - resolvedCount[name]++; + if (checked[name].get(uniqueId)) { + resolvedCount[name]++; + } continue; } - checked[name].add(uniqueId); - // - const partDef = STPart.getPart(meta, name); + // get part symbol + const partDef = STStructure.getPart(symbol, name); + // save to cache + checked[name].set(uniqueId, !!partDef); + if (!partDef) { continue; } @@ -837,10 +875,10 @@ export class InferredSelector { const selectorList = cloneSelector(partDef.mapTo); const selectorStr = stringifySelector(partDef.mapTo); selectorList.forEach((selector) => { - const r = removeFirstRootInFirstCompound(selector, meta); + const r = removeInitialCompoundMarker(selector, meta, structureMode); selector.nodes = r.selector.nodes; selector.before = ''; - if (!r.hadRoot && !isFirstInSelector) { + if (!r.hadCompoundStart && !isFirstInSelector) { selector.nodes.unshift( createCombinatorSelector({ combinator: 'space' }) ); @@ -853,6 +891,17 @@ export class InferredSelector { selectorStr ); internalContext.isStandaloneSelector = isFirstInSelector; + if (!structureMode && experimentalSelectorInference) { + internalContext.inferredSelectorStart.set( + this.api.createInferredSelector(meta, { + name: 'root', + type: 'class', + }) + ); + internalContext.inferredSelector.set( + internalContext.inferredSelectorStart + ); + } const customAstSelectors = this.api.scopeSelectorAst(internalContext); const inferred = customAstSelectors.length === 1 || experimentalSelectorInference @@ -861,10 +910,13 @@ export class InferredSelector { { _kind: 'css', meta, - symbol: { _kind: 'element', name: '*' }, + symbol: CSSType.createSymbol({ name: '*' }), }, ]); - + // add part resolve to inferred resolve set + if (structureMode) { + inferred.addPartOverride({ _kind: 'css', meta, symbol: partDef }); + } addInferredElement(name, inferred, customAstSelectors); break resolved; } else { @@ -984,6 +1036,8 @@ export class ScopeContext { public lastInferredSelectorNode: SelectorNode | undefined; // selector is not a continuation of another selector public isStandaloneSelector = true; + // used as initial selector + public inferredSelectorStart: InferredSelector; // used as initial selector or after combinators public inferredSelectorContext: InferredSelector; // used for nesting selector @@ -1026,7 +1080,7 @@ export class ScopeContext { { _kind: 'css', meta: originMeta, - symbol: { _kind: 'element', name: '*' }, + symbol: CSSType.createSymbol({ name: '*' }), }, ]) : transformer.createInferredSelector(originMeta, { @@ -1036,6 +1090,7 @@ export class ScopeContext { // set selector data this.selectorStr = selectorStr || stringifySelector(selectorAst); this.inferredSelectorContext = new InferredSelector(this.transformer, inferredContext); + this.inferredSelectorStart = new InferredSelector(this.transformer, inferredContext); this.inferredSelectorNest = inferredSelectorNest || this.inferredSelectorContext.clone(); this.inferredSelector = new InferredSelector( this.transformer, diff --git a/packages/core/src/stylable-utils.ts b/packages/core/src/stylable-utils.ts index ef5b3a3022..4e35b198b3 100644 --- a/packages/core/src/stylable-utils.ts +++ b/packages/core/src/stylable-utils.ts @@ -1,5 +1,5 @@ import { isAbsolute } from 'path'; -import type * as postcss from 'postcss'; +import * as postcss from 'postcss'; import { createDiagnosticReporter, Diagnostics } from './diagnostics'; import type { ImportSymbol, StylableSymbol } from './features'; import { isChildOfAtRule, stMixinMarker, isStMixinMarker } from './helpers/rule'; @@ -15,6 +15,11 @@ export const utilDiagnostics = { 'error', (mergeValue: string) => `invalid merge of: \n"${mergeValue}"` ), + INVALID_RECURSIVE_MIXIN: createDiagnosticReporter( + '10010', + 'error', + () => `invalid recursive mixin` + ), }; // ToDo: move to helpers/mixin @@ -46,7 +51,8 @@ export function mergeRules( mixinRoot = 'NoRoot'; mixinRule.selector = selector; } - } else { + } else if (!isChildOfMixinRoot(mixinRule, mixinRoot)) { + // scope to mixin target if not already scoped by parent const { selector } = scopeNestedSelector( parseSelectorWithCache(rule.selector), parseSelectorWithCache(mixinRule.selector), @@ -54,19 +60,43 @@ export function mergeRules( anchorNodeCheck ); mixinRule.selector = selector; + } else if (mixinRule.selector.includes(anchorSelector)) { + // report invalid nested mixin + mixinRule.selector = mixinRule.selector.split(anchorSelector).join('&'); + report?.report(utilDiagnostics.INVALID_RECURSIVE_MIXIN(), { + node: rule, + }); } }); if (mixinAst.nodes) { let nextRule: postcss.Rule | postcss.AtRule = rule; // TODO: handle rules before and after decl on entry + const inlineMixin = !hasNonDeclsBeforeDecl(mixinDecl); + const mixInto = inlineMixin ? rule : postcss.rule({ selector: '&' }); + const mixIntoRule = (node: postcss.AnyNode) => { + // mix node into rule + if (inlineMixin) { + mixInto.insertBefore(mixinDecl, node); + } else { + // indent first level - doesn't change deep nested + node.raws.before = (node.raws.before || '') + ' '; + mixInto.append(node); + } + // mark following decls for nesting + if (!nestFollowingDecls && node.type !== 'decl' && hasAnyDeclsAfter(mixinDecl)) { + nestFollowingDecls = true; + } + }; + let nestFollowingDecls = false; mixinAst.nodes.slice().forEach((node) => { if (node === mixinRoot) { for (const nested of [...node.nodes]) { - rule.insertBefore(mixinDecl, nested); + mixIntoRule(nested); } } else if (node.type === 'decl') { - rule.insertBefore(mixinDecl, node); + // stand alone decl - most likely from js mixin + mixIntoRule(node); } else if (node.type === 'rule' || node.type === 'atrule') { const valid = !nestedInKeyframes; if (valid) { @@ -83,11 +113,57 @@ export function mergeRules( } } }); + // add nested mixin to rule body + if (mixInto !== rule && mixInto.nodes.length) { + mixinDecl.before(mixInto); + } + // nest following decls if needed + if (nestFollowingDecls) { + const nestFollowingDecls = postcss.rule({ selector: '&' }); + while (mixinDecl.next()) { + const nextNode = mixinDecl.next()!; + nextNode.raws.before = (nextNode.raws.before || '') + ' '; + nestFollowingDecls.append(nextNode); + } + mixinDecl.after(nestFollowingDecls); + } } return rule; } +function hasNonDeclsBeforeDecl(decl: postcss.Declaration) { + let current: postcss.AnyNode | undefined = decl.prev(); + while (current) { + if (current.type !== 'decl' && current.type !== 'comment') { + return true; + } + current = current.prev(); + } + return false; +} +function hasAnyDeclsAfter(decl: postcss.Declaration) { + let current: postcss.AnyNode | undefined = decl.next(); + while (current) { + if (current.type === 'decl') { + return true; + } + current = current.prev(); + } + return false; +} + +const isChildOfMixinRoot = (rule: postcss.Rule, mixinRoot: postcss.Rule | null | 'NoRoot') => { + let current: postcss.Container | postcss.Document | undefined = rule.parent; + while (current) { + if (current === mixinRoot) { + return true; + } + current = current.parent; + } + return false; +}; + export const sourcePathDiagnostics = { MISSING_SOURCE_FILENAME: createDiagnosticReporter( '17001', diff --git a/packages/core/src/stylable.ts b/packages/core/src/stylable.ts index a02327ca4d..10ac303795 100644 --- a/packages/core/src/stylable.ts +++ b/packages/core/src/stylable.ts @@ -17,6 +17,7 @@ import { createDefaultResolver } from './module-resolver'; import { STImport, STScope, STVar, STMixin, CSSClass, CSSCustomProperty } from './features'; import { Dependency, visitMetaCSSDependencies } from './visit-meta-css-dependencies'; import * as postcss from 'postcss'; +import { defaultFeatureFlags, type FeatureFlags } from './features/feature'; export interface StylableConfig { projectRoot: string; @@ -37,12 +38,15 @@ export interface StylableConfig { resolverCache?: StylableResolverCache; fileProcessorCache?: Record>; experimentalSelectorInference?: boolean; + flags?: Partial; } // This defines and validates known configs for the defaultConfig in 'stylable.config.js const globalDefaultSupportedConfigs = new Set([ 'resolveModule', 'resolveNamespace', + 'requireModule', + 'flags', 'experimentalSelectorInference', ]); export function validateDefaultConfig(defaultConfigObj: any) { @@ -89,6 +93,7 @@ export class Stylable { // This cache is fragile and should be fresh if onProcess/resolveNamespace/cssParser is different protected fileProcessorCache?: Record>; private experimentalSelectorInference: boolean; + public flags: FeatureFlags; constructor(config: StylableConfig) { this.experimentalSelectorInference = !!config.experimentalSelectorInference; this.projectRoot = config.projectRoot; @@ -109,12 +114,17 @@ export class Stylable { this.cssParser = config.cssParser || cssParse; this.resolverCache = config.resolverCache; // ToDo: v5 default to `new Map()` this.fileProcessorCache = config.fileProcessorCache; + this.flags = { + ...defaultFeatureFlags, + ...config.flags, + }; this.fileProcessor = createStylableFileProcessor({ fileSystem: this.fileSystem, onProcess: this.onProcess, resolveNamespace: this.resolveNamespace, cssParser: this.cssParser, cache: this.fileProcessorCache, + flags: this.flags, }); this.resolver = this.createResolver(); @@ -154,7 +164,7 @@ export class Stylable { public createProcessor({ resolveNamespace = this.resolveNamespace, }: CreateProcessorOptions = {}) { - return new StylableProcessor(new Diagnostics(), resolveNamespace); + return new StylableProcessor(new Diagnostics(), resolveNamespace, this.flags); } private createTransformer(options: Partial = {}) { return new StylableTransformer({ diff --git a/packages/core/test/diagnostic-codes.spec.ts b/packages/core/test/diagnostic-codes.spec.ts index 1149d0410c..e3477f04de 100644 --- a/packages/core/test/diagnostic-codes.spec.ts +++ b/packages/core/test/diagnostic-codes.spec.ts @@ -15,6 +15,7 @@ import { STVar, STCustomSelector, STCustomState, + STStructure, } from '@stylable/core/dist/features'; import { generalDiagnostics } from '@stylable/core/dist/features/diagnostics'; import { atPropertyValidationWarnings } from '@stylable/core/dist/helpers/css-custom-property'; @@ -55,6 +56,7 @@ describe('diagnostics error codes', () => { ...transformerDiagnostics, ...utilDiagnostics, ...sourcePathDiagnostics, + ...STStructure.diagnostics, }; let failingCode = ''; diff --git a/packages/core/test/features/css-class.spec.ts b/packages/core/test/features/css-class.spec.ts index bd25e2eac7..d0958029a6 100644 --- a/packages/core/test/features/css-class.spec.ts +++ b/packages/core/test/features/css-class.spec.ts @@ -28,14 +28,16 @@ describe(`features/css-class`, () => { shouldReportNoDiagnostics(autoResult.meta); // symbols - expect(CSSClass.get(autoResult.meta, `root`), `auto root symbol`).to.contain({ - _kind: `class`, - name: 'root', - }); - expect(CSSClass.get(explicitResult.meta, `root`), `explicit root symbol`).to.contain({ - _kind: `class`, - name: 'root', - }); + expect(CSSClass.get(autoResult.meta, `root`), `auto root symbol`).to.deep.contain( + CSSClass.createSymbol({ + name: 'root', + }) + ); + expect(CSSClass.get(explicitResult.meta, `root`), `explicit root symbol`).to.deep.contain( + CSSClass.createSymbol({ + name: 'root', + }) + ); // JS exports expect(autoResult.exports.classes.root, `auto root JS export`).to.eql(`auto__root`); @@ -245,10 +247,11 @@ describe(`features/css-class`, () => { shouldReportNoDiagnostics(meta); // symbols - ToDo: remove escape from key? - expect(CSSClass.get(meta, `a\\.`), `symbol`).to.contain({ - _kind: `class`, - name: 'a\\.', - }); + expect(CSSClass.get(meta, `a\\.`), `symbol`).to.deep.contain( + CSSClass.createSymbol({ + name: 'a\\.', + }) + ); // JS exports - ToDo: remove escape from key expect(exports.classes[`a\\.`], `JS export`).to.eql(`entry.__a.`); @@ -301,10 +304,11 @@ describe(`features/css-class`, () => { const { meta, exports } = sheets['/entry.st.css']; // symbols - expect(CSSClass.get(meta, `a`), `symbol`).to.contain({ - _kind: `class`, - name: 'a', - }); + expect(CSSClass.get(meta, `a`), `symbol`).to.deep.contain( + CSSClass.createSymbol({ + name: 'a', + }) + ); // JS exports expect(exports.classes.a, `JS export`).to.eql(`entry__a`); @@ -582,16 +586,18 @@ describe(`features/css-class`, () => { // symbols const importDef = meta.getImportStatements()[0]; - expect(CSSClass.get(meta, `before`), `before symbol`).to.eql({ - _kind: `class`, - name: 'before', - alias: STImport.createImportSymbol(importDef, `named`, `before`, `/`), - }); - expect(CSSClass.get(meta, `after`), `after symbol`).to.eql({ - _kind: `class`, - name: 'after', - alias: STImport.createImportSymbol(importDef, `named`, `after`, `/`), - }); + expect(CSSClass.get(meta, `before`), `before symbol`).to.eql( + CSSClass.createSymbol({ + name: 'before', + alias: STImport.createImportSymbol(importDef, `named`, `before`, `/`), + }) + ); + expect(CSSClass.get(meta, `after`), `after symbol`).to.eql( + CSSClass.createSymbol({ + name: 'after', + alias: STImport.createImportSymbol(importDef, `named`, `after`, `/`), + }) + ); expect(CSSClass.get(meta, `unused`), `unused symbol`).to.eql(undefined); // JS exports @@ -619,11 +625,12 @@ describe(`features/css-class`, () => { // symbols const importDef = meta.getImportStatements()[0]; - expect(CSSClass.get(meta, `unknown`), `unknown symbol`).to.eql({ - _kind: `class`, - name: 'unknown', - alias: STImport.createImportSymbol(importDef, `named`, `unknown`, `/`), - }); + expect(CSSClass.get(meta, `unknown`), `unknown symbol`).to.eql( + CSSClass.createSymbol({ + name: 'unknown', + alias: STImport.createImportSymbol(importDef, `named`, `unknown`, `/`), + }) + ); // JS exports expect(exports.classes[`unknown`], `unknown JS export`).to.eql( @@ -653,11 +660,12 @@ describe(`features/css-class`, () => { // symbols const importDef = meta.getImportStatements()[0]; - expect(CSSClass.get(meta, `imported-part`), `imported-part symbol`).to.eql({ - _kind: `class`, - name: 'imported-part', - alias: STImport.createImportSymbol(importDef, `named`, `imported-part`, `/`), - }); + expect(CSSClass.get(meta, `imported-part`), `imported-part symbol`).to.eql( + CSSClass.createSymbol({ + name: 'imported-part', + alias: STImport.createImportSymbol(importDef, `named`, `imported-part`, `/`), + }) + ); // JS exports expect(exports.classes[`imported-part`], `imported-part JS export`).to.eql( @@ -679,12 +687,13 @@ describe(`features/css-class`, () => { const { meta } = sheets['/entry.st.css']; // symbols - expect(CSSClass.get(meta, `root`), `class`).to.eql({ - _kind: `class`, - name: 'root', - '-st-root': true, - alias: undefined, - }); + expect(CSSClass.get(meta, `root`), `class`).to.eql( + CSSClass.createSymbol({ + name: 'root', + '-st-root': true, + alias: undefined, + }) + ); expect(STSymbol.get(meta, `root`), `general`).to.equal(CSSClass.get(meta, `root`)); }); it(`should report unscoped class`, () => { @@ -796,13 +805,11 @@ describe(`features/css-class`, () => { // symbols expect(CSSClass.get(meta, `imported`), `imported symbol`).to.eql(undefined); - expect(CSSClass.get(meta, `root`), `root symbol`).to.contain({ - _kind: `class`, + expect(CSSClass.get(meta, `root`), `root symbol`).to.deep.contain({ name: 'root', alias: undefined, }); - expect(CSSClass.get(meta, `class`), `class symbol`).to.contain({ - _kind: `class`, + expect(CSSClass.get(meta, `class`), `class symbol`).to.deep.contain({ name: 'class', alias: undefined, }); @@ -841,13 +848,11 @@ describe(`features/css-class`, () => { shouldReportNoDiagnostics(meta); // symbols - expect(CSSClass.get(meta, `root`), `root symbol`).to.contain({ - _kind: `class`, + expect(CSSClass.get(meta, `root`), `root symbol`).to.deep.contain({ name: 'root', alias: undefined, }); - expect(CSSClass.get(meta, `class`), `class symbol`).to.contain({ - _kind: `class`, + expect(CSSClass.get(meta, `class`), `class symbol`).to.deep.contain({ name: 'class', alias: undefined, }); @@ -1002,6 +1007,27 @@ describe(`features/css-class`, () => { }); }); }); + describe('st-scope', () => { + it('should allow nested global/external selectors anywhere', () => { + const { sheets } = testStylableCore({ + '/external.st.css': ``, + '/valid.st.css': ` + @st-import [root as external] from './external.st.css'; + @st-scope .root { + .external {} + + @media screen and (max-width: 555px) { + .external {} + } + } + `, + }); + + const { meta } = sheets['/valid.st.css']; + + shouldReportNoDiagnostics(meta); + }); + }); describe(`css-pseudo-element`, () => { // ToDo: move to css-pseudo-element spec once feature is created describe(`st-mixin`, () => { @@ -1152,10 +1178,11 @@ describe(`features/css-class`, () => { ); // symbols - expect(CSSClass.get(meta, 'name'), 'imported symbol').to.contain({ - _kind: 'class', - name: 'name', - }); + expect(CSSClass.get(meta, 'name'), 'imported symbol').to.deep.contain( + CSSClass.createSymbol({ + name: 'name', + }) + ); // JS exports expect(exports.classes, 'JS export').to.eql({ diff --git a/packages/core/test/features/css-custom-property.spec.ts b/packages/core/test/features/css-custom-property.spec.ts index 4af7db716b..1f4827da50 100644 --- a/packages/core/test/features/css-custom-property.spec.ts +++ b/packages/core/test/features/css-custom-property.spec.ts @@ -1,4 +1,4 @@ -import { STImport, CSSCustomProperty, STSymbol } from '@stylable/core/dist/features'; +import { STImport, STVar, CSSCustomProperty, STSymbol } from '@stylable/core/dist/features'; import { generateScopedCSSVar } from '@stylable/core/dist/helpers/css-custom-property'; import { testStylableCore, @@ -10,6 +10,7 @@ import { expect } from 'chai'; const stImportDiagnostics = diagnosticBankReportToStrings(STImport.diagnostics); const stSymbolDiagnostics = diagnosticBankReportToStrings(STSymbol.diagnostics); +const stVarDiagnostics = diagnosticBankReportToStrings(STVar.diagnostics); const customPropertyDiagnostics = diagnosticBankReportToStrings(CSSCustomProperty.diagnostics); describe(`features/css-custom-property`, () => { @@ -290,6 +291,44 @@ describe(`features/css-custom-property`, () => { expect(CSSCustomProperty.getRuntimeTypedDefinitionNames(meta)).to.eql(['--c', '--d']); }); + it('should warn on undefined property in strict mode', () => { + testStylableCore( + { + '/invalid.st.css': ` + .root { + /* + @analyze-error word(--prop) ${customPropertyDiagnostics.UNDEFINED_CSS_CUSTOM_PROP( + '--prop' + )} + @decl --invalid-prop: green + */ + --prop: green; + + /* + @analyze-error word(--prop2) ${customPropertyDiagnostics.UNDEFINED_CSS_CUSTOM_PROP( + '--prop2' + )} + @decl color: var(--invalid-prop2) + */ + color: var(--prop2); + } + `, + '/valid.st.css': ` + @st-import [--prop] from './invalid.st.css'; + @property --prop2; + + .root { + /* @decl --invalid-prop: green */ + --prop: green; + + /* @decl color: var(--valid-prop2) */ + color: var(--prop2); + } + `, + }, + { stylableConfig: { flags: { strictCustomProperty: true } } } + ); + }); it.skip(`should escape`, () => { const { sheets } = testStylableCore(` .root { @@ -748,7 +787,7 @@ describe(`features/css-custom-property`, () => { }); it(`should NOT define property as var value (change in v5)`, () => { // ToDo: in the future property should be able to be defined in var value - const { sheets } = testStylableCore(` + testStylableCore(` :vars { myVar: var(--color); } @@ -758,8 +797,50 @@ describe(`features/css-custom-property`, () => { prop: value(myVar); } `); + }); + it(`should report deprecation info on unknown custom properties`, () => { + const { sheets } = testStylableCore({ + './other.st.css': ` + @property --knownA; + `, + './invalid.st.css': ` + :vars { + /* @transform-info(single) ${stVarDiagnostics.UNKNOWN_CUSTOM_PROP([ + '--unknown1', + ])} */ + single: var(--unknown1); + + /* @transform-info(between) ${stVarDiagnostics.UNKNOWN_CUSTOM_PROP([ + '--unknown2', + ])} */ + betweenValue: before var(--unknown2) after; + + /* @transform-info(multiple) ${stVarDiagnostics.UNKNOWN_CUSTOM_PROP([ + '--unknownY', + '--unknownX', + '--unknownZ', + ])} */ + multiple: var(--unknownY) var(--unknownX, var(--unknownZ)); + } + `, + './valid.st.css': ` + @st-import [--knownA] from './other.st.css'; + @property --knownB; + .root { + --knownC: green; + } - const { meta } = sheets['/entry.st.css']; + :vars { + single: var(--knownA); + + betweenValue: before var(--knownB) after; + + multiple: var(--knownC) var(--knownB, var(--knownA)); + } + `, + }); + + const { meta } = sheets['/valid.st.css']; shouldReportNoDiagnostics(meta); }); @@ -923,8 +1004,9 @@ describe(`features/css-custom-property`, () => { }); describe('native css', () => { it('should not namespace', () => { - const { stylable } = testStylableCore({ - '/native.css': deindent(` + const { stylable } = testStylableCore( + { + '/native.css': deindent(` @property --a { syntax: ''; initial-value: green; @@ -934,7 +1016,7 @@ describe(`features/css-custom-property`, () => { --b: var(--c); } `), - '/entry.st.css': ` + '/entry.st.css': ` @st-import [--a, --b, --c] from './native.css'; .root { @@ -948,7 +1030,9 @@ describe(`features/css-custom-property`, () => { --c: var(--c); } `, - }); + }, + { stylableConfig: { flags: { strictCustomProperty: true } } } + ); const { meta: nativeMeta } = stylable.transform('/native.css'); const { meta, exports } = stylable.transform('/entry.st.css'); @@ -976,6 +1060,23 @@ describe(`features/css-custom-property`, () => { c: '--c', }); }); + it('should ignore strictCustomProperty', () => { + const { stylable } = testStylableCore( + { + '/entry.css': ` + .root { + /* @decl --a: var(--z) */ + --a: var(--z); + } + `, + }, + { stylableConfig: { flags: { strictCustomProperty: true } } } + ); + + const { meta } = stylable.transform('/entry.css'); + + shouldReportNoDiagnostics(meta); + }); it('should ignore stylable specific transformations', () => { const { stylable } = testStylableCore({ '/native.css': deindent(` diff --git a/packages/core/test/features/css-general.spec.ts b/packages/core/test/features/css-general.spec.ts new file mode 100644 index 0000000000..2970ce69a9 --- /dev/null +++ b/packages/core/test/features/css-general.spec.ts @@ -0,0 +1,20 @@ +import { shouldReportNoDiagnostics, testStylableCore } from '@stylable/core-test-kit'; + +describe('features/css-general', () => { + describe('svg', () => { + it('should preserve path value function quotes', () => { + // ToDo: remove once experimentalSelectorInference is the default + const { sheets } = testStylableCore(` + + .path { + /* @decl d: path("M0 0 L10 0 L10 10Z") */ + d: path("M0 0 L10 0 L10 10Z"); + } + `); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); + }); +}); diff --git a/packages/core/test/features/css-keyframes.spec.ts b/packages/core/test/features/css-keyframes.spec.ts index 7c60eb3011..1829932ba8 100644 --- a/packages/core/test/features/css-keyframes.spec.ts +++ b/packages/core/test/features/css-keyframes.spec.ts @@ -149,10 +149,13 @@ describe(`features/css-keyframes`, () => { // ToDo: make sure this is actually testing anything: "from" and "to" wouldn't be namespaces anyhow const { sheets } = testStylableCore(` @keyframes name { - /* @check from */ + /* @rule from */ from {} - /* @check to */ - to {} + /* @rule to */ + to { + /* @rule deep */ + deep {} + } } `); diff --git a/packages/core/test/features/css-pseudo-class.spec.ts b/packages/core/test/features/css-pseudo-class.spec.ts index 7d92248541..299335807a 100644 --- a/packages/core/test/features/css-pseudo-class.spec.ts +++ b/packages/core/test/features/css-pseudo-class.spec.ts @@ -34,24 +34,40 @@ describe('features/css-pseudo-class', () => { }); describe('st-custom-state', () => { it('should transform boolean state', () => { - const { sheets } = testStylableCore(` - .root { - /* @transform-remove(removed decl) */ - -st-states: bool, - exBool(boolean); - } + const { sheets } = testStylableCore({ + '/valid.st.css': ` + .root { + /* @transform-remove(removed decl) */ + -st-states: bool, + exBool(boolean); + } - /* @rule(boolean) .entry__root.entry--bool */ - .root:bool {} + /* @rule(boolean) .valid__root.valid--bool */ + .root:bool {} - /* @rule(explicit boolean) .entry__root.entry--exBool */ - .root:exBool {} + /* @rule(explicit boolean) .valid__root.valid--exBool */ + .root:exBool {} - /* @rule(nested) .entry__root:not(.entry--bool) */ - .root:not(:bool) {} - `); + /* @rule(nested) .valid__root:not(.valid--bool) */ + .root:not(:bool) {} + `, + '/invalid.st.css': ` + .root { + -st-states: bool; + } + + /* + @transform-error ${stCustomStateDiagnostics.NO_PARAM_REQUIRED( + 'bool', + 'unknown-param' + )} + @rule .invalid__root.invalid--bool + */ + .root:bool(unknown-param) {} + `, + }); - const { meta } = sheets['/entry.st.css']; + const { meta } = sheets['/valid.st.css']; shouldReportNoDiagnostics(meta); }); describe('string parameter', () => { @@ -412,6 +428,38 @@ describe('features/css-pseudo-class', () => { `); }); }); + describe('custom mapped static', () => { + it('should transform to global selector', () => { + const { sheets } = testStylableCore(` + .root { + -st-states: static(".x[y]"), + } + + /* @rule .entry__root.x[y]*/ + .root:static {} + `); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it('should report error for unexpected param', () => { + testStylableCore(` + .root { + -st-states: static("[y]"), + } + + /* + @transform-error ${stCustomStateDiagnostics.NO_PARAM_REQUIRED( + 'static', + 'unknown-param' + )} + @rule .entry__root[y] + */ + .root:static(unknown-param) {} + `); + }); + }); describe('custom mapped parameter', () => { it('should transform mapped state (quoted)', () => { const { sheets } = testStylableCore(` diff --git a/packages/core/test/features/css-pseudo-element.spec.ts b/packages/core/test/features/css-pseudo-element.spec.ts index 6dc067b038..85a499440a 100644 --- a/packages/core/test/features/css-pseudo-element.spec.ts +++ b/packages/core/test/features/css-pseudo-element.spec.ts @@ -324,6 +324,58 @@ describe('features/css-pseudo-element', () => { } ); }); + it('should transform custom element with multiple selector inside nested pseudo-classes', () => { + // ToDo: with experimentalSelectorInference=true, the nested selector will be transformed inlined + testStylableCore( + ` + @custom-selector :--part .partA, .partB; + @custom-selector :--nestedPart ::part, .partC; + + /* @rule(1 level) .entry__root:not(.entry__partA,.entry__partB) */ + .root:not(::part) {} + + /* + notice: partB is pushed at the end because of how custom selectors are + processed atm. + + @rule(2 levels) .entry__root:not(.entry__partA,.entry__partC,.entry__partB) + */ + .root:not(::nestedPart) {} + + /* @rule(custom-selector syntax) + .entry__root:not(.entry__partA, .entry__partB) + */ + .root:not(:--part) {} + `, + { stylableConfig: { experimentalSelectorInference: true } } + ); + }); + }); + }); + describe('st-import', () => { + it('should resolve inferred selector across stylesheet', () => { + const { sheets } = testStylableCore({ + 'origin.st.css': ` + .root {} + .extend { + -st-extends: root; + } + `, + 'entry.st.css': ` + @st-import [extend as eee] from './origin.st.css'; + + .local { + -st-extends: eee; + } + + /* @rule .entry__local .origin__extend */ + .local::extend {} + `, + }); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); }); }); }); diff --git a/packages/core/test/features/css-type.spec.ts b/packages/core/test/features/css-type.spec.ts index 3cffb69630..33815ef2c9 100644 --- a/packages/core/test/features/css-type.spec.ts +++ b/packages/core/test/features/css-type.spec.ts @@ -24,10 +24,11 @@ describe(`features/css-type`, () => { const { meta } = sheets['/entry.st.css']; // symbols - expect(CSSType.get(meta, `Btn`), `collect capital letters`).to.contain({ - _kind: `element`, - name: 'Btn', - }); + expect(CSSType.get(meta, `Btn`), `collect capital letters`).to.deep.contain( + CSSType.createSymbol({ + name: 'Btn', + }) + ); expect(CSSType.get(meta, `div`), `ignore lowercase`).to.eql(undefined); expect(STSymbol.get(meta, `Btn`), `general symbols`).to.equal(CSSType.get(meta, `Btn`)); expect(CSSType.getAll(meta), `getAll`).to.eql({ @@ -115,16 +116,18 @@ describe(`features/css-type`, () => { // symbols const importBeforeDef = meta.getImportStatements()[0]; const importAfterDef = meta.getImportStatements()[1]; - expect(CSSType.get(meta, `Before`), `before type symbol`).to.eql({ - _kind: `element`, - name: 'Before', - alias: STImport.createImportSymbol(importBeforeDef, `default`, `default`, `/`), - }); - expect(CSSType.get(meta, `After`), `after type symbol`).to.eql({ - _kind: `element`, - name: 'After', - alias: STImport.createImportSymbol(importAfterDef, `default`, `default`, `/`), - }); + expect(CSSType.get(meta, `Before`), `before type symbol`).to.eql( + CSSType.createSymbol({ + name: 'Before', + alias: STImport.createImportSymbol(importBeforeDef, `default`, `default`, `/`), + }) + ); + expect(CSSType.get(meta, `After`), `after type symbol`).to.eql( + CSSType.createSymbol({ + name: 'After', + alias: STImport.createImportSymbol(importAfterDef, `default`, `default`, `/`), + }) + ); // JS exports expect(exports.classes, `not added as classes exports`).to.eql({ @@ -154,16 +157,18 @@ describe(`features/css-type`, () => { // symbols const importBeforeDef = meta.getImportStatements()[0]; const importAfterDef = meta.getImportStatements()[1]; - expect(CSSType.get(meta, `BeforePart`), `before type symbol`).to.eql({ - _kind: `element`, - name: 'BeforePart', - alias: STImport.createImportSymbol(importBeforeDef, `named`, `BeforePart`, `/`), - }); - expect(CSSType.get(meta, `AfterPart`), `after type symbol`).to.eql({ - _kind: `element`, - name: 'AfterPart', - alias: STImport.createImportSymbol(importAfterDef, `named`, `AfterPart`, `/`), - }); + expect(CSSType.get(meta, `BeforePart`), `before type symbol`).to.eql( + CSSType.createSymbol({ + name: 'BeforePart', + alias: STImport.createImportSymbol(importBeforeDef, `named`, `BeforePart`, `/`), + }) + ); + expect(CSSType.get(meta, `AfterPart`), `after type symbol`).to.eql( + CSSType.createSymbol({ + name: 'AfterPart', + alias: STImport.createImportSymbol(importAfterDef, `named`, `AfterPart`, `/`), + }) + ); // JS exports expect(exports.classes, `not add as classes exports`).to.eql({ @@ -194,16 +199,18 @@ describe(`features/css-type`, () => { // symbols const importBeforeDef = meta.getImportStatements()[0]; const importAfterDef = meta.getImportStatements()[1]; - expect(CSSType.get(meta, `BeforePart`), `before type symbol`).to.eql({ - _kind: `element`, - name: 'BeforePart', - alias: STImport.createImportSymbol(importBeforeDef, `named`, `BeforePart`, `/`), - }); - expect(CSSType.get(meta, `AfterPart`), `after type symbol`).to.eql({ - _kind: `element`, - name: 'AfterPart', - alias: STImport.createImportSymbol(importAfterDef, `named`, `AfterPart`, `/`), - }); + expect(CSSType.get(meta, `BeforePart`), `before type symbol`).to.eql( + CSSType.createSymbol({ + name: 'BeforePart', + alias: STImport.createImportSymbol(importBeforeDef, `named`, `BeforePart`, `/`), + }) + ); + expect(CSSType.get(meta, `AfterPart`), `after type symbol`).to.eql( + CSSType.createSymbol({ + name: 'AfterPart', + alias: STImport.createImportSymbol(importAfterDef, `named`, `AfterPart`, `/`), + }) + ); // JS exports expect(exports.classes, `not add as classes exports`).to.eql({ root: `entry__root`, diff --git a/packages/core/test/features/st-mixin.spec.ts b/packages/core/test/features/st-mixin.spec.ts index c905152b47..2d5dc27861 100644 --- a/packages/core/test/features/st-mixin.spec.ts +++ b/packages/core/test/features/st-mixin.spec.ts @@ -6,9 +6,7 @@ import { shouldReportNoDiagnostics, matchRuleAndDeclaration, diagnosticBankReportToStrings, - assertRule, - assertDecl, - assertAtRule, + deindent, } from '@stylable/core-test-kit'; import chai, { expect } from 'chai'; import type * as postcss from 'postcss'; @@ -41,6 +39,62 @@ describe(`features/st-mixin`, () => { shouldReportNoDiagnostics(meta); }); + it(`should append mixin declarations (within nesting)`, () => { + const { sheets } = testStylableCore(` + .mix { + propA: blue; + propB: green; + } + + /* @rule .entry__empty {propA: blue; propB: green;} */ + .empty { + -st-mixin: mix; + } + + .insert { + /* @rule .entry__child {before:1; propA:blue; propB:green; after: 2} */ + .child { + before: 1; + -st-mixin: mix; + after: 2; + } + } + `); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it.skip(`should keep other nested rules`, () => { + const { sheets } = testStylableCore(` + .mix { + propA: blue; + propB: green; + } + + /* @rule .entry__empty {propA: blue; propB: green;} */ + .empty { + -st-mixin: mix; + } + + .insert { + /* @rule .entry__child {.entry__grandchild-1 { z-index: 1; }; before: 1; .entry__grandchild-2 { z-index: 2; }; propA: blue; propB: green; .entry__grandchild-3 { z-index: 3; }; after: 2; .entry__grandchild-4 { z-index: 4; }} */ + .child { + .grandchild-1 { z-index: 1; } + before: 1; + .grandchild-2 { z-index: 2; } + -st-mixin: mix; + .grandchild-3 { z-index: 3; } + after: 2; + .grandchild-4 { z-index: 4; } + } + } + `); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); it(`should append mixin rules`, () => { const { sheets } = testStylableCore(` .mix { @@ -218,6 +272,48 @@ describe(`features/st-mixin`, () => { shouldReportNoDiagnostics(meta); }); + it(`should accept used build-vars from mixin and replace them`, () => { + const deindentAndRemoveSpaces = (str: string) => deindent(str).replace(/\s/g, ''); + const { sheets } = testStylableCore({ + '/mix.st.css': ` + :vars { + a: red; + point_to_a: value(a); + media-val: 123px + } + .mix { + color: value(point_to_a); + } + @media (min-width: value(media-val)) { + .mix { color: purple; } + } + `, + '/valid.st.css': ` + @st-import [mix] from "./mix.st.css"; + + .root { + -st-mixin: mix( + a green, + media-val 789px + ); + } + `, + }); + + const { meta } = sheets['/valid.st.css']; + + shouldReportNoDiagnostics(meta); + expect(deindentAndRemoveSpaces(meta.targetAst!.toString())).to.equal( + deindentAndRemoveSpaces(` + .valid__root { + color: green; + } + @media (min-width: 789px) { + .valid__root { color: purple; } + } + `) + ); + }); it(`should report unknown args`, () => { testStylableCore(` :vars { @@ -310,37 +406,255 @@ describe(`features/st-mixin`, () => { } ); }); - it('should support CSS nesting as part of a mixin', () => { - const { sheets } = testStylableCore(` - .mix { - id: mix; - &:hover.mix { - id: hover; + describe('css nesting', () => { + it('should support CSS nesting as part of a mixin', () => { + const { sheets } = testStylableCore(` + .mix { + .inner { + color: green; + } } - @media { - id: atrule; + + .into { + -st-mixin: mix; } - } + `); - .root { - -st-mixin: mix; - } - `); + const { meta } = sheets['/entry.st.css']; - const { meta } = sheets['/entry.st.css']; + expect(deindent(meta.targetAst!.toString())).to.eql( + deindent(` + .entry__mix { + .entry__inner { + color: green; + } + } - shouldReportNoDiagnostics(meta); - const mixedIntoRule = assertRule(meta.targetAst!.nodes[1], 'mixed into'); - expect(mixedIntoRule.selector).to.eql('.entry__root'); - const firstMixedDecl = assertDecl(mixedIntoRule.nodes[0], 'id: mix'); - expect(firstMixedDecl.prop).to.eql('id'); - expect(firstMixedDecl.value).to.eql('mix'); - const nestHoverRule = assertRule(mixedIntoRule.nodes[1], '&:hover.mix'); - expect(nestHoverRule.selector).to.eql('.entry__root&:hover'); - const nestAtRule = assertAtRule(mixedIntoRule.nodes[2], '@media'); - const nestInAtRule = assertDecl(nestAtRule.nodes[0], 'id: atrule'); - expect(nestInAtRule.prop).to.eql('id'); - expect(nestInAtRule.value).to.eql('atrule'); + .entry__into { + .entry__inner { + color: green; + } + } + `) + ); + }); + it('should preserve nesting selector', () => { + const { sheets } = testStylableCore(` + .mix { + &.inner { + color: green; + } + } + + .into { + -st-mixin: mix; + } + `); + + const { meta } = sheets['/entry.st.css']; + + expect(deindent(meta.targetAst!.toString())).to.eql( + deindent(` + .entry__mix { + &.entry__inner { + color: green; + } + } + + .entry__into { + &.entry__inner { + color: green; + } + } + `) + ); + }); + it('should mix into nesting context', () => { + const { sheets } = testStylableCore(` + .mix { + &.inner { + color: green; + } + } + + .intoTop { + &.intoNested { + -st-mixin: mix; + } + } + `); + + const { meta } = sheets['/entry.st.css']; + + expect(deindent(meta.targetAst!.toString())).to.eql( + deindent(` + .entry__mix { + &.entry__inner { + color: green; + } + } + + .entry__intoTop { + &.entry__intoNested { + &.entry__inner { + color: green; + } + } + } + `) + ); + }); + it('should report recursive mixin ', () => { + const { sheets } = testStylableCore(` + .mix { + &.inner.mix { + color: green; + } + } + + /* @transform-error ${mixinDiagnostics.INVALID_RECURSIVE_MIXIN()}*/ + .into { + -st-mixin: mix; + } + `); + + const { meta } = sheets['/entry.st.css']; + + expect(deindent(meta.targetAst!.toString())).to.eql( + deindent(` + .entry__mix { + &.entry__inner.entry__mix { + color: green; + } + } + + /* @transform-error ${mixinDiagnostics.INVALID_RECURSIVE_MIXIN()}*/ + .entry__into { + &&.entry__inner { + color: green; + } + } + `) + ); + }); + it('should mix nested at-rules with content', () => { + const { sheets } = testStylableCore(` + .mix { + @media (x>y) { + .inner { + color: green; + } + } + } + + .into { + -st-mixin: mix; + } + `); + + const { meta } = sheets['/entry.st.css']; + + expect(deindent(meta.targetAst!.toString())).to.eql( + deindent(` + .entry__mix { + @media (x>y) { + .entry__inner { + color: green; + } + } + } + + .entry__into { + @media (x>y) { + .entry__inner { + color: green; + } + } + } + `) + ); + }); + it('should nest any declaration following nested mixed-in rules', () => { + const { sheets } = testStylableCore(` + .mix { + .inner { + color: green; + } + } + + .into { + declA: 1; + declB: 2; + -st-mixin: mix; + declC: 3; + declD: 4; + } + `); + + const { meta } = sheets['/entry.st.css']; + + expect(deindent(meta.targetAst!.toString())).to.eql( + deindent(` + .entry__mix { + .entry__inner { + color: green; + } + } + + .entry__into { + declA: 1; + declB: 2; + .entry__inner { + color: green; + } + & { + declC: 3; + declD: 4; + } + } + `) + ); + }); + it('should nest mixin decls that follow another mixin with nested nodes', () => { + const { sheets } = testStylableCore(` + .mixNested { + .inner { + color: green; + } + } + .mixDecl { + color: blue; + } + + .into { + -st-mixin: mixNested, mixDecl; + } + `); + + const { meta } = sheets['/entry.st.css']; + + expect(deindent(meta.targetAst!.toString())).to.eql( + deindent(` + .entry__mixNested { + .entry__inner { + color: green; + } + } + .entry__mixDecl { + color: blue; + } + + .entry__into { + .entry__inner { + color: green; + } + & { + color: blue; + } + } + `) + ); + }); }); describe(`st-import`, () => { it(`should mix imported class`, () => { @@ -1707,6 +2021,78 @@ describe(`features/st-mixin`, () => { shouldReportNoDiagnostics(meta); }); + it('should collect mixin from st-sope selector (experimentalSelectorInference)', () => { + const { sheets } = testStylableCore( + { + '/mix.st.css': ` + @st-scope .mix { + .part { color: green; } + .part2 { color: purple; } + &:state { color: gold; } + } + @st-scope .mix.compoundAfter { + .part { color: blue; } + } + @st-scope .compoundBefore.mix { + .part { color: pink; } + } + @st-scope .mix, .notMix, .mix[extra] { + .part { color: white; } + } + .mix { + -st-states: state; + } + `, + '/entry.st.css': ` + @st-import [mix] from './mix.st.css'; + + /* + @rule(descendant)[1] .entry__into .mix__part {color: green;} + @rule(descendant2)[2] .entry__into .mix__part2 {color: purple;} + @rule(state)[3] .entry__into.mix--state {color: gold;} + @rule(+after)[4] .entry__into.mix__compoundAfter .mix__part {color: blue;} + @rule(+before)[5] .entry__into.mix__compoundBefore .mix__part {color: pink;} + @rule(multi selector)[6] .entry__into .mix__part, .entry__into[extra] .mix__part {color: white;} + */ + .into { + -st-mixin: mix; + } + `, + }, + { stylableConfig: { experimentalSelectorInference: true } } + ); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it('should collect only st-scope nested rules', () => { + const { sheets } = testStylableCore({ + '/mix.st.css': ` + .before { color: RED; } + @st-scope .mix { + .inside { color: green; } + } + .after { color: RED; } + `, + '/entry.st.css': ` + @st-import [mix] from './mix.st.css'; + + .into {-st-mixin: mix;} + `, + }); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + + expect(deindent(meta.targetAst!.toString())).to.eql( + deindent(` + .entry__into {} + .entry__into .mix__inside { color: green; } + `) + ); + }); }); describe(`higher-level feature integrations`, () => { // ToDo: move to their higher level feature spec when created diff --git a/packages/core/test/features/st-namespace.spec.ts b/packages/core/test/features/st-namespace.spec.ts index 17a6939f4b..df0d804bac 100644 --- a/packages/core/test/features/st-namespace.spec.ts +++ b/packages/core/test/features/st-namespace.spec.ts @@ -245,11 +245,16 @@ describe('features/st-namespace', () => { @namespace was previously used instead of @st-namespace. In order to preserve backwards compatibility, @namespace will continue to define the stylable namespace under specific conditions. + + ToDo(major): remove special handling of native @namespace */ it('should override default namespace with @namespace', () => { const { sheets } = testStylableCore({ '/other.st.css': ` - /* @transform-remove */ + /* + @transform-remove + @analyze-info ${diagnostics.NATIVE_OVERRIDE_DEPRECATION()} + */ @namespace "button"; /* @rule .button__x */ @@ -259,8 +264,6 @@ describe('features/st-namespace', () => { const { meta, exports } = sheets['/other.st.css']; - shouldReportNoDiagnostics(meta); - expect(meta.namespace, 'meta.namespace').to.eql('button'); // JS exports diff --git a/packages/core/test/features/st-scope.spec.ts b/packages/core/test/features/st-scope.spec.ts index 7a059c73f3..8441d17d58 100644 --- a/packages/core/test/features/st-scope.spec.ts +++ b/packages/core/test/features/st-scope.spec.ts @@ -1,6 +1,11 @@ import { STGlobal } from '@stylable/core/dist/features'; import type { StylableMeta } from '@stylable/core'; -import { testStylableCore, collectAst, shouldReportNoDiagnostics } from '@stylable/core-test-kit'; +import { + testStylableCore, + collectAst, + shouldReportNoDiagnostics, + deindent, +} from '@stylable/core-test-kit'; import { expect } from 'chai'; import type * as postcss from 'postcss'; @@ -28,6 +33,77 @@ const queryStScope = (meta: StylableMeta, params: string): postcss.AtRule | unde describe(`features/st-scope`, () => { // ToDo: move relevant tests here + it('should allow nested global/external selectors', () => { + const { sheets } = testStylableCore({ + '/external.st.css': ``, + '/valid.st.css': ` + @st-import External, [root as external] from './external.st.css'; + @st-scope { + .external {} + External {} + div {} + + @media screen and (max-width: 555px) { + .external {} + External {} + span {} + } + } + `, + }); + + const { meta } = sheets['/valid.st.css']; + + shouldReportNoDiagnostics(meta); + expect(deindent(meta.targetAst!.toString())).to.eql( + deindent(` + .external__root {} + .external__root {} + div {} + + @media screen and (max-width: 555px) { + .external__root {} + .external__root {} + span {} + } + `) + ); + }); + it('should prepend scoping selector to nested rules', () => { + const { sheets } = testStylableCore({ + '/external.st.css': `.part{}`, + '/prepend.st.css': ` + @st-import External, [part as externalPart] from './external.st.css'; + @st-scope .s { + + /* @rule .prepend__s .external__part */ + .externalPart {} + + /* @rule .prepend__s .external__root */ + External {} + + /* @rule .prepend__s div */ + div {} + + @media screen and (max-width: 555px) { + + /* @rule .prepend__s .external__part */ + .externalPart {} + + /* @rule .prepend__s .external__root */ + External {} + + /* @rule .prepend__s span */ + span {} + } + } + `, + }); + + const { meta } = sheets['/prepend.st.css']; + + shouldReportNoDiagnostics(meta); + }); describe('st-global', () => { it('should collect global rules', () => { const { sheets } = testStylableCore(` diff --git a/packages/core/test/features/st-structure.spec.ts b/packages/core/test/features/st-structure.spec.ts new file mode 100644 index 0000000000..654a154502 --- /dev/null +++ b/packages/core/test/features/st-structure.spec.ts @@ -0,0 +1,727 @@ +import { + diagnosticBankReportToStrings, + shouldReportNoDiagnostics, + testStylableCore, + spyCalls, +} from '@stylable/core-test-kit'; +import { + CSSClass, + STStructure, + transformerDiagnostics, + STCustomState, +} from '@stylable/core/dist/index-internal'; +import { expect } from 'chai'; + +const transformerStringDiagnostics = diagnosticBankReportToStrings(transformerDiagnostics); +const stStructureDiagnostics = diagnosticBankReportToStrings(STStructure.diagnostics); +const stStateDiagnostics = diagnosticBankReportToStrings(STCustomState.diagnostics); +const classDiagnostics = diagnosticBankReportToStrings(CSSClass.diagnostics); + +describe('@st structure', () => { + it('should warn experimental feature', () => { + const warnSpy = spyCalls(console, 'warn'); + const filterExpCalls = () => + warnSpy.calls.filter( + ([msg]) => typeof msg === 'string' && msg === STStructure.experimentalMsg + ); + + // no warn without using @st + testStylableCore(` + .root{} + `); + + expect(filterExpCalls(), 'not used').to.have.lengthOf(0); + + // reset calls + warnSpy.resetSpy(); + + testStylableCore(` + @st; + @st; + `); + + expect(filterExpCalls(), 'only once').to.have.lengthOf(1); + + warnSpy.restoreSpy(); + }); + it('should have no implicit root', () => { + const { sheets } = testStylableCore(` + @st .comp; + `); + + const { meta, exports } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + expect(exports.classes.root).to.eql(undefined); + }); + describe('@st .name (top level class)', () => { + it('should prevent automatic .class=>::part definition', () => { + testStylableCore(` + @st .root; + .customPart {} + + /* + @transform-error ${transformerStringDiagnostics.UNKNOWN_PSEUDO_ELEMENT( + `customPart` + )} + @rule .entry__root::customPart + */ + .root::customPart {} + `); + }); + it('should register css class', () => { + const { sheets } = testStylableCore(` + @st .abc; + @st .xyz {} + @st .comment /*comment*/ {} + .normal-class {} + `); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + expect(meta.getAllClasses()).to.have.keys(['abc', 'xyz', 'comment', 'normal-class']); + }); + it('should be valid only at top level', () => { + testStylableCore(` + @st .abc { + /* @analyze-error ${stStructureDiagnostics.CLASS_OUT_OF_CONTEXT()} */ + @st .xyz; + } + `); + }); + it('should report re-decare', () => { + testStylableCore(` + @st .dup; + + /* @analyze-error word(.dup) ${stStructureDiagnostics.REDECLARE('class', '.dup')} */ + @st .dup; + `); + }); + it('should report non-class definition', () => { + const { sheets } = testStylableCore(` + /* @analyze-error(element) ${stStructureDiagnostics.UNSUPPORTED_TOP_DEF()} */ + @st .; + + /* @analyze-error(element) ${stStructureDiagnostics.UNSUPPORTED_TOP_DEF()} */ + @st abc; + + /* @analyze-error(attribute) ${stStructureDiagnostics.UNSUPPORTED_TOP_DEF()} */ + @st [abc]; + + /* @analyze-error(multi classes) word(.b) ${stStructureDiagnostics.UNEXPECTED_EXTRA_VALUE( + '.b' + )} */ + @st .a.b; + `); + + const { meta } = sheets['/entry.st.css']; + + expect(CSSClass.getAll(meta)).to.eql({}); + }); + it('should extend another class', () => { + const { sheets } = testStylableCore(` + @st .abc :is(.defined-class-inline); + @st .xyz :is(.existing-class-after); + + .existing-class-after { + -st-states: state; + }; + + /* @rule .entry__xyz.entry--state */ + .xyz:state {} + `); + + const { meta, exports } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + expect(exports.classes.abc, 'composed inline def').to.eql( + 'entry__abc entry__defined-class-inline' + ); + }); + it('should add runtime inherit check (dev mode)', () => { + const source = ` + @st .super :is(.root); + `; + // + const { sheets: devSheets } = testStylableCore(source, { + stylableConfig: { mode: 'development' }, + }); + const { sheets: prodSheets } = testStylableCore(source, { + stylableConfig: { mode: 'production' }, + }); + + const { meta: devMeta } = devSheets['/entry.st.css']; + const { meta: prodMeta } = prodSheets['/entry.st.css']; + + const devActual = devMeta.targetAst!.toString().replace(/\s\s+/g, ' '); + const prodActual = prodMeta.targetAst?.toString().replace(/\s\s+/g, ' '); + + const expected = CSSClass.createWarningRule( + '.root' /*extendedNode*/, + '.entry__root' /*scopedExtendedNode*/, + 'entry.st.css' /*extendedFile*/, + '.super' /*extendingNode*/, + '.entry__super' /*scopedExtendingNode*/, + 'entry.st.css' /*extendingFile*/ + ) + .toString() + .replace(/\s\s+/g, ' '); + + expect(devActual, 'development').to.contain(expected); + expect(prodActual, 'production').to.not.contain(expected); + }); + it('should disallow unsupported extends', () => { + testStylableCore(` + /* @analyze-error(element) ${stStructureDiagnostics.MISSING_EXTEND()}*/ + @st .xyz :is(root); + + /* @analyze-error(multi class) ${stStructureDiagnostics.MISSING_EXTEND()}*/ + @st .xyz :is(.a, .b); + `); + }); + it('should error on non local definition', () => { + testStylableCore({ + 'origin.st.css': ` + .external {} + `, + 'entry.st.css': ` + @st-import [external] from "./origin.st.css"; + + /* @analyze-error ${stStructureDiagnostics.OVERRIDE_IMPORTED_CLASS()}*/ + @st .external; + `, + }); + }); + it('should register css class selector mapping', () => { + const { sheets } = testStylableCore(` + @st .abc => :global(.xyz); + + @st .comments =>/*c1*/:global(.comments); + + /* @rule(standalone) .xyz */ + .abc {} + + /* @rule(comments) .comments */ + .comments {} + `); + + const { meta, exports } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + + expect(exports.classes.abc, 'single global class export').to.eql('xyz'); + }); + it('should report selector mapping diagnostics', () => { + testStylableCore({ + 'general.st.css': ` + /* @analyze-error(empty) ${stStructureDiagnostics.MISSING_MAPPED_SELECTOR()} */ + @st .empty => ; + + /* @rule(not global) .general__empty */ + .empty {} + + /* @analyze-error(multi) ${stStructureDiagnostics.MULTI_MAPPED_SELECTOR()} */ + @st .multi => .a, .b; + + /* @rule(multi) .general__multi */ + .multi {} + `, + 'global.st.css': ` + /* @analyze-error(not global) word(.xyz) ${stStructureDiagnostics.GLOBAL_MAPPING_LIMITATION()} */ + @st .not-global => .xyz; + + /* @rule(not global) .global__not-global */ + .not-global {} + + /* @analyze-error(not global pseudo) ${stStructureDiagnostics.GLOBAL_MAPPING_LIMITATION()} */ + @st .top-level-is => :is(.xyz); + + /* @rule(not global pseudo) .global__top-level-is */ + .top-level-is {} + + /* @analyze-error(empty global) ${stStructureDiagnostics.GLOBAL_MAPPING_LIMITATION()} */ + @st .empty-global => :global; + + /* @analyze-error(no value global) ${stStructureDiagnostics.GLOBAL_MAPPING_LIMITATION()} */ + @st .no-value-global => :global(); + + /* @analyze-error(multi global) ${stStructureDiagnostics.GLOBAL_MAPPING_LIMITATION()} */ + @st .multi-global => :global(.a, .b); + + /* @analyze-error(more then one global) ${stStructureDiagnostics.GLOBAL_MAPPING_LIMITATION()} */ + @st .more-then-one-global => :global(.a) :global(.b); + + /* @rule(multi global) .global__multi-global */ + .multi-global {} + `, + }); + }); + it('should report unexpected extra value', () => { + testStylableCore(` + /* @analyze-error word(unexpected value) ${stStructureDiagnostics.UNEXPECTED_EXTRA_VALUE( + 'unexpected value' + )} */ + @st .empty unexpected value; + `); + }); + it('should disallow -st-* definitions on class that is defined with @st', () => { + testStylableCore(` + @st .new; + + .old { -st-states: yState; } + + .new { + /* @analyze-error(extend) ${classDiagnostics.DISABLED_DIRECTIVE( + 'new', + '-st-extends' + )} */ + -st-extends: old; + + /* @analyze-error(extend) ${classDiagnostics.DISABLED_DIRECTIVE( + 'new', + '-st-states' + )} */ + -st-states: xState; + + /* @analyze-error(extend) ${classDiagnostics.DISABLED_DIRECTIVE( + 'new', + '-st-global' + )} */ + -st-global: ".xxx"; + } + + /* @rule(extend fail) .entry__new:yState */ + .new:yState {} + + + /* @rule(legacy def) .entry__old.entry--yState */ + .old:yState {} + `); + }); + }); + describe('@st :name (pseudo-class)', () => { + it('should define pseudo-class on parent class def', () => { + const { sheets } = testStylableCore(` + @st .x { + @st :bool; + @st :ops(enum(a, b)); + @st :opsWithDefault(enum(w, x, y, z)) x; + } + + /* @rule(bool) .entry__x.entry--bool*/ + .x:bool {} + + /* @rule(param) .entry__x.entry---ops-1-b*/ + .x:ops(b) {} + + /* @rule(default param) .entry__x.entry---opsWithDefault-1-x*/ + .x:opsWithDefault {} + `); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it('should be nested in `@st .class{}`', () => { + testStylableCore(` + /* @analyze-error ${stStructureDiagnostics.STATE_OUT_OF_CONTEXT()}*/ + @st :top-level; + + @media { + /* @analyze-error ${stStructureDiagnostics.STATE_OUT_OF_CONTEXT()}*/ + @st :in-at-rule; + } + `); + }); + it('should report parsing issues', () => { + const { sheets } = testStylableCore({ + 'invalid.st.css': ` + @st .x { + /* @analyze-warn ${stStateDiagnostics.NO_STATE_TYPE_GIVEN('bool')}*/ + @st :bool(); + + /* @analyze-error ${stStateDiagnostics.STATE_STARTS_WITH_HYPHEN( + '-dashProxy' + )}*/ + @st :-dashProxy; + + /* @analyze-error ${stStructureDiagnostics.UNEXPECTED_EXTRA_VALUE( + 'abc xyz' + )}*/ + @st :boolWithExtra abc xyz; + } + `, + 'valid.st.css': ` + @st .x { + @st :boolWithExtra /*abc xyz*/; + } + + /* @rule(boolWithExtra) .valid__x.valid--boolWithExtra */ + .x:boolWithExtra {} + `, + }); + + const { meta } = sheets['/valid.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it('should report re-declare of state (first win)', () => { + testStylableCore(` + @st .x { + @st :conflict(string); + + /* @analyze-error word(:conflict) ${stStructureDiagnostics.REDECLARE( + 'pseudo-state', + ':conflict' + )} */ + @st :conflict(enum(a, b)) b; + } + + /* @rule .entry__x.entry---conflict-3-ccc */ + .x:conflict(ccc) {} + `); + }); + }); + describe('@st ::name (pseudo-element)', () => { + it('should define pseudo-element on parent class def', () => { + const { sheets } = testStylableCore(` + @st .x { + @st ::part => [part="x"]; + + @st ::noSpaces=>[noSpaces]; + + @st /*c1*/ :/*what?*/:/*c2*/comments/*c3*/=> [weirdComment]/*c5*/; + + @st ::unscoped => unscopedElement; + } + + /* @rule .entry__x [part="x"] */ + .x::part {} + + /* @rule .entry__x [noSpaces] */ + .x::noSpaces {} + + /* @rule .entry__x [weirdComment] */ + .x::comments {} + + /* @rule .entry__x unscopedElement */ + .x::unscoped {} + `); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it('should define compound mapping', () => { + const { sheets } = testStylableCore(` + @st .x { + @st ::compound => &[compound]; + + @st ::withComments => /*c1*/&/*c2*/[withComments]/*c3*/; + } + + /* @rule .entry__x[compound] */ + .x::compound {} + + /* @rule .entry__x[withComments]*/ + .x::withComments {} + `); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it('should analyze selector mapping', () => { + const { sheets } = testStylableCore(` + @st .x { + @st ::part => .innerClass; + } + `); + + const { meta, exports } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + expect(exports.classes.innerClass, 'class definition').to.eql('entry__innerClass'); + }); + it('should define nested pseudo-elements', () => { + const { sheets } = testStylableCore(` + @st .x { + @st ::first => [first] { + @st ::second => [second]; + }; + } + + /* @rule .entry__x [first] [second] */ + .x::first::second {} + `); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it('should resolve first level definition', () => { + const { sheets } = testStylableCore(` + @st .b { + @st ::title => & > h2; + } + @st .a :is(.b) { + @st ::title => & > h1; + } + + /* @rule .entry__a > h1 */ + .a::title {} + + /* @rule .entry__b > h2 */ + .b::title {} + `); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it('should resolve inherited between multiple stylesheet definitions', () => { + const { sheets } = testStylableCore({ + 'origin.st.css': ` + @st .origin { + @st ::x => [x-of-origin]; + } + `, + 'def.st.css': ` + @st-import [origin] from "./origin.st.css"; + + @st .base :is(.origin) { + @st ::a => [a-of-base]; + } + @st .compose :is(.base) { + @st ::b => [b-of-compose]; + } + + /* @rule(compose) .def__compose [x-of-origin] */ + .compose::x {} + + /* @rule(compose) .def__compose [b-of-compose] */ + .compose::b {} + + /* @rule(inherited) .def__compose [a-of-base] */ + .compose::a {} + `, + 'entry.st.css': ` + @st-import [compose] from "./def.st.css"; + + @st .x :is(.compose); + + /* @rule(compose) .entry__x [x-of-origin] */ + .x::x {} + + /* @rule(compose) .entry__x [b-of-compose] */ + .x::b {} + + /* @rule(inherited) .entry__x [a-of-base] */ + .x::a {} + `, + }); + + shouldReportNoDiagnostics(sheets['/def.st.css'].meta); + shouldReportNoDiagnostics(sheets['/entry.st.css'].meta); + }); + it('should resolve inherited parts with legacy flat mode', () => { + const { sheets } = testStylableCore({ + 'base.st.css': ` + @st .base { + @st ::part => [part="x"]; + } + `, + 'legacy.st.css': ` + @st-import [base] from "./base.st.css"; + .clsA { + -st-extends: base; + } + `, + 'entry.st.css': ` + @st-import Legacy, [clsA] from "./legacy.st.css"; + + @st .root :is(.Legacy); + @st .clsB :is(.clsA); + + /* @rule(extend) .entry__clsB [part="x"] */ + .clsB::part {} + + /* @rule(through extending part) .entry__root .legacy__clsA [part="x"] */ + .root::clsA::part {} + `, + }); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it('should be invalid out of `@st .class{}` and `@st ::part`', () => { + testStylableCore(` + /* @analyze-error ${stStructureDiagnostics.ELEMENT_OUT_OF_CONTEXT()}*/ + @st ::top-level => .top; + + @media { + /* @analyze-error ${stStructureDiagnostics.ELEMENT_OUT_OF_CONTEXT()}*/ + @st ::in-at-rule => .media; + } + `); + }); + it('should report mapped selector issues', () => { + testStylableCore(` + @st .x { + /* @analyze-error(empty) ${stStructureDiagnostics.MISSING_MAPPED_SELECTOR()}*/ + @st ::missing-selector => ; + + /* @analyze-error(comment) ${stStructureDiagnostics.MISSING_MAPPED_SELECTOR()}*/ + @st ::missing-selector => /*c*/; + + /* @analyze-error(multi) ${stStructureDiagnostics.MULTI_MAPPED_SELECTOR()}*/ + @st ::multi-selector => .a, .b; + + /* @analyze-error(no-arrow) ${stStructureDiagnostics.MISSING_MAPPING()}*/ + @st ::missing-mapping ; + + /* @analyze-error(nesting) ${stStructureDiagnostics.MAPPING_UNSUPPORTED_NESTING()}*/ + @st ::multi-selector => .a:not(&); + } + `); + }); + it('should report definition issues', () => { + // ToDo: report on the original definition as well + const { sheets } = testStylableCore({ + 'invalid.st.css': ` + @st .x { + @st ::duplicate => .a; + + /* @analyze-error word(::duplicate) ${stStructureDiagnostics.REDECLARE( + 'pseudo-element', + '::duplicate' + )}*/ + @st ::duplicate => .b; + + /* @analyze-error ${stStructureDiagnostics.INVALID_ST_DEF( + ': :invalidSpace => .c' + )}*/ + @st : :invalidSpace => .c; + } + + /* @rule .invalid__x::invalidSpace */ + .x::invalidSpace {} + `, + 'valid.st.css': ` + @st .x { + @st ::noConflict => .xChild { + @st ::noConflict => .deepChild; + }; + } + @st .y { + @st ::noConflict => .yChild; + } + `, + }); + + const { meta } = sheets['/valid.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it('should infer nested pseudo-element', () => { + const { sheets } = testStylableCore({ + 'def.st.css': ` + @st .x { + @st ::a => .base { + @st ::aChild => .deep; + } + @st ::b => .base; + } + @st .base { + @st ::baseChild => .baseChild; + } + `, + 'valid.st.css': ` + @st-import [x] from './def.st.css'; + + /* @rule(a::aChild) .valid__t .def__x .def__base .def__deep */ + .t .x::a::aChild {} + + /* @rule(a::baseChild) .valid__t .def__x .def__base .def__baseChild */ + .t .x::a::baseChild {} + + /* @rule(b::baseChild) .valid__t .def__x .def__base .def__baseChild */ + .t .x::b::baseChild {} + `, + 'invalid.st.css': ` + @st-import [x] from './def.st.css'; + + .x::a::aChild {/*cause resolve of base*/} + /* @rule(base infer unmodified) .def__x .def__base::aChild */ + .x::b::aChild {} + `, + }); + + const { meta } = sheets['/valid.st.css']; + + shouldReportNoDiagnostics(meta); + }); + it('should define pseudo-class for pseudo-element', () => { + const { sheets } = testStylableCore(` + @st .base { + @st :baseState; + } + + @st .x { + @st ::a => .base { + @st :aState; + } + } + + /* @rule(a::aState) .entry__x .entry__base.entry--aState */ + .x::a:aState {} + + /* @rule(a::baseState) .entry__x .entry__base.entry--baseState */ + .x::a:baseState {} + `); + + const { meta } = sheets['/entry.st.css']; + + shouldReportNoDiagnostics(meta); + }); + }); + describe('@st-import', () => { + it('should handle default import with no implicit root', () => { + // ToDo: choose how to handle from a structure move stylesheet + testStylableCore({ + 'origin.st.css': ` + @st .x {} + `, + 'entry.st.css': ` + @st-import Default from "./origin.st.css"; + + .y { + /* @transform-error ${classDiagnostics.CANNOT_EXTEND_UNKNOWN_SYMBOL( + 'default' + )} */ + -st-extends: Default; + } + `, + }); + }); + }); + describe('native css', () => { + it('should not collect `@st` definition from non stylable file', () => { + testStylableCore({ + 'native.css': ` + @st .x { + @st ::y => .z; + } + `, + 'entry.st.css': ` + @st-import [x] from './native.css'; + + /* @rule(not existing on native) .entry__x */ + .x {} + `, + }); + }); + }); +}); diff --git a/packages/core/test/features/st-symbol.spec.ts b/packages/core/test/features/st-symbol.spec.ts index 47616c1ff8..892d09195a 100644 --- a/packages/core/test/features/st-symbol.spec.ts +++ b/packages/core/test/features/st-symbol.spec.ts @@ -7,6 +7,8 @@ import { VarSymbol, ImportSymbol, KeyframesSymbol, + CSSClass, + CSSType, } from '@stylable/core/dist/features'; import { Diagnostics } from '@stylable/core/dist/diagnostics'; import { diagnosticBankReportToStrings, testStylableCore } from '@stylable/core-test-kit'; @@ -23,7 +25,7 @@ describe(`features/st-symbol`, () => { it(`should keep symbol on meta`, () => { const { sheets } = testStylableCore(``); const { meta } = sheets[`/entry.st.css`]; - const symbol: StylableSymbol = { _kind: `class`, name: `a` }; + const symbol: StylableSymbol = CSSClass.createSymbol({ name: `a` }); const context = { meta, diagnostics: new Diagnostics() }; STSymbol.addSymbol({ context, symbol }); @@ -37,8 +39,8 @@ describe(`features/st-symbol`, () => { it(`should keep track of symbols by type`, () => { const { sheets } = testStylableCore(``); const { meta } = sheets[`/entry.st.css`]; - const classSymbol: StylableSymbol = { _kind: `class`, name: `a` }; - const typeSymbol: StylableSymbol = { _kind: `element`, name: `a` }; + const classSymbol: StylableSymbol = CSSClass.createSymbol({ name: `a` }); + const typeSymbol: StylableSymbol = CSSType.createSymbol({ name: `a` }); const context = { meta, diagnostics: new Diagnostics() }; STSymbol.addSymbol({ context, symbol: classSymbol }); @@ -57,8 +59,8 @@ describe(`features/st-symbol`, () => { it(`should override previous symbol`, () => { const { sheets } = testStylableCore(``); const { meta } = sheets[`/entry.st.css`]; - const symbolA: StylableSymbol = { _kind: `class`, name: `a` }; - const symbolB: StylableSymbol = { _kind: `element`, name: `a` }; + const symbolA: StylableSymbol = CSSClass.createSymbol({ name: `a` }); + const symbolB: StylableSymbol = CSSType.createSymbol({ name: `a` }); const context = { meta, diagnostics: new Diagnostics() }; STSymbol.addSymbol({ context, symbol: symbolA }); @@ -85,8 +87,8 @@ describe(`features/st-symbol`, () => { it(`should return collected symbols by namespace`, () => { const { sheets } = testStylableCore(``); const { meta } = sheets[`/entry.st.css`]; - const classSymbol: StylableSymbol = { _kind: `class`, name: `a` }; - const typeSymbol: StylableSymbol = { _kind: `element`, name: `b` }; + const classSymbol: StylableSymbol = CSSClass.createSymbol({ name: `a` }); + const typeSymbol: StylableSymbol = CSSType.createSymbol({ name: `b` }); const keyframesSymbol: StylableSymbol = { _kind: `keyframes`, name: `c`, alias: `` }; const context = { meta, diagnostics: new Diagnostics() }; @@ -119,23 +121,23 @@ describe(`features/st-symbol`, () => { STSymbol.addSymbol({ context, localName: `localA`, - symbol: { - _kind: `class`, + symbol: CSSClass.createSymbol({ name: `A`, - }, + }), }); - expect(STSymbol.get(meta, `localA`)).to.eql({ - _kind: `class`, - name: `A`, - }); + expect(STSymbol.get(meta, `localA`)).to.eql( + CSSClass.createSymbol({ + name: `A`, + }) + ); expect(STSymbol.get(meta, `A`)).to.eql(undefined); }); describe(`diagnostics`, () => { it(`should warn on node with re-declared symbol`, () => { const { sheets } = testStylableCore(``); const { meta } = sheets[`/entry.st.css`]; - const symbol: StylableSymbol = { _kind: `class`, name: `a` }; + const symbol: StylableSymbol = CSSClass.createSymbol({ name: `a` }); const ruleA = new postcss.Rule(); const ruleB = new postcss.Rule(); const context = { meta, diagnostics: new Diagnostics() }; @@ -162,7 +164,7 @@ describe(`features/st-symbol`, () => { it(`should NOT warn re-declared symbol with safeRedeclare=true`, () => { const { sheets } = testStylableCore(``); const { meta } = sheets[`/entry.st.css`]; - const symbol: StylableSymbol = { _kind: `class`, name: `a` }; + const symbol: StylableSymbol = CSSClass.createSymbol({ name: `a` }); const ruleA = new postcss.Rule(); const ruleB = new postcss.Rule(); const context = { meta, diagnostics: new Diagnostics() }; @@ -179,7 +181,7 @@ describe(`features/st-symbol`, () => { it(`should warn on root declaration`, () => { const { sheets } = testStylableCore(``); const { meta } = sheets[`/entry.st.css`]; - const symbol: StylableSymbol = { _kind: `class`, name: `root` }; + const symbol: StylableSymbol = CSSClass.createSymbol({ name: `root` }); const rule = new postcss.Rule(); const context = { meta, diagnostics: new Diagnostics() }; diff --git a/packages/core/test/helpers/rule.spec.ts b/packages/core/test/helpers/rule.spec.ts index 06bc9a404c..3482a0e85e 100644 --- a/packages/core/test/helpers/rule.spec.ts +++ b/packages/core/test/helpers/rule.spec.ts @@ -52,6 +52,9 @@ describe(`helpers/rule`, () => { /*nesting*/ .i[out] { .i[in] {} } + + /*nesting at-rule*/ + .i[out] { @media (x) { [in] {} } } `), '.i' ); @@ -81,6 +84,16 @@ describe(`helpers/rule`, () => { selector: '[st-mixin-marker][out]', nodes: [{ selector: '[st-mixin-marker][in]' }], }, + { + selector: '[st-mixin-marker][out]', + nodes: [ + { + name: 'media', + params: '(x)', + nodes: [{ selector: '[in]' }], + }, + ], + }, ]; testMatcher(expected, res.nodes); diff --git a/packages/core/test/intellisense/intellisense.spec.ts b/packages/core/test/intellisense/intellisense.spec.ts index 8a4a026e06..dbb5979fb4 100644 --- a/packages/core/test/intellisense/intellisense.spec.ts +++ b/packages/core/test/intellisense/intellisense.spec.ts @@ -1,6 +1,6 @@ import { expect } from 'chai'; import { createTransformer } from '@stylable/core-test-kit'; -import { STCustomSelector } from '@stylable/core/dist/index-internal'; +import { STCustomSelector, CSSType } from '@stylable/core/dist/index-internal'; describe('Stylable intellisense selector meta data', () => { it('resolve single class element', () => { @@ -251,7 +251,7 @@ describe('Stylable intellisense selector meta data', () => { { type: 'pseudo-element', name: 'part', - resolved: [{ _kind: 'css', meta, symbol: { _kind: 'element', name: '*' } }], + resolved: [{ _kind: 'css', meta, symbol: CSSType.createSymbol({ name: '*' }) }], }, ]); }); @@ -526,7 +526,7 @@ describe('Stylable intellisense selector meta data', () => { type: 'pseudo-element', name: 'pongo', resolved: [ - { _kind: 'css', meta: otherMeta, symbol: { _kind: 'element', name: '*' } }, + { _kind: 'css', meta: otherMeta, symbol: CSSType.createSymbol({ name: '*' }) }, ], }, ]); diff --git a/packages/core/test/scope-directive.spec.ts b/packages/core/test/scope-directive.spec.ts index aa467884b7..dd5ad85f6e 100644 --- a/packages/core/test/scope-directive.spec.ts +++ b/packages/core/test/scope-directive.spec.ts @@ -9,9 +9,7 @@ import { shouldReportNoDiagnostics, } from '@stylable/core-test-kit'; import { transformerDiagnostics } from '@stylable/core/dist/index-internal'; -import { STScope } from '@stylable/core/dist/features'; -const stScopeDiagnostics = diagnosticBankReportToStrings(STScope.diagnostics); const transformerStringDiagnostics = diagnosticBankReportToStrings(transformerDiagnostics); use(flatMatch); @@ -516,29 +514,5 @@ describe('@st-scope', () => { '.entry__root::unknownPart .entry__part::unknownPart' ); }); - it('should warn about a missing scoping parameter', () => { - const config = { - entry: `/entry.st.css`, - files: { - '/entry.st.css': { - namespace: 'entry', - content: ` - |@st-scope { - .part {} - }| - `, - }, - }, - }; - - const { meta } = expectTransformDiagnostics(config, [ - { - message: stScopeDiagnostics.MISSING_SCOPING_PARAM(), - file: '/entry.st.css', - severity: 'error', - }, - ]); - expect((meta.targetAst!.first as Rule).selector).to.equal('.entry__part'); - }); }); }); diff --git a/packages/core/test/stylable-processor.spec.ts b/packages/core/test/stylable-processor.spec.ts index f090f3b60d..938a5b5bb1 100644 --- a/packages/core/test/stylable-processor.spec.ts +++ b/packages/core/test/stylable-processor.spec.ts @@ -2,7 +2,10 @@ import { resolve } from 'path'; import chai, { expect } from 'chai'; import { flatMatch, processSource } from '@stylable/core-test-kit'; import { processNamespace } from '@stylable/core'; -import { knownPseudoClassesWithNestedSelectors } from '@stylable/core/dist/index-internal'; +import { + CSSClass, + knownPseudoClassesWithNestedSelectors, +} from '@stylable/core/dist/index-internal'; chai.use(flatMatch); @@ -101,12 +104,11 @@ describe('Stylable postcss process', () => { ); expect(result.getAllClasses()).to.eql({ - root: { - _kind: 'class', + root: CSSClass.createSymbol({ name: 'root', '-st-root': true, alias: undefined, - }, + }), }); }); diff --git a/packages/core/test/stylable-transformer/transformer.unit.spec.ts b/packages/core/test/stylable-transformer/transformer.unit.spec.ts index 0671866cea..88fa1abec8 100644 --- a/packages/core/test/stylable-transformer/transformer.unit.spec.ts +++ b/packages/core/test/stylable-transformer/transformer.unit.spec.ts @@ -1,24 +1,9 @@ import { expect } from 'chai'; -import { testStylableCore } from '@stylable/core-test-kit'; - -function createSpy any>(fn?: T) { - const spy = (...args: any[]) => { - spy.calls.push(args); - spy.callCount++; - return fn?.(...args); - }; - spy.calls = [] as unknown[][]; - spy.callCount = 0; - spy.resetHistory = () => { - spy.calls.length = 0; - spy.callCount = 0; - }; - return spy; -} +import { testStylableCore, logCalls } from '@stylable/core-test-kit'; describe('Transformer', () => { it('should not resolve path more then once', () => { - const onResolve = createSpy((resolved) => resolved); + const onResolve = logCalls((resolved: any) => resolved); testStylableCore( { '/base.st.css': ` diff --git a/packages/create-stylable-app/package.json b/packages/create-stylable-app/package.json index 15c1c899c2..9006768af6 100644 --- a/packages/create-stylable-app/package.json +++ b/packages/create-stylable-app/package.json @@ -1,6 +1,6 @@ { "name": "create-stylable-app", - "version": "5.11.0", + "version": "5.17.0", "description": "Quickly create a Stylable application", "main": "dist/index.js", "bin": { diff --git a/packages/create-stylable-app/template/ts-react-rollup/template.js b/packages/create-stylable-app/template/ts-react-rollup/template.js index 1c656ef314..a3e2eedfa4 100644 --- a/packages/create-stylable-app/template/ts-react-rollup/template.js +++ b/packages/create-stylable-app/template/ts-react-rollup/template.js @@ -26,6 +26,7 @@ module.exports = { 'rollup-plugin-copy', 'rollup-plugin-serve', 'serve', + 'tslib', 'typescript', ], packageJson: { diff --git a/packages/custom-value/package.json b/packages/custom-value/package.json index e78dbaad1d..40a0335c9d 100644 --- a/packages/custom-value/package.json +++ b/packages/custom-value/package.json @@ -1,13 +1,13 @@ { "name": "@stylable/custom-value", - "version": "5.11.0", + "version": "5.17.0", "description": "Custom values (variables) for Stylable", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\" --timeout 20000" }, "dependencies": { - "@stylable/core": "^5.11.0" + "@stylable/core": "^5.17.0" }, "files": [ "dist", diff --git a/packages/dom-test-kit/package.json b/packages/dom-test-kit/package.json index 0b3217c0ac..4ef1f2e147 100644 --- a/packages/dom-test-kit/package.json +++ b/packages/dom-test-kit/package.json @@ -1,15 +1,15 @@ { "name": "@stylable/dom-test-kit", - "version": "5.11.0", + "version": "5.17.0", "description": "Stylable DOM testing utilities", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\"" }, "dependencies": { - "@stylable/core": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "@tokey/css-selector-parser": "^0.6.1" + "@stylable/core": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "@tokey/css-selector-parser": "^0.6.2" }, "files": [ "dist", diff --git a/packages/e2e-test-kit/package.json b/packages/e2e-test-kit/package.json index e96ffc6a34..bc4433d569 100644 --- a/packages/e2e-test-kit/package.json +++ b/packages/e2e-test-kit/package.json @@ -1,16 +1,16 @@ { "name": "@stylable/e2e-test-kit", - "version": "5.11.0", + "version": "5.17.0", "description": "A collection of tools to help test Stylable components and applications from end-to-end", "main": "dist/index.js", "peerDependencies": { "webpack": "^5.30.0" }, "dependencies": { - "@stylable/runtime": "^5.11.0", + "@stylable/runtime": "^5.17.0", "node-eval": "^2.0.0", - "playwright-core": "^1.33.0", - "rimraf": "^5.0.0" + "playwright-core": "^1.40.1", + "rimraf": "^5.0.5" }, "files": [ "dist", diff --git a/packages/e2e-test-kit/src/project-runner.ts b/packages/e2e-test-kit/src/project-runner.ts index d6902f7272..dbda3953ca 100644 --- a/packages/e2e-test-kit/src/project-runner.ts +++ b/packages/e2e-test-kit/src/project-runner.ts @@ -289,7 +289,9 @@ export class ProjectRunner { names.push(module.identifier().split(/[\\/]/).slice(-2).join('/')); } } - chunkByName[chunk.name] = names; + if (chunk.name) { + chunkByName[chunk.name] = names; + } }); return chunkByName; } diff --git a/packages/e2e-test-kit/src/stylable-project-runner.ts b/packages/e2e-test-kit/src/stylable-project-runner.ts index 4eb66c5a2e..46a2a445aa 100644 --- a/packages/e2e-test-kit/src/stylable-project-runner.ts +++ b/packages/e2e-test-kit/src/stylable-project-runner.ts @@ -5,7 +5,7 @@ export class StylableProjectRunner extends ProjectRunner { const config = super.loadWebpackConfig(); if (config.plugins) { const plugin = config.plugins.find( - (plugin) => plugin.constructor.name === 'StylableWebpackPlugin' + (plugin) => plugin?.constructor.name === 'StylableWebpackPlugin' ); if (plugin) { diff --git a/packages/esbuild/package.json b/packages/esbuild/package.json index 5f553b0889..d1d850ba7a 100644 --- a/packages/esbuild/package.json +++ b/packages/esbuild/package.json @@ -1,23 +1,22 @@ { "name": "@stylable/esbuild", - "version": "5.11.0", + "version": "5.17.0", "description": "Stylable plugin for esbuild", "main": "dist/index.js", "scripts": { "test": "mocha \"dist/test/**/*.spec.js\"" }, "peerDependencies": { - "esbuild": "^0.17.18" + "esbuild": ">=0.17.18" }, "dependencies": { - "@stylable/build-tools": "^5.11.0", - "@stylable/cli": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "decache": "^4.6.1" + "@stylable/build-tools": "^5.17.0", + "@stylable/cli": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "decache": "^4.6.2" }, "files": [ "dist", diff --git a/packages/esbuild/src/build-cache.ts b/packages/esbuild/src/build-cache.ts new file mode 100644 index 0000000000..70040cc00e --- /dev/null +++ b/packages/esbuild/src/build-cache.ts @@ -0,0 +1,55 @@ +import { statSync } from 'fs'; +import type { OnLoadResult } from 'esbuild'; + +// mtimes of known files shared between builds +const fileInfo = new Map(); + +export function buildCache() { + const fileInfoDuringBuild = new Map(); + const cache = new Map(); + const checkCache = (path: string) => { + const cached = cache.get(path); + if (cached) { + const shouldRebuild = cached.watchFiles?.some((path) => { + const num = fileInfo.get(path); + if (num) { + let stat = fileInfoDuringBuild.get(path); + if (stat === undefined) { + try { + stat = statSync(path).mtimeMs; + fileInfoDuringBuild.set(path, stat); + } catch (e) { + fileInfo.delete(path); + return true; + } + } + return stat !== num; + } else { + return true; + } + }); + if (!shouldRebuild) { + return cached; + } + } + return undefined; + }; + const addToCache = (path: string, result: OnLoadResult) => { + cache.set(path, result); + for (const watchFile of result.watchFiles || []) { + if (fileInfo.has(watchFile)) { + continue; + } + fileInfo.set(watchFile, statSync(watchFile).mtimeMs); + } + return result; + }; + const transferBuildInfo = () => { + for (const [key, value] of fileInfoDuringBuild) { + fileInfo.set(key, value); + } + fileInfoDuringBuild.clear(); + }; + + return { checkCache, addToCache, transferBuildInfo }; +} diff --git a/packages/esbuild/src/debug.ts b/packages/esbuild/src/debug.ts new file mode 100644 index 0000000000..92bb4a137f --- /dev/null +++ b/packages/esbuild/src/debug.ts @@ -0,0 +1,53 @@ +const timers: Record = {}; +const counters: Record = {}; + +(globalThis as any).stylable_debug = () => { + console.log('Counters:'); + console.table(counters); + console.log('Timers:'); + console.table(timers); + console.log( + 'Total time:', + Object.values(timers) + .reduce((a, b) => a + b, 0) + .toFixed(2), + 'ms' + ); +}; + +(globalThis as any).stylable_debug_clear = () => { + for (const key of Object.keys(timers)) { + timers[key] = 0; + } + for (const key of Object.keys(counters)) { + counters[key] = 0; + } +}; + +export function wrapDebug(name: string, fn: (...args: T) => R) { + if (process.env.STYLABLE_DEBUG !== 'true') { + return fn; + } + return (...args: T) => { + inc(name); + const stop = start(name); + try { + return fn(...args); + } finally { + stop(); + } + }; +} + +function inc(name: string) { + counters[name] ??= 0; + counters[name]++; +} + +function start(name: string) { + timers[name] ??= 0; + const start = performance.now(); + return () => { + timers[name] += performance.now() - start; + }; +} diff --git a/packages/esbuild/src/plugin-utils.ts b/packages/esbuild/src/plugin-utils.ts new file mode 100644 index 0000000000..491b2c77d2 --- /dev/null +++ b/packages/esbuild/src/plugin-utils.ts @@ -0,0 +1,289 @@ +import { join, isAbsolute } from 'path'; +import decache from 'decache'; +import type { PluginBuild, Metafile } from 'esbuild'; +import type { Stylable, StylableConfig, StylableMeta, StylableResults } from '@stylable/core'; +import type { ESBuildOptions } from './stylable-esbuild-plugin'; +import { packageJsonLookupCache } from '@stylable/node'; +import { sortModulesByDepth, processUrlDependencies } from '@stylable/build-tools'; +import { DiagnosticsMode, emitDiagnostics } from '@stylable/core/dist/index-internal'; +import { parse } from 'postcss'; + +export const namespaces = { + unused: 'stylable-unused', + jsModule: 'stylable-js-module', + css: 'stylable-css', + nativeCss: 'stylable-native-css', +}; +export function lazyDebugPrint() { + if (process.env.STYLABLE_DEBUG !== 'true') { + return; + } + void Promise.resolve().then(() => { + (globalThis as any).stylable_debug(); + (globalThis as any).stylable_debug_clear(); + }); +} +export function debounce void>(fn: T, time: number) { + let timeout: ReturnType; + return (...args: Parameters): void => { + clearTimeout(timeout); + timeout = setTimeout(() => fn(...args), time); + }; +} +export function clearCaches(stylable: Stylable) { + packageJsonLookupCache.clear(); + stylable.initCache(); +} +export function processAssetsStubs(moduleCode: string) { + return moduleCode.replace( + /\\"http:\/\/__stylable_url_asset_(.*?)__\\"/g, + (_$0, $1) => `" + JSON.stringify(__css_asset_${Number($1)}__) + "` + ); +} +export function processAssetsAndApplyStubs( + imports: { from: string; defaultImport?: string }[], + res: StylableResults, + stylable: Stylable +) { + processUrlDependencies({ + meta: res.meta, + rootContext: stylable.projectRoot, + host: { + isAbsolute, + join, + }, + getReplacement: ({ index }) => `http://__stylable_url_asset_${index}__`, + }).forEach((url, i) => { + imports.push({ + from: url, + defaultImport: `__css_asset_${i}__`, + }); + }); +} +export function importsCollector(res: StylableResults) { + const imports: { from: string }[] = []; + const collector = (contextMeta: StylableMeta, absPath: string, hasSideEffects: boolean) => { + if (hasSideEffects) { + if (!absPath.endsWith('.st.css')) { + // pass to the native css loader hook + imports.push({ from: namespaces.nativeCss + `:` + absPath }); + } else { + imports.push({ from: absPath }); + } + } else if (contextMeta === res.meta) { + imports.push({ from: namespaces.unused + `:` + absPath }); + } + }; + return { imports, collector }; +} +export function enableEsbuildMetafile(build: PluginBuild, cssInjection: string) { + if (cssInjection === 'css') { + if (build.initialOptions.metafile === false) { + console.warn( + "'stylable-esbuild-plugin' requires the 'metafile' configuration option to be enabled for CSS injection. Since it appears to be disabled, we will automatically enable it for you. Please note that this is necessary for proper plugin functionality." + ); + } + build.initialOptions.metafile = true; + } +} +export function buildUsageMapping(metafile: Metafile, stylable: Stylable): OptimizationMapping { + const usageMapping: Record = {}; + const globalMappings: Record> = {}; + const usagesByNamespace: Record< + string, + Set<{ + path: string; + meta: StylableMeta; + }> + > = {}; + for (const [key] of Object.entries(metafile.inputs)) { + if (key.startsWith(namespaces.jsModule)) { + const path = key.replace(namespaces.jsModule + ':', ''); + const meta = stylable.fileProcessor.cache[path]?.value; + if (!meta) { + throw new Error(`build usage mapping failed: meta not found for ${key}`); + } + globalMappings[path] ||= {}; + Object.assign(globalMappings[path], meta.globals); + usagesByNamespace[meta.namespace] ||= new Set(); + usagesByNamespace[meta.namespace].add({ path, meta }); + usageMapping[meta.namespace] = true; + } else if (key.startsWith(namespaces.unused)) { + const meta = + stylable.fileProcessor.cache[key.replace(namespaces.unused + ':', '')].value; + if (!meta) { + throw new Error(`build usage mapping failed: meta not found for ${key}`); + } + // mark unused as false if not already marked as used + usageMapping[meta.namespace] ||= false; + } + } + + for (const [namespace, usage] of Object.entries(usagesByNamespace)) { + if (usage.size > 1) { + throw new Error( + `The namespace '${namespace}' is being used in multiple files. Please review the following file(s) and update them to use a unique namespace:\n${[ + ...usage, + ] + .map((e) => e.path) + .join('\n')}` + ); + } + } + return { usagesByNamespace, usageMapping, globalMappings }; +} +export function esbuildEmitDiagnostics(res: StylableResults, diagnosticsMode: DiagnosticsMode) { + const errors: { pluginName: string; text: string }[] = []; + const warnings: { pluginName: string; text: string }[] = []; + + emitDiagnostics( + { + emitError(e) { + errors.push({ + pluginName: 'stylable', + text: e.message, + }); + }, + emitWarning(e) { + warnings.push({ + pluginName: 'stylable', + text: e.message, + }); + }, + }, + res.meta, + diagnosticsMode, + res.meta.source + ); + return { errors, warnings }; +} +export function applyDefaultOptions(options: ESBuildOptions, prod = true) { + const mode = options.mode ?? (prod ? 'production' : 'development'); + return { + mode, + cssInjection: mode === 'development' ? 'js' : 'css', + diagnosticsMode: 'auto', + stylableConfig: (config: StylableConfig) => config, + configFile: true, + runtimeStylesheetId: mode === 'production' ? 'namespace' : 'module+namespace', + ...options, + devTypes: { + enabled: !!options.devTypes, + srcDir: 'src', + outDir: 'st-types', + dtsSourceMap: true, + ...options.devTypes, + }, + optimize: { + removeUnusedComponents: prod, + ...options.optimize, + }, + } satisfies ESBuildOptions; +} +export function createDecacheRequire(build: PluginBuild) { + const cacheIds = new Set(); + build.onStart(() => { + for (const id of cacheIds) { + decache(id); + } + cacheIds.clear(); + }); + return (id: string) => { + cacheIds.add(id); + return require(id); + }; +} +export function wrapWithDepthMarkers(css: string, depth: number | string, pathId: number) { + return `[stylable-start]{--depth:${depth}; --path: ${pathId};}${css}[stylable-end]{--path:${pathId}}`; +} +export interface OptimizationMapping { + usageMapping?: Record; + globalMappings?: Record>; + usagesByNamespace?: Record< + string, + Set<{ + path: string; + meta: StylableMeta; + }> + >; +} +export function sortMarkersByDepth( + css: string, + stylable: Stylable, + idForMap: IdForPath, + { usageMapping, globalMappings }: OptimizationMapping +) { + const extracted: { depth: number; css: string; path: string }[] = []; + const leftOverCss = css.replace( + /(\/\* stylable-?\w*?-css:[\s\S]*?\*\/[\s\S]*?)?\[stylable-start\][\s\S]*?\{[\s\S]*?--depth:[\s\S]*?(\d+)[\s]*;[\s\S]*?--path:[\s\S]*?(\d+)[\s\S]*?;?\}([\s\S]*?)\[stylable-end\][\s\S]*?\{[\s\S]*?--path:[\s\S]*?\d+[\s\S]*?\}/g, + (...args) => { + const { 1: esbuildComment, 2: depth, 3: pathId, 4: css } = args; + extracted.push({ + depth: parseInt(depth, 10), + css: (esbuildComment || '') + css, + path: idForMap.getPath(parseInt(pathId, 10)) || '', + }); + return ''; + } + ); + + const sorted = sortModulesByDepth( + extracted, + (m) => m.depth, + (_) => '', + -1 + ); + + return ( + leftOverCss.trimStart() + + sorted + .map((m) => + usageMapping && globalMappings + ? removeUnusedComponents(m.css, stylable, usageMapping, globalMappings[m.path]) + : m.css + ) + .join('') + ); +} + +export class IdForPath { + private idToPath = new Map(); + private pathToId = new Map(); + getId(path: string) { + if (!this.pathToId.has(path)) { + const id = this.pathToId.size; + this.pathToId.set(path, id); + this.idToPath.set(id, path); + } + return this.pathToId.get(path)!; + } + getPath(id: number) { + return this.idToPath.get(id); + } +} + +const stubExports = { + classes: {}, + containers: {}, + keyframes: {}, + vars: {}, + layers: {}, + stVars: {}, +}; +function removeUnusedComponents( + css: string, + stylable: Stylable, + usageMapping: Record, + // global mapping per stylable meta + globalMappings: Record +) { + const ast = parse(css); + stylable.optimizer?.optimizeAst( + { removeUnusedComponents: true }, + ast, + usageMapping, + stubExports, + globalMappings + ); + return ast.toString(); +} diff --git a/packages/esbuild/src/stylable-esbuild-plugin.ts b/packages/esbuild/src/stylable-esbuild-plugin.ts index d65356cc90..f503786744 100644 --- a/packages/esbuild/src/stylable-esbuild-plugin.ts +++ b/packages/esbuild/src/stylable-esbuild-plugin.ts @@ -1,26 +1,37 @@ import fs, { readFileSync, writeFileSync } from 'fs'; import { relative, join, isAbsolute, dirname } from 'path'; -import decache from 'decache'; -import type { Plugin, PluginBuild, Metafile } from 'esbuild'; -import { Stylable, StylableConfig, StylableMeta, StylableResults } from '@stylable/core'; +import type { Plugin, PluginBuild } from 'esbuild'; +import { + Stylable, + StylableConfig, + StylableResults, + generateStylableJSModuleSource, +} from '@stylable/core'; import { StylableOptimizer } from '@stylable/optimizer'; import { resolveNamespace as resolveNamespaceNode } from '@stylable/node'; -import { generateStylableJSModuleSource } from '@stylable/module-utils'; -import { - sortModulesByDepth, - collectImportsWithSideEffects, - processUrlDependencies, -} from '@stylable/build-tools'; +import { collectImportsWithSideEffects } from '@stylable/build-tools'; import { resolveConfig, buildDTS } from '@stylable/cli'; -import { DiagnosticsMode, emitDiagnostics } from '@stylable/core/dist/index-internal'; -import { parse } from 'postcss'; - -const namespaces = { - unused: 'stylable-unused', - jsModule: 'stylable-js-module', - css: 'stylable-css', - nativeCss: 'stylable-native-css', -}; +import type { DiagnosticsMode } from '@stylable/core/dist/index-internal'; +import { buildCache } from './build-cache'; +import { wrapDebug } from './debug'; +import { + applyDefaultOptions, + debounce, + clearCaches, + enableEsbuildMetafile, + createDecacheRequire, + namespaces, + esbuildEmitDiagnostics, + importsCollector, + processAssetsAndApplyStubs, + processAssetsStubs, + wrapWithDepthMarkers, + lazyDebugPrint, + OptimizationMapping, + buildUsageMapping, + sortMarkersByDepth, + IdForPath, +} from './plugin-utils'; export interface ESBuildOptions { /** @@ -88,6 +99,10 @@ export const stylablePlugin = (initialPluginOptions: ESBuildOptions = {}): Plugi optimize, devTypes, } = applyDefaultOptions(initialPluginOptions); + // we need a cache instance per stylable config. + const { checkCache, addToCache, transferBuildInfo } = buildCache(); + + const lazyClearCaches = debounce(clearCaches, 1000); enableEsbuildMetafile(build, cssInjection); @@ -112,465 +127,258 @@ export const stylablePlugin = (initialPluginOptions: ESBuildOptions = {}): Plugi }, build ); - + let onLoadCalled = false; const stylable = new Stylable(stConfig); - // Order of onResolve hooks matters - - build.onStart(() => { - stylable.initCache(); - }); + const idForPath = new IdForPath(); /** * make all unused imports resolve to a special empty js module */ - build.onResolve({ filter: /^stylable-unused:/, namespace: namespaces.jsModule }, (args) => { - return { - path: stylable.resolvePath( - args.resolveDir, - args.path.replace(namespaces.unused + `:`, '') - ), - namespace: namespaces.unused, - }; - }); + build.onResolve( + { filter: /^stylable-unused:/, namespace: namespaces.jsModule }, + wrapDebug('onResolve unused', (args) => { + return { + path: args.path.replace(namespaces.unused + `:`, ''), + namespace: namespaces.unused, + }; + }) + ); /** * handle css/stylable files imported via other stylable files */ - build.onResolve({ filter: /\.css$/, namespace: namespaces.jsModule }, (args) => { - // stylable file generated JavaScript module import self CSS source - if (args.path === args.importer) { + build.onResolve( + { filter: /\.css$/, namespace: namespaces.jsModule }, + wrapDebug('onResolve from stylable js module', (args) => { + // stylable file generated JavaScript module import self CSS source + if (args.path === args.importer) { + return { + path: args.path, + pluginData: args.pluginData, + namespace: namespaces.css, + }; + } + // dependency import of stylable files js module return { - path: args.path, + path: args.path.replace(namespaces.nativeCss + `:`, ''), + namespace: cssInjection === 'css' ? namespaces.nativeCss : namespaces.jsModule, pluginData: args.pluginData, - namespace: namespaces.css, }; - } - // dependency import of stylable files js module - return { - path: stylable.resolvePath( - args.resolveDir, - args.path.replace(namespaces.nativeCss + `:`, '') - ), - namespace: cssInjection === 'css' ? namespaces.nativeCss : namespaces.jsModule, - pluginData: args.pluginData, - }; - }); + }) + ); /** * handle all initial stylable requests from javascript */ - build.onResolve({ filter: /\.st\.css$/ }, (args) => { - return { - path: stylable.resolvePath(args.resolveDir, args.path), - namespace: namespaces.jsModule, - }; - }); + build.onResolve( + { filter: /\.st\.css$/ }, + wrapDebug('onResolve initial requests from js', (args) => { + return { + path: stylable.resolvePath(args.resolveDir, args.path), + namespace: namespaces.jsModule, + }; + }) + ); /** * main loader for stylable files * this flow will create the Stylable JS modules */ - build.onLoad({ filter: /.*/, namespace: namespaces.jsModule }, (args) => { - const res = stylable.transform(args.path); - const { errors, warnings } = esbuildEmitDiagnostics(res, diagnosticsMode); - const { imports, collector } = importsCollector(res); - const { cssDepth = 0, deepDependencies } = res.meta.transformCssDepth!; - const getModuleId = () => { - switch (runtimeStylesheetId) { - case 'module': - return relative(stylable.projectRoot, args.path); - case 'namespace': - return res.meta.namespace; - case 'module+namespace': - return `${relative(stylable.projectRoot, args.path)}|${res.meta.namespace}`; - default: - throw new Error(`Unknown runtimeStylesheetId: ${runtimeStylesheetId}`); + build.onLoad( + { filter: /.*/, namespace: namespaces.jsModule }, + wrapDebug('onLoad stylable module', (args) => { + const cacheResults = checkCache(args.path); + if (cacheResults) { + return cacheResults; } - }; - - collectImportsWithSideEffects(stylable, res.meta, collector); + onLoadCalled = true; + + const res = stylable.transform(args.path); + const { errors, warnings } = esbuildEmitDiagnostics(res, diagnosticsMode); + const { imports, collector } = importsCollector(res); + const { cssDepth = 0, deepDependencies } = res.meta.transformCssDepth!; + const getModuleId = () => { + switch (runtimeStylesheetId) { + case 'module': + return relative(stylable.projectRoot, args.path); + case 'namespace': + return res.meta.namespace; + case 'module+namespace': + return `${relative(stylable.projectRoot, args.path)}|${ + res.meta.namespace + }`; + default: + throw new Error(`Unknown runtimeStylesheetId: ${runtimeStylesheetId}`); + } + }; - if (cssInjection === 'js') { - processAssetsAndApplyStubs(imports, res, stylable); - } + collectImportsWithSideEffects(stylable, res.meta, collector); - if (cssInjection === 'css') { - imports.push({ - from: args.path, - }); - } + if (cssInjection === 'js') { + processAssetsAndApplyStubs(imports, res, stylable); + } - const moduleCode = generateStylableJSModuleSource( - { - imports, - namespace: res.meta.namespace, - jsExports: res.exports, - moduleType: 'esm', - runtimeRequest: '@stylable/runtime/esm/pure', - }, - cssInjection === 'js' - ? { - css: res.meta.targetAst!.toString(), - depth: cssDepth, - runtimeId: 'esbuild', - id: getModuleId(), - } - : undefined - ); + if (cssInjection === 'css') { + imports.push({ + from: args.path, + }); + } - return { - errors, - warnings, - watchFiles: [args.path, ...deepDependencies], - resolveDir: '.', - contents: cssInjection === 'js' ? processStubs(moduleCode) : moduleCode, - pluginData: { stylableResults: res }, - }; - }); + const moduleCode = generateStylableJSModuleSource( + { + imports, + namespace: res.meta.namespace, + jsExports: res.exports, + moduleType: 'esm', + runtimeRequest: '@stylable/runtime/esm/pure', + }, + cssInjection === 'js' + ? { + css: res.meta.targetAst!.toString(), + depth: cssDepth, + runtimeId: 'esbuild', + id: getModuleId(), + } + : undefined + ); + return addToCache(args.path, { + errors, + warnings, + watchFiles: [args.path, ...deepDependencies], + resolveDir: dirname(args.path), + contents: cssInjection === 'js' ? processAssetsStubs(moduleCode) : moduleCode, + pluginData: { stylableResults: res }, + }); + }) + ); /** * unused stylable imports results in an empty js module */ - build.onLoad({ filter: /.*/, namespace: namespaces.unused }, (args) => { - return { - contents: `/* unused ${JSON.stringify(args.path)} */`, - }; - }); + build.onLoad( + { filter: /.*/, namespace: namespaces.unused }, + wrapDebug('onLoad unused module', (args) => { + return { + contents: `/* unused ${JSON.stringify(args.path)} */`, + }; + }) + ); /** * load css via esbuild native css loader * we need to explicit transform here. the pluginData is for the requester module. * this is the final step for the css content so no pluginData is passed */ - build.onLoad({ filter: /.*/, namespace: namespaces.nativeCss }, (args) => { - const res = stylable.transform(args.path); - const cssDepth = res.meta.transformCssDepth!.cssDepth; - return { - resolveDir: '.', - contents: wrapWithDepthMarkers(res.meta.targetAst!.toString(), cssDepth), - loader: 'css', - }; - }); + build.onLoad( + { filter: /.*/, namespace: namespaces.nativeCss }, + wrapDebug('onLoad native css', (args) => { + const key = namespaces.nativeCss + ':' + args.path; + const cacheResults = checkCache(key); + if (cacheResults) { + return cacheResults; + } + onLoadCalled = true; + const res = stylable.transform(args.path); + const { cssDepth, deepDependencies } = res.meta.transformCssDepth!; + const pathId = idForPath.getId(args.path); + return addToCache(key, { + watchFiles: [args.path, ...deepDependencies], + resolveDir: dirname(args.path), + contents: wrapWithDepthMarkers( + res.meta.targetAst!.toString(), + cssDepth, + pathId + ), + loader: 'css', + }); + }) + ); /** * handle css output of stylable files */ - build.onLoad({ filter: /.*/, namespace: namespaces.css }, (args) => { - const { meta } = args.pluginData.stylableResults as StylableResults; - const { cssDepth = 0 } = meta.transformCssDepth!; - return { - resolveDir: '.', - contents: wrapWithDepthMarkers(meta.targetAst!.toString(), cssDepth), - loader: 'css', - }; - }); + build.onLoad( + { filter: /.*/, namespace: namespaces.css }, + wrapDebug('onLoad css output', (args) => { + const { meta } = args.pluginData.stylableResults as StylableResults; + const { cssDepth = 0 } = meta.transformCssDepth!; + const pathId = idForPath.getId(args.path); + return { + resolveDir: dirname(args.path), + contents: wrapWithDepthMarkers(meta.targetAst!.toString(), cssDepth, pathId), + loader: 'css', + }; + }) + ); /** * process the generated bundle and optimize the css output */ - build.onEnd(({ metafile }) => { - let mapping: OptimizationMapping; - - if (devTypes.enabled) { - if (!metafile) { - throw new Error('metafile is required for css injection'); + build.onEnd( + wrapDebug(`onEnd generate cssInjection: ${cssInjection}`, ({ metafile }) => { + transferBuildInfo(); + if (!onLoadCalled) { + lazyDebugPrint(); + return; } - const absSrcDir = join(projectRoot, devTypes.srcDir); - const absOutDir = join(projectRoot, devTypes.outDir); - - mapping ??= buildUsageMapping(metafile, stylable); - - for (const metaSet of Object.values(mapping.usagesByNamespace!)) { - for (const { meta, path } of metaSet) { - if (path.startsWith(absSrcDir)) { - buildDTS({ - res: { meta, exports: meta.exports! }, - targetFilePath: join(absOutDir, relative(absSrcDir, path)), - outputLogs: [], - sourceFilePath: undefined, - generated: new Set(), - dtsSourceMap: devTypes.dtsSourceMap, - writeFileSync: fs.writeFileSync, - relative, - dirname, - isAbsolute, - }); + onLoadCalled = false; + let mapping: OptimizationMapping; + if (devTypes.enabled) { + if (!metafile) { + throw new Error('metafile is required for css injection'); + } + const absSrcDir = join(projectRoot, devTypes.srcDir); + const absOutDir = join(projectRoot, devTypes.outDir); + + mapping ??= buildUsageMapping(metafile, stylable); + + for (const metaSet of Object.values(mapping.usagesByNamespace!)) { + for (const { meta, path } of metaSet) { + if (path.startsWith(absSrcDir)) { + buildDTS({ + res: { meta, exports: meta.exports! }, + targetFilePath: join(absOutDir, relative(absSrcDir, path)), + outputLogs: [], + sourceFilePath: undefined, + generated: new Set(), + dtsSourceMap: devTypes.dtsSourceMap, + writeFileSync: fs.writeFileSync, + relative, + dirname, + isAbsolute, + }); + } } } } - } - - if (cssInjection === 'css') { - if (!metafile) { - throw new Error('metafile is required for css injection'); - } - mapping ??= buildUsageMapping(metafile, stylable); - for (const distFile of Object.keys(metafile.outputs)) { - if (!distFile.endsWith('.css')) { - continue; + if (cssInjection === 'css') { + if (!metafile) { + throw new Error('metafile is required for css injection'); } - const distFilePath = join(stylable.projectRoot, distFile); + mapping ??= buildUsageMapping(metafile, stylable); - writeFileSync( - distFilePath, - sortMarkersByDepth( - readFileSync(distFilePath, 'utf8'), - stylable, - optimize.removeUnusedComponents ? mapping : {} - ) - ); + for (const distFile of Object.keys(metafile.outputs)) { + if (!distFile.endsWith('.css')) { + continue; + } + const distFilePath = join(stylable.projectRoot, distFile); + + writeFileSync( + distFilePath, + sortMarkersByDepth( + readFileSync(distFilePath, 'utf8'), + stylable, + idForPath, + optimize.removeUnusedComponents ? mapping : {} + ) + ); + } } - } - }); + lazyClearCaches(stylable); + lazyDebugPrint(); + }) + ); }, }); - -function processStubs(moduleCode: string) { - return moduleCode.replace( - /\\"http:\/\/__stylable_url_asset_(.*?)__\\"/g, - (_$0, $1) => `" + JSON.stringify(__css_asset_${Number($1)}__) + "` - ); -} - -function processAssetsAndApplyStubs( - imports: { from: string; defaultImport?: string }[], - res: StylableResults, - stylable: Stylable -) { - processUrlDependencies({ - meta: res.meta, - rootContext: stylable.projectRoot, - host: { - isAbsolute, - join, - }, - getReplacement: ({ index }) => `http://__stylable_url_asset_${index}__`, - }).forEach((url, i) => { - imports.push({ - from: url, - defaultImport: `__css_asset_${i}__`, - }); - }); -} - -function importsCollector(res: StylableResults) { - const imports: { from: string }[] = []; - const collector = (contextMeta: StylableMeta, absPath: string, hasSideEffects: boolean) => { - if (hasSideEffects) { - if (!absPath.endsWith('.st.css')) { - // pass to the native css loader hook - imports.push({ from: namespaces.nativeCss + `:` + absPath }); - } else { - imports.push({ from: absPath }); - } - } else if (contextMeta === res.meta) { - imports.push({ from: namespaces.unused + `:` + absPath }); - } - }; - return { imports, collector }; -} - -function enableEsbuildMetafile(build: PluginBuild, cssInjection: string) { - if (cssInjection === 'css') { - if (build.initialOptions.metafile === false) { - console.warn( - "'stylable-esbuild-plugin' requires the 'metafile' configuration option to be enabled for CSS injection. Since it appears to be disabled, we will automatically enable it for you. Please note that this is necessary for proper plugin functionality." - ); - } - build.initialOptions.metafile = true; - } -} - -function buildUsageMapping(metafile: Metafile, stylable: Stylable): OptimizationMapping { - const usageMapping: Record = {}; - const globalMappings: Record> = {}; - const usagesByNamespace: Record< - string, - Set<{ - path: string; - meta: StylableMeta; - }> - > = {}; - for (const [key] of Object.entries(metafile.inputs)) { - if (key.startsWith(namespaces.jsModule)) { - const path = key.replace(namespaces.jsModule + ':', ''); - const meta = stylable.fileProcessor.cache[path]?.value; - if (!meta) { - throw new Error(`build usage mapping failed: meta not found for ${key}`); - } - globalMappings[path] ||= {}; - Object.assign(globalMappings[path], meta.globals); - usagesByNamespace[meta.namespace] ||= new Set(); - usagesByNamespace[meta.namespace].add({ path, meta }); - usageMapping[meta.namespace] = true; - } else if (key.startsWith(namespaces.unused)) { - const meta = - stylable.fileProcessor.cache[key.replace(namespaces.unused + ':', '')].value; - if (!meta) { - throw new Error(`build usage mapping failed: meta not found for ${key}`); - } - // mark unused as false if not already marked as used - usageMapping[meta.namespace] ||= false; - } - } - - for (const [namespace, usage] of Object.entries(usagesByNamespace)) { - if (usage.size > 1) { - throw new Error( - `The namespace '${namespace}' is being used in multiple files. Please review the following file(s) and update them to use a unique namespace:\n${[ - ...usage, - ] - .map((e) => e.path) - .join('\n')}` - ); - } - } - return { usagesByNamespace, usageMapping, globalMappings }; -} - -function esbuildEmitDiagnostics(res: StylableResults, diagnosticsMode: DiagnosticsMode) { - const errors: { pluginName: string; text: string }[] = []; - const warnings: { pluginName: string; text: string }[] = []; - - emitDiagnostics( - { - emitError(e) { - errors.push({ - pluginName: 'stylable', - text: e.message, - }); - }, - emitWarning(e) { - warnings.push({ - pluginName: 'stylable', - text: e.message, - }); - }, - }, - res.meta, - diagnosticsMode, - res.meta.source - ); - return { errors, warnings }; -} - -function applyDefaultOptions(options: ESBuildOptions, prod = true) { - const mode = options.mode ?? (prod ? 'production' : 'development'); - return { - mode, - cssInjection: mode === 'development' ? 'js' : 'css', - diagnosticsMode: 'auto', - stylableConfig: (config: StylableConfig) => config, - configFile: true, - runtimeStylesheetId: mode === 'production' ? 'namespace' : 'module+namespace', - ...options, - devTypes: { - enabled: !!options.devTypes, - srcDir: 'src', - outDir: 'st-types', - dtsSourceMap: true, - ...options.devTypes, - }, - optimize: { - removeUnusedComponents: prod, - ...options.optimize, - }, - } satisfies ESBuildOptions; -} - -function createDecacheRequire(build: PluginBuild) { - const cacheIds = new Set(); - build.onStart(() => { - for (const id of cacheIds) { - decache(id); - } - cacheIds.clear(); - }); - return (id: string) => { - cacheIds.add(id); - return require(id); - }; -} - -function wrapWithDepthMarkers(css: string, depth: number | string) { - return `[stylable-depth]{--depth:${depth}}${css}[stylable-depth]{--end:${depth}}`; -} - -interface OptimizationMapping { - usageMapping?: Record; - globalMappings?: Record>; - usagesByNamespace?: Record< - string, - Set<{ - path: string; - meta: StylableMeta; - }> - >; -} - -function sortMarkersByDepth( - css: string, - stylable: Stylable, - { usageMapping, globalMappings }: OptimizationMapping -) { - const extracted: { depth: number; css: string; path: string }[] = []; - const leftOverCss = css.replace( - /(\/\* stylable-?\w*?-css:[\s\S]*?\*\/[\s\S]*?)?\[stylable-depth\][\s\S]*?\{[\s\S]*?--depth:[\s\S]*?(\d+)[\s\S]*?\}([\s\S]*?)\[stylable-depth\][\s\S]*?\{[\s\S]*?--end:[\s\S]*?\d+[\s\S]*?\}/g, - (...args) => { - const { 1: esbuildComment, 2: depth, 3: css } = args; - extracted.push({ - depth: parseInt(depth, 10), - css: (esbuildComment || '') + css, - path: esbuildComment.match(/\/\* stylable-?\w*?-css:([\s\S]*?)\s*\*\//)?.[1] || '', - }); - return ''; - } - ); - - const sorted = sortModulesByDepth( - extracted, - (m) => m.depth, - (m) => m.path, - -1 - ); - - return ( - leftOverCss.trimStart() + - sorted - .map((m) => - usageMapping && globalMappings - ? removeUnusedComponents(m.css, stylable, usageMapping, globalMappings[m.path]) - : m.css - ) - .join('') - ); -} - -const stubExports = { - classes: {}, - containers: {}, - keyframes: {}, - vars: {}, - layers: {}, - stVars: {}, -}; - -function removeUnusedComponents( - css: string, - stylable: Stylable, - usageMapping: Record, - // global mapping per stylable meta - globalMappings: Record -) { - const ast = parse(css); - stylable.optimizer?.optimizeAst( - { removeUnusedComponents: true }, - ast, - usageMapping, - stubExports, - globalMappings - ); - return ast.toString(); -} diff --git a/packages/esbuild/src/tsconfig.json b/packages/esbuild/src/tsconfig.json index 59c8cb4f07..83f24b5830 100644 --- a/packages/esbuild/src/tsconfig.json +++ b/packages/esbuild/src/tsconfig.json @@ -7,7 +7,6 @@ { "path": "../../core/src" }, { "path": "../../cli/src" }, { "path": "../../node/src" }, - { "path": "../../module-utils/src" }, { "path": "../../optimizer/src" } ] } diff --git a/packages/esbuild/test/e2e/duplicate-namespace/a.st.css b/packages/esbuild/test/e2e/duplicate-namespace/a.st.css index 3acc0c6974..e66882a45e 100644 --- a/packages/esbuild/test/e2e/duplicate-namespace/a.st.css +++ b/packages/esbuild/test/e2e/duplicate-namespace/a.st.css @@ -1,3 +1,3 @@ -@namespace "X"; +@st-namespace "X"; -/* st-namespace-reference="x" */ \ No newline at end of file +/* st-namespace-reference="x" */ diff --git a/packages/esbuild/test/e2e/duplicate-namespace/b.st.css b/packages/esbuild/test/e2e/duplicate-namespace/b.st.css index 3acc0c6974..e66882a45e 100644 --- a/packages/esbuild/test/e2e/duplicate-namespace/b.st.css +++ b/packages/esbuild/test/e2e/duplicate-namespace/b.st.css @@ -1,3 +1,3 @@ -@namespace "X"; +@st-namespace "X"; -/* st-namespace-reference="x" */ \ No newline at end of file +/* st-namespace-reference="x" */ diff --git a/packages/esbuild/test/e2e/esbuild-testkit.ts b/packages/esbuild/test/e2e/esbuild-testkit.ts index ee34a4af4c..bd1b2fc7a1 100644 --- a/packages/esbuild/test/e2e/esbuild-testkit.ts +++ b/packages/esbuild/test/e2e/esbuild-testkit.ts @@ -20,10 +20,12 @@ export class ESBuildTestKit { project, buildExport, tmp = true, + overrideOptions = {}, }: { project: string; buildExport?: string; tmp?: boolean; + overrideOptions?: BuildOptions; }) { let openServerUrl: string | undefined; let buildFile = require.resolve(`@stylable/esbuild/test/e2e/${project}/build.js`); @@ -62,6 +64,7 @@ export class ESBuildTestKit { format: 'esm', target: ['es2020'], bundle: true, + ...overrideOptions, })); this.disposables.push(() => buildContext.dispose()); diff --git a/packages/esbuild/test/e2e/simple-case/a.st.css b/packages/esbuild/test/e2e/simple-case/a.st.css index 2e4338278f..84803ddea1 100644 --- a/packages/esbuild/test/e2e/simple-case/a.st.css +++ b/packages/esbuild/test/e2e/simple-case/a.st.css @@ -1,6 +1,7 @@ +@test-marker a.st.css|a; @st-import Imported from './imported-only-from-css.st.css'; .root { -st-extends: Imported; color: red; -} \ No newline at end of file +} diff --git a/packages/esbuild/test/e2e/simple-case/b.st.css b/packages/esbuild/test/e2e/simple-case/b.st.css index d910f3843d..e4d8a609e5 100644 --- a/packages/esbuild/test/e2e/simple-case/b.st.css +++ b/packages/esbuild/test/e2e/simple-case/b.st.css @@ -1,3 +1,4 @@ +@test-marker b.st.css|b; @st-import Deep from "./deep.st.css"; @st-import "./side-effects.st.css"; @st-import themeColor from "./theme-color.js"; @@ -11,4 +12,4 @@ .root Deep { --unused-deep: override-active; -} \ No newline at end of file +} diff --git a/packages/esbuild/test/e2e/simple-case/index.js b/packages/esbuild/test/e2e/simple-case/index.js index 0f41269873..6721a8bcd5 100644 --- a/packages/esbuild/test/e2e/simple-case/index.js +++ b/packages/esbuild/test/e2e/simple-case/index.js @@ -1,8 +1,10 @@ import { classes as classesA } from './a.st.css'; import { classes as classesB } from './b.st.css'; +import { classes as classesInternalDir } from './internal-dir/internal-dir.st.css'; document.body.className = classesA.root + ' ' + classesB.root; document.body.textContent = 'This color should be green'; document.body.appendChild(createDeepElementWithoutInputDeepCss()); +document.body.appendChild(createTestElement()); function createDeepElementWithoutInputDeepCss() { const element = document.createElement('div'); @@ -10,3 +12,10 @@ function createDeepElementWithoutInputDeepCss() { element.textContent = 'This element should not have --unused-deep variable'; return element; } + +function createTestElement() { + const element = document.createElement('div'); + element.className = classesInternalDir.root; + element.textContent = 'This element should have purple stylable logo background'; + return element; +} diff --git a/packages/esbuild/test/e2e/simple-case/internal-dir/internal-dir.png b/packages/esbuild/test/e2e/simple-case/internal-dir/internal-dir.png new file mode 100644 index 0000000000..d2479007ac Binary files /dev/null and b/packages/esbuild/test/e2e/simple-case/internal-dir/internal-dir.png differ diff --git a/packages/esbuild/test/e2e/simple-case/internal-dir/internal-dir.st.css b/packages/esbuild/test/e2e/simple-case/internal-dir/internal-dir.st.css new file mode 100644 index 0000000000..b3e7bdd0db --- /dev/null +++ b/packages/esbuild/test/e2e/simple-case/internal-dir/internal-dir.st.css @@ -0,0 +1,5 @@ +@test-marker internal-dir.st.css|internaldir; + +.root { + background: url('./internal-dir.png'); +} diff --git a/packages/esbuild/test/e2e/simple-case/reset.css b/packages/esbuild/test/e2e/simple-case/reset.css index 59fd9cceb8..3e212e2be0 100644 --- a/packages/esbuild/test/e2e/simple-case/reset.css +++ b/packages/esbuild/test/e2e/simple-case/reset.css @@ -1,5 +1,7 @@ +@test-marker reset.css|reset; + body { --reset: true; margin: 0; padding: 0; -} \ No newline at end of file +} diff --git a/packages/esbuild/test/e2e/simple-case/side-effects.st.css b/packages/esbuild/test/e2e/simple-case/side-effects.st.css index 3a20c202af..bd20988bf9 100644 --- a/packages/esbuild/test/e2e/simple-case/side-effects.st.css +++ b/packages/esbuild/test/e2e/simple-case/side-effects.st.css @@ -1,7 +1,8 @@ +@test-marker side-effects.st.css|sideeffects; @property st-global(--side-effects); :global(body) { font-size: 100px; --side-effects: true; background: url(./asset.png); -} \ No newline at end of file +} diff --git a/packages/esbuild/test/e2e/simple-case/simple-case.spec.ts b/packages/esbuild/test/e2e/simple-case/simple-case.spec.ts index fcf0957f7e..00498cefcb 100644 --- a/packages/esbuild/test/e2e/simple-case/simple-case.spec.ts +++ b/packages/esbuild/test/e2e/simple-case/simple-case.spec.ts @@ -1,6 +1,7 @@ import { expect } from 'chai'; import { ESBuildTestKit } from '../esbuild-testkit'; import type { Page, Response } from 'playwright-core'; +import { sep } from 'node:path'; /** * This is the expected order of the stylesheets in the DOM @@ -8,16 +9,29 @@ import type { Page, Response } from 'playwright-core'; */ const stylesInOrder = [ { - st_id: 'reset.css|reset', + path: 'reset.css', + fileName: 'reset.css', + namespace: 'reset', }, { - st_id: 'side-effects.st.css|sideeffects', + path: 'side-effects.st.css', + fileName: 'side-effects.st.css', + namespace: 'sideeffects', }, { - st_id: 'a.st.css|a', + path: `internal-dir${sep}internal-dir.st.css`, + fileName: 'internal-dir.st.css', + namespace: 'internaldir', }, { - st_id: 'b.st.css|b', + path: 'a.st.css', + fileName: 'a.st.css', + namespace: 'a', + }, + { + path: 'b.st.css', + fileName: 'b.st.css', + namespace: 'b', }, ]; @@ -34,7 +48,7 @@ describe('Stylable ESBuild plugin', () => { const { open } = await tk.build({ project: 'simple-case', buildExport: 'cssInJsDev' }); await contract( await open({}, 'index.html', true), - stylesInOrder, + stylesInOrder.map(({ path, namespace }) => ({ st_id: `${path}|${namespace}` })), `"class extending component '.root => .b__root' in stylesheet 'b.st.css' was set on a node that does not extend '.root => .deep__root' from stylesheet 'deep.st.css'"`, 'override-active' ); @@ -49,11 +63,29 @@ describe('Stylable ESBuild plugin', () => { const css = read('dist-bundle/index.css'); const matchOrder = new RegExp( - stylesInOrder.map(({ st_id }) => escapeRegExp(st_id.split('|')[0])).join('[\\s\\S]*?') + stylesInOrder.map(({ fileName }) => escapeRegExp(fileName)).join('[\\s\\S]*?') ); expect(css).to.match(matchOrder); }); + + it('should build a project with a bundle (minify)', async () => { + const { open, read } = await tk.build({ + project: 'simple-case', + buildExport: 'cssBundleProd', + overrideOptions: { + minify: true, + }, + }); + await contract(await open({}, 'index.bundle.html', true), [], 'none', 'override-removed'); + + const css = read('dist-bundle/index.css'); + + const matchOrder = new RegExp( + stylesInOrder.map(({ fileName }) => escapeRegExp(fileName)).join('[\\s\\S]*?') + ); + expect(css).to.match(matchOrder); + }); }); function escapeRegExp(string: string) { @@ -83,9 +115,11 @@ async function contract( ).getPropertyValue('--unused-deep'), }; }); - + const assetLoaded = Boolean(responses?.find((r) => r.url().match(/asset-.*?\.png$/))); + const internalDirAsset = Boolean(responses?.find((r) => r.url().match(/internal-dir-.*?\.png$/))); + expect(internalDirAsset, 'asset loaded from internal dir').to.eql(true); expect(assetLoaded, 'asset loaded').to.eql(true); expect(reset, 'reset applied').to.eql('true'); expect(sideEffects, 'side effects loaded').to.eql('true'); diff --git a/packages/eslint-plugin-stylable/package.json b/packages/eslint-plugin-stylable/package.json index 7f79f57fb0..3f6b855683 100644 --- a/packages/eslint-plugin-stylable/package.json +++ b/packages/eslint-plugin-stylable/package.json @@ -1,14 +1,14 @@ { "name": "eslint-plugin-stylable", - "version": "5.11.0", + "version": "5.17.0", "description": "eslint plugin for Stylable usages", "main": "dist/index.js", "scripts": { "test": "mocha \"dist/test/**/*.spec.js\" --timeout 5000" }, "dependencies": { - "@stylable/core": "^5.11.0", - "@typescript-eslint/experimental-utils": "^5.59.2" + "@stylable/core": "^5.17.0", + "@typescript-eslint/utils": "^5.61.0" }, "keywords": [ "eslint", diff --git a/packages/eslint-plugin-stylable/src/stylable-es-lint.ts b/packages/eslint-plugin-stylable/src/stylable-es-lint.ts index c9f0656bea..1c331fcc4d 100644 --- a/packages/eslint-plugin-stylable/src/stylable-es-lint.ts +++ b/packages/eslint-plugin-stylable/src/stylable-es-lint.ts @@ -7,7 +7,7 @@ import { AST_NODE_TYPES, ASTUtils, TSESTree as esTree, -} from '@typescript-eslint/experimental-utils'; +} from '@typescript-eslint/utils'; const { isIdentifier } = ASTUtils; diff --git a/packages/eslint-plugin-stylable/test/stylable-es-lint.spec.ts b/packages/eslint-plugin-stylable/test/stylable-es-lint.spec.ts index 8b0adabc0e..ba48df3212 100644 --- a/packages/eslint-plugin-stylable/test/stylable-es-lint.spec.ts +++ b/packages/eslint-plugin-stylable/test/stylable-es-lint.spec.ts @@ -1,6 +1,6 @@ import path from 'path'; import fs from 'fs'; -import { ESLintUtils } from '@typescript-eslint/experimental-utils'; +import { ESLintUtils } from '@typescript-eslint/utils'; import StylableLint from 'eslint-plugin-stylable/dist/stylable-es-lint'; import { createTempDirectorySync } from '@stylable/e2e-test-kit'; diff --git a/packages/experimental-loader/package.json b/packages/experimental-loader/package.json index faba5e53d3..c9e7622683 100644 --- a/packages/experimental-loader/package.json +++ b/packages/experimental-loader/package.json @@ -1,15 +1,15 @@ { "name": "@stylable/experimental-loader", - "version": "5.11.0", + "version": "5.17.0", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\" --timeout 20000" }, "dependencies": { - "@stylable/core": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "css-loader": "^6.7.3", - "decache": "^4.6.1", + "@stylable/core": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "css-loader": "^6.8.1", + "decache": "^4.6.2", "loader-utils": "^3.2.1" }, "files": [ diff --git a/packages/experimental-loader/src/add-build-info.ts b/packages/experimental-loader/src/add-build-info.ts index 65bde7a3be..9227aa479a 100644 --- a/packages/experimental-loader/src/add-build-info.ts +++ b/packages/experimental-loader/src/add-build-info.ts @@ -2,7 +2,7 @@ import type { LoaderContext } from 'webpack'; export function addBuildInfo(ctx: LoaderContext, namespace: string) { try { - ctx._module!.buildInfo.stylableNamespace = namespace; + (ctx._module!.buildInfo as any).stylableNamespace = namespace; } catch (error) { ctx.emitWarning( new Error( diff --git a/packages/experimental-loader/test/testkit/manifest-plugin.ts b/packages/experimental-loader/test/testkit/manifest-plugin.ts index 9a19366dba..c7b6e43d8e 100644 --- a/packages/experimental-loader/test/testkit/manifest-plugin.ts +++ b/packages/experimental-loader/test/testkit/manifest-plugin.ts @@ -12,16 +12,13 @@ export class TestManifestPlugin { const data: Record = {}; for (const module of compilation.modules) { if (isNormalModule(module) && module.resource.endsWith('.st.css')) { - const { - resource, - buildInfo: { stylableNamespace }, - } = module; + const stylableNamespace = module.buildInfo?.stylableNamespace; if (!stylableNamespace) { throw new Error('No stylableNamespace found in buildInfo'); } - data[relative(compiler.context, resource)] = stylableNamespace; + data[relative(compiler.context, module.resource)] = stylableNamespace; } } diff --git a/packages/jest/package.json b/packages/jest/package.json index d4c2051eec..7def5bd528 100644 --- a/packages/jest/package.json +++ b/packages/jest/package.json @@ -1,16 +1,16 @@ { "name": "@stylable/jest", - "version": "5.11.0", + "version": "5.17.0", "description": "Test your Stylable React components using Jest", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\"" }, "dependencies": { - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/runtime": "^5.11.0" + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/runtime": "^5.17.0" }, "files": [ "dist", diff --git a/packages/language-service/package.json b/packages/language-service/package.json index e62ce0c202..f6eacb9a97 100644 --- a/packages/language-service/package.json +++ b/packages/language-service/package.json @@ -1,6 +1,6 @@ { "name": "@stylable/language-service", - "version": "5.11.0", + "version": "5.17.0", "description": "Stylable Language Services - syntax highlighting, completions, hinting and more for the Stylable CSS preprocessor.", "main": "dist/index.js", "scripts": { @@ -11,20 +11,20 @@ "typescript": ">=3.8" }, "dependencies": { - "@file-services/types": "^7.2.5", - "@file-services/typescript": "^7.2.5", - "@stylable/code-formatter": "^5.11.0", - "@stylable/core": "^5.11.0", - "@tokey/core": "^1.3.0", - "@tokey/css-selector-parser": "^0.6.1", - "@tokey/css-value-parser": "^0.1.2", + "@file-services/types": "^8.3.3", + "@file-services/typescript": "^8.3.3", + "@stylable/code-formatter": "^5.17.0", + "@stylable/core": "^5.17.0", + "@tokey/core": "^1.4.0", + "@tokey/css-selector-parser": "^0.6.2", + "@tokey/css-value-parser": "^0.1.4", "css-selector-tokenizer": "^0.8.0", - "postcss": "^8.4.23", + "postcss": "^8.4.32", "postcss-value-parser": "^4.2.0", - "vscode-css-languageservice": "^6.2.5", - "vscode-languageserver": "^8.1.0", - "vscode-languageserver-textdocument": "^1.0.8", - "vscode-uri": "^3.0.7" + "vscode-css-languageservice": "^6.2.11", + "vscode-languageserver": "^9.0.1", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-uri": "^3.0.8" }, "author": "Wix.com", "files": [ diff --git a/packages/language-service/src/lib-new/ast-from-position.ts b/packages/language-service/src/lib-new/ast-from-position.ts index 8b0408cfbf..34cf3ddeca 100644 --- a/packages/language-service/src/lib-new/ast-from-position.ts +++ b/packages/language-service/src/lib-new/ast-from-position.ts @@ -39,7 +39,6 @@ export type AstLocation = | 'atRuleBody' | 'declProp' | 'declBetweenPropAndColon' - | 'declBetweenColonAndValue' | 'declValue' | 'invalid'; } @@ -56,7 +55,6 @@ export type AstLocation = node: CSSValue.BaseAstNode | CSSValue.BaseAstNode[]; offsetInNode: number; parents: NodeType[]; - afterValue: boolean; } | { type: 'atRuleParams'; @@ -64,7 +62,6 @@ export type AstLocation = node: CSSValue.BaseAstNode | CSSValue.BaseAstNode[]; offsetInNode: number; parents: NodeType[]; - afterValue: boolean; }; export interface AstLocationResult { base: AstLocation & { type: 'base' }; @@ -74,7 +71,7 @@ export interface AstLocationResult { } function isClosed(node: postcss.AnyNode) { const isLast = node.parent && node.parent.nodes[node.parent.nodes.length - 1] === node; - if (node.type === 'decl') { + if (node.type === 'decl' || (node.type === 'atrule' && !node.nodes)) { return isLast ? node.parent?.raws.semicolon : true; } return true; @@ -237,30 +234,38 @@ function checkRuleSelector( } function checkDeclValue(node: postcss.AnyNode, checkContext: CheckContext) { if (isDeclaration(node)) { - const between = node.raws.between!; - const valueStart = checkContext.baseNodeOffset + node.prop.length + between.length; - const valueEnd = valueStart + node.value.length; + const { between = '', value: rawsValue } = node.raws; + const colon = between.slice(0, between.indexOf(':') + 1); + const afterColon = between.slice(colon.length); + const valueStart = checkContext.baseNodeOffset + node.prop.length + colon.length; + // ToDo: "where=declImportant" + const parentNode = node.parent; + const unclosedDeclExtraSpace = + parentNode?.nodes[parentNode.nodes.length - 1] === node && !parentNode.raws.semicolon + ? node.parent?.raws.after + : ''; + const valueAfterColon = + afterColon + (rawsValue?.raw ? rawsValue.raw : node.value + unclosedDeclExtraSpace); + const valueEnd = valueStart + valueAfterColon.length; + const ast = CSSValue.parseCSSValue(valueAfterColon); const isInValue = checkValue({ type: 'declValue', - value: node.value, + ast, node, valueStart, valueEnd, - afterSpace: 0, checkContext, }); - let where: typeof base['where'] = 'declValue'; + let where: (typeof base)['where'] = 'declValue'; const base = checkContext.result.base; if (isInValue) { + // prop:| value | where = 'declValue'; } else if (base.offsetInNode > node.prop.length) { - const spaceAfterColon = between.length - between.indexOf(':'); - if (valueStart - spaceAfterColon >= checkContext.targetOffset) { - where = 'declBetweenPropAndColon'; - } else { - where = 'declBetweenColonAndValue'; - } + // prop | |: value + where = 'declBetweenPropAndColon'; } else { + // |prop|: value where = 'declProp'; } base.where = where; @@ -268,88 +273,99 @@ function checkDeclValue(node: postcss.AnyNode, checkContext: CheckContext) { } function checkAtRuleParams(node: postcss.AnyNode, checkContext: CheckContext) { if (isAtRule(node)) { - const valueStart = - checkContext.baseNodeOffset + 1 + node.name.length + node.raws.afterName!.length; - const valueEnd = valueStart + node.params.length; + const AtPrefixLength = 1; + const { afterName = '', between = '' } = node.raws; + const parentNode = node.parent; + const unclosedExtraSpace = + parentNode?.nodes[parentNode.nodes.length - 1] === node && !parentNode.raws.semicolon + ? node.parent?.raws.after + : ''; + const prelude = afterName + node.params + between + unclosedExtraSpace; + const valueStart = checkContext.baseNodeOffset + AtPrefixLength + node.name.length; + const valueEnd = valueStart + prelude.length; + + const ast = CSSValue.parseCSSValue(prelude); + const isInParams = checkValue({ type: 'atRuleParams', - value: node.params, + ast, node, valueStart, valueEnd, - afterSpace: node.raws.between!.length, checkContext, }); - let where: typeof base['where'] = 'declValue'; + let where: (typeof base)['where'] = 'atRuleParams'; const base = checkContext.result.base; if (isInParams) { - where = 'atRuleParams'; + if (checkContext.result.atRuleParams!.offsetInNode === 0) { + // @name| params + where = 'atRuleName'; + } else { + // @name |params| + where = 'atRuleParams'; + } } else if ( checkContext.baseNodeOffset + node.name.length + 1 >= checkContext.targetOffset ) { + // @|nam|e params where = 'atRuleName'; } else { + // @name params { | } where = 'atRuleBody'; } base.where = where; } } function checkValue({ - value, + ast, node, type, valueStart, valueEnd, - afterSpace, - checkContext: { targetOffset, result, afterNodeContent }, + checkContext: { targetOffset, result }, }: { - value: string; + ast: CSSValue.BaseAstNode[]; node: postcss.AnyNode; type: 'atRuleParams' | 'declValue'; valueStart: number; valueEnd: number; - afterSpace: number; checkContext: CheckContext; }) { + /* value | */ const isAfterValue = valueEnd < targetOffset; - const isInIncludedSpace = - afterNodeContent || (isAfterValue && valueEnd + afterSpace >= targetOffset); - if (valueStart > targetOffset || (isAfterValue && !isInIncludedSpace)) { + const isBeforeValue = valueStart > targetOffset; + if (isBeforeValue || isAfterValue) { // not in value return false; } - const ast = CSSValue.parseCSSValue(value); const valueLocation: Extract = { type, ast, node: ast, - offsetInNode: !isInIncludedSpace ? 0 : value.length + targetOffset - valueEnd, + offsetInNode: 0, parents: [node], - afterValue: isInIncludedSpace, }; - if (!isInIncludedSpace) { - walkValue(ast, (node) => { - const isTargetAfterStart = - valueStart + node.start < targetOffset || - (valueStart === targetOffset && node.start === 0); - const isTargetBeforeEnd = valueStart + node.end >= targetOffset; - if (!isTargetAfterStart) { - // value is after the target offset - return walk.stopAll; - } else if (!isTargetBeforeEnd) { - // value ends before target offset - return walk.skipNested; - } - // update - if (!Array.isArray(valueLocation.node)) { - valueLocation.parents.push(valueLocation.node); - } - valueLocation.node = node; - valueLocation.offsetInNode = targetOffset - valueStart - node.start; - return; - }); - } + walkValue(ast, (node) => { + const isTargetAfterStart = + valueStart + node.start < targetOffset || + (valueStart === targetOffset && node.start === 0); + const isTargetBeforeEnd = valueStart + node.end >= targetOffset; + if (!isTargetAfterStart) { + // value is after the target offset + return walk.stopAll; + } else if (!isTargetBeforeEnd) { + // value ends before target offset + return walk.skipNested; + } + // update + if (!Array.isArray(valueLocation.node)) { + valueLocation.parents.push(valueLocation.node); + } + valueLocation.node = node; + valueLocation.offsetInNode = targetOffset - valueStart - node.start; + return; + }); result[type] = valueLocation as any; // ToDo: figure out type issue return true; } @@ -362,7 +378,7 @@ function isPostcssNodeInRange(node: postcss.AnyNode | postcss.Container, target: if (node.source?.start && node.source?.end) { const beforeSize = node.type === 'rule' ? node.raws.before.length : 0; result.nodeStartBeforeCaret = node.source.start.offset - beforeSize <= target; - result.nodeEndsAfterCaret = node.source.end.offset + 1 >= target; + result.nodeEndsAfterCaret = node.source.end.offset >= target; result.isInRange = result.nodeStartBeforeCaret && result.nodeEndsAfterCaret; } return result; diff --git a/packages/language-service/src/lib-new/edit-time-parser.ts b/packages/language-service/src/lib-new/edit-time-parser.ts index 400db65c37..2fade1ae5b 100644 --- a/packages/language-service/src/lib-new/edit-time-parser.ts +++ b/packages/language-service/src/lib-new/edit-time-parser.ts @@ -26,6 +26,7 @@ export function parseForEditing( const input = new postcss.Input(source, { from }); // ToDo: check why stringifier option doesn't work const parser = new EditTimeParser(input); parser.parse(); + parser.closeAstSource(); return { ast: parser.root, errorNodes: parser.errorNodes, @@ -56,6 +57,29 @@ class EditTimeParser extends Parser { createTokenizer() { this.tokenizer = tokenizer(this.input, { ignoreErrors: true }); } + public closeAstSource(node: postcss.Node = this.root) { + if (!node.source!.end) { + const nodes = (node as any).nodes; + // ToDo: add before/between/after values + if (!nodes || nodes.length === 0) { + const startPos = node.source!.start!; + node.source!.end = { + offset: startPos.offset + node.source!.input.css.length, + line: startPos.line, + column: startPos.column, + }; + } else { + const lastNode = nodes[nodes.length - 1]; + this.closeAstSource(lastNode); + const closePos = lastNode.source!.end!; + node.source!.end = { + offset: closePos.offset + (node.raws.after?.length || 0), + line: closePos.line, + column: closePos.column, + }; + } + } + } private reportNode(node: AnyNode, type: 'error' | 'ambiguity', report: string) { const bucket = type === 'error' ? this.errorNodes : this.ambiguousNodes; @@ -71,6 +95,7 @@ class EditTimeParser extends Parser { this.init(node, tokens[0][2]); this.raw(node, 'value', tokens, /* keep spaces*/ true); node.source!.end = this.getPosition(this.getLastOffset(tokens)); + node.source!.end.offset++; this.extendParentEnd(node); return node; } diff --git a/packages/language-service/src/lib-new/features/ls-st-import.ts b/packages/language-service/src/lib-new/features/ls-st-import.ts index caf7b777e2..5d86a95916 100644 --- a/packages/language-service/src/lib-new/features/ls-st-import.ts +++ b/packages/language-service/src/lib-new/features/ls-st-import.ts @@ -6,8 +6,21 @@ import path from 'path'; import { STSymbol } from '@stylable/core/dist/index-internal'; import type { AstLocationResult } from '../ast-from-position'; import type { CSSValueAST } from '@tokey/css-value-parser'; +import type { LangServicePlugin } from '../../lib/completion-providers'; -export function getCompletions(context: LangServiceContext): Completion[] { +export const StImportPlugin: LangServicePlugin = { + analyzeCaretLocation(context) { + const node = context.location.base.node; + if (node.type === 'atrule' && node.name === 'st-import') { + context.flags.runNativeCSSService = false; + } + }, + onCompletion({ context }) { + return getCompletions(context); + }, +}; + +function getCompletions(context: LangServiceContext): Completion[] { const completions: Completion[] = []; const { node } = context.location.base; if (node.type === 'atrule' && node.name === 'st-import') { diff --git a/packages/language-service/src/lib-new/lang-service-context.ts b/packages/language-service/src/lib-new/lang-service-context.ts index 183cd9d0d2..673f4dd630 100644 --- a/packages/language-service/src/lib-new/lang-service-context.ts +++ b/packages/language-service/src/lib-new/lang-service-context.ts @@ -33,6 +33,9 @@ export class LangServiceContext { public ambiguousNodes: Map; public location: ReturnType; public document: TextDocument; + public flags = { + runNativeCSSService: true, + }; constructor( public fs: IFileSystem, public stylable: Stylable, diff --git a/packages/language-service/src/lib/completion-providers.ts b/packages/language-service/src/lib/completion-providers.ts index f81c0bade0..fc18c8c0c2 100644 --- a/packages/language-service/src/lib/completion-providers.ts +++ b/packages/language-service/src/lib/completion-providers.ts @@ -15,9 +15,9 @@ import type { import { nativePseudoElements, ResolvedElement, - STPart, STCustomSelector, STCustomState, + STStructure, } from '@stylable/core/dist/index-internal'; import type { IFileSystem } from '@file-services/types'; import { @@ -48,13 +48,12 @@ import { isInValue, } from './provider'; import type { ExtendedTsLanguageService } from './types'; -import { getAtRuleByPosition, isComment, isDeclaration } from './utils/postcss-ast-utils'; +import { isComment, isDeclaration } from './utils/postcss-ast-utils'; import type { CursorPosition } from './utils/selector-analyzer'; import type { LangServiceContext } from '../lib-new/lang-service-context'; import * as cssPseudoClass from '../lib-new/features/ls-css-pseudo-class'; -import * as stImport from '../lib-new/features/ls-st-import'; -export interface ProviderOptions { +export interface PluginCompletionOptions { context: LangServiceContext; meta: StylableMeta; fs: IFileSystem; @@ -76,8 +75,9 @@ export interface ProviderOptions { fakes: postcss.Rule[]; } -export interface CompletionProvider { - provide(options: ProviderOptions): Completion[]; +export interface LangServicePlugin { + analyzeCaretLocation?(context: LangServiceContext): void; + onCompletion(options: PluginCompletionOptions): Completion[]; } export class ProviderPosition { @@ -193,14 +193,14 @@ const topLevelDeclarations: Array = [ // Inside :import ruleset, which is not inside media query // If directive doesn't already exist -export const ImportInternalDirectivesProvider: CompletionProvider = { - provide({ +export const ImportInternalDirectivesPlugin: LangServicePlugin = { + onCompletion({ parentSelector, isMediaQuery, fullLineText, position, lineChunkAtCursor, - }: ProviderOptions): Completion[] { + }: PluginCompletionOptions): Completion[] { if (parentSelector && parentSelector.selector === ':import' && !isMediaQuery) { const res: Completion[] = []; importDeclarations.forEach((name) => { @@ -229,16 +229,16 @@ export const ImportInternalDirectivesProvider: CompletionProvider = { // Inside ruleset, which is not :import or :vars // Only inside simple selector, except -st-mixin // If directive doesn't already exist -export const RulesetInternalDirectivesProvider: CompletionProvider & { +export const RulesetInternalDirectivesPlugin: LangServicePlugin & { isSimpleSelector: (sel: string) => boolean; } = { - provide({ + onCompletion({ parentSelector, isMediaQuery, fullLineText, position, lineChunkAtCursor, - }: ProviderOptions): Completion[] { + }: PluginCompletionOptions): Completion[] { const res: Completion[] = []; if ( parentSelector && @@ -291,8 +291,8 @@ export const RulesetInternalDirectivesProvider: CompletionProvider & { // Only top level // @st-namespace may not repeat -export const TopLevelDirectiveProvider: CompletionProvider = { - provide({ +export const TopLevelDirectivePlugin: LangServicePlugin = { + onCompletion({ parentSelector, isMediaQuery, fullLineText, @@ -300,7 +300,7 @@ export const TopLevelDirectiveProvider: CompletionProvider = { lineChunkAtCursor, meta, astAtCursor, - }: ProviderOptions): Completion[] { + }: PluginCompletionOptions): Completion[] { if (!parentSelector) { if ( !isMediaQuery && @@ -341,10 +341,14 @@ export const TopLevelDirectiveProvider: CompletionProvider = { // RHS of declaration // Declaration is not -st-directive (except -st-mixin) // Not inside another value() -export const ValueDirectiveProvider: CompletionProvider & { +export const ValueDirectivePlugin: LangServicePlugin & { isInsideValueDirective: (wholeLine: string, pos: number) => boolean; } = { - provide({ parentSelector, fullLineText, position }: ProviderOptions): Completion[] { + onCompletion({ + parentSelector, + fullLineText, + position, + }: PluginCompletionOptions): Completion[] { if ( parentSelector && !isDirective(fullLineText) && @@ -401,25 +405,24 @@ export const ValueDirectiveProvider: CompletionProvider & { }; // Selector level -export const GlobalCompletionProvider: CompletionProvider = { - provide({ +export const GlobalCompletionPlugin: LangServicePlugin = { + onCompletion({ + context, parentSelector, fullLineText, position, lineChunkAtCursor, - astAtCursor, - }: ProviderOptions): Completion[] { + }: PluginCompletionOptions): Completion[] { + const isSelectorContext = + context.isInSelectorAllowedSpace() || + // natively allow in custom-selector; ToDO: make custom-selector plugin that enable selector at mapped location + (context.location.base.node as any).name === 'custom-selector'; if ( + isSelectorContext && !parentSelector && !lineChunkAtCursor.endsWith('::') && !isBetweenChars(fullLineText, position, '(', ')') ) { - if (astAtCursor.type === 'root') { - if (getAtRuleByPosition(astAtCursor, position, 'st-import')) { - return []; - } - } - let offset = 0; if (fullLineText.lastIndexOf(':') !== -1) { if ( @@ -448,8 +451,9 @@ export const GlobalCompletionProvider: CompletionProvider = { // Selector level // Not after :, unless entire chunk is : -export const SelectorCompletionProvider: CompletionProvider = { - provide({ +export const SelectorCompletionPlugin: LangServicePlugin = { + onCompletion({ + context, parentSelector, fullLineText, position, @@ -457,8 +461,12 @@ export const SelectorCompletionProvider: CompletionProvider = { meta, fakes, stylable, - }: ProviderOptions): Completion[] { - if (!parentSelector && (lineChunkAtCursor === ':' || !lineChunkAtCursor.endsWith(':'))) { + }: PluginCompletionOptions): Completion[] { + if ( + context.isInSelectorAllowedSpace() && + !parentSelector && + (lineChunkAtCursor === ':' || !lineChunkAtCursor.endsWith(':')) + ) { const comps: Completion[] = []; comps.push( ...Object.keys(meta.getAllClasses()) @@ -523,8 +531,13 @@ export const SelectorCompletionProvider: CompletionProvider = { // Inside ruleset of simple selector, not :import or :vars // RHS of -st-extends -export const ExtendCompletionProvider: CompletionProvider = { - provide({ lineChunkAtCursor, position, meta, stylable }: ProviderOptions): Completion[] { +export const ExtendCompletionPlugin: LangServicePlugin = { + onCompletion({ + lineChunkAtCursor, + position, + meta, + stylable, + }: PluginCompletionOptions): Completion[] { if (lineChunkAtCursor.startsWith(`-st-extends`)) { const value = lineChunkAtCursor.slice(`-st-extends:`.length); const spaces = value.search(/\S|$/); @@ -579,8 +592,13 @@ export const ExtendCompletionProvider: CompletionProvider = { // Inside ruleset, which is not :import or :vars // RHS of -st-extends -export const CssMixinCompletionProvider: CompletionProvider = { - provide({ lineChunkAtCursor, meta, position, fullLineText }: ProviderOptions): Completion[] { +export const CssMixinCompletionPlugin: LangServicePlugin = { + onCompletion({ + lineChunkAtCursor, + meta, + position, + fullLineText, + }: PluginCompletionOptions): Completion[] { if (lineChunkAtCursor.startsWith(`-st-mixin:`)) { const { names, lastName } = getExistingNames(fullLineText, position); const symbols = meta.getAllSymbols(); @@ -620,8 +638,8 @@ export const CssMixinCompletionProvider: CompletionProvider = { // Only inside simple selector // RHS of -st-mixin // There is a JS/TS import -export const CodeMixinCompletionProvider: CompletionProvider = { - provide({ +export const CodeMixinCompletionPlugin: LangServicePlugin = { + onCompletion({ parentSelector, meta, fullLineText, @@ -630,7 +648,7 @@ export const CodeMixinCompletionProvider: CompletionProvider = { fs, tsLangService, stylable, - }: ProviderOptions): Completion[] { + }: PluginCompletionOptions): Completion[] { if ( meta .getImportStatements() @@ -662,8 +680,8 @@ export const CodeMixinCompletionProvider: CompletionProvider = { // Inside ruleset, which is not :import // RHS of any rule except -st-extends, -st-from -export const FormatterCompletionProvider: CompletionProvider = { - provide({ +export const FormatterCompletionPlugin: LangServicePlugin = { + onCompletion({ meta, fullLineText, parentSelector, @@ -672,7 +690,7 @@ export const FormatterCompletionProvider: CompletionProvider = { fs, tsLangService, stylable, - }: ProviderOptions): Completion[] { + }: PluginCompletionOptions): Completion[] { if ( meta .getImportStatements() @@ -708,14 +726,14 @@ export const FormatterCompletionProvider: CompletionProvider = { // Inside :import // RHS of -st-named // import exists -export const NamedCompletionProvider: CompletionProvider & { +export const NamedCompletionPlugin: LangServicePlugin & { resolveImport: ( importName: string, stylable: Stylable, meta: StylableMeta ) => StylableMeta | null; } = { - provide({ + onCompletion({ parentSelector, astAtCursor, stylable, @@ -723,7 +741,7 @@ export const NamedCompletionProvider: CompletionProvider & { position, fullLineText, src, - }: ProviderOptions): Completion[] { + }: PluginCompletionOptions): Completion[] { const { isNamedValueLine, namedValues } = getNamedValues(src, position.line); if (isNamedValueLine) { let importName = ''; @@ -886,14 +904,8 @@ function maybeResolveImport( return resolvedImport; } -export const newStImportCompletionProvider: CompletionProvider = { - provide({ context }) { - return stImport.getCompletions(context); - }, -}; - -export const PseudoElementCompletionProvider: CompletionProvider = { - provide({ +export const PseudoElementCompletionPlugin: LangServicePlugin = { + onCompletion({ parentSelector, resolved, resolvedElements, @@ -903,7 +915,7 @@ export const PseudoElementCompletionProvider: CompletionProvider = { meta, position, fullLineText, - }: ProviderOptions): Completion[] { + }: PluginCompletionOptions): Completion[] { let comps: any[] = []; if ( !parentSelector && @@ -946,12 +958,8 @@ export const PseudoElementCompletionProvider: CompletionProvider = { const colons = lineChunkAtCursor.match(/:*$/)![0].length; scope?.resolved.forEach((res) => { - if (!(res.symbol as ClassSymbol)[`-st-root`]) { - return; - } - comps = comps.concat( - STPart.getPartNames(res.meta) + STStructure.getPartNames(res.symbol) .filter((e) => e.startsWith(filter) && e !== 'root') .map((c) => { let relPath = path.relative(path.dirname(meta.source), res.meta.source); @@ -991,7 +999,7 @@ export const PseudoElementCompletionProvider: CompletionProvider = { } comps = comps.concat( - STPart.getPartNames(res.meta) + STStructure.getPartNames(res.symbol) .filter((e) => e.startsWith(filter) && e !== 'root') .map((c) => { let relPath = path.relative( @@ -1104,8 +1112,8 @@ function isPositionInDecl(position: ProviderPosition, decl: postcss.Declaration) return false; } -export const StateTypeCompletionProvider: CompletionProvider = { - provide({ astAtCursor, fullLineText, position }: ProviderOptions): Completion[] { +export const StateTypeCompletionPlugin: LangServicePlugin = { + onCompletion({ astAtCursor, fullLineText, position }: PluginCompletionOptions): Completion[] { const acc: Completion[] = []; if (isNodeRule(astAtCursor)) { @@ -1188,14 +1196,19 @@ export const StateTypeCompletionProvider: CompletionProvider = { }, }; -export const StateSelectorCompletionProvider: CompletionProvider = { - provide({ context }: ProviderOptions) { +export const StateSelectorCompletionPlugin: LangServicePlugin = { + onCompletion({ context }: PluginCompletionOptions) { return cssPseudoClass.getCompletions(context); }, }; -export const ValueCompletionProvider: CompletionProvider = { - provide({ fullLineText, position, meta, stylable }: ProviderOptions): Completion[] { +export const ValueCompletionPlugin: LangServicePlugin = { + onCompletion({ + fullLineText, + position, + meta, + stylable, + }: PluginCompletionOptions): Completion[] { if (isInValue(fullLineText, position)) { const inner = fullLineText .slice(0, fullLineText.indexOf(')', position.character) + 1) diff --git a/packages/language-service/src/lib/css-service.ts b/packages/language-service/src/lib/css-service.ts index 2c17b382a6..7dab7883d6 100644 --- a/packages/language-service/src/lib/css-service.ts +++ b/packages/language-service/src/lib/css-service.ts @@ -145,6 +145,7 @@ export class CssService { atRule.name = mq; const replacementDiff = `${stScope} ${atRule.params}`.length - `${mq} all`.length; + atRule.raws.afterName = ' '; atRule.params = 'all' + ' '.repeat(replacementDiff); }); @@ -174,6 +175,7 @@ export class CssService { } else if ( diag.code === 'unknownAtRules' && (atRuleName === '@custom-selector' || + atRuleName === '@st' || atRuleName === '@st-scope' || atRuleName === '@st-namespace' || atRuleName === '@st-import' || @@ -198,7 +200,12 @@ export class CssService { } else if (diag.code === 'unknownProperties') { const prop = diag.message.match(/'(.*)'/)![1]; - if (meta.getStVar(prop) || prop === 'container' || prop === 'container-name') { + if ( + meta.getStVar(prop) || + prop === 'container' || + prop === 'container-name' || + prop === 'd' + ) { return false; } } diff --git a/packages/language-service/src/lib/provider.ts b/packages/language-service/src/lib/provider.ts index 5be7afb71d..f9ae236d8e 100644 --- a/packages/language-service/src/lib/provider.ts +++ b/packages/language-service/src/lib/provider.ts @@ -29,27 +29,26 @@ import type { import { URI } from 'vscode-uri'; import { - CodeMixinCompletionProvider, - CompletionProvider, + CodeMixinCompletionPlugin, + LangServicePlugin, createRange, - CssMixinCompletionProvider, - ExtendCompletionProvider, - FormatterCompletionProvider, - GlobalCompletionProvider, - ImportInternalDirectivesProvider, - NamedCompletionProvider, - ProviderOptions, + CssMixinCompletionPlugin, + ExtendCompletionPlugin, + FormatterCompletionPlugin, + GlobalCompletionPlugin, + ImportInternalDirectivesPlugin, + NamedCompletionPlugin, + PluginCompletionOptions, ProviderPosition, ProviderRange, - PseudoElementCompletionProvider, - RulesetInternalDirectivesProvider, - SelectorCompletionProvider, - StateSelectorCompletionProvider, - StateTypeCompletionProvider, - TopLevelDirectiveProvider, - ValueCompletionProvider, - ValueDirectiveProvider, - newStImportCompletionProvider, + PseudoElementCompletionPlugin, + RulesetInternalDirectivesPlugin, + SelectorCompletionPlugin, + StateSelectorCompletionPlugin, + StateTypeCompletionPlugin, + TopLevelDirectivePlugin, + ValueCompletionPlugin, + ValueDirectivePlugin, } from './completion-providers'; import { topLevelDirectives } from './completion-types'; import type { Completion } from './completion-types'; @@ -68,6 +67,7 @@ import { SelectorQuery, } from './utils/selector-analyzer'; import type { LangServiceContext } from '../lib-new/lang-service-context'; +import { StImportPlugin } from '../lib-new/features/ls-st-import'; function findLast( arr: T[], @@ -85,26 +85,31 @@ function findLast( } export class Provider { - private providers: CompletionProvider[] = [ - newStImportCompletionProvider, - RulesetInternalDirectivesProvider, - ImportInternalDirectivesProvider, - TopLevelDirectiveProvider, - ValueDirectiveProvider, - GlobalCompletionProvider, - SelectorCompletionProvider, - ExtendCompletionProvider, - CssMixinCompletionProvider, - CodeMixinCompletionProvider, - FormatterCompletionProvider, - NamedCompletionProvider, - StateTypeCompletionProvider, - StateSelectorCompletionProvider, - PseudoElementCompletionProvider, - ValueCompletionProvider, + private plugins: LangServicePlugin[] = [ + StImportPlugin, + RulesetInternalDirectivesPlugin, + ImportInternalDirectivesPlugin, + TopLevelDirectivePlugin, + ValueDirectivePlugin, + GlobalCompletionPlugin, + SelectorCompletionPlugin, + ExtendCompletionPlugin, + CssMixinCompletionPlugin, + CodeMixinCompletionPlugin, + FormatterCompletionPlugin, + NamedCompletionPlugin, + StateTypeCompletionPlugin, + StateSelectorCompletionPlugin, + PseudoElementCompletionPlugin, + ValueCompletionPlugin, ]; constructor(private stylable: Stylable, private tsLangService: ExtendedTsLanguageService) {} + public analyzeCaretContext(context: LangServiceContext) { + for (const plugin of this.plugins) { + plugin.analyzeCaretLocation?.(context); + } + } public provideCompletionItemsFromSrc( context: LangServiceContext, fs: IFileSystem @@ -119,7 +124,7 @@ export class Provider { return []; } - const options = this.createProviderOptions( + const options = this.createPluginCompletionOptions( context, src, pos, @@ -129,8 +134,8 @@ export class Provider { res.cursorLineIndex, fs ); - for (const provider of this.providers) { - completions.push(...provider.provide(options)); + for (const provider of this.plugins) { + completions.push(...provider.onCompletion(options)); } return this.dedupeComps(completions); @@ -395,7 +400,7 @@ export class Provider { let mixin = ''; const rev = parsed.nodes[parsed.nodes.length - 1]; - if (rev.type === 'function' && !!rev.unclosed) { + if (rev?.type === 'function' && !!rev.unclosed) { mixin = rev.value; } else { return null; @@ -722,7 +727,7 @@ export class Provider { } } - private createProviderOptions( + private createPluginCompletionOptions( context: LangServiceContext, src: string, position: ProviderPosition, @@ -731,7 +736,7 @@ export class Provider { fullLineText: string, cursorPosInLine: number, fs: IFileSystem - ): ProviderOptions { + ): PluginCompletionOptions { const path = pathFromPosition(meta.sourceAst, { line: position.line + 1, character: position.character, diff --git a/packages/language-service/src/lib/service.ts b/packages/language-service/src/lib/service.ts index 574074c1de..6fe3767b9c 100644 --- a/packages/language-service/src/lib/service.ts +++ b/packages/language-service/src/lib/service.ts @@ -32,6 +32,7 @@ import { getRefs, getRenameRefs } from './provider'; import { typescriptSupport } from './typescript-support'; import type { ExtendedTsLanguageService } from './types'; import { LangServiceContext } from '../lib-new/lang-service-context'; +import { wrapAndCatchErrors } from './utils/wrap-and-log'; export interface StylableLanguageServiceOptions { fs: IFileSystem; @@ -67,6 +68,7 @@ export class StylableLanguageService { if (stylableFile && stylableFile.stat.isFile()) { const context = new LangServiceContext(this.fs, this.stylable, stylableFile, offset); + this.provider.analyzeCaretContext(context); return this.getCompletions(context); } else { return []; @@ -326,17 +328,17 @@ export class StylableLanguageService { ); } } - - const cssCompletions = this.cssService.getCompletions(cleanDocument, position); - - for (const cssComp of cssCompletions) { - const label = cssComp.label; - - if (!groupedCompletions.has(label)) { - // CSS declaration property names have built in sorting - // at-rules, rules and declaration values do not - cssComp.sortText = cssComp.sortText || 'z'; - groupedCompletions.set(label, cssComp); + // native CSS service + if (context.flags.runNativeCSSService) { + const cssCompletions = this.cssService.getCompletions(cleanDocument, position); + for (const cssComp of cssCompletions) { + const label = cssComp.label; + if (!groupedCompletions.has(label)) { + // CSS declaration property names have built in sorting + // at-rules, rules and declaration values do not + cssComp.sortText = cssComp.sortText || 'z'; + groupedCompletions.set(label, cssComp); + } } } @@ -417,6 +419,22 @@ export class StylableLanguageService { } } +wrapAndCatchErrors( + { + onDefinition: () => [], + onCompletion: () => [], + onSignatureHelp: () => null, + onReferences: () => [], + onHover: () => null, + onColorPresentation: () => [], + onDocumentColor: () => [], + onDocumentFormatting: () => [], + onDocumentRangeFormatting: () => [], + onRenameRequest: () => ({ changes: {} }), + }, + StylableLanguageService +); + export interface StylableFile { path: string; stat: IFileSystemStats; diff --git a/packages/language-service/src/lib/utils/wrap-and-log.ts b/packages/language-service/src/lib/utils/wrap-and-log.ts new file mode 100644 index 0000000000..8ee1d126f1 --- /dev/null +++ b/packages/language-service/src/lib/utils/wrap-and-log.ts @@ -0,0 +1,34 @@ +type FunctionConfig = Pick< + { + [K in keyof T]: T[K] extends (...args: any[]) => infer R ? () => R : never; + }, + { + [K in keyof T]: T[K] extends (...args: any[]) => any ? K : never; + }[keyof T] +>; + +export function wrapAndCatchErrors>( + config: Partial>, + context: new (...args: any[]) => T +) { + const proto = context.prototype; + for (const [name, defaultReturn] of Object.entries(config)) { + const func = proto[name]; + if (typeof func !== 'function') { + console.error( + `expected to find a function named ${name} on context, but found ${typeof func}` + ); + continue; + } + proto[name as keyof T] = function (this: T, ...args: unknown[]) { + try { + return func.apply(this, args) || (defaultReturn as () => unknown)(); + } catch (e) { + const errorContent = e instanceof Error ? e.stack : e; + console.error(`\nUnexpected error in ${name}\n`); + console.log(`${errorContent}\n\n`); + return; + } + } as T[typeof name]; + } +} diff --git a/packages/language-service/test/fixtures/server-cases/pseudo-elements/multiple-states.st.css b/packages/language-service/test/fixtures/server-cases/pseudo-elements/multiple-states.st.css deleted file mode 100644 index 303a6a6300..0000000000 --- a/packages/language-service/test/fixtures/server-cases/pseudo-elements/multiple-states.st.css +++ /dev/null @@ -1,12 +0,0 @@ -:import { - -st-from: "./import.st.css"; - -st-default: Comp; -} - -.local { - -st-extends: Comp; -} - -.local::momo:anotherState| { - -} diff --git a/packages/language-service/test/fixtures/server-cases/pseudo-elements/recursive-import-3-deep-state.st.css b/packages/language-service/test/fixtures/server-cases/pseudo-elements/recursive-import-3-deep-state.st.css deleted file mode 100644 index 606caf54cf..0000000000 --- a/packages/language-service/test/fixtures/server-cases/pseudo-elements/recursive-import-3-deep-state.st.css +++ /dev/null @@ -1,11 +0,0 @@ -:import { - -st-from: "./recursive-import-2.st.css"; - -st-default: Comp; -} - -.gaga { - -st-extends: Comp; - -st-states: lala; -} - -.gaga:lala::bobo:otherState:state::momo:anotherState| diff --git a/packages/language-service/test/fixtures/server-cases/states/class-with-states-double-colon.st.css b/packages/language-service/test/fixtures/server-cases/states/class-with-states-double-colon.st.css deleted file mode 100644 index 86bfc0aecd..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/class-with-states-double-colon.st.css +++ /dev/null @@ -1,5 +0,0 @@ -.gaga{ - -st-states:hello,goodbye; -} - -.gaga::| diff --git a/packages/language-service/test/fixtures/server-cases/states/class-with-states.st.css b/packages/language-service/test/fixtures/server-cases/states/class-with-states.st.css deleted file mode 100644 index 73f72b071d..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/class-with-states.st.css +++ /dev/null @@ -1,5 +0,0 @@ -.gaga{ - -st-states:hello,goodbye; -} - -.gaga| diff --git a/packages/language-service/test/fixtures/server-cases/states/complex-selectors-with-states.st.css b/packages/language-service/test/fixtures/server-cases/states/complex-selectors-with-states.st.css deleted file mode 100644 index 48fd079dc3..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/complex-selectors-with-states.st.css +++ /dev/null @@ -1,10 +0,0 @@ -.gaga{ - -st-states:hello,holla; -} -.zagzag{ - -st-states:goodbye; -} -.baga{ - -st-states:cheerio; -} -.zagzag button.gaga:holla| .baga diff --git a/packages/language-service/test/fixtures/server-cases/states/complex-selectors.st.css b/packages/language-service/test/fixtures/server-cases/states/complex-selectors.st.css deleted file mode 100644 index 18a96f7058..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/complex-selectors.st.css +++ /dev/null @@ -1,10 +0,0 @@ -.gaga{ - -st-states:hello; -} -.zagzag{ - -st-states:goodbye; -} -.baga{ - -st-states:cheerio; -} -.zagzag button.gaga| .baga diff --git a/packages/language-service/test/fixtures/server-cases/states/top-level-with-extend.st.css b/packages/language-service/test/fixtures/server-cases/states/top-level-with-extend.st.css deleted file mode 100644 index 03f263d3ed..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/top-level-with-extend.st.css +++ /dev/null @@ -1,10 +0,0 @@ -:import { - -st-from: "./comp-to-import.st.css"; - -st-default: Comp; -} - -.root { - -st-extends: Comp; -} - -| \ No newline at end of file diff --git a/packages/language-service/test/fixtures/server-cases/states/top-level.st.css b/packages/language-service/test/fixtures/server-cases/states/top-level.st.css deleted file mode 100644 index fd433e9aeb..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/top-level.st.css +++ /dev/null @@ -1,5 +0,0 @@ -.root { - -st-states: shmover; -} - -| \ No newline at end of file diff --git a/packages/language-service/test/fixtures/server-cases/states/with-param/enum/imported-state-with-enum-middle.st.css b/packages/language-service/test/fixtures/server-cases/states/with-param/enum/imported-state-with-enum-middle.st.css deleted file mode 100644 index cf73dfd7f7..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/with-param/enum/imported-state-with-enum-middle.st.css +++ /dev/null @@ -1,12 +0,0 @@ -:import { - -st-from: "./state-with-enum.st.css"; - -st-default: Enum; -} - -.blah { - -st-extends: Enum; -} - -.blah:hello(e|) { - -} diff --git a/packages/language-service/test/fixtures/server-cases/states/with-param/enum/imported-state-with-enum-start.st.css b/packages/language-service/test/fixtures/server-cases/states/with-param/enum/imported-state-with-enum-start.st.css deleted file mode 100644 index 56c8ded864..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/with-param/enum/imported-state-with-enum-start.st.css +++ /dev/null @@ -1,12 +0,0 @@ -:import { - -st-from: "./state-with-enum.st.css"; - -st-default: Enum; -} - -.blah { - -st-extends: Enum; -} - -.blah:hello(|) { - -} diff --git a/packages/language-service/test/fixtures/server-cases/states/with-param/enum/imported-state-with-template-enum-middle.st.css b/packages/language-service/test/fixtures/server-cases/states/with-param/enum/imported-state-with-template-enum-middle.st.css deleted file mode 100644 index adcab58e8c..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/with-param/enum/imported-state-with-template-enum-middle.st.css +++ /dev/null @@ -1,12 +0,0 @@ -:import { - -st-from: "./state-with-enum.st.css"; - -st-default: Enum; -} - -.blah { - -st-extends: Enum; -} - -.blah:templateEnum(e|) { - -} diff --git a/packages/language-service/test/fixtures/server-cases/states/with-param/enum/state-with-enum.st.css b/packages/language-service/test/fixtures/server-cases/states/with-param/enum/state-with-enum.st.css deleted file mode 100644 index e87d43f230..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/with-param/enum/state-with-enum.st.css +++ /dev/null @@ -1,7 +0,0 @@ -.root { - -st-states: hello(enum(bob, alice, eve)), otherState, templateEnum(".$0", enum(aaa, eee, bbb, e22)); -} - -.root .part { - -} diff --git a/packages/language-service/test/fixtures/server-cases/states/with-param/enum/state-with-param-enum-suggestion.st.css b/packages/language-service/test/fixtures/server-cases/states/with-param/enum/state-with-param-enum-suggestion.st.css deleted file mode 100644 index 588a00052b..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/with-param/enum/state-with-param-enum-suggestion.st.css +++ /dev/null @@ -1,5 +0,0 @@ -.gaga{ - -st-states: hello(enum(bob, alice, eve)); -} - -.gaga:hello(|) diff --git a/packages/language-service/test/fixtures/server-cases/states/with-param/imported-state-param.st.css b/packages/language-service/test/fixtures/server-cases/states/with-param/imported-state-param.st.css deleted file mode 100644 index c2c5836c6d..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/with-param/imported-state-param.st.css +++ /dev/null @@ -1,10 +0,0 @@ -:import { - -st-from: "./comp-to-import-with-param.st.css"; - -st-default: Comp -} - -.gaga{ - -st-extends: Comp; -} - -.gaga| diff --git a/packages/language-service/test/fixtures/server-cases/states/with-param/local-state-param.st.css b/packages/language-service/test/fixtures/server-cases/states/with-param/local-state-param.st.css deleted file mode 100644 index b22511d7c5..0000000000 --- a/packages/language-service/test/fixtures/server-cases/states/with-param/local-state-param.st.css +++ /dev/null @@ -1,5 +0,0 @@ -.gaga{ - -st-states:hello(string); -} - -.gaga| diff --git a/packages/language-service/test/lib-new/ast-from-position.spec.ts b/packages/language-service/test/lib-new/ast-from-position.spec.ts index 69628d6fb3..53510c1ade 100644 --- a/packages/language-service/test/lib-new/ast-from-position.spec.ts +++ b/packages/language-service/test/lib-new/ast-from-position.spec.ts @@ -2,12 +2,13 @@ import { expect } from 'chai'; import { getAstNodeAt, type NodeType, + AstLocationResult, } from '@stylable/language-service/dist/lib-new/ast-from-position'; import { parseForEditing } from '@stylable/language-service/dist/lib-new/edit-time-parser'; import { stringifySelectorAst } from '@tokey/css-selector-parser'; import { stringifyCSSValue } from '@tokey/css-value-parser'; import { deindent } from '@stylable/core-test-kit'; -import { assertRule, assertAtRule } from '../test-kit/postcss-node-asserts'; +import { assertRule } from '../test-kit/postcss-node-asserts'; function setupWithCursor(source: string, options: { deindent?: boolean } = {}) { const deindented = options.deindent === false ? source : deindent(source); @@ -27,17 +28,78 @@ function assertNodes( nodes.forEach((actual, i) => { const expected = expectedNodes[i]; const desc = expected.desc || i; - const isPostCss = 'raws' in actual; - const actualStr = isPostCss - ? actual.toString() - : stringifyCSSValue(actual as any) || stringifySelectorAst(actual as any); + const actualStr = stringifyResultAst(actual); if (expected.type) { - expect(actual.type, 'type ' + desc).to.eql(expected.type); + if ('type' in actual) { + expect(actual.type, 'type ' + desc).to.eql(expected.type); + } else { + throw new Error(`expected node.type`); + } } expect(actualStr, 'string compare ' + desc).to.eql(expected.str); }); } +function stringifyResultAst(node: NodeType | NodeType[]): string { + if (Array.isArray(node)) { + return node.map(stringifyResultAst).join(''); + } + const isPostCss = 'raws' in node; + return isPostCss + ? node.toString() + : stringifyCSSValue(node as any) || stringifySelectorAst(node as any); +} +function expectAstLocation( + actual: NonNullable, + expectation: { + node?: NodeType; + stringify?: string; + deindent?: boolean; + where?: string; + parents?: { str: string; desc?: string; type?: string }[]; + } +) { + if (expectation.node) { + expect(actual.node, 'node').to.equal(expectation.node); + } + if (expectation.where) { + if ('where' in actual) { + expect(actual.where, 'where').to.equal(expectation.where); + } else { + throw new Error(`expected where="${expectation.where}"`); + } + } + if (expectation.stringify) { + const disableDeindent = + expectation.deindent === false || !expectation.stringify.includes('\n'); + const expectedSource = disableDeindent + ? expectation.stringify + : deindent(expectation.stringify); + let caretOffset = actual.offsetInNode; + let stringified = stringifyResultAst(actual.node); + if (expectedSource.includes('|')) { + // naively add spaces for cases where postcss keeps the initial spaces in the before + if (caretOffset < 0) { + stringified = stringified.padStart(-1 * caretOffset + stringified.length, ' '); + caretOffset = 0; + } else if (caretOffset > stringified.length) { + stringified = stringified.padEnd(caretOffset, ' '); + } + const withCaret = + stringified.slice(0, caretOffset) + '|' + stringified.slice(caretOffset); + expect(withCaret, 'stringify (with caret)').to.equal(expectedSource); + } else { + expect(stringified, 'stringify (with caret)').to.equal(expectedSource); + } + } + if (expectation.parents) { + if ('parents' in actual) { + assertNodes(actual.parents, expectation.parents); + } else { + throw new Error(`expected parents`); + } + } +} /** * these tests sometimes have before/after the actual source that is being tested * in order to verify that offsets are being calculated correctly. @@ -47,23 +109,28 @@ describe('ast-from-position', () => { it(`should find root (empty)`, () => { const { position, parsed } = setupWithCursor(`|`); - const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); + const result = getAstNodeAt(parsed, position); - expect(base.node, 'node').to.equal(parsed.ast); - expect(base.offsetInNode, 'offset').to.eql(0); - expect(base.where, 'where').to.eql('root'); - expect(selector, 'selector').to.eql(undefined); - expect(declValue, 'declValue').to.eql(undefined); - expect(atRuleParams, 'atRuleParams').to.eql(undefined); + expectAstLocation(result.base, { + node: parsed.ast, + where: 'root', + stringify: '|', + }); + expect(result.selector, 'selector').to.eql(undefined); + expect(result.declValue, 'declValue').to.eql(undefined); + expect(result.atRuleParams, 'atRuleParams').to.eql(undefined); }); it(`should find root (whitespace)`, () => { const { position, parsed } = setupWithCursor(` \t\n|\n\t `, { deindent: false }); const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); - expect(base.node, 'node').to.equal(parsed.ast); - expect(base.offsetInNode, 'offset').to.eql(3); - expect(base.where, 'where').to.eql('root'); + expectAstLocation(base, { + node: parsed.ast, + where: 'root', + stringify: ' \t\n|\n\t ', + deindent: false, + }); expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -73,9 +140,11 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); - expect(base.node, 'node').to.equal(parsed.ast.nodes[1]); - expect(base.offsetInNode, 'offset').to.eql(9); - expect(base.where, 'where').to.eql('comment'); + expectAstLocation(base, { + node: parsed.ast.nodes[1], + where: 'comment', + stringify: '/*comment|*/', + }); expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -94,27 +163,30 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target class node').to.eql( - '.bookmark.after {\n prop: val;\n}' - ); - expect(base.offsetInNode, 'base offset').to.eql(0); - expect(base.where, 'where').to.eql('ruleSelector'); + expectAstLocation(base, { + node: parsed.ast.nodes[1], + where: 'ruleSelector', + stringify: ` + |.bookmark.after { + prop: val; + } + `, + }); // selector level - expect(stringifySelectorAst(selector!.node), 'target selector').to.eql( - '.bookmark.after' - ); + expectAstLocation(selector!, { + stringify: `|.bookmark.after`, + parents: [ + { + desc: 'rule node', + str: deindent(` + .bookmark.after { + prop: val; + } + `), + }, + ], + }); expect(selector!.afterSelector, 'after selector').to.eql(false); - expect(selector!.offsetInNode).to.eql(0); - assertNodes(selector!.parents, [ - { - desc: 'rule node', - str: deindent(` - .bookmark.after { - prop: val; - } - `), - }, - ]); // unresolved levels expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -131,29 +203,34 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target class node').to.eql( - '.before.bookmark.after {\n prop: val;\n}' - ); - expect(base.offsetInNode, 'base offset').to.eql(12); - expect(base.where, 'where').to.eql('ruleSelector'); + expectAstLocation(base, { + node: parsed.ast.nodes[1], + where: 'ruleSelector', + stringify: ` + .before.book|mark.after { + prop: val; + } + `, + }); // selector level - expect(stringifySelectorAst(selector!.node), 'target class node').to.eql('.bookmark'); + expectAstLocation(selector!, { + stringify: `.book|mark`, + parents: [ + { + desc: 'rule node', + str: deindent(` + .before.bookmark.after { + prop: val; + } + `), + }, + { + desc: 'top selector node', + str: '.before.bookmark.after', + }, + ], + }); expect(selector!.afterSelector, 'after selector').to.eql(false); - expect(selector!.offsetInNode).to.eql(5); - assertNodes(selector!.parents, [ - { - desc: 'rule node', - str: deindent(` - .before.bookmark.after { - prop: val; - } - `), - }, - { - desc: 'top selector node', - str: '.before.bookmark.after', - }, - ]); // unresolved levels expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -169,32 +246,37 @@ describe('ast-from-position', () => { const { base, selector } = getAstNodeAt(parsed, position); - expect(base.where, 'where').to.eql('ruleSelector'); - - expect(stringifySelectorAst(selector!.node), 'target class node').to.eql('.target'); - expect(selector!.offsetInNode).to.eql(5); - assertNodes(selector!.parents, [ - { - desc: 'rule node', - str: deindent(` - .before:is(.target.a).after { - decl: declValue; - } - `), - }, - { - desc: 'top selector node', - str: '.before:is(.target.a).after', - }, - { - desc: 'is() selector node', - str: ':is(.target.a)', - }, - { - desc: 'nested selector node', - str: '.target.a', - }, - ]); + // base level + expectAstLocation(base, { + node: parsed.ast.nodes[1], + where: 'ruleSelector', + }); + // selector level + expectAstLocation(selector!, { + stringify: `.targ|et`, + parents: [ + { + desc: 'rule node', + str: deindent(` + .before:is(.target.a).after { + decl: declValue; + } + `), + }, + { + desc: 'top selector node', + str: '.before:is(.target.a).after', + }, + { + desc: 'is() selector node', + str: ':is(.target.a)', + }, + { + desc: 'nested selector node', + str: '.target.a', + }, + ], + }); }); it(`should find selector end`, () => { const { position, parsed } = setupWithCursor(` @@ -208,29 +290,34 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target class node').to.eql( - '.before.bookmark {\n prop: val;\n}' - ); - expect(base.offsetInNode, 'base offset').to.eql(16); - expect(base.where, 'where').to.eql('ruleSelector'); + expectAstLocation(base, { + node: parsed.ast.nodes[1], + where: 'ruleSelector', + stringify: ` + .before.bookmark| { + prop: val; + } + `, + }); // selector level - expect(stringifySelectorAst(selector!.node), 'target class node').to.eql('.bookmark'); + expectAstLocation(selector!, { + stringify: `.bookmark|`, + parents: [ + { + desc: 'rule node', + str: deindent(` + .before.bookmark { + prop: val; + } + `), + }, + { + desc: 'top selector node', + str: '.before.bookmark', + }, + ], + }); expect(selector!.afterSelector, 'after selector').to.eql(false); - expect(selector!.offsetInNode).to.eql(9); - assertNodes(selector!.parents, [ - { - desc: 'rule node', - str: deindent(` - .before.bookmark { - prop: val; - } - `), - }, - { - desc: 'top selector node', - str: '.before.bookmark', - }, - ]); // unresolved levels expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -247,23 +334,30 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target class node').to.eql('{\n prop: val;\n}'); - expect(base.offsetInNode, 'base offset').to.eql(-1); - expect(base.where, 'where').to.eql('ruleBetweenSelectorAndBody'); + expectAstLocation(base, { + node: parsed.ast.nodes[1], + where: 'ruleBetweenSelectorAndBody', + stringify: ` + | { + prop: val; + } + `, + }); // selector level - expect(stringifySelectorAst(selector!.node), '').to.eql(''); + expectAstLocation(selector!, { + stringify: `|`, + parents: [ + { + desc: 'rule node', + str: deindent(` + { + prop: val; + } + `), + }, + ], + }); expect(selector!.afterSelector, 'after selector').to.eql(false); - expect(selector!.offsetInNode).to.eql(0); - assertNodes(selector!.parents, [ - { - desc: 'rule node', - str: deindent(` - { - prop: val; - } - `), - }, - ]); // unresolved levels expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -280,25 +374,30 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target class node').to.eql( - '.bookmark {\n prop: val;\n}' - ); - expect(base.offsetInNode, 'base offset').to.eql(12); - expect(base.where, 'where').to.eql('ruleBetweenSelectorAndBody'); + expectAstLocation(base, { + node: parsed.ast.nodes[1], + where: 'ruleBetweenSelectorAndBody', + stringify: ` + .bookmark | { + prop: val; + } + `, + }); // selector-after level - expect(stringifySelectorAst(selector!.node), 'target selector').to.eql('.bookmark'); + expectAstLocation(selector!, { + stringify: `.bookmark |`, + parents: [ + { + desc: 'rule node', + str: deindent(` + .bookmark { + prop: val; + } + `), + }, + ], + }); expect(selector!.afterSelector, 'after selector').to.eql(true); - expect(selector!.offsetInNode).to.eql(12); - assertNodes(selector!.parents, [ - { - desc: 'rule node', - str: deindent(` - .bookmark { - prop: val; - } - `), - }, - ]); // unresolved levels expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -315,25 +414,29 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target class node').to.eql( - '.before, .bookmark , .after {\n prop: val;\n}' - ); - expect(base.offsetInNode, 'base offset').to.eql(19); - expect(base.where, 'where').to.eql('ruleSelector'); + expectAstLocation(base, { + where: 'ruleSelector', + stringify: ` + .before, .bookmark |, .after { + prop: val; + } + `, + }); // selector-after level - expect(stringifySelectorAst(selector!.node), 'target selector').to.eql(' .bookmark '); + expectAstLocation(selector!, { + stringify: ` .bookmark |`, + parents: [ + { + desc: 'rule node', + str: deindent(` + .before, .bookmark , .after { + prop: val; + } + `), + }, + ], + }); expect(selector!.afterSelector, 'after selector').to.eql(true); - expect(selector!.offsetInNode).to.eql(11); - assertNodes(selector!.parents, [ - { - desc: 'rule node', - str: deindent(` - .before, .bookmark , .after { - prop: val; - } - `), - }, - ]); // unresolved levels expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -347,10 +450,12 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); - const rule = assertRule(parsed.ast.nodes[1]); - expect(base.node, 'node').to.equal(rule); - expect(base.offsetInNode, 'offset').to.eql(5); - expect(base.where, 'where').to.eql('ruleBody'); + // base level + expectAstLocation(base, { + node: assertRule(parsed.ast.nodes[1]), + where: 'ruleBody', + stringify: `.x { | decl: declValue; }`, + }); // ToDo: maybe offer before/after nodes // expect(base.beforeNode, 'beforeNode').to.eql(undefined); // expect(base.afterNode, 'afterNode').to.eql(rule.nodes[0]); @@ -368,10 +473,12 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); - const rule = assertRule(parsed.ast.nodes[1]); - expect(base.node, 'node').to.equal(rule); - expect(base.offsetInNode, 'offset').to.eql(20); - expect(base.where, 'where').to.eql('ruleBody'); + // base level + expectAstLocation(base, { + node: assertRule(parsed.ast.nodes[1]), + where: 'ruleBody', + stringify: `.x { decl1: before; | decl2: after }`, + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -386,10 +493,12 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); - const rule = assertRule(parsed.ast.nodes[1]); - expect(base.node, 'node').to.equal(rule); - expect(base.offsetInNode, 'offset').to.eql(19); - expect(base.where, 'where').to.eql('ruleBody'); + // base level + expectAstLocation(base, { + node: assertRule(parsed.ast.nodes[1]), + where: 'ruleBody', + stringify: `.x { decl: before; | }`, + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -408,9 +517,11 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node, 'node').to.equal((parsed.ast as any).nodes[0].nodes[0]); - expect(base.offsetInNode, 'offset').to.equal(0); - expect(base.where, 'where').to.eql('declProp'); + expectAstLocation(base, { + node: (parsed.ast as any).nodes[0].nodes[0], + where: 'declProp', + stringify: `|decl: declValue`, + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -425,9 +536,11 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node, 'node').to.equal((parsed.ast as any).nodes[0].nodes[0]); - expect(base.offsetInNode, 'offset').to.equal(4); - expect(base.where, 'where').to.eql('declProp'); + expectAstLocation(base, { + node: (parsed.ast as any).nodes[0].nodes[0], + where: 'declProp', + stringify: `decl|: declValue`, + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -442,9 +555,11 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node, 'node').to.equal((parsed.ast as any).nodes[0].nodes[0]); - expect(base.offsetInNode, 'offset').to.equal(5); - expect(base.where, 'where').to.eql('declBetweenPropAndColon'); + expectAstLocation(base, { + node: (parsed.ast as any).nodes[0].nodes[0], + where: 'declBetweenPropAndColon', + stringify: `decl | : declValue`, + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -459,39 +574,51 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node, 'node').to.equal((parsed.ast as any).nodes[0].nodes[0]); - expect(base.offsetInNode, 'offset').to.equal(6); - expect(base.where, 'where').to.eql('declBetweenColonAndValue'); + expectAstLocation(base, { + node: (parsed.ast as any).nodes[0].nodes[0], + where: 'declValue', + stringify: `decl: | declValue`, + }); + // decl-value level + expectAstLocation(declValue!, { + stringify: ' | ', + parents: [ + { + desc: 'decl', + str: 'decl: declValue', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); - expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); }); it(`should find value start`, () => { const { position, parsed } = setupWithCursor(` .selector { - decl1: |bookmark after; + decl1: |bookmark after ; decl2: other; } `); const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node, 'node').to.equal((parsed.ast as any).nodes[0].nodes[0]); - expect(base.offsetInNode, 'offset').to.equal(7); - expect(base.where, 'where').to.eql('declValue'); + expectAstLocation(base, { + node: (parsed.ast as any).nodes[0].nodes[0], + where: 'declValue', + stringify: `decl1: |bookmark after `, + }); // decl-value level - expect(stringifyCSSValue(declValue!.node as any), 'target value node').to.eql( - 'bookmark' - ); - expect(declValue!.offsetInNode).to.eql(0); - assertNodes(declValue!.parents, [ - { - desc: 'value node', - str: 'decl1: bookmark after', - }, - ]); - expect(stringifyCSSValue(declValue!.ast), 'value ast').to.eql('bookmark after'); + expect(stringifyCSSValue(declValue!.ast), 'value ast').to.eql(' bookmark after '); + expectAstLocation(declValue!, { + stringify: ' |', + parents: [ + { + desc: 'value node', + str: 'decl1: bookmark after ', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -506,21 +633,22 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node, 'node').to.equal((parsed.ast as any).nodes[0].nodes[0]); - expect(base.offsetInNode, 'offset').to.equal(18); - expect(base.where, 'where').to.eql('declValue'); + expectAstLocation(base, { + node: (parsed.ast as any).nodes[0].nodes[0], + where: 'declValue', + stringify: `decl1: before book|mark after`, + }); // decl-value level - expect(stringifyCSSValue(declValue!.node as any), 'target value node').to.eql( - 'bookmark' - ); - expect(declValue!.offsetInNode).to.eql(4); - assertNodes(declValue!.parents, [ - { - desc: 'value node', - str: 'decl1: before bookmark after', - }, - ]); - expect(stringifyCSSValue(declValue!.ast), 'value ast').to.eql('before bookmark after'); + expect(stringifyCSSValue(declValue!.ast), 'value ast').to.eql(' before bookmark after'); + expectAstLocation(declValue!, { + stringify: 'book|mark', + parents: [ + { + desc: 'value node', + str: 'decl1: before bookmark after', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -534,27 +662,28 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node, 'node').to.equal((parsed.ast as any).nodes[0].nodes[0]); - expect(base.where, 'where').to.eql('declValue'); - expect(base.offsetInNode, 'offset').to.equal(22); + expectAstLocation(base, { + node: (parsed.ast as any).nodes[0].nodes[0], + where: 'declValue', + stringify: `decl: before nest(book|mark) after`, + }); // decl-value level - expect(stringifyCSSValue(declValue!.node as any), 'target value node').to.eql( - 'bookmark' - ); - expect(declValue!.offsetInNode).to.eql(4); - assertNodes(declValue!.parents, [ - { - desc: 'value node', - str: 'decl: before nest(bookmark) after', - }, - { - desc: 'nest node', - str: 'nest(bookmark)', - }, - ]); expect(stringifyCSSValue(declValue!.ast), 'value ast').to.eql( - 'before nest(bookmark) after' + ' before nest(bookmark) after' ); + expectAstLocation(declValue!, { + stringify: 'book|mark', + parents: [ + { + desc: 'value node', + str: 'decl: before nest(bookmark) after', + }, + { + desc: 'nest node', + str: 'nest(bookmark)', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -562,28 +691,29 @@ describe('ast-from-position', () => { it(`should find value end`, () => { const { position, parsed } = setupWithCursor(` .selector { - decl1: before bookmark|; + decl1: before bookmark| ; decl2: other; } `); const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node, 'node').to.equal((parsed.ast as any).nodes[0].nodes[0]); - expect(base.offsetInNode, 'offset').to.equal(22); - expect(base.where, 'where').to.eql('declValue'); + expectAstLocation(base, { + node: (parsed.ast as any).nodes[0].nodes[0], + where: 'declValue', + stringify: `decl1: before bookmark| `, + }); // decl-value level - expect(stringifyCSSValue(declValue!.node as any), 'target value node').to.eql( - 'bookmark' - ); - expect(declValue!.offsetInNode).to.eql(8); - assertNodes(declValue!.parents, [ - { - desc: 'decl node', - str: 'decl1: before bookmark', - }, - ]); - expect(stringifyCSSValue(declValue!.ast), 'value ast').to.eql('before bookmark'); + expect(stringifyCSSValue(declValue!.ast), 'value ast').to.eql(' before bookmark '); + expectAstLocation(declValue!, { + stringify: 'bookmark|', + parents: [ + { + desc: 'decl node', + str: 'decl1: before bookmark ', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -597,20 +727,25 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node, 'node').to.equal((parsed.ast as any).nodes[0].nodes[0]); - expect(base.offsetInNode, 'offset').to.equal(16); - expect(base.where, 'where').to.eql('declValue'); + expectAstLocation(base, { + node: (parsed.ast as any).nodes[0].nodes[0], + where: 'declValue', + stringify: `decl1: before |`, + }); // decl-value level - expect(stringifyCSSValue(declValue!.node as any), 'target value node').to.eql('before'); - expect(declValue!.afterValue, 'after value').to.eql(true); - expect(declValue!.offsetInNode).to.eql(9); - assertNodes(declValue!.parents, [ - { - desc: 'decl node', - str: 'decl1: before', - }, - ]); - expect(stringifyCSSValue(declValue!.ast), 'value ast').to.eql('before'); + expect(stringifyCSSValue(declValue!.ast), 'value ast').to.eql(' before \t\n'); + expectAstLocation(declValue!, { + stringify: ' | \t\n', + deindent: false, + parents: [ + { + desc: 'decl node', + // postcss stringify doesn't show unclosed after spaces on decl + // they belong in parent rule raws after + str: 'decl1: before', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -627,9 +762,10 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target at-rule node').to.eql('@bookmark params {}'); - expect(base.offsetInNode, 'base offset').to.eql(1); - expect(base.where, 'where').to.eql('atRuleName'); + expectAstLocation(base, { + stringify: '@|bookmark params {}', + where: 'atRuleName', + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -645,13 +781,51 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target at-rule node').to.eql('@bookmark params {}'); - expect(base.offsetInNode, 'base offset').to.eql(9); - expect(base.where, 'where').to.eql('atRuleName'); + expectAstLocation(base, { + stringify: '@bookmark| params {}', + where: 'atRuleName', + }); + // at-rule-params level + expect(stringifyCSSValue(atRuleParams!.ast), 'params ast').to.eql(' params '); + expectAstLocation(atRuleParams!, { + stringify: '| ', + parents: [ + { + desc: 'atRule node', + str: '@bookmark params {}', + }, + ], + }); + // unresolved levels + expect(selector, 'selector').to.eql(undefined); + expect(declValue, 'declValue').to.eql(undefined); + }); + it(`should find between name and params (pre param whitespace)`, () => { + const { position, parsed } = setupWithCursor(` + @name | params {} + `); + + const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); + + // base level + expectAstLocation(base, { + stringify: '@name | params {}', + where: 'atRuleParams', + }); + // atrule-params level + expect(stringifyCSSValue(atRuleParams!.ast), 'params ast').to.eql(' params '); + expectAstLocation(atRuleParams!, { + stringify: ' | ', + parents: [ + { + desc: 'atRule node', + str: '@name params {}', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); - expect(atRuleParams, 'atRuleParams').to.eql(undefined); }); it(`should find params start`, () => { const { position, parsed } = setupWithCursor(` @@ -663,23 +837,21 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target at-rule node').to.eql( - '@name bookmark after {}' - ); - expect(base.offsetInNode, 'base offset').to.eql(6); - expect(base.where, 'where').to.eql('atRuleParams'); + expectAstLocation(base, { + stringify: '@name |bookmark after {}', + where: 'atRuleParams', + }); // atrule-params level - expect(stringifyCSSValue(atRuleParams!.node as any), 'target params node').to.eql( - 'bookmark' - ); - expect(atRuleParams!.offsetInNode).to.eql(0); - assertNodes(atRuleParams!.parents, [ - { - desc: 'rule node', - str: '@name bookmark after {}', - }, - ]); - expect(stringifyCSSValue(atRuleParams!.ast), 'params ast').to.eql('bookmark after'); + expect(stringifyCSSValue(atRuleParams!.ast), 'params ast').to.eql(' bookmark after '); + expectAstLocation(atRuleParams!, { + stringify: ' |', + parents: [ + { + desc: 'rule node', + str: '@name bookmark after {}', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -694,25 +866,23 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target at-rule node').to.eql( - '@name before bookmark after {}' - ); - expect(base.offsetInNode, 'base offset').to.eql(17); - expect(base.where, 'where').to.eql('atRuleParams'); + expectAstLocation(base, { + stringify: '@name before book|mark after {}', + where: 'atRuleParams', + }); // atrule-params level - expect(stringifyCSSValue(atRuleParams!.node as any), 'target params node').to.eql( - 'bookmark' - ); - expect(atRuleParams!.offsetInNode).to.eql(4); - assertNodes(atRuleParams!.parents, [ - { - desc: 'rule node', - str: '@name before bookmark after {}', - }, - ]); expect(stringifyCSSValue(atRuleParams!.ast), 'params ast').to.eql( - 'before bookmark after' + ' before bookmark after ' ); + expectAstLocation(atRuleParams!, { + stringify: 'book|mark', + parents: [ + { + desc: 'rule node', + str: '@name before bookmark after {}', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -727,29 +897,27 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target at-rule node').to.eql( - '@name before nest(bookmark) after {}' - ); - expect(base.offsetInNode, 'base offset').to.eql(22); - expect(base.where, 'where').to.eql('atRuleParams'); + expectAstLocation(base, { + stringify: '@name before nest(book|mark) after {}', + where: 'atRuleParams', + }); // atrule-params level - expect(stringifyCSSValue(atRuleParams!.node as any), 'target params node').to.eql( - 'bookmark' - ); - expect(atRuleParams!.offsetInNode).to.eql(4); - assertNodes(atRuleParams!.parents, [ - { - desc: 'rule node', - str: '@name before nest(bookmark) after {}', - }, - { - desc: 'nest node', - str: 'nest(bookmark)', - }, - ]); expect(stringifyCSSValue(atRuleParams!.ast), 'params ast').to.eql( - 'before nest(bookmark) after' + ' before nest(bookmark) after ' ); + expectAstLocation(atRuleParams!, { + stringify: 'book|mark', + parents: [ + { + desc: 'rule node', + str: '@name before nest(bookmark) after {}', + }, + { + desc: 'nest node', + str: 'nest(bookmark)', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -764,23 +932,21 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target at-rule node').to.eql( - '@name start bookmark {}' - ); - expect(base.offsetInNode, 'base offset').to.eql(20); - expect(base.where, 'where').to.eql('atRuleParams'); + expectAstLocation(base, { + stringify: '@name start bookmark| {}', + where: 'atRuleParams', + }); // atrule-params level - expect(stringifyCSSValue(atRuleParams!.node as any), 'target params node').to.eql( - 'bookmark' - ); - expect(atRuleParams!.offsetInNode).to.eql(8); - assertNodes(atRuleParams!.parents, [ - { - desc: 'rule node', - str: '@name start bookmark {}', - }, - ]); - expect(stringifyCSSValue(atRuleParams!.ast), 'params ast').to.eql('start bookmark'); + expect(stringifyCSSValue(atRuleParams!.ast), 'params ast').to.eql(' start bookmark '); + expectAstLocation(atRuleParams!, { + stringify: 'bookmark|', + parents: [ + { + desc: 'rule node', + str: '@name start bookmark {}', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -795,21 +961,20 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target at-rule node').to.eql('@name params {}'); - expect(base.offsetInNode, 'base offset').to.eql(15); - expect(base.where, 'where').to.eql('atRuleParams'); + expectAstLocation(base, { + stringify: '@name params | {}', + where: 'atRuleParams', + }); // atrule-params level - expect(stringifyCSSValue(atRuleParams!.node as any), 'target params node').to.eql( - 'params' - ); - expect(atRuleParams!.afterValue, 'after params value').to.eql(true); - expect(atRuleParams!.offsetInNode).to.eql(9); - assertNodes(atRuleParams!.parents, [ - { - desc: 'rule node', - str: '@name params {}', - }, - ]); + expectAstLocation(atRuleParams!, { + stringify: ' | ', + parents: [ + { + desc: 'rule node', + str: '@name params {}', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -826,21 +991,49 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target at-rule node').to.eql('@name params '); - expect(base.offsetInNode, 'base offset').to.eql(15); - expect(base.where, 'where').to.eql('atRuleParams'); + expectAstLocation(base, { + stringify: '@name params | ', + where: 'atRuleParams', + }); // atrule-params level - expect(stringifyCSSValue(atRuleParams!.node as any), 'target params node').to.eql( - 'params' - ); - expect(atRuleParams!.afterValue, 'after params value').to.eql(true); - expect(atRuleParams!.offsetInNode).to.eql(9); - assertNodes(atRuleParams!.parents, [ - { - desc: 'rule node', - str: '@name params ', - }, - ]); + expectAstLocation(atRuleParams!, { + stringify: ' | ', + parents: [ + { + desc: 'rule node', + str: '@name params ', + }, + ], + }); + // unresolved levels + expect(selector, 'selector').to.eql(undefined); + expect(declValue, 'declValue').to.eql(undefined); + }); + it(`should find between params and unclosed end`, () => { + const { position, parsed } = setupWithCursor(`@name params | \n\t`, { + deindent: false, + }); + + const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); + + // base level + expectAstLocation(base, { + stringify: '@name params |', + deindent: false, + where: 'atRuleParams', + }); + // atrule-params level + expect(stringifyCSSValue(atRuleParams!.ast), 'params ast').to.eql(' params \n\t'); + expectAstLocation(atRuleParams!, { + stringify: ' | \n\t', + deindent: false, + parents: [ + { + desc: 'rule node', + str: '@name params', + }, + ], + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -854,10 +1047,12 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); - const rule = assertAtRule(parsed.ast.nodes[1]); - expect(base.node, 'node').to.equal(rule); - expect(base.offsetInNode, 'offset').to.eql(11); - expect(base.where, 'where').to.eql('atRuleBody'); + // base level + expectAstLocation(base, { + node: parsed.ast.nodes[1], + where: 'atRuleBody', + stringify: '@x params{ | decl: declValue; }', + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -872,10 +1067,12 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); - const rule = assertAtRule(parsed.ast.nodes[1]); - expect(base.node, 'node').to.equal(rule); - expect(base.offsetInNode, 'offset').to.eql(27); - expect(base.where, 'where').to.eql('atRuleBody'); + // base level + expectAstLocation(base, { + node: parsed.ast.nodes[1], + where: 'atRuleBody', + stringify: '@x params { decl1: before; | decl2: after }', + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -890,10 +1087,12 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); - const rule = assertAtRule(parsed.ast.nodes[1]); - expect(base.node, 'node').to.equal(rule); - expect(base.offsetInNode, 'offset').to.eql(26); - expect(base.where, 'where').to.eql('atRuleBody'); + // base level + expectAstLocation(base, { + node: parsed.ast.nodes[1], + where: 'atRuleBody', + stringify: '@x params { decl: before; | }', + }); // unresolved levels expect(selector, 'selector').to.eql(undefined); expect(declValue, 'declValue').to.eql(undefined); @@ -909,36 +1108,35 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target at-rule node').to.eql( - '@st-scope .before.bookmark.after {}' - ); - expect(base.offsetInNode, 'base offset').to.eql(22); - expect(base.where, 'where').to.eql('atRuleParams'); + expectAstLocation(base, { + stringify: '@st-scope .before.book|mark.after {}', + where: 'atRuleParams', + }); // atrule-params level - expect(stringifyCSSValue(atRuleParams!.node as any), 'target params node').to.eql( - 'bookmark' - ); - expect(atRuleParams!.offsetInNode).to.eql(4); - assertNodes(atRuleParams!.parents, [ - { - desc: 'rule node', - str: '@st-scope .before.bookmark.after {}', - }, - ]); + expectAstLocation(atRuleParams!, { + stringify: 'book|mark', + parents: [ + { + desc: 'rule node', + str: '@st-scope .before.bookmark.after {}', + }, + ], + }); // selector level - expect(stringifySelectorAst(selector!.node), 'target class node').to.eql('.bookmark'); expect(selector!.afterSelector, 'after selector').to.eql(false); - expect(selector!.offsetInNode).to.eql(5); - assertNodes(selector!.parents, [ - { - desc: 'st-scope atrule node', - str: '@st-scope .before.bookmark.after {}', - }, - { - desc: 'top selector node', - str: '.before.bookmark.after', - }, - ]); + expectAstLocation(selector!, { + stringify: '.book|mark', + parents: [ + { + desc: 'st-scope atrule node', + str: '@st-scope .before.bookmark.after {}', + }, + { + desc: 'top selector node', + str: '.before.bookmark.after', + }, + ], + }); // unresolved levels expect(declValue, 'declValue').to.eql(undefined); }); @@ -953,27 +1151,30 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target class node').to.eql('.before.bookmark.after'); - expect(base.offsetInNode, 'base offset').to.eql(12); - expect(base.where, 'where').to.eql('invalid'); + expectAstLocation(base, { + stringify: '.before.book|mark.after', + where: 'invalid', + }); + // selector level - expect(stringifySelectorAst(selector!.node), 'target class node').to.eql('.bookmark'); expect(selector!.afterSelector, 'after selector').to.eql(false); - expect(selector!.offsetInNode).to.eql(5); - assertNodes(selector!.parents, [ - { - desc: 'invalid node', - type: 'invalid', - str: deindent(` - .before.bookmark.after - `), - }, - { - desc: 'top selector node', - type: 'selector', - str: '.before.bookmark.after', - }, - ]); + expectAstLocation(selector!, { + stringify: '.book|mark', + parents: [ + { + desc: 'invalid node', + type: 'invalid', + str: deindent(` + .before.bookmark.after + `), + }, + { + desc: 'top selector node', + type: 'selector', + str: '.before.bookmark.after', + }, + ], + }); // unresolved levels expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -987,26 +1188,30 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node, 'node').to.equal((parsed.ast as any).nodes[0].nodes[0]); expect(base.node.type, 'base node type').to.equal('invalid'); - expect(base.offsetInNode, 'offset').to.equal(4); - expect(base.where, 'where').to.eql('invalid'); + expectAstLocation(base, { + node: (parsed.ast as any).nodes[0].nodes[0], + where: 'invalid', + stringify: 'book|mark\n', + deindent: false, + }); // selector level - expect(stringifySelectorAst(selector!.node), 'target selector node').to.eql('bookmark'); expect(selector!.afterSelector, 'after selector').to.eql(false); - expect(selector!.offsetInNode).to.eql(4); - assertNodes(selector!.parents, [ - { - desc: 'potential invalid rule', - type: 'invalid', - str: 'bookmark\n', - }, - { - desc: 'top selector node', - type: 'selector', - str: 'bookmark\n', - }, - ]); + expectAstLocation(selector!, { + stringify: 'book|mark', + parents: [ + { + desc: 'potential invalid rule', + type: 'invalid', + str: 'bookmark\n', + }, + { + desc: 'top selector node', + type: 'selector', + str: 'bookmark\n', + }, + ], + }); // unresolved levels expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); @@ -1020,35 +1225,38 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node, 'node').to.equal((parsed.ast as any).nodes[0].nodes[0]); - expect(base.offsetInNode, 'offset').to.equal(10); - expect(base.where, 'where').to.eql('declValue'); + expectAstLocation(base, { + node: (parsed.ast as any).nodes[0].nodes[0], + where: 'declValue', + stringify: 'color: gre|en', + }); // decl-value level - expect(stringifyCSSValue(declValue!.node as any), 'target value node').to.eql('green'); - expect(declValue!.offsetInNode).to.eql(3); - assertNodes(declValue!.parents, [ - { - desc: 'decl node', - type: 'decl', - str: 'color: green', - }, - ]); - expect(stringifyCSSValue(declValue!.ast), 'value ast').to.eql('green'); + expectAstLocation(declValue!, { + stringify: 'gre|en', + parents: [ + { + desc: 'decl node', + type: 'decl', + str: 'color: green', + }, + ], + }); // selector level - expect(stringifySelectorAst(selector!.node), 'target class node').to.eql('green'); expect(selector!.afterSelector, 'after selector').to.eql(false); - expect(selector!.offsetInNode).to.eql(3); - assertNodes(selector!.parents, [ - { - desc: 'decl node', - type: 'decl', - str: 'color: green', - }, - { - desc: 'top selector node', - str: 'color: green', - }, - ]); + expectAstLocation(selector!, { + stringify: 'gre|en', + parents: [ + { + desc: 'decl node', + type: 'decl', + str: 'color: green', + }, + { + desc: 'top selector node', + str: 'color: green', + }, + ], + }); // unresolved levels expect(atRuleParams, 'atRuleParams').to.eql(undefined); }); @@ -1060,25 +1268,74 @@ describe('ast-from-position', () => { const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); // base level - expect(base.node.toString(), 'base target invalid node').to.eql('.before \t'); - expect(base.offsetInNode, 'base offset').to.eql(10); - expect(base.where, 'where').to.eql('invalid'); + expectAstLocation(base, { + stringify: '.before | \t', + where: 'invalid', + }); // selector level - expect(stringifySelectorAst(selector!.node), 'target selector').to.eql( - '.before \t' - ); expect(selector!.afterSelector, 'after selector').to.eql(true); - expect(selector!.offsetInNode).to.eql(10); - assertNodes(selector!.parents, [ - { - desc: 'invalid node', - type: 'invalid', - str: '.before \t', - }, - ]); + expectAstLocation(selector!, { + stringify: '.before | \t', + parents: [ + { + desc: 'invalid node', + type: 'invalid', + str: '.before \t', + }, + ], + }); // unresolved levels expect(declValue, 'declValue').to.eql(undefined); expect(atRuleParams, 'atRuleParams').to.eql(undefined); }); + it('should get unclosed at-rule cursor at name', () => { + const { position, parsed } = setupWithCursor(`@bookmark|`); + + const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); + + // base level + expectAstLocation(base, { + stringify: '@bookmark|', + where: 'atRuleName', + }); + // atrule-params level + expectAstLocation(atRuleParams!, { + stringify: '|', + parents: [ + { + desc: 'atrule node', + str: '@bookmark', + }, + ], + }); + // unresolved levels + expect(selector, 'selector').to.eql(undefined); + expect(declValue, 'declValue').to.eql(undefined); + }); + it('should get unclosed at-rule cursor empty params', () => { + const { position, parsed } = setupWithCursor(`@bookmark |`); + + const { base, selector, declValue, atRuleParams } = getAstNodeAt(parsed, position); + + // base level + expectAstLocation(base, { + stringify: '@bookmark |', + where: 'atRuleParams', + }); + // atrule-params level + expect(stringifyCSSValue(atRuleParams!.ast), 'params ast').to.eql(' '); + expectAstLocation(atRuleParams!, { + stringify: ' |', + parents: [ + { + desc: 'rule node', + str: '@bookmark ', + }, + ], + }); + // unresolved levels + expect(selector, 'selector').to.eql(undefined); + expect(declValue, 'declValue').to.eql(undefined); + }); }); }); diff --git a/packages/language-service/test/lib-new/edit-time-parser.spec.ts b/packages/language-service/test/lib-new/edit-time-parser.spec.ts index 674521f7f2..b314a03aa1 100644 --- a/packages/language-service/test/lib-new/edit-time-parser.spec.ts +++ b/packages/language-service/test/lib-new/edit-time-parser.spec.ts @@ -43,7 +43,7 @@ describe('edit-time-parser', () => { const invalid = assertInvalid(ast.nodes[0]); expect(invalid.assume, 'assume').to.eql(new Set(['rule'])); expect(errorNodes.get(invalid), 'errors').to.eql([ERRORS.RULE_MISSING_OPEN]); - expect(ast.source!.end!.offset, 'top end').to.eql(2); + expect(ast.source!.end!.offset, 'top end').to.eql(3); }); it('should assume last-no-semicolon declaration as potential unopened rule', () => { /** @@ -292,7 +292,7 @@ describe('edit-time-parser', () => { ERRORS.ATRULE_MISSING_NAME, ]); }); - it('should handle unclosed at-rule', () => { + it('should handle unclosed at-rule (open body without close)', () => { const { ast, errorNodes } = safeParse(` @xxx abc { `); @@ -306,6 +306,17 @@ describe('edit-time-parser', () => { }); expect(errorNodes.get(unclosed), 'errors').to.eql([ERRORS.MISSING_CLOSE]); }); + it('should handle unclosed at-rule (no body or semicolon)', () => { + const { ast } = parseForEditing(`@xxx abc \t\t\t`); + + expect(ast.toString(), 'stringify').to.equal('@xxx abc \t\t\t'); + const unclosed = assertAtRule(ast.nodes[0]); + expect(unclosed, 'node').to.include({ + name: 'xxx', + params: 'abc', + }); + expect(ast.source!.end!.offset, 'close parent with extra space').to.eql(12); + }); it('should keep track of end of source for unclosed nested nodes', () => { const { ast } = safeParse(` @xxx abc { @@ -317,9 +328,14 @@ describe('edit-time-parser', () => { const atrule = assertAtRule(ast.nodes[0]); const rule = assertRule(atrule.nodes[0]); const invalid = assertInvalid(rule.nodes[0]); - expect(atrule.source!.end!, 'atrule').to.eql(ast.source!.end); - expect(rule.source!.end!, 'rule').to.eql(ast.source!.end); - expect(invalid.source!.end!, 'decl').to.eql(ast.source!.end); + /** + * ToDo(fix): ast.end.column should be 11 (not 12) + * this is a postcss bug that is caused by calculating the root + * end with the next non existing position + */ + expect(atrule.source!.end!.offset, 'atrule').to.eql(ast.source!.end!.offset); + expect(rule.source!.end!.offset, 'rule').to.eql(ast.source!.end!.offset); + expect(invalid.source!.end!.offset, 'decl').to.eql(ast.source!.end!.offset); }); it('should handle unclosed comment', () => { const { ast, errorNodes, ambiguousNodes } = safeParse(` diff --git a/packages/language-service/test/lib-new/features/ls-css-pseudo-class.spec.ts b/packages/language-service/test/lib-new/features/ls-css-pseudo-class.spec.ts index c7c85f91f3..7215ba238f 100644 --- a/packages/language-service/test/lib-new/features/ls-css-pseudo-class.spec.ts +++ b/packages/language-service/test/lib-new/features/ls-css-pseudo-class.spec.ts @@ -1,31 +1,137 @@ +import { Command } from 'vscode-languageserver'; import { testLangService } from '../../test-kit/test-lang-service'; +import { createTempDirectorySync } from '@stylable/core-test-kit'; + +const triggerCompletion = Command.create('additional', 'editor.action.triggerSuggest'); +const triggerParameterHints = Command.create('additional', 'editor.action.triggerParameterHints'); describe('LS: css-pseudo-class', () => { - it('should suggest root custom states', () => { - const { service, carets, assertCompletions } = testLangService(` - .root { - -st-states: aaa,bbb; + it('should suggest class custom states', () => { + const { service, assertCompletions } = testLangService(` + .x { + -st-states: xxx; + } + .y { + -st-states: yyy; + } + .z { + -st-states: aaa, bbb; } - .root^afterRoot^ {} + .z^afterRoot^ {} - ^empty^ {} + .z:a^partial^ {} + .z .x^complex^ .y {} `); - const entryCarets = carets['/entry.st.css']; + const entryPath = '/entry.st.css'; - assertCompletions({ - actualList: service.onCompletion('/entry.st.css', entryCarets.afterRoot), + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'classes states', + actualList: service.onCompletion(filePath, carets.afterRoot), expectedList: [{ label: ':aaa' }, { label: ':bbb' }], - }); + unexpectedList: [{ label: ':xxx' }, { label: ':yyy' }], + })); + + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ + message: 'partial', + actualList: service.onCompletion(filePath, carets.partial), + expectedList: [ + { + label: ':aaa', + textEdit: replaceText(carets.partial, ':aaa', { deltaStart: -2 }), + }, + ], + unexpectedList: [{ label: ':bbb' }], + })); + + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ + message: 'complex selector', + actualList: service.onCompletion(filePath, carets.partial), + expectedList: [ + { + label: ':aaa', + textEdit: replaceText(carets.partial, ':aaa', { deltaStart: -2 }), + }, + ], + unexpectedList: [{ label: ':bbb' }], + })); + }); + it('should suggest root custom states in empty selector', () => { + // ToDo: once experimentalSelectorInference is on this should not behave like this + const { service, assertCompletions } = testLangService(` + .root { + -st-states: aaa, bbb; + } + + ^empty^ {} + `); + const entryPath = '/entry.st.css'; - assertCompletions({ - actualList: service.onCompletion('/entry.st.css', entryCarets.empty), + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'empty', + actualList: service.onCompletion(filePath, carets.empty), expectedList: [{ label: ':aaa' }, { label: ':bbb' }], - }); + })); + }); + it('should NOT suggest used states', () => { + const { service, assertCompletions } = testLangService(` + .x { + -st-states: aaa, bbb; + } + + .x:aaa^afterExistingState^ {} + `); + const entryPath = '/entry.st.css'; + + assertCompletions(entryPath, ({ filePath, carets }) => ({ + actualList: service.onCompletion(filePath, carets.afterExistingState), + expectedList: [{ label: ':bbb' }], + unexpectedList: [{ label: ':aaa' }], + })); + }); + it('should suggest pseudo-element custom states', () => { + const { service, assertCompletions } = testLangService(` + .root {} + .part { + -st-states: aaa, bbb; + } + + .root::part^afterPseudoElement^ {} + `); + const entryPath = '/entry.st.css'; + + assertCompletions(entryPath, ({ filePath, carets }) => ({ + actualList: service.onCompletion(filePath, carets.afterPseudoElement), + expectedList: [{ label: ':aaa' }, { label: ':bbb' }], + })); + }); + it('should suggest states from extended class', () => { + const { service, assertCompletions } = testLangService(` + .y { + -st-states: aaa, bbb; + } + .x { + -st-extends: y; + -st-states: ccc, ddd; + } + + .x^afterClass^ {} + `); + const entryPath = '/entry.st.css'; + + assertCompletions(entryPath, ({ filePath, carets }) => ({ + actualList: service.onCompletion(filePath, carets.afterClass), + expectedList: [ + { label: ':aaa' }, + { label: ':bbb' }, + { label: ':ccc' }, + { label: ':ddd' }, + ], + })); }); it('should provide nested context', () => { - const { service, carets, assertCompletions } = testLangService(` + const { service, assertCompletions } = testLangService(` .root { -st-states: rrr; } @@ -49,32 +155,137 @@ describe('LS: css-pseudo-class', () => { } `); - const entryCarets = carets['/entry.st.css']; - assertCompletions({ + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ message: 'nestRoot', - actualList: service.onCompletion('/entry.st.css', entryCarets.nestRoot), + actualList: service.onCompletion(filePath, carets.nestRoot), expectedList: [{ label: ':rrr' }], unexpectedList: [{ label: ':aaa' }, { label: ':bbb' }], - }); + })); - assertCompletions({ + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ message: 'nestA', - actualList: service.onCompletion('/entry.st.css', entryCarets.nestA), + actualList: service.onCompletion(filePath, carets.nestA), expectedList: [{ label: ':aaa' }], unexpectedList: [{ label: ':rrr' }, { label: ':bbb' }], - }); + })); - assertCompletions({ + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ message: 'nestB', - actualList: service.onCompletion('/entry.st.css', entryCarets.nestB), + actualList: service.onCompletion(filePath, carets.nestB), expectedList: [{ label: ':bbb' }], unexpectedList: [{ label: ':rrr' }, { label: ':aaa' }], + })); + }); + it('should NOT suggest states after ::', () => { + const { service, assertCompletions } = testLangService(` + .x { + -st-states: aaa, bbb; + } + + .x::^afterDoubleColon^ {} + `); + const entryPath = '/entry.st.css'; + + assertCompletions(entryPath, ({ filePath, carets }) => ({ + actualList: service.onCompletion(filePath, carets.afterDoubleColon), + unexpectedList: [{ label: ':aaa' }, { label: ':bbb' }], + })); + }); + describe.skip('definition', () => { + /*ToDo: move tests when implementation is refactored*/ + }); + describe('state with param', () => { + it('should suggest state with parenthesis', () => { + const { service, assertCompletions } = testLangService(` + .x { + -st-states: + word(string), + size(enum(small, big)); + } + + .x^afterClass^ {} + `); + const entryPath = '/entry.st.css'; + + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ + actualList: service.onCompletion(filePath, carets.afterClass), + expectedList: [ + { + label: ':word()', + textEdit: replaceText(carets.afterClass, ':word($1)'), + command: triggerParameterHints, + }, + { + label: ':size()', + textEdit: replaceText(carets.afterClass, ':size($1)'), + command: triggerCompletion, + }, + ], + })); + }); + it('should suggest enum possible parameters', () => { + // ToDo: prevent names native css lsp from suggesting inside states definitions. + // because native css lsp is returning results that mix with fixture + // (everything is with prefixed with 'x') + const { service, assertCompletions } = testLangService(` + .root { + -st-states: + size(enum(xsmall, xmedium, xbig, xbigger)), + type(enum(shirt, hat)); + } + .partA {} + + .root:size(^emptyEnumParam^) {} + + .root:size(xb^partialEnumParam^) {} + `); + const entryPath = '/entry.st.css'; + + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'empty param', + actualList: service.onCompletion(filePath, carets.emptyEnumParam), + expectedList: [ + { label: 'xsmall' }, + { label: 'xmedium' }, + { label: 'xbig' }, + { label: 'xbigger' }, + ], + unexpectedList: [ + // no selector completions + // ToDo: normalize provider API + { label: ':size' }, + { label: ':type' }, + { label: '::partA' }, + { label: ':global()' }, + // ToDo: disable native-css-lsp in this context: { label: '.partA' }, + ], + })); + + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ + message: 'partial param', + actualList: service.onCompletion(filePath, carets.partialEnumParam), + expectedList: [ + { + label: 'xbig', + textEdit: replaceText(carets.partialEnumParam, 'xbig', { + deltaStart: -2, + }), + }, + { + label: 'xbigger', + textEdit: replaceText(carets.partialEnumParam, 'xbigger', { + deltaStart: -2, + }), + }, + ], + unexpectedList: [{ label: 'xsmall' }, { label: 'xmedium' }], + })); }); }); describe('st-scope', () => { it('should suggest class custom states (in st-scope params)', () => { - const { service, carets, assertCompletions } = testLangService(` + const { service, assertCompletions } = testLangService(` .root { -st-states: aaa,bbb; } @@ -84,20 +295,19 @@ describe('LS: css-pseudo-class', () => { @st-scope ^empty^ {} `); - const entryCarets = carets['/entry.st.css']; - assertCompletions({ - actualList: service.onCompletion('/entry.st.css', entryCarets.afterRoot), + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ + actualList: service.onCompletion(filePath, carets.afterRoot), expectedList: [{ label: ':aaa' }, { label: ':bbb' }], - }); + })); - assertCompletions({ - actualList: service.onCompletion('/entry.st.css', entryCarets.empty), + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ + actualList: service.onCompletion(filePath, carets.empty), expectedList: [{ label: ':aaa' }, { label: ':bbb' }], - }); + })); }); it('should suggest class custom states with nesting selector', () => { - const { service, carets, assertCompletions, textEditContext } = testLangService(` + const { service, assertCompletions } = testLangService(` .x { -st-states: aaa,bbb; } @@ -115,57 +325,61 @@ describe('LS: css-pseudo-class', () => { } } `); - const entryCarets = carets['/entry.st.css']; - const { replaceText } = textEditContext('/entry.st.css'); - assertCompletions({ + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ message: 'after &', - actualList: service.onCompletion('/entry.st.css', entryCarets.nest), + actualList: service.onCompletion(filePath, carets.nest), expectedList: [{ label: ':aaa' }, { label: ':bbb' }], - }); + })); - assertCompletions({ + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ message: 'after & in media', - actualList: service.onCompletion('/entry.st.css', entryCarets.nestInMedia), + actualList: service.onCompletion(filePath, carets.nestInMedia), expectedList: [{ label: ':aaa' }, { label: ':bbb' }], - }); - - assertCompletions({ - message: 'after &:', - actualList: service.onCompletion('/entry.st.css', entryCarets.nestColon), - expectedList: [ - { - label: ':aaa', - textEdit: replaceText(entryCarets.nestColon, ':aaa', { deltaStart: -1 }), - }, - { - label: ':bbb', - textEdit: replaceText(entryCarets.nestColon, ':bbb', { deltaStart: -1 }), - }, - ], - }); - - assertCompletions({ - message: 'after &: in media', - actualList: service.onCompletion('/entry.st.css', entryCarets.nestColonInMedia), - expectedList: [ - { - label: ':aaa', - textEdit: replaceText(entryCarets.nestColonInMedia, ':aaa', { - deltaStart: -1, - }), - }, - { - label: ':bbb', - textEdit: replaceText(entryCarets.nestColonInMedia, ':bbb', { - deltaStart: -1, - }), - }, - ], - }); + })); + + assertCompletions( + '/entry.st.css', + ({ filePath, carets, textEdit: { replaceText } }) => ({ + message: 'after &:', + actualList: service.onCompletion(filePath, carets.nestColon), + expectedList: [ + { + label: ':aaa', + textEdit: replaceText(carets.nestColon, ':aaa', { deltaStart: -1 }), + }, + { + label: ':bbb', + textEdit: replaceText(carets.nestColon, ':bbb', { deltaStart: -1 }), + }, + ], + }) + ); + + assertCompletions( + '/entry.st.css', + ({ filePath, carets, textEdit: { replaceText } }) => ({ + message: 'after &: in media', + actualList: service.onCompletion(filePath, carets.nestColonInMedia), + expectedList: [ + { + label: ':aaa', + textEdit: replaceText(carets.nestColonInMedia, ':aaa', { + deltaStart: -1, + }), + }, + { + label: ':bbb', + textEdit: replaceText(carets.nestColonInMedia, ':bbb', { + deltaStart: -1, + }), + }, + ], + }) + ); }); it('should suggest root custom states an empty nested selector', () => { - const { service, carets, assertCompletions, textEditContext } = testLangService(` + const { service, assertCompletions } = testLangService(` .root { -st-states: root-state; } @@ -186,59 +400,65 @@ describe('LS: css-pseudo-class', () => { } } `); - const entryCarets = carets['/entry.st.css']; - const { replaceText } = textEditContext('/entry.st.css'); - assertCompletions({ + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ message: 'empty', - actualList: service.onCompletion('/entry.st.css', entryCarets.empty), + actualList: service.onCompletion(filePath, carets.empty), expectedList: [{ label: ':root-state' }], unexpectedList: [{ label: ':aaa' }, { label: ':bbb' }], - }); + })); - assertCompletions({ + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ message: 'empty in media', - actualList: service.onCompletion('/entry.st.css', entryCarets.emptyInMedia), + actualList: service.onCompletion(filePath, carets.emptyInMedia), expectedList: [{ label: ':root-state' }], unexpectedList: [{ label: ':aaa' }, { label: ':bbb' }], - }); - - assertCompletions({ - message: 'colon', - actualList: service.onCompletion('/entry.st.css', entryCarets.colon), - expectedList: [ - { - label: ':root-state', - textEdit: replaceText(entryCarets.colon, ':root-state', { - deltaStart: -1, - }), - }, - ], - unexpectedList: [{ label: ':aaa' }, { label: ':bbb' }], - }); - - assertCompletions({ - message: 'colonInMedia', - actualList: service.onCompletion('/entry.st.css', entryCarets.colonInMedia), - expectedList: [ - { - label: ':root-state', - textEdit: replaceText(entryCarets.colonInMedia, ':root-state', { - deltaStart: -1, - }), - }, - ], - unexpectedList: [{ label: ':aaa' }, { label: ':bbb' }], - }); + })); + + assertCompletions( + '/entry.st.css', + ({ filePath, carets, textEdit: { replaceText } }) => ({ + message: 'colon', + actualList: service.onCompletion(filePath, carets.colon), + expectedList: [ + { + label: ':root-state', + textEdit: replaceText(carets.colon, ':root-state', { + deltaStart: -1, + }), + }, + ], + unexpectedList: [{ label: ':aaa' }, { label: ':bbb' }], + }) + ); + + assertCompletions( + '/entry.st.css', + ({ filePath, carets, textEdit: { replaceText } }) => ({ + message: 'colonInMedia', + actualList: service.onCompletion(filePath, carets.colonInMedia), + expectedList: [ + { + label: ':root-state', + textEdit: replaceText(carets.colonInMedia, ':root-state', { + deltaStart: -1, + }), + }, + ], + unexpectedList: [{ label: ':aaa' }, { label: ':bbb' }], + }) + ); }); it('should suggest matching intersection states', () => { - const { service, carets, assertCompletions, textEditContext } = testLangService({ - 'comp.st.css': ` + const tempDir = createTempDirectorySync('lps-import-test-'); + const { service, assertCompletions, fs } = testLangService( + { + 'comp.st.css': ` .root { -st-states: comp-state; } `, - 'entry.st.css': ` + 'entry.st.css': ` @st-import Comp from './comp.st.css'; .root { -st-extends: Comp; @@ -259,32 +479,33 @@ describe('LS: css-pseudo-class', () => { } `, - }); - const entryCarets = carets['/entry.st.css']; - const { replaceText } = textEditContext('/entry.st.css'); + }, + { testOnNativeFileSystem: tempDir.path } + ); + const entryPath = fs.join(tempDir.path, 'entry.st.css'); - assertCompletions({ - actualList: service.onCompletion('/entry.st.css', entryCarets.inScope), + assertCompletions(entryPath, ({ filePath, carets }) => ({ + actualList: service.onCompletion(filePath, carets.inScope), expectedList: [{ label: ':root-state' }, { label: ':comp-state' }], unexpectedList: [{ label: ':shared' }, { label: ':onlyA' }, { label: ':onlyB' }], - }); + })); - assertCompletions({ - actualList: service.onCompletion('/entry.st.css', entryCarets.nest), + assertCompletions(entryPath, ({ filePath, carets }) => ({ + actualList: service.onCompletion(filePath, carets.nest), expectedList: [{ label: ':shared' }], unexpectedList: [ { label: ':onlyA' }, { label: ':onlyB' }, { label: ':root-state' }, ], - }); + })); - assertCompletions({ - actualList: service.onCompletion('/entry.st.css', entryCarets.nestColon), + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ + actualList: service.onCompletion(filePath, carets.nestColon), expectedList: [ { label: ':shared', - textEdit: replaceText(entryCarets.nestColon, ':shared', { + textEdit: replaceText(carets.nestColon, ':shared', { deltaStart: -1, }), }, @@ -294,12 +515,12 @@ describe('LS: css-pseudo-class', () => { { label: ':onlyB' }, { label: ':root-state' }, ], - }); + })); }); }); describe('nesting', () => { it('should infer nest from parent nesting selector', () => { - const { service, carets, assertCompletions } = testLangService(` + const { service, assertCompletions } = testLangService(` .root { -st-states: root-state; } @@ -324,26 +545,181 @@ describe('LS: css-pseudo-class', () => { } } `); - const entryCarets = carets['/entry.st.css']; - assertCompletions({ + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ message: 'nest', - actualList: service.onCompletion('/entry.st.css', entryCarets.nest), + actualList: service.onCompletion(filePath, carets.nest), expectedList: [{ label: ':part-state' }], unexpectedList: [{ label: ':root-state' }], - }); - assertCompletions({ + })); + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ message: 'doubleNest', - actualList: service.onCompletion('/entry.st.css', entryCarets.doubleNest), + actualList: service.onCompletion(filePath, carets.doubleNest), expectedList: [{ label: ':part-state' }], unexpectedList: [{ label: ':root-state' }], - }); - assertCompletions({ + })); + assertCompletions('/entry.st.css', ({ filePath, carets }) => ({ message: 'nestUnderNonAmp', - actualList: service.onCompletion('/entry.st.css', entryCarets.nestUnderNonAmp), + actualList: service.onCompletion(filePath, carets.nestUnderNonAmp), expectedList: [{ label: ':root-state' }], unexpectedList: [{ label: ':part-state' }], - }); + })); + }); + }); + describe('st-import', () => { + let tempDir: ReturnType; + beforeEach('crate temp dir', () => { + tempDir = createTempDirectorySync('lps-import-test-'); + }); + afterEach('remove temp dir', () => { + tempDir.remove(); + }); + it('should suggest states from imported class', () => { + const { service, assertCompletions, fs } = testLangService( + { + 'origin.st.css': ` + .root { + -st-states: stateX; + } + .part { + -st-states: stateY; + } + `, + 'entry.st.css': ` + @st-import Root, [part] from './origin.st.css'; + + .extendingDefault { + -st-extends: Root; + -st-states: stateR; + } + .extendingNamed { + -st-extends: part; + -st-states: stateZ; + } + + .Root^defaultClass^ {} + .part^namedClass^ {} + .extendingDefault^extendingDefault^ {} + .extendingNamed^extendingClass^ {} + `, + }, + { testOnNativeFileSystem: tempDir.path } + ); + const entryPath = fs.join(tempDir.path, 'entry.st.css'); + + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'default class', + actualList: service.onCompletion(filePath, carets.defaultClass), + expectedList: [{ label: ':stateX' }], + unexpectedList: [{ label: ':stateY' }, { label: ':stateZ' }, { label: ':stateR' }], + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'named class', + actualList: service.onCompletion(filePath, carets.namedClass), + expectedList: [{ label: ':stateY' }], + unexpectedList: [{ label: ':stateX' }, { label: ':stateZ' }, { label: ':stateR' }], + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'extending default (root)', + actualList: service.onCompletion(filePath, carets.extendingDefault), + expectedList: [{ label: ':stateX' }, { label: ':stateR' }], + unexpectedList: [{ label: ':stateY' }, { label: ':stateZ' }], + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'extending named', + actualList: service.onCompletion(filePath, carets.extendingClass), + expectedList: [{ label: ':stateY' }, { label: ':stateZ' }], + unexpectedList: [{ label: ':stateX' }, { label: ':stateR' }], + })); + }); + it('should suggest states for pseudo-elements', () => { + const { service, assertCompletions, fs } = testLangService( + { + 'part-base.st.css': ` + .root { + -st-states: yyy; + } + .base { + -st-states: xxx; + } + `, + 'comp.st.css': ` + @st-import PartBase from './part-base.st.css'; + .root { + -st-states: root-state; + } + .part { + -st-extends: PartBase; + -st-states: part-state, another-part-state; + } + `, + 'entry.st.css': ` + @st-import Comp from './comp.st.css'; + + .extending { + -st-extends: Comp; + -st-states: xxx; + } + + .extending::part^afterPseudoElement^ {} + + .extending::part:another-part-state:^afterUsedState^ {} + + .extending:xxx::part:another-part-state:yyy::base:^inDeepPseudoElement^ {} + `, + }, + { testOnNativeFileSystem: tempDir.path } + ); + const entryPath = fs.join(tempDir.path, 'entry.st.css'); + + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'after pseudo element', + actualList: service.onCompletion(filePath, carets.afterPseudoElement), + expectedList: [{ label: ':part-state' }, { label: ':another-part-state' }], + unexpectedList: [{ label: ':root-state' }], + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'after existing state', + actualList: service.onCompletion(filePath, carets.afterUsedState), + expectedList: [{ label: ':part-state' }], + unexpectedList: [{ label: ':root-state' }, { label: ':another-part-state' }], + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'after 2 levels of pseudo-elements', + actualList: service.onCompletion(filePath, carets.inDeepPseudoElement), + expectedList: [{ label: ':xxx' }], + })); + }); + it('should suggest enum possible parameters', () => { + const { service, assertCompletions, fs } = testLangService( + { + 'origin.st.css': ` + .root { + -st-states: type(enum(shirt, hat)); + } + `, + 'entry.st.css': ` + @st-import Root from './origin.st.css'; + + .Root:type(^empty^) {} + .Root:type(sh^partial^) {} + `, + }, + { testOnNativeFileSystem: tempDir.path } + ); + const entryPath = fs.join(tempDir.path, 'entry.st.css'); + + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'empty', + actualList: service.onCompletion(filePath, carets.empty), + expectedList: [{ label: 'shirt' }, { label: 'hat' }], + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'partial', + actualList: service.onCompletion(filePath, carets.partial), + expectedList: [{ label: 'shirt' }], + unexpectedList: [{ label: 'hat' }], + })); }); }); }); diff --git a/packages/language-service/test/lib-new/features/ls-st-import.spec.ts b/packages/language-service/test/lib-new/features/ls-st-import.spec.ts index caeee38da2..ad94d2ec77 100644 --- a/packages/language-service/test/lib-new/features/ls-st-import.spec.ts +++ b/packages/language-service/test/lib-new/features/ls-st-import.spec.ts @@ -1,4 +1,5 @@ import { createDefaultResolver } from '@stylable/core'; +import { CSSClass } from '@stylable/core/dist/index-internal'; import { createTempDirectorySync } from '@stylable/core-test-kit'; import { testLangService } from '../../test-kit/test-lang-service'; import { stImportNamedCompletion } from '@stylable/language-service/dist/lib/completion-types'; @@ -18,7 +19,7 @@ describe('LS: st-import', () => { it('should suggest @st-import at top level', () => { // ToDo: refactor code to be handled as part of the st-import feature // and use new ls-context instead of TopLevelDirectiveProvider - const { service, carets, assertCompletions, fs, textEditContext } = testLangService( + const { service, assertCompletions, fs } = testLangService( { 'a.st.css': ` ^topLevel^ @@ -47,53 +48,97 @@ describe('LS: st-import', () => { const aPath = fs.join(tempDir.path, 'a.st.css'); const bPath = fs.join(tempDir.path, 'b.st.css'); const cPath = fs.join(tempDir.path, 'c.st.css'); - const aCarets = carets[aPath]; - const bCarets = carets[bPath]; - const cCarets = carets[cPath]; - const { replaceText: bReplaceText } = textEditContext(bPath); - assertCompletions({ + assertCompletions(aPath, ({ filePath, carets }) => ({ message: 'top-level', - actualList: service.onCompletion(aPath, aCarets.topLevel), + actualList: service.onCompletion(filePath, carets.topLevel), expectedList: [{ label: '@st-import' }], - }); - assertCompletions({ + })); + assertCompletions(bPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ message: 'partial', - actualList: service.onCompletion(bPath, bCarets.partial), + actualList: service.onCompletion(filePath, carets.partial), expectedList: [ { label: '@st-import', - textEdit: bReplaceText(bCarets.partial, `@st-import $2 from "$1";`, { + textEdit: replaceText(carets.partial, `@st-import $2 from "$1";`, { deltaStart: -3, }), }, ], - }); - assertCompletions({ + })); + assertCompletions(cPath, ({ filePath, carets }) => ({ message: 'nested-in-rule', - actualList: service.onCompletion(cPath, cCarets.nestedInRule), + actualList: service.onCompletion(filePath, carets.nestedInRule), unexpectedList: [{ label: '@st-import' }], - }); + })); // ToDo: remove specific at-rules handling - @st-import should only be top level - assertCompletions({ + assertCompletions(cPath, ({ filePath, carets }) => ({ message: 'nested-in-media', - actualList: service.onCompletion(cPath, cCarets.nestedInMedia), + actualList: service.onCompletion(filePath, carets.nestedInMedia), unexpectedList: [{ label: '@st-import' }], - }); - assertCompletions({ + })); + assertCompletions(cPath, ({ filePath, carets }) => ({ message: 'nested-in-st-scope', - actualList: service.onCompletion(cPath, cCarets.nestedInStScope), + actualList: service.onCompletion(filePath, carets.nestedInStScope), unexpectedList: [{ label: '@st-import' }], - }); - assertCompletions({ + })); + assertCompletions(cPath, ({ filePath, carets }) => ({ message: 'before-selector', - actualList: service.onCompletion(cPath, cCarets.beforeSelector), + actualList: service.onCompletion(filePath, carets.beforeSelector), unexpectedList: [{ label: '@st-import' }], - }); + })); + }); + it('should not suggest native css or selectors', () => { + const { service, assertCompletions, fs } = testLangService( + { + 'other.st.css': ``, + 'entry.st.css': ` + @st-import ^default^ from '.^specifierEmpty^'; + @st-import [^named^, keyframes(^namedTyped^)] from '.^specifierWithDot^'; + + .xxx {} + `, + }, + { testOnNativeFileSystem: tempDir.path } + ); + + const entryPath = fs.join(tempDir.path, 'entry.st.css'); + + const unexpectedList = [ + { label: '.xxx' }, + { label: 'input' }, + { label: '@media' }, + { label: ':global()' }, + ]; + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'specifierEmpty', + actualList: service.onCompletion(filePath, carets.specifierEmpty), + unexpectedList, + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'specifierWithDot', + actualList: service.onCompletion(filePath, carets.specifierWithDot), + unexpectedList, + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'default', + actualList: service.onCompletion(filePath, carets.default), + unexpectedList, + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'named', + actualList: service.onCompletion(filePath, carets.named), + unexpectedList, + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ + message: 'namedTyped', + actualList: service.onCompletion(filePath, carets.namedTyped), + unexpectedList, + })); }); describe('named imports', () => { it('should suggest named imports', () => { - const { service, carets, assertCompletions, fs, textEditContext } = testLangService( + const { service, assertCompletions, fs } = testLangService( { 'source.st.css': ` .classA {} @@ -116,25 +161,23 @@ describe('LS: st-import', () => { { testOnNativeFileSystem: tempDir.path } ); const entryPath = fs.join(tempDir.path, 'entry.st.css'); - const entryCarets = carets[entryPath]; - const { replaceText } = textEditContext(entryPath); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'top', - actualList: service.onCompletion(entryPath, entryCarets.topEmpty), + actualList: service.onCompletion(filePath, carets.topEmpty), expectedList: [ { label: 'root', detail: stImportNamedCompletion.detail({ relativePath: './source.st.css', - symbol: { _kind: 'class', name: 'root' }, + symbol: CSSClass.createSymbol({ name: 'root' }), }), }, { label: 'classA', detail: stImportNamedCompletion.detail({ relativePath: './source.st.css', - symbol: { _kind: 'class', name: 'classA' }, + symbol: CSSClass.createSymbol({ name: 'classA' }), }), }, { @@ -165,19 +208,19 @@ describe('LS: st-import', () => { { label: 'jump' }, { label: 'comp' }, ], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ message: 'partial', - actualList: service.onCompletion(entryPath, entryCarets.partial), + actualList: service.onCompletion(filePath, carets.partial), expectedList: [ { label: '--propA', - textEdit: replaceText(entryCarets.partial, '--propA', { deltaStart: -5 }), + textEdit: replaceText(carets.partial, '--propA', { deltaStart: -5 }), }, { label: '--propB', - textEdit: replaceText(entryCarets.partial, '--propB', { deltaStart: -5 }), + textEdit: replaceText(carets.partial, '--propB', { deltaStart: -5 }), }, ], unexpectedList: [ @@ -189,13 +232,12 @@ describe('LS: st-import', () => { { label: 'jump' }, { label: 'comp' }, ], - }); + })); }); it('should suggest typed named imports', () => { - const { service, carets, assertCompletions, fs, textEditContext, completion } = - testLangService( - { - 'source.st.css': ` + const { service, assertCompletions, fs, completion } = testLangService( + { + 'source.st.css': ` .aClass { --aProp: 1; container-name: aContainer; @@ -209,7 +251,7 @@ describe('LS: st-import', () => { @layer aLayer {} @layer bLayer {} `, - 'entry.st.css': ` + 'entry.st.css': ` @st-import [ keyframes(^keyframesEmpty^) layer(^layerEmpty^) @@ -221,21 +263,19 @@ describe('LS: st-import', () => { container(a^containerPartial^) ] from './source.st.css'; `, - }, - { testOnNativeFileSystem: tempDir.path } - ); + }, + { testOnNativeFileSystem: tempDir.path } + ); const entryPath = fs.join(tempDir.path, 'entry.st.css'); - const entryCarets = carets[entryPath]; - const { replaceText } = textEditContext(entryPath); const capitalize = (value: string) => value[0].toUpperCase() + value.slice(1); const supportedTypes = ['keyframes', 'layer', 'container'] as const; const allTypes = ['class', 'prop', 'buildVar', ...supportedTypes] as const; for (const type of supportedTypes) { const capitalizedType = capitalize(type); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: `empty ${type}`, - actualList: service.onCompletion(entryPath, entryCarets[type + 'Empty']), + actualList: service.onCompletion(filePath, carets[type + 'Empty']), expectedList: [ // a&b param from type ...completion(['a' + capitalizedType, 'b' + capitalizedType], (name) => ({ @@ -261,19 +301,17 @@ describe('LS: st-import', () => { }) ), ], - }); - assertCompletions({ + })); + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ message: `partial ${type}`, - actualList: service.onCompletion(entryPath, entryCarets[type + 'Partial']), + actualList: service.onCompletion(filePath, carets[type + 'Partial']), expectedList: [ // a param from type (without b) { label: 'a' + capitalizedType, - textEdit: replaceText( - entryCarets[type + 'Partial'], - 'a' + capitalizedType, - { deltaStart: -1 } - ), + textEdit: replaceText(carets[type + 'Partial'], 'a' + capitalizedType, { + deltaStart: -1, + }), detail: stImportNamedCompletion.detail({ relativePath: './source.st.css', symbol: { _kind: type, name: 'a' + capitalizedType }, @@ -296,16 +334,15 @@ describe('LS: st-import', () => { }) ), ], - }); + })); } }); it('should suggest typed import asserters', () => { - const { service, carets, assertCompletions, fs, completion, textEditContext } = - testLangService( - { - 'source.st.css': ``, - 'code.js': ``, - 'entry.st.css': ` + const { service, assertCompletions, fs, completion } = testLangService( + { + 'source.st.css': ``, + 'code.js': ``, + 'entry.st.css': ` @st-import [ ^topLevelEmpty^ ] from './source.st.css'; @@ -324,32 +361,30 @@ describe('LS: st-import', () => { keyframes(^onlyInCSS^) ] from './code.js'; `, - }, - { testOnNativeFileSystem: tempDir.path } - ); + }, + { testOnNativeFileSystem: tempDir.path } + ); const entryPath = fs.join(tempDir.path, 'entry.st.css'); - const entryCarets = carets[entryPath]; - const { replaceText } = textEditContext(entryPath); const supportedTypes = ['keyframes', 'layer', 'container'] as const; - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: `all`, - actualList: service.onCompletion(entryPath, entryCarets['topLevelEmpty']), + actualList: service.onCompletion(filePath, carets['topLevelEmpty']), expectedList: [ ...completion([...supportedTypes], (type) => ({ label: type + '()', detail: stImportNamedCompletion.typeAssertCallDetail(type), })), ], - }); - assertCompletions({ + })); + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ message: `partial`, - actualList: service.onCompletion(entryPath, entryCarets['topPartial']), + actualList: service.onCompletion(filePath, carets['topPartial']), expectedList: [ // partial "lay" - only layer() { label: 'layer()', - textEdit: replaceText(entryCarets['topPartial'], 'layer($1)', { + textEdit: replaceText(carets['topPartial'], 'layer($1)', { deltaStart: -3, }), detail: stImportNamedCompletion.typeAssertCallDetail('layer'), @@ -363,15 +398,15 @@ describe('LS: st-import', () => { (type) => ({ label: type + '()' }) ), ], - }); - assertCompletions({ + })); + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ message: `with existing`, - actualList: service.onCompletion(entryPath, entryCarets['topWithExisting']), + actualList: service.onCompletion(filePath, carets['topWithExisting']), expectedList: [ // keyframes&layer already exist - only container { label: 'container()', - textEdit: replaceText(entryCarets['topWithExisting'], 'container($1)'), + textEdit: replaceText(carets['topWithExisting'], 'container($1)'), detail: stImportNamedCompletion.typeAssertCallDetail('container'), command: triggerCompletion, }, @@ -383,26 +418,26 @@ describe('LS: st-import', () => { (type) => ({ label: type + '()' }) ), ], - }); - assertCompletions({ + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: `only at top of params`, - actualList: service.onCompletion(entryPath, entryCarets['notTop']), + actualList: service.onCompletion(filePath, carets['notTop']), unexpectedList: [ // all ...completion([...supportedTypes], (type) => ({ label: type + '()' })), ], - }); - assertCompletions({ + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: `only in CSS`, - actualList: service.onCompletion(entryPath, entryCarets['onlyInCSS']), + actualList: service.onCompletion(filePath, carets['onlyInCSS']), unexpectedList: [ // all ...completion([...supportedTypes], (type) => ({ label: type + '()' })), ], - }); + })); }); it('should suggest re-exports', () => { - const { service, carets, assertCompletions, fs } = testLangService( + const { service, assertCompletions, fs } = testLangService( { 'origin.st.css': ` .originClassA { @@ -442,24 +477,23 @@ describe('LS: st-import', () => { { testOnNativeFileSystem: tempDir.path } ); const entryPath = fs.join(tempDir.path, 'entry.st.css'); - const entryCarets = carets[entryPath]; - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'top', - actualList: service.onCompletion(entryPath, entryCarets.topEmpty), + actualList: service.onCompletion(filePath, carets.topEmpty), expectedList: [ { label: 'root', detail: stImportNamedCompletion.detail({ relativePath: './proxy.st.css', - symbol: { _kind: 'class', name: 'root' }, + symbol: CSSClass.createSymbol({ name: 'root' }), }), }, { label: 'proxyClassA', detail: stImportNamedCompletion.detail({ relativePath: './extend.st.css', - symbol: { _kind: 'class', name: 'classA' }, + symbol: CSSClass.createSymbol({ name: 'classA' }), }), }, { @@ -485,10 +519,10 @@ describe('LS: st-import', () => { }, ], unexpectedList: [{ label: 'proxyJump' }, { label: 'proxyComp' }], - }); + })); }); it('should show global information as part of detail', () => { - const { service, carets, assertCompletions, fs } = testLangService( + const { service, assertCompletions, fs } = testLangService( { 'source.st.css': ` .classA { @@ -508,21 +542,19 @@ describe('LS: st-import', () => { { testOnNativeFileSystem: tempDir.path } ); const entryPath = fs.join(tempDir.path, 'entry.st.css'); - const entryCarets = carets[entryPath]; - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'top', - actualList: service.onCompletion(entryPath, entryCarets.top), + actualList: service.onCompletion(filePath, carets.top), expectedList: [ { label: 'classA', detail: stImportNamedCompletion.detail({ relativePath: './source.st.css', - symbol: { - _kind: 'class', + symbol: CSSClass.createSymbol({ name: 'classA', '-st-global': parseCssSelector('.globalA'), - }, + }), }), }, { @@ -533,10 +565,10 @@ describe('LS: st-import', () => { }), }, ], - }); - assertCompletions({ + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'keyframes', - actualList: service.onCompletion(entryPath, entryCarets.keyframes), + actualList: service.onCompletion(filePath, carets.keyframes), expectedList: [ { label: 'jump', @@ -546,10 +578,10 @@ describe('LS: st-import', () => { }), }, ], - }); - assertCompletions({ + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'layer', - actualList: service.onCompletion(entryPath, entryCarets.layer), + actualList: service.onCompletion(filePath, carets.layer), expectedList: [ { label: 'comps', @@ -559,10 +591,10 @@ describe('LS: st-import', () => { }), }, ], - }); - assertCompletions({ + })); + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'container', - actualList: service.onCompletion(entryPath, entryCarets.container), + actualList: service.onCompletion(filePath, carets.container), expectedList: [ { label: 'box', @@ -572,10 +604,10 @@ describe('LS: st-import', () => { }), }, ], - }); + })); }); it('should suggest symbols from native css', () => { - const { service, carets, assertCompletions, fs } = testLangService( + const { service, assertCompletions, fs } = testLangService( { 'native.css': ` .classA {} @@ -596,32 +628,29 @@ describe('LS: st-import', () => { } ); const entryPath = fs.join(tempDir.path, 'entry.st.css'); - const entryCarets = carets[entryPath]; - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'top', - actualList: service.onCompletion(entryPath, entryCarets.top), + actualList: service.onCompletion(filePath, carets.top), expectedList: [ { label: 'classA', detail: stImportNamedCompletion.detail({ relativePath: './native.css', - symbol: { - _kind: 'class', + symbol: CSSClass.createSymbol({ name: 'classA', '-st-global': parseCssSelector('.classA'), - }, + }), }), }, { label: 'classB', detail: stImportNamedCompletion.detail({ relativePath: './native.css', - symbol: { - _kind: 'class', + symbol: CSSClass.createSymbol({ name: 'classB', '-st-global': parseCssSelector('.classB'), - }, + }), }), }, { @@ -632,10 +661,10 @@ describe('LS: st-import', () => { }), }, ], - }); + })); }); it('should suggest symbols from js', () => { - const { service, carets, assertCompletions, fs, textEditContext } = testLangService( + const { service, assertCompletions, fs } = testLangService( { 'code.js': ` exports.mixinA = function mixinA(){} @@ -653,12 +682,10 @@ describe('LS: st-import', () => { { testOnNativeFileSystem: tempDir.path } ); const entryPath = fs.join(tempDir.path, 'entry.st.css'); - const entryCarets = carets[entryPath]; - const { replaceText } = textEditContext(entryPath); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'top', - actualList: service.onCompletion(entryPath, entryCarets.top), + actualList: service.onCompletion(filePath, carets.top), expectedList: [ { label: 'mixinA', @@ -709,11 +736,11 @@ describe('LS: st-import', () => { }), }, ], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ message: 'partial', - actualList: service.onCompletion(entryPath, entryCarets.partial), + actualList: service.onCompletion(filePath, carets.partial), expectedList: [ { label: 'mixinA', @@ -723,7 +750,7 @@ describe('LS: st-import', () => { /**/ }, }), - textEdit: replaceText(entryCarets.partial, 'mixinA', { deltaStart: -3 }), + textEdit: replaceText(carets.partial, 'mixinA', { deltaStart: -3 }), }, { label: 'mixinB', @@ -733,16 +760,16 @@ describe('LS: st-import', () => { /**/ }, }), - textEdit: replaceText(entryCarets.partial, 'mixinB', { deltaStart: -3 }), + textEdit: replaceText(carets.partial, 'mixinB', { deltaStart: -3 }), }, ], unexpectedList: [{ label: 'formatterA' }, { label: 'strA' }, { label: 'boolA' }], - }); + })); }); }); describe('specifier completion', () => { it('should suggest relative paths', () => { - const { service, carets, assertCompletions, fs } = testLangService( + const { service, assertCompletions, fs } = testLangService( { 'a.st.css': ``, 'b.js': ``, @@ -765,11 +792,10 @@ describe('LS: st-import', () => { } ); const entryPath = fs.join(tempDir.path, 'src', 'entry.st.css'); - const entryCarets = carets[entryPath]; - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'same dir', - actualList: service.onCompletion(entryPath, entryCarets.sameDir), + actualList: service.onCompletion(filePath, carets.sameDir), expectedList: [ { label: 'c.st.css', command: undefined }, { @@ -778,33 +804,33 @@ describe('LS: st-import', () => { }, ], unexpectedList: [{ label: 'entry.st.css' }], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'up dir', - actualList: service.onCompletion(entryPath, entryCarets.upDir), + actualList: service.onCompletion(filePath, carets.upDir), expectedList: [{ label: 'a.st.css' }, { label: 'b.js' }, { label: 'src/' }], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'nested dir', - actualList: service.onCompletion(entryPath, entryCarets.nestedDir), + actualList: service.onCompletion(filePath, carets.nestedDir), expectedList: [{ label: 'd.st.css' }], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'just dot without slash', - actualList: service.onCompletion(entryPath, entryCarets.justDot), + actualList: service.onCompletion(filePath, carets.justDot), unexpectedList: [ { label: '/c.st.css' }, { label: '/inner/' }, { label: '/entry.st.css' }, ], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'up dir without slash', - actualList: service.onCompletion(entryPath, entryCarets.upDirNoSlash), + actualList: service.onCompletion(filePath, carets.upDirNoSlash), unexpectedList: [ { label: '/a.st.css' }, { label: '/b.js' }, @@ -812,10 +838,10 @@ describe('LS: st-import', () => { { label: '/inner/' }, { label: '/entry.st.css' }, ], - }); + })); }); it('should suggest from both relative directory and base', () => { - const { service, carets, assertCompletions, textEditContext, fs } = testLangService( + const { service, assertCompletions, fs } = testLangService( { 'file.st.css': ``, files: { @@ -834,32 +860,30 @@ describe('LS: st-import', () => { } ); const entryPath = fs.join(tempDir.path, 'entry.st.css'); - const entryCarets = carets[entryPath]; - const { replaceText } = textEditContext(entryPath); - assertCompletions({ - actualList: service.onCompletion(entryPath, entryCarets[0]), + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ + actualList: service.onCompletion(filePath, carets[0]), expectedList: [ { label: 'file.st.css', - textEdit: replaceText(entryCarets[0], 'file.st.css', { deltaStart: -3 }), + textEdit: replaceText(carets[0], 'file.st.css', { deltaStart: -3 }), }, { label: 'files/', - textEdit: replaceText(entryCarets[0], 'files/', { deltaStart: -3 }), + textEdit: replaceText(carets[0], 'files/', { deltaStart: -3 }), }, { label: 'fil/', - textEdit: replaceText(entryCarets[0], 'fil/', { deltaStart: -3 }), + textEdit: replaceText(carets[0], 'fil/', { deltaStart: -3 }), }, { label: '/b.st.css' }, ], unexpectedList: [{ label: 'entry.st.css' }, { label: 'not-start-with-fil.st.css' }], - }); + })); }); describe('node_modules', () => { it('should suggest picked up node_modules package names', () => { - const { service, carets, assertCompletions, textEditContext, fs } = testLangService( + const { service, assertCompletions, fs } = testLangService( { node_modules: { '@scoped-a': { @@ -884,27 +908,25 @@ describe('LS: st-import', () => { { testOnNativeFileSystem: tempDir.path } ); const entryPath = fs.join(tempDir.path, 'src/entry.st.css'); - const entryCarets = carets[entryPath]; - const { replaceText } = textEditContext(entryPath); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'empty', - actualList: service.onCompletion(entryPath, entryCarets.empty), + actualList: service.onCompletion(filePath, carets.empty), expectedList: [ { label: '@scoped-a/pack1' }, { label: '@scoped-a/pack2' }, { label: '@scoped-a/pack3' }, { label: 'package-a' }, ], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ message: 'start with p', - actualList: service.onCompletion(entryPath, entryCarets.startWithP), + actualList: service.onCompletion(filePath, carets.startWithP), expectedList: [ { label: 'package-a', - textEdit: replaceText(entryCarets.startWithP, 'package-a', { + textEdit: replaceText(carets.startWithP, 'package-a', { deltaStart: -1, }), }, @@ -914,36 +936,36 @@ describe('LS: st-import', () => { { label: '@scoped-a/pack2' }, { label: '@scoped-a/pack3' }, ], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ message: 'start with @', - actualList: service.onCompletion(entryPath, entryCarets.startWithAt), + actualList: service.onCompletion(filePath, carets.startWithAt), expectedList: [ { label: '@scoped-a/pack1', - textEdit: replaceText(entryCarets.startWithAt, '@scoped-a/pack1', { + textEdit: replaceText(carets.startWithAt, '@scoped-a/pack1', { deltaStart: -1, }), }, { label: '@scoped-a/pack2', - textEdit: replaceText(entryCarets.startWithAt, '@scoped-a/pack2', { + textEdit: replaceText(carets.startWithAt, '@scoped-a/pack2', { deltaStart: -1, }), }, { label: '@scoped-a/pack3', - textEdit: replaceText(entryCarets.startWithAt, '@scoped-a/pack3', { + textEdit: replaceText(carets.startWithAt, '@scoped-a/pack3', { deltaStart: -1, }), }, ], unexpectedList: [{ label: 'package-a' }], - }); + })); }); it('should suggest package relative content (no exports field)', () => { - const { service, carets, assertCompletions, textEditContext, fs } = testLangService( + const { service, assertCompletions, fs } = testLangService( { node_modules: { '@scoped': { @@ -973,53 +995,51 @@ describe('LS: st-import', () => { { testOnNativeFileSystem: tempDir.path } ); const entryPath = fs.join(tempDir.path, 'entry.st.css'); - const entryCarets = carets[entryPath]; - const { replaceText } = textEditContext(entryPath); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'scoped root', - actualList: service.onCompletion(entryPath, entryCarets.scopedRoot), + actualList: service.onCompletion(filePath, carets.scopedRoot), expectedList: [ { label: 'dist/' }, { label: 'src/' }, { label: 'package.json' }, ], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'flat root', - actualList: service.onCompletion(entryPath, entryCarets.flatRoot), + actualList: service.onCompletion(filePath, carets.flatRoot), expectedList: [{ label: 'esm/' }, { label: 'lib/' }, { label: 'package.json' }], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ message: 'scoped internal', - actualList: service.onCompletion(entryPath, entryCarets.scopedInternal), + actualList: service.onCompletion(filePath, carets.scopedInternal), expectedList: [ { label: 'file.js', - textEdit: replaceText(entryCarets.scopedInternal, 'file.js', { + textEdit: replaceText(carets.scopedInternal, 'file.js', { deltaStart: -2, }), }, ], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets, textEdit: { replaceText } }) => ({ message: 'flat internal', - actualList: service.onCompletion(entryPath, entryCarets.flatInternal), + actualList: service.onCompletion(filePath, carets.flatInternal), expectedList: [ { label: 'file.js', - textEdit: replaceText(entryCarets.flatInternal, 'file.js', { + textEdit: replaceText(carets.flatInternal, 'file.js', { deltaStart: -2, }), }, ], - }); + })); }); it('should suggest closer resolved package', () => { - const { service, carets, assertCompletions, fs } = testLangService( + const { service, assertCompletions, fs } = testLangService( { node_modules: { x: { @@ -1042,17 +1062,16 @@ describe('LS: st-import', () => { { testOnNativeFileSystem: tempDir.path } ); const entryPath = fs.join(tempDir.path, 'src', 'entry.st.css'); - const entryCarets = carets[entryPath]; - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'empty', - actualList: service.onCompletion(entryPath, entryCarets[0]), + actualList: service.onCompletion(filePath, carets[0]), expectedList: [{ label: 'green.js' }, { label: 'package.json' }], unexpectedList: [{ label: 'red.js' }], - }); + })); }); it('should suggest package exports', () => { - const { service, carets, assertCompletions, fs } = testLangService( + const { service, assertCompletions, fs } = testLangService( { node_modules: { x: { @@ -1092,11 +1111,10 @@ describe('LS: st-import', () => { { testOnNativeFileSystem: tempDir.path } ); const entryPath = fs.join(tempDir.path, 'entry.st.css'); - const entryCarets = carets[entryPath]; - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'package root', - actualList: service.onCompletion(entryPath, entryCarets.packageRoot), + actualList: service.onCompletion(filePath, carets.packageRoot), expectedList: [{ label: 'inner-a' }, { label: 'inner-b' }, { label: 'wild/' }], unexpectedList: [ { label: 'private.js' }, @@ -1108,11 +1126,11 @@ describe('LS: st-import', () => { }, { label: 'invalid-2/' }, ], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'wild card at end', - actualList: service.onCompletion(entryPath, entryCarets.wildCardAtEnd), + actualList: service.onCompletion(filePath, carets.wildCardAtEnd), expectedList: [ { label: 'c-file.js', command: undefined }, { label: 'd-file.js', command: undefined }, @@ -1125,11 +1143,11 @@ describe('LS: st-import', () => { { label: 'private.js' }, { label: 'package.json' }, ], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'wild card at end with partial file name', - actualList: service.onCompletion(entryPath, entryCarets.wildCardAtEndPartial), + actualList: service.onCompletion(filePath, carets.wildCardAtEndPartial), expectedList: [{ label: 'c-file.js' }], unexpectedList: [ { label: 'd-file.js' }, @@ -1140,13 +1158,13 @@ describe('LS: st-import', () => { { label: 'private.js' }, { label: 'package.json' }, ], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'internal', - actualList: service.onCompletion('/entry.st.css', entryCarets.internal), + actualList: service.onCompletion(filePath, carets.internal), unexpectedList: [{ label: 'x-file.js' }], - }); + })); }); it('should handle conditional exports', () => { /** @@ -1154,7 +1172,7 @@ describe('LS: st-import', () => { * will only get hard-coded known conditions: * node, import, require, default, browse */ - const { service, carets, assertCompletions, fs } = testLangService( + const { service, assertCompletions, fs } = testLangService( { node_modules: { topLevelConditions: { @@ -1206,36 +1224,32 @@ describe('LS: st-import', () => { { testOnNativeFileSystem: tempDir.path } ); const entryPath = fs.join(tempDir.path, 'entry.st.css'); - const entryCarets = carets[entryPath]; - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'known conditions', - actualList: service.onCompletion(entryPath, entryCarets.topLevelConditions), + actualList: service.onCompletion(filePath, carets.topLevelConditions), expectedList: [{ label: 'import.js' }], unexpectedList: [{ label: 'require.js' }, { label: 'default.js' }], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'nested conditions', - actualList: service.onCompletion(entryPath, entryCarets.nestedConditions), + actualList: service.onCompletion(filePath, carets.nestedConditions), expectedList: [{ label: 'give-me/' }], unexpectedList: [{ label: 'import.js' }], - }); + })); - assertCompletions({ + assertCompletions(entryPath, ({ filePath, carets }) => ({ message: 'nested subpath conditions', - actualList: service.onCompletion( - entryPath, - entryCarets.nestedSubpathConditions - ), + actualList: service.onCompletion(filePath, carets.nestedSubpathConditions), expectedList: [{ label: 'a.js' }, { label: 'b.js' }], unexpectedList: [{ label: 'x.js' }], - }); + })); }); }); describe('custom resolve', () => { it('should suggest from custom mapped', () => { - const { service, carets, assertCompletions, fs } = testLangService( + const { service, assertCompletions, fs } = testLangService( { node_modules: { x: { @@ -1275,19 +1289,18 @@ describe('LS: st-import', () => { ); const defaultResolveModule = createDefaultResolver(fs, {}); const entryPath = fs.join(tempDir.path, 'src', 'entry.st.css'); - const entryCarets = carets[entryPath]; /** * mapping like this cannot override the original resolved package * and combine suggestions from both locations. */ - assertCompletions({ - actualList: service.onCompletion(entryPath, entryCarets[0]), + assertCompletions(entryPath, ({ filePath, carets }) => ({ + actualList: service.onCompletion(filePath, carets[0]), expectedList: [ { label: 'green.js' }, { label: 'yellow.js' }, { label: 'package.json' }, ], - }); + })); }); }); }); diff --git a/packages/language-service/test/lib-new/features/ls-st-structure.spec.ts b/packages/language-service/test/lib-new/features/ls-st-structure.spec.ts new file mode 100644 index 0000000000..59081e7fd0 --- /dev/null +++ b/packages/language-service/test/lib-new/features/ls-st-structure.spec.ts @@ -0,0 +1,61 @@ +import { expect } from 'chai'; +import { testLangService } from '../../test-kit/test-lang-service'; + +describe('LS: st-structure', () => { + // ToDo: refactor legacy flat mode tests cases here + it('should not report unknown rule from native lsp', () => { + const { service } = testLangService(` + @st .x { + @st :y; + @st ::z => [z]; + } + `); + + const result = service.diagnose('/entry.st.css'); + + expect(result).to.eql([]); + }); + it('should suggest nested parts', () => { + const { service, carets, assertCompletions } = testLangService(` + @st .cls { + @st ::shallow => [shallow] { + @st ::deep => [deep]; + } + } + + .cls^afterCls^ {} + + .cls::shallow^afterShallow^ {} + `); + const entryCarets = carets['/entry.st.css']; + + assertCompletions({ + message: 'afterCls', + actualList: service.onCompletion('/entry.st.css', entryCarets.afterCls), + expectedList: [{ label: '::shallow' }], + unexpectedList: [{ label: '::deep' }], + }); + + assertCompletions({ + message: 'afterShallow', + actualList: service.onCompletion('/entry.st.css', entryCarets.afterShallow), + expectedList: [{ label: '::deep' }], + unexpectedList: [{ label: '::shallow' }], + }); + }); + it('should NOT automatically set classes as parts on .root (not legacy flat mode)', () => { + const { service, carets, assertCompletions } = testLangService(` + @st .cls { + @st ::innerPart => [innerPart]; + } + + .root^afterRoot^ {} + `); + const entryCarets = carets['/entry.st.css']; + + assertCompletions({ + actualList: service.onCompletion('/entry.st.css', entryCarets.afterRoot), + unexpectedList: [{ label: '::cls' }, { label: '::innerPart' }], + }); + }); +}); diff --git a/packages/language-service/test/lib-new/general-css.spec.ts b/packages/language-service/test/lib-new/general-css.spec.ts new file mode 100644 index 0000000000..8fc903d1d8 --- /dev/null +++ b/packages/language-service/test/lib-new/general-css.spec.ts @@ -0,0 +1,18 @@ +import { expect } from 'chai'; +import { testLangService } from '../test-kit/test-lang-service'; + +describe('LS: css-pseudo-class', () => { + describe('svg', () => { + it('should not report unknown properties from native lsp', () => { + const { service } = testLangService(` + .path { + d: path("M0 0 L10 0 L10 10Z"); + } + `); + + const result = service.diagnose('/entry.st.css'); + + expect(result).to.eql([]); + }); + }); +}); diff --git a/packages/language-service/test/lib/completions/st-scope.spec.ts b/packages/language-service/test/lib/completions/st-scope.spec.ts index 13b7348440..9ef066b294 100644 --- a/packages/language-service/test/lib/completions/st-scope.spec.ts +++ b/packages/language-service/test/lib/completions/st-scope.spec.ts @@ -130,7 +130,7 @@ describe('completion inside @st-scope', () => { title: 'Suggest', command: 'editor.action.triggerSuggest', }, - sortText: 'd_a0', + sortText: 'd_a1', }); }); diff --git a/packages/language-service/test/lib/completions/states.spec.ts b/packages/language-service/test/lib/completions/states.spec.ts index 5e9db82a84..71a135ef8a 100644 --- a/packages/language-service/test/lib/completions/states.spec.ts +++ b/packages/language-service/test/lib/completions/states.spec.ts @@ -6,134 +6,6 @@ import type { Completion } from '@stylable/language-service/dist/lib/completion- import * as asserters from '../../test-kit/completions-asserters'; describe('States', () => { - describe('Local states', () => { - const str1 = ':hello'; - const str2 = ':goodbye'; - const str3 = ':holla'; - const str4 = ':shmover'; - const createCompletion = (str: string, rng: ProviderRange, path?: string) => - asserters.stateSelectorCompletion(str.slice(1), rng, path); - - [str1, str2].forEach((str, j, a) => { - str.split('').forEach((_c, i) => { - const prefix = str.slice(0, i); - - it( - 'should complete available states from same file, with prefix ' + prefix + ' ', - () => { - const rng = createRange(4, 5, 4, 5 + i); - const asserter = asserters.getCompletions( - 'states/class-with-states.st.css', - prefix - ); - const exp: Array> = []; - const notExp: Array> = []; - exp.push(createCompletion(a[j], rng)); - if (prefix.length <= 1) { - exp.push(createCompletion(a[1 - j], rng)); - } else { - notExp.push(createCompletion(a[1 - j], rng)); - } - asserter.suggested(exp); - asserter.notSuggested(notExp); - } - ); - - it( - 'should complete available states in complex selectors, with prefix ' + - prefix + - ' ', - () => { - const rng = createRange(9, 19, 9, 19 + i); - const asserter = asserters.getCompletions( - 'states/complex-selectors.st.css', - prefix - ); - const exp: Array> = []; - const notExp: Array> = []; - if (str === str1) { - exp.push(createCompletion(str1, rng)); - } else if (prefix.length <= 1) { - exp.push(createCompletion(str1, rng)); - } - notExp.push(createCompletion(str2, rng)); - asserter.suggested(exp); - asserter.notSuggested(notExp); - } - ); - }); - }); - - [str1, str3].forEach((str) => { - str.split('').forEach((_c, i) => { - const prefix = str.slice(0, i); - - it( - 'should complete only unused states in complex selectors ending in state name, with prefix ' + - prefix + - ' ', - () => { - const rng = createRange(9, 25, 9, 25 + i); - const asserter = asserters.getCompletions( - 'states/complex-selectors-with-states.st.css', - prefix - ); - const exp: Array> = []; - const notExp: Array> = []; - if (str === str1) { - exp.push(createCompletion(str1, rng)); - } else if (prefix.length <= 2) { - exp.push(createCompletion(str1, rng)); - } - notExp.push(createCompletion(str3, rng)); - asserter.suggested(exp); - asserter.notSuggested(notExp); - } - ); - }); - }); - - str4.split('').forEach((_c, i) => { - const prefix = str4.slice(0, i); - - it('should complete local root state on top level with prefix ' + prefix + ' ', () => { - const rng = createRange(4, 0, 4, 0 + i); - const asserter = asserters.getCompletions('states/top-level.st.css', prefix); - const exp: Array> = []; - const compl = createCompletion(str4, rng); - exp.push(compl); - asserter.suggested(exp); - }); - - it( - 'should complete local root state on top level from extends with prefix ' + - prefix + - ' ', - () => { - const rng = createRange(9, 0, 9, 0 + i); - const asserter = asserters.getCompletions( - 'states/top-level-with-extend.st.css', - prefix - ); - const exp: Array> = []; - const compl = createCompletion(str4, rng, './comp-to-import.st.css'); - exp.push(compl); - asserter.suggested(exp); - } - ); - }); - - it('should not complete state value after :: ', () => { - const asserter = asserters.getCompletions( - 'states/class-with-states-double-colon.st.css' - ); - asserter.notSuggested([ - asserters.stateSelectorCompletion('hello', createRange(0, 0, 0, 0)), - asserters.stateSelectorCompletion('goodbye', createRange(0, 0, 0, 0)), - ]); - }); - }); - describe('State with param', () => { describe('Definition', () => { it('should complete available states param types', () => { @@ -427,331 +299,5 @@ describe('States', () => { }); }); }); - - describe('Usage', () => { - it('should complete available states from same file (with parenthesis)', () => { - const rng = createRange(4, 5, 4, 5); - const createCompletion = (str: string, rng: ProviderRange, path?: string) => - asserters.stateSelectorCompletion(str.slice(1), rng, path, true); - - const asserter = asserters.getCompletions( - 'states/with-param/local-state-param.st.css' - ); - const exp: Array> = []; - exp.push(createCompletion(':hello', rng)); - asserter.suggested(exp); - }); - - it('should complete imported state (with parenthesis)', () => { - const rng = createRange(9, 5, 9, 5); - const createCompletion = (str: string, rng: ProviderRange, path?: string) => - asserters.stateSelectorCompletion(str.slice(1), rng, path, true); - - const asserter = asserters.getCompletions( - 'states/with-param/imported-state-param.st.css' - ); - const exp: Array> = []; - exp.push(createCompletion(':shmover', rng, './comp-to-import-with-param.st.css')); - asserter.suggested(exp); - }); - - it('should complete enum state parameter options', () => { - const rng = createRange(4, 12, 4, 12); - const createCompletion = (str: string, rng: ProviderRange, path?: string) => - asserters.stateEnumCompletion(str, rng, path); - - const asserter = asserters.getCompletions( - 'states/with-param/enum/state-with-param-enum-suggestion.st.css' - ); - const exp: Array> = []; - exp.push(createCompletion('bob', rng)); - exp.push(createCompletion('alice', rng)); - exp.push(createCompletion('eve', rng)); - asserter.suggested(exp); - }); - - it('should complete pre-existing enum state parameter options from imported file', () => { - const rng = createRange(9, 12, 9, 13); - const createCompletion = (str: string, rng: ProviderRange, path?: string) => - asserters.stateEnumCompletion(str, rng, path); - - const asserter = asserters.getCompletions( - 'states/with-param/enum/imported-state-with-enum-middle.st.css' - ); - const exp: Array> = []; - const unExp: Array> = []; - exp.push(createCompletion('eve', rng, './state-with-enum.st.css')); - unExp.push(createCompletion('alice', rng, './state-with-enum.st.css')); - unExp.push(createCompletion('bob', rng, './state-with-enum.st.css')); - asserter.suggested(exp); - asserter.notSuggested(unExp); - }); - - it('should complete template with enum parameter options from imported file', () => { - const rng = createRange(9, 19, 9, 20); - const createCompletion = (str: string, rng: ProviderRange, path?: string) => - asserters.stateEnumCompletion(str, rng, path); - - const asserter = asserters.getCompletions( - 'states/with-param/enum/imported-state-with-template-enum-middle.st.css' - ); - const exp: Array> = []; - const unExp: Array> = []; - exp.push(createCompletion('eee', rng, './state-with-enum.st.css')); - exp.push(createCompletion('e22', rng, './state-with-enum.st.css')); - unExp.push(createCompletion('aaa', rng, './state-with-enum.st.css')); - unExp.push(createCompletion('bbb', rng, './state-with-enum.st.css')); - asserter.suggested(exp); - asserter.notSuggested(unExp); - }); - - it('should not complete pseudo-states and pseudo-elements when inside an enum (from imported file)', () => { - const rng = createRange(9, 12, 9, 12); - const createEnumComp = (str: string, rng: ProviderRange, path?: string) => - asserters.stateEnumCompletion(str, rng, path); - const createStateComp = (str: string, rng: ProviderRange, path?: string) => - asserters.stateSelectorCompletion(str, rng, path); - const createElementComp = (str: string, rng: ProviderRange, path?: string) => - asserters.pseudoElementCompletion(str, rng, path); - const createGlobalComp = (rng: ProviderRange) => asserters.globalCompletion(rng); - - const asserter = asserters.getCompletions( - 'states/with-param/enum/imported-state-with-enum-start.st.css' - ); - const exp: Array> = []; - const unExp: Array> = []; - exp.push(createEnumComp('eve', rng, './state-with-enum.st.css')); - exp.push(createEnumComp('alice', rng, './state-with-enum.st.css')); - exp.push(createEnumComp('bob', rng, './state-with-enum.st.css')); - unExp.push(createStateComp('otherState', rng, './state-with-enum.st.css')); - unExp.push(createElementComp('part', rng)); - unExp.push(createGlobalComp(rng)); - asserter.suggested(exp); - asserter.notSuggested(unExp); - }); - }); - }); - - describe('Imported states', () => { - const str1 = ':state'; - const str2 = ':otherState'; - const str3 = ':anotherState'; - const str4 = ':oneMoreState'; - - const createCompletion = (str: string, rng: ProviderRange, path: string) => - asserters.stateSelectorCompletion(str.slice(1), rng, path); - - [str1, str2].forEach((str, j, a) => { - str.split('').forEach((_c, i) => { - const prefix = str.slice(0, i); - - it( - 'should complete state ' + - str + - ' value for default import used as tag, with prefix ' + - prefix + - ' ', - () => { - const rng = createRange(6, 4, 6, 4 + i); - const asserter = asserters.getCompletions( - 'pseudo-elements/default-import-as-tag.st.css', - prefix - ); - const exp: Array> = []; - const notExp: Array> = []; - exp.push(createCompletion(a[j], rng, './import.st.css')); - if (prefix.length <= 1) { - exp.push(createCompletion(a[1 - j], rng, './import.st.css')); - } else { - notExp.push(createCompletion(a[1 - j], rng, './import.st.css')); - } - asserter.suggested(exp); - asserter.notSuggested(notExp); - } - ); - - it( - 'should complete state ' + - str + - ' value for local class extending default import, with prefix ' + - prefix + - ' ', - () => { - const rng = createRange(9, 5, 9, 5 + i); - const asserter = asserters.getCompletions( - 'pseudo-elements/default-import-extended.st.css', - prefix - ); - const exp: Array> = []; - const notExp: Array> = []; - exp.push(createCompletion(a[j], rng, './import.st.css')); - if (prefix.length <= 1) { - exp.push(createCompletion(a[1 - j], rng, './import.st.css')); - } else { - notExp.push(createCompletion(a[1 - j], rng, './import.st.css')); - } - asserter.suggested(exp); - asserter.notSuggested(notExp); - } - ); - }); - }); - - [str3, str4].forEach((str, j, a) => { - str.split('').forEach((_c, i) => { - const prefix = str.slice(0, i); - - it( - 'should complete state ' + - str + - ' value for local class extending named import, with prefix ' + - prefix + - ' ', - () => { - const rng = createRange(9, 5, 9, 5 + i); - const asserter = asserters.getCompletions( - 'pseudo-elements/named-import-extended-named.st.css', - prefix - ); - const exp: Array> = []; - const notExp: Array> = []; - exp.push(createCompletion(a[j], rng, './import.st.css')); - if (prefix.length <= 1) { - exp.push(createCompletion(a[1 - j], rng, './import.st.css')); - } else { - notExp.push(createCompletion(a[1 - j], rng, './import.st.css')); - } - notExp.push(createCompletion(str1, rng, './import.st.css')); - notExp.push(createCompletion(str2, rng, './import.st.css')); - asserter.suggested(exp); - asserter.notSuggested(notExp); - } - ); - }); - }); - - [str1, str2].forEach((str, j, a) => { - str.split('').forEach((_c, i) => { - const prefix = str.slice(0, i); - it( - 'should complete state ' + - str + - ' after pseudo-element, with prefix ' + - prefix + - ' ', - () => { - const rng = createRange(10, 11, 10, 11 + i); - const asserter = asserters.getCompletions( - 'pseudo-elements/recursive-import-3.st.css', - prefix - ); - const exp: Array> = []; - const notExp: Array> = []; - exp.push(createCompletion(a[j], rng, './recursive-import-1.st.css')); - if (prefix.length <= 1) { - exp.push( - createCompletion(a[1 - j], rng, './recursive-import-1.st.css') - ); - } else { - notExp.push( - createCompletion(a[1 - j], rng, './recursive-import-1.st.css') - ); - } - notExp.push(createCompletion(str3, rng, './recursive-import-1.st.css')); - notExp.push(createCompletion(str4, rng, './recursive-import-1.st.css')); - asserter.suggested(exp); - asserter.notSuggested(notExp); - } - ); - - it( - 'should complete state ' + - str + - ' after pseudo-element when line has leading spaces, with prefix ' + - prefix + - ' ', - () => { - const rng = createRange(10, 12, 10, 12 + i); - const asserter = asserters.getCompletions( - 'pseudo-elements/recursive-import-3-leading-space.st.css', - prefix - ); - const exp: Array> = []; - const notExp: Array> = []; - exp.push(createCompletion(a[j], rng, './recursive-import-1.st.css')); - if (prefix.length <= 1) { - exp.push( - createCompletion(a[1 - j], rng, './recursive-import-1.st.css') - ); - } else { - notExp.push( - createCompletion(a[1 - j], rng, './recursive-import-1.st.css') - ); - } - notExp.push(createCompletion(str3, rng, './recursive-import-1.st.css')); - notExp.push(createCompletion(str4, rng, './recursive-import-1.st.css')); - asserter.suggested(exp); - asserter.notSuggested(notExp); - } - ); - }); - }); - - [str3, str4].forEach((str) => { - str.split('').forEach((_c, i) => { - const prefix = str.slice(0, i); - it( - 'should complete only unused pseudo-element states when pseudo-element state exists, with prefix ' + - prefix + - ' ', - () => { - const rng = createRange(9, 25, 9, 25 + i); - const asserter = asserters.getCompletions( - 'pseudo-elements/multiple-states.st.css', - prefix - ); - const exp: Array> = []; - const notExp: Array> = []; - if (prefix.length <= 1 || str === str4) { - exp.push(createCompletion(str4, rng, './import.st.css')); - } - notExp.push(createCompletion(str1, rng, './import.st.css')); - notExp.push(createCompletion(str2, rng, './import.st.css')); - notExp.push(createCompletion(str3, rng, './import.st.css')); - asserter.suggested(exp); - asserter.notSuggested(notExp); - } - ); - }); - }); - }); - - describe('Deep recursive imports', () => { - const str = ':loompa'; - const createCompletion = (str: string, rng: ProviderRange, path: string) => - asserters.stateSelectorCompletion(str.slice(1), rng, path); - - str.split('').forEach((_c, i) => { - const prefix = str.slice(0, i); - const rng = createRange(10, 52, 10, 52 + i); - it( - 'should complete state ' + - str + - ' in deep chain ending with state, with prefix ' + - prefix + - ' ', - () => { - const asserter = asserters.getCompletions( - 'pseudo-elements/recursive-import-3-deep-state.st.css', - prefix - ); - const exp: Array> = []; - const notExp: Array> = []; - exp.push(createCompletion(str, rng, './recursive-import-0.st.css')); - asserter.suggested(exp); - asserter.notSuggested(notExp); - } - ); - }); }); }); diff --git a/packages/language-service/test/lib/diagnostics.spec.ts b/packages/language-service/test/lib/diagnostics.spec.ts index 9df7d16fb5..abdfa6edb5 100644 --- a/packages/language-service/test/lib/diagnostics.spec.ts +++ b/packages/language-service/test/lib/diagnostics.spec.ts @@ -176,6 +176,14 @@ describe('diagnostics', () => { const diagnostics = createDiagnostics( { [filePath]: deindent(` + @st-scope{ + .root {} + } + + @st-scope { + .root {} + } + @st-scope [div=rtl] { .root {} } diff --git a/packages/language-service/test/test-kit/test-lang-service.ts b/packages/language-service/test/test-kit/test-lang-service.ts index 46feb2fc12..5d8044ef5d 100644 --- a/packages/language-service/test/test-kit/test-lang-service.ts +++ b/packages/language-service/test/test-kit/test-lang-service.ts @@ -67,12 +67,14 @@ export function testLangService( } const service = new StylableLanguageService({ fs, stylable }); - return { + const api = { fs, stylable, service, carets, - assertCompletions, + assertCompletions: (...args: AssertArgs) => { + assertCompletions(api, args); + }, completion( data: T[], template: (value: T) => Partial @@ -87,19 +89,25 @@ export function testLangService( fs.readFileSync(filePath, { encoding: 'utf-8' }) ); return { - replaceText( - offset: number, - text: string, - replaceOffsets?: Parameters[1] - ) { - const position = document.positionAt(offset); - return TextEdit.replace(range(position, replaceOffsets), text); - }, + replaceText: createReplaceText(document), }; }, }; + return api; +} +function createReplaceText(document: TextDocument) { + return function replaceText( + offset: number, + text: string, + replaceOffsets?: Parameters[1] + ) { + const position = document.positionAt(offset); + return TextEdit.replace(range(position, replaceOffsets), text); + }; } +type TestKitApi = ReturnType; + function setupFileSystem(input: string | IDirectoryContents, options: Partial) { const content = typeof input === `string` ? { '/entry.st.css': input } : input; if (options.testOnNativeFileSystem) { @@ -113,17 +121,42 @@ function setupFileSystem(input: string | IDirectoryContents, options: Partial>; unexpectedList?: Array>; message?: string; -}) { +} +type AssertArgs = + | [config: AssertCompletionsConfig] + | [ + filePath: string, + config: (context: { + filePath: string; + carets: Record; + textEdit: { + replaceText: ReturnType; + }; + }) => AssertCompletionsConfig + ]; + +export function assertCompletions( + api: Pick, + [configOrPath, generateConfig]: AssertArgs +) { + const { + actualList, + expectedList = [], + unexpectedList = [], + message = '', + } = typeof configOrPath === 'string' + ? generateConfig!({ + filePath: configOrPath, + carets: api.carets[configOrPath], + textEdit: api.textEditContext(configOrPath), + }) + : configOrPath; + const messagePrefix = message ? `(${message}) ` : ''; for (const expected of expectedList) { const actual = actualList.find(({ label }) => label === expected.label); @@ -132,9 +165,11 @@ export function assertCompletions({ `${messagePrefix}expected to find completion with label "${expected.label}"` ); } - for (const [expectedField, expectedValue] of Object.entries(expected)) { + for (const [expectedField, expectedValue] of Object.entries(expected) as [ + [keyof CompletionItem, any] + ]) { const expectLabel = `${messagePrefix}expected "${expected.label}" completions to have ${expectedField}`; - expect((actual as any)[expectedField], expectLabel).to.eql(expectedValue); + expect(actual[expectedField], expectLabel).to.eql(expectedValue); } } for (const expected of unexpectedList) { diff --git a/packages/module-utils/README.md b/packages/module-utils/README.md index b864ba3ad7..5204584fbc 100644 --- a/packages/module-utils/README.md +++ b/packages/module-utils/README.md @@ -12,5 +12,7 @@ Creates a factory for creating multiple Stylable modules in a shared context, us Creates a single Stylable module source code. +> This function moved to `@stylable/core` and will be removed in the next major version. + ## License Copyright (c) 2017 Wix.com Ltd. All Rights Reserved. Use of this source code is governed by an [MIT license](./LICENSE). diff --git a/packages/module-utils/package.json b/packages/module-utils/package.json index 0ecb7a7468..815c30f28d 100644 --- a/packages/module-utils/package.json +++ b/packages/module-utils/package.json @@ -1,14 +1,14 @@ { "name": "@stylable/module-utils", - "version": "5.11.0", + "version": "5.17.0", "description": "Stylable module creation utilities", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\"" }, "dependencies": { - "@stylable/core": "^5.11.0", - "@tokey/core": "^1.3.0", + "@stylable/core": "^5.17.0", + "@tokey/core": "^1.4.0", "vlq": "^2.0.4" }, "files": [ diff --git a/packages/module-utils/src/index.ts b/packages/module-utils/src/index.ts index 98b1bb1751..0f15550b4c 100644 --- a/packages/module-utils/src/index.ts +++ b/packages/module-utils/src/index.ts @@ -4,4 +4,5 @@ export { createModuleSource, generateModuleSource } from './module-source'; export { Options, stylableModuleFactory } from './module-factory'; export { generateDTSContent } from './generate-dts'; export { generateDTSSourceMap } from './generate-dts-sourcemaps'; -export { generateStylableJSModuleSource } from './stylable-js-module-source'; +// ToDo(major): moved to core +export { generateStylableJSModuleSource } from '@stylable/core'; diff --git a/packages/module-utils/src/module-factory.ts b/packages/module-utils/src/module-factory.ts index fd7e2ed0b9..1a2fce0510 100644 --- a/packages/module-utils/src/module-factory.ts +++ b/packages/module-utils/src/module-factory.ts @@ -1,5 +1,4 @@ -import { Stylable, StylableConfig } from '@stylable/core'; -import { generateStylableJSModuleSource } from './stylable-js-module-source'; +import { Stylable, StylableConfig, generateStylableJSModuleSource } from '@stylable/core'; export interface Options { injectCSS: boolean; diff --git a/packages/node/package.json b/packages/node/package.json index bf9a8e2175..ffaddf22b8 100644 --- a/packages/node/package.json +++ b/packages/node/package.json @@ -1,15 +1,15 @@ { "name": "@stylable/node", - "version": "5.11.0", + "version": "5.17.0", "description": "Integrate Stylable into your node application", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\" --timeout 10000" }, "dependencies": { - "@stylable/build-tools": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", + "@stylable/build-tools": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", "find-config": "^1.0.0" }, "files": [ diff --git a/packages/node/src/find-files.ts b/packages/node/src/find-files.ts index 7994e1c9f8..5de3e3a4a6 100644 --- a/packages/node/src/find-files.ts +++ b/packages/node/src/find-files.ts @@ -17,16 +17,15 @@ export function findFiles( while (folders.length) { const current = folders.pop()!; try { - fs.readdirSync(current).forEach((item: string) => { - if (blacklist.has(item)) { + fs.readdirSync(current, { withFileTypes: true }).forEach((item) => { + if (blacklist.has(item.name)) { return; } - const itemFullPath = join(current, item); + const itemFullPath = join(current, item.name); try { - const status = fs.statSync(itemFullPath); - if (status.isDirectory()) { + if (item.isDirectory()) { folders.push(itemFullPath); - } else if (status.isFile() && itemFullPath.endsWith(ext)) { + } else if (item.isFile() && itemFullPath.endsWith(ext)) { result.add( useRelative ? relative(rootDirectory, itemFullPath) : itemFullPath ); diff --git a/packages/node/src/find-package-json.ts b/packages/node/src/find-package-json.ts new file mode 100644 index 0000000000..fb355ab32a --- /dev/null +++ b/packages/node/src/find-package-json.ts @@ -0,0 +1,38 @@ +import fs from 'fs'; +import { dirname, join } from 'path'; + +export function findPackageJson( + cwd: string, + cache = new Map(), + visited: string[] = [] +) { + while (cwd) { + if (cache.has(cwd)) { + return { + packageJsonPath: cache.get(cwd), + visited, + cache, + }; + } + + const packageJsonPath = join(cwd, 'package.json'); + visited.push(cwd); + if (fs.existsSync(packageJsonPath)) { + for (const dir of visited) { + cache.set(dir, packageJsonPath); + } + return { + packageJsonPath, + visited, + cache, + }; + } else { + const parent = dirname(cwd); + if (parent === cwd) { + return null; + } + cwd = parent; + } + } + return null; +} diff --git a/packages/node/src/index.ts b/packages/node/src/index.ts index f6f47dd176..6a0a909e3a 100644 --- a/packages/node/src/index.ts +++ b/packages/node/src/index.ts @@ -3,5 +3,6 @@ export { resolveNamespace, resolveNamespaceFactory, createNamespaceStrategyNode, + packageJsonLookupCache, } from './resolve-namespace'; export { FileSystem, findFiles } from './find-files'; diff --git a/packages/node/src/resolve-namespace.ts b/packages/node/src/resolve-namespace.ts index 5bda089a84..5a4c661d93 100644 --- a/packages/node/src/resolve-namespace.ts +++ b/packages/node/src/resolve-namespace.ts @@ -4,7 +4,7 @@ import { defaultNoMatchHandler, } from '@stylable/core'; import { dirname, relative } from 'path'; -import findConfig from 'find-config'; +import { findPackageJson } from './find-package-json'; export function resolveNamespaceFactory( hashSalt = '', @@ -14,13 +14,18 @@ export function resolveNamespaceFactory( return createNamespaceStrategyNode({ hashSalt, prefix, ...options }); } +export const packageJsonLookupCache = new Map(); + export function createNamespaceStrategyNode(options: Partial = {}) { return createNamespaceStrategy({ normalizePath(packageRoot: string, stylesheetPath: string) { return relative(packageRoot, stylesheetPath).replace(/\\/g, '/'); }, getPackageInfo: (stylesheetPath) => { - const configPath = findConfig('package.json', { cwd: dirname(stylesheetPath) }); + const configPath = findPackageJson( + dirname(stylesheetPath), + packageJsonLookupCache + )?.packageJsonPath; if (!configPath) { throw new Error(`Could not find package.json for ${stylesheetPath}`); } diff --git a/packages/optimizer/package.json b/packages/optimizer/package.json index ee076bc991..9aaf4e97ef 100644 --- a/packages/optimizer/package.json +++ b/packages/optimizer/package.json @@ -1,16 +1,16 @@ { "name": "@stylable/optimizer", - "version": "5.11.0", + "version": "5.17.0", "description": "Stylable core optimizer", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\"" }, "dependencies": { - "@stylable/core": "^5.11.0", - "@tokey/css-selector-parser": "^0.6.1", + "@stylable/core": "^5.17.0", + "@tokey/css-selector-parser": "^0.6.2", "csso": "^5.0.5", - "postcss": "^8.4.23" + "postcss": "^8.4.32" }, "files": [ "dist", diff --git a/packages/rollup-plugin/package.json b/packages/rollup-plugin/package.json index b55428b8f1..558ddcb42c 100644 --- a/packages/rollup-plugin/package.json +++ b/packages/rollup-plugin/package.json @@ -1,22 +1,22 @@ { "name": "@stylable/rollup-plugin", - "version": "5.11.0", + "version": "5.17.0", "description": "Stylable plugin for Rollup", "main": "dist/index.js", "scripts": { "test": "mocha \"dist/test/**/*.spec.js\"" }, "peerDependencies": { - "rollup": "^2.70.0 || ^3.0.0" + "rollup": "^2.70.0 || ^3.0.0 || ^4.0.0" }, "dependencies": { - "@stylable/build-tools": "^5.11.0", - "@stylable/cli": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "decache": "^4.6.1", + "@stylable/build-tools": "^5.17.0", + "@stylable/cli": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "decache": "^4.6.2", "mime": "^3.0.0" }, "files": [ diff --git a/packages/rollup-plugin/src/index.ts b/packages/rollup-plugin/src/index.ts index 2d36004930..c249d972ea 100644 --- a/packages/rollup-plugin/src/index.ts +++ b/packages/rollup-plugin/src/index.ts @@ -14,7 +14,7 @@ import { hasImportedSideEffects, collectImportsWithSideEffects, } from '@stylable/build-tools'; -import { resolveNamespace as resolveNamespaceNode } from '@stylable/node'; +import { packageJsonLookupCache, resolveNamespace as resolveNamespaceNode } from '@stylable/node'; import { StylableOptimizer } from '@stylable/optimizer'; import decache from 'decache'; import { @@ -110,6 +110,7 @@ export function stylableRollupPlugin({ if (stylable) { clearRequireCache(); stylable.initCache(); + packageJsonLookupCache.clear(); } else { const stConfig = stylableConfig({ fileSystem: fs, @@ -177,6 +178,7 @@ export function stylableRollupPlugin({ const { isStFile, isLoadableCssFile, path } = getLoadableModuleData(id); if (isLoadableCssFile || isStFile) { const code = fs.readFileSync(path, 'utf8'); + this.addWatchFile(path); return { code, moduleSideEffects: isLoadableCssFile }; } return null; diff --git a/packages/runtime/package.json b/packages/runtime/package.json index 7a77d13305..d52d11b411 100644 --- a/packages/runtime/package.json +++ b/packages/runtime/package.json @@ -1,6 +1,6 @@ { "name": "@stylable/runtime", - "version": "5.11.0", + "version": "5.17.0", "description": "Stylable runtime DOM integration", "main": "dist/index.js", "scripts": { diff --git a/packages/schema-extract/package.json b/packages/schema-extract/package.json index 4c51819c55..72b6d8e740 100644 --- a/packages/schema-extract/package.json +++ b/packages/schema-extract/package.json @@ -1,14 +1,14 @@ { "name": "@stylable/schema-extract", - "version": "5.11.0", + "version": "5.17.0", "description": "A utility for extracting JSON schema objects from a Stylable stylesheet", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\"" }, "dependencies": { - "@stylable/core": "^5.11.0", - "jest-docblock": "^29.4.3" + "@stylable/core": "^5.17.0", + "jest-docblock": "^29.7.0" }, "files": [ "dist", diff --git a/packages/uni-driver/package.json b/packages/uni-driver/package.json index ece5273aab..0d3419d32f 100644 --- a/packages/uni-driver/package.json +++ b/packages/uni-driver/package.json @@ -1,6 +1,6 @@ { "name": "@stylable/uni-driver", - "version": "5.11.0", + "version": "5.17.0", "description": "Stylable UniDriver testing utilities", "main": "dist/index.js", "scripts": { diff --git a/packages/webpack-extensions/package.json b/packages/webpack-extensions/package.json index 4ec27872ee..443150ce84 100644 --- a/packages/webpack-extensions/package.json +++ b/packages/webpack-extensions/package.json @@ -1,6 +1,6 @@ { "name": "@stylable/webpack-extensions", - "version": "5.11.0", + "version": "5.17.0", "description": "Experimental Stylable webpack plugins", "main": "dist/index.js", "scripts": { @@ -10,10 +10,10 @@ "webpack": "^5.30.0" }, "dependencies": { - "@stylable/core": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/webpack-plugin": "^5.11.0", - "@tokey/css-selector-parser": "^0.6.1", + "@stylable/core": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/webpack-plugin": "^5.17.0", + "@tokey/css-selector-parser": "^0.6.2", "find-config": "^1.0.0", "lodash.clonedeep": "^4.5.0" }, diff --git a/packages/webpack-extensions/src/create-metadata-stylesheet.ts b/packages/webpack-extensions/src/create-metadata-stylesheet.ts index 3185b192af..faa0218e14 100644 --- a/packages/webpack-extensions/src/create-metadata-stylesheet.ts +++ b/packages/webpack-extensions/src/create-metadata-stylesheet.ts @@ -26,7 +26,7 @@ export function createMetadataForStylesheet( }; } -export function createNamespaceMapping( +function createNamespaceMapping( usedMeta: Map, hashes: Map ) { @@ -37,7 +37,7 @@ export function createNamespaceMapping( return namespaceMapping; } -export function rewriteImports( +function rewriteImports( usedMeta: Map, hashes: Map ) { @@ -57,8 +57,8 @@ export function rewriteImports( ); } if (rawRule.type === 'rule') { - rawRule.walkDecls((decl) => { - if (decl.prop === `-st-from`) { + rawRule.nodes.forEach((decl) => { + if (decl.type === 'decl' && decl.prop === `-st-from`) { decl.value = JSON.stringify( `/${ensureHash(resolved.meta, hashes)}.st.css` ); @@ -92,7 +92,7 @@ function ruleByLocation(ruleA: Rule | AtRule) { }; } -export function ensureHash(meta: StylableMeta, hashes: Map) { +function ensureHash(meta: StylableMeta, hashes: Map) { const hash = hashes.get(meta); if (!hash) { throw new Error('Missing meta hash for:' + meta.source); @@ -100,15 +100,15 @@ export function ensureHash(meta: StylableMeta, hashes: Map return hash; } -export function createContentHashPerMeta(usedMeta: Iterable) { +function createContentHashPerMeta(usedMeta: Iterable) { const hashes = new Map(); for (const meta of usedMeta) { - hashes.set(meta, hashContent(meta.sourceAst.toString())); + hashes.set(meta, hashContent(meta.source + meta.sourceAst.toString())); } return hashes; } -export function collectDependenciesDeep( +function collectDependenciesDeep( stylable: Stylable, meta: StylableMeta, out = new Map() diff --git a/packages/webpack-extensions/src/index.ts b/packages/webpack-extensions/src/index.ts index a13cffb824..d0a7de1f30 100644 --- a/packages/webpack-extensions/src/index.ts +++ b/packages/webpack-extensions/src/index.ts @@ -9,6 +9,8 @@ export { applyStylableForceStateSelectors, createDataAttr, createForceStateMatchers, + createForceStatesContext, + mutateWithForceStates, } from './stylable-forcestates-plugin'; export { GetLogicModule, diff --git a/packages/webpack-extensions/src/stylable-forcestates-plugin.ts b/packages/webpack-extensions/src/stylable-forcestates-plugin.ts index 61abbea33e..3bd66711c4 100644 --- a/packages/webpack-extensions/src/stylable-forcestates-plugin.ts +++ b/packages/webpack-extensions/src/stylable-forcestates-plugin.ts @@ -36,50 +36,21 @@ export function createDataAttr(dataAttrPrefix: string, stateName: string, param? const statePart = param !== undefined ? STCustomState.resolveStateParam(param) : ''; return `${dataAttrPrefix}${paramWithValueExtraDil}${stateName}${statePart}`; } - +/** + * + * @param targetAst - target ast to transform + * @param namespaceMapping - known namespaces (use to detect framework specific namespaces like Stylable) + * @param dataPrefix - prefix for the data attribute + * @param plugin - plugin to override the context + */ export function applyStylableForceStateSelectors( targetAst: postcss.Root, namespaceMapping: Record | ((namespace: string) => boolean) = {}, dataPrefix = OVERRIDE_STATE_PREFIX, plugin: (ctx: AddForceStateSelectorsContext) => AddForceStateSelectorsContext = (id) => id ) { - const isKnownNamespace = - typeof namespaceMapping === 'function' - ? namespaceMapping - : (name: string) => hasOwnProperty.call(namespaceMapping, name); - const mapping: Record = {}; - addForceStateSelectors( - targetAst, - plugin({ - getForceStateAttrContentFromNative(name) { - return this.getForceStateAttrContent(name); - }, - getForceStateAttrContent(name) { - return dataPrefix + name; - }, - getStateClassName(name) { - const parts = name.match(MATCH_STATE_CLASS); - return parts![2]; - }, - getStateAttr(content) { - const parts = content.match(MATCH_STATE_ATTR); - return parts![2]; - }, - isStateClassName(name) { - const parts = name.match(MATCH_STATE_CLASS); - return parts ? isKnownNamespace(parts[1]) : false; - }, - isStateAttr(content) { - const parts = content.match(MATCH_STATE_ATTR); - return parts ? isKnownNamespace(parts[1]) : false; - }, - onMapping(key, value) { - mapping[key] = value; - mapping[value] = key; - }, - }) - ); + addForceStateSelectors(targetAst, createForceStatesContext(dataPrefix, namespaceMapping, mapping, plugin)); return mapping; } @@ -93,22 +64,91 @@ export interface AddForceStateSelectorsContext { onMapping(key: string, value: string): void; } -export function addForceStateSelectors(ast: postcss.Root, context: AddForceStateSelectorsContext) { - ast.walkRules((rule) => { - const selectorAst = parseCssSelector(rule.selector); +/** + * adds force state selectors to the entire ast + * @param targetAst - target ast to transform + * @param context - context to use for the transformation + */ +export function addForceStateSelectors( + targetAst: postcss.Root, + context: AddForceStateSelectorsContext +) { + targetAst.walkRules((rule) => + mutateWithForceStates(parseCssSelector(rule.selector), context, rule) + ); +} +/** + * creates a context to share across the transformation of addForceStateSelectors + * @param dataPrefix - prefix for the data attribute + * @param namespaceMapping - known namespaces (use to detect framework specific namespaces like Stylable) + * @param mapping - mapping of the original state to the override state + * @param plugin - plugin to override the context + */ +export function createForceStatesContext( + dataPrefix: string, + namespaceMapping: Record | ((namespace: string) => boolean), + mapping: Record, + plugin: (ctx: AddForceStateSelectorsContext) => AddForceStateSelectorsContext +) { + const isKnownNamespace = + typeof namespaceMapping === 'function' + ? namespaceMapping + : (name: string) => hasOwnProperty.call(namespaceMapping, name); + + return plugin({ + getForceStateAttrContentFromNative(name) { + return this.getForceStateAttrContent(name); + }, + getForceStateAttrContent(name) { + return dataPrefix + name; + }, + getStateClassName(name) { + const parts = name.match(MATCH_STATE_CLASS); + return parts![2]; + }, + getStateAttr(content) { + const parts = content.match(MATCH_STATE_ATTR); + return parts![2]; + }, + isStateClassName(name) { + const parts = name.match(MATCH_STATE_CLASS); + return parts ? isKnownNamespace(parts[1]) : false; + }, + isStateAttr(content) { + const parts = content.match(MATCH_STATE_ATTR); + return parts ? isKnownNamespace(parts[1]) : false; + }, + onMapping(key, value) { + mapping[key] = value; + mapping[value] = key; + }, + }); +} - const overrideSelectors = selectorAst.reduce((selectors, selector) => { - if (hasStates(selector, context)) { - selectors.push(transformStates(cloneDeep(selector), context)); - } - return selectors; - }, [] as SelectorList); +/** + * + * @param selectorAst - selector ast to override + * @param context - context to use for the transformation + * @param rule - optional rule to update the selector on (if not provided only the selector ast will be mutated) + */ +export function mutateWithForceStates( + selectorAst: SelectorList, + context: AddForceStateSelectorsContext, + rule?: postcss.Rule +) { + const overrideSelectors: SelectorList = []; + for (const selector of selectorAst) { + if (hasStates(selector, context)) { + overrideSelectors.push(transformStates(cloneDeep(selector), context)); + } + } - if (overrideSelectors.length) { - selectorAst.push(...overrideSelectors); + if (overrideSelectors.length) { + selectorAst.push(...overrideSelectors); + if (rule) { rule.selector = stringifySelectorAst(selectorAst); } - }); + } } function isNative(name: string) { diff --git a/packages/webpack-extensions/src/stylable-manifest-plugin.ts b/packages/webpack-extensions/src/stylable-manifest-plugin.ts index 2f2934852e..b524d2be53 100644 --- a/packages/webpack-extensions/src/stylable-manifest-plugin.ts +++ b/packages/webpack-extensions/src/stylable-manifest-plugin.ts @@ -139,10 +139,16 @@ export class StylableManifestPlugin { stylable: Stylable, modules: Module[] ): MetadataList { - const stylableComps = modules.filter((module) => { - const resource = (module as any).resource; - return resource && this.options.filterComponents(resource); - }); + const stylableComps = modules + .filter((module) => { + const resource = (module as any).resource; + return resource && this.options.filterComponents(resource); + }) + .sort((m1, m2) => { + const r = (m1 as any).resource; + const r2 = (m2 as any).resource; + return r.localeCompare(r2); + }); return stylableComps.map((module) => { const resource = (module as any).resource; diff --git a/packages/webpack-extensions/src/stylable-metadata-plugin.ts b/packages/webpack-extensions/src/stylable-metadata-plugin.ts index b7f76cdcdf..9598785831 100644 --- a/packages/webpack-extensions/src/stylable-metadata-plugin.ts +++ b/packages/webpack-extensions/src/stylable-metadata-plugin.ts @@ -6,6 +6,8 @@ import { ComponentConfig, ComponentMetadataBuilder } from './component-metadata- import { getCSSViewModuleWebpack, + getWebpackBuildMeta, + getStylableBuildMeta, getStylableModules, isStylableModule, uniqueFilterMap, @@ -69,9 +71,11 @@ export class StylableMetadataPlugin { const getViewModule = getCSSViewModuleWebpack(compilation.moduleGraph); const stylableModulesWithData = getStylableModules(compilation); for (const module of stylableModules) { + const buildMeta = getWebpackBuildMeta(module); + const stylableBuildMeta = getStylableBuildMeta(module); const namespace = - stylableModulesWithData?.get(module)?.namespace ?? module.buildMeta.namespace; - const depth = module.buildMeta.stylable.depth; + stylableModulesWithData?.get(module)?.namespace ?? buildMeta.namespace; + const depth = stylableBuildMeta.depth; const resource = this.options.normalizeModulePath ? this.options.normalizeModulePath(module.resource, builder) : module.resource; diff --git a/packages/webpack-extensions/test/e2e/fs-manifest.spec.ts b/packages/webpack-extensions/test/e2e/fs-manifest.spec.ts index a398ecbf06..49a625c21c 100644 --- a/packages/webpack-extensions/test/e2e/fs-manifest.spec.ts +++ b/packages/webpack-extensions/test/e2e/fs-manifest.spec.ts @@ -1,9 +1,9 @@ -import { readFileSync } from 'fs'; import { EOL } from 'os'; import { dirname, join } from 'path'; import { expect } from 'chai'; import { StylableProjectRunner } from '@stylable/e2e-test-kit'; -import { ComponentsMetadata, hashContent } from '@stylable/webpack-extensions'; +import type { ComponentsMetadata } from '@stylable/webpack-extensions'; +import { getSheetContentAndHash } from './utils'; const project = 'manifest-plugin'; const projectDir = dirname( @@ -29,13 +29,11 @@ describe(`${project} - fs-manifest`, () => { const manifestKey = Object.keys(assets).find((key) => key.startsWith('stylable.manifest'))!; const source = assets[manifestKey].source(); - const compContent = readFileSync( - join(projectRunner.testDir, 'Button.comp.st.css'), - 'utf-8' + const button = getSheetContentAndHash(join(projectRunner.testDir, 'Button.comp.st.css')); + const accordion = getSheetContentAndHash( + join(projectRunner.testDir, 'Accordion.comp.st.css') ); - const commonContent = readFileSync(join(projectRunner.testDir, 'common.st.css'), 'utf-8'); - const commonHash = hashContent(commonContent); - const compHash = hashContent(compContent); + const common = getSheetContentAndHash(join(projectRunner.testDir, 'common.st.css')); const fsMetadata: ComponentsMetadata = { name: 'manifest-plugin-test', @@ -44,22 +42,35 @@ describe(`${project} - fs-manifest`, () => { Button: { id: 'Button', namespace: 'Buttoncomp1090430236', - stylesheetPath: `/${compHash}.st.css`, + stylesheetPath: `/${button.hash}.st.css`, + }, + Accordion: { + id: 'Accordion', + namespace: 'Accordioncomp4108556147', + stylesheetPath: `/${accordion.hash}.st.css`, }, }, fs: { [`/manifest-plugin-test/index.st.css`]: { - content: `:import{-st-from: "/${compHash}.st.css";-st-default: Button;} .root Button{}${EOL}`, + content: [ + `:import{-st-from: "/${accordion.hash}.st.css";-st-default: Accordion;} .root Accordion{}`, + `:import{-st-from: "/${button.hash}.st.css";-st-default: Button;} .root Button{}`, + ``, // empty line + ].join(EOL), metadata: { namespace: 'manifest-plugin-test', }, }, - [`/${compHash}.st.css`]: { - content: compContent.replace('./common.st.css', `/${commonHash}.st.css`), + [`/${button.hash}.st.css`]: { + content: button.content.replace('./common.st.css', `/${common.hash}.st.css`), metadata: { namespace: 'Buttoncomp1090430236' }, }, - [`/${commonHash}.st.css`]: { - content: commonContent, + [`/${accordion.hash}.st.css`]: { + content: accordion.content.replace('./common.st.css', `/${common.hash}.st.css`), + metadata: { namespace: 'Accordioncomp4108556147' }, + }, + [`/${common.hash}.st.css`]: { + content: common.content, metadata: { namespace: 'common911354609' }, }, }, diff --git a/packages/webpack-extensions/test/e2e/manifest.css-vars.spec.ts b/packages/webpack-extensions/test/e2e/manifest.css-vars.spec.ts index 9617f05d69..883af5761e 100644 --- a/packages/webpack-extensions/test/e2e/manifest.css-vars.spec.ts +++ b/packages/webpack-extensions/test/e2e/manifest.css-vars.spec.ts @@ -1,9 +1,8 @@ import { StylableProjectRunner } from '@stylable/e2e-test-kit'; import { expect } from 'chai'; -import { readFileSync } from 'fs'; import { dirname, join } from 'path'; -import { hashContent } from '@stylable/webpack-extensions'; import { EOL } from 'os'; +import { getSheetContentAndHash } from './utils'; const project = 'manifest-plugin'; const projectDir = dirname( @@ -32,29 +31,39 @@ describe(`${project} - manifest (vars)`, () => { const manifestKey = Object.keys(assets).find((key) => key.startsWith('stylable.manifest'))!; const source = assets[manifestKey].source(); - const compContent = readFileSync( - join(projectRunner.testDir, 'Button.comp.st.css'), - 'utf-8' + const button = getSheetContentAndHash(join(projectRunner.testDir, 'Button.comp.st.css')); + const accordion = getSheetContentAndHash( + join(projectRunner.testDir, 'Accordion.comp.st.css') ); - const commonContent = readFileSync(join(projectRunner.testDir, 'common.st.css'), 'utf-8'); - const commonHash = hashContent(commonContent); - const compHash = hashContent(compContent); + const common = getSheetContentAndHash(join(projectRunner.testDir, 'common.st.css')); expect(JSON.parse(source)).to.deep.include({ name: 'manifest-plugin-test', version: '0.0.0-test', - componentsIndex: `:import{-st-from: "/${compHash}.st.css";-st-default: Button;-st-named:--myColor as --Button-myColor;} .root Button{}${EOL}`, - componentsEntries: { Button: `/${compHash}.st.css` }, + componentsIndex: [ + `:import{-st-from: "/${accordion.hash}.st.css";-st-default: Accordion;-st-named:--myColor as --Accordion-myColor;} .root Accordion{}`, + `:import{-st-from: "/${button.hash}.st.css";-st-default: Button;-st-named:--myColor as --Button-myColor;} .root Button{}`, + ``, // empty line + ].join(EOL), + componentsEntries: { + Button: `/${button.hash}.st.css`, + Accordion: `/${accordion.hash}.st.css`, + }, stylesheetMapping: { - [`/${compHash}.st.css`]: compContent.replace( + [`/${button.hash}.st.css`]: button.content.replace( + './common.st.css', + `/${common.hash}.st.css` + ), + [`/${accordion.hash}.st.css`]: accordion.content.replace( './common.st.css', - `/${commonHash}.st.css` + `/${common.hash}.st.css` ), - [`/${commonHash}.st.css`]: commonContent, + [`/${common.hash}.st.css`]: common.content, }, namespaceMapping: { - [`/${commonHash}.st.css`]: 'common911354609', - [`/${compHash}.st.css`]: 'Buttoncomp1090430236', + [`/${common.hash}.st.css`]: 'common911354609', + [`/${button.hash}.st.css`]: 'Buttoncomp1090430236', + [`/${accordion.hash}.st.css`]: 'Accordioncomp4108556147', }, }); }); diff --git a/packages/webpack-extensions/test/e2e/manifest.spec.ts b/packages/webpack-extensions/test/e2e/manifest.spec.ts index f19ea71346..6e60440454 100644 --- a/packages/webpack-extensions/test/e2e/manifest.spec.ts +++ b/packages/webpack-extensions/test/e2e/manifest.spec.ts @@ -1,9 +1,8 @@ import { StylableProjectRunner } from '@stylable/e2e-test-kit'; import { expect } from 'chai'; -import { readFileSync } from 'fs'; import { dirname, join } from 'path'; -import { hashContent } from '@stylable/webpack-extensions'; import { EOL } from 'os'; +import { getSheetContentAndHash } from './utils'; const project = 'manifest-plugin'; const projectDir = dirname( @@ -31,29 +30,39 @@ describe(`${project} - manifest (e2e)`, () => { const manifestKey = Object.keys(assets).find((key) => key.startsWith('stylable.manifest'))!; const source = assets[manifestKey].source(); - const compContent = readFileSync( - join(projectRunner.testDir, 'Button.comp.st.css'), - 'utf-8' + const button = getSheetContentAndHash(join(projectRunner.testDir, 'Button.comp.st.css')); + const accordion = getSheetContentAndHash( + join(projectRunner.testDir, 'Accordion.comp.st.css') ); - const commonContent = readFileSync(join(projectRunner.testDir, 'common.st.css'), 'utf-8'); - const commonHash = hashContent(commonContent); - const compHash = hashContent(compContent); + const common = getSheetContentAndHash(join(projectRunner.testDir, 'common.st.css')); expect(JSON.parse(source)).to.deep.include({ name: 'manifest-plugin-test', version: '0.0.0-test', - componentsIndex: `:import{-st-from: "/${compHash}.st.css";-st-default: Button;} .root Button{}${EOL}`, - componentsEntries: { Button: `/${compHash}.st.css` }, + componentsIndex: [ + `:import{-st-from: "/${accordion.hash}.st.css";-st-default: Accordion;} .root Accordion{}`, + `:import{-st-from: "/${button.hash}.st.css";-st-default: Button;} .root Button{}`, + ``, // empty line + ].join(EOL), + componentsEntries: { + Button: `/${button.hash}.st.css`, + Accordion: `/${accordion.hash}.st.css`, + }, stylesheetMapping: { - [`/${compHash}.st.css`]: compContent.replace( + [`/${button.hash}.st.css`]: button.content.replace( + './common.st.css', + `/${common.hash}.st.css` + ), + [`/${accordion.hash}.st.css`]: button.content.replace( './common.st.css', - `/${commonHash}.st.css` + `/${common.hash}.st.css` ), - [`/${commonHash}.st.css`]: commonContent, + [`/${common.hash}.st.css`]: common.content, }, namespaceMapping: { - [`/${commonHash}.st.css`]: 'common911354609', - [`/${compHash}.st.css`]: 'Buttoncomp1090430236', + [`/${common.hash}.st.css`]: 'common911354609', + [`/${button.hash}.st.css`]: 'Buttoncomp1090430236', + [`/${accordion.hash}.st.css`]: 'Accordioncomp4108556147', }, }); }); diff --git a/packages/webpack-extensions/test/e2e/metadata-loader-case.spec.ts b/packages/webpack-extensions/test/e2e/metadata-loader-case.spec.ts index 2443e3d793..6ef4c11665 100644 --- a/packages/webpack-extensions/test/e2e/metadata-loader-case.spec.ts +++ b/packages/webpack-extensions/test/e2e/metadata-loader-case.spec.ts @@ -1,8 +1,7 @@ import { StylableProjectRunner } from '@stylable/e2e-test-kit'; import { expect } from 'chai'; import { dirname, join } from 'path'; -import { readFileSync } from 'fs'; -import { hashContent } from '@stylable/webpack-extensions'; +import { getSheetContentAndHash } from './utils'; const project = 'metadata-loader-case'; const projectDir = dirname( @@ -28,18 +27,16 @@ describe(`(${project})`, () => { // eslint-disable-next-line @typescript-eslint/no-implied-eval const getMetadataFromLibraryBundle = new Function(bundleContent + '\nreturn metadata;'); - const compXContent = readFileSync(join(projectRunner.testDir, 'comp-x.st.css'), 'utf-8'); - const compContent = readFileSync(join(projectRunner.testDir, 'comp.st.css'), 'utf-8'); - const indexContent = readFileSync(join(projectRunner.testDir, 'index.st.css'), 'utf-8'); - const indexHash = hashContent(indexContent); - const compHash = hashContent(compContent); - const compXHash = hashContent(compXContent); + const comp = getSheetContentAndHash(join(projectRunner.testDir, 'comp.st.css')); + const compX = getSheetContentAndHash(join(projectRunner.testDir, 'comp-x.st.css')); + const index = getSheetContentAndHash(join(projectRunner.testDir, 'index.st.css')); + const stylesheetMapping = { - [`/${indexHash}.st.css`]: indexContent - .replace('./comp.st.css', `/${compHash}.st.css`) - .replace('./comp-x.st.css', `/${compXHash}.st.css`), - [`/${compXHash}.st.css`]: compXContent, - [`/${compHash}.st.css`]: compContent, + [`/${index.hash}.st.css`]: index.content + .replace('./comp.st.css', `/${comp.hash}.st.css`) + .replace('./comp-x.st.css', `/${compX.hash}.st.css`), + [`/${compX.hash}.st.css`]: compX.content, + [`/${comp.hash}.st.css`]: comp.content, }; const metadata = getMetadataFromLibraryBundle().default; @@ -47,12 +44,12 @@ describe(`(${project})`, () => { entry: metadata.entry, stylesheetMapping: metadata.stylesheetMapping, }).to.deep.include({ - entry: `/${indexHash}.st.css`, + entry: `/${index.hash}.st.css`, stylesheetMapping, }); - expect(metadata.namespaceMapping[`/${indexHash}.st.css`]).to.match(/index\d+/); - expect(metadata.namespaceMapping[`/${compHash}.st.css`]).to.match(/comp\d+/); - expect(metadata.namespaceMapping[`/${compXHash}.st.css`]).to.match(/compx\d+/); + expect(metadata.namespaceMapping[`/${index.hash}.st.css`]).to.match(/index\d+/); + expect(metadata.namespaceMapping[`/${comp.hash}.st.css`]).to.match(/comp\d+/); + expect(metadata.namespaceMapping[`/${compX.hash}.st.css`]).to.match(/compx\d+/); }); }); diff --git a/packages/webpack-extensions/test/e2e/projects/manifest-plugin/Accordion.comp.st.css b/packages/webpack-extensions/test/e2e/projects/manifest-plugin/Accordion.comp.st.css new file mode 100644 index 0000000000..16d66770ce --- /dev/null +++ b/packages/webpack-extensions/test/e2e/projects/manifest-plugin/Accordion.comp.st.css @@ -0,0 +1,9 @@ +:import { + -st-from: "./common.st.css"; + -st-named: myColor; +} + +.root { + --myColor: red; + color: value(myColor); +} diff --git a/packages/webpack-extensions/test/e2e/projects/manifest-plugin/Button.comp.st.css b/packages/webpack-extensions/test/e2e/projects/manifest-plugin/Button.comp.st.css index 30601cacca..16d66770ce 100644 --- a/packages/webpack-extensions/test/e2e/projects/manifest-plugin/Button.comp.st.css +++ b/packages/webpack-extensions/test/e2e/projects/manifest-plugin/Button.comp.st.css @@ -5,5 +5,5 @@ .root { --myColor: red; - color: value(myColor) + color: value(myColor); } diff --git a/packages/webpack-extensions/test/e2e/projects/manifest-plugin/index.js b/packages/webpack-extensions/test/e2e/projects/manifest-plugin/index.js index 294a70b93c..571792cdb0 100644 --- a/packages/webpack-extensions/test/e2e/projects/manifest-plugin/index.js +++ b/packages/webpack-extensions/test/e2e/projects/manifest-plugin/index.js @@ -1 +1,2 @@ import './Button.comp.st.css'; +import './Accordion.comp.st.css'; diff --git a/packages/webpack-extensions/test/e2e/utils.ts b/packages/webpack-extensions/test/e2e/utils.ts new file mode 100644 index 0000000000..6439e4654d --- /dev/null +++ b/packages/webpack-extensions/test/e2e/utils.ts @@ -0,0 +1,11 @@ +import { readFileSync } from 'fs'; +import { hashContent } from '@stylable/webpack-extensions'; + +export function getSheetContentAndHash(sheetPath: string) { + const content = readFileSync(sheetPath, 'utf-8'); + return { + path: sheetPath, + content, + hash: hashContent(sheetPath + content), + }; +} diff --git a/packages/webpack-plugin/package.json b/packages/webpack-plugin/package.json index 29d643d685..9a35336561 100644 --- a/packages/webpack-plugin/package.json +++ b/packages/webpack-plugin/package.json @@ -1,7 +1,7 @@ { "name": "@stylable/webpack-plugin", "description": "Webpack (5.x) plugin for Stylable modules", - "version": "5.11.0", + "version": "5.17.0", "main": "dist/index.js", "scripts": { "test": "mocha \"./dist/test/**/*.spec.js\" --timeout 20000" @@ -10,16 +10,16 @@ "webpack": "^5.30.0" }, "dependencies": { - "@stylable/build-tools": "^5.11.0", - "@stylable/cli": "^5.11.0", - "@stylable/core": "^5.11.0", - "@stylable/module-utils": "^5.11.0", - "@stylable/node": "^5.11.0", - "@stylable/optimizer": "^5.11.0", - "@stylable/runtime": "^5.11.0", - "decache": "^4.6.1", + "@stylable/build-tools": "^5.17.0", + "@stylable/cli": "^5.17.0", + "@stylable/core": "^5.17.0", + "@stylable/module-utils": "^5.17.0", + "@stylable/node": "^5.17.0", + "@stylable/optimizer": "^5.17.0", + "@stylable/runtime": "^5.17.0", + "decache": "^4.6.2", "lodash.clonedeep": "^4.5.0", - "postcss": "^8.4.23" + "postcss": "^8.4.32" }, "files": [ "dist", diff --git a/packages/webpack-plugin/src/index.ts b/packages/webpack-plugin/src/index.ts index e48e8962f9..917bc29e92 100644 --- a/packages/webpack-plugin/src/index.ts +++ b/packages/webpack-plugin/src/index.ts @@ -16,6 +16,7 @@ export { getOnlyChunk, getSortedModules, getStaticPublicPath, + getWebpackBuildMeta, getStylableBuildData, getStylableBuildMeta, getStylableModules, diff --git a/packages/webpack-plugin/src/mini-css-support.ts b/packages/webpack-plugin/src/mini-css-support.ts index ddc3cdfc60..402e7b945f 100644 --- a/packages/webpack-plugin/src/mini-css-support.ts +++ b/packages/webpack-plugin/src/mini-css-support.ts @@ -1,5 +1,9 @@ import type { Compilation, Compiler, NormalModule } from 'webpack'; -import { replaceMappedCSSAssetPlaceholders, getStylableBuildData } from './plugin-utils'; +import { + replaceMappedCSSAssetPlaceholders, + getStylableBuildData, + getStylableBuildMeta, +} from './plugin-utils'; import { StylableWebpackPlugin } from './plugin'; import type { BuildData } from './types'; @@ -11,7 +15,7 @@ export function injectCssModules( assetsModules: Map ) { const MiniCssExtractPlugin = compilation.options.plugins.find( - (plugin) => plugin.constructor?.name === 'MiniCssExtractPlugin' + (plugin) => plugin?.constructor?.name === 'MiniCssExtractPlugin' ); if (!MiniCssExtractPlugin) { @@ -70,7 +74,7 @@ export function injectCssModules( for (const chunk of chunkGraph.getModuleChunksIterable(module)) { const [chunkGroup] = chunk.groupsIterable; chunkGraph.connectChunkAndModule(chunk, cssModule); - chunkGroup.setModulePostOrderIndex(cssModule, module.buildMeta.stylable.depth); + chunkGroup.setModulePostOrderIndex(cssModule, getStylableBuildMeta(module).depth); } } }); diff --git a/packages/webpack-plugin/src/plugin-utils.ts b/packages/webpack-plugin/src/plugin-utils.ts index fcfc621a8b..48d10d4cac 100644 --- a/packages/webpack-plugin/src/plugin-utils.ts +++ b/packages/webpack-plugin/src/plugin-utils.ts @@ -49,7 +49,7 @@ export function isSameResourceModule(moduleA: any, moduleB: any) { } export function isStylableModule(module: any): module is NormalModule { - return module.resource?.endsWith('.st.css'); + return module?.resource?.endsWith('.st.css'); } export function isLoadedNativeCSSModule( module: any, @@ -128,6 +128,10 @@ export function replaceMappedCSSAssetPlaceholders({ getData: () => data, }); + if (!assetModule.buildInfo) { + throw new Error('Missing asset module build info for ' + resourcePath); + } + if (assetModule.buildInfo.dataUrl) { // Investigate using the data map from getData currently there is an unknown in term from escaping keeping extractDataUrlFromAssetModuleSource return extractDataUrlFromAssetModuleSource( @@ -308,8 +312,16 @@ export function createStaticCSS( return cssChunks; } +export function getWebpackBuildMeta(module: Module): NonNullable { + const buildMeta = module.buildMeta; + if (!buildMeta) { + throw new Error(`Stylable module ${module.identifier()} does not contains build meta`); + } + return buildMeta; +} + export function getStylableBuildMeta(module: Module): StylableBuildMeta { - const meta = module.buildMeta.stylable; + const meta = module.buildMeta?.stylable; if (!meta) { throw new Error(`Stylable module ${module.identifier()} does not contains build meta`); } @@ -344,7 +356,7 @@ export function findIfStylableModuleUsed( let isInUse = false; for (const connectionModule of inConnections) { - if (connectionModule.buildMeta.sideEffectFree) { + if (connectionModule.buildMeta?.sideEffectFree) { const info = moduleGraph.getExportsInfo(connectionModule); const usedExports = ( info.getUsedExports as any @@ -458,7 +470,7 @@ function getModuleRequestPath( export interface OptimizationMapping { usageMapping: Record; namespaceMapping: Record; - namespaceToFileMapping: Map>; + potentialNamespaceCollision: Map>; } export function createOptimizationMapping( @@ -473,17 +485,21 @@ export function createOptimizationMapping( acc.usageMapping[namespace] = isUsed ?? true; } acc.namespaceMapping[namespace] = optimizer.getNamespace(namespace); - if (acc.namespaceToFileMapping.has(namespace)) { - acc.namespaceToFileMapping.get(namespace)!.add(module); + if (!isUsed) { + // skip collision map for unused stylesheets + return acc; + } + if (acc.potentialNamespaceCollision.has(namespace)) { + acc.potentialNamespaceCollision.get(namespace)!.add(module); } else { - acc.namespaceToFileMapping.set(namespace, new Set([module])); + acc.potentialNamespaceCollision.set(namespace, new Set([module])); } return acc; }, { usageMapping: {}, namespaceMapping: {}, - namespaceToFileMapping: new Map>(), + potentialNamespaceCollision: new Map>(), } ); } diff --git a/packages/webpack-plugin/src/plugin.ts b/packages/webpack-plugin/src/plugin.ts index f46801b024..5a4b2c5165 100644 --- a/packages/webpack-plugin/src/plugin.ts +++ b/packages/webpack-plugin/src/plugin.ts @@ -34,6 +34,7 @@ import { getStylableBuildData, isDependencyOf, normalizeNamespaceCollisionOption, + getWebpackBuildMeta, } from './plugin-utils'; import { injectCssModules } from './mini-css-support'; import type { @@ -431,7 +432,7 @@ export class StylableWebpackPlugin { isUsed: undefined, ...loaderData, }; - module.buildMeta.stylable = stylableBuildMeta; + getWebpackBuildMeta(module).stylable = stylableBuildMeta; /** * We want to add the unused imports because we need them to calculate the depth correctly @@ -504,7 +505,7 @@ export class StylableWebpackPlugin { for (const module of modules) { if ( (isStylableModule(module) || isLoadedNativeCSSModule(module, moduleGraph)) && - module.buildMeta.stylable + module.buildMeta?.stylable ) { stylableModules.set(module, null); } @@ -588,11 +589,11 @@ export class StylableWebpackPlugin { (m) => m.resource ); - const { usageMapping, namespaceMapping, namespaceToFileMapping } = + const { usageMapping, namespaceMapping, potentialNamespaceCollision } = createOptimizationMapping(sortedModules, optimizer); reportNamespaceCollision( - namespaceToFileMapping, + potentialNamespaceCollision, compilation, normalizeNamespaceCollisionOption( this.options.unsafeMuteDiagnostics.DUPLICATE_MODULE_NAMESPACE diff --git a/packages/webpack-plugin/src/re-ext-plugin.ts b/packages/webpack-plugin/src/re-ext-plugin.ts index 9819645c3e..0f66f8b45f 100644 --- a/packages/webpack-plugin/src/re-ext-plugin.ts +++ b/packages/webpack-plugin/src/re-ext-plugin.ts @@ -43,7 +43,7 @@ export class ReExt { }, `replacing extension for ${relativeFilePath} to ${newExt}`, resolveContext, - (err: Error, resolved: unknown) => { + (err, resolved) => { err ? res(undefined) : res(resolved); } ); diff --git a/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components-deep/button.st.css b/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components-deep/button.st.css index cdf6db2836..683396a159 100644 --- a/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components-deep/button.st.css +++ b/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components-deep/button.st.css @@ -1,8 +1,9 @@ -@namespace "topBtn"; +@st-namespace "topBtn"; .root { background: red; } + .text { color: aliceblue; -} \ No newline at end of file +} diff --git a/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components-deep/index.st.css b/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components-deep/index.st.css index 69db58ba4a..f083fe3a4a 100644 --- a/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components-deep/index.st.css +++ b/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components-deep/index.st.css @@ -1,8 +1,8 @@ -@namespace "topIndex"; +@st-namespace "topIndex"; :import { -st-from: "./button.st.css"; -st-default: Button; } -Button {} \ No newline at end of file +Button {} diff --git a/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/index.st.css b/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/index.st.css index c4b8389733..3800a2c6c0 100644 --- a/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/index.st.css +++ b/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/index.st.css @@ -1,4 +1,5 @@ -@namespace "compsIndex"; +@st-namespace "compsIndex"; + :import { -st-from: "test-components-deep/button.st.css"; -st-default: Button; @@ -8,4 +9,4 @@ Button {} .root { -st-mixin: Button; -} \ No newline at end of file +} diff --git a/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/node_modules/test-components-deep/button.st.css b/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/node_modules/test-components-deep/button.st.css index 8f6f03e310..26aed7c25a 100644 --- a/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/node_modules/test-components-deep/button.st.css +++ b/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/node_modules/test-components-deep/button.st.css @@ -1,8 +1,9 @@ -@namespace "deepBtn"; +@st-namespace "deepBtn"; .root { background: green; } + .text { color: blue; -} \ No newline at end of file +} diff --git a/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/node_modules/test-components-deep/index.st.css b/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/node_modules/test-components-deep/index.st.css index 0fd5038a43..8c689a5e13 100644 --- a/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/node_modules/test-components-deep/index.st.css +++ b/packages/webpack-plugin/test/e2e/projects/4th-party-project/node_modules/test-components/node_modules/test-components-deep/index.st.css @@ -1,8 +1,8 @@ -@namespace "deepIndex"; +@st-namespace "deepIndex"; :import { -st-from: "./button.st.css"; -st-default: Button; } -Button {} \ No newline at end of file +Button {} diff --git a/packages/webpack-plugin/test/e2e/projects/browser-field/node_modules/test-components/cjs/button.st.css b/packages/webpack-plugin/test/e2e/projects/browser-field/node_modules/test-components/cjs/button.st.css index d518f58ec0..b7cc949e0f 100644 --- a/packages/webpack-plugin/test/e2e/projects/browser-field/node_modules/test-components/cjs/button.st.css +++ b/packages/webpack-plugin/test/e2e/projects/browser-field/node_modules/test-components/cjs/button.st.css @@ -1,4 +1,4 @@ -@namespace "cjs"; +@st-namespace "cjs"; .root { background: red; diff --git a/packages/webpack-plugin/test/e2e/projects/browser-field/node_modules/test-components/esm/button.st.css b/packages/webpack-plugin/test/e2e/projects/browser-field/node_modules/test-components/esm/button.st.css index 2d2949da69..6cbee8c0df 100644 --- a/packages/webpack-plugin/test/e2e/projects/browser-field/node_modules/test-components/esm/button.st.css +++ b/packages/webpack-plugin/test/e2e/projects/browser-field/node_modules/test-components/esm/button.st.css @@ -1,4 +1,4 @@ -@namespace "esm"; +@st-namespace "esm"; .root { background: green; diff --git a/packages/webpack-plugin/test/e2e/projects/native-css/src/external.css b/packages/webpack-plugin/test/e2e/projects/native-css/src/external.css new file mode 100644 index 0000000000..2c552e2690 --- /dev/null +++ b/packages/webpack-plugin/test/e2e/projects/native-css/src/external.css @@ -0,0 +1,3 @@ +.added-to-webpack-entry { + color: purple; +} diff --git a/packages/webpack-plugin/test/e2e/projects/native-css/webpack.config.js b/packages/webpack-plugin/test/e2e/projects/native-css/webpack.config.js index fecdc4cff4..22d2a1b545 100644 --- a/packages/webpack-plugin/test/e2e/projects/native-css/webpack.config.js +++ b/packages/webpack-plugin/test/e2e/projects/native-css/webpack.config.js @@ -4,6 +4,7 @@ const HtmlWebpackPlugin = require('html-webpack-plugin'); /** @type {import('webpack').Configuration} */ module.exports = { + entry: ['./src/external.css', './src/index.js'], mode: 'development', context: __dirname, devtool: 'source-map', @@ -23,4 +24,14 @@ module.exports = { }), new HtmlWebpackPlugin(), ], + /*JUST TO TEST THAT AN EXTERNAL ENTRY CSS IS SAFE TO USE */ + module: { + rules: [ + { + test: /\.css$/i, + exclude: /\.st\.css?/, + use: ['css-loader'], + }, + ], + }, }; diff --git a/packages/webpack-plugin/test/e2e/projects/simplest-project-target-node/node_modules/comp-lib/index.cjs.st.css b/packages/webpack-plugin/test/e2e/projects/simplest-project-target-node/node_modules/comp-lib/index.cjs.st.css index 79625d7c68..6a9ed70541 100644 --- a/packages/webpack-plugin/test/e2e/projects/simplest-project-target-node/node_modules/comp-lib/index.cjs.st.css +++ b/packages/webpack-plugin/test/e2e/projects/simplest-project-target-node/node_modules/comp-lib/index.cjs.st.css @@ -1,4 +1,4 @@ -@namespace "Index"; +@st-namespace "Index"; :vars { kind: cjs; diff --git a/packages/webpack-plugin/test/e2e/projects/simplest-project-target-node/node_modules/comp-lib/index.es.st.css b/packages/webpack-plugin/test/e2e/projects/simplest-project-target-node/node_modules/comp-lib/index.es.st.css index 1bb5feae0b..f21af64d97 100644 --- a/packages/webpack-plugin/test/e2e/projects/simplest-project-target-node/node_modules/comp-lib/index.es.st.css +++ b/packages/webpack-plugin/test/e2e/projects/simplest-project-target-node/node_modules/comp-lib/index.es.st.css @@ -1,4 +1,4 @@ -@namespace "Index"; +@st-namespace "Index"; :vars { kind: esm; diff --git a/pleb.config.mjs b/pleb.config.mjs index 6cb4efc595..4e994f1967 100644 --- a/pleb.config.mjs +++ b/pleb.config.mjs @@ -1,3 +1,40 @@ export default { - // pinnedPackages: [{ name: 'name', reason: 'reason' }], + pinnedPackages: [ + { + name: '@typescript-eslint/eslint-plugin', + reason: 'drop node 14 and type issues with ESLintUtils.RuleCreator', + }, + { + name: '@typescript-eslint/parser', + reason: 'drop node 14 and type issues with ESLintUtils.RuleCreator', + }, + { + name: '@typescript-eslint/utils', + reason: 'drop node 14 and type issues with ESLintUtils.RuleCreator', + }, + { + name: '@wixc3/resolve-directory-context', + reason: 'drop node 14', + }, + { + name: 'balanced-match', + reason: 'esm only', + }, + { + name: 'flat', + reason: 'esm only', + }, + { + name: 'chai', + reason: 'version 5 is esm only', + }, + { + name: 'postcss-safe-parser', + reason: 'version 7 removed support for node 16/14/12', + }, + { + name: 'mime', + reason: 'version 4 is esm only & removed support for node < 18', + }, + ], }; diff --git a/scripts/build.js b/scripts/build.js new file mode 100644 index 0000000000..94dabdf47b --- /dev/null +++ b/scripts/build.js @@ -0,0 +1,73 @@ +// @ts-check + +const fs = require('node:fs'); +const path = require('node:path'); +const esbuild = require('esbuild'); + +const packagesRoot = path.join(__dirname, '..', 'packages'); + +buildPureEsmRuntime(); +buildCoreLib(); +/** + * duplicate the pure.js file from the dist folder in to a .mjs file + */ +function buildPureEsmRuntime() { + const projectRoot = path.join(packagesRoot, 'runtime'); + + const pureJs = path.join(projectRoot, 'dist', 'pure.js'); + const pureMjs = path.join(projectRoot, 'dist', 'pure.mjs'); + + fs.copyFileSync(pureJs, pureMjs); +} + +function buildCoreLib() { + const coreRoot = path.join(packagesRoot, 'core'); + // bundle({ + // absWorkingDir: coreRoot, + // format: 'iife', + // outfile: `./dist/lib.js`, + // globalName: 'StylableCore', + // }); + bundle({ + absWorkingDir: coreRoot, + format: 'cjs', + outfile: `./dist/lib.cjs`, + }); + bundle({ + absWorkingDir: coreRoot, + format: 'esm', + outfile: `./dist/lib.mjs`, + }); +} +function bundle(options) { + esbuild + .build({ + entryPoints: ['./src/index.ts'], + bundle: true, + platform: 'browser', + sourcemap: true, + minify: true, + write: true, + alias: { + path: '@file-services/path', + // remove after moving the defaultResolver from core + 'enhanced-resolve/lib/ResolverFactory.js': path.join( + options.absWorkingDir, + 'src', + 'enhanced-resolve-alias.ts' + ), + }, + ...options, + }) + .then(({ errors, warnings }) => { + if (errors.length || warnings.length) { + console.error('build errors', errors); + console.warn('build warnings', warnings); + process.exitCode = 1; + } + }) + .catch((e) => { + console.error(e); + process.exitCode = 1; + }); +} diff --git a/tsconfig.base.json b/tsconfig.base.json index 341e3e11fc..2133fd1677 100644 --- a/tsconfig.base.json +++ b/tsconfig.base.json @@ -105,6 +105,6 @@ /* Completeness */ // "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */ - // "skipLibCheck": true /* Skip type checking all .d.ts files. */ + "skipLibCheck": true /* Skip type checking all .d.ts files. */ } }